1061 lines
36 KiB
JavaScript
1061 lines
36 KiB
JavaScript
Ext.namespace('Shipping');
|
|
|
|
Shipping.AiriFenBillList = function (config) {
|
|
Ext.applyIf(this, config);
|
|
this.initUIComponents();
|
|
window.Shipping.AiriFenBillList.superclass.constructor.call(this);
|
|
};
|
|
|
|
Ext.extend(Shipping.AiriFenBillList, Ext.Panel, {
|
|
ParentWin: null,
|
|
OpStatus: 'add',
|
|
EditRecord: null,
|
|
StoreList: null,
|
|
region: 'north',
|
|
BsNo: '',
|
|
FenBsNo:'',
|
|
OprationStatus: null, //仅当弹出界面时使用
|
|
SelectedRecord: null,
|
|
|
|
|
|
initUIComponents: function () {
|
|
|
|
|
|
this.formHead = Ext.widget('form', {
|
|
frame: true,
|
|
title: "主票信息",
|
|
region: 'center',
|
|
bodyPadding: 5,
|
|
fieldDefaults: {
|
|
margins: '2 2 2 2',
|
|
labelAlign: 'right',
|
|
flex: 1,
|
|
labelWidth: 90,
|
|
msgTarget: 'qtip'
|
|
},
|
|
items: [
|
|
{
|
|
xtype: 'fieldset',
|
|
defaultType: 'textfield',
|
|
layout: 'anchor',
|
|
defaults: {
|
|
anchor: '100%'
|
|
},
|
|
items: [
|
|
{ xtype: 'container',
|
|
layout: 'hbox',
|
|
defaultType: 'textfield',
|
|
items: [{
|
|
fieldLabel: '业务编号',
|
|
name: 'BSNO', hidden: true
|
|
}, {
|
|
fieldLabel: '委托编号',
|
|
readOnly: true,
|
|
name: 'CUSTNO'
|
|
}, {
|
|
fieldLabel: '主提单号',
|
|
readOnly: true,
|
|
name: 'MBLNO'
|
|
}, {
|
|
fieldLabel: '委托单位',
|
|
readOnly: true,
|
|
name: 'CUSTOMERNAME'
|
|
},
|
|
{
|
|
fieldLabel: '计费重量',
|
|
readOnly: true,
|
|
name: 'FEEKGS'
|
|
}, {
|
|
fieldLabel: '付费方式',
|
|
readOnly: true,
|
|
name: 'BLFRT'
|
|
}
|
|
]
|
|
},
|
|
{ xtype: 'container',
|
|
layout: 'hbox',
|
|
defaultType: 'textfield',
|
|
items: [
|
|
{
|
|
fieldLabel: '航班',
|
|
readOnly: true,
|
|
name: 'VESSEL'
|
|
}, {
|
|
fieldLabel: '进口日期',
|
|
readOnly: true,
|
|
name: 'ETA'
|
|
}, {
|
|
fieldLabel: '装货港',
|
|
readOnly: true,
|
|
name: 'PORTLOAD'
|
|
}, {
|
|
fieldLabel: '卸货港',
|
|
readOnly: true,
|
|
name: 'PORTDISCHARGE'
|
|
}, {
|
|
fieldLabel: '航班公司',
|
|
readOnly: true,
|
|
name: 'CARRIER'
|
|
}
|
|
]
|
|
},
|
|
{ xtype: 'container',
|
|
layout: 'hbox',
|
|
defaultType: 'textfield',
|
|
items: [
|
|
{
|
|
fieldLabel: '件数',
|
|
readOnly: true,
|
|
name: 'PKGS'
|
|
}, {
|
|
fieldLabel: '包装',
|
|
readOnly: true,
|
|
name: 'KINGPKGS'
|
|
}, {
|
|
fieldLabel: '毛重',
|
|
readOnly: true,
|
|
name: 'KGS'
|
|
}, {
|
|
fieldLabel: '体积',
|
|
readOnly: true,
|
|
name: 'CBM'
|
|
}, {
|
|
fieldLabel: '国外代理',
|
|
readOnly: true,
|
|
name: 'AGENTID'
|
|
}
|
|
]
|
|
}
|
|
|
|
|
|
]
|
|
|
|
}]
|
|
|
|
|
|
}); //end this.formEdit
|
|
|
|
//#region 按钮Toolbar
|
|
this.panelBtn = new Ext.Panel({
|
|
region: "north",
|
|
tbar: [{
|
|
id: 'btnEPrev',
|
|
text: "上一票",
|
|
// iconCls: "btnsave",
|
|
handler: function (button, event) {
|
|
this.PrevRecord();
|
|
},
|
|
scope: this
|
|
}, {
|
|
id: 'btnENext',
|
|
text: "下一票",
|
|
// iconCls: "btnsave",
|
|
handler: function (button, event) {
|
|
this.NextRecord();
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: "打印",
|
|
iconCls: "btnprint",
|
|
handler: function (button, event) {
|
|
this.Print();
|
|
},
|
|
scope: this
|
|
}]
|
|
}); //end 按钮Toolbar
|
|
//#endregion
|
|
|
|
|
|
this.panelTop = new Ext.Panel({
|
|
layout: "border",
|
|
region: "north",
|
|
height: 160,
|
|
items: [this.panelBtn, this.formHead]
|
|
});
|
|
|
|
_thisfenlist = this;
|
|
|
|
this.StoreOpRange = Ext.create('DsExt.ux.RefTableStore', {
|
|
model: 'MsOP',
|
|
proxy: { url: '/MvcShipping/MsBaseInfo/GetOpRang' }
|
|
});
|
|
this.StoreOpRange.load({ params: { optype: "modOpAiriList"} });
|
|
|
|
//#region 分票列表
|
|
this.storeBodyList = Ext.create('Ext.data.Store', {
|
|
model: 'MsOpAiriModel',
|
|
remoteSort: true,
|
|
proxy: {
|
|
type: 'ajax',
|
|
url: '/MvcShipping/MsOpAiri/GetFenList',
|
|
reader: {
|
|
id: 'BsNo',
|
|
root: 'data',
|
|
totalProperty: 'totalCount'
|
|
}
|
|
}
|
|
});
|
|
|
|
this.storeCustCode = Ext.create('DsExt.ux.RefTableStore', {
|
|
model: 'DsShipping.ux.CustomRefModel',
|
|
proxy: { url: '/CommMng/BasicDataRef/GetCustomRefList' }
|
|
});
|
|
|
|
this.comboxCustCode = Ext.create('DsExt.ux.RefTableCombox', {
|
|
store: this.storeCustCode,
|
|
forceSelection: true,
|
|
name: 'CUSTOMERNAME',
|
|
valueField: 'CustName',
|
|
displayField: 'CodeAndName'
|
|
});
|
|
|
|
this.storeOpCode = Ext.create('DsExt.ux.RefTableStore', {
|
|
model: 'DsShipping.ux.UserRefModel',
|
|
proxy: { url: '/CommMng/BasicDataRef/GetUserLinkRefList' }
|
|
});
|
|
this.comboxSALE = Ext.create('DsExt.ux.RefTableCombox', {
|
|
store: this.storeOpCode,
|
|
forceSelection: true,
|
|
name: 'SALE',
|
|
valueField: 'UserName',
|
|
displayField: 'CodeAndName'
|
|
});
|
|
|
|
this.storeFrt = Ext.create('Ext.data.Store', {
|
|
fields: ['FRT']
|
|
});
|
|
this.storeFrt.add({ "FRT": "PP" });
|
|
this.storeFrt.add({ "FRT": "CC" });
|
|
|
|
|
|
this.comboxBLFRT = Ext.create('DsExt.ux.RefTableCombox', {
|
|
store: this.storeFrt,
|
|
forceSelection: true,
|
|
valueField: 'FRT',
|
|
displayField: 'FRT'
|
|
});
|
|
|
|
this.storeCodePackage = Ext.create('DsExt.ux.RefTableStore', {
|
|
model: 'DsShipping.ux.CodePackageModel',
|
|
proxy: { url: '/CommMng/BasicDataRef/GetCodePackageList' }
|
|
});
|
|
this.storeCodePackage.load();
|
|
this.comboxKINDPKGS = Ext.create('DsExt.ux.RefTableCombox', {
|
|
store: this.storeCodePackage,
|
|
name: 'KINDPKGS',
|
|
valueField: 'PKGS',
|
|
displayField: 'PKGS'
|
|
});
|
|
|
|
this.storeCodeDisport = Ext.create('DsExt.ux.RefTableStore', {
|
|
model: 'DsShipping.ux.CodeDisportModel',
|
|
proxy: { url: '/CommMng/BasicDataRef/GetCodeDisportList' }
|
|
});
|
|
|
|
this.comboxDESTINATION = Ext.create('DsExt.ux.RefTableCombox', {
|
|
store: this.storeCodeDisport,
|
|
name: 'DESTINATION',
|
|
valueField: 'PORT',
|
|
displayField: 'PORT'
|
|
});
|
|
|
|
//明细表表格
|
|
this.gridListCellEditing = Ext.create('Ext.grid.plugin.CellEditing', {
|
|
clicksToEdit: 1
|
|
});
|
|
this.GridCheckBoxModel = Ext.create('Ext.selection.CheckboxModel');
|
|
|
|
this.gridList = new Ext.grid.GridPanel({
|
|
store: this.storeBodyList,
|
|
enableHdMenu: false,
|
|
region: 'center',
|
|
loadMask: { msg: "数据加载中,请稍等..." },
|
|
trackMouseOver: true,
|
|
disableSelection: false,
|
|
plugins: [this.gridListCellEditing],
|
|
selModel: this.GridCheckBoxModel,
|
|
selType: 'cellmodel',
|
|
tbar: [{
|
|
text: '添加分票',
|
|
tooltip: '添加分票',
|
|
id: "btnadddetail",
|
|
iconCls: "btnadddetail",
|
|
handler: function (button, event) {
|
|
this.onAddDetailClick(button, event);
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: '保存分票',
|
|
tooltip: '保存分票',
|
|
iconCls: "btnsave",
|
|
handler: function (button, event) {
|
|
this.onPostDetailClick(button, event);
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: '删除分票',
|
|
tooltip: '删除分票',
|
|
id: "btndeldetail",
|
|
iconCls: "btndeletedetail",
|
|
handler: function (button, event) {
|
|
this.onDelDetailClick(button, event);
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: '委托信息',
|
|
tooltip: '委托信息',
|
|
handler: function (button, event) {
|
|
var selectedRecords = this.GridCheckBoxModel.selected.items;
|
|
if (selectedRecords.length == 0) {
|
|
Ext.Msg.show({ title: '提示', msg: '请先选择要编辑的分票!', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
return;
|
|
}
|
|
var rec = selectedRecords[0];
|
|
this.SelectedRecord = rec;
|
|
this.OprationStatus = 'edit';
|
|
// DsOpenEditWin('/MvcShipping/MsOpSeae/FenEdit', "分票信息");
|
|
DsOpenEditWin('/MvcShipping/MsOpAiri/Edit', "分票信息");
|
|
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: '费用信息',
|
|
tooltip: '费用信息',
|
|
handler: function (button, event) {
|
|
_thisfenlist.onFenFeeEditClick(button, event);
|
|
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: '提单信息',
|
|
tooltip: '提单信息',
|
|
handler: function (button, event) {
|
|
// this.onPostDetailClick(button, event);
|
|
},
|
|
scope: this
|
|
}, '-', {
|
|
text: '业务函电',
|
|
tooltip: '业务函电',
|
|
handler: function (button, event) {
|
|
// this.onPostDetailClick(button, event);
|
|
},
|
|
scope: this
|
|
}],
|
|
|
|
columns: [{
|
|
sortable: true,
|
|
dataIndex: 'MASTERNO',
|
|
header: '主编号',
|
|
hidden: true,
|
|
width: 0
|
|
}, {
|
|
sortable: true,
|
|
dataIndex: 'BSNO',
|
|
header: '业务编号',
|
|
hidden: true,
|
|
width: 0
|
|
}, {
|
|
dataIndex: 'MBLNO',
|
|
header: '主提单号',
|
|
width: 130,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'HBLNO',
|
|
header: '分提单号',
|
|
width: 130,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'CUSTOMERNAME',
|
|
header: '委托单位',
|
|
width: 120,
|
|
editor: this.comboxCustCode
|
|
}, {
|
|
dataIndex: 'SALE',
|
|
header: '销售',
|
|
width: 70,
|
|
editor: this.comboxSALE
|
|
}, {
|
|
sortable: true,
|
|
dataIndex: 'PKGS',
|
|
header: '件数',
|
|
width: 80,
|
|
editor: {
|
|
xtype: 'numberfield',
|
|
allowBlank: false,
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'KINDPKGS',
|
|
header: '包装',
|
|
width: 100,
|
|
editor: this.comboxKINDPKGS
|
|
}, {
|
|
dataIndex: 'KGS',
|
|
header: '重量',
|
|
width: 80,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'CBM',
|
|
header: '尺码',
|
|
width: 80,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'FEEKGS',
|
|
header: '计费重量',
|
|
width: 80,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'BLFRT',
|
|
header: '运费',
|
|
width: 60,
|
|
editor: this.comboxBLFRT
|
|
}, {
|
|
dataIndex: 'OTFRT',
|
|
header: '杂费',
|
|
width: 60,
|
|
editor: this.comboxBLFRT
|
|
}, {
|
|
dataIndex: 'GOODSNAME',
|
|
header: '品名',
|
|
width: 150,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'REMARK',
|
|
header: '备注',
|
|
width: 150,
|
|
editor: {
|
|
xtype: 'textfield',
|
|
selectOnFocus: true
|
|
}
|
|
}, {
|
|
dataIndex: 'CUSTNO',
|
|
header: '委托编号',
|
|
width: 130
|
|
}]
|
|
});
|
|
//#endregion
|
|
|
|
|
|
|
|
|
|
//#region 合计列表
|
|
|
|
this.SumField = [
|
|
{ name: 'NOBILL', type: 'number' },
|
|
{ name: 'KGS', type: 'number' },
|
|
{ name: 'PKGS', type: 'number' },
|
|
{ name: 'CBM', type: 'number' }
|
|
];
|
|
|
|
this.storeSumList = Ext.create('Ext.data.Store', {
|
|
pageSize: this.PageSize,
|
|
fields: this.SumField,
|
|
remoteSort: true,
|
|
proxy: {
|
|
type: 'ajax',
|
|
url: '/MvcShipping/MsOpAiri/GetDataListSum',
|
|
reader: {
|
|
id: '',
|
|
root: 'data',
|
|
totalProperty: 'totalCount'
|
|
}
|
|
}
|
|
});
|
|
|
|
this.girdcolumsSum = [{
|
|
sortable: true,
|
|
dataIndex: 'NOBILL',
|
|
header: '票数',
|
|
align: 'right',
|
|
width: 60
|
|
}, {
|
|
sortable: true,
|
|
dataIndex: 'PKGS',
|
|
header: '件数',
|
|
renderer: function (value, cellmeta, record, rowIndex, columnIndex, store) { try { var lsValue = usMoney(value, 2, '', false); if (lsValue != "NaN") { value = lsValue; if (parseFloat(lsValue) < 0) { return '<SPAN style="COLOR: red">' + lsValue + '</SPAN>'; } } else { return value; } } catch (e) { return value; } return value; },
|
|
align: 'right',
|
|
width: 80
|
|
}, {
|
|
sortable: true,
|
|
dataIndex: 'KGS',
|
|
header: '毛重',
|
|
renderer: function (value, cellmeta, record, rowIndex, columnIndex, store) { try { var lsValue = usMoney(value, 2, '', false); if (lsValue != "NaN") { value = lsValue; if (parseFloat(lsValue) < 0) { return '<SPAN style="COLOR: red">' + lsValue + '</SPAN>'; } } else { return value; } } catch (e) { return value; } return value; },
|
|
align: 'right',
|
|
width: 80
|
|
}, {
|
|
sortable: true,
|
|
dataIndex: 'CBM',
|
|
header: '尺码',
|
|
renderer: function (value, cellmeta, record, rowIndex, columnIndex, store) { try { var lsValue = usMoney(value, 2, '', false); if (lsValue != "NaN") { value = lsValue; if (parseFloat(lsValue) < 0) { return '<SPAN style="COLOR: red">' + lsValue + '</SPAN>'; } } else { return value; } } catch (e) { return value; } return value; },
|
|
align: 'right',
|
|
width: 60
|
|
}, {
|
|
sortable: true,
|
|
dataIndex: 'FEEKGS',
|
|
header: '计费重量',
|
|
renderer: function (value, cellmeta, record, rowIndex, columnIndex, store) { try { var lsValue = usMoney(value, 2, '', false); if (lsValue != "NaN") { value = lsValue; if (parseFloat(lsValue) < 0) { return '<SPAN style="COLOR: red">' + lsValue + '</SPAN>'; } } else { return value; } } catch (e) { return value; } return value; },
|
|
align: 'right',
|
|
width: 60
|
|
}
|
|
|
|
];
|
|
|
|
this.gridListSum = new Ext.grid.GridPanel({
|
|
store: this.storeSumList,
|
|
enableHdMenu: false,
|
|
region: 'center',
|
|
loadMask: { msg: "数据加载中,请稍等..." },
|
|
trackMouseOver: true,
|
|
disableSelection: false,
|
|
columns: this.girdcolumsSum
|
|
});
|
|
|
|
|
|
//#endregion
|
|
|
|
this.panelBodysouth = new Ext.Panel({
|
|
layout: "border",
|
|
height: 90,
|
|
region: 'south',
|
|
//margin: '5 10',
|
|
frame: true,
|
|
items: [this.gridListSum]
|
|
});
|
|
|
|
this.gridList.on('edit', function (editor, e, eOpts) {
|
|
this.gridListAfterEdit(editor, e, eOpts);
|
|
}, this);
|
|
|
|
this.gridListCellEditing.on('beforeedit', function (editor, e) {
|
|
return this.cellEditingBeforeEdit(editor, e);
|
|
}, this);
|
|
|
|
this.gridList.addListener('itemdblclick', function (dataview, record, item, index, e, b) {
|
|
this.SelectedRecord = record;
|
|
this.OprationStatus = 'edit';
|
|
DsOpenEditWin('/MvcShipping/MsOpAiri/Edit', "分票信息");
|
|
}, this);
|
|
|
|
|
|
this.panelBody = new Ext.Panel({
|
|
title: '分票信息',
|
|
region: 'center',
|
|
layout: "border",
|
|
frame: true,
|
|
items: [this.gridList, this.panelBodysouth]
|
|
});
|
|
|
|
Ext.apply(this, {
|
|
items: [this.panelTop, this.panelBody]
|
|
});
|
|
|
|
this.storeBodyList.on('beforeload', function (store) {
|
|
var sql = " MASTERNO='" + this.EditRecord.get('BSNO') + "' AND BSNO<>MASTERNO";
|
|
Ext.apply(store.proxy.extraParams, { condition: sql });
|
|
}, this);
|
|
|
|
|
|
parentWin = window.parent.opener;
|
|
this.InitData();
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
//#region 加载事件
|
|
InitData: function () {
|
|
this.opStatus = 'add';
|
|
var condition = '';
|
|
_this = this;
|
|
if (parentWin) {
|
|
var ret = parentWin.OprationSwap();
|
|
this.opStatus = ret[0];
|
|
this.StoreList = ret[1];
|
|
this.EditRecord = ret[2];
|
|
}
|
|
|
|
this.BsNo = this.EditRecord.get('BSNO');
|
|
|
|
condition = " MASTERNO='" + this.EditRecord.get('BSNO') + "' AND BSNO<>MASTERNO";
|
|
|
|
this.LoadData();
|
|
this.storeCustCode.load({ params: { condition: "ISCONTROLLER='1'"} });
|
|
this.storeOpCode.load();
|
|
this.storeCodeDisport.load();
|
|
this.storeBodyList.load({ params: { condition: condition} });
|
|
this.storeSumList.load({ params: { condition: condition} });
|
|
|
|
}, //end InitData
|
|
|
|
LoadData: function () {
|
|
this.formHead.getForm().loadRecord(this.EditRecord);
|
|
|
|
|
|
|
|
|
|
}, // end LoadDate
|
|
|
|
|
|
PrevRecord: function () {
|
|
var j = this.StoreList.indexOf(this.EditRecord);
|
|
if (j == 0) {
|
|
Ext.Msg.show({ title: '警告', msg: '已是最前一票', icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK });
|
|
|
|
return;
|
|
}
|
|
if (j == this.StoreList.count) {
|
|
Ext.Msg.show({ title: '警告', msg: '已是最后一票', icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK });
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
j = j - 1;
|
|
this.EditRecord = this.StoreList.getAt(j);
|
|
this.BsNo = this.EditRecord.get('BSNO');
|
|
this.LoadData();
|
|
},
|
|
NextRecord: function () {
|
|
var j = this.StoreList.indexOf(this.EditRecord);
|
|
|
|
if (j == (this.StoreList.count - 1)) {
|
|
Ext.Msg.show({ title: '警告', msg: '已是最后一票', icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK });
|
|
|
|
return;
|
|
|
|
}
|
|
j = j + 1;
|
|
this.EditRecord = this.StoreList.getAt(j);
|
|
this.BsNo = this.EditRecord.get('BSNO');
|
|
this.LoadData();
|
|
|
|
},
|
|
|
|
onNextKeyClick: function (col) {
|
|
|
|
var rows = this.gridList.getSelectionModel().getSelection();
|
|
var row = rows[rows.length - 1];
|
|
var s = this.gridList.getStore();
|
|
var number = s.indexOf(row) + 1;
|
|
if (number == this.gridList.getStore().getCount()) {
|
|
this.onAddDetailClick(s, event);
|
|
} else {
|
|
this.gridListCellEditing.startEditByPosition({ row: number, column: col });
|
|
}
|
|
|
|
},
|
|
onAddDetailClick: function (button, event) {
|
|
|
|
var allow = this.getAllowOperationDetail();
|
|
if (allow == false) {
|
|
return;
|
|
}
|
|
|
|
var store = null;
|
|
store = this.storeBodyList;
|
|
var myDate = new Date();
|
|
var mydatestr = Ext.util.Format.date(myDate, 'Y-m-d');
|
|
var record = null;
|
|
record = Ext.create('MsOpAiriModel', {
|
|
BSNO: NewGuid(),
|
|
ORDERTYPE: '操作录入',
|
|
MASTERNO: '*',
|
|
CUSTNO: '',
|
|
MBLNO: this.EditRecord.get('MBLNO'),
|
|
HBLNO: '',
|
|
BSSTATUS: false,
|
|
FEESTATUS: false,
|
|
BSSTATUSREF: '未锁定',
|
|
FEESTATUSREF: '未锁定',
|
|
ACCDATE: this.EditRecord.get('ACCDATE'),
|
|
BSDATE: mydatestr,
|
|
INPUTBY: SHOWNAME,
|
|
OP: SHOWNAME,
|
|
CUSTSERVICE: SHOWNAME,
|
|
VESSEL: this.EditRecord.get('VESSEL'),
|
|
ETD: this.EditRecord.get('ETD'),
|
|
PORTLOADID: this.EditRecord.get('PORTLOADID'),
|
|
PORTLOAD: this.EditRecord.get('PORTLOAD'),
|
|
PORTDISCHARGEID: this.EditRecord.get('PORTDISCHARGEID'),
|
|
PORTDISCHARGE: this.EditRecord.get('PORTDISCHARGE'),
|
|
BLTYPE: '空运分票',
|
|
AGENTID: this.EditRecord.get('AGENTID'),
|
|
AGENT: this.EditRecord.get('AGENT'),
|
|
ETA: this.EditRecord.get('ETA'),
|
|
BLFRT: 'PP',
|
|
OTFRT: 'PP',
|
|
FORWARDER: this.EditRecord.get('FORWARDER'),
|
|
AIRLINES: this.EditRecord.get('AIRLINES'),
|
|
KINGPKGS: 'CTNS',
|
|
CARGOID: 'S',
|
|
PKGS: 0,
|
|
KGS: 0,
|
|
CBM: 0,
|
|
FEEKGS: 0,
|
|
ISVOU: false
|
|
});
|
|
|
|
|
|
store.add(record);
|
|
|
|
var editColumnIndex = 0;
|
|
var cellediting = this.gridListCellEditing;
|
|
editColumnIndex = 3;
|
|
var n = store.getCount();
|
|
cellediting.startEditByPosition({ row: n - 1, column: editColumnIndex });
|
|
|
|
},
|
|
|
|
onPostDetailClick: function (button, event) {
|
|
|
|
var bodyDatas = [];
|
|
var i;
|
|
|
|
|
|
for (i = 0; i < this.storeBodyList.getCount(); i += 1) {
|
|
var memberyf = this.storeBodyList.getAt(i);
|
|
bodyDatas.push(memberyf);
|
|
|
|
};
|
|
var jsonBody = ConvertRecordsToJsonAll(bodyDatas);
|
|
|
|
|
|
|
|
Ext.Msg.wait('正在保存数据, 请稍侯..');
|
|
Ext.Ajax.request({
|
|
waitMsg: '正在保存数据...',
|
|
url: '/MvcShipping/MsOpAiri/SaveFen',
|
|
scope: this,
|
|
params: {
|
|
bsno: _thisfenlist.BsNo,
|
|
fenbody: jsonBody
|
|
},
|
|
callback: function (options, success, response) {
|
|
if (success) {
|
|
Ext.MessageBox.hide();
|
|
var jsonresult = Ext.JSON.decode(response.responseText);
|
|
if (jsonresult.Success) {
|
|
|
|
for (var i = 0; i < this.storeBodyList.getCount(); i += 1) {
|
|
var member = this.storeBodyList.getAt(i);
|
|
member.set("MASTERNO", _thisfenlist.BsNo);
|
|
member.commit();
|
|
}
|
|
|
|
|
|
} else {
|
|
Ext.Msg.show({ title: '错误', msg: jsonresult.Message, icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK });
|
|
}
|
|
} else {
|
|
Ext.Msg.show({ title: '请重试',
|
|
msg: '服务器响应出错',
|
|
icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK
|
|
});
|
|
}
|
|
}
|
|
});
|
|
}, //end save
|
|
|
|
onDelDetailClick: function (button, event) {
|
|
var allow = this.getAllowOperationDetail();
|
|
if (allow == false) {
|
|
return;
|
|
}
|
|
var feeGidSql = '';
|
|
var selectedRecords = [];
|
|
|
|
selectedRecords = this.GridCheckBoxModel.selected.items;
|
|
var candelete = this.CheckDelete(selectedRecords);
|
|
if (candelete == false)
|
|
return;
|
|
|
|
|
|
|
|
if (selectedRecords.length == 0) {
|
|
Ext.Msg.show({ title: '提示', msg: '请先选择要删除的分票!', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
return;
|
|
}
|
|
|
|
var bodyDatas = [];
|
|
|
|
Ext.MessageBox.confirm('提示', '确定要删除选中的分票吗?', function (btn) {
|
|
if (btn == 'yes') {
|
|
|
|
|
|
if (selectedRecords.length > 0) {
|
|
for (var i = 0; i < selectedRecords.length; i++) {
|
|
var rec = selectedRecords[i];
|
|
if (rec.data.MASTERNO == "*") //如果是新增但没有保存的数据,没有必要提交到后台
|
|
{
|
|
this.storeBodyList.remove(selectedRecords[i]);
|
|
|
|
} else {
|
|
bodyDatas.push(rec);
|
|
var feeGId = "'" + rec.data.BSNO + "'";
|
|
if (feeGidSql == '') {
|
|
feeGidSql = feeGId;
|
|
} else {
|
|
feeGidSql = feeGidSql + "," + feeGId;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
var jsonBody = ConvertRecordsToJsonAll(bodyDatas);
|
|
_thisfenlist = this;
|
|
|
|
Ext.Msg.wait('正在删除数据...');
|
|
if (feeGidSql != '') {
|
|
Ext.Ajax.request({
|
|
waitMsg: '正在删除数据...',
|
|
url: '/MvcShipping/MsOpAiri/DeleteFen',
|
|
params: {
|
|
bsno: _thisfenlist.BsNo,
|
|
fenbody: jsonBody
|
|
},
|
|
callback: function (options, success, response) {
|
|
if (success) {
|
|
var jsonresult = Ext.JSON.decode(response.responseText);
|
|
if (jsonresult.Success) {
|
|
|
|
this.storeBodyList.load({ params: { condition: " MASTERNO='" + _thisfenlist.EditRecord.get('BSNO') + "' AND BSNO<>MASTERNO"} });
|
|
|
|
Ext.Msg.show({ title: '提示', msg: jsonresult.Message, icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
}
|
|
else {
|
|
Ext.Msg.show({ title: '错误', msg: jsonresult.Message, icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK });
|
|
}
|
|
}
|
|
},
|
|
failure: function (response, options) {
|
|
Ext.Msg.show({ title: '警告', msg: '服务器响应出错,请重试', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
},
|
|
success: function (response, options) {
|
|
},
|
|
scope: this
|
|
}); //end Ext.Ajax.request
|
|
} else {
|
|
|
|
Ext.Msg.show({ title: '提示', msg: "删除成功!", icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
}
|
|
|
|
}
|
|
}, this);
|
|
|
|
|
|
},
|
|
|
|
getAllowOperationDetail: function () {
|
|
var BsStatus = this.EditRecord.get('BSSTATUS');
|
|
if (BsStatus == '0')
|
|
return true;
|
|
else {
|
|
Ext.Msg.show({ title: '错误', msg: "此票主票已业务锁定,不允许操作分票!", icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK });
|
|
return false;
|
|
}
|
|
},
|
|
|
|
CheckDelete: function (records) {
|
|
for (var i = 0; i < records.length; i++) {
|
|
var rec = records[i];
|
|
var BsStatus = rec.data.BSSTATUS;
|
|
if (BsStatus == true) {
|
|
Ext.Msg.show({ title: '提示',
|
|
msg: '已业务锁定无法修改或删除!',
|
|
icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK
|
|
});
|
|
return false;
|
|
}
|
|
|
|
if (BsStatus != true) {
|
|
var op = rec.data.OP;
|
|
var inputby = rec.data.INPUTBY;
|
|
var records = DsStoreQueryBy(_thisfenlist.StoreOpRange, 'OPID', op);
|
|
if (records.getCount() > 0) {
|
|
canedit = true;
|
|
} else {
|
|
var recordins = DsStoreQueryBy(_thisfenlist.StoreOpRange, 'OPID', inputby);
|
|
if (recordins.getCount() > 0) {
|
|
canedit = true;
|
|
} else {
|
|
Ext.Msg.show({ title: '提示', msg: '你没有权限删除或修改' + op + '录入的业务!', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
return false;
|
|
}
|
|
}
|
|
if (canedit == false) {
|
|
Ext.Msg.show({ title: '提示', msg: '你没有权限删除或修改' + op + '录入的业务!', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
return false;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
cellEditingBeforeEdit: function (editor, e) {
|
|
var allow = this.getAllowOperationDetail();
|
|
if (allow == false) {
|
|
return;
|
|
}
|
|
var chfeefeeStatus = e.record.get('BSSTATUS');
|
|
var canedit = chfeefeeStatus != true;
|
|
|
|
if (canedit) {
|
|
var op = e.record.get('OP');
|
|
var inputby = e.record.get('INPUTBY');
|
|
var records = DsStoreQueryBy(_thisfenlist.StoreOpRange, 'OPID', op);
|
|
if (records.getCount() > 0) {
|
|
canedit = true;
|
|
} else {
|
|
var recordins = DsStoreQueryBy(_thisfenlist.StoreOpRange, 'OPID', inputby);
|
|
if (recordins.getCount() > 0) {
|
|
canedit = true;
|
|
} else {
|
|
Ext.Msg.show({ title: '提示', msg: '你没有权限删除或修改' + op + '录入的业务!', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
canedit = false;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
return canedit;
|
|
|
|
},
|
|
|
|
gridListAfterEdit: function (editor, e, eOpts) {
|
|
|
|
if (e.value == e.originalValue) return;
|
|
|
|
if (e.field == 'CUSTOMERNAME') {
|
|
var records = DsStoreQueryBy(this.storeCustCode, 'CustName', e.value);
|
|
if (records.getCount() > 0) {
|
|
var data = records.getAt(0).data;
|
|
e.record.set('SALE', data.SALE);
|
|
}
|
|
} else if (e.field == 'PKGS') {
|
|
var PKGS = e.value;
|
|
var KINDPKGS = e.record.data['KINDPKGS'];
|
|
e.record.set('NOPKGS', PKGS + KINDPKGS);
|
|
e.record.set('TOTALNO', 'SAY:' + ToEn(PKGS).toUpperCase() + ' ' + KINDPKGS + ' ONLY.');
|
|
this.calcDetailTotal();
|
|
} else if (e.field == 'KINDPKGS') {
|
|
var PKGS = e.record.data['PKGS'];
|
|
var KINDPKGS = e.value
|
|
e.record.set('NOPKGS', PKGS + KINDPKGS);
|
|
e.record.set('TOTALNO', 'SAY:' + ToEn(PKGS).toUpperCase() + ' ' + KINDPKGS + ' ONLY.');
|
|
} else if (e.field == 'BLFRT') {
|
|
|
|
if (e.value == "FREIGHT PREPAID") {
|
|
var portload = e.record.data['PORTLOAD'];
|
|
e.record.set('PREPARDAT', portload);
|
|
e.record.set('PAYABLEAT', '');
|
|
} else if (e.value == "FREIGHT COLLECT") {
|
|
var PORTDISCHARGE = e.record.data['PORTDISCHARGE'];
|
|
e.record.set('PREPARDAT', '');
|
|
e.record.set('PAYABLEAT', PORTDISCHARGE);
|
|
}
|
|
} else if (e.field == 'CBM') {
|
|
this.calcDetailTotal();
|
|
} else if (e.field == 'KGS') {
|
|
this.calcDetailTotal();
|
|
} else if (e.field == 'FEEKGS') {
|
|
this.calcDetailTotal();
|
|
}
|
|
|
|
},
|
|
|
|
calcDetailTotal: function () {
|
|
var blcount = 0;
|
|
var ttlpkgs = 0;
|
|
var ttlkgs = 0;
|
|
var ttlcbm = 0;
|
|
var ttlfeekgs = 0;
|
|
|
|
|
|
for (var i = 0; i < this.storeBodyList.getCount(); i += 1) {
|
|
var member = this.storeBodyList.getAt(i);
|
|
var PKGS = member.get('PKGS');
|
|
var KGS = member.get('KGS');
|
|
var CBM = member.get('CBM');
|
|
var FEEKGS = member.get('FEEKGS');
|
|
ttlpkgs = Add(parseFloat(ttlpkgs), PKGS);
|
|
ttlkgs = Add(parseFloat(ttlkgs), KGS);
|
|
ttlcbm = Add(parseFloat(ttlcbm), CBM);
|
|
ttlfeekgs = Add(parseFloat(ttlfeekgs), FEEKGS);
|
|
blcount = blcount + 1;
|
|
}
|
|
|
|
|
|
var memberyf = this.storeSumList.getAt(0);
|
|
memberyf.set("NOBILL", blcount);
|
|
memberyf.set("PKGS", ttlpkgs);
|
|
memberyf.set("KGS", ttlkgs);
|
|
memberyf.set("CBM", ttlcbm);
|
|
memberyf.set("FEEKGS", ttlfeekgs);
|
|
memberyf.commit();
|
|
},
|
|
OprationSwap: function () {
|
|
var ret = new Array();
|
|
ret[0] = this.OprationStatus;
|
|
ret[1] = this.storeBodyList;
|
|
ret[2] = this.SelectedRecord;
|
|
ret[3] = this.EditRecord;
|
|
return ret;
|
|
},
|
|
|
|
onFenFeeEditClick: function (menu, event) {
|
|
|
|
var selections = this.gridList.getSelectionModel().getSelection();
|
|
if (selections.length == 0) {
|
|
Ext.Msg.show({ title: '提示', msg: '请先选择业务!', icon: Ext.Msg.INFO, buttons: Ext.Msg.OK });
|
|
return;
|
|
}
|
|
|
|
var record = selections[0];
|
|
|
|
this.SelectedRecord = record;
|
|
this.OprationStatus = 'edit';
|
|
DsOpenEditWin('/MvcShipping/MsOpAiri/PiLiangFenFee', '分票费用');
|
|
|
|
},
|
|
|
|
Print: function () {
|
|
|
|
var printType = 'MSOPAIRIFENLIST';
|
|
var sql1 = "select * from op_airi WHERE BSNO='" + this.BsNo + "'";
|
|
var sql2 = "select * from op_airi where MASTERNO='" + this.BsNo + "' AND BSNO<>MASTERNO ORDER BY HBLNO";
|
|
var sql3 = "";
|
|
var sql4 = "";
|
|
var sql5 = "";
|
|
var sql6 = "";
|
|
|
|
PrintComm(printType, sql1, sql2, sql3, sql4, sql5, sql6);
|
|
}
|
|
|
|
|
|
});
|
|
|