123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329 |
- Ext.QuickTips.init();
- Ext.define('erp.controller.co.inventory.CheckIVAccount', {
- extend: 'Ext.app.Controller',
- requires: ['erp.util.BaseUtil'],
- views: ['co.inventory.CheckIVAccount'],
- FormUtil: Ext.create('erp.util.FormUtil'),
- init:function(){
- var me = this;
- this.BaseUtil = Ext.create('erp.util.BaseUtil');
- this.control({
- 'button[id=check]': {
- click: function(btn) {
- var grid = btn.ownerCt.ownerCt;
- grid.store.each(function(r){
- r.set('check', '');
- });
- btn.hide();
- me.check(grid, 0, btn);
- }
- },
- '#allow' : {
- change : function(f) {
- if(!me.checked) {
- if(f.getValue()) {
- Ext.getCmp('accoutover').setDisabled(false);
- } else {
- Ext.getCmp('accoutover').setDisabled(true);
- }
- }
- }
- },
- 'button[id=accoutover]': {
- click: function() {
- this.startAccount();
- }
- },
- 'button[id=close]': {
- click: function() {
- me.BaseUtil.getActiveTab().close();
- }
- },
- 'button[id=resaccoutover]': {
- click: function() {
- this.overAccount();
- }
- },
- 'grid[id=account-check]': {
- itemclick: function(selModel, record) {
- var val = record.get('check');
- if(val == 'error') {
- me.showDetail(selModel.ownerCt, record);
- }
- }
- },
- 'tbtext[id=yearmonth]': {
- afterrender: function(f) {
- this.getCurrentMonth(f);
- }
- }
- });
- },
- startAccount: function(){
- var me = this;
- me.FormUtil.setLoading(true);
- Ext.Ajax.request({
- url : basePath + "scm/reserve/confirmReserveClose.action",
- params:{
- param : me.currentMonth
- },
- timeout: 120000,
- method:'post',
- callback:function(options,success,response){
- me.FormUtil.setLoading(false);
- var localJson = new Ext.decode(response.responseText);
- if (localJson.success) {
- window.location.reload();
- } else {
- if (localJson.exceptionInfo) {
- var str = localJson.exceptionInfo;
- if (str.trim().substr(0, 12) == 'AFTERSUCCESS') {// 特殊情况:操作成功,但是出现警告,允许刷新页面
- str = str.replace('AFTERSUCCESS', '');
- showMessage('提示', str);
- window.location.reload();
- } else {
- showError(str);
- return;
- }
- }
- }
- }
- });
- },
- overAccount: function(){
- var me = this;
- me.FormUtil.setLoading(true);
- Ext.Ajax.request({
- url : basePath + "scm/reserve/unperiodsdetail.action",
- params:{
- param : me.currentMonth
- },
- method:'post',
- callback:function(options,success,response){
- me.FormUtil.setLoading(false);
- var localJson = new Ext.decode(response.responseText);
- if (localJson.success) {
- window.location.reload();
- } else {
- if (localJson.exceptionInfo) {
- var str = localJson.exceptionInfo;
- if (str.trim().substr(0, 12) == 'AFTERSUCCESS') {// 特殊情况:操作成功,但是出现警告,允许刷新页面
- str = str.replace('AFTERSUCCESS', '');
- showMessage('提示', str);
- window.location.reload();
- } else {
- showError(str);
- return;
- }
- }
- }
- }
- });
- },
- check: function(grid, idx, btn) {
- var me =this,f = grid.store.getAt(idx);
- if(!f) {
- btn.setDisabled(false);
- return;
- }
- f.set('check', 'loading');
- var win = Ext.getCmp('win-' + f.get('type'));
- if(win) {
- win.destroy();
- }
- Ext.Ajax.request({
- url: basePath + f.get('action'),
- params: {
- type: f.get('type'),
- month: me.currentMonth,
- start: me.datestart,
- end: me.dateend
- },
- callback: function(opt, s, r) {
- me.check(grid, ++idx, btn);
- var rs = Ext.decode(r.responseText);
- if(rs.ok) {
- f.set('check', 'checked');
- } else {
- f.set('check', 'error');
- }
- if(idx == grid.store.data.length) {
- var ch = 0;
- grid.store.each(function(){
- if(this.get('check') == 'checked') {
- ch ++;
- }
- });
- if(idx == ch) {
- me.checked = true;
- Ext.getCmp('accoutover').setDisabled(false);
- } else {
- me.checked = false;
- Ext.getCmp('allow').show();
- }
- }
- }
- });
- },
- showDetail: function(grid, record) {
- var me = this, wid = 'win-' + record.get('type'),
- win = Ext.getCmp(wid);
- if(!win) {
- win = Ext.create('Ext.Window', {
- title: record.get('value'),
- id: wid,
- width: 800,
- height: 500,
- layout: 'anchor',
- items: [{
- xtype: 'gridpanel',
- anchor: '100% 100%',
- columnLines: true,
- cls: 'custom',
- columns: [{
- text: '单据',
- flex: 1,
- dataIndex: 'be_class'
- },{
- text: '编号',
- flex: 1.6,
- dataIndex: 'be_code'
- },{
- text: '检测时间',
- flex: 1,
- dataIndex: 'be_date',
- renderer: function(val) {return Ext.Date.format(new Date(val), 'Y-m-d');}
- },{
- text: '检测人',
- flex: .8,
- dataIndex: 'be_checker'
- },{
- text: '备注',
- flex: 3,
- dataIndex: 'be_remark'
- }],
- store: new Ext.data.Store({
- fields: ['be_class', 'be_code', 'be_date', 'be_checker', 'be_remark']
- })
- }],
- buttonAlign: 'center',
- buttons: [{
- text: $I18N.common.button.erpExportButton,
- iconCls: 'x-button-icon-excel',
- cls: 'x-btn-blue',
- handler: function(btn) {
- me.BaseUtil.exportGrid(btn.up('window').down('gridpanel'));
- }
- },{
- text: '导出全部',
- iconCls: 'x-button-icon-excel',
- cls: 'x-btn-blue',
- handler: function(btn) {
- me.getAll(grid, record);
- }
- },{
- text: $I18N.common.button.erpCloseButton,
- cls: 'x-btn-blue',
- handler: function(btn) {
- btn.ownerCt.ownerCt.close();
- }
- }]
- });
- this.getBillError(record.get('type'), win.down('gridpanel'));
- }
- win.show();
- },
- getCurrentMonth: function(f) {
- var me = this;
- Ext.Ajax.request({
- url: basePath + 'fa/getMonth.action',
- params: {
- type: 'MONTH-P'
- },
- callback: function(opt, s, r) {
- var rs = Ext.decode(r.responseText);
- if(rs.data) {
- me.currentMonth = rs.data.PD_DETNO;
- me.datestart = Ext.Date.format(new Date(rs.data.PD_STARTDATE), 'Ymd');
- me.dateend = Ext.Date.format(new Date(rs.data.PD_ENDDATE), 'Ymd');
- f.setText(rs.data.PD_DETNO + ' 从' + Ext.Date.format(new Date(rs.data.PD_STARTDATE), 'Y-m-d')
- + ' 到 ' + Ext.Date.format(new Date(rs.data.PD_ENDDATE), 'Y-m-d'));
- }
- }
- });
- },
- getBillError: function(type, grid) {
- Ext.Ajax.request({
- url: basePath + 'fa/getBillError.action',
- params: {
- type: type
- },
- callback: function(opt, s, r) {
- var rs = Ext.decode(r.responseText);
- if(rs.data) {
- grid.store.loadData(rs.data);
- } else if(rs.exceptionInfo) {
- showError(rs.exceptionInfo);
- }
- }
- });
- },
- getAll: function(grid, record) {
- var p = Ext.create('Ext.ProgressBar', {
- renderTo: Ext.getBody(),
- floating: true,
- width: 300,
- value: 0.4,
- text: '获取全部数据...'
- }).show();
- this.checkAll(grid, record);
- p.updateProgress(0.8, '正在下载...', true);
- this.exportExcel(record.get('type'));
- Ext.defer(function(){
- p.setVisible(false);
- }, 3000);
- },
- checkAll: function(grid, record) {
- var me =this;
- record.set('check', 'loading');
- Ext.Ajax.request({
- url: basePath + record.get('action'),
- params: {
- type: record.get('type'),
- month: me.currentMonth,
- start: me.datestart,
- end: me.dateend,
- all: true
- },
- async: false,
- callback: function(opt, s, r) {
- var rs = Ext.decode(r.responseText);
- if(rs.ok) {
- record.set('check', 'checked');
- } else {
- record.set('check', 'error');
- }
- }
- });
- },
- exportExcel: function(type) {
- var title = Ext.Date.format(new Date(), 'Y-m-d H:m:s');
- if (!Ext.fly('ext-grid-excel')) {
- var frm = document.createElement('form');
- frm.id = 'ext-grid-excel';
- frm.name = id;
- frm.className = 'x-hidden';
- document.body.appendChild(frm);
- }
- Ext.Ajax.request({
- url: basePath + ('fa/exportBillError.xls'),
- method: 'post',
- form: Ext.fly('ext-grid-excel'),
- isUpload: true,
- params: {
- type: type,
- title: title
- }
- });
- }
- });
|