/** * Company.js * 监控单元管理界面 * emial: yaoqiang@chinausky.com * create: 2018-12-08 */ Ext.Loader.setConfig({ enabled: true }); Ext.Loader.setPath('Ext.ux', '../../res/extjs/examples/ux'); Ext.require([ 'Ext.grid.*', 'Ext.data.*', 'Ext.ux.RowExpander', 'Ext.selection.CheckboxModel' ]); var sm = Ext.create('Ext.selection.CheckboxModel'); Ext.define('Unit',{ extend: 'Ext.data.Model', fields: [ {name:'UQ_UNIT_ID', type:'string'}, {name:'I_ORDER_IDX', type:'int'}, {name:'V_UNIT_CODE', type:'string'}, {name:'UQ_IOTCARD_ID', type:'string'}, {name:'UQ_COMPANY_ID', type:'string'}, {name:'UQ_UNIT_MODEL_ID', type:'string'}, {name:'V_UNIT_NAME', type:'string'}, {name:'V_POSITION', type:'string'}, {name:'UQ_EMPLOYEE_ID', type:'string'}, {name:'E_STATUS', type:'string'}, {name:'V_COMMENT', type:'string'}, {name:'UQ_ADMIN_ID', type:'string'}, {name:'I_VERSION', type:'int'}, {name:'D_INSTALLTIME', type:'string'}, ] }); Ext.onReady(function(){ var baseUrl = document.getElementById('basePath').value; var theme = document.getElementById('theme').value; var chkIcon = '' var unchkIcon = '' var countPerPage = 20; var maxHeight = 10000; var chkBoolean = function(flag) { if(flag) return chkIcon; return unchkIcon; } var states1 = Ext.create('Ext.data.Store', { fields: ['status', 'name'], data : [ // {"status":-1, "name":"全选"}, {"status":"待开通", "name":"待开通"}, {"status":"已开通", "name":"已开通"}, {"status":"已锁定", "name":"已锁定"}, {"status":"注销", "name":"注销"}, ] }); var clear_append_form = function (){ Ext.getCmp('fa_V_UNIT_NAME').setValue(""); Ext.getCmp('fa_V_UNIT_CODE').setValue(""); Ext.getCmp('fa_UQ_COMPANY_ID').setValue(""); Ext.getCmp('fa_UQ_UNIT_MODEL_ID').setValue(""); Ext.getCmp('fa_V_POSITION').setValue(""); Ext.getCmp('fa_UQ_EMPLOYEE_ID').setValue(""); Ext.getCmp('fa_UQ_ADMIN_ID').setValue(""); Ext.getCmp('fa_UQ_IOTCARD_ID').setValue(""); Ext.getCmp('fa_V_COMMENT').setValue(""); //Ext.getCmp('fa_E_STATUS').setValue(); Ext.getCmp('UnitListPanel').getStore().reload(); } var myStore = Ext.create('Ext.data.Store', { model: 'Unit', pageSize: countPerPage, proxy: { type: 'ajax', url: baseUrl+'iot/unit/getList', reader: { type: 'json', root: 'RESULT', totalProperty: 'totalCount' } }, remoteSort: true }); var AppendForm = Ext.create('Ext.form.Panel', { id: 'unitAppendForm', labelWidth: 55, url: baseUrl+'iot/unit/append', defaultType: 'textfield', bodyPadding: 15, items: [{ fieldLabel:'监控单元名称', id: 'fa_V_UNIT_NAME', name:'V_UNIT_NAME', maxLength:20, maxLengthText:'长度不得超出{0}', anchor:'75%' },{ fieldLabel:'监控单元编号', id: 'fa_V_UNIT_CODE', name: 'V_UNIT_CODE', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'物联网卡ID', id: 'fa_UQ_IOTCARD_ID', name: 'UQ_IOTCARD_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'单位/部门ID', id: 'fa_UQ_COMPANY_ID', name: 'UQ_COMPANY_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'监控单元型号ID', id: 'fa_UQ_UNIT_MODEL_ID', name: 'UQ_UNIT_MODEL_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'监控单元安装位置', id: 'fa_V_POSITION', name: 'V_POSITION', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'安装人ID', id: 'fa_UQ_EMPLOYEE_ID', name: 'UQ_EMPLOYEE_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'信息录入人ID', id: 'fa_UQ_ADMIN_ID', name:'UQ_ADMIN_ID', maxLength: 30, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'新增说明', id: 'fa_V_COMMENT', name:'V_COMMENT', xtype: 'textareafield', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'100%' },{ id:'fa_queryJson', name:'queryJson', hidden:true }], buttons: [{ text: '提交', iconCls:'ok_btn', handler: function() { var form = this.up('form').getForm(); if (form.isValid()) { var query = new Object(); query.V_UNIT_NAME = Ext.getCmp('fa_V_UNIT_NAME').getValue(); query.V_UNIT_CODE = Ext.getCmp('fa_V_UNIT_CODE').getValue(); query.UQ_COMPANY_ID = Ext.getCmp('fa_UQ_COMPANY_ID').getValue(); query.UQ_UNIT_MODEL_ID = Ext.getCmp('fa_UQ_UNIT_MODEL_ID').getValue(); query.V_POSITION = Ext.getCmp('fa_V_POSITION').getValue(); query.UQ_ADMIN_ID = Ext.getCmp('fa_UQ_ADMIN_ID').getValue(); query.UQ_EMPLOYEE_ID = Ext.getCmp('fa_UQ_EMPLOYEE_ID').getValue(); query.UQ_IOTCARD_ID = Ext.getCmp('fa_UQ_IOTCARD_ID').getValue(); query.V_COMMENT = Ext.getCmp('fa_V_COMMENT').getValue(); // query.E_STATUS = Ext.getCmp('fa_E_STATUS').getValue(0); var jsonstr = Ext.JSON.encode(query); Ext.getCmp('fa_queryJson').setValue(jsonstr); form.submit({ method:'post', success: function(form, action) { Ext.Msg.alert('操作成功', '新增单位已保存', function(btn,txt){ clear_append_form(); }); }, failure: function(form, action) { Ext.Msg.alert('操作失败', action.Msg , function(btn,txt){ clear_append_form(); }); } }); } } },{ text: '关闭', iconCls: 'cancel_btn', handler: function() { this.up('window').hide(); } }] }); var appendwin = function(){ Ext.create('Ext.window.Window', { title: '新增监控单元', height: 450, width: 400, layout: 'fit', items: AppendForm, closeAction: 'hide' }).show(); } //筛选 var states2 = Ext.create('Ext.data.Store', { fields: ['status', 'name'], data : [ {"status":10, "name":"全选"}, {"status":0, "name":"待开通"}, {"status":1, "name":"已开通"}, {"status":2, "name":"已锁定"}, {"status":3, "name":"注销"}, ] }); var clear_filter_form = function(){ Ext.getCmp('ff_V_UNIT_NAME').setValue(""); Ext.getCmp('ff_UQ_UNIT_MODEL_ID').setValue(""); Ext.getCmp('ff_UQ_COMPANY_ID').setValue(""); Ext.getCmp('ff_V_UNIT_CODE').setValue(""); Ext.getCmp('ff_UQ_EMPLOYEE_ID').setValue(""); Ext.getCmp('ff_E_STATUS').setValue("10"); // Ext.getCmp('ff_V_COMMENT').setValue(""); } // // var states = Ext.create('Ext.data.Store', { fields: ['status', 'name'], data : [ {"status":-1, "name":"全选"}, {"status":0, "name":"无效"}, {"status":1, "name":"有效"} ] }); var FilterWin = Ext.create('Ext.form.Panel', { id: 'UnitFilterForm', labelWidth: 55, defaultType: 'textfield', bodyPadding: 15, items: [{ fieldLabel:'监控单元名称', id: 'ff_V_UNIT_NAME', name:'V_UNIT_NAME', maxLength:20, maxLengthText:'长度不得超出{0}', value : document.getElementById('unitName').value, anchor:'75%' },{ fieldLabel:'当前状态', id:'ff_E_STATUS', name:'E_STATUS', xtype:'combo', store:states2, displayField : 'name', valueField : 'status', value : document.getElementById('estatus').value, editable : false },{ fieldLabel:'监控单元型号ID', id: 'ff_UQ_UNIT_MODEL_ID', name: 'UQ_UNIT_MODEL_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', value : document.getElementById('unitModelId').value, anchor:'95%' },{ fieldLabel:'单位/部门ID', id: 'ff_UQ_COMPANY_ID', name:'UQ_COMPANY_ID', maxLength: 30, maxLengthText:'长度不得超出{0}', value : document.getElementById('companyId').value, anchor:'95%' },{ fieldLabel:'监控单元编号', id: 'ff_V_UNIT_CODE', name:'UQ_V_UNIT_CODE', maxLength: 30, maxLengthText:'长度不得超出{0}', value : document.getElementById('unitCode').value, anchor:'95%' },{ fieldLabel:'安装人ID', id: 'ff_UQ_EMPLOYEE_ID', name:'UQ_EMPLOYEE_ID', maxLength: 30, maxLengthText:'长度不得超出{0}', value : document.getElementById('employeeId').value, anchor:'95%' },{ id:'ff_queryJson', name:'queryJson', hidden:true }], buttons: [{ text: '提交', iconCls:'ok_btn', handler: function() { var form = this.up('form').getForm(); if (form.isValid()) { var query = new Object(); if(Ext.getCmp('ff_V_UNIT_NAME').getValue().length>0) query.V_UNIT_NAME = Ext.getCmp('ff_V_UNIT_NAME').getValue(); if(Ext.getCmp('ff_UQ_UNIT_MODEL_ID').getValue().length>0) query.UQ_UNIT_MODEL_ID = Ext.getCmp('ff_UQ_UNIT_MODEL_ID').getValue(); query.E_STATUS = Ext.getCmp('ff_E_STATUS').getValue(); if(Ext.getCmp('ff_UQ_COMPANY_ID').getValue().length>0) query.UQ_COMPANY_ID = Ext.getCmp('ff_UQ_COMPANY_ID').getValue(); if(Ext.getCmp('ff_V_UNIT_CODE').getValue().length>0) query.V_UNIT_CODE = Ext.getCmp('ff_V_UNIT_CODE').getValue(); if(Ext.getCmp('ff_UQ_EMPLOYEE_ID').getValue().length>0) query.UQ_EMPLOYEE_ID = Ext.getCmp('ff_UQ_EMPLOYEE_ID').getValue(); var jsonstr = Ext.JSON.encode(query); myStore.getProxy().extraParams = { queryJson : jsonstr }; Ext.getCmp('UnitListPageToolbar').moveFirst(); Ext.getCmp('unitName').setValue(query.V_UNIT_NAME); Ext.getCmp('unitModelId').setValue(query.UQ_UNIT_MODEL_ID); Ext.getCmp('companyId').setValue(query.UQ_COMPANY_ID); Ext.getCmp('unitCode').setValue(query.UQ_V_UNIT_CODE); Ext.getCmp('employeeId').setValue(query.UQ_EMPLOYEE_ID); Ext.getCmp('estatus').setValue(query.E_STATUS); // myStore.reload(); clear_filter_form(); this.up('window').hide(); } } },{ text: '关闭', iconCls: 'cancel_btn', handler: function() { this.up('window').hide(); } }] }); var filterwin = function() { Ext.create('Ext.window.Window',{ title: '筛选', height: 300, width: 350, layout: 'fit', items: FilterWin, closeAction: 'hide' }).show(); } var clear_modify_form = function (){ //Ext.getCmp('fm_V_UNIT_ID').setValue(""); Ext.getCmp('fm_V_UNIT_NAME').setValue(""); Ext.getCmp('fm_V_UNIT_CODE').setValue(""); Ext.getCmp('fm_UQ_COMPANY_ID').setValue(""); Ext.getCmp('fm_UQ_UNIT_MODEL_ID').setValue(""); Ext.getCmp('fm_V_POSITION').setValue(""); Ext.getCmp('fm_UQ_EMPLOYEE_ID').setValue(""); Ext.getCmp('fm_UQ_ADMIN_ID').setValue("0000-0000-0000"); Ext.getCmp('fm_E_STATUS').setValue(10); Ext.getCmp('fm_UQ_IOTCARD_ID').setValue(""); Ext.getCmp('fm_V_COMMENT').setValue(""); Ext.getCmp('UnitListPanel').getStore().reload(); } var ModifyForm = Ext.create('Ext.form.Panel', { id: 'UnitEditForm', labelWidth: 55, url: baseUrl+'iot/unit/update', defaultType: 'textfield', bodyPadding: 15, items: [{ fieldLabel:'监控单元名称', id: 'fm_V_UNIT_NAME', name:'V_UNIT_NAME', maxLength:20, maxLengthText:'长度不得超出{0}', anchor:'75%' },{ fieldLabel:'监控单元编号', id: 'fm_V_UNIT_CODE', name: 'V_UNIT_CODE', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' }, { fieldLabel:'单位/部门ID', id: 'fm_UQ_COMPANY_ID', name: 'UQ_COMPANY_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'监控单元型号ID', id: 'fm_UQ_UNIT_MODEL_ID', name: 'UQ_UNIT_MODEL_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'监控单元安装位置', id: 'fm_V_POSITION', name: 'V_POSITION', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'安装人ID', id: 'fm_UQ_EMPLOYEE_ID', name: 'UQ_EMPLOYEE_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'录入人ID', id: 'fm_UQ_ADMIN_ID', name:'UQ_ADMIN_ID', maxLength: 250, value : "0000-0000-0000", maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'物联网卡ID', id: 'fm_UQ_IOTCARD_ID', name: 'UQ_IOTCARD_ID', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'95%' },{ fieldLabel:'当前状态', id:'fm_E_STATUS', name:'E_STATUS', xtype:'combo', store:states1, displayField : 'name', valueField : 'status', value : 0, editable : false },{ fieldLabel:'新增说明', id: 'fm_V_COMMENT', name:'V_COMMENT', xtype: 'textareafield', maxLength: 250, maxLengthText:'长度不得超出{0}', anchor:'100%' },{ id: 'fm_UQ_UNIT_ID', name:'UQ_UNIT_ID', hidden:true },{ id:'fm_queryJson', name:'queryJson', hidden:true }], buttons: [{ text: '修改', iconCls:'ok_btn', handler: function() { var form = this.up('form').getForm(); if (form.isValid()) { var query = new Object(); query.UQ_UNIT_ID = Ext.getCmp('fm_UQ_UNIT_ID').getValue(); query.UQ_IOTCARD_ID = Ext.getCmp('fm_UQ_IOTCARD_ID').getValue(); query.V_COMMENT = Ext.getCmp('fm_V_COMMENT').getValue(); query.V_UNIT_NAME = Ext.getCmp('fm_V_UNIT_NAME').getValue(); query.V_UNIT_CODE = Ext.getCmp('fm_V_UNIT_CODE').getValue(); query.UQ_COMPANY_ID = Ext.getCmp('fm_UQ_COMPANY_ID').getValue(); query.UQ_UNIT_MODEL_ID = Ext.getCmp('fm_UQ_UNIT_MODEL_ID').getValue(); query.V_POSITION = Ext.getCmp('fm_V_POSITION').getValue(); query.UQ_EMPLOYEE_ID = Ext.getCmp('fm_UQ_EMPLOYEE_ID').getValue(); query.UQ_ADMIN_ID = Ext.getCmp('fm_UQ_ADMIN_ID').getValue(); if(Ext.getCmp('fm_E_STATUS').getValue()=="待开通"){ query.E_STATUS=0; } if(Ext.getCmp('fm_E_STATUS').getValue()=="已开通"){ query.E_STATUS=1; } if(Ext.getCmp('fm_E_STATUS').getValue()=="已锁定"){ query.E_STATUS=2; } if(Ext.getCmp('fm_E_STATUS').getValue()=="注销"){ query.E_STATUS=3; } var jsonstr = Ext.JSON.encode(query); Ext.getCmp('fm_queryJson').setValue(jsonstr); form.submit({ method:'post', success: function(form, action) { //Ext.getCmp('adminId').setValue(query.UQ_ADMIN_ID); Ext.Msg.alert('操作成功', '已修改', function(btn,txt){ clear_modify_form(); }); }, failure: function(form, action) { Ext.Msg.alert('操作失败', action.Msg , function(btn,txt){ clear_modify_form(); }); } }); this.up('window').hide(); } } },{ text: '关闭', iconCls: 'cancel_btn', handler: function() { this.up('window').hide(); } }] }); var modifywin = function(){ Ext.create('Ext.window.Window', { title: '修改监控单元', height: 500, width: 400, layout: 'fit', items: ModifyForm, closeAction: 'hide' }).show(); } var chk_sm = function() { if(sm.getCount()==1){ modifywin(); var selected = sm.getSelection( ); // var estatus = parseInt(selected[0].raw.E_STATUS); Ext.getCmp('fm_UQ_IOTCARD_ID').setValue(selected[0].raw.UQ_IOTCARD_ID); Ext.getCmp('fm_E_STATUS').setValue(selected[0].raw.E_STATUS); //Ext.getCmp('fm_V_COMMENT').setValue(selected[0].raw.V_COMMENT); Ext.getCmp('fm_UQ_UNIT_ID').setValue(selected[0].raw.UQ_UNIT_ID); Ext.getCmp('fm_V_UNIT_NAME').setValue(selected[0].raw.V_UNIT_NAME); Ext.getCmp('fm_V_UNIT_CODE').setValue(selected[0].raw.V_UNIT_CODE); Ext.getCmp('fm_V_POSITION').setValue(selected[0].raw.V_POSITION); Ext.getCmp('fm_UQ_COMPANY_ID').setValue(selected[0].raw.UQ_COMPANY_ID); Ext.getCmp('fm_UQ_UNIT_MODEL_ID').setValue(selected[0].raw.UQ_UNIT_MODEL_ID); //Ext.getCmp('fm_UQ_ADMIN_ID').setValue(selected[0].raw.UQ_ADMIN_ID); Ext.getCmp('fm_UQ_EMPLOYEE_ID').setValue(selected[0].raw.UQ_EMPLOYEE_ID); }else{ Ext.Msg.alert('请先选择','请先选择一条记录,再点击修改'); } } var clear_filter_form1 = function(){ Ext.getCmp('fc_V_COMPANY_NAME').setValue(""); Ext.getCmp('fc_V_COMPANY_ADDRESS_0').setValue(""); Ext.getCmp('fc_E_STATUS').setValue(-1); Ext.getCmp('fc_UQ_ADMIN_ID').setValue(""); Ext.getCmp('fc_V_COMMENT').setValue(""); // Ext.getCmp('PermissionListPanel').getStore().reload(); } var deletewin = function() { if(sm.getCount()>=1){ // var companyname = selected[0].raw.V_COMPANY_NAME; // window.alert(selected[0].raw); var query = new Object(); var list = new Array(); for (var i=0;i