exams.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form','editable'], function ($, undefined, Backend, Table, Form,editable) {
  2. var Controller = {
  3. index: function () {
  4. $('.btn-edit').data('area',['70%','95%']);
  5. // 初始化表格参数配置
  6. Table.api.init({
  7. extend: {
  8. index_url: 'teacher/exams/index' + location.search,
  9. add_url: 'teacher/exams/add',
  10. edit_url: 'teacher/exams/edit',
  11. del_url: 'teacher/exams/del',
  12. multi_url: 'teacher/exams/multi',
  13. import_url: 'teacher/exams/import',
  14. table: 'teacher_exams',
  15. }
  16. });
  17. var table = $("#table");
  18. table.on('load-success.bs.table', function (e, data) {
  19. //这里可以获取从服务端获取的JSON数据
  20. //这里我们手动设置顶部的企业总数
  21. $(".pingfen_total").text(data.defen.pingfen);
  22. $(".max_total").text(data.defen.max);
  23. $(".min_total").text(data.defen.min);
  24. var task_tr = '';
  25. // console.log(data.tongji.one_static.length+'###')
  26. for (i=0;i<data.tongji.one_static.length;++i){
  27. var one_data = data.tongji.one_static[i];
  28. // console.log(one_data+[i]);
  29. var epercent = '';
  30. if(one_data.epercent!='undefined' && one_data.epercent != undefined){
  31. epercent = one_data.epercent;
  32. }
  33. task_tr += '<tr style="text-align: center">';
  34. task_tr += ' <td>'+one_data.name+'</td>';
  35. task_tr += ' <td>'+epercent+'</td>';
  36. task_tr += '</tr>';
  37. $(".tbodyone").html(task_tr);
  38. }
  39. var task_tr = '';
  40. for (j=0;j<data.tongji.two_static.length;++j){
  41. var two_data = data.tongji.two_static[j];
  42. var epercent = '';
  43. if(two_data.epercent!='undefined' && two_data.epercent != undefined){
  44. epercent = two_data.epercent;
  45. }
  46. task_tr += '<tr style="text-align: center">';
  47. task_tr += ' <td>'+two_data.name+'</td>';
  48. task_tr += ' <td>'+epercent+'</td>';
  49. task_tr += '</tr>';
  50. $(".tbodytwo").html(task_tr);
  51. }
  52. var task_tr = '';
  53. for (k=0;k<data.tongji.three_static.length;++k){
  54. var three_data = data.tongji.three_static[k];
  55. var epercent = '';
  56. if(three_data.epercent!='undefined' && three_data.epercent != undefined){
  57. epercent = three_data.epercent;
  58. }
  59. task_tr += '<tr style="text-align: center">';
  60. task_tr += ' <td>'+three_data.name+'</td>';
  61. task_tr += ' <td>'+epercent+'</td>';
  62. task_tr += '</tr>';
  63. $(".tbodythree").html(task_tr);
  64. }
  65. });
  66. // 初始化表格
  67. table.bootstrapTable({
  68. url: $.fn.bootstrapTable.defaults.extend.index_url,
  69. pk: 'exam_id',
  70. sortName: 'exam_id',
  71. fixedColumns: true,
  72. fixedRightNumber: 1,
  73. searchFormVisible:true,
  74. // singleSelect : true, //
  75. search:false,
  76. showExport:false,
  77. showToggle:false,
  78. showColumns: false,
  79. columns: [
  80. [
  81. {checkbox: true},
  82. {field: 'user_username', title: __('学号'),operate: 'like'},
  83. {field: 'user_nickname', title: __('姓名'),operate: 'like'},
  84. // {field: 'exam_status', title: __('Exam_status'),searchList: {"0":"未登录","1":"已登录","2":"模拟器检查并下发故障中","3":"模拟器正常","4":"答题中","5":"已交卷","6":"计算成绩中","7":"获取到成绩报告","80":"教员标记缺考","81":"登录未开始答题","90":"模拟器异常结束"},formatter: Table.api.formatter.simexamstatus},
  85. {field: 'exam_collection_name', title: __('考试名称'),operate: 'like'},
  86. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  87. {
  88. field: 'user_depart_id',
  89. title: __('区队'),
  90. visible: false,
  91. addclass: 'selectpage',
  92. extend: 'data-source="department/index/index" data-field="name"',
  93. operate: Config.groupIds !=8 ? 'in':false,
  94. formatter:function (value, row, index) {
  95. return value.toString().replace(/(&|&amp;)nbsp;/g, '&nbsp;');
  96. }
  97. // formatter: Table.api.formatter.search
  98. },
  99. // {field: 'name', title: __('Name'), align: 'left', formatter:function (value, row, index) {
  100. // return value.toString().replace(/(&|&amp;)nbsp;/g, '&nbsp;');
  101. // }
  102. // },
  103. {field: 'task_id', title: __('训练任务'),visible:false,
  104. operate:'=',
  105. searchList: $.getJSON("teacher/task/selectlist")
  106. },
  107. {field: 'total_score', title: __('Total_score'),operate:false},
  108. {field: 'exam_duration', title: __('考试时长(秒)'),operate: "between",visible:false},
  109. {field: 'exam_duration_text', title: __('考试时长'),operate: false},
  110. {field: 'starttime', title: __('开始考试时间'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
  111. {field: 'endtime', title: __('交卷时间'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
  112. // {field: 'endtime', title: __('End_time'), formatter: Table.api.formatter.datetime, operate: false, addclass: 'datetimerange', sortable: true},
  113. // {field: 'login_time', title: __('Login_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  114. // {field: 'logout_time', title: __('Logout_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  115. {field: 'is_sure', title: __('成绩确认'),operate: '=',searchList:{"1":"已确认","0":"未确认"},
  116. formatter: function(value, row,index) {
  117. if(value==0){
  118. return '<span class="text-warning">未确认</span>';
  119. }else if(value==1){
  120. return '<span class="text-success">已确认</span>';
  121. }
  122. }
  123. },
  124. // {field: 'createtime', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  125. // {field: 'update_by', title: __('Update_by'), operate: 'LIKE'},
  126. // {field: 'update_time', title: __('Update_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  127. // {field: 'remark', title: __('Remark'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  128. {field: 'operate', title: __('Operate'), table: table,
  129. events: Table.api.events.operate,
  130. // formatter: Table.api.formatter.operate
  131. formatter: Table.api.formatter.buttons,
  132. buttons: [
  133. {
  134. name: 'dispatch',
  135. text: '编辑',
  136. icon: 'fa fa-pencil',
  137. title: '编辑',
  138. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  139. extend: 'data-area=\'["70%","95%"]\'',
  140. url: 'teacher/exams/edit',
  141. },
  142. {
  143. name: 'dispatch',
  144. text: '成绩详情',
  145. icon: 'fa fa-eye',
  146. title: '成绩详情',
  147. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  148. extend: 'data-area=\'["70%","95%"]\'',
  149. url: 'teacher/exams/view',
  150. }
  151. ],
  152. }
  153. ]
  154. ],
  155. // onCheck: function (row, $element) {
  156. // console.log('选中了')
  157. // },
  158. // onUncheck: function (row) {
  159. // console.log('取消选中')
  160. // },
  161. // onCheckAll:function (row){
  162. // // $(".btn-bianji").removeClass('btn-edit')
  163. // // $(".btn-bianji").addClass('disabled')
  164. // // $(".btn-chakan").removeClass('btn-view')
  165. // $(".btn-chakan").addClass('disabled')
  166. // $(".btn-chakan").addClass('btn-disabled')
  167. // },
  168. // onUncheckAll:function (row){
  169. // $(".btn-bianji").addClass('btn-edit')
  170. // $(".btn-chakan").addClass('btn-view')
  171. // }
  172. });
  173. // 为表格绑定事件
  174. Table.api.bindevent(table);
  175. $(document).on('click', '.btn-view', function () {
  176. var ids = Table.api.selectedids(table);
  177. var title = '成绩详情';
  178. Fast.api.open(Fast.api.fixurl("teacher/exams/view/ids/"+ids), title, { area: ["75%", "95%"] });
  179. });
  180. //导出
  181. $(document).on("click", ".btn-export", function () {
  182. var parenttable = table.closest('.bootstrap-table');
  183. var options = table.bootstrapTable('getOptions');
  184. var toolbar = $(options.toolbar, parenttable);
  185. // 导出
  186. var options = table.bootstrapTable('getOptions');
  187. var search = options.queryParams({});
  188. var filter = JSON.parse(search.filter);
  189. var op = JSON.parse(search.op);
  190. url = '/admin/teacher/exams/export';
  191. if(url){
  192. window.open(url+ '?filter='+JSON.stringify(filter)+'&op='+JSON.stringify(op));
  193. }
  194. });
  195. },
  196. persent: function () {
  197. Table.api.init({
  198. extend: {
  199. index_url: 'teacher/exams/persent/ids/'+Config.ids + location.search,
  200. edit_url: 'teacher/exams/editscore',
  201. indexed_url: 'teacher/exams/examing/ids/'+Config.ids + location.search,
  202. score_url: 'teacher/exams/score/ids/'+Config.ids + location.search,
  203. table: 'teacher_exams',
  204. }
  205. });
  206. var table = $("#table");
  207. // 初始化表格
  208. table.bootstrapTable({
  209. url: $.fn.bootstrapTable.defaults.extend.index_url,
  210. pk: 'rel_id',
  211. sortName: 'rel_id',
  212. toolbar: '#toolbar',
  213. fixedColumns: true,
  214. fixedRightNumber: 1,
  215. searchFormVisible:false,
  216. showExport:false,
  217. search:false,
  218. showExport:false,
  219. showToggle:false,
  220. showColumns: false,
  221. columns: [
  222. [
  223. // {checkbox: true},
  224. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  225. {field: 'fault_name', title: __('更换件')},
  226. {field: 'create_by', title: __('学员姓名')},
  227. {field: 'request_status', title: __('状态'),
  228. formatter: function(value, row,index) {
  229. if(value==1){
  230. return '<span class="text-warning">待处理</span>';
  231. }else if(value==2){
  232. return '<span class="text-success">已送</span>';
  233. }else if(value==3){
  234. return '<span class="text-danger">已驳回</span>';
  235. }
  236. }
  237. },
  238. {field: 'createtime', title: __('申请时间'), formatter: Table.api.formatter.datetime, operate: false, addclass: 'datetimerange', sortable: true},
  239. {field: 'operate', title: __('Operate'), table: table,
  240. events: Table.api.events.operate,
  241. // formatter: Table.api.formatter.operate
  242. formatter: Table.api.formatter.buttons,
  243. buttons: [
  244. {
  245. name: 'dispatch',
  246. text: '已送',
  247. icon: 'fa fa-check',
  248. title: '已送',
  249. classname: 'btn btn-success btn-xs btn-magic btn-ajax',
  250. url: 'teacher/exams/handle/type/1',
  251. visible: function (rr) {
  252. if(rr.request_status == 1 || rr.request_status == 0){
  253. return true;
  254. }
  255. return false;
  256. },
  257. success: function (data, ret) {
  258. table.bootstrapTable("refresh");
  259. },
  260. },{
  261. name: 'dispatch',
  262. text: '驳回',
  263. icon: 'fa fa-reply-all',
  264. title: '驳回',
  265. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  266. url: 'teacher/exams/handle/type/2',
  267. visible: function (rr) {
  268. if(rr.request_status == 1 || rr.request_status == 0){
  269. return true;
  270. }
  271. return false;
  272. },
  273. success: function (data, ret) {
  274. table.bootstrapTable("refresh");
  275. },
  276. }
  277. ],
  278. }
  279. ]
  280. ]
  281. });
  282. // 为表格绑定事件
  283. Table.api.bindevent(table);
  284. var table1 = $("#table1");
  285. // 初始化表格
  286. table1.bootstrapTable({
  287. url: $.fn.bootstrapTable.defaults.extend.indexed_url,
  288. pk: 'exam_id',
  289. sortName: 'exam_id',
  290. toolbar: '#toolbar1',
  291. fixedColumns: true,
  292. fixedRightNumber: 1,
  293. searchFormVisible:false,
  294. showExport:false,
  295. search:false,
  296. pagination:false,
  297. showExport:false,
  298. showToggle:false,
  299. showColumns: false,
  300. columns: [
  301. [
  302. // {checkbox: true},
  303. {field: 'seat_id', title: __('座号')},
  304. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  305. {field: 'sim_state', title: __('模拟器状态'),
  306. formatter: function(value, row,index) {
  307. // if(value=='在线'){
  308. // return '<span class="text-success">'+value+'</span>';
  309. // }
  310. // if(value=='离线'){
  311. // return '<span class="text-danger">'+value+'</span>';
  312. // }
  313. return '<span class="text-success">'+value+'</span>';
  314. }
  315. },
  316. {field: 'user_username', title: __('学员学号')},
  317. {field: 'user_nickname', title: __('学员姓名')},
  318. {field: 'exam_status', title: __('考试状态'),
  319. formatter: function(value, row,index) {
  320. if(value=='未登录'){
  321. return '<span class="text-danger">'+value+'</span>';
  322. }else if(value=='已登录未开始考试'){
  323. return '<span class="text-warning">'+value+'</span>';
  324. }else if(value=='已开始考试'){
  325. return '<span class="text-info">'+value+'</span>';
  326. }else if(value=='已交卷'){
  327. return '<span class="text-success">'+value+'</span>';
  328. }
  329. }
  330. },
  331. {field: 'total_score', title: __('考试成绩')},
  332. {field: 'fault_names', title: __('出题题目'),formatter: Table.api.formatter.faultname},
  333. // {field: 'xianxiang_names', title: __('故障现象'),formatter: Table.api.formatter.answerName},
  334. // {field: 'yuanyin_names', title: __('可能原因'),formatter: Table.api.formatter.answerName},
  335. // {field: 'buwei_names', title: __('故障部位'),formatter: Table.api.formatter.answerName},
  336. // {field: 'fangfa_names', title: __('排除方法'),formatter: Table.api.formatter.answerName},
  337. {field: 'operate', title: __('Operate'), table: table1,
  338. events: Table.api.events.operate,
  339. // formatter: Table.api.formatter.operate
  340. formatter: Table.api.formatter.buttons,
  341. buttons: [
  342. {
  343. name: 'dispatch',
  344. text: '成绩详情',
  345. icon: 'fa fa-eye',
  346. title: '成绩详情',
  347. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  348. extend: 'data-area=\'["75%","95%"]\'',
  349. visible: function (row) {
  350. if(row.total_score>0){
  351. return true;
  352. }
  353. return false;
  354. },
  355. url: 'teacher/exams/view',
  356. }
  357. ],
  358. }
  359. ]
  360. ]
  361. });
  362. // 为表格绑定事件
  363. Table.api.bindevent(table1);
  364. var table2 = $("#table2");
  365. // 初始化表格
  366. table2.bootstrapTable({
  367. url: $.fn.bootstrapTable.defaults.extend.score_url,
  368. pk: 'exam_id',
  369. sortName: 'exam_id',
  370. toolbar: '#toolbar2',
  371. fixedColumns: true,
  372. pageSize: 10,
  373. pagination:false,
  374. fixedLeftNumber: 4,
  375. searchFormVisible:false,
  376. showExport:false,
  377. search:false,
  378. showExport:false,
  379. showToggle:false,
  380. showColumns: false,
  381. columns: [
  382. [
  383. // {checkbox: true},
  384. {field: 'seat_id', title: __('座号')},
  385. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  386. {field: 'user_username', title: __('学员学号')},
  387. {field: 'user_nickname', title: __('学员姓名')},
  388. {field: 'total', title: __('考试成绩')},
  389. {field: 'fault_one_score', title: __('故障一扣分'),editable:true},
  390. {field: 'fault_two_score', title: __('故障二扣分'),editable:true},
  391. {field: 'fault_three_score', title: __('故障三扣分'),editable:true},
  392. {field: 'xianxian_score', title: __('故障现象扣分'),editable:true},
  393. {field: 'yuanyin_socre', title: __('可能原因扣分'),editable:true},
  394. {field: 'buwei_score', title: __('故障部位扣分'),editable:true},
  395. {field: 'fangfa_score', title: __('排除方法扣分'),editable:true},
  396. {field: 'overtime_score', title: __('超时扣分'),editable:true},
  397. {field: 'operate', title: __('Operate'), table: table1,
  398. events: Table.api.events.operate,
  399. // formatter: Table.api.formatter.operate
  400. formatter: Table.api.formatter.buttons,
  401. buttons: [
  402. {
  403. name: 'dispatch',
  404. text: '成绩详情',
  405. icon: 'fa fa-eye',
  406. title: '成绩详情',
  407. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  408. extend: 'data-area=\'["75%","95%"]\'',
  409. url: 'teacher/exams/view',
  410. }
  411. ],
  412. }
  413. ]
  414. ],
  415. onEditableSave: function (field, row, oldValue, $el) {
  416. var data = {}; //组合更新数据
  417. // data["row[field]"] = field; //字段名
  418. data["row[" + field + "]"] = row[field]; //字段值
  419. // data["row[id]"] = row['id']; //主键
  420. Fast.api.ajax({
  421. url: "teacher/exams/editscore/ids/" + row[this.pk],
  422. data: data
  423. }, function () {
  424. $(".btn-refresh").trigger("click");
  425. });
  426. },
  427. });
  428. // 为表格绑定事件
  429. Table.api.bindevent(table2);
  430. //关闭考试 并且
  431. $(document).on('click', '.btn-closes', function () {
  432. var ids = Config.ids;
  433. $.ajax({
  434. type:'post',
  435. url:'teacher/collection/multi',
  436. data:{ids:ids,params:'exam_collection_state=3'}, //重点必须为一个变量如:data
  437. success:function(data){
  438. if(data.code==1){
  439. Backend.api.closetabs('/admin/teacher/exams/persent/ids/'+Config.ids)
  440. // Backend.api.addtabs('teacher/collection','考试列表');
  441. }
  442. },
  443. error:function(){
  444. layer.alert("操作失败");
  445. return;
  446. }
  447. })
  448. });
  449. $("button[name=commonSearch]").css('display','none');
  450. //定时刷新
  451. setInterval(function() {
  452. table.bootstrapTable('refresh');
  453. table1.bootstrapTable('refresh');
  454. table2.bootstrapTable('refresh');
  455. }, 30000);
  456. },
  457. add: function () {
  458. Controller.api.bindevent();
  459. },
  460. edit: function () {
  461. Controller.api.bindevent();
  462. },
  463. api: {
  464. bindevent: function () {
  465. Form.api.bindevent($("form[role=form]"));
  466. }
  467. }
  468. };
  469. return Controller;
  470. });