exams.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  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: __('成绩确认'), visible:false,operate: '=',searchList:{"1":"已确认","0":"未确认"}},
  116. // {field: 'createtime', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  117. // {field: 'update_by', title: __('Update_by'), operate: 'LIKE'},
  118. // {field: 'update_time', title: __('Update_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  119. // {field: 'remark', title: __('Remark'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  120. {field: 'operate', title: __('Operate'), table: table,
  121. events: Table.api.events.operate,
  122. // formatter: Table.api.formatter.operate
  123. formatter: Table.api.formatter.buttons,
  124. buttons: [
  125. {
  126. name: 'dispatch',
  127. text: '编辑',
  128. icon: 'fa fa-pencil',
  129. title: '编辑',
  130. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  131. extend: 'data-area=\'["70%","95%"]\'',
  132. url: 'teacher/exams/edit',
  133. }
  134. ],
  135. }
  136. ]
  137. ]
  138. });
  139. // 为表格绑定事件
  140. Table.api.bindevent(table);
  141. $(document).on('click', '.btn-view', function () {
  142. var ids = Table.api.selectedids(table);
  143. var title = '成绩详情';
  144. Fast.api.open(Fast.api.fixurl("teacher/exams/view/ids/"+ids), title, { area: ["75%", "95%"] });
  145. });
  146. //导出
  147. $(document).on("click", ".btn-export", function () {
  148. var parenttable = table.closest('.bootstrap-table');
  149. var options = table.bootstrapTable('getOptions');
  150. var toolbar = $(options.toolbar, parenttable);
  151. // 导出
  152. var options = table.bootstrapTable('getOptions');
  153. var search = options.queryParams({});
  154. var filter = JSON.parse(search.filter);
  155. var op = JSON.parse(search.op);
  156. url = '/admin/teacher/exams/export';
  157. if(url){
  158. window.open(url+ '?filter='+JSON.stringify(filter)+'&op='+JSON.stringify(op));
  159. }
  160. });
  161. },
  162. persent: function () {
  163. Table.api.init({
  164. extend: {
  165. index_url: 'teacher/exams/persent/ids/'+Config.ids + location.search,
  166. edit_url: 'teacher/exams/editscore',
  167. indexed_url: 'teacher/exams/examing/ids/'+Config.ids + location.search,
  168. score_url: 'teacher/exams/score/ids/'+Config.ids + location.search,
  169. table: 'teacher_exams',
  170. }
  171. });
  172. var table = $("#table");
  173. // 初始化表格
  174. table.bootstrapTable({
  175. url: $.fn.bootstrapTable.defaults.extend.index_url,
  176. pk: 'rel_id',
  177. sortName: 'rel_id',
  178. toolbar: '#toolbar',
  179. fixedColumns: true,
  180. fixedRightNumber: 1,
  181. searchFormVisible:false,
  182. showExport:false,
  183. search:false,
  184. showExport:false,
  185. showToggle:false,
  186. showColumns: false,
  187. columns: [
  188. [
  189. // {checkbox: true},
  190. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  191. {field: 'fault_name', title: __('更换件')},
  192. {field: 'create_by', title: __('学员姓名')},
  193. {field: 'request_status', title: __('状态'),
  194. formatter: function(value, row,index) {
  195. if(value==1){
  196. return '<span class="text-warning">待处理</span>';
  197. }else if(value==2){
  198. return '<span class="text-success">已送</span>';
  199. }else if(value==3){
  200. return '<span class="text-danger">已驳回</span>';
  201. }
  202. }
  203. },
  204. {field: 'createtime', title: __('申请时间'), formatter: Table.api.formatter.datetime, operate: false, addclass: 'datetimerange', sortable: true},
  205. {field: 'operate', title: __('Operate'), table: table,
  206. events: Table.api.events.operate,
  207. // formatter: Table.api.formatter.operate
  208. formatter: Table.api.formatter.buttons,
  209. buttons: [
  210. {
  211. name: 'dispatch',
  212. text: '已送',
  213. icon: 'fa fa-check',
  214. title: '已送',
  215. classname: 'btn btn-success btn-xs btn-magic btn-ajax',
  216. url: 'teacher/exams/handle/type/1',
  217. visible: function (rr) {
  218. if(rr.request_status == 1 || rr.request_status == 0){
  219. return true;
  220. }
  221. return false;
  222. },
  223. success: function (data, ret) {
  224. table.bootstrapTable("refresh");
  225. },
  226. },{
  227. name: 'dispatch',
  228. text: '驳回',
  229. icon: 'fa fa-reply-all',
  230. title: '驳回',
  231. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  232. url: 'teacher/exams/handle/type/2',
  233. visible: function (rr) {
  234. if(rr.request_status == 1 || rr.request_status == 0){
  235. return true;
  236. }
  237. return false;
  238. },
  239. success: function (data, ret) {
  240. table.bootstrapTable("refresh");
  241. },
  242. }
  243. ],
  244. }
  245. ]
  246. ]
  247. });
  248. // 为表格绑定事件
  249. Table.api.bindevent(table);
  250. var table1 = $("#table1");
  251. // 初始化表格
  252. table1.bootstrapTable({
  253. url: $.fn.bootstrapTable.defaults.extend.indexed_url,
  254. pk: 'exam_id',
  255. sortName: 'exam_id',
  256. toolbar: '#toolbar1',
  257. fixedColumns: true,
  258. fixedRightNumber: 1,
  259. searchFormVisible:false,
  260. showExport:false,
  261. search:false,
  262. pagination:false,
  263. showExport:false,
  264. showToggle:false,
  265. showColumns: false,
  266. columns: [
  267. [
  268. // {checkbox: true},
  269. {field: 'seat_id', title: __('座号')},
  270. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  271. {field: 'sim_state', title: __('模拟器状态'),
  272. formatter: function(value, row,index) {
  273. // if(value=='在线'){
  274. // return '<span class="text-success">'+value+'</span>';
  275. // }
  276. // if(value=='离线'){
  277. // return '<span class="text-danger">'+value+'</span>';
  278. // }
  279. return '<span class="text-success">'+value+'</span>';
  280. }
  281. },
  282. {field: 'user_username', title: __('学员学号')},
  283. {field: 'user_nickname', title: __('学员姓名')},
  284. {field: 'exam_status', title: __('考试状态'),
  285. formatter: function(value, row,index) {
  286. if(value=='未登录'){
  287. return '<span class="text-danger">'+value+'</span>';
  288. }else if(value=='已登录未开始考试'){
  289. return '<span class="text-warning">'+value+'</span>';
  290. }else if(value=='已开始考试'){
  291. return '<span class="text-info">'+value+'</span>';
  292. }else if(value=='已交卷'){
  293. return '<span class="text-success">'+value+'</span>';
  294. }
  295. }
  296. },
  297. {field: 'total_score', title: __('考试成绩')},
  298. {field: 'fault_names', title: __('出题题目'),formatter: Table.api.formatter.faultname},
  299. // {field: 'xianxiang_names', title: __('故障现象'),formatter: Table.api.formatter.answerName},
  300. // {field: 'yuanyin_names', title: __('可能原因'),formatter: Table.api.formatter.answerName},
  301. // {field: 'buwei_names', title: __('故障部位'),formatter: Table.api.formatter.answerName},
  302. // {field: 'fangfa_names', title: __('排除方法'),formatter: Table.api.formatter.answerName},
  303. {field: 'operate', title: __('Operate'), table: table1,
  304. events: Table.api.events.operate,
  305. // formatter: Table.api.formatter.operate
  306. formatter: Table.api.formatter.buttons,
  307. buttons: [
  308. {
  309. name: 'dispatch',
  310. text: '成绩详情',
  311. icon: 'fa fa-eye',
  312. title: '成绩详情',
  313. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  314. extend: 'data-area=\'["75%","95%"]\'',
  315. visible: function (row) {
  316. if(row.total_score>0){
  317. return true;
  318. }
  319. return false;
  320. },
  321. url: 'teacher/exams/view',
  322. }
  323. ],
  324. }
  325. ]
  326. ]
  327. });
  328. // 为表格绑定事件
  329. Table.api.bindevent(table1);
  330. var table2 = $("#table2");
  331. // 初始化表格
  332. table2.bootstrapTable({
  333. url: $.fn.bootstrapTable.defaults.extend.score_url,
  334. pk: 'exam_id',
  335. sortName: 'exam_id',
  336. toolbar: '#toolbar2',
  337. fixedColumns: true,
  338. pageSize: 10,
  339. pagination:false,
  340. fixedLeftNumber: 4,
  341. searchFormVisible:false,
  342. showExport:false,
  343. search:false,
  344. showExport:false,
  345. showToggle:false,
  346. showColumns: false,
  347. columns: [
  348. [
  349. // {checkbox: true},
  350. {field: 'seat_id', title: __('座号')},
  351. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  352. {field: 'user_username', title: __('学员学号')},
  353. {field: 'user_nickname', title: __('学员姓名')},
  354. {field: 'total', title: __('考试成绩')},
  355. {field: 'fault_one_score', title: __('故障一扣分'),editable:true},
  356. {field: 'fault_two_score', title: __('故障二扣分'),editable:true},
  357. {field: 'fault_three_score', title: __('故障三扣分'),editable:true},
  358. {field: 'xianxian_score', title: __('故障现象扣分'),editable:true},
  359. {field: 'yuanyin_socre', title: __('可能原因扣分'),editable:true},
  360. {field: 'buwei_score', title: __('故障部位扣分'),editable:true},
  361. {field: 'fangfa_score', title: __('排除方法扣分'),editable:true},
  362. {field: 'overtime_score', title: __('超时扣分'),editable:true},
  363. {field: 'operate', title: __('Operate'), table: table1,
  364. events: Table.api.events.operate,
  365. // formatter: Table.api.formatter.operate
  366. formatter: Table.api.formatter.buttons,
  367. buttons: [
  368. {
  369. name: 'dispatch',
  370. text: '成绩详情',
  371. icon: 'fa fa-eye',
  372. title: '成绩详情',
  373. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  374. extend: 'data-area=\'["75%","95%"]\'',
  375. url: 'teacher/exams/view',
  376. }
  377. ],
  378. }
  379. ]
  380. ],
  381. onEditableSave: function (field, row, oldValue, $el) {
  382. var data = {}; //组合更新数据
  383. // data["row[field]"] = field; //字段名
  384. data["row[" + field + "]"] = row[field]; //字段值
  385. // data["row[id]"] = row['id']; //主键
  386. Fast.api.ajax({
  387. url: "teacher/exams/editscore/ids/" + row[this.pk],
  388. data: data
  389. }, function () {
  390. $(".btn-refresh").trigger("click");
  391. });
  392. },
  393. });
  394. // 为表格绑定事件
  395. Table.api.bindevent(table2);
  396. //关闭考试 并且
  397. $(document).on('click', '.btn-closes', function () {
  398. var ids = Config.ids;
  399. $.ajax({
  400. type:'post',
  401. url:'teacher/collection/multi',
  402. data:{ids:ids,params:'exam_collection_state=3'}, //重点必须为一个变量如:data
  403. success:function(data){
  404. if(data.code==1){
  405. Backend.api.closetabs('/admin/teacher/exams/persent/ids/'+Config.ids)
  406. // Backend.api.addtabs('teacher/collection','考试列表');
  407. }
  408. },
  409. error:function(){
  410. layer.alert("操作失败");
  411. return;
  412. }
  413. })
  414. });
  415. $("button[name=commonSearch]").css('display','none');
  416. //定时刷新
  417. setInterval(function() {
  418. table.bootstrapTable('refresh');
  419. table1.bootstrapTable('refresh');
  420. table2.bootstrapTable('refresh');
  421. }, 30000);
  422. },
  423. add: function () {
  424. Controller.api.bindevent();
  425. },
  426. edit: function () {
  427. Controller.api.bindevent();
  428. },
  429. api: {
  430. bindevent: function () {
  431. Form.api.bindevent($("form[role=form]"));
  432. }
  433. }
  434. };
  435. return Controller;
  436. });