Dispatch.js 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. Ext.QuickTips.init();
  2. Ext.define('erp.controller.pm.make.Dispatch', {
  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. 'core.form.Panel','pm.make.Dispatch','core.grid.Panel2','core.toolbar.Toolbar',
  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',
  11. 'core.button.ResSubmit','core.button.Scan','core.button.CopyAll','core.trigger.MultiDbfindTrigger2',
  12. 'core.trigger.DbfindTrigger','core.trigger.TextAreaTrigger','core.form.YnField'
  13. ],
  14. init:function(){
  15. var me = this;
  16. this.control({
  17. 'erpGridPanel2': {
  18. itemclick: function(selModel, record){
  19. if(!Ext.getCmp('grid').readOnly){
  20. this.onGridItemClick(selModel, record);
  21. }
  22. },
  23. afterrender : function(grid){
  24. //did_stepcode --->工序编号
  25. grid.plugins[0].on('beforeedit',function(e){
  26. if(e.field == 'did_stepcode'){
  27. var record = e.record;
  28. var column = e.column;
  29. var trigger = column.editor?column.editor:column.field;
  30. //如果did_craftcode ---->工艺路线
  31. if(record.data.hasOwnProperty('did_craftcode')){
  32. var did_craftcode = record.data['did_craftcode'];
  33. trigger.dbBaseCondition = "cd_crid = (select cr_id from craft where cr_code = '"+did_craftcode+"')";
  34. }
  35. }
  36. });
  37. }
  38. },
  39. 'erpSaveButton': {
  40. click: function(btn){
  41. var form = me.getForm(btn);
  42. if(Ext.getCmp(form.codeField).value == null || Ext.getCmp(form.codeField).value == ''){
  43. me.BaseUtil.getRandomNumber();//自动添加编号
  44. }
  45. me.setDetailEmcode();
  46. me.FormUtil.beforeSave(this);
  47. //me.beforeSaveUpdateSubmit('save');
  48. // if(r){
  49. // this.FormUtil.beforeSave(this);
  50. // }
  51. }
  52. },
  53. 'erpDeleteButton' : {
  54. click: function(btn){
  55. me.FormUtil.onDelete(Ext.getCmp('di_id').value);
  56. }
  57. },
  58. 'erpUpdateButton': {
  59. click: function(btn){
  60. me.setDetailEmcode();
  61. me.FormUtil.onUpdate(this);
  62. //me.beforeSaveUpdateSubmit('update');
  63. // if(r){
  64. // this.FormUtil.onUpdate(this);
  65. // }
  66. }
  67. },
  68. 'erpAddButton': {
  69. click: function(){
  70. me.FormUtil.onAdd('addDispatch', '新增生产日报', 'jsps/pm/make/dispatch.jsp?whoami=' + caller);
  71. }
  72. },
  73. 'erpCloseButton': {
  74. click: function(btn){
  75. me.FormUtil.beforeClose(me);
  76. }
  77. },
  78. 'erpSubmitButton': {
  79. afterrender: function(btn){
  80. var status = Ext.getCmp('di_statuscode');
  81. if(status && status.value != 'ENTERING'){
  82. btn.hide();
  83. }
  84. },
  85. click: function(btn){
  86. me.FormUtil.onSubmit(Ext.getCmp('di_id').value);
  87. //me.beforeSaveUpdateSubmit('submit');
  88. // if(r){
  89. // me.FormUtil.onSubmit(Ext.getCmp('di_id').value);
  90. // }
  91. }
  92. },
  93. 'dbfindtrigger[name=did_stepcode]': {
  94. focus: function(t) {
  95. t.setHideTrigger(false);
  96. t.setReadOnly(false);
  97. var grid=Ext.getCmp('grid');
  98. var dbfind='';
  99. Ext.Array.each(grid.columns,function(column) {
  100. if (column.dataIndex == 'did_stepcode' ) {
  101. dbfind=column.dbfind.split('|')[0];
  102. }
  103. });
  104. if(dbfind=='Ration'){
  105. var record = Ext.getCmp('grid').selModel.lastSelected;
  106. var code = record.data['did_prodcode'];
  107. if(code == null || code == ''){
  108. showError("请先选择关联单号!");
  109. t.setHideTrigger(true);
  110. t.setReadOnly(true);
  111. } else {
  112. t.dbBaseCondition = "ra_topmothercode='" + code + "'";
  113. }
  114. }
  115. }
  116. },
  117. 'erpResSubmitButton': {
  118. afterrender: function(btn){
  119. var status = Ext.getCmp('di_statuscode');
  120. if(status && status.value != 'COMMITED'){
  121. btn.hide();
  122. }
  123. },
  124. click: function(btn){
  125. me.FormUtil.onResSubmit(Ext.getCmp('di_id').value);
  126. }
  127. },
  128. 'erpAuditButton': {
  129. afterrender: function(btn){
  130. var status = Ext.getCmp('di_statuscode');
  131. if(status && status.value != 'COMMITED'){
  132. btn.hide();
  133. }
  134. },
  135. click: function(btn){
  136. me.FormUtil.onAudit(Ext.getCmp('di_id').value);
  137. }
  138. },
  139. 'erpResAuditButton': {
  140. afterrender: function(btn){
  141. var status = Ext.getCmp('di_statuscode');
  142. if(status && status.value != 'AUDITED'){
  143. btn.hide();
  144. }
  145. },
  146. click: function(btn){
  147. me.FormUtil.onResAudit(Ext.getCmp('di_id').value);
  148. }
  149. },
  150. 'erpPrintButton': {
  151. click: function(btn){
  152. me.FormUtil.onPrint(Ext.getCmp('di_id').value);
  153. }
  154. },
  155. 'erpCopyButton': {
  156. click:function(btn){
  157. warnMsg("确定复制?", function(btn){
  158. if(btn == 'yes'){
  159. me.FormUtil.getActiveTab().setLoading(true);//loading...
  160. Ext.Ajax.request({
  161. url : basePath + 'pm/make/copyDispatch.action',
  162. params: {
  163. id: Ext.getCmp('di_id').getValue()
  164. },
  165. method : 'post',
  166. callback : function(options,success,response){
  167. me.FormUtil.getActiveTab().setLoading(false);
  168. var localJson = new Ext.decode(response.responseText);
  169. if(localJson.exceptionInfo){
  170. showError(localJson.exceptionInfo);
  171. }
  172. if(localJson.success){
  173. turnSuccess(function(){
  174. var id = localJson.id;
  175. var url = "jsps/pm/make/dispatch.jsp?whoami=Dispatch!Base&formCondition=di_id=" + id + "&gridCondition=did_diid=" + id;
  176. me.FormUtil.onAdd('Dispatch' + id, '生产日报' + id, url);
  177. });
  178. }
  179. }
  180. });
  181. }
  182. });
  183. }
  184. }
  185. });
  186. },
  187. beforeSaveUpdateSubmit:function(type){
  188. var me = this;
  189. var grid = Ext.getCmp('grid');
  190. var o = new Object();
  191. var b = true; //true的时候 没有重复数据
  192. Ext.each(grid.getStore().data.items,function(item,index){
  193. if(!me.GridUtil.isBlank(grid,item.data)){
  194. // item.data['did_devicecode']; //流程单号
  195. // item.data['did_stepcode']; //工序编号
  196. var search_code = item.data['did_devicecode'] + item.data['did_stepcode'];
  197. if(!o.hasOwnProperty(search_code)){
  198. o[search_code] = true;
  199. //这个合成编号不存在
  200. }else {
  201. //这个合成编号存在 返回单号重复录入提示
  202. //b == false 存在重复数据
  203. b = false;
  204. return;
  205. }
  206. }
  207. });
  208. if(!b){
  209. showError('不能存在流程单号重复,并且工序编号重复的明细行!');
  210. }else{
  211. if (type == 'save'){
  212. me.FormUtil.beforeSave(me);
  213. } else if(type == 'update'){
  214. me.FormUtil.onUpdate(me);
  215. } else if(type == 'submit'){
  216. me.FormUtil.onSubmit(Ext.getCmp('di_id').value);
  217. }
  218. }
  219. },
  220. onGridItemClick: function(selModel, record){//grid行选择
  221. this.GridUtil.onGridItemClick(selModel, record);
  222. },
  223. getForm: function(btn){
  224. return btn.ownerCt.ownerCt;
  225. },
  226. setDetailEmcode: function(){
  227. if(Ext.getCmp('di_emcode')){ //di_emcode ---->员工编号
  228. var grid = Ext.getCmp('grid'), items = grid.store.data.items;
  229. var emcode = Ext.getCmp('di_emcode'), emname = Ext.getCmp('di_emname'); //员工编号 员工姓名
  230. if(emcode && emname) {
  231. Ext.Array.each(items, function(item){
  232. if(!Ext.isEmpty(item.data['did_makecode'])){
  233. item.set('pd_whcode', emcode.value);
  234. item.set('pd_whname', emname.value);
  235. }
  236. });
  237. }
  238. }
  239. }
  240. });