exams.js 26 KB

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