| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310 |
- Ext.QuickTips.init();
- Ext.define('erp.controller.pm.outsource.MakeMaterialScrap', {
- extend: 'Ext.app.Controller',
- requires: ['erp.util.RenderUtil', 'erp.util.GridUtil', 'erp.util.BaseUtil'],
- views:[
- 'pm.outsource.MakeMaterialScrap', 'core.grid.Panel5', 'common.editorColumn.GridPanel', 'core.grid.YnColumn',
- 'core.button.CreateDetail', 'core.button.PrintDetail', 'core.trigger.DbfindTrigger'
- ],
- init:function(){
- var me = this;
- me.GridUtil = Ext.create('erp.util.GridUtil');
- me.BaseUtil = Ext.create('erp.util.BaseUtil');
- this.control({
- 'button[id=retreat]': {
- click: function(btn){
- var grid = Ext.getCmp('editorColumnGridPanel');
- var e = me.checkQty(Ext.getCmp('grid'), grid);
- if(e.length > 0) {
- showError(e);return;
- }
- e = me.check(grid.selModel.getSelection());
- if(e.length > 0) {
- showError(e);return;
- }
- warnMsg("确定要生成报废单吗?", function(btn){
- if(btn == 'yes'){
- me.turnOut(grid);
- }
- });
- }
- },
- 'button[name=query]': {
- click: function(btn){
- me.onQuery();
- }
- },
- 'erpEditorColumnGridPanel' : {
- afterlayout: function(grid) {
- grid.store.on('load', function(store){
- me.getProductWh(grid);
- });
- }
- },
- 'checkbox[id=whcode]' : {
- afterrender : function(f) {
- me.getSetting(f);
- }
- }
- });
- },
- turnOut: function(grid) {
- var me = this,
- material = this.getEffectData(grid.selModel.getSelection());
- if(material.length > 0){
- grid.setLoading(true);//loading...
- Ext.Ajax.request({
- url : basePath + 'pm/make/turnScrap.action',
- params: {
- data: Ext.encode(material),
- caller: caller,
- type: 'OS'
- },
- method : 'post',
- callback : function(options,success,response){
- grid.setLoading(false);
- var localJson = new Ext.decode(response.responseText);
- if(localJson.exceptionInfo){
- showError(localJson.exceptionInfo);
- }
- if(localJson.log){
- showMessage('提示', localJson.log);
- }
- if(localJson.success){
- turnSuccess(function(){
- grid.multiselected = new Array();
- });
- }
- me.onQuery();
- }
- });
- }
- },
- /**
- * 筛选
- */
- onQuery: function(){
- var grid = Ext.getCmp('grid');
- //计算thisqty
- this.calOnlineQty(grid);
- //Query
- var condition = null;
- Ext.each(grid.store.data.items, function(item){
- if(item.data['ma_code'] != null && item.data['ma_code'] != ''){
- if(condition == null){
- condition = "(mm_code='" + item.data['ma_code'] + "'";
- } else {
- condition += " OR mm_code='" + item.data['ma_code'] + "'";
- }
- }
- });
- if(condition != null){
- grid.busy = true;
- grid.multiselected = new Array();
- var dg = Ext.getCmp('editorColumnGridPanel');
- dg.busy = true;
- condition += ") AND (nvl(mm_materialstatus,' ')=' ') AND (mm_thisqty > 0)";
- dg.getGridColumnsAndStore(condition + ' order by mm_maid,mm_detno');
- this.showReplace(condition, dg);
- setTimeout(function(){
- dg.busy = false;
- grid.busy = false;
- }, 1000);
- }
- },
- /**
- * 更新工单用料在线结存数量
- **/
- calOnlineQty: function(grid){
- var items = grid.store.data.items, idx = new Array();
- Ext.each(items, function(item){
- if(item.data['ma_code'] != null && item.data['ma_code'] != ''){
- idx.push(item.data['ma_id']);
- }
- });
- if(idx.length > 0) {
- Ext.Ajax.request({
- url : basePath + 'pm/make/calOnlineQty.action',
- async: false,
- params: {
- ids: Ext.Array.concate(idx, ',')
- },
- callback: function(opt, s, r){
- var res = Ext.decode(r.responseText);
- if(res.exceptionInfo) {
- showError(res.exceptionInfo);
- }
- }
- });
- }
- },
- /**
- * 替代料
- */
- showReplace: function(condition, grid){
- Ext.Ajax.request({
- url : basePath + 'common/getFieldsDatas.action',
- params: {
- caller: 'MakeMaterialReplace left join MakeMaterial on mm_id=mp_mmid left join Product on mp_prodcode=pr_code' +
- ' left join WareHouse on wh_id=mp_warehouseid',
- fields: 'mp_mmid,mp_detno,mp_thisqty,mp_canuseqty,mp_repqty,mp_remark,mp_prodcode,pr_detail,pr_spec,pr_unit,wh_code',
- condition: condition + ' and (mp_thisqty > 0)'
- },
- async: false,
- method : 'post',
- callback : function(options,success,response){
- var localJson = new Ext.decode(response.responseText);
- if(localJson.exceptionInfo){
- showError(localJson.exceptionInfo);return;
- }
- if(localJson.success){
- var data = Ext.decode(localJson.data);
- if(data && data.length > 0) {
- var idx, store = grid.store, record;
- grid.lockrender = true;
- Ext.each(data, function(d){
- idx = store.find('mm_id', d.MP_MMID);
- record = store.getAt(idx);
- if(idx != null && idx >= 0) {
- store.insert(idx + 1, {
- mm_prodcode: d.MP_PRODCODE,
- mm_oneuseqty: record.data.mm_oneuseqty,
- mm_code: record.data.mm_code,
- pr_detail: d.PR_DETAIL,
- pr_spec: d.PR_SPEC,
- pr_unit: d.PR_UNIT,
- mm_canuserepqty: d.MP_CANUSEQTY,
- mm_thisqty: d.MP_THISQTY,
- mm_totaluseqty: d.MP_REPQTY,
- mm_ifrep: 1,
- mm_remark: d.MP_REMARK,
- mm_whcode: d.WH_CODE,
- mm_detno: d.MP_DETNO,
- mm_id: d.MP_MMID,
- isrep: true
- });
- }
- });
- grid.lockrender = false;
- }
- grid.store.fireEvent('load', grid.store);
- }
- }
- });
- },
- /**
- * 转领料前,校验发料套数与领料数
- */
- checkQty: function(a, b){
- var c = this.getMixedGroups(b.selModel.getSelection(), ['mm_code', 'mm_id']),
- code,count,q = 0,m = 0,err = '';
- a.store.each(function(d){
- code = d.get('ma_code');
- if(!Ext.isEmpty(code)) {
- q = d.get('ma_thisqty');
- Ext.Array.each(c, function(i) {
- if(i.keys.mm_code == code) {
- count = 0;
- m = 0;
- Ext.Array.each(i.groups, function(j){
- if(m == 0)
- m = j.get('mm_oneuseqty');
- count += j.get('mm_thisqty');
- });
- if(q * m < count) {
- err += '\n报废数超出报废套数,工单号[' + code + ']';
- }
- }
- });
- }
- });
- return err;
- },
- getMixedGroups: function(items, fields) {
- var data = new Object(),k,o;
- Ext.Array.each(items, function(d){
- k = '';
- o = new Object();
- Ext.each(fields, function(f){
- k += f + ':' + d.get(f) + ',';
- o[f] = d.get(f);
- });
- if(k.length > 0) {
- if(!data[k]) {
- data[k] = {keys: o, groups: [d]};
- } else {
- data[k].groups.push(d);
- }
- }
- });
- return Ext.Object.getValues(data);
- },
- check: function(items) {
- var e = '';
- Ext.Array.each(items, function(item){
- if(Ext.isEmpty(item.get('mm_whcode'))) {
- e += '\n工单[' + item.get('mm_code') + '],行号[' + item.get('mm_detno') + ']仓库为空';
- }
- if(Ext.isEmpty(item.get('mm_thisqty'))) {
- e += '\n工单[' + item.get('mm_code') + '],行号[' + item.get('mm_detno') + ']领料数为空';
- }
- });
- return e;
- },
- getEffectData: function(items) {
- var d = new Array();
- Ext.Array.each(items, function(item){
- d.push({
- mm_detno: item.get('mm_detno'),
- mm_code: item.get('mm_code'),
- mm_id: item.get('isrep') == null ? item.get('mm_id') : -item.get('mm_id'),
- mm_thisqty: item.get('mm_thisqty'),
- mm_whcode: item.get('mm_whcode')
- });
- });
- return d;
- },
- getProductWh: function(grid) {
- var codes = [];
- grid.store.each(function(d){
- codes.push("'" + d.get('mm_prodcode') + "'");
- });
- Ext.Ajax.request({
- url: basePath + 'scm/product/getProductwh.action',
- params: {
- codes: codes.join(',')
- },
- callback: function (opt, s, r) {
- if(s) {
- var rs = Ext.decode(r.responseText);
- if(rs.data) {
- grid.productwh = rs.data;
- }
- }
- }
- });
- },
- getSetting : function(f) {
- Ext.Ajax.request({
- url : basePath + 'common/getFieldData.action',
- async: false,
- params: {
- caller: 'Setting',
- field: 'se_value',
- condition: 'se_what=\'GroupWarehouse.OS\''
- },
- method : 'post',
- callback : function(opt, s, res){
- var r = new Ext.decode(res.responseText);
- if(r.exceptionInfo){
- showError(r.exceptionInfo);return;
- }
- if(r.success && r.data){
- if (r.data == 'false') {
- f.setValue(false);
- }
- }
- }
- });
- }
- });
|