Ext.QuickTips.init(); Ext.define('erp.controller.scm.sale.SaleChange', { extend: 'Ext.app.Controller', FormUtil: Ext.create('erp.util.FormUtil'), GridUtil: Ext.create('erp.util.GridUtil'), BaseUtil: Ext.create('erp.util.BaseUtil'), views:[ 'core.form.Panel','scm.sale.SaleChange','core.grid.Panel2','core.toolbar.Toolbar','core.form.FileField', 'core.button.Save','core.button.Add','core.button.Submit','core.button.Print','core.button.Upload','core.button.ResAudit', 'core.button.Audit','core.button.Close','core.button.Delete','core.button.Update','core.button.DeleteDetail', 'core.button.ResSubmit','core.form.FileField', 'core.form.MultiField','core.trigger.MultiDbfindTrigger', 'core.trigger.DbfindTrigger','core.trigger.TextAreaTrigger','core.form.YnField','core.grid.YnColumnNV' ], init:function(){ var me = this; this.control({ 'erpGridPanel2': { itemclick: this.onGridItemClick }, 'erpSaveButton': { click: function(btn){ var form = me.getForm(btn); if(Ext.getCmp(form.codeField).value == null || Ext.getCmp(form.codeField).value == ''){ me.BaseUtil.getRandomNumber();//自动添加编号 } var grid = Ext.getCmp('grid'), items = grid.store.data.items, bool = true; Ext.Array.each(items, function(item){ if(!Ext.isEmpty(item.data['scd_sddetno'])){ if(Ext.isEmpty(item.data['scd_newdelivery'])){ item.set('scd_newdelivery', Ext.getCmp('scd_delivery')); } } }); if(bool) this.FormUtil.beforeSave(this); } }, 'erpDeleteButton' : { click: function(btn){ me.FormUtil.onDelete(Ext.getCmp('sc_id').value); } }, 'erpUpdateButton': { click: function(btn){ var grid = Ext.getCmp('grid'), items = grid.store.data.items, bool = true; Ext.Array.each(items, function(item){ if(!Ext.isEmpty(item.data['scd_sddetno'])){ if(Ext.isEmpty(item.data['scd_newdelivery'])){ item.set('scd_newdelivery', Ext.getCmp('scd_delivery')); } } }); if(bool) this.FormUtil.onUpdate(this); } }, 'erpAddButton': { click: function(){ me.FormUtil.onAdd('addSaleChange', '新增销售变更单', 'jsps/scm/sale/saleChange.jsp?whoami=' + caller); } }, 'erpCloseButton': { click: function(btn){ me.FormUtil.beforeClose(me); } }, 'erpSubmitButton': { afterrender: function(btn){ var status = Ext.getCmp('sc_statuscode'); if(status && status.value != 'ENTERING'){ btn.hide(); } }, click: function(btn){ me.onSubmit(Ext.getCmp('sc_id').value); } }, 'erpResSubmitButton': { afterrender: function(btn){ var status = Ext.getCmp('sc_statuscode'); if(status && status.value != 'COMMITED'){ btn.hide(); } }, click: function(btn){ me.FormUtil.onResSubmit(Ext.getCmp('sc_id').value); } }, 'erpAuditButton': { afterrender: function(btn){ var status = Ext.getCmp('sc_statuscode'); if(status && status.value != 'COMMITED'){ btn.hide(); } }, click: function(btn){ me.FormUtil.onAudit(Ext.getCmp('sc_id').value); } }, 'erpResAuditButton': { afterrender: function(btn){ var status = Ext.getCmp('sc_statuscode'); if(status && status.value != 'AUDITED'){ btn.hide(); } }, click: function(btn){ me.FormUtil.onResAudit(Ext.getCmp('sc_id').value); } }, 'erpPrintButton': { click:function(btn){ var reportName="SaleChange"; var condition='{SaleChange.sc_id}='+Ext.getCmp('sc_id').value+''; var id=Ext.getCmp('sc_id').value; me.FormUtil.onwindowsPrint2(id,reportName,condition); } }, 'dbfindtrigger[name=scd_sddetno]': { focus: function(t){ t.setHideTrigger(false); t.setReadOnly(false); var record = Ext.getCmp('grid').selModel.lastSelected; var code = record.data['scd_sacode']; var grid = Ext.getCmp('grid'); if(code == null || code == ''){ showError("请先选择订单号!"); t.setHideTrigger(true); t.setReadOnly(true); } else { t.dbBaseCondition = "sa_code='" + code + "'"; } var cond ="(sa_code='"+code+"' "; var arr = new Array(); Ext.each(grid.store.data.items, function(item){ if(item.data['scd_sacode'] != null && item.data['scd_sacode'] != '' && item.data['scd_sddetno'] != null && item.data['scd_sddetno'] !=''){ if(item.data['scd_sacode'] ==code){ arr.push("sd_detno<>"+item.data['scd_sddetno']); } } }); if(arr.length > 0){ cond += ' AND ' + arr.join(' and '); } t.dbBaseCondition = cond + ") "; } }, 'multidbfindtrigger[name=scd_sddetno]': { focus: function(t){ t.setHideTrigger(false); t.setReadOnly(false); var record = Ext.getCmp('grid').selModel.lastSelected; var code = record.data['scd_sacode']; var grid = Ext.getCmp('grid'); if(code == null || code == ''){ showError("请先选择订单号!"); t.setHideTrigger(true); t.setReadOnly(true); } else { t.dbBaseCondition = "sa_code='" + code + "'"; } var cond ="(sa_code='"+code+"' "; var arr = new Array(); Ext.each(grid.store.data.items, function(item){ if(item.data['scd_sacode'] != null && item.data['scd_sacode'] != '' && item.data['scd_sddetno'] != null && item.data['scd_sddetno'] !=''){ if(item.data['scd_sacode'] ==code){ arr.push("sd_detno<>"+item.data['scd_sddetno']); } } }); if(arr.length > 0){ cond += ' AND ' + arr.join(' and '); } t.dbBaseCondition = cond + ") "; } }, 'textfield[name=sc_newdelivery]': { change: function(field){ if(field.value != null && field.value != ''){ var grid = Ext.getCmp('grid'); var date = field.value; Ext.Array.each(grid.getStore().data.items,function(item){ item.set('scd_newdelivery',date); }); } } }, 'dbfindtrigger[name=sc_dpcode]': { afterrender: function(t) {// 根据录入人带出部门 Ext.defer(function(){ var form = t.up('form'), status = form.down('#sc_statuscode'); if(Ext.isEmpty(t.getValue()) && status && status.value == 'ENTERING'){ me.getDepart(function(data){ t.setValue(data.dp_code); form.down('#sc_dpname').setValue(data.dp_name); }); } }, 300); } }, 'dbfindtrigger[name=scd_newpayments]': { focus: function(t){ t.setHideTrigger(false); t.setReadOnly(false);//用disable()可以,但enable()无效 var grid = Ext.getCmp('grid'); var column = grid.down('gridcolumn[dataIndex=scd_newpayments]'); if(column && column.dbfind && column.dbfind.indexOf('CustomerPayments') > -1) { var record = grid.selModel.getLastSelected(); var code = record.data['cu_id']; if(code == null || code == ''){ showError("请先选择订单单号!"); t.setHideTrigger(true); t.setReadOnly(true); } else { t.dbBaseCondition = "cp_cuid='" + code + "'"; } } } } }); }, /** * @param allowEmpty 是否允许Grid为空 */ onSubmit: function(id, allowEmpty, errFn, scope){ var me = this; var form = Ext.getCmp('form'); if(form && form.getForm().isValid()){ var s = me.FormUtil.checkFormDirty(form); if(s == '' || s == '
'){ me.FormUtil.submit(id); } else { Ext.MessageBox.show({ title:'保存修改?', msg: '该单据已被修改:
' + s + '
提交前要先保存吗?', buttons: Ext.Msg.YESNOCANCEL, icon: Ext.Msg.WARNING, fn: function(btn){ if(btn == 'yes'){ if(typeof errFn === 'function') errFn.call(scope); else me.FormUtil.onUpdate(form, true); } else if(btn == 'no'){ me.FormUtil.submit(id); } else { return; } } }); } } else { me.FormUtil.checkForm(); } }, onGridItemClick: function(selModel, record){//grid行选择 this.GridUtil.onGridItemClick(selModel, record); }, getForm: function(btn){ return btn.ownerCt.ownerCt; }, getDepart: function(fn) { Ext.Ajax.request({ url : basePath + 'common/getFieldsData.action', async: false, params: { caller: 'Department left join employee on em_depart=dp_name', fields: 'dp_code,dp_name', condition: 'em_code=\'' + em_code + '\'' }, method : 'post', callback : function(opt, s, res){ var r = new Ext.decode(res.responseText); if(r.exceptionInfo){ showError(r.exceptionInfo); } else if(r.success && r.data){ fn.call(null, r.data); } } }); } });