order.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. // 初始化表格参数配置
  5. Table.api.init({
  6. extend: {
  7. index_url: 'order/index' + location.search,
  8. add_url: 'order/add',
  9. edit_url: 'order/edit',
  10. del_url: 'order/del',
  11. multi_url: 'order/multi',
  12. import_url: 'order/import',
  13. table: 'order',
  14. }
  15. });
  16. var table = $("#table");
  17. // 初始化表格
  18. table.bootstrapTable({
  19. url: $.fn.bootstrapTable.defaults.extend.index_url,
  20. pk: 'id',
  21. sortName: 'id',
  22. fixedColumns: true,
  23. fixedRightNumber: 1,
  24. columns: [
  25. [
  26. {checkbox: true},
  27. {field: 'id', title: __('Id')},
  28. // {field: 'user_id', title: __('User_id')},
  29. {field: 'no', title: __('No'), operate: 'LIKE'},
  30. {field: 'customer', title: __('Customer'), operate: 'LIKE'},
  31. {field: 'product', title: __('Product'), operate: 'LIKE'},
  32. {field: 'specs', title: __('Specs'), operate: 'LIKE'},
  33. {field: 'unit', title: __('Unit'), operate: 'LIKE'},
  34. {field: 'number', title: __('Number')},
  35. {field: 'price', title: __('Price'), operate: 'LIKE'},
  36. {field: 'delivery_date', title: __('Delivery_date'), operate: 'LIKE'},
  37. {field: 'remark', title: __('Remark'), operate: 'LIKE'},
  38. {field: 'date', title: __('Date'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  39. {field: 'user_name', title: __('User_name'), operate: 'LIKE'},
  40. {field: 'examine', title: __('Examine'), operate: 'LIKE'},
  41. {field: 'status', title: __('Status'), searchList: {"1":__('计划中'),"2":__('生产中'),"3":__('已完成')}, formatter: Table.api.formatter.status},
  42. // {field: 'create', title: __('Create'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  43. // {field: 'update', title: __('Update'), operate:'RANGE', addclass:'datetimerange', autocomplete:false},
  44. // {field: 'company_id', title: __('Company_id')},
  45. // {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  46. {field: 'operate', title: '操作', buttons:[{
  47. name:'task',
  48. text:'生成作业票',
  49. title:'生成作业票',
  50. icon:'fa fa-add',
  51. extend: 'data-area=["100%","100%"]',
  52. classname:'btn btn-xs btn-info btn-fields btn-dialog task',
  53. url:'order/task',
  54. }],
  55. table: table,
  56. events: Table.api.events.operate, formatter: Table.api.formatter.operate
  57. },
  58. ]
  59. ]
  60. });
  61. table.on('post-body.bs.table',function(){
  62. $(".btn-editone").data("area",["100%","100%"]);
  63. })
  64. // 为表格绑定事件
  65. Table.api.bindevent(table);
  66. },
  67. add: function () {
  68. Controller.api.bindevent();
  69. },
  70. edit: function () {
  71. Controller.api.bindevent();
  72. },
  73. task: function () {
  74. $('#add').click(function () {
  75. //配方获取和计算
  76. var ids = $('#c-name').val();
  77. // console.log(ids);return false;
  78. var number = $('#c-number').val();
  79. if (number == ''){
  80. layer.confirm('生产量不能为空');
  81. return false;
  82. }
  83. //给打印界面赋值
  84. $('.total').text(number);
  85. var remark = $('#c-remark').val();
  86. remark = '备注:'+remark;
  87. //给打印表头赋值
  88. var bach = $('#c-bach').val();
  89. $('#bach').text(bach);
  90. //获取配方名称,去掉版本号
  91. var formula = $('#c-name').find("option:selected").text();
  92. var n = formula.indexOf("v");
  93. if (n >= 0){
  94. formula = formula.slice(0,n);
  95. }
  96. // console.log(formula);return false;
  97. $('#formula').val(formula);
  98. var drawer_name = $('#c-drawer_name').val();
  99. $('#drawer_name').text(drawer_name);
  100. var examine_name = $('#c-examine_name').val();
  101. $('#examine_name').text(examine_name);
  102. $.ajax({
  103. type: "POST",
  104. url: "formula/getNumber",
  105. data: {
  106. 'ids': ids,
  107. 'number': number
  108. },
  109. success:function(data) {
  110. if (1 == data.status)
  111. {
  112. var html = '';
  113. var str = '';
  114. $.each(data.data,function (key,value){
  115. html += '<tr><td><input class="form-control material" type="text" value="'+value.material+'"></td>';
  116. html += '<td><input class="form-control percentage" type="text" value="'+value.percentage+'"></td>';
  117. html += '<td><input class="form-control num" type="text" value="'+value.num+'"></td>';
  118. html += '<td><input class="form-control gy_name" type="text" value="'+value.gy_name+'"></td>';
  119. html += '<td><input class="form-control gy_num" type="text" value="'+value.gy_num+'"></td>';
  120. str += '<tr><td style="width: 100px;text-align: center">'+value.material+'</td>';
  121. str += '<td style="width: 100px;text-align: center">'+value.num+'</td>';
  122. str += '<td style="width: 100px;text-align: center"> </td>';
  123. str += '<td style="width: 400px;">'+value.gy_name+'</td></tr>';
  124. })
  125. $('#gy').text('');
  126. $('#gy').append(html);
  127. str += '<tr><td style="width: 100px;text-align: center">总计</td><td class="total" style="width: 100px;text-align: center">'+number+'</td> <td></td><td></td></tr>';
  128. str += '<tr> <td colspan="5" class="remark">'+remark+'</td></tr>';
  129. $('#print').text('');
  130. $('#print').append(str);
  131. $('#formula_no').text(data.formula_no);
  132. $('#date').text(data.date);
  133. }else {
  134. layer.confirm(data.msg);
  135. }
  136. }
  137. })
  138. })
  139. Controller.api.bindevent();
  140. $(document).on('click','.submit',function () {
  141. Form.api.bindevent($("form[role=form]"), function(data, ret){
  142. Toastr.success('111');//成功
  143. }, function(data, ret){
  144. Toastr.success("222");
  145. }, function(success, error){
  146. var verify = 1;
  147. var ids = $('#c-name').val();
  148. //获取配方名称,去掉版本号
  149. var name = $('#c-name').find("option:selected").text();
  150. var n = name.indexOf("v");
  151. if (n >= 0){
  152. name = name.slice(0,n);
  153. }
  154. // console.log(formula);return false;
  155. if (name == '' || name== undefined) {
  156. verify = -1;
  157. }
  158. var bach = $('#c-bach').val();
  159. if (bach == '' || bach== undefined) {
  160. verify = -1;
  161. }
  162. var drawer_name = $('#c-drawer_name').val();
  163. if (drawer_name == '' || drawer_name== undefined) {
  164. verify = -1;
  165. }
  166. var examine_name = $('#c-examine_name').val();
  167. if (examine_name == '' || examine_name== undefined) {
  168. verify = -1;
  169. }
  170. var number = $('#c-number').val();
  171. if (number == '' || number== undefined) {
  172. verify = -1;
  173. }
  174. var remark = $('#c-remark').val();
  175. if (verify == -1){
  176. layer.confirm("数据格式不对,请仔细核查!");return false;
  177. }
  178. //基础数据
  179. var baseData = [];
  180. baseData.push(ids);
  181. baseData.push(name);
  182. baseData.push(bach);
  183. baseData.push(drawer_name);
  184. baseData.push(examine_name);
  185. baseData.push(number);
  186. baseData.push(remark);
  187. Fast.api.ajax({
  188. url:'formula/task?ids='+ids,
  189. data:{baseData:baseData}
  190. },function (data,ret) {
  191. //成功回调
  192. parent.Toastr.success("添加成功");
  193. Fast.api.close();
  194. parent.Fast.api.refreshmenu();
  195. return false;
  196. },function (data,ret) {
  197. parent.Toastr.error("添加失败");
  198. Fast.api.close();
  199. return false;
  200. });
  201. return false;
  202. });
  203. });
  204. },
  205. api: {
  206. bindevent: function () {
  207. Form.api.bindevent($("form[role=form]"));
  208. }
  209. }
  210. };
  211. return Controller;
  212. });