You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DS7/DSWeb/TruckMng/Viewsjs/MsWl_LK_Line/MsWl_LK_LineIndex.js

596 lines
19 KiB
JavaScript

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

//集运管理-路单查询
Ext.namespace('DsTruck');
DsTruck.MsWl_LK_LineIndex = function (config) {
Ext.applyIf(this, config);
this.initUIComponents();
window.DsTruck.MsWl_LK_LineIndex.superclass.constructor.call(this);
};
//201403060002
//13号
Ext.extend(DsTruck.MsWl_LK_LineIndex, Ext.Panel, {
PageSize: 500,
OprationStatus: null, //仅当弹出界面时使用
SelectedRecord: null,
initUIComponents: function () {
this.bodyDel = [];
//定义数据集
this.storeList = Ext.create('Ext.data.Store', {
pageSize: this.PageSize,
idProperty: 'GID',
model: 'MsWl_LK_Linemb',
remoteSort: true,
proxy: {
type: 'ajax',
url: '/TruckMng/MsWl_LK_Line/GetDataList',
reader: {
id: 'GID',
root: 'data',
totalProperty: 'totalCount'
}
}
});
this.formname = "MsWl_LK_Line";
this.formname2 = "MsWl_LK_Point";
this.storeParent = Ext.create('DsExt.ux.RefTableStore', {
model: 'MsWl_LK_CargoInfomb',
proxy: { url: '/TruckMng/MsWl_LK_CargoInfo/GetDataList' }
,
listeners: {
load: function (store, records, successful, operation) {
if (successful) {
var ins_rec = Ext.create('MsWl_LK_CargoInfomb', {
GID: '',
CARGONAME: ''
});
store.insert(0, ins_rec);
}
}
}
});
this.storeParent.load({
params: { start: 0, limit: 500, condition: "" }
});
this.comboxParent = Ext.create('DsExt.ux.RefTableCombox', {
//fieldLabel: '车牌号',
store: this.storeParent,
name: 'PARENT_GID',
valueField: 'GID',
displayField: 'CARGONAME',
listeners: {
change: function (field, newValue, oldValue) {
//this.tonAndTruckNoChange(field, newValue, oldValue);
},
scope: this
}
});
Ext.define('POINTTYPEMd', {
extend: 'Ext.data.Model',
fields: [
{ name: 'POINT_TYPE', type: 'string' }
]
});
var POINTTYPEData = [{ "POINT_TYPE": "水站" },
{ "POINT_TYPE": "干线" }
];
this.storePOINTTYPE = Ext.create('Ext.data.Store', {
model: 'POINTTYPEMd',
data: POINTTYPEData
});
this.comboxPOINTTYPE = Ext.create('DsExt.ux.RefEnumCombox', {
//fieldLabel: '收付类型',
forceSelection: true,
store: this.storePOINTTYPE,
name: 'POINT_TYPE',
valueField: 'POINT_TYPE',
displayField: 'POINT_TYPE'
});
Ext.define('AREAmb', {
extend: 'Ext.data.Model',
fields: [
{ name: 'AREA', type: 'string' }
]
});
var AREAData = [
{ "AREA": "" },
{ "AREA": "市内" },
{ "AREA": "周边" }
];
this.storeAREA = Ext.create('Ext.data.Store', {
model: 'AREAmb',
data: AREAData
});
this.comboxAREA = Ext.create('DsExt.ux.RefEnumCombox', {
//fieldLabel: '收付类型',
forceSelection: true,
store: this.storeAREA,
name: 'AREA',
valueField: 'AREA',
displayField: 'AREA'
});
this.column = [
{
sortable: true,
dataIndex: 'GID', hidden: true,
header: 'GID',
width: 80
}, {
sortable: true,
dataIndex: 'INSERTED', hidden: true,
header: 'INSERTED',
width: 80
},
{
sortable: true,
dataIndex: 'SEQUENCE',
header: '顺序号',
editor: {
xtype: 'numberfield',
allowBlank: false,
selectOnFocus: true
},
width: 45
},
{
sortable: true,
dataIndex: 'NAME',
header: '路线名称',
width: 80,
editor: { xtype: 'textfield',
selectOnFocus: true
}
},
{
sortable: true,
dataIndex: 'LINETYPE',
header: '站点种类(干线、分拨)',
width: 80,
editor: this.comboxPOINTTYPE
},
{
sortable: true,
dataIndex: 'AREA',
header: '站点区域(市内/周边)',
width: 80,
editor: this.comboxAREA
},
{
sortable: true,
dataIndex: 'NoLoadMil',
header: '空载里程',
width: 80,
editor: { xtype: 'numberfield',
selectOnFocus: true
}
},
{
sortable: true,
dataIndex: 'OverLoadMil',
header: '重载里程',
width: 80,
editor: { xtype: 'numberfield',
selectOnFocus: true
}
},
{
sortable: true,
dataIndex: 'Remark',
header: '备注',
width: 150,
editor: { xtype: 'textfield',
selectOnFocus: true
}
}];
this.cellEditing = Ext.create('Ext.grid.plugin.CellEditing', {
clicksToEdit: 1
});
this.ProjectCBModel = Ext.create('Ext.selection.CheckboxModel', { checkOnly: true });
Ext.grid.RowNumberer = Ext.extend(Ext.grid.RowNumberer, {
width: 50
});
//定义Grid
this.gridList = new Ext.grid.GridPanel({
store: this.storeList,
enableHdMenu: false,
region: 'center',
trackResetOnLoad: true,
//height: 160,
title: '路线信息',
loadMask: { msg: "数据加载中,请稍等..." },
trackMouseOver: true,
disableSelection: false,
plugins: [this.cellEditing],
stateful: false,
selModel: this.ProjectCBModel,
selType: 'cellmodel',
columns: [new Ext.grid.RowNumberer()],
bbar: Ext.create('Ext.PagingToolbar', {
store: this.storeList,
displayInfo: true,
displayMsg: '当前显示 {0} - {1}条记录 /共 {2}条记录',
emptyMsg: "没有数据"
})
});
/////////////以下部分为获取存储的gridpanel显示样式
this.column = DsTruck.GetGridPanel(USERID, this.formname, this.column, 1);
//使用者id表名 中间column数组跳过一开始的几列
this.gridList.reconfigure(this.storeList, this.column);
this.gridList.columns[0] = new Ext.grid.RowNumberer();
////////////////////////////
this.gridList.addListener('itemdblclick', function (dataview, record, item, index, e, b) {
this.SelectedRecord = record;
this.OprationStatus = 'edit';
DsOpenEditWin("/TruckMng/MsWl_LK_Line/Edit", record.data.GID, "450", "800");
}, this);
//#region formSearch
this.formSearch = Ext.widget('form', {
frame: true,
region: 'center',
bodyPadding: 5,
fieldDefaults: {
margins: '2 2 2 2',
labelAlign: 'right',
flex: 1,
labelWidth: 90,
msgTarget: 'qtip'
},
items: [
{//fieldset 1
xtype: 'container',
defaultType: 'textfield',
layout: 'anchor',
defaults: {
anchor: '100%'
},
items: [{
xtype: 'container',
layout: 'hbox',
defaultType: 'textfield',
items: [
{
fieldLabel: '线路名称',
name: 'NAME', flex: 1
}, {
fieldLabel: '线路类型',
name: 'LINETYPE', flex: 1
}, {
fieldLabel: '站点名称',
name: 'POINTNAME', flex: 1
}, {
xtype: 'hiddenfield', flex: 2
}
]
}
]//end items(fieldset 1)
}, //end fieldset 1
{//fieldset 2
xtype: 'container',
defaultType: 'textfield',
layout: 'anchor',
defaults: {
anchor: '100%'
},
items: [{
xtype: 'container',
layout: 'hbox',
defaultType: 'textfield',
items: []
}
]//end items(fieldset 2)
}//end fieldset 2
, {//fieldset 2
xtype: 'container',
defaultType: 'textfield',
layout: 'anchor',
defaults: {
anchor: '100%'
},
items: [{
xtype: 'container',
layout: 'hbox',
defaultType: 'textfield',
items: []
}]//end items(fieldset 2)
}//end fieldset 2
]//end root items
});
//查询工具条
this.panelBtn = new Ext.Panel({
region: "north",
tbar: [
{
text: "执行查询",
iconCls: "btnrefresh",
handler: function (button, event) {
this.onRefreshClick(button, event);
},
scope: this
},
{
text: "导出Excel",
id: "btnExportExcel",
iconCls: 'btnexportexcel',
handler: function (button, event) {
this.onExportClick(button, event);
},
scope: this
},
{
text: "保存列表样式",
id: "btntest",
handler: function (button, event) {
this.column = DsTruck.SaveGridPanel(USERID, this.formname, this.gridList.columns, this.column, 1, true);
//alert(this.column[0].id);
},
scope: this
}, '-', {
text: '增加明细',
tooltip: '增加明细',
iconCls: "btnadddetail",
handler: function (button, event) {
this.onAddProjectClick(button, event);
},
scope: this
}, {
text: '删除明细',
tooltip: '删除明细',
iconCls: "btndeletedetail",
handler: function (button, event) {
this.onDelProjectClick(button, event);
},
scope: this
}, {
id: "btnSave",
text: '保存更改',
tooltip: '保存更改',
iconCls: "btnsave",
handler: function (button, event) {
this.Save();
//alert(USERID);
},
scope: this
}, '-'
]
});
//#endregion
this.panelTop = new Ext.Panel({
layout: "border",
region: "north",
height: 100,
items: [this.formSearch, this.panelBtn]
});
Ext.apply(this, {
items: [this.panelTop, this.gridList]
});
this.storeList.on('beforeload', function (store) {
if (!this.checkSearchCondition())
return;
var sql = this.getCondition();
Ext.apply(store.proxy.extraParams, { condition: sql });
}, this);
this.gridList.on('edit', function (editor, e, eOpts) {
this.CargoInfoAfterEdit(editor, e, eOpts);
}, this);
this.onRefreshClick();
}, //end initUIComponents
CargoInfoAfterEdit: function (editor, e, eOpts) {
if (e.field == 'PARENT_GID') {
var records = DsStoreQueryBy(this.storeParent, 'GID', e.value);
if (records.getCount() > 0) {
var data = records.getAt(0).data;
e.record.set('PARENT_NAME', data.CARGONAME);
} else {
e.record.set('PARENT_NAME', '');
}
}
},
reLine: function (button, event) {
var _L = 1;
this.storeList.each(function (record) {
var ln = _L + "";
_L = _L + 1;
record.set('SEQUENCE', ln);
});
},
onAddProjectClick: function (button, event) {
function newID() {
var guid = "";
for (var i = 1; i <= 32; i++) {
var n = Math.floor(Math.random() * 16.0).toString(16);
guid += n;
if ((i == 8) || (i == 12) || (i == 16) || (i == 20))
guid += "-";
}
return guid.toUpperCase();
}
var linenum = this.storeList.getCount() + 1;
var record = Ext.create('MsWl_LK_Linemb', {
'GID': newID(),
'NAME': '',
'LINETYPE': '',
'NoLoadMil': '',
'OverLoadMil': '',
'Remark': '',
'SEQUENCE': linenum,
'INSERTED': ''
});
this.storeList.add(record);
var n = this.storeList.getCount();
this.cellEditing.startEditByPosition({ row: n - 1, column: 3 });
},
onDelProjectClick: function (button, event) {
var selectedRecords = this.gridList.selModel.getSelection();
Ext.MessageBox.confirm('提示', '确定删除记录吗?', function (btn) {
if (btn == 'yes') {
for (var i = 0; i < selectedRecords.length; i++) {
var rec = selectedRecords[i];
if (rec.INSERTED != "") //如果是新增但没有保存的数据,没有必要提交到后台
{
this.bodyDel.push(rec);
}
this.storeList.remove(selectedRecords[i]);
}
}
}, this);
},
OprationSwap: function () {
var ret = new Array();
ret[0] = this.OprationStatus;
ret[1] = this.storeList;
ret[2] = this.SelectedRecord;
return ret;
},
onRefreshClick: function (button, event) {
if (!this.checkSearchCondition())
return;
var sql = this.getCondition();
this.storeList.load({
params: { start: 0, limit: this.PageSize, condition: sql },
waitMsg: "正在查询数据...",
scope: this
});
this.bodyDel = [];
},
getCondition: function () {
var form = this.formSearch.getForm();
if (!form.isValid()) {
Ext.Msg.alert('提示', '查询条件赋值错误,请检查。');
return '';
}
var sql = '';
var NAME = form.findField('NAME').getValue();
sql = sql + getAndConSql(sql, NAME, "NAME like '%" + NAME + "%'");
var LINETYPE = form.findField('LINETYPE').getValue();
sql = sql + getAndConSql(sql, LINETYPE, "LINETYPE like '%" + LINETYPE + "%'");
var POINTNAME = form.findField('POINTNAME').getValue();
sql = sql + getAndConSql(sql, POINTNAME, " GID in(select line_GID from tmswl_lk_linedetail where point_gid in (select gid from tmswl_lk_point where name like '%" + LINETYPE + "%'))");
return sql;
},
checkSearchCondition: function () {
var form = this.formSearch.getForm();
if (!form.isValid()) {
Ext.Msg.alert('提示', '查询条件赋值错误,请检查。');
return false;
}
return true;
},
onExportClick: function (button, event) {
GridExportExcelPage(this.gridList);
},
getStrValue: function (list) {
var _list = [];
for (var _i = 0; _i < list.length; _i++) {
_list.push("'" + list[_i] + "'");
}
return _list;
},
Save: function (type) {
//费用
var bodyList = [];
for (i = 0; i < this.storeList.getCount(); i += 1) {
var member = this.storeList.getAt(i);
bodyList.push(member);
var NAME = member.data.NAME;
var LINETYPE = member.data.LINETYPE;
if (NAME == '' || LINETYPE == '') {
Ext.Msg.show({ title: '警告',
msg: '站点名称和类别均不允许为空,请修改后再保存',
icon: Ext.Msg.ERROR, buttons: Ext.Msg.OK
});
return;
}
};
var jsonBody = ConvertRecordsToJson(bodyList);
var jsonDelBody = ConvertRecordsToJsonAll(this.bodyDel);
if (jsonBody == '' && jsonDelBody == '') {
return;
}
Ext.Msg.wait('正在保存数据, 请稍侯..');
Ext.Ajax.request({
waitMsg: '正在保存数据...',
url: '/TruckMng/MsWl_LK_Line/SaveLine',
scope: this,
params: {
Body: jsonBody,
DelBody: jsonDelBody
},
callback: function (options, success, response) {
if (success) {
Ext.MessageBox.hide();
var jsonresult = Ext.JSON.decode(response.responseText);
if (jsonresult.Success) {
//alert("保存成功");
var returnData = jsonresult.Data;
this.storeList.commitChanges();
} 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
});
}
//alert('03');
}
});
}
});