WCPlanMaterialLack.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  1. Ext.QuickTips.init();
  2. Ext.define('erp.controller.pm.make.WCPlanMaterialLack', {
  3. extend: 'Ext.app.Controller',
  4. requires: ['erp.util.FormUtil', 'erp.util.GridUtil', 'erp.util.BaseUtil', 'erp.util.RenderUtil'],
  5. views:[
  6. 'common.batchDeal.Viewport','common.batchDeal.Form','pm.make.WCPlanMaterialLackGrid',
  7. 'core.trigger.DbfindTrigger','core.form.FtField','core.form.FtFindField','core.form.ConDateField',
  8. 'core.trigger.TextAreaTrigger','core.form.YnField', 'core.form.MonthDateField','core.button.Import','core.button.ImportAll'
  9. ],
  10. init:function(){
  11. var me = this;
  12. me.resized = false;
  13. this.control({
  14. 'erpBatchDealFormPanel': {
  15. alladded: function(form){
  16. var grid = Ext.getCmp('batchDealGridPanel');
  17. me.resize(form, grid);
  18. }
  19. },
  20. 'erpBatchDealGridPanel': {
  21. afterrender: function(grid){
  22. var form = Ext.getCmp('dealform');
  23. me.resize(form, grid);
  24. }
  25. },
  26. 'erpVastDealButton':{
  27. afterrender:function(btn){
  28. btn.show();
  29. btn.setText('二维导出');
  30. },
  31. click:function(btn){
  32. var grid =Ext.getCmp('batchDealGridPanel');
  33. var s=grid.getStore().data.items;
  34. var dd;
  35. jsonGridData = new Array();
  36. for(var i=0;i<s.length;i++){//将grid里面各行的数据获取并拼成jsonGridData
  37. var data = s[i].data;
  38. dd = new Object();
  39. Ext.each(grid.columns, function(c){
  40. if((!c.isCheckerHd)&&(c.logic != 'ignore')){//只需显示,无需后台操作的字段,自动略去
  41. if(c.xtype == 'datecolumn'){
  42. c.format = c.format || 'Y-m-d';
  43. if(Ext.isDate(data[c.dataIndex])){
  44. dd[c.dataIndex] = Ext.Date.format(data[c.dataIndex], c.format);
  45. } else {
  46. if(c.editor){
  47. dd[c.dataIndex] = Ext.Date.format(new Date(), c.format);//如果用户没输入日期,或输入有误,就给个默认日期,
  48. }
  49. }
  50. } else if(c.xtype == 'datetimecolumn'){
  51. if(Ext.isDate(data[c.dataIndex])){
  52. dd[c.dataIndex] = Ext.Date.format(data[c.dataIndex], 'Y-m-d H:i:s');//在这里把GMT日期转化成Y-m-d H:i:s格式日期
  53. } else {
  54. if(c.editor){
  55. dd[c.dataIndex] = Ext.Date.format(new Date(), 'Y-m-d H:i:s');//默认日期,
  56. }
  57. }
  58. } else if(c.xtype == 'numbercolumn'){//赋个默认值0吧,不然不好保存
  59. if(data[c.dataIndex] == null || data[c.dataIndex] == ''){
  60. dd[c.dataIndex] = '0';//也可以从data里面去掉这些字段
  61. } else {
  62. dd[c.dataIndex] = "" + s[i].data[c.dataIndex];
  63. }
  64. } else {
  65. dd[c.dataIndex] = s[i].data[c.dataIndex];
  66. }
  67. }
  68. });
  69. if(grid.mainField && form && form.keyField){//例如,将pu_id的值赋给pd_puid
  70. dd[grid.mainField] = Ext.getCmp(form.keyField).value;
  71. }
  72. jsonGridData.push(Ext.JSON.encode(dd));
  73. }
  74. var arr=new Array();
  75. Ext.Array.each(grid.columns,function(gridcolumn){
  76. dd = new Object();
  77. dd.dataIndex=gridcolumn.dataIndex;
  78. dd.xtype=gridcolumn.xtype;
  79. dd.text=gridcolumn.text;
  80. if(gridcolumn.columns){
  81. Ext.Array.each(gridcolumn.columns,function(column){
  82. dd=new Object();
  83. dd.dataIndex=column.dataIndex;
  84. dd.xtype=column.xtype;
  85. dd.text=column.dataIndex;
  86. arr.push(Ext.JSON.encode(dd));
  87. });
  88. }else arr.push(Ext.JSON.encode(dd));
  89. });
  90. var columns= unescape(arr.toString().replace(/\\/g,"%"));
  91. var param=jsonGridData;
  92. param=param=null?[]:'['+param.toString()+"]";
  93. var data=unescape(param.toString().replace(/\\/g,"%"));
  94. window.location.href=basePath+'excel/twoExport.action?data='+data+"&columns="+columns;
  95. }
  96. },
  97. 'button[id=query]':{
  98. beforerender:function(btn){
  99. btn.handler=function(select){
  100. var grid = Ext.getCmp('batchDealGridPanel'),sel = [];
  101. if(!grid){
  102. grid = Ext.getCmp('grid');
  103. }
  104. grid.multiselected = new Array();
  105. if(select == true) {
  106. sel = grid.selModel.getSelection();
  107. }
  108. var form = Ext.getCmp('dealform');
  109. var cond = me.getCondition(grid);
  110. if(Ext.isEmpty(cond)) {
  111. cond = '1=1';
  112. }
  113. form.beforeQuery(caller, cond);//执行查询前逻辑
  114. var gridParam = {caller: caller, condition: cond + form.getOrderBy(grid)};
  115. if(grid.getGridColumnsAndStore){
  116. grid.loadNewStore(grid, 'common/singleGridPanel.action', gridParam, "");
  117. }
  118. if(select == true) {
  119. Ext.each(sel, function(){
  120. grid.selModel.select(this.index);
  121. });
  122. }
  123. };
  124. }
  125. },
  126. 'erpImportButton':{
  127. click:function(btn){
  128. me.vastDeal(btn.ownerCt.ownerCt.dealUrl);
  129. }
  130. },
  131. 'erpImportAllButton':{
  132. click:function(btn){
  133. me.vastDeal(btn.ownerCt.ownerCt.dealUrl,'all');
  134. }
  135. }
  136. });
  137. },
  138. resize: function(form, grid){
  139. if(!this.resized && form && grid && form.items.items.length > 0){
  140. var height = window.innerHeight;
  141. if(Ext.isIE){
  142. height = screen.height*0.75;
  143. }
  144. var cw = 0;
  145. Ext.each(form.items.items, function(){
  146. if(!this.hidden && this.xtype != 'hidden') {
  147. cw += this.columnWidth;
  148. }
  149. });
  150. cw = Math.ceil(cw);
  151. if(cw == 0){
  152. cw = 5;
  153. } else if(cw > 2 && cw <= 5){
  154. cw -= 1;
  155. } else if(cw > 5 && cw < 8){
  156. cw = 4;
  157. }
  158. cw = Math.min(cw, 5);
  159. form.setHeight(height*cw/10 + 10);
  160. grid.setHeight(height*(10 - cw)/10 - 10);
  161. this.resized = true;
  162. }
  163. },
  164. countGrid: function(){
  165. //重新计算合计栏值
  166. var grid = Ext.getCmp('batchDealGridPanel');
  167. Ext.each(grid.columns, function(column){
  168. if(column.summary){
  169. var sum = 0;
  170. Ext.each(grid.store.data.items, function(item){
  171. if(item.value != null && item.value != ''){
  172. sum += Number(item.value);
  173. }
  174. });
  175. Ext.getCmp(column.dataIndex + '_sum').setText(column.text + '(sum):' + sum);
  176. } else if(column.average) {
  177. var average = 0;
  178. Ext.each(grid.store.data.items, function(item){
  179. if(item.value != null && item.value != ''){
  180. average += Number(item.value);
  181. }
  182. });
  183. average = average/grid.store.data.items.length;
  184. Ext.getCmp(column.dataIndex + '_average').setText(column.text + '(average):' + average);
  185. } else if(column.count) {
  186. var count = 0;
  187. Ext.each(grid.store.data.items, function(item){
  188. if(item.value != null && item.value != ''){
  189. count++;
  190. }
  191. });
  192. Ext.getCmp(column.dataIndex + '_count').setText(column.text + '(count):' + count);
  193. }
  194. });
  195. },
  196. getCondition:function(grid){
  197. grid = grid || Ext.getCmp('batchDealGridPanel');
  198. if(!grid){
  199. grid = Ext.getCmp('grid');
  200. }
  201. var form = Ext.getCmp('dealform');
  202. var condition = Ext.isEmpty(grid.defaultCondition) ? '' : ('(' + grid.defaultCondition + ')');
  203. Ext.each(form.items.items, function(f){
  204. if(f.name=='ml_kind'){
  205. if(f.value!=null&&f.value!=''){
  206. if(condition == ''){
  207. condition += f.value;
  208. } else {
  209. condition += ' AND ' + f.value;
  210. }
  211. }
  212. }else {
  213. if(f.logic != null && f.logic != ''){
  214. if(f.xtype == 'checkbox' && f.value == true){
  215. if(condition == ''){
  216. condition += f.logic;
  217. } else {
  218. condition += ' AND ' + f.logic;
  219. }
  220. } else if(f.xtype == 'datefield' && f.value != null){
  221. var v = Ext.Date.format(new Date(f.value), 'Y-m-d');
  222. if(condition == ''){
  223. condition += f.logic + "=to_date('" + v + "', 'yyyy-MM-dd')";
  224. } else {
  225. condition += ' AND ' + f.logic + "=to_date('" + v + "', 'yyyy-MM-dd')";
  226. }
  227. } else if(f.xtype == 'datetimefield' && f.value != null){
  228. var v = Ext.Date.format(new Date(f.value), 'Y-m-d H:i:s');
  229. if(condition == ''){
  230. condition += f.logic + "=to_date('" + v + "', 'yyyy-MM-dd HH24:mi:ss')";
  231. } else {
  232. condition += ' AND ' + f.logic + "=to_date('" + v + "', 'yyyy-MM-dd HH24:mi:ss')";
  233. }
  234. } else if(f.xtype == 'numberfield' && f.value != null && f.value != ''){
  235. if(condition == ''){
  236. condition += f.logic + '=' + f.value;
  237. } else {
  238. condition += ' AND ' + f.logic + '=' + f.value;
  239. }
  240. } else if(f.xtype == 'combo' && f.value == '$ALL'){
  241. if(f.store.data.length > 1) {
  242. if(condition == ''){
  243. condition += '(';
  244. } else {
  245. condition += ' AND (';
  246. }
  247. f.store.each(function(d, idx){
  248. if(d.data.value != '$ALL') {
  249. if(idx == 0){
  250. condition += f.logic + "='" + d.data.value + "'";
  251. } else {
  252. condition += ' OR ' + f.logic + "='" + d.data.value + "'";
  253. }
  254. }
  255. });
  256. condition += ')';
  257. }
  258. } else {
  259. //一般情况下,在执行批量处理时,是不需要把form的数据传回去,
  260. //但某些情况下,需要将form的某些字段的值也传回去
  261. //例如 请购批量转采购,如果指定了采购单号,就要把采购单号传回去
  262. if(contains(f.logic, 'to:', true)){
  263. if(!grid.toField){
  264. grid.toField = new Array();
  265. }
  266. grid.toField.push(f.logic.split(':')[1]);
  267. } else {
  268. if(!Ext.isEmpty(f.value)){
  269. if(contains(f.value.toString(), 'BETWEEN', true) && contains(f.value.toString(), 'AND', true)){
  270. if(condition == ''){
  271. condition += f.logic + " " + f.value;
  272. } else {
  273. condition += ' AND (' + f.logic + " " + f.value + ")";
  274. }
  275. } else if(contains(f.value.toString(), '||', true)){
  276. var str = '';
  277. Ext.each(f.value.split('||'), function(v){
  278. if(v != null && v != ''){
  279. if(str == ''){
  280. str += f.logic + "='" + v + "'";
  281. } else {
  282. str += ' OR ' + f.logic + "='" + v + "'";
  283. }
  284. }
  285. });
  286. if(condition == ''){
  287. condition += "(" + str + ")";
  288. } else {
  289. condition += ' AND (' + str + ")";
  290. }
  291. } else if(f.value.toString().charAt(0) == '!'){
  292. if(condition == ''){
  293. condition += 'nvl(' + f.logic + ",' ')<>'" + f.value.substr(1) + "'";
  294. } else {
  295. condition += ' AND (nvl(' + f.logic + ",' ')<>'" + f.value.substr(1) + "')";
  296. }
  297. } else {
  298. if(condition == ''){
  299. condition += f.logic + "='" + f.value + "'";
  300. } else {
  301. condition += ' AND (' + f.logic + "='" + f.value + "')";
  302. }
  303. }
  304. }
  305. }
  306. }
  307. }
  308. }
  309. });
  310. return condition;
  311. },
  312. vastDeal: function(url,type){
  313. var grid = Ext.getCmp('batchDealGridPanel');
  314. var form = Ext.getCmp('dealform');
  315. var wc_id=getUrlParam('keyValue');
  316. var panelId=getUrlParam('panelId');
  317. var records =null;
  318. if(type&&type=='all'){
  319. records=Ext.Array.unique(grid.getStore().data.items);
  320. }else {
  321. var items = grid.selModel.getSelection();
  322. Ext.each(items, function(item, index){
  323. if(this.data[grid.keyField] != null && this.data[grid.keyField] != ''
  324. && this.data[grid.keyField] != '0' && this.data[grid.keyField] != 0){
  325. item.index = this.data[grid.keyField];
  326. grid.multiselected.push(item);
  327. }
  328. });
  329. records = Ext.Array.unique(grid.multiselected);
  330. }
  331. if(records.length > 0){
  332. var params = new Object();
  333. params.caller = caller;
  334. var data = new Array();
  335. var bool = false;
  336. Ext.each(records, function(record, index){
  337. var f = form.fo_detailMainKeyField;
  338. if((grid.keyField && this.data[grid.keyField] != null && this.data[grid.keyField] != ''
  339. && this.data[grid.keyField] != '0' && this.data[grid.keyField] != 0)
  340. ||(f && this.data[f] != null && this.data[f] != ''
  341. && this.data[f] != '0' && this.data[f] != 0)){
  342. bool = true;
  343. var o = new Object();
  344. if(grid.keyField){
  345. o[grid.keyField] = record.data[grid.keyField];
  346. } else {
  347. params.id[index] = record.data[form.fo_detailMainKeyField];
  348. }
  349. if(grid.toField){
  350. Ext.each(grid.toField, function(f, index){
  351. var v = Ext.getCmp(f).value;
  352. if(v != null && v.toString().trim() != '' && v.toString().trim() != 'null'){
  353. o[f] = v;
  354. }
  355. });
  356. }
  357. if(grid.necessaryFields){
  358. Ext.each(grid.necessaryFields, function(f, index){
  359. var v = record.data[f];
  360. if(Ext.isDate(v)){
  361. v = Ext.Date.toString(v);
  362. }
  363. o[f] = v;
  364. });
  365. }
  366. data.push(o);
  367. }
  368. });
  369. if(bool){
  370. params.data = unescape(Ext.JSON.encode(data).replace(/\\/g,"%"));
  371. params.wc_id=wc_id;
  372. var main = parent.Ext.getCmp("content-panel");
  373. main.getActiveTab().setLoading(true);//loading...
  374. Ext.Ajax.request({
  375. url : basePath + url,
  376. params: params,
  377. method : 'post',
  378. callback : function(options,success,response){
  379. main.getActiveTab().setLoading(false);
  380. var localJson = new Ext.decode(response.responseText);
  381. if(localJson.exceptionInfo){
  382. var str = localJson.exceptionInfo;
  383. if(str.trim().substr(0, 12) == 'AFTERSUCCESS'){
  384. str = str.replace('AFTERSUCCESS', '');
  385. grid.multiselected = new Array();
  386. Ext.getCmp('dealform').onQuery();
  387. }
  388. showError(str);return;
  389. }
  390. if(localJson.success){
  391. if(localJson.log){
  392. showMessage("提示", localJson.log);
  393. }
  394. Ext.Msg.alert("提示", "处理成功!", function(){
  395. /*grid.multiselected = new Array();
  396. Ext.getCmp('dealform').onQuery();*/
  397. var panel=parent.Ext.getCmp(panelId);
  398. main.getActiveTab().close();
  399. var loadgrid=panel.currentGrid;
  400. loadgrid.getGridColumnsAndStore(grid,'common/singleGridPanel.action',{caller:'WCPlan',condition:'wd_wcid='+wc_id});
  401. main.setActiveTab(panel);
  402. });
  403. }
  404. }
  405. });
  406. } else {
  407. showError("没有需要处理的数据!");
  408. }
  409. }
  410. },
  411. });