exams.js 29 KB

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