BOMBatchBack.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. Ext.QuickTips.init();
  2. Ext.define('erp.controller.pm.bom.BOMBatchBack', {
  3. extend: 'Ext.app.Controller',
  4. FormUtil: Ext.create('erp.util.FormUtil'),
  5. GridUtil: Ext.create('erp.util.GridUtil'),
  6. BaseUtil: Ext.create('erp.util.BaseUtil'),
  7. views:[
  8. 'pm.bom.BOMBatchBack','core.form.Panel','core.grid.Panel2','core.toolbar.Toolbar','core.button.Scan','core.button.Export',
  9. 'core.button.Save','core.button.Add','core.button.Submit','core.button.Print','core.button.Upload','core.button.ResAudit',
  10. 'core.button.Audit','core.button.Close','core.button.Delete','core.button.Update','core.button.DeleteDetail','core.button.ResSubmit',
  11. 'core.trigger.DbfindTrigger','core.trigger.TextAreaTrigger','core.button.CleanDetail','core.button.BOMBack'
  12. ],
  13. init:function(){
  14. var me = this;
  15. this.control({
  16. 'erpGridPanel2': {
  17. itemclick: this.onGridItemClick
  18. },
  19. 'erpUpdateButton': {
  20. click: function(btn){
  21. this.FormUtil.onUpdate(this);
  22. }
  23. },
  24. 'erpCloseButton': {
  25. click: function(btn){
  26. me.FormUtil.beforeClose(me);
  27. }
  28. },
  29. //bom批量批量反查
  30. 'erpBOMBackButton' : {
  31. click: function(btn){
  32. if(me.checkGridHaveItems()){
  33. me.beforeBomBack();
  34. }else{
  35. showMessage('提示', '没有需要批量反查的数据!', 1000);
  36. return ;
  37. }
  38. }
  39. },
  40. //清除明细
  41. 'erpCleanDetailButton' : {
  42. click: function(btn){
  43. var param = new Array();
  44. param = me.checkGridHaveItems();
  45. if(param.length == 0 || param == null){
  46. showMessage('提示', '没有需要清除的明细!', 1000);
  47. return ;
  48. }
  49. me.cleanDetail();
  50. }
  51. }
  52. /*'erpExportButton' : {
  53. afterrender:function(btn){
  54. btn.handler=function(){
  55. };
  56. },
  57. click:function(btn){
  58. //检查是否明细行是否有数据
  59. if(!me.checkGridHaveItems()){
  60. showMessage('提示', '没有需要导出的数据!', 1000);
  61. return ;
  62. }
  63. }
  64. }*/
  65. });
  66. },
  67. cleanDetail: function(){
  68. var grid=Ext.getCmp('grid');
  69. grid.setLoading(true);
  70. Ext.Ajax.request({
  71. url :basePath+ 'pm/bom/cleanBOMBatchBack.action',
  72. params: {
  73. id:Ext.getCmp('em_id').value
  74. },
  75. method : 'post',
  76. callback : function(options,success,response){
  77. grid.setLoading(false);
  78. var localJson = new Ext.decode(response.responseText);
  79. if(localJson.success){
  80. showMessage('提示', '操作成功!', 1000);
  81. //update成功后刷新页面进入可编辑的页面
  82. window.location.reload();
  83. } else if(localJson.exceptionInfo){
  84. showError(str);return;
  85. }
  86. }
  87. });
  88. },
  89. beforeBomBack: function(){
  90. //form里面数据
  91. var me = this;
  92. var grid = Ext.getCmp('grid');
  93. var param = new Array();
  94. param = me.checkGridHaveItems();
  95. if(param.length == 0 || param == null){
  96. showError("请先选择需要批量反查的物料明细");
  97. return ;
  98. }
  99. param = param == null ? [] : "[" + param.toString().replace(/\\/g,"%") + "]";
  100. me.FormUtil.setLoading(true);//loading...
  101. Ext.Ajax.request({
  102. url : basePath+'pm/bom/bomBack.action',
  103. params: {
  104. id:Ext.getCmp('em_id').value,
  105. gridStore:param
  106. },
  107. method : 'post',
  108. callback : function(options,success,response){
  109. me.FormUtil.setLoading(false);
  110. var localJson = new Ext.decode(response.responseText);
  111. if(localJson.success){
  112. showMessage('提示', '操作成功!', 1000);
  113. //导出
  114. var con="bm_emid="+em_uu+"and nvl(bm_level,0)>0";
  115. me.BaseUtil.createExcel('BOMStruct!ManyQuery!Query', 'detailgrid', con);
  116. grid.GridUtil.loadNewStore(grid, {
  117. caller: caller,
  118. condition: gridCondition
  119. });
  120. } else if(localJson.exceptionInfo){
  121. var str = localJson.exceptionInfo;
  122. showError(str);return;
  123. }
  124. }
  125. });
  126. },
  127. onGridItemClick: function(selModel, record){//grid行选择
  128. this.GridUtil.onGridItemClick(selModel, record);
  129. },
  130. getForm: function(btn){
  131. return btn.ownerCt.ownerCt;
  132. },
  133. checkGridHaveItems:function(){//检查明细行是否有明细
  134. var me = this;
  135. var grid = Ext.getCmp('grid');
  136. var jsonGridData = new Array();
  137. var form = Ext.getCmp('form');
  138. if(grid!=null){
  139. grid.getStore().each(function(item){//将grid里面各行的数据获取并拼成jsonGridData
  140. var data = Ext.clone(item.data);
  141. var dd = new Object();
  142. if(data[grid.necessaryField] != null && data[grid.necessaryField] != ""){
  143. if(grid.mainField && form && form.keyField){//例如,将pu_id的值赋给pd_puid
  144. dd[grid.mainField] = Ext.getCmp(form.keyField).value;
  145. }
  146. Ext.each(grid.columns, function(c){
  147. if((c.logic != 'ignore') && c.dataIndex){//只需显示,无需后台操作的字段,自动略去
  148. if(c.xtype == 'datecolumn'){
  149. if(Ext.isDate(data[c.dataIndex])){
  150. dd[c.dataIndex] = Ext.Date.toString(data[c.dataIndex]);//在这里把GMT日期转化成Y-m-d格式日期
  151. } else {
  152. dd[c.dataIndex] = Ext.Date.format(new Date(), 'Y-m-d');//如果用户没输入日期,或输入有误,就给个默认日期,
  153. //或干脆return;并且提示一下用户
  154. }
  155. } else if(c.xtype == 'numbercolumn'){//赋个默认值0吧,不然不好保存
  156. if(data[c.dataIndex] == null || data[c.dataIndex] == ''){
  157. dd[c.dataIndex] = '0';//也可以从data里面去掉这些字段
  158. } else {
  159. dd[c.dataIndex] = "" + data[c.dataIndex];
  160. }
  161. }else{
  162. dd[c.dataIndex] = data[c.dataIndex];
  163. }
  164. }
  165. });
  166. jsonGridData.push(Ext.JSON.encode(dd));
  167. }
  168. });
  169. return jsonGridData;
  170. }
  171. }
  172. });