exams.js 26 KB

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