task.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  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,.btn-editone').data('area',['85%','85%']);
  6. // 初始化表格参数配置
  7. Table.api.init({
  8. extend: {
  9. index_url: 'teacher/task/index' + location.search,
  10. add_url: 'teacher/task/add',
  11. edit_url: 'teacher/task/edit',
  12. del_url: 'teacher/task/del',
  13. multi_url: 'teacher/task/multi',
  14. import_url: 'teacher/task/import',
  15. table: 'teacher_task',
  16. }
  17. });
  18. var table = $("#table");
  19. // 初始化表格
  20. table.bootstrapTable({
  21. url: $.fn.bootstrapTable.defaults.extend.index_url,
  22. pk: 'task_id',
  23. sortName: 'task_id',
  24. fixedColumns: true,
  25. fixedRightNumber: 1,
  26. searchFormVisible:true,
  27. columns: [
  28. [
  29. {checkbox: true},
  30. {field: 'task_id', title: __('Task_id'),operate: false,width:'80px'},
  31. {field: 'name', title: __('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: 'task_type', title: __('Task_type'),operate: false,formatter: function (value, row, index) {
  34. // return '教师创建';
  35. // }
  36. // },
  37. // {field: 'xianxiang_count', title: __('故障现象数量')},
  38. {field: 'fault_name', title: __('故障内容'),formatter: Table.api.formatter.faultname},
  39. // {field: 'buwei_count', title: __('故障部位数量')},
  40. // {field: 'create_by', title: __('Create_by'), operate: 'LIKE'},
  41. // {field: 'createtime', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false,formatter: Table.api.formatter.datetime,width:'120px'},
  42. // {field: 'update_by', title: __('Update_by'), operate: 'LIKE'},
  43. // {field: 'update_time', title: __('Update_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  44. // {field: 'remark', title: __('Remark'), operate: false, table: table, class: 'autocontent'},
  45. {field: 'operate', title: __('Operate'), table: table,
  46. events: Table.api.events.operate,
  47. // formatter: Table.api.formatter.operate,
  48. formatter: Table.api.formatter.buttons,
  49. buttons: [
  50. {
  51. name: 'dispatch',
  52. text: '',
  53. icon: 'fa fa-pencil',
  54. title: '编辑',
  55. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  56. extend: 'data-area=\'["85%","85%"]\'',
  57. url: 'teacher/task/edit',
  58. },{
  59. name: 'dispatch',
  60. text: '',
  61. icon: 'fa fa-trash',
  62. title: '删除',
  63. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  64. url: 'teacher/task/del',
  65. confirm: '确定要删除吗?',
  66. success: function (data, ret) {
  67. $(".btn-refresh").trigger("click");
  68. },
  69. error: function (data, ret) {
  70. Layer.alert(ret.msg);
  71. return false;
  72. }
  73. }
  74. ],
  75. }
  76. ]
  77. ]
  78. });
  79. // 为表格绑定事件
  80. Table.api.bindevent(table);
  81. },
  82. add: function () {
  83. Controller.api.bindevent();
  84. },
  85. edit: function () {
  86. Controller.api.bindevent();
  87. },
  88. api: {
  89. bindevent: function () {
  90. var rel_Ids = [];
  91. var rel_Names = [];
  92. if(Config.rel_Ids){
  93. $.each(Config.rel_Ids, function(index, value) {
  94. rel_Ids.push(value);
  95. });
  96. $.each(Config.rel_Names, function(index, value) {
  97. rel_Names.push(value);
  98. });
  99. }
  100. $('select[name="row[sim_type]"]').change(function () {
  101. $(".fault_ids").val('');
  102. $(".fault_names").val('');
  103. rel_Ids = [];
  104. rel_Names = [];
  105. console.log($(this).val());
  106. console.log( $(this).find("option:selected").text())
  107. var xinghao = $(this).find("option:selected").text();
  108. $.ajax({
  109. url: "fault/getdatalist",
  110. type: 'post',
  111. data: {
  112. simtype: $(this).val(),
  113. },
  114. success: function (data) {
  115. if(data.code==1){
  116. var task_tr = '';
  117. var ret = data.data;
  118. for (var i = 0; i < ret.length; i++) {
  119. if(ret[0].sim_type == '0001'){
  120. task_tr += '<tr>';
  121. if(i==0){
  122. task_tr += ' <td rowspan="11">'+xinghao+'</td>';
  123. }
  124. if(i<4){
  125. task_tr += ' <td rowspan="2">'+ret[i].name+'</td>';
  126. }else{
  127. task_tr += ' <td rowspan="1">'+ret[i].name+'</td>';
  128. }
  129. for (var j = 0; j < ret[i].children.length; j++) {
  130. var ret1 = ret[i].children;
  131. if(j>0){
  132. task_tr += ' </tr><tr><td>'+ret1[j].name+'</td>';
  133. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'"></td>';
  134. }else{
  135. task_tr += ' <td>'+ret1[j].name+'</td>';
  136. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'"></td>';
  137. }
  138. }
  139. task_tr += '</tr>';
  140. }else if(ret[0].sim_type == '0002'){
  141. task_tr += '<tr>';
  142. if(i==0){
  143. task_tr += ' <td rowspan="15">'+xinghao+'</td>';
  144. }
  145. if(i<5){
  146. task_tr += ' <td rowspan="2">'+ret[i].name+'</td>';
  147. }else{
  148. task_tr += ' <td rowspan="1">'+ret[i].name+'</td>';
  149. }
  150. for (var j = 0; j < ret[i].children.length; j++) {
  151. var ret1 = ret[i].children;
  152. if(j>0){
  153. task_tr += ' </tr><tr><td>'+ret1[j].name+'</td>';
  154. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'"></td>';
  155. }else{
  156. task_tr += ' <td>'+ret1[j].name+'</td>';
  157. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'"></td>';
  158. }
  159. }
  160. }else if(ret[0].sim_type == '0003'){
  161. //003 暂缺
  162. }
  163. }
  164. $(".task_list").html(task_tr);
  165. }
  166. }
  167. });
  168. });
  169. //只允许选择三个故障
  170. $(document).on('click', "input[type='checkbox']", function () {
  171. if ($(this).attr("checked")) {
  172. var index = rel_Ids.indexOf($(this).val());
  173. if (index > -1) {
  174. rel_Ids.splice(index, 1);
  175. rel_Names.splice(rel_Names.indexOf($(this).attr('vname')), 1);
  176. }
  177. $(".fault_ids").val(rel_Ids.join(','));
  178. $(".fault_names").val(rel_Names.join(','));
  179. } else {
  180. if(rel_Ids.length>2){
  181. Layer.alert('故障内容只允许选择3个');
  182. return false
  183. }
  184. $(this).attr("checked", "true");
  185. rel_Ids.push($(this).val());
  186. $(".fault_ids").val(rel_Ids.join())
  187. rel_Names.push($(this).attr('vname'));
  188. $(".fault_names").val(rel_Names.join(','));
  189. }
  190. });
  191. // 选中全部
  192. // $(document).on('click', ".btnselectall", function () {
  193. // rel_Ids = [];
  194. // $("input[name='checkbox']").each(function (){
  195. // $(this).attr( "checked" , "true");
  196. // // console.log(rel_Ids+'####')
  197. // // if(!$.inArray($(this).val(),rel_Ids)){
  198. // // var index = rel_Ids.indexOf($(this).val());
  199. // // if (index > -1) {
  200. // // rel_Ids.splice(index, 1);
  201. // // }
  202. // // // $(".fault_ids").val(rel_Ids.join(','));
  203. // // // rel_Ids = arr;
  204. // // }else{
  205. // // rel_Ids.push($(this).val());
  206. // // }
  207. // // //
  208. // rel_Ids.push($(this).val());
  209. // $(".fault_ids").val(rel_Ids);
  210. // });
  211. // });
  212. // //取消选择
  213. // $(document).on('click', ".cancelselectall", function () {
  214. // $("input[name='checkbox']").each(function (){
  215. // var index = rel_Ids.indexOf($(this).val());
  216. // if (index > -1) {
  217. // rel_Ids.splice(index, 1);
  218. // }
  219. // $(".fault_ids").val(rel_Ids.join(','));
  220. // $(this).removeAttr("checked");
  221. // });
  222. // });
  223. Form.api.bindevent($("form[role=form]"));
  224. }
  225. }
  226. };
  227. return Controller;
  228. });