SetProdLabelTemplate.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. Ext.QuickTips.init();
  2. Ext.define('erp.controller.scm.product.SetProdLabelTemplate', {
  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','scm.product.SetProdLabelTemplate','core.grid.Panel2','core.toolbar.Toolbar',
  9. 'core.button.Close','core.button.Save','core.button.CleanDetail','core.button.Update',
  10. 'core.trigger.DbfindTrigger','core.trigger.TextAreaTrigger','core.form.YnField','core.button.Query'
  11. ],
  12. init:function(){
  13. var me = this;
  14. this.control({
  15. 'erpGridPanel2': {
  16. itemclick: this.onGridItemClick
  17. },
  18. 'erpCleanDetailButton' : {
  19. click: function(btn){
  20. var param = me.getGridItems();
  21. if(param == null || param == ''){
  22. showError("没有需要清除的明细");
  23. return ;
  24. }
  25. me.cleanDetail();
  26. }
  27. },
  28. 'erpUpdateButton': {
  29. click: function(btn){
  30. //"PL_SOFT"给grid
  31. var labelSoft = Ext.getCmp('pl_labelsoft');
  32. var grid = Ext.getCmp('grid');
  33. var num = grid.getStore().data.length;
  34. for(var i=0 ; i < num ; i++){
  35. var record = grid.getStore().getAt(i);
  36. }
  37. this.FormUtil.onUpdate(this);
  38. }
  39. },
  40. 'erpCloseButton': {
  41. click: function(btn){
  42. me.FormUtil.beforeClose(me);
  43. }
  44. },
  45. 'erpQueryButton': {
  46. click: function(btn){
  47. var grid = Ext.getCmp('grid');
  48. var gridCondition = "pl_prodcode='"+Ext.getCmp('pr_code').value+"'";
  49. var gridParam = {caller: caller, condition: gridCondition};
  50. me.GridUtil.loadNewStore(grid, gridParam);
  51. }
  52. }
  53. });
  54. },
  55. onGridItemClick: function(selModel, record){//grid行选择
  56. this.GridUtil.onGridItemClick(selModel, record);
  57. },
  58. getForm: function(btn){
  59. return btn.ownerCt.ownerCt;
  60. },
  61. Query: function(){
  62. },
  63. cleanDetail: function(){
  64. var grid=Ext.getCmp('grid');
  65. grid.setLoading(true);
  66. Ext.Ajax.request({
  67. url :basePath+ 'scm/product/cleanMakeSNCode.action',
  68. params: {
  69. id:Ext.getCmp('pr_id').value,
  70. code:Ext.getCmp('pr_code').value
  71. },
  72. method : 'post',
  73. callback : function(options,success,response){
  74. grid.setLoading(false);
  75. var localJson = new Ext.decode(response.responseText);
  76. if(localJson.success){
  77. showMessage('提示', '操作成功!', 1000);
  78. //update成功后刷新页面进入可编辑的页面
  79. window.location.reload();
  80. } else if(localJson.exceptionInfo){
  81. showError(localJson.exceptionInfo);return;
  82. }
  83. }
  84. });
  85. },
  86. getGridItems :function(){//检查明细行是否有明细
  87. var grid = Ext.getCmp('grid');
  88. var jsonGridData = new Array();
  89. var form = Ext.getCmp('form');
  90. if(grid!=null){
  91. grid.getStore().each(function(item){//将grid里面各行的数据获取并拼成jsonGridData
  92. var data = Ext.clone(item.data);
  93. var dd = new Object();
  94. if(data[grid.necessaryField] != null && data[grid.necessaryField] != ""){
  95. if(grid.mainField && form && form.keyField){//例如,将pu_id的值赋给pd_puid
  96. dd[grid.mainField] = Ext.getCmp(form.keyField).value;
  97. }
  98. Ext.each(grid.columns, function(c){
  99. if((c.logic != 'ignore') && c.dataIndex){//只需显示,无需后台操作的字段,自动略去
  100. if(c.xtype == 'datecolumn'){
  101. if(Ext.isDate(data[c.dataIndex])){
  102. dd[c.dataIndex] = Ext.Date.toString(data[c.dataIndex]);//在这里把GMT日期转化成Y-m-d格式日期
  103. } else {
  104. dd[c.dataIndex] = Ext.Date.format(new Date(), 'Y-m-d');//如果用户没输入日期,或输入有误,就给个默认日期,
  105. //或干脆return;并且提示一下用户
  106. }
  107. } else if(c.xtype == 'numbercolumn'){//赋个默认值0吧,不然不好保存
  108. if(data[c.dataIndex] == null || data[c.dataIndex] == ''){
  109. dd[c.dataIndex] = '0';//也可以从data里面去掉这些字段
  110. } else {
  111. dd[c.dataIndex] = "" + data[c.dataIndex];
  112. }
  113. }else{
  114. dd[c.dataIndex] = data[c.dataIndex];
  115. }
  116. }
  117. });
  118. jsonGridData.push(Ext.JSON.encode(dd));
  119. }
  120. });
  121. return jsonGridData;
  122. }
  123. }
  124. });