| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335 |
- Ext.QuickTips.init();
- Ext.define('erp.controller.pm.make.MakePlan', {
- extend: 'Ext.app.Controller',
- requires: ['erp.util.BaseUtil', 'erp.util.FormUtil', 'erp.util.RenderUtil'],
- views:[
- 'pm.make.MakePlan','common.datalist.GridPanel','common.datalist.Toolbar','core.button.VastAudit','core.button.VastDelete',
- 'core.button.VastPrint','core.button.VastReply','core.button.VastSubmit','core.button.ResAudit','core.form.FtField',
- 'core.grid.TfColumn','core.grid.YnColumn','core.trigger.DbfindTrigger','core.form.FtDateField','core.form.FtFindField',
- 'core.form.FtNumberField', 'core.form.MonthDateField','common.batchDeal.Form','core.form.MonthDateField','core.form.ConMonthDateField','core.trigger.DbfindTrigger','core.form.ConDateField'
- ],
- init:function(){
- this.BaseUtil = Ext.create('erp.util.BaseUtil');
- this.FormUtil = Ext.create('erp.util.FormUtil');
- this.control({
- 'erpDatalistGridPanel': {
- itemclick: this.onGridItemClick,
- afterrender:function(grid){
- if(Ext.isIE){
- document.body.attachEvent('onkeydown', function(){
- if(window.event.ctrlKey && window.event.keyCode == 67){//Ctrl + C
- var e = window.event;
- if(e.srcElement) {
- window.clipboardData.setData('text', e.srcElement.innerHTML);
- }
- }
- });
- } else {
- grid.getEl().dom.addEventListener("mouseover", function(e){
- if(e.ctrlKey){
- var Contextvalue=e.target.textContent==""?e.target.value:e.target.textContent;
- textarea_text = parent.document.getElementById("textarea_text");
- textarea_text.value=Contextvalue;
- textarea_text.focus();
- textarea_text.select();
- }
- });
- }
- }
- },
- 'erpVastDeleteButton': {
- click: function(btn){
- var dlwin = new Ext.window.Window({
- id : 'dlwin',
- title: btn.text,
- height: "100%",
- width: "80%",
- maximizable : true,
- buttonAlign : 'center',
- layout : 'anchor',
- items: [{
- tag : 'iframe',
- frame : true,
- anchor : '100% 100%',
- layout : 'fit',
- html : '<iframe id="iframe_dl_'+caller+'" src="'+basePath+'jsps/common/vastDatalist.jsp?urlcondition='+condition+'&whoami='+caller+'" height="100%" width="100%" frameborder="0" scrolling="auto"></iframe>'
- }],
- buttons : [{
- text: btn.text,
- iconCls: btn.iconCls,
- cls: 'x-btn-gray-1',
- handler: function(){
-
- }
- },{
- text : '关 闭',
- iconCls: 'x-button-icon-close',
- cls: 'x-btn-gray',
- handler : function(){
- Ext.getCmp('dlwin').close();
- }
- }]
- });
- dlwin.show();
- }
- },
- 'button[id=query]':{
- beforerender:function(btn){
- btn.handler=function(){
- var form=btn.ownerCt.ownerCt;
- if(form){
- var condition=form.getCondition();
- if(!Ext.isEmpty(condition)) {
- var grid=Ext.getCmp('grid');
- grid.getCount(caller,condition);
- }
- }
- };
- }
- },
- 'button[id=searchlist]': {
- beforerender:function(btn){
- btn.hidden=true;
- },
- //searchlist存在很多问题
- click: function(){
- this.showSearchListWin();
- }
- },
- 'button[id=customize]': {
- click: function(){
- this.showCustomizeWin();
- }
- },
- 'button[id=relativelist]':{
- beforerender:function(btn){
- btn.hidden=true;
- }
- },
- 'dbfindtrigger[name=sl_label]': {
- afterrender: function(t){
- t.dbBaseCondition = 'sl_caller=\'' + caller + '\'';
- }
- }
- });
- },
- showCustomizeWin:function(){
- var me = this, win = this.CustomizeWin, grid = Ext.getCmp('grid');
- if(!win){
- var ablecolumns=new Array(),unselectcolumns=grid.basecolumns;
- Ext.Array.each(grid.columns,function(item){
- if(item.text && item.text.indexOf(' ')<0){
- ablecolumns.push(item);
- }
- });
- unselectcolumns.splice(0,ablecolumns.length);
- this.CustomizeWin=win = Ext.create('Ext.window.Window', {
- title: '<div align="center">个性设置</div>',
- height: screen.height*0.7,
- width: screen.width*0.7*0.9,
- layout:'border',
- closeAction:'hide',
- items:[{
- region:'center',
- layout:{
- type: 'hbox',
- align: 'stretch',
- padding: 5
- },
- defaults : { flex : 1 },
- items:[{
- xtype:'grid',
- multiSelect: true,
- id: 'fromgrid',
- title:'可选项',
- flex:0.7,
- cls: 'custom-grid',
- store:Ext.create('Ext.data.Store', {
- fields: [{name:'dataIndex',type:'string'},{name:'text',type:'string'},{name:'width',type:'number'}],
- data: unselectcolumns,
- filterOnLoad: false
- }),
- plugins: [Ext.create('erp.view.core.grid.HeaderFilter')],
- viewConfig: {
- plugins: {
- ptype: 'gridviewdragdrop',
- dragGroup: 'togrid',
- dropGroup: 'togrid'
- }
- },
- stripeRows: false,
- columnLines:true,
- columns:[{
- dataIndex:'dataIndex',
- cls :"x-grid-header-1",
- text:'字段名称',
- width:120,
- filter: {
- xtype : 'textfield'
- }
- },{
- dataIndex:'text',
- text:'描述',
- cls :"x-grid-header-1",
- flex:1,
- filter: {
- xtype : 'textfield'
- }
- },{
- dataIndex:'width',
- text:'宽度',
- width:60,
- cls :"x-grid-header-1",
- align:'right',
- editor: {
- xtype: 'numberfield',
- format:0
- },
- filter: {
- xtype : 'textfield'
- }
- }]
- },{
- xtype:'grid',
- multiSelect: true,
- id: 'togrid',
- stripeRows: true,
- columnLines:true,
- title:'显示项',
- store:Ext.create('Ext.data.Store', {
- fields: [{name:'dataIndex',type:'string'},{name:'text',type:'string'},{name:'width',type:'number'},
- {name:'orderby',type:'string'},{name:'priority',type:'string'}],
- data:ablecolumns,
- filterOnLoad: false
- }),
- necessaryField:'dataIndex',
- plugins: [Ext.create('erp.view.core.grid.HeaderFilter'),
- Ext.create('Ext.grid.plugin.CellEditing', {
- clicksToEdit: 1
- })],
- viewConfig: {
- plugins: {
- ptype: 'gridviewdragdrop',
- dragGroup: 'togrid',
- dropGroup: 'togrid'
- }
- },
- columns:[{
- dataIndex:'dataIndex',
- text:'字段名称',
- cls :"x-grid-header-1",
- width:120,
- filter: {
- xtype : 'textfield'
- }
- },{
- dataIndex:'text',
- text:'描述',
- cls :"x-grid-header-1",
- flex:1,
- filter: {
- xtype : 'textfield'
- }
- },{
- dataIndex:'width',
- text:'宽度',
- width:60,
- xtype:'numbercolumn',
- align:'right',
- cls :"x-grid-header-1",
- filter: {
- xtype : 'textfield'
- },
- editable:true,
- format: '0',
- editor: {
- xtype: 'numberfield',
- hideTrigger: true
- },
- },
- {
- dataIndex:'orderby',
- text:'排序',
- width:60,
- xtype:'combocolumn',
- cls :"x-grid-header-1",
- filter: {
- xtype : 'textfield'
- },
- renderer:function(val){
- if(val=='ASC'){
- return '<img src="' + basePath + 'resource/images/16/up.png">' +
- '<span style="color:red;padding-left:2px">升序</span>';
- } else if(val=='DESC') {
- return '<img src="' + basePath + 'resource/images/16/down.png">' +
- '<span style="color:red;padding-left:2px">降序</span>';
- }
- },
- editor:{
- xtype:'combo',
- queryMode: 'local',
- displayField: 'display',
- valueField: 'value',
- store:Ext.create('Ext.data.Store', {
- fields: ['value', 'display'],
- data : [{value:"ASC", display:"升序"},
- {value:"DESC", display:"降序"}]
- })
- }
- },{
- dataIndex:'priority',
- text:'优先级',
- width:60,
- align:'right',
- cls :"x-grid-header-1",
- filter: {
- xtype : 'textfield'
- },
- editor:{
- xtype:'combo',
- queryMode: 'local',
- displayField: 'display',
- valueField: 'value',
- store:Ext.create('Ext.data.Store', {
- fields: ['value', 'display'],
- data : [{value:"1", display:"1"},
- {value:"2", display:"2"},
- {value:"3", display:"3"},
- {value:"4", display:"4"},
- {value:"5", display:"5"},
- {value:"6", display:"6"},
- {value:"7", display:"7"},
- {value:"8", display:"8"},
- {value:"9", display:"9"},]
- })
- }
- }]
- }]
- }],
- buttonAlign:'center',
- buttons:['->',{
- text:'重置',
- scope:this,
- handler:function(btn){
- warnMsg('重置列表将还原配置,确认重置吗?', function(btn){
- if(btn == 'yes'){
- Ext.Ajax.request({
- url : basePath + 'common/resetEmpsDataListDetails.action',
- params: {
- caller:caller
- },
- method : 'post',
- callback : function(options,success,response){
- var localJson = new Ext.decode(response.responseText);
- if(localJson.success){
- showMessage('提示','重置成功!',1000);
- window.location.reload();
- } else {
- if(localJson.exceptionInfo){
- var str = localJson.exceptionInfo;
- if(str.trim().substr(0, 12) == 'AFTERSUCCESS'){//特殊情况:操作成功,但是出现警告,允许刷新页面
- str = str.replace('AFTERSUCCESS', '');
- showError(str);
- } else {
- showError(str);return;
- }
- }
- }
- }
- });
- }
- });
- }
- },{
- style:'margin-left:5px;',
- text:'保存',
- scope:this,
- handler:function(btn){
- var grid=Ext.getCmp('togrid'),fromgrid=Ext.getCmp('fromgrid');
- var jsonGridData = new Array(),datas=new Array();
- var form = Ext.getCmp('form');
- grid.getStore().each(function(item){//将grid里面各行的数据获取并拼成jsonGridData
- var data = {
- dde_field:item.data.dataIndex,
- dde_width:item.data.width,
- dde_orderby:item.data.orderby,
- dde_priority:item.data.priority
- };
- item.dirty=false;
- jsonGridData.push(Ext.JSON.encode(data));
- datas.push(item.data);
- });
- Ext.Ajax.request({
- url : basePath + 'common/saveEmpsDataListDetails.action',
- params : {
- caller:caller,
- data:unescape(jsonGridData.toString())
- },
- method : 'post',
- callback : function(options,success,response){
- var localJson = new Ext.decode(response.responseText);
- if(localJson.success){
- showMessage('提示','保存成功!',1000);
- window.location.reload();
- }
- }
- });
-
- }
- },{
- style:'margin-left:5px;',
- text:'关闭',
- handler:function(btn){
- btn.ownerCt.ownerCt.hide();
- }
- },'->']
- });
- }
- win.show();
- },
- onGridItemClick: function(selModel, record){
- //打开小窗口 编辑 分拆工单
- var ma_code=record.data.ma_code;
- Ext.create('Ext.window.Window',{
- width:850,
- height:'80%',
- iconCls:'x-grid-icon-partition',
- title:'<h1>工单拆分</h1>',
- id:'win',
- items:[{
- xtype:'form',
- layout:'column',
- region:'north',
- frame:true,
- defaults:{
- xtype:'textfield',
- columnWidth:0.5,
- readOnly:true,
- fieldStyle:'background:#f0f0f0;border: 0px solid #8B8970;color:blue;'
- },
- items:[{
- fieldLabel:'制造单号',
- value:record.data.ma_code,
- id:'macode'
- },{
- fieldLabel:'物料编号' ,
- value:record.data.ma_prodcode
- },{
- fieldLabel:'物料名称',
- value:record.data.pr_detail
- },{
- fieldLabel:'订单编号' ,
- value:record.data.ma_salecode
- },{
- fieldLabel:'订单序号',
- value:record.data.ma_saledetno
- },{
- fieldLabel:'制单数量',
- value:record.data.ma_qty,
- id:'ma_qty'
- },{
- fieldLabel:'已完工数',
- value:record.data.ma_madeqty,
- id:'ma_madeqty'
- }]
- },{
- xtype:'form',
- layout:'column',
- frame:true,
- id:'planform',
- defaults:{
- xtype:'textfield',
- columnWidth:0.26,
- readOnly:false,
- labelAlign:'right',
- fieldStyle:'background:#FFFAFA;color:#515151;'
- },
- items:[{
- fieldLabel:'计划开工日期',
- xtype:'datefield',
- id:'ma_planbegindate',
- name:'ma_planbegindate',
- value:record.data.ma_planbegindate
- },{
- fieldLabel:'计划完工日期',
- xtype:'datefield',
- id:'ma_planenddate',
- name:'ma_planenddate',
- value:record.data.ma_planenddate
- },{
- fieldLabel:'线别',
- id:'ma_teamcode',
- name:'ma_teamcode',
- labelWidth:50,
- columnWidth:0.2,
- xtype:'dbfindtrigger',
- value:record.data.ma_teamcode
- },{
- id:'ma_id',
- xtype:'hidden',
- name:'ma_id',
- value:record.data.ma_id
- },{
- xtype:'button',
- columnWidth:0.12,
- text:'保存',
- width:60,
- iconCls: 'x-button-icon-save',
- margin:'0 0 0 30',
- handler:function(btn){
- var store=Ext.getCmp('smallgrid').getStore();
- var count=0;
- var jsonData=new Array();
- var dd,version;
- Ext.Array.each(store.data.items,function(item){
- if(item.data.ma_planbegindate!=null&&item.data.ma_qty>0){
- version=item.data.ma_version;
- if(!version){
- dd=new Object();
- //说明是新增批次
- dd['ma_planbegindate']=Ext.Date.format(item.data.ma_planbegindate, 'Y-m-d');
- if(item.data.ma_planenddate!=null){
- dd['ma_planenddate']=Ext.Date.format(item.data.ma_planenddate, 'Y-m-d');
- }else{
- dd['ma_planenddate']=null;
- }
-
- dd['ma_qty']=item.data.ma_qty;
- dd['ma_teamcode']=item.data.ma_teamcode;
- jsonData.push(Ext.JSON.encode(dd));
- count+=Number(item.data.ma_qty);
- }
-
- }
- });
- var r=Ext.getCmp('planform').getValues();
- var params=new Object();
- params.formdata = unescape(Ext.JSON.encode(r).replace(/\\/g,"%"));
- params.data = unescape(jsonData.toString().replace(/\\/g,"%"));
- var assqty=Number(record.data.ma_qty)-Number(record.data.ma_madeqty);
- if(count>assqty){
- showError('分拆数量不能大于未完工数!') ;
- return;
- }else{
- Ext.Ajax.request({
- url : basePath +'pm/make/splitMake.action',
- params : params,
- method : 'post',
- callback : function(options,success,response){
- var localJson = new Ext.decode(response.responseText);
- if(localJson.success){
- saveSuccess(function(){
- //add成功后刷新页面进入可编辑的页面
- Ext.create('erp.util.GridUtil').loadNewStore(Ext.getCmp('smallgrid'),{
- caller:'MakeSplit',
- condition:"ma_version='"+ma_code+"' order by ma_id desc"
- });
- });
- } else if(localJson.exceptionInfo){
- var str = localJson.exceptionInfo;
- if(str.trim().substr(0, 12) == 'AFTERSUCCESS'){//特殊情况:操作成功,但是出现警告,允许刷新页面
- str = str.replace('AFTERSUCCESS', '');
- saveSuccess(function(){
- //add成功后刷新页面进入可编辑的页面
- Ext.create('erp.util.GridUtil').loadNewStore(Ext.getCmp('smallgrid'),{
- caller:'MakeSplit',
- condition:"ma_version='"+ma_code+"' order by ma_id desc"
- });
- });
- showError(str);
- } else {
- showError(str);
- return;
- }
-
- } else{
- saveFailure();
- }
- }
- });
-
- }
- }
- },{
- xtype:'button',
- columnWidth:0.1,
- text:'关闭',
- width:60,
- iconCls: 'x-button-icon-close',
- margin:'0 0 0 10',
- handler:function(btn){
- Ext.getCmp('win').close();
- }
- }]
- },{
- xtype:'gridpanel',
- region:'south',
- id:'smallgrid',
- layout:'fit',
- height:0.45*(window.height),
- autoScroll:true,
- columnLines:true,
- store:Ext.create('Ext.data.Store',{
- fields:[{name:'ma_planbegindate',type:'date'},{name:'ma_planenddate',type:'date'},{name:'ma_teamcode',type:'string'},{name:'ma_qty',type:'int'},{name:'ma_code',type:'string'},{name:'ma_version',type:'string'}],
- data:[]
- }),
- plugins: [Ext.create('Ext.grid.plugin.CellEditing', {
- clicksToEdit: 1,
- listeners:{
- 'edit':function(editor,e,Opts){
- var record=e.record;
- var version=record.data.ma_version;
- if(version){
- e.record.reject();
- Ext.Msg.alert('提示','不能修改已拆分工单!');
- }
- }
- }
- })],
- tbar: [{
- tooltip: '添加批次',
- iconCls: 'x-button-icon-add',
- width:25,
- handler : function() {
- var store = Ext.getCmp('smallgrid').getStore();
- var r = new Object();
- r.ma_planbegindate=null;
- r.ma_planenddate=null;
- r.ma_qty=null;
- r.ma_code=null;
- store.insert(store.getCount(), r);
- }
- }, {
- tooltip: '删除批次',
- width:25,
- itemId: 'delete',
- iconCls: 'x-button-icon-delete',
- handler: function(btn) {
- var sm = Ext.getCmp('smallgrid').getSelectionModel();
- //ma_version 存在则不让删除
- var store=Ext.getCmp('smallgrid').getStore();
- store.remove(sm.getSelection());
- if (store.getCount() > 0) {
- sm.select(0);
- }
- },
- disabled: true
- }],
- listeners:{
- itemmousedown:function(selmodel, record){
- selmodel.ownerCt.down('#delete').setDisabled(false);
- }
- },
- columns:[{
- dataIndex:'ma_planbegindate',
- header:'计划开工日期',
- xtype:'datecolumn',
- width:120,
- editable:true,
- renderer:function(val,meta,record){
- if(record.data.ma_version){
- meta.tdCls = "x-grid-cell-renderer-cl";
- }
- if(val)
- return Ext.Date.format(val, 'Y-m-d');
- else return null;
- },
- editor:{
- xtype: 'datefield',
- format:'Y-m-d'
- },
- },{
- dataIndex:'ma_planenddate',
- header:'计划完工日期',
- xtype:'datecolumn',
- width:120,
- editable:true,
- renderer:function(val,meta,record){
- if(record.data.ma_version){
- meta.tdCls = "x-grid-cell-renderer-cl";
- }
- if(val)
- return Ext.Date.format(val, 'Y-m-d');
- else return null;
- },
- format:'Y-m-d',
- editor:{
- xtype: 'datefield',
- format:'Y-m-d'
- }
- },{
- dataIndex:'ma_qty',
- header:'数量',
- width:120,
- xtype:'numbercolumn',
- editable:true,
- renderer:function(val,meta,record){
- if(record.data.ma_version){
- meta.tdCls = "x-grid-cell-renderer-cl";
- }
- return val;
- },
- editor:{
- xtype:'numberfield',
- format:'0',
- hideTrigger: true
- }
- },{
- dataIndex:'ma_teamcode',
- header:'线别',
- width:120,
- editable:true,
- renderer:function(val,meta,record){
- if(record.data.ma_version){
- meta.tdCls = "x-grid-cell-renderer-cl";
- }
- return val;
- },
- dbfind:'MakeTeam|ct_varchar50_1',
- editor:{
- xtype:'dbfindtrigger',
- hideTrigger: false,
- name:'ma_teamcode',
- which:'grid',
- dbfind:'MakeTeam|ct_varchar50_1',
- listeners: {
- aftertrigger: function(t, d) {
- var record = Ext.getCmp('smallgrid').selModel.lastSelected;
- record.set('ma_teamcode', d.data.CT_VARCHAR50_1);
- }
- }
-
- }
- },{
- dataIndex:'ma_code',
- header:'制造单号',
- width:150,
- renderer:function(val,meta,record){
- if(record.data.ma_version){
- meta.tdCls = "x-grid-cell-renderer-cl";
- }
- return val;
- },
- },{
- dataIndex:'ma_version',
- header:'原始工单',
- width:150,
- editable:false
- }]
- }]
-
- }).show();
- //给grid 赋值
- Ext.create('erp.util.GridUtil').loadNewStore(Ext.getCmp('smallgrid'),{
- caller:'MakeSplit',
- condition:"ma_version='"+ma_code+"' order by ma_id desc"
- });
-
- },
- openUrl: function(record) {
- var me = this, value = record.data[keyField];
- var formCondition = keyField + "IS" + value ;
- var gridCondition = pfField + "IS" + value;
- if(!Ext.isEmpty(pfField) && pfField.indexOf('+') > -1) {//多条件传入维护界面//vd_vsid@vd_id+vd_class@vd_class
- var arr = pfField.split('+'),ff = [],k = [];
- Ext.Array.each(arr, function(r){
- ff = r.split('@');
- k.push(ff[0] + 'IS\'' + record.get(ff[1]) + '\'');
- });
- gridCondition = k.join(' AND ');
- }
- var panelId = caller + keyField + "_" + value + gridCondition;
- var panel = Ext.getCmp(panelId);
- var main = parent.Ext.getCmp("content-panel");
- if(!main){
- main = parent.parent.Ext.getCmp("content-panel");
- }
- if(!panel){
- var title = "";
- if (value.toString().length>4) {
- title = value.toString().substring(value.toString().length-4);
- } else {
- title = value;
- }
- var myurl = '';
- if(me.BaseUtil.contains(url, '?', true)){
- myurl = url + '&formCondition='+formCondition+'&gridCondition='+gridCondition;
- } else {
- myurl = url + '?formCondition='+formCondition+'&gridCondition='+gridCondition;
- }
- myurl += "&datalistId=" + main.getActiveTab().id;
- main.getActiveTab().currentStore = me.getCurrentStore(value);//用于单据翻页
- if(main._mobile) {
- main.addPanel(me.BaseUtil.getActiveTab().title+'('+title+')', myurl, panelId);
- } else {
- panel = {
- title : me.BaseUtil.getActiveTab().title+'('+title+')',
- tag : 'iframe',
- tabConfig:{tooltip:me.BaseUtil.getActiveTab().tabConfig.tooltip+'('+keyField + "=" + value+')'},
- frame : true,
- border : false,
- layout : 'fit',
- iconCls : 'x-tree-icon-tab-tab1',
- html : '<iframe id="iframe_maindetail_'+caller+"_"+value+'" src="' + myurl + '" height="100%" width="100%" frameborder="0" style="border-width: 0px;padding: 0px;" scrolling="auto"></iframe>',
- closable : true,
- listeners : {
- close : function(){
- if(!main){
- main = parent.parent.Ext.getCmp("content-panel");
- }
- main.setActiveTab(main.getActiveTab().id);
- }
- }
- };
- this.openTab(panel, panelId);
- }
- }else{
- main.setActiveTab(panel);
- }
- },
- openQueryUrl: function(record) {
- var me = this, arr = keyField.split('+'),ff = [],k = [];//vd_vsid@vd_id+vd_class@vd_class
- Ext.Array.each(arr, function(r){
- ff = r.split('@');
- k.push(ff[0] + '=' + record.get(ff[1]));
- });
- var myurl = k.join('&');
- var panelId = caller + "_" + myurl;
- var panel = Ext.getCmp(panelId);
- var main = parent.Ext.getCmp("content-panel");
- if(!main){
- main = parent.parent.Ext.getCmp("content-panel");
- }
- if(!panel){
- var title = me.BaseUtil.getActiveTab().title + '-查询';
- if(contains(url, '?', true)){
- myurl = url + '&' + myurl;
- } else {
- myurl = url + '?' + myurl;
- }
- if (main._mobile) {
- main.addPanel(title, myurl, panelId);
- } else {
- panel = {
- title : title,
- tag : 'iframe',
- tabConfig: {tooltip: title},
- frame : true,
- border : false,
- layout : 'fit',
- iconCls : 'x-tree-icon-tab-tab1',
- html : '<iframe src="' + myurl + '" height="100%" width="100%" frameborder="0" style="border-width: 0px;padding: 0px;" scrolling="auto"></iframe>',
- closable : true,
- listeners : {
- close : function(){
- if(!main){
- main = parent.parent.Ext.getCmp("content-panel");
- }
- main.setActiveTab(main.getActiveTab().id);
- }
- }
- };
- this.openTab(panel, panelId);
- }
- } else {
- main.setActiveTab(panel);
- }
- },
- openTab : function (panel,id){
- var o = (typeof panel == "string" ? panel : id || panel.id);
- var main = parent.Ext.getCmp("content-panel");
- /*var tab = main.getComponent(o); */
- if(!main) {
- main =parent.parent.Ext.getCmp("content-panel");
- }
- var tab = main.getComponent(o);
- if (tab) {
- main.setActiveTab(tab);
- } else if(typeof panel!="string"){
- panel.id = o;
- var p = main.add(panel);
- main.setActiveTab(p);
- }
- },
- getCurrentStore: function(value){
- var grid = Ext.getCmp('grid');
- var items = grid.store.data.items;
- var array = new Array();
- var o = null;
- Ext.each(items, function(item, index){
- o = new Object();
- o.selected = false;
- if(index == 0){
- o.prev = null;
- } else {
- o.prev = items[index-1].data[keyField];
- }
- if(index == items.length - 1){
- o.next = null;
- } else {
- o.next = items[index+1].data[keyField];
- }
- var v = item.data[keyField];
- o.value = v;
- if(v == value)
- o.selected = true;
- array.push(o);
- });
- return array;
- },
- showSearchListWin: function(){
- var me = this, win = this.searchWin;
- if (!win){
- win = this.searchWin = Ext.create('Ext.window.Window', {
- title: '高级查询',
- height: screen.height*0.7*0.8,
- width: screen.width*0.7*0.6,
- maximizable : true,
- closable: false,
- buttonAlign : 'center',
- layout : 'border',
- bodyStyle: 'background:#f1f1f1;',
- tools: [{
- type: 'close',
- handler: function(e, el, header, tool){
- tool.ownerCt.ownerCt.down('grid').setEffectData();//保留已选择的条件
- tool.ownerCt.ownerCt.hide();
- }
- }],
- items: [{
- xtype: 'form',
- region: 'north',
- layout: 'column',
- bodyStyle: 'background:#f1f1f1;',
- maxHeight: 100,
- buttonAlign: 'center',
- buttons: [{
- name: 'query',
- id: 'query',
- text: $I18N.common.button.erpQueryButton,
- iconCls: 'x-button-icon-query',
- cls: 'x-btn-gray',
- handler: function(btn){
- Ext.getCmp('grid').getCount(caller);
- btn.ownerCt.ownerCt.ownerCt.hide();
- }
- },{
- cls: 'x-btn-gray',
- text: '清空',
- handler: function(btn){
- btn.ownerCt.ownerCt.ownerCt.down('grid').store.loadData([{},{},{},{},{},{},{},{},{},{}]);
- Ext.getCmp('grid').getCount(caller);
- }
- },{
- cls: 'x-btn-gray',
- text: '关闭',
- handler: function(btn){
- btn.ownerCt.ownerCt.ownerCt.down('grid').setEffectData();
- btn.ownerCt.ownerCt.ownerCt.hide();
- }
- },{
- xtype: 'radio',
- name: 'separator',
- boxLabel: '与',
- checked: true,
- inputValue: 'AND',
- getCheckValue: function(){
- return this.checked ? 'AND' : 'OR';
- }
- },{
- xtype: 'radio',
- name: 'separator',
- boxLabel: '或',
- inputValue: 'OR'
- }]
- }, me.getSearchListGrid()]
- });
- Ext.getCmp('grid').searchGrid = win.down('grid');
- }
- win.show();
- win.down('grid').loadData();
- },
- getGridColumns : function() {
- var grid = Ext.getCmp('grid'), columns = grid.headerCt.getGridColumns(), data = [];
- Ext.each(columns, function(){
- if(this.dataIndex && this.getWidth() > 0) {
- data.push({
- display : this.text,
- value : this.text,
- column : this
- });
- }
- });
- return data;
- },
- getSearchListGrid: function(){
- var data = this.getGridColumns();
- var grid = Ext.create('Ext.grid.Panel', {
- maxHeight: 350,
- region: 'center',
- store: Ext.create('Ext.data.Store', {
- fields:[{
- name: 'sl_label',
- type: 'string'
- },{
- name: 'sl_field',
- type: 'string'
- },{
- name: 'sl_type',
- type: 'string'
- },{
- name: 'sl_dbfind',
- type: 'string'
- },{
- name: 'union',
- type: 'string'
- },{
- name: 'value'
- }],
- data: []
- }),
- columns: [{
- text: '条件',
- flex: 2,
- dataIndex: 'sl_label',
- editor: {
- xtype: 'combo',
- store : Ext.create('Ext.data.Store', {
- fields : [ 'display', 'value', 'column' ],
- data : data
- }),
- editable: false,
- displayField : 'display',
- valueField : 'value',
- queryMode : 'local'
- },
- renderer : function(val, meta, record, x, y, store, view) {
- if (val) {
- var column = view.ownerCt.headerCt.getHeaderAtIndex(y);
- if(column && typeof column.getEditor != 'undefined') {
- var editor = column.getEditor(record);
- if (editor && editor.lastSelection.length > 0) {
- var cm = editor.lastSelection[0].get('column'),
- field = cm.dataIndex;
- if (record.get('sl_field') != field)
- record.set('sl_field', field);
- var t = 'S';
- if(cm.xtype == 'datecolumn' || cm.xtype == 'datetimecolumn') {
- t = 'D';
- } else if(cm.xtype == 'numbercolumn') {
- t = 'N';
- }
- if (record.get('sl_type') != t)
- record.set('sl_type', t);
- }
- }
- } else {
- if (record.get('sl_field')) {
- record.set('sl_field', null);
- }
- }
- return val;
- },
- processEvent : function(type, view, cell, recordIndex, cellIndex, e) {
- if (type == 'click' || type == 'dbclick') {
- return true;
- }
- return false;
- }
- },{
- text: '',
- hidden: true,
- dataIndex: 'sl_field',
- processEvent : function(type, view, cell, recordIndex, cellIndex, e) {
- return false;
- }
- },{
- text: '',
- hidden: true,
- dataIndex: 'sl_type',
- processEvent : function(type, view, cell, recordIndex, cellIndex, e) {
- return false;
- }
- },{
- text: '关系',
- flex: 1,
- dataIndex: 'union',
- xtype:'combocolumn',
- editor: {
- xtype: 'combo',
- store: Ext.create('Ext.data.Store', {
- fields: ['display', 'value'],
- data : [{"display": '等于', "value": '='},
- {"display": '大于', "value": '>'},
- {"display": '大于等于', "value": '>='},
- {"display": '小于', "value": '<'},
- {"display": '小于等于', "value": '<='},
- {"display": '不等于', "value": '<>'},
- {"display": '介于', "value": 'Between And'},
- {"display": '包含', "value": 'like'},
- {"display": '不包含', "value": 'not like'},
- {"display": '开头是', "value": 'begin like'},
- {"display": '开头不是', "value": 'begin not like'},
- {"display": '结尾是', "value": 'end like'},
- {"display": '结尾不是', "value": 'end not like'}]
- }),
- displayField: 'display',
- valueField: 'value',
- queryMode: 'local',
- editable: false,
- value: 'like'
- },
- /* renderer : function(v) {
- var r = v;
- switch(v) {
- case 'like':
- r = 'Like';break;
- case '=':
- r = '等于';break;
- case '>':
- r = '大于';break;
- case '>=':
- r = '大于等于';break;
- case '<':
- r = '小于';break;
- case '<=':
- r = '小于等于';break;
- case '<>':
- r = '不等于';break;
- case 'Between And':
- r = '介于';break;
- }
- return r;
- },*/
- processEvent : function(type, view, cell, recordIndex, cellIndex, e) {
- if (type == 'click' || type == 'dbclick') {
- return true;
- }
- return false;
- }
- },{
- text: '值',
- flex: 3,
- dataIndex: 'value',
- renderer: function(val){
- if(Ext.isDate(val)){
- return Ext.Date.format(val, 'Y-m-d');
- }
- return val;
- },
- processEvent : function(type, view, cell, recordIndex, cellIndex, e) {
- if (type == 'click' || type == 'dbclick') {
- var s = view.ownerCt.selModel, m = s.getSelection(), n = [];
- Ext.Array.each(m, function(){
- n.push(this);
- });
- n.push(view.ownerCt.store.getAt(recordIndex));
- s.select(n);
- return true;
- }
- return false;
- }
- }],
- columnLines: true,
- plugins: Ext.create('Ext.grid.plugin.CellEditing', {
- clicksToEdit: 1,
- listeners: {
- beforeedit: function(e){
- if(e.field == 'value'){
- var record = e.record;
- var column = e.column;
- if(record.data['union'] == null || record.data['union'] == ''){
- record.set('union', 'like');
- }
- var f = record.data['sl_field'];
- switch(record.data['sl_type']){
- case 'D':
- switch(record.data['union']){
- case 'Between And':
- column.setEditor(new erp.view.core.form.FtDateField({
- id: f,
- name: f
- }));break;
- default:
- column.setEditor(new Ext.form.field.Date({
- id: f,
- name: f
- }));break;
- }
- break;
- case 'S':
- switch(record.data['union']){
- case 'Between And':
- column.setEditor(new erp.view.core.form.FtField({
- id: f,
- name: f,
- value: e.value
- }));break;
- default:
- column.setEditor(new Ext.form.field.Text({
- id: f,
- name: f
- }));break;
- }
- break;
- case 'N':
- switch(record.data['union']){
- case 'Between And':
- column.setEditor(new erp.view.core.form.FtNumberField({
- id: f,
- name: f
- }));break;
- default:
- column.setEditor(new Ext.form.field.Number({
- id: f,
- name: f
- }));break;
- }
- break;
- case 'T':
- column.dbfind = record.get('sl_dbfind');
- switch(record.data['union']){
- case 'Between And':
- column.setEditor(new erp.view.core.form.FtFindField({
- id: f,
- name: f
- }));break;
- default:
- column.setEditor(new erp.view.core.trigger.DbfindTrigger({
- id: f,
- name: f
- }));break;
- }
- break;
- default:
- column.setEditor(null);
- }
- }
- }
- }
- }),
- selModel: Ext.create('Ext.selection.CheckboxModel',{
- }),
- setEffectData: function(){
- var me = this;
- var datas = new Array();
- Ext.each(me.selModel.getSelection(), function(item){
- var data = item.data;
- if(!Ext.isEmpty(data.sl_label) && !Ext.isEmpty(data.union) && !Ext.isEmpty(data.value)){
- datas.push(data);
- }
- });
- me.effectdata = datas;
- },
- getEffectData: function(){
- return this.effectdata || new Array();
- },
- loadData: function(){
- if(!this.effectdata) {
- this.store.add([{},{},{},{},{},{},{},{},{},{}]);
- }
- },
- /**
- * 将数据拼成Sql条件语句
- */
- getCondition: function(){
- this.setEffectData();
- var condition = '';
- var separator = this.up('window').down('form').down('radio').getCheckValue();
- Ext.each(this.effectdata, function(data){
- if(data.union == 'Between And'){
- var v1 = data.value.split('~')[0];
- var v2 = data.value.split('~')[1];
- if(data.sl_type == 'D'){
- if(condition == ''){
- condition = '(' + data.sl_field + " BETWEEN to_date('" + v1 + " 00:00:00','yyyy-MM-dd HH24:mi:ss') AND to_date('"
- + v2 + " 23:59:59','yyyy-MM-dd HH24:mi:ss')" + ') ';
- } else {
- condition += ' ' + separator + ' (' + data.sl_field + " BETWEEN to_date('" + v1 + " 00:00:00','yyyy-MM-dd HH24:mi:ss') AND to_date('"
- + v2 + " 23:59:59','yyyy-MM-dd HH24:mi:ss')" + ') ';
- }
- } else if(data.sl_type == 'N'){
- if(condition == ''){
- condition = '(' + data.sl_field + " BETWEEN " + v1 + ' AND ' + v2 + ') ';
- } else {
- condition += ' ' + separator + ' (' + data.sl_field + " BETWEEN " + v1 + ' AND ' + v2 + ') ';
- }
- } else{
- if(condition == ''){
- condition = '(' + data.sl_field + " BETWEEN '" + v1 + "' AND '" + v2 + "') ";
- } else {
- condition += ' ' + separator + ' (' + data.sl_field + " BETWEEN '" + v1 + "' AND '" + v2 + "') ";
- }
- }
- } else {
- if(data.sl_type == 'D'){
- var v = data.value, field = data.sl_field;
- if(Ext.isDate(v)) {
- v = Ext.Date.format(v, 'Y-m-d');
- }
- if(data.union == '<' || data.union == '<=' || data.union == '>' || data.union == '>='){
- v = "to_date('" + v + "','yyyy-MM-dd')";
- }else {
- v = Ext.Date.format(data.value, 'Ymd');
- field = "to_char(" + field + ",'yyyymmdd')";
- }
- if(condition == ''){
- condition = '(' + field + data.union + v + ') ';
- } else {
- condition += ' ' + separator +' (' + field + data.union + v + ') ';
- }
- } else {
- var v = data.value;
- if(data.union == 'like' || data.union=='not like'){
- v = " '%" + data.value + "%'";
- }else if(data.union =='begin like' || data.union =='begin not like'){
- v = " '" + data.value + "%'";
- data.union=data.union.substring(5);
- }else if(data.union =='end like' || data.union=='end not like'){
- v = " '%" + data.value + "'";
- data.union=data.union.substring(3);
- }else {
- v = " '" + data.value + "'";
- }
- if(condition == ''){
- condition = '(' + data.sl_field + " " + data.union + v + ") ";
- } else {
- condition += ' ' + separator +' (' + data.sl_field + " " + data.union + v + ") ";
- }
- }
- }
- });
- return condition;
- }
- });
- return grid;
- },
- getFilterCondition: function(){
- var fields = Ext.getCmp('grid').plugins[0].fields;
- var items = new Array();
- Ext.each(Ext.Object.getKeys(fields), function(key){
- var item = fields[key];
- if(item.value != null && item.value.toString().trim() != ''){
- items.push({
- xtype: item.xtype,
- id: item.itemId,
- fieldLabel: item.fieldLabel,
- fieldStyle: item.fieldStyle,
- value: item.value,
- columnWidth: 0.5,
- cls: 'form-field-border',
- listeners: {
- change: function(f){
- Ext.getCmp(item.id).setValue(f.value);
- }
- }
- });
- }
- });
- return items;
- }
- });
|