practice.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  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. columns: [
  28. [
  29. {checkbox: true},
  30. {field: 'exam_collection_id', title: __('编号'),operate: false},
  31. {field: 'exam_collection_name', title: __('Exam_collection_name'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  32. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  33. {field: 'question_setting_method', title: __('Question_setting_method'),searchList:{"1":"系统随机","2":"教师自选","3":"任务自选"},formatter: Table.api.formatter.simmethod},
  34. // {field: 'exam_collection_type', title: __('Exam_collection_type'),operate: false,formatter: function (value, row, index) {
  35. // return '练习';
  36. // }
  37. // },
  38. {
  39. field: 'exam_collection_state',searchList:{"2":"打开","3":"关闭"},
  40. title: __('是否开启练习'),
  41. align: 'center',
  42. table: table,
  43. formatter: Table.api.formatter.collectonstate
  44. },
  45. // {field: 'task_id', title: __('Task_id')},
  46. {field: 'limit_duration', title: __('Limit_duration')},
  47. // {field: 'start_time', title: __('Start_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  48. // {field: 'end_time', title: __('End_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  49. // {field: 'create_user_id', title: __('Create_user_id')},
  50. {field: 'create_by', title: __('Create_by'), operate: 'LIKE'},
  51. {field: 'qudui_count', title: __('区队数量'), operate: false},
  52. {field: 'xueyuan_count', title: __('应考人数'), operate: false},
  53. {field: 'yikao_count', title: __('已考人数'), operate: false},
  54. {field: 'createtime', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false,formatter: Table.api.formatter.datetime},
  55. // {field: 'update_by', title: __('Update_by'), operate: 'LIKE'},
  56. // {field: 'update_time', title: __('Update_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  57. // {field: 'remark', title: __('Remark'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  58. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate,
  59. // formatter: Table.api.formatter.operate
  60. formatter: Table.api.formatter.buttons,
  61. buttons: [
  62. {
  63. name: 'dispatch',
  64. text: '编辑',
  65. icon: 'fa fa-pencil',
  66. title: '编辑',
  67. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  68. extend: 'data-area=\'["85%","85%"]\'',
  69. url: 'teacher/practice/edit',
  70. },
  71. {
  72. name: 'dispatch',
  73. text: '进入练习',
  74. icon: 'fa fa-hand-pointer-o',
  75. title: '进入练习',
  76. visible: function (rr) {
  77. if(rr.exam_collection_state == 2){
  78. return true;
  79. }
  80. return false;
  81. },
  82. classname: 'btn btn-info btn-xs btn-magic btn-addtabs',
  83. url: 'teacher/practice/persent',
  84. },
  85. {
  86. name: 'dispatch',
  87. text: '删除',
  88. icon: 'fa fa-trash',
  89. title: '删除',
  90. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  91. url: 'teacher/practice/del',
  92. confirm: '确定要删除吗?',
  93. success: function (data, ret) {
  94. $(".btn-refresh").trigger("click");
  95. },
  96. error: function (data, ret) {
  97. Layer.alert(ret.msg);
  98. return false;
  99. }
  100. }
  101. ],
  102. }
  103. ]
  104. ]
  105. });
  106. // 为表格绑定事件
  107. Table.api.bindevent(table);
  108. $(document).on('click', '.btn-start', function () {
  109. var ids = Table.api.selectedids(table);
  110. Fast.api.ajax({
  111. url: "teacher/practice/start/ids/"+ids,
  112. type: "post",
  113. }, function () {
  114. table.bootstrapTable('refresh');
  115. Layer.close(index);
  116. });
  117. });
  118. },
  119. persent: function () {
  120. Table.api.init({
  121. extend: {
  122. index_url: 'teacher/practice/persent' + location.search,
  123. indexed_url: 'teacher/practice/examing' + location.search,
  124. table: 'teacher_exams',
  125. }
  126. });
  127. var table = $("#table");
  128. // 初始化表格
  129. table.bootstrapTable({
  130. url: $.fn.bootstrapTable.defaults.extend.index_url,
  131. pk: 'exam_id',
  132. sortName: 'exam_id',
  133. toolbar: '#toolbar',
  134. fixedColumns: true,
  135. fixedRightNumber: 1,
  136. searchFormVisible:false,
  137. showExport:false,
  138. search:false,
  139. columns: [
  140. [
  141. // {checkbox: true},
  142. {field: 'fault_name', title: __('更换件')},
  143. {field: 'create_by', title: __('学员姓名')},
  144. {field: 'request_status', title: __('状态'),
  145. formatter: function(value, row,index) {
  146. if(value==1){
  147. return '<span class="text-warning">待处理</span>';
  148. }else if(value==2){
  149. return '<span class="text-success">已送</span>';
  150. }else if(value==3){
  151. return '<span class="text-danger">已驳回</span>';
  152. }
  153. }
  154. },
  155. {field: 'createtime', title: __('申请时间'), formatter: Table.api.formatter.datetime, operate: false, addclass: 'datetimerange', sortable: true},
  156. {field: 'operate', title: __('Operate'), table: table,
  157. events: Table.api.events.operate,
  158. // formatter: Table.api.formatter.operate
  159. formatter: Table.api.formatter.buttons,
  160. buttons: [
  161. {
  162. name: 'dispatch',
  163. text: '',
  164. icon: 'fa fa-check',
  165. title: '已送',
  166. classname: 'btn btn-success btn-xs btn-magic btn-ajax',
  167. url: 'teacher/exams/handle/type/1',
  168. visible: function (rr) {
  169. if(rr.request_status == 1 || rr.request_status == 0){
  170. return true;
  171. }
  172. return false;
  173. },
  174. success: function (data, ret) {
  175. table.bootstrapTable("refresh");
  176. },
  177. },{
  178. name: 'dispatch',
  179. text: '',
  180. icon: 'fa fa-reply-all',
  181. title: '驳回',
  182. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  183. url: 'teacher/exams/handle/type/2',
  184. visible: function (rr) {
  185. if(rr.request_status == 1 || rr.request_status == 0){
  186. return true;
  187. }
  188. return false;
  189. },
  190. success: function (data, ret) {
  191. table.bootstrapTable("refresh");
  192. },
  193. }
  194. ],
  195. }
  196. ]
  197. ]
  198. });
  199. // 为表格绑定事件
  200. Table.api.bindevent(table);
  201. var table1 = $("#table1");
  202. // 初始化表格
  203. table1.bootstrapTable({
  204. url: $.fn.bootstrapTable.defaults.extend.indexed_url,
  205. pk: 'exam_collection_id',
  206. sortName: 'exam_collection_id',
  207. toolbar: '#toolbar1',
  208. fixedColumns: true,
  209. fixedRightNumber: 1,
  210. searchFormVisible:false,
  211. columns: [
  212. [
  213. // {checkbox: true},
  214. {field: 'seat_id', title: __('座号')},
  215. {field: '', title: __('模拟器状态'),
  216. formatter: function(value, row,index) {
  217. return '<span class="text-success">就绪</span>';
  218. }
  219. },
  220. {field: 'user_username', title: __('学员学号')},
  221. {field: 'user_nickname', title: __('学员姓名')},
  222. {field: '', title: __('状态'),
  223. formatter: function(value, row,index) {
  224. return '<span class="text-success">已交卷</span>';
  225. }
  226. },
  227. {field: 'total_score', title: __('模拟成绩')},
  228. ]
  229. ]
  230. });
  231. // 为表格绑定事件
  232. Table.api.bindevent(table1);
  233. },
  234. add: function () {
  235. Controller.api.bindevent();
  236. },
  237. edit: function () {
  238. Controller.api.bindevent();
  239. },
  240. api: {
  241. bindevent: function () {
  242. var rel_Ids = [];
  243. var qudui_total = 0;
  244. var xueyuan_total = 0;
  245. Table.api.init({
  246. extend: {
  247. index_url: 'department/admin/departadmintotal' + location.search,
  248. }
  249. });
  250. var table = $("#table1");
  251. // 初始化表格
  252. table.bootstrapTable({
  253. url: $.fn.bootstrapTable.defaults.extend.index_url,
  254. pk: 'id',
  255. sortName: 'id',
  256. fixedColumns: true,
  257. fixedRightNumber: 1,
  258. searchFormVisible:false,
  259. Search:false,
  260. columns: [
  261. [
  262. {checkbox: true,
  263. formatter: function(value,row,index){
  264. // console.log(row.id+'####'+Config.row_info.depart_ids)
  265. if(Config.row_info != undefined && Config.row_info.depart_ids.indexOf(row.id)>-1){
  266. rel_Ids.push(row.id);
  267. return true;
  268. }
  269. return false;
  270. }
  271. },
  272. {field: 'department_name', title: __('区队名称'), operate: false,width: '400px', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  273. {field: 'department_admin_count', title: __('全部人员数量'),operate: false},
  274. ]
  275. ],
  276. onLoadSuccess: function(data) {
  277. $.each(data.rows, function(index, row) {
  278. if(Config.row_info != undefined && Config.row_info.depart_ids.indexOf(row.id)>-1){
  279. qudui_total = qudui_total+1;
  280. xueyuan_total = xueyuan_total+row.department_admin_count;
  281. }
  282. });
  283. $(".qudui_total").html(qudui_total);
  284. $(".xueyuan_total").html(xueyuan_total);
  285. $(".qudui_input").val(qudui_total);
  286. $(".xueyuan_input").val(xueyuan_total);
  287. },
  288. });
  289. // 为表格绑定事件
  290. Table.api.bindevent(table);
  291. table.on('click-row.bs.table', function (e, row, element) {
  292. console.log(rel_Ids)
  293. // console.log('row')
  294. if(!$.inArray(row.id,rel_Ids)){
  295. if(Config.row_info.starttime>0){
  296. Layer.alert('考试正在进行中,只可增加区队不可取消区队');
  297. return false;
  298. }
  299. arr = $.grep(rel_Ids, function(value) {
  300. return value != row["id"];
  301. });
  302. rel_Ids = arr;
  303. qudui_total = qudui_total-1;
  304. xueyuan_total = xueyuan_total-row.department_admin_count;
  305. }else if(rel_Ids.indexOf(row.id)>-1){
  306. if(Config.row_info.starttime>0){
  307. Layer.alert('考试正在进行中,只可增加区队不可取消区队');
  308. return false;
  309. }
  310. var index = rel_Ids.indexOf(row.id);
  311. if(index > -1) {
  312. rel_Ids.splice(index, 1);
  313. }
  314. qudui_total = qudui_total-1;
  315. xueyuan_total = xueyuan_total-row.department_admin_count;
  316. }else{
  317. qudui_total = qudui_total+1;
  318. xueyuan_total = xueyuan_total+row.department_admin_count;
  319. rel_Ids.push(row.id);
  320. }
  321. console.log(qudui_total);
  322. console.log(xueyuan_total);
  323. $(".depart_ids").val(rel_Ids.join());
  324. $(".qudui_total").html(qudui_total);
  325. $(".xueyuan_total").html(xueyuan_total);
  326. $(".qudui_input").val(qudui_total);
  327. $(".xueyuan_input").val(xueyuan_total);
  328. });
  329. $(document).on('change', '#c-question_setting_method', function () {
  330. if($(this).val()==1){
  331. $(".btn-sm,.btn-task").css('display','none');
  332. }else if($(this).val()==2){
  333. $(".btn-sm").show();
  334. $(".btn-task").css('display','none');
  335. }else if($(this).val()==3){
  336. $(".btn-sm").css('display','none');
  337. $(".btn-task").show();
  338. }
  339. $(".question_ids").val(0);
  340. $(".task_id").val(0);
  341. $("#c-task_name").val('');
  342. $("#c-fault_name").val('');
  343. $("#c-question_name").val('');
  344. $(".tasks,.questions").css('display','none')
  345. });
  346. //考题
  347. $(document).on('click', '.btn-sm', function () {
  348. var simtype = $("#c-sim_type").val();
  349. if(!simtype){
  350. Layer.alert('请选择模拟器类型');
  351. return false
  352. }
  353. var title = '选择考题';
  354. Fast.api.open(Fast.api.fixurl("teacher/collection/faults/type/"+simtype), title, {
  355. area: ["85%", "85%"],
  356. maxmin: true,
  357. moveOut: false,
  358. offset: ['40px'],
  359. callback: function(value) {
  360. if (value.task_id) {
  361. $(".questions").css('display','block')
  362. $(".question_ids").val(value.task_id);
  363. $("#c-question_name").val(value.task_name);
  364. $(".tasks").css('display','none')
  365. $(".task_id").val(0);
  366. $("#c-task_name").val('');
  367. $("#c-fault_name").val('');
  368. }
  369. }
  370. });
  371. });
  372. //任务
  373. $(document).on('click', '.btn-task', function () {
  374. var simtype = $("#c-sim_type").val();
  375. if(!simtype){
  376. Layer.alert('请选择模拟器类型');
  377. return false;
  378. }
  379. var title = '选择任务';
  380. parent.Fast.api.open(Fast.api.fixurl("teacher/collection/task/type/"+simtype), title, {
  381. area: ["65%", "70%"],
  382. maxmin: true,
  383. moveOut: false,
  384. offset: ['40px'],
  385. callback: function(value) {
  386. console.log(value);
  387. if (value.task_id) {
  388. $(".tasks").css('display','block')
  389. $(".task_id").val(value.task_id);
  390. $("#c-task_name").val(value.task_name);
  391. $("#c-fault_name").val(value.fault_name);
  392. $(".questions").css('display','none')
  393. $(".question_ids").val(0);
  394. $("#c-question_name").val('');
  395. }
  396. }
  397. });
  398. });
  399. // $("input[name='btSelectAll']").click(function () {
  400. // var ids = Table.api.selectedids(table);
  401. // console.log(ids);
  402. // $(".depart_ids").val(ids);
  403. // });
  404. $("button[name=commonSearch]").css('display','none');
  405. $("input[name='btSelectAll']").css('display','none');
  406. Form.api.bindevent($("form[role=form]"));
  407. }
  408. }
  409. };
  410. return Controller;
  411. });