Browse Source

[新建]考官阅卷首页面搭建

master
chenjingyu 4 years ago
parent
commit
5f75d202ab
  1. 22
      src/app/examiner/examiner-index/examiner-index.component.html
  2. 53
      src/app/examiner/examiner-index/examiner-index.component.ts
  3. 6
      src/app/examiner/examiner-routing.ts
  4. 3
      src/app/examiner/examiner.module.ts
  5. 55
      src/app/examiner/mark-papers-index/mark-papers-index.component.html
  6. 95
      src/app/examiner/mark-papers-index/mark-papers-index.component.scss
  7. 25
      src/app/examiner/mark-papers-index/mark-papers-index.component.spec.ts
  8. 40
      src/app/examiner/mark-papers-index/mark-papers-index.component.ts
  9. 4
      src/app/navigation/navigation.component.html

22
src/app/examiner/examiner-index/examiner-index.component.html

@ -4,14 +4,14 @@
* @Author: sueRimn * @Author: sueRimn
* @Date: 2020-12-11 09:06:03 * @Date: 2020-12-11 09:06:03
* @LastEditors: sueRimn * @LastEditors: sueRimn
* @LastEditTime: 2020-12-14 14:22:11 * @LastEditTime: 2020-12-14 15:59:51
--> -->
<div class="content"> <div class="content">
<div class="header"> <div class="header">
<div class="queryBox"> <div class="queryBox">
<div class="queryField"> <div class="queryField">
<label style="margin-right: 10px;font-size: 18px;">消防救援站:</label> <label style="margin-right: 10px;font-size: 18px;">消防救援站:</label>
<input list="cars" placeholder="请输入用户账号"/> <input list="cars" placeholder="请输入用户账号" [(ngModel)]="accound" />
<datalist id="cars"> <datalist id="cars">
<option value="admin"> <option value="admin">
<option value="surper"> <option value="surper">
@ -19,8 +19,8 @@
</datalist> </datalist>
</div> </div>
<div class="queryField"> <div class="queryField">
<button style="background-color: #07CDCF;">查询</button> <button style="background-color: #07CDCF;" (click)="findClick()">查询</button>
<button style="margin-left: 10px; background-color: #FF8678;">重置</button> <button style="margin-left: 10px; background-color: #FF8678;" (click)="Reset()">重置</button>
</div> </div>
<div class="queryField" style="margin-left: 720px;"> <div class="queryField" style="margin-left: 720px;">
<button style="background-color: #07CDCF;" (click)="newExamination()"><img style="position: relative;top: 3px;" src="../../../assets/images/add.png"> 新增考题</button> <button style="background-color: #07CDCF;" (click)="newExamination()"><img style="position: relative;top: 3px;" src="../../../assets/images/add.png"> 新增考题</button>
@ -36,7 +36,7 @@
</table> --> </table> -->
<table> <table >
<thead> <thead>
<th style="width: 15%;">试卷名称</th> <th style="width: 15%;">试卷名称</th>
<th style="width: 15%;">考核中队</th> <th style="width: 15%;">考核中队</th>
@ -55,15 +55,17 @@
<td> <td>
<span style="color: #07CDCF;margin-right: 10px;">编辑</span> <span style="color: #07CDCF;margin-right: 10px;">编辑</span>
<span style="color: #07CDCF;">详情</span> <span style="color: #07CDCF;">详情</span>
<span *ngIf="item.testState=='未开考'" style="color: #FF8678;margin-left: 10px;">删除</span> <span *ngIf="item.testState=='未开考'" style="color: #FF8678;margin-left: 10px;cursor: pointer;">删除</span>
</td> </td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
<mat-paginator [length]="10" <mat-paginator [length]="length"
[pageSize]="10" [pageSize]="pageSize"
[pageSizeOptions]="[10]"> [pageSizeOptions]="pageSizeOptions"
</mat-paginator> (page)="chagePage($event)">
</mat-paginator>
</div> </div>
</div> </div>

53
src/app/examiner/examiner-index/examiner-index.component.ts

@ -4,7 +4,7 @@
* @Author: sueRimn * @Author: sueRimn
* @Date: 2020-12-11 09:06:03 * @Date: 2020-12-11 09:06:03
* @LastEditors: sueRimn * @LastEditors: sueRimn
* @LastEditTime: 2020-12-11 19:38:25 * @LastEditTime: 2020-12-14 16:44:42
*/ */
import { Component, OnInit, ViewChild, Inject } from '@angular/core'; import { Component, OnInit, ViewChild, Inject } from '@angular/core';
import {HttpClient} from '@angular/common/http' import {HttpClient} from '@angular/common/http'
@ -35,11 +35,58 @@ const ELEMENT_DATA = [
export class ExaminerIndexComponent implements OnInit { export class ExaminerIndexComponent implements OnInit {
constructor(private router: Router,private activatedRoute: ActivatedRoute,public http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar) { } constructor(private router: Router,private activatedRoute: ActivatedRoute,public http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar) { }
displayedColumns: string[] = ['name', 'organization', 'startTime', 'overTime', 'testState', 'operation']; //displayedColumns: string[] = ['name', 'organization', 'startTime', 'overTime', 'testState', 'operation'];
dataSource = ELEMENT_DATA; dataSource = ELEMENT_DATA;
ngOnInit(): void { ngOnInit(): void {
//this.getAlltabledate()
}
displayedColumns: string[] = ['name','startTime','endTime', 'examzhong','scc'];
tabledataSource:any
accound
//分页
@ViewChild(MatPaginator, {static: true})
pageEvent: PageEvent;
paginator: MatPaginator;
length:any; //共多少条数据
pageSize:any; //每页条数
pageSizeOptions: number[] = [10] //设置每页条数
PageNumber:any //第几页
//分页事件
chagePage(e){
this.PageNumber = e.pageIndex+1
//this.getAllKeyUnit();
}
//获取表格信息
getAlltabledate(){
let paramsdata:any = {
PageNumber: this.PageNumber || '1',
PageSize: this.pageSizeOptions[0],
Sort: null,
SortType: null,
}
//console.log(paramsdata)
this.http.get("/api/Papers",{params:paramsdata}).subscribe((data:any)=>{
console.log(data)
})
//console.log(this.tabledataSource)
}
//查询按钮
findClick(){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
if(this.accound==undefined){
this.snackBar.open('请输入消防救援队名称','确定',config);
}
console.log(this.accound)
}
//重置按钮
Reset(){
this.accound=undefined
} }
//新增考题跳转 //新增考题跳转
newExamination(){ newExamination(){

6
src/app/examiner/examiner-routing.ts

@ -4,17 +4,19 @@
* @Author: sueRimn * @Author: sueRimn
* @Date: 2020-12-10 12:11:26 * @Date: 2020-12-10 12:11:26
* @LastEditors: sueRimn * @LastEditors: sueRimn
* @LastEditTime: 2020-12-12 09:16:04 * @LastEditTime: 2020-12-14 16:33:04
*/ */
import { Routes, RouterModule } from '@angular/router'; import { Routes, RouterModule } from '@angular/router';
import { NgModule } from '@angular/core'; import { NgModule } from '@angular/core';
import { ExaminerIndexComponent } from './examiner-index/examiner-index.component' import { ExaminerIndexComponent } from './examiner-index/examiner-index.component'
import { ExaminerNewOneComponent} from './examiner-new-one/examiner-new-one.component' import { ExaminerNewOneComponent} from './examiner-new-one/examiner-new-one.component'
import { MarkPapersIndexComponent} from './mark-papers-index/mark-papers-index.component'
const routes: Routes = [ const routes: Routes = [
// { path: '', component:CreateExamComponent } // { path: '', component:CreateExamComponent }
{ path: 'createexam-index', component:ExaminerIndexComponent }, { path: 'createexam-index', component:ExaminerIndexComponent },
{ path: 'examiner-new-one', component:ExaminerNewOneComponent } { path: 'examiner-new-one', component:ExaminerNewOneComponent },
{ path: 'mark-papers-index',component:MarkPapersIndexComponent}
//{ path: 'createexam-index', component:ExaminerIndexComponent }, //{ path: 'createexam-index', component:ExaminerIndexComponent },
] ]

3
src/app/examiner/examiner.module.ts

@ -52,9 +52,10 @@ import { NzTreeModule } from 'ng-zorro-antd/tree';
import { ExaminerIndexComponent } from './examiner-index/examiner-index.component'; import { ExaminerIndexComponent } from './examiner-index/examiner-index.component';
import { ExaminerNewOneComponent } from './examiner-new-one/examiner-new-one.component'; import { ExaminerNewOneComponent } from './examiner-new-one/examiner-new-one.component';
import { NzDatePickerModule } from 'ng-zorro-antd/date-picker'; import { NzDatePickerModule } from 'ng-zorro-antd/date-picker';
import { MarkPapersIndexComponent } from './mark-papers-index/mark-papers-index.component';
@NgModule({ @NgModule({
declarations: [CreateTestScoreComponent,AddPlanDialog,AddPlanTwoDialog,LookTreeNodeDialog,ExaminerIndexComponent, ExaminerNewOneComponent,FinishDialog], declarations: [CreateTestScoreComponent,AddPlanDialog,AddPlanTwoDialog,LookTreeNodeDialog,ExaminerIndexComponent, ExaminerNewOneComponent,FinishDialog, MarkPapersIndexComponent],
imports: [ imports: [
CommonModule, CommonModule,
examinerRoutingModule, examinerRoutingModule,

55
src/app/examiner/mark-papers-index/mark-papers-index.component.html

@ -0,0 +1,55 @@
<!--
* @Descripttion:
* @version:
* @Author: sueRimn
* @Date: 2020-12-14 16:30:31
* @LastEditors: sueRimn
* @LastEditTime: 2020-12-14 16:57:25
-->
<div class="content">
<div class="header">
<div class="queryBox">
<div class="queryField">
<label style="margin-right: 10px;font-size: 18px;">试卷名称:</label>
<input type="text" placeholder="请输入试卷名称" style="font-size: 16px;" [(ngModel)]="markName"/>
</div>
<div class="queryField">
<label style="margin-right: 10px;font-size: 18px;">考试日期:</label>
<input type="date" placeholder="请输入考试日期" style="font-size: 16px;" [(ngModel)]="markDate"/>
</div>
<div class="queryField">
<button style="background-color: #07CDCF;" >查询</button>
<button style="margin-left: 10px; background-color: #FF8678;" (click)="resert()">重置</button>
</div>
</div>
</div>
<div class="centertable">
<table >
<thead>
<th style="width: 15%;">试卷名称</th>
<th style="width: 15%;">考核中队</th>
<th style="width: 15%;">开始时间</th>
<th style="width: 15%;">结束时间</th>
<th style="width: 20%;">操作</th>
</thead>
<tbody>
<tr *ngFor="let item of dataSource">
<td>{{item.name}}</td>
<td>{{item.organization}}</td>
<td>{{item.startTime}}</td>
<td>{{item.overTime}}</td>
<td>
<span style="color: #07CDCF;cursor: pointer;">阅卷</span>
</td>
</tr>
</tbody>
</table>
<mat-paginator [length]="100"
[pageSize]="10"
[pageSizeOptions]="[10]">
</mat-paginator>
</div>
</div>

95
src/app/examiner/mark-papers-index/mark-papers-index.component.scss

@ -0,0 +1,95 @@
table {
width: 100%;
text-align: center;
.cdk-header-cell {
text-align: center;
}
}
.content {
width: 100%;
height: 100%;
overflow: hidden;
background: #F2F5F6;
overflow-y: auto;
}
.header {
width: 100%;
padding: 10px;
margin-bottom: 10px;
box-sizing: border-box;
.queryBox {
box-sizing: border-box;
padding: 5px 15px;
display: flex;
flex-direction: row;
flex-wrap: wrap;
align-items:center;
justify-content:left;
.queryField {
margin: 0 25px;
font-size: 14px;
input {
width: 320px;
height: 44px;
line-height: 34px;
border-radius: 5px;
padding-left: 5px;
outline: none;
border: 1px solid rgb(226, 211, 211);
}
button {
border: none;
color: white;
padding: 10px 25px;
text-align: center;
text-decoration: none;
display: inline-block;
font-size: 16px;
margin: 4px 2px;
cursor: pointer;
border-radius: 8px;
outline:0 none !important;
}
}
.headerright{
float: right;
}
} //queryBox
}
.centertable{
width: 95%;
margin-right: 40px;
margin-left: 40px;
background-color: #FFFFFF;
table{
td,th{
height: 48px;
font-size: 16px;
}
td{
border-bottom: 1px solid #F2F5F6;
}
thead{
background-color:#F5FDFE;
}
.green{
color: #07CDCF;
}
.red{
color: #FF8678;
}
}
}
.operationSpan{
margin: 0 10px;
.spanbtn {
font-weight: 550;
cursor: pointer;
}
.green{ color: #04ced1; }
.red{ color: #FF8678 }
.gray{ color: gray; }
}

25
src/app/examiner/mark-papers-index/mark-papers-index.component.spec.ts

@ -0,0 +1,25 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { MarkPapersIndexComponent } from './mark-papers-index.component';
describe('MarkPapersIndexComponent', () => {
let component: MarkPapersIndexComponent;
let fixture: ComponentFixture<MarkPapersIndexComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ MarkPapersIndexComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(MarkPapersIndexComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

40
src/app/examiner/mark-papers-index/mark-papers-index.component.ts

@ -0,0 +1,40 @@
import { Component, OnInit, ViewChild, Inject } from '@angular/core';
import {HttpClient} from '@angular/common/http'
import { MatDialogRef, MatDialog, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { MatPaginator } from '@angular/material/paginator';
import { MatTableDataSource } from '@angular/material/table';
import { PageEvent } from '@angular/material/paginator';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import {FormControl} from '@angular/forms';
import { Router,ActivatedRoute } from '@angular/router';
const ELEMENT_DATA = [
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'未开考'},
{name: "富华酒店", organization: '黄埔支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'未开考'},
{name: "雁山园", organization: '徐汇支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'开考中'},
{name: "富华酒店", organization: '普陀支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'开考中'},
{name: "立新加油站", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'开考中'},
{name: "富华酒店", organization: '宝山支队', startTime: "2020-07-19 10:00", overTime: '2020-07-19 12:00',testState:'已结束'},
{name: "裕达国际酒店", organization: '浦东支队', startTime: "2020-08-19 10:00", overTime: '2020-08-19 12:00',testState:'已结束'},
{name: "锦德大酒店", organization: '长宁支队', startTime: "2019-09-19 10:00", overTime: '2019-09-19 12:00',testState:'已结束'},
];
@Component({
selector: 'app-mark-papers-index',
templateUrl: './mark-papers-index.component.html',
styleUrls: ['./mark-papers-index.component.scss']
})
export class MarkPapersIndexComponent implements OnInit {
constructor(private router: Router,private activatedRoute: ActivatedRoute,public http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar) { }
ngOnInit(): void {
}
dataSource = ELEMENT_DATA;
markName//试卷名称
markDate//考试日期
resert(){
this.markName=undefined
this.markDate=undefined
}
}

4
src/app/navigation/navigation.component.html

@ -4,7 +4,7 @@
* @Author: sueRimn * @Author: sueRimn
* @Date: 2020-12-10 10:21:40 * @Date: 2020-12-10 10:21:40
* @LastEditors: sueRimn * @LastEditors: sueRimn
* @LastEditTime: 2020-12-11 10:26:25 * @LastEditTime: 2020-12-14 16:33:43
--> -->
<mat-sidenav-container class="example-container" autosize [class.myapp-dark-theme]="darktheme"> <mat-sidenav-container class="example-container" autosize [class.myapp-dark-theme]="darktheme">
@ -25,7 +25,7 @@
<div class="navbox"> <div class="navbox">
<ul class="teacher"> <ul class="teacher">
<li [routerLink]="['createexam-index']" routerLinkActive="router-link-active" ><div (click)="clickLeftmenu('found')" [ngClass]="{'clickStyle': leftMenuname=='found'}"><img src="../../assets/images/found.png" style="background-color: #FFFFFF;"> 创建考试</div></li> <li [routerLink]="['createexam-index']" routerLinkActive="router-link-active" ><div (click)="clickLeftmenu('found')" [ngClass]="{'clickStyle': leftMenuname=='found'}"><img src="../../assets/images/found.png" style="background-color: #FFFFFF;"> 创建考试</div></li>
<li [routerLink]="['createexam-index']" routerLinkActive="router-link-active" ><div (click)="clickLeftmenu('papers')" [ngClass]="{'clickStyle': leftMenuname=='papers'}"><img src="../../assets/images/papers.png" style="position: relative;right: 20px;background-color: #07CDCF;"> 阅卷</div></li> <li [routerLink]="['mark-papers-index']" routerLinkActive="router-link-active" ><div (click)="clickLeftmenu('papers')" [ngClass]="{'clickStyle': leftMenuname=='papers'}"><img src="../../assets/images/papers.png" style="position: relative;right: 20px;background-color: #07CDCF;"> 阅卷</div></li>
<li [routerLink]="['createexam-index']" routerLinkActive="router-link-active" ><div (click)="clickLeftmenu('Statistics')" [ngClass]="{'clickStyle': leftMenuname=='Statistics'}"><img src="../../assets/images/Statistics.png" style="background-color: #07CDCF;"> 统计分析</div></li> <li [routerLink]="['createexam-index']" routerLinkActive="router-link-active" ><div (click)="clickLeftmenu('Statistics')" [ngClass]="{'clickStyle': leftMenuname=='Statistics'}"><img src="../../assets/images/Statistics.png" style="background-color: #07CDCF;"> 统计分析</div></li>
</ul> </ul>
<img style="width: 191px;height: 113px; position: absolute; bottom: 0;" src="../../assets/images/backbottom.png"> <img style="width: 191px;height: 113px; position: absolute; bottom: 0;" src="../../assets/images/backbottom.png">

Loading…
Cancel
Save