task.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. $('.btn-add').data('area',['80%','80%']);
  5. $('.btn-edit,.btn-editone').data('area',['80%','80%']);
  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. search:false,
  28. showExport:false,
  29. showToggle:false,
  30. showColumns: false,
  31. columns: [
  32. [
  33. {checkbox: true},
  34. // {field: 'task_id', title: __('Task_id'),operate: false,width:'80px'},
  35. {field: 'name', title: __('Name'), operate: 'LIKE', table: table, class: 'autocontent', formatter: Table.api.formatter.content},
  36. {field: 'sim_type', title: __('Sim_type'),searchList:{"0001":"FZD04B型侦毒器","0002":"FZB006型毒剂报警器","0003":"防化兵用毒剂报警器"},formatter: Table.api.formatter.simtype},
  37. {field: 'fault_name', title: __('具体故障清单'),formatter: Table.api.formatter.faultname, operate: 'LIKE'},
  38. {field: 'operate', title: __('Operate'), table: table,
  39. events: Table.api.events.operate,
  40. // formatter: Table.api.formatter.operate,
  41. formatter: Table.api.formatter.buttons,
  42. buttons: [
  43. {
  44. name: 'dispatch',
  45. text: '编辑',
  46. icon: 'fa fa-pencil',
  47. title: '编辑',
  48. classname: 'btn btn-success btn-xs btn-magic btn-dialog',
  49. extend: 'data-area=\'["75%","75%"]\'',
  50. url: 'teacher/task/edit',
  51. },{
  52. name: 'dispatch',
  53. text: '删除',
  54. icon: 'fa fa-trash',
  55. title: '删除',
  56. classname: 'btn btn-danger btn-xs btn-magic btn-ajax',
  57. url: 'teacher/task/del',
  58. confirm: '确定要删除吗?',
  59. success: function (data, ret) {
  60. $(".btn-refresh").trigger("click");
  61. },
  62. error: function (data, ret) {
  63. Layer.alert(ret.msg);
  64. return false;
  65. }
  66. }
  67. ],
  68. }
  69. ]
  70. ]
  71. });
  72. // 为表格绑定事件
  73. Table.api.bindevent(table);
  74. },
  75. add: function () {
  76. Controller.api.bindevent();
  77. },
  78. edit: function () {
  79. Controller.api.bindevent();
  80. },
  81. api: {
  82. bindevent: function () {
  83. var rel_Ids = [];
  84. var rel_Names = [];
  85. var prel_Ids = [];
  86. if(Config.rel_Ids){
  87. $.each(Config.rel_Ids, function(index, value) {
  88. rel_Ids.push(value);
  89. });
  90. $.each(Config.rel_Names, function(index, value) {
  91. rel_Names.push(value);
  92. });
  93. $.each(Config.prel_Ids, function(index, value) {
  94. prel_Ids.push(value);
  95. });
  96. }
  97. $('select[name="row[sim_type]"]').change(function () {
  98. $(".fault_ids").val('');
  99. $(".fault_names").val('');
  100. $(".pfault_ids").val('');
  101. rel_Ids = [];
  102. rel_Names = [];
  103. prel_Ids = [];
  104. console.log($(this).val());
  105. console.log( $(this).find("option:selected").text())
  106. var xinghao = $(this).find("option:selected").text();
  107. $.ajax({
  108. url: "fault/getdatalist",
  109. type: 'post',
  110. data: {
  111. simtype: $(this).val(),
  112. },
  113. success: function (data) {
  114. if(data.code==1){
  115. var task_tr = '';
  116. var ret = data.data;
  117. for (var i = 0; i < ret.length; i++) {
  118. if(ret[0].sim_type == '0001'){
  119. task_tr += '<tr>';
  120. if(i==0){
  121. task_tr += ' <td rowspan="11">'+xinghao+'</td>';
  122. }
  123. if(i<4){
  124. task_tr += ' <td rowspan="2">'+ret[i].name+'</td>';
  125. }else{
  126. task_tr += ' <td rowspan="1">'+ret[i].name+'</td>';
  127. }
  128. for (var j = 0; j < ret[i].children.length; j++) {
  129. var ret1 = ret[i].children;
  130. if(j>0){
  131. task_tr += ' </tr><tr><td>'+ret1[j].name+'</td>';
  132. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'" pvalue="'+ret[i].fault_id+'"></td>';
  133. }else{
  134. task_tr += ' <td>'+ret1[j].name+'</td>';
  135. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'" pvalue="'+ret[i].fault_id+'"></td>';
  136. }
  137. }
  138. task_tr += '</tr>';
  139. }else if(ret[0].sim_type == '0002'){
  140. task_tr += '<tr>';
  141. if(i==0){
  142. task_tr += ' <td rowspan="15">'+xinghao+'</td>';
  143. }
  144. if(i<5){
  145. task_tr += ' <td rowspan="2">'+ret[i].name+'</td>';
  146. }else{
  147. task_tr += ' <td rowspan="1">'+ret[i].name+'</td>';
  148. }
  149. for (var j = 0; j < ret[i].children.length; j++) {
  150. var ret1 = ret[i].children;
  151. if(j>0){
  152. task_tr += ' </tr><tr><td>'+ret1[j].name+'</td>';
  153. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'" pvalue="'+ret[i].fault_id+'"></td>';
  154. }else{
  155. task_tr += ' <td>'+ret1[j].name+'</td>';
  156. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'" pvalue="'+ret[i].fault_id+'"></td>';
  157. }
  158. }
  159. }else if(ret[0].sim_type == '0003'){
  160. task_tr += '<tr>';
  161. if(i==0){
  162. task_tr += ' <td rowspan="15">'+xinghao+'</td>';
  163. }
  164. if(i<4){
  165. task_tr += ' <td rowspan="2">'+ret[i].name+'</td>';
  166. }else if(i==4){
  167. task_tr += ' <td rowspan="3">'+ret[i].name+'</td>';
  168. }else if(i==5){
  169. task_tr += ' <td rowspan="2">'+ret[i].name+'</td>';
  170. }else{
  171. task_tr += ' <td rowspan="1">'+ret[i].name+'</td>';
  172. }
  173. for (var j = 0; j < ret[i].children.length; j++) {
  174. var ret1 = ret[i].children;
  175. if(j>0){
  176. task_tr += ' </tr><tr><td>'+ret1[j].name+'</td>';
  177. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'" pvalue="'+ret[i].fault_id+'"></td>';
  178. }else{
  179. task_tr += ' <td>'+ret1[j].name+'</td>';
  180. task_tr += ' <td><input type="checkbox" name="checkbox" value="'+ret1[j].fault_id+'" vname="'+ret1[j].name+'" pvalue="'+ret[i].fault_id+'"></td>';
  181. }
  182. }
  183. }
  184. }
  185. $(".task_list").html(task_tr);
  186. }
  187. }
  188. });
  189. });
  190. //只允许选择三个故障
  191. $(document).on('click', "input[type='checkbox']", function () {
  192. if ($(this).attr("checked")) {
  193. var index = rel_Ids.indexOf($(this).val());
  194. if (index > -1) {
  195. rel_Ids.splice(index, 1);
  196. rel_Names.splice(rel_Names.indexOf($(this).attr('vname')), 1);
  197. prel_Ids.splice(prel_Ids.indexOf($(this).attr('pvalue')), 1);
  198. }
  199. $(".fault_ids").val(rel_Ids.join(','));
  200. $(".fault_names").val(rel_Names.join(','));
  201. $(".pfault_ids").val(prel_Ids.join(','))
  202. $(this).removeAttr("checked");
  203. } else {
  204. if(rel_Ids.length>2){
  205. Layer.alert('故障内容最多允许选择3个');
  206. return false
  207. }
  208. var pfault_id = $(this).attr('pvalue');
  209. var index2 = prel_Ids.indexOf(pfault_id);
  210. if (index2 > -1) {
  211. Layer.alert('一个故障现象下只允许申请一个故障部位');
  212. return false
  213. }
  214. prel_Ids.push(pfault_id);
  215. $(".pfault_ids").val(prel_Ids.join())
  216. $(this).attr("checked", "true");
  217. rel_Ids.push($(this).val());
  218. $(".fault_ids").val(rel_Ids.join())
  219. rel_Names.push($(this).attr('vname'));
  220. $(".fault_names").val(rel_Names.join(','));
  221. }
  222. });
  223. Form.api.bindevent($("form[role=form]"));
  224. }
  225. }
  226. };
  227. return Controller;
  228. });