practice.js 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form','editable'], function ($, undefined, Backend, Table, Form,editable) {
  2. var Controller = {
  3. index: function () {
  4. // $('.btn-add').data('area',['85%','85%']);
  5. // $('.btn-edit').data('area',['85%','85%']);
  6. // 初始化表格参数配置
  7. Table.api.init({
  8. extend: {
  9. index_url: 'teacher/practice/index' + location.search,
  10. add_url: 'teacher/practice/add',
  11. edit_url: 'teacher/practice/edit',
  12. del_url: 'teacher/practice/del',
  13. multi_url: 'teacher/practice/multi',
  14. import_url: 'teacher/practice/import',
  15. table: 'teacher_collection',
  16. }
  17. });
  18. var table = $("#table");
  19. // 初始化表格
  20. table.bootstrapTable({
  21. url: $.fn.bootstrapTable.defaults.extend.index_url,
  22. pk: 'exam_collection_id',
  23. sortName: 'exam_collection_id',
  24. fixedColumns: true,
  25. fixedRightNumber: 1,
  26. searchFormVisible:true,
  27. search:false,
  28. columns: [
  29. [
  30. {checkbox: true},
  31. {field: 'exam_collection_id', title: __('编号'),operate: false},
  32. {field: 'exam_collection_name', title: __('Exam_collection_name'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  33. // {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  34. // {field: 'question_setting_method', title: __('Question_setting_method'),searchList:{"1":"系统随机","2":"教师自选","3":"任务自选"},formatter: Table.api.formatter.simmethod},
  35. // {field: 'exam_collection_type', title: __('Exam_collection_type'),operate: false,formatter: function (value, row, index) {
  36. // return '练习';
  37. // }
  38. // },
  39. {
  40. field: 'exam_collection_state',searchList:{"2":"打开","3":"关闭"},
  41. title: __('是否开启练习'),
  42. align: 'center',
  43. table: table,
  44. formatter: Table.api.formatter.collectonstate
  45. },
  46. // {field: 'task_id', title: __('Task_id')},
  47. {field: 'limit_duration', title: __('Limit_duration')},
  48. {field: 'create_by', title: __('Create_by'), operate: 'LIKE'},
  49. // {field: 'qudui_count', title: __('区队数量'), operate: false},
  50. {field: 'xueyuan_count', title: __('应考人数'), operate: false},
  51. {field: 'yikao_count', title: __('已考人数'), operate: false},
  52. {field: 'createtime', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false,formatter: Table.api.formatter.datetime},
  53. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate,
  54. // formatter: Table.api.formatter.operate
  55. formatter: Table.api.formatter.buttons,
  56. buttons: [
  57. {
  58. name: 'dispatch',
  59. text: '编辑',
  60. icon: 'fa fa-pencil',
  61. title: '编辑',
  62. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  63. // extend: 'data-area=\'["85%","85%"]\'',
  64. url: 'teacher/practice/edit',
  65. },
  66. {
  67. name: 'dispatch',
  68. text: '进入练习',
  69. icon: 'fa fa-hand-pointer-o',
  70. title: '进入练习',
  71. visible: function (rr) {
  72. if(rr.exam_collection_state == 2){
  73. return true;
  74. }
  75. return false;
  76. },
  77. classname: 'btn btn-info btn-xs btn-magic btn-addtabs',
  78. url: 'teacher/practice/persent',
  79. },
  80. {
  81. name: 'dispatch',
  82. text: '查看学员',
  83. icon: 'fa fa-eye',
  84. title: '查看学员',
  85. visible: function (rr) {
  86. if(rr.user_count > 0){
  87. return true;
  88. }
  89. return false;
  90. },
  91. classname: 'btn btn-warning btn-xs btn-magic btn-dialog',
  92. extend: 'data-area=\'["85%","85%"]\'',
  93. url: 'teacher/collection/viewuser',
  94. },
  95. {
  96. name: 'dispatch',
  97. text: '添加学员',
  98. icon: 'fa fa-plus',
  99. title: '添加学员',
  100. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  101. extend: 'data-area=\'["85%","85%"]\'',
  102. url: 'teacher/practice/adduser',
  103. },
  104. {
  105. name: 'dispatch',
  106. text: '删除学员',
  107. icon: 'fa fa-pencil',
  108. title: '删除学员',
  109. visible: function (rr) {
  110. if(rr.user_count > 0){
  111. return true;
  112. }
  113. return false;
  114. },
  115. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  116. extend: 'data-area=\'["75%","75%"]\'',
  117. url: 'teacher/practice/edituser',
  118. },
  119. {
  120. name: 'dispatch',
  121. text: '删除',
  122. icon: 'fa fa-trash',
  123. title: '删除',
  124. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  125. url: 'teacher/practice/del',
  126. confirm: '确定要删除吗?',
  127. success: function (data, ret) {
  128. $(".btn-refresh").trigger("click");
  129. },
  130. error: function (data, ret) {
  131. Layer.alert(ret.msg);
  132. return false;
  133. }
  134. }
  135. ],
  136. }
  137. ]
  138. ]
  139. });
  140. // 为表格绑定事件
  141. Table.api.bindevent(table);
  142. $(document).on('click', '.btn-start', function () {
  143. var ids = Table.api.selectedids(table);
  144. Fast.api.ajax({
  145. url: "teacher/practice/start/ids/"+ids,
  146. type: "post",
  147. }, function () {
  148. table.bootstrapTable('refresh');
  149. Layer.close(index);
  150. });
  151. });
  152. },
  153. persent: function () {
  154. Table.api.init({
  155. extend: {
  156. index_url: 'teacher/practice/persent/ids/'+Config.ids + location.search,
  157. indexed_url: 'teacher/practice/examing/ids/'+ Config.ids+ location.search,
  158. score_url: 'teacher/practice/score/ids/'+Config.ids + location.search,
  159. table: 'teacher_exams',
  160. }
  161. });
  162. var table = $("#table");
  163. // 初始化表格
  164. table.bootstrapTable({
  165. url: $.fn.bootstrapTable.defaults.extend.index_url,
  166. pk: 'rel_id',
  167. sortName: 'rel_id',
  168. toolbar: '#toolbar',
  169. fixedColumns: true,
  170. fixedRightNumber: 1,
  171. searchFormVisible:false,
  172. showExport:false,
  173. search:false,
  174. columns: [
  175. [
  176. // {checkbox: true},
  177. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  178. {field: 'fault_name', title: __('更换件')},
  179. {field: 'create_by', title: __('学员姓名')},
  180. {field: 'request_status', title: __('状态'),
  181. formatter: function(value, row,index) {
  182. if(value==1){
  183. return '<span class="text-warning">待处理</span>';
  184. }else if(value==2){
  185. return '<span class="text-success">已送</span>';
  186. }else if(value==3){
  187. return '<span class="text-danger">已驳回</span>';
  188. }
  189. }
  190. },
  191. {field: 'createtime', title: __('申请时间'), formatter: Table.api.formatter.datetime, operate: false, addclass: 'datetimerange', sortable: true},
  192. {field: 'operate', title: __('Operate'), table: table,
  193. events: Table.api.events.operate,
  194. // formatter: Table.api.formatter.operate
  195. formatter: Table.api.formatter.buttons,
  196. buttons: [
  197. {
  198. name: 'dispatch',
  199. text: '已送',
  200. icon: 'fa fa-check',
  201. title: '已送',
  202. classname: 'btn btn-success btn-xs btn-magic btn-ajax',
  203. url: 'teacher/exams/handle/type/1',
  204. visible: function (rr) {
  205. if(rr.request_status == 1 || rr.request_status == 0){
  206. return true;
  207. }
  208. return false;
  209. },
  210. success: function (data, ret) {
  211. table.bootstrapTable("refresh");
  212. },
  213. },{
  214. name: 'dispatch',
  215. text: '驳回',
  216. icon: 'fa fa-reply-all',
  217. title: '驳回',
  218. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  219. url: 'teacher/exams/handle/type/2',
  220. visible: function (rr) {
  221. if(rr.request_status == 1 || rr.request_status == 0){
  222. return true;
  223. }
  224. return false;
  225. },
  226. success: function (data, ret) {
  227. table.bootstrapTable("refresh");
  228. },
  229. }
  230. ],
  231. }
  232. ]
  233. ]
  234. });
  235. // 为表格绑定事件
  236. Table.api.bindevent(table);
  237. var table1 = $("#table1");
  238. // 初始化表格
  239. table1.bootstrapTable({
  240. url: $.fn.bootstrapTable.defaults.extend.indexed_url,
  241. pk: 'exam_id',
  242. sortName: 'exam_id',
  243. toolbar: '#toolbar1',
  244. fixedColumns: true,
  245. fixedRightNumber: 1,
  246. searchFormVisible:false,
  247. showExport:false,
  248. search:false,
  249. pagination:false,
  250. columns: [
  251. [
  252. // {checkbox: true},
  253. {field: 'seat_id', title: __('座号')},
  254. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  255. {field: 'sim_state', title: __('模拟器状态'),
  256. formatter: function(value, row,index) {
  257. // if(value=='在线'){
  258. // return '<span class="text-success">'+value+'</span>';
  259. // }
  260. // if(value=='离线'){
  261. // return '<span class="text-danger">'+value+'</span>';
  262. // }
  263. return '<span class="text-success">'+value+'</span>';
  264. }
  265. },
  266. {field: 'user_username', title: __('学员学号')},
  267. {field: 'user_nickname', title: __('学员姓名')},
  268. {field: 'exam_status', title: __('考试状态'),
  269. formatter: function(value, row,index) {
  270. if(value=='未登录'){
  271. return '<span class="text-danger">'+value+'</span>';
  272. }else if(value=='已登录未开始考试'){
  273. return '<span class="text-warning">'+value+'</span>';
  274. }else if(value=='已开始考试'){
  275. return '<span class="text-info">'+value+'</span>';
  276. }else if(value=='已交卷'){
  277. return '<span class="text-success">'+value+'</span>';
  278. }
  279. }
  280. },
  281. {field: 'total_score', title: __('考试成绩')},
  282. {field: 'fault_names', title: __('出题题目'),formatter: Table.api.formatter.faultname},
  283. {field: 'operate', title: __('Operate'), table: table1,
  284. events: Table.api.events.operate,
  285. // formatter: Table.api.formatter.operate
  286. formatter: Table.api.formatter.buttons,
  287. buttons: [
  288. {
  289. name: 'dispatch',
  290. text: '成绩详情',
  291. icon: 'fa fa-eye',
  292. title: '成绩详情',
  293. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  294. extend: 'data-area=\'["75%","95%"]\'',
  295. visible: function (row) {
  296. if(row.total_score>0){
  297. return true;
  298. }
  299. return false;
  300. },
  301. url: 'teacher/exams/view',
  302. }
  303. ],
  304. }
  305. ]
  306. ]
  307. });
  308. // 为表格绑定事件
  309. Table.api.bindevent(table1);
  310. var table2 = $("#table2");
  311. // 初始化表格
  312. table2.bootstrapTable({
  313. url: $.fn.bootstrapTable.defaults.extend.score_url,
  314. pk: 'exam_id',
  315. sortName: 'exam_id',
  316. toolbar: '#toolbar2',
  317. fixedColumns: true,
  318. pageSize: 10,
  319. pagination:false,
  320. fixedLeftNumber: 4,
  321. searchFormVisible:false,
  322. showExport:false,
  323. search:false,
  324. columns: [
  325. [
  326. // {checkbox: true},
  327. {field: 'seat_id', title: __('座号')},
  328. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  329. {field: 'user_username', title: __('学员学号')},
  330. {field: 'user_nickname', title: __('学员姓名')},
  331. {field: 'total', title: __('考试成绩')},
  332. {field: 'fault_one_score', title: __('故障一扣分'),editable:true},
  333. {field: 'fault_two_score', title: __('故障二扣分'),editable:true},
  334. {field: 'fault_three_score', title: __('故障三扣分'),editable:true},
  335. {field: 'xianxian_score', title: __('故障现象扣分'),editable:true},
  336. {field: 'yuanyin_socre', title: __('可能原因扣分'),editable:true},
  337. {field: 'buwei_score', title: __('故障部位扣分'),editable:true},
  338. {field: 'fangfa_score', title: __('排除方法扣分'),editable:true},
  339. {field: 'overtime_score', title: __('超时扣分'),editable:true},
  340. {field: 'operate', title: __('Operate'), table: table1,
  341. events: Table.api.events.operate,
  342. // formatter: Table.api.formatter.operate
  343. formatter: Table.api.formatter.buttons,
  344. buttons: [
  345. {
  346. name: 'dispatch',
  347. text: '成绩详情',
  348. icon: 'fa fa-eye',
  349. title: '成绩详情',
  350. classname: 'btn btn-info btn-xs btn-magic btn-dialog',
  351. extend: 'data-area=\'["75%","95%"]\'',
  352. url: 'teacher/exams/view',
  353. }
  354. ],
  355. }
  356. ]
  357. ]
  358. });
  359. // 为表格绑定事件
  360. Table.api.bindevent(table2);
  361. //关闭考试 并且
  362. $(document).on('click', '.btn-closes', function () {
  363. var ids = Config.ids;
  364. Backend.api.closetabs('/admin/teacher/practice/persent/ids/'+Config.ids)
  365. // Backend.api.addtabs('teacher/practice','练习列表');
  366. // $.ajax({
  367. // type:'post',
  368. // url:'teacher/collection/multi',
  369. // data:{ids:ids,params:'exam_collection_state=3'}, //重点必须为一个变量如:data
  370. // success:function(data){
  371. // if(data.code==1){
  372. // Backend.api.closetabs('/admin/teacher/exams/persent/ids/'+Config.ids)
  373. // Backend.api.addtabs('teacher/collection','考试列表');
  374. // }
  375. // },
  376. // error:function(){
  377. // layer.alert("操作失败");
  378. // return;
  379. // }
  380. // })
  381. });
  382. $("button[name=commonSearch]").css('display','none');
  383. //定时刷新
  384. setInterval(function() {
  385. table.bootstrapTable('refresh');
  386. table1.bootstrapTable('refresh');
  387. table2.bootstrapTable('refresh');
  388. }, 30000);
  389. },
  390. add: function () {
  391. Controller.api.bindevent1();
  392. },
  393. edit: function () {
  394. Controller.api.bindevent1();
  395. },
  396. adduser: function () {
  397. Controller.api.bindevent2();
  398. },
  399. edituser: function () {
  400. Controller.api.bindevent2();
  401. },
  402. api: {
  403. bindevent1: function () {
  404. Form.api.bindevent($("form[role=form]"));
  405. },
  406. initSubTable: function (index, row, $detail,parent_table) {
  407. var admin_id = row.id;
  408. var cur_table = $detail.html('<table id="sub_'+ admin_id +'" style="background-color:#d7d1d147"></table>').find('table');
  409. var sub_table = $(cur_table);
  410. sub_table.bootstrapTable({
  411. // url: 'area/index',
  412. toolbar: false,
  413. showColumns: false,
  414. showToggle: false,
  415. showExport: false,
  416. search: false,
  417. pagination:false,
  418. commonSearch: false,
  419. sortOrder: 'ASC',
  420. checkboxHeader: false,
  421. columns: [
  422. {checkbox: true,
  423. formatter: function(value,rows,index){
  424. console.log('Config.user_ids');
  425. console.log(Config.user_ids);
  426. if(Config.user_ids.length==0){
  427. return false;
  428. }else if(Config.user_ids.indexOf(rows.id)>-1){
  429. return true;
  430. }else{
  431. return {disabled : true}
  432. }
  433. }
  434. },
  435. // {field: 'id', title: 'ID'},
  436. {field: 'username', title: __('学号')},
  437. {field: 'nickname', title: __('姓名')},
  438. ],
  439. data: row.alluser
  440. });
  441. Table.api.bindevent(sub_table);
  442. sub_table.on("check.bs.table uncheck.bs.table check-all.bs.table uncheck-all.bs.table post-body.bs.table", function (e) {
  443. var selectedIds = Table.api.selectedids(sub_table);
  444. console.log(selectedIds);
  445. $(".xueyuan_input").val(selectedIds.length);
  446. $(".xueyuan_total").html(selectedIds.length);
  447. $(".depart_ids").val(selectedIds.join());
  448. })
  449. },
  450. bindevent2: function () {
  451. var rel_Ids = [];
  452. var qudui_total = 0;
  453. var xueyuan_total = 0;
  454. Table.api.init({
  455. extend: {
  456. index_url: 'department/admin/departadmintotal' + location.search,
  457. }
  458. });
  459. var table = $("#table1");//当内容渲染完成后展开详细
  460. table.on('post-body.bs.table', function (e, data) {
  461. $('#table1').bootstrapTable('expandAllRows');
  462. });
  463. // 初始化表格
  464. table.bootstrapTable({
  465. url: $.fn.bootstrapTable.defaults.extend.index_url,
  466. pk: 'id',
  467. sortName: 'id',
  468. fixedColumns: true,
  469. fixedRightNumber: 1,
  470. searchFormVisible:false,
  471. // pagination:false,
  472. detailView: true,//父子表
  473. Search:false,
  474. columns: [
  475. [
  476. {checkbox: true,},
  477. {field: 'department_name', title: __('区队名称'), operate: false,width: '400px', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  478. {field: 'department_admin_count', title: __('全部人员数量'),operate: false},
  479. ]
  480. ],
  481. onExpandRow: function (index, row, $detail) {
  482. Controller.api.initSubTable(index, row, $detail);
  483. },
  484. onCheck: function (row, $element) {
  485. $('.btn-disabled').addClass('disabled');
  486. var id = row.id;
  487. $("#sub_" + id).bootstrapTable("checkAll");
  488. },
  489. onUncheck: function (row) {
  490. var id = row.id;
  491. $("#sub_" + id).bootstrapTable("uncheckAll");
  492. },
  493. });
  494. // 为表格绑定事件
  495. Table.api.bindevent(table);
  496. $(document).on('change', '#c-question_setting_method', function () {
  497. if($(this).val()==1){
  498. $(".btn-sm,.btn-task").css('display','none');
  499. $(".fault_total").css('display','block');
  500. $('form[role=form]').validator("setField", {
  501. "row[fault_total]": "required",
  502. });
  503. }else if($(this).val()==2){
  504. $(".btn-sm").show();
  505. $(".btn-task,.fault_total").css('display','none');
  506. $('form[role=form]').validator("setField", {
  507. "row[fault_total]":null,
  508. });
  509. }else if($(this).val()==3){
  510. $(".btn-sm,.fault_total").css('display','none');
  511. $('form[role=form]').validator("setField", {
  512. "row[fault_total]": null,
  513. });
  514. $(".btn-task").show();
  515. }
  516. $(".question_ids").val(0);
  517. $(".task_id").val(0);
  518. $("#c-task_name").val('');
  519. $("#c-fault_name").val('');
  520. $("#c-question_name").val('');
  521. $(".tasks,.questions").css('display','none');
  522. });
  523. //考题
  524. $(document).on('click', '.btn-sm', function () {
  525. var simtype = $("#c-sim_type").val();
  526. if(!simtype){
  527. Layer.alert('请选择模拟器类型');
  528. return false
  529. }
  530. var examid = $(".examid").val();
  531. var title = '选择考题';
  532. Fast.api.open(Fast.api.fixurl("teacher/collection/faults/type/"+simtype+"/ids/"+examid), title, {
  533. area: ["85%", "85%"],
  534. maxmin: true,
  535. moveOut: false,
  536. offset: ['40px'],
  537. callback: function(value) {
  538. if (value.task_id) {
  539. $(".questions").css('display','block')
  540. $(".question_ids").val(value.task_id);
  541. $("#c-question_name").val(value.task_name);
  542. $(".tasks").css('display','none')
  543. $(".task_id").val(0);
  544. $("#c-task_name").val('');
  545. $("#c-fault_name").val('');
  546. }
  547. }
  548. });
  549. });
  550. //任务
  551. $(document).on('click', '.btn-task', function () {
  552. var simtype = $("#c-sim_type").val();
  553. if(!simtype){
  554. Layer.alert('请选择模拟器类型');
  555. return false;
  556. }
  557. var examid = $(".examid").val();
  558. var title = '选择任务';
  559. parent.Fast.api.open(Fast.api.fixurl("teacher/collection/task/type/"+simtype+"/ids/"+examid), title, {
  560. area: ["65%", "70%"],
  561. maxmin: true,
  562. moveOut: false,
  563. offset: ['40px'],
  564. callback: function(value) {
  565. console.log(value);
  566. if (value.task_id) {
  567. $(".tasks").css('display','block')
  568. $(".task_id").val(value.task_id);
  569. $("#c-task_name").val(value.task_name);
  570. $("#c-fault_name").val(value.fault_name);
  571. $(".questions").css('display','none')
  572. $(".question_ids").val(0);
  573. $("#c-question_name").val('');
  574. }
  575. }
  576. });
  577. });
  578. $("button[name=commonSearch]").css('display','none');
  579. $("input[name='btSelectAll']").css('display','none');
  580. Form.api.bindevent($("form[role=form]"));
  581. }
  582. }
  583. };
  584. return Controller;
  585. });