|
|
@@ -1,6 +1,3 @@
|
|
|
-/**
|
|
|
- * Created by zhouy on 2018/10/18.
|
|
|
- */
|
|
|
Ext.define('saas.view.sys.account.DataList', {
|
|
|
extend: 'Ext.grid.Panel',
|
|
|
xtype: 'sys-account-datalist',
|
|
|
@@ -17,31 +14,45 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
width: 150,
|
|
|
name: 'username',
|
|
|
xtype: 'textfield',
|
|
|
- emptyText : '账户名称'
|
|
|
+ emptyText : '账户名称',
|
|
|
+ enableKeyEvents: true,
|
|
|
+ listeners: {
|
|
|
+ keydown: {
|
|
|
+ fn: function(th, e, eOpts) {
|
|
|
+ if(e.keyCode == 13) {
|
|
|
+ var grid = th.up('grid');
|
|
|
+ grid.condition = grid.getConditions();
|
|
|
+ grid.store.loadPage(1);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
},{
|
|
|
width: 140,
|
|
|
name: 'mobile',
|
|
|
xtype: 'textfield',
|
|
|
emptyText : '手机号码',
|
|
|
// regex:/^1(3|4|5|7|8|9)\d{9}$/,
|
|
|
- // regexText:'请输入正确的手机号码'
|
|
|
+ // regexText:'请输入正确的手机号码',
|
|
|
+ enableKeyEvents: true,
|
|
|
+ listeners: {
|
|
|
+ keydown: {
|
|
|
+ fn: function(th, e, eOpts) {
|
|
|
+ if(e.keyCode == 13) {
|
|
|
+ var grid = th.up('grid');
|
|
|
+ grid.condition = grid.getConditions();
|
|
|
+ grid.store.loadPage(1);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
},{
|
|
|
xtype:'button',
|
|
|
text:'查询',
|
|
|
listeners: {
|
|
|
click:function(b){
|
|
|
- var grid = b.ownerCt.ownerCt;
|
|
|
- var tbar = b.ownerCt;
|
|
|
- grid.condition = '';
|
|
|
- var items = [];
|
|
|
- var fields = tbar.items.items.map(f => f.name);
|
|
|
- Ext.each(fields, function(f, index){
|
|
|
- var field = tbar.down('[name='+f+']');
|
|
|
- if(field){
|
|
|
- items.push(field);
|
|
|
- }
|
|
|
- });
|
|
|
- grid.condition = grid.getCondition(items);
|
|
|
+ var grid = b.up('grid');
|
|
|
+ grid.condition = grid.getConditions();
|
|
|
grid.store.loadPage(1);
|
|
|
}
|
|
|
}
|
|
|
@@ -144,6 +155,9 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
});
|
|
|
}
|
|
|
}]
|
|
|
+ }, {
|
|
|
+ dataIndex: '',
|
|
|
+ flex: 1
|
|
|
}],
|
|
|
|
|
|
dbSearchFields: [],
|
|
|
@@ -279,6 +293,7 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
width:50,
|
|
|
dataIndex:'actioncolumn',
|
|
|
text:'操作',
|
|
|
+ align: 'center',
|
|
|
items: [{
|
|
|
tooltip: '编辑',
|
|
|
iconCls: 'x-fa fa-pencil fa-fw',
|
|
|
@@ -319,10 +334,11 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
/**
|
|
|
* 获得过滤条件
|
|
|
*/
|
|
|
- getCondition: function(items) {
|
|
|
+ getConditions: function() {
|
|
|
var me = this,
|
|
|
+ tbar = me.getDockedItems()[0],
|
|
|
+ items = tbar.items.items,
|
|
|
conditions = [];
|
|
|
-
|
|
|
for(var i = 0; i < items.length; i++) {
|
|
|
var item = items[i];
|
|
|
var field = item.name,
|
|
|
@@ -337,10 +353,9 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
value: func(value)
|
|
|
}
|
|
|
}else {
|
|
|
- var xtype = item.xtype || 'textfield',
|
|
|
- type = item.fieldType || me.getDefaultFieldType(xtype),
|
|
|
- operation = item.operation || me.getDefaultFieldOperation(xtype),
|
|
|
- conditionValue = me.getConditionValue(xtype, value);
|
|
|
+ var type = item.fieldType || me.getDefaultFieldType(item),
|
|
|
+ operation = item.operation || me.getDefaultFieldOperation(item),
|
|
|
+ conditionValue = me.getConditionValue(item, value);
|
|
|
|
|
|
if(!conditionValue) {
|
|
|
continue;
|
|
|
@@ -354,38 +369,58 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
}
|
|
|
conditions.push(condition);
|
|
|
}
|
|
|
- };
|
|
|
+ }
|
|
|
+
|
|
|
return conditions;
|
|
|
},
|
|
|
|
|
|
- getDefaultFieldType: function(xtype) {
|
|
|
- var type;
|
|
|
+ /**
|
|
|
+ * 只要arr1和arr2中存在相同项即返回真
|
|
|
+ */
|
|
|
+ isContainsAny: function (arr1, arr2) {
|
|
|
+ for (var i = 0; i < arr2.length; i++) {
|
|
|
+ var a2 = arr2[i];
|
|
|
+ if (!!arr1.find(function (a1) {
|
|
|
+ return a1 == a2
|
|
|
+ })) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return false;
|
|
|
+ },
|
|
|
+
|
|
|
+ getDefaultFieldType: function (field) {
|
|
|
+ var me = this,
|
|
|
+ xtypes = field.getXTypes().split('/'),
|
|
|
+ type;
|
|
|
|
|
|
- if(Ext.Array.contains(['numberfield'], xtype)) {
|
|
|
+ if (me.isContainsAny(xtypes, ['numberfield'])) {
|
|
|
type = 'number';
|
|
|
- }else if(Ext.Array.contains(['datefield', 'condatefield'], xtype)) {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['datefield', 'condatefield', 'conmonthfield'])) {
|
|
|
type = 'date';
|
|
|
- }else if(Ext.Array.contains(['combobox', 'multicombo', 'combo', 'radiofield', 'radio'], xtype)) {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['dbfindtrigger'])) {
|
|
|
type = 'enum';
|
|
|
- }else {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['combobox', 'multicombo', 'combo', 'radiofield', 'radio'])) {
|
|
|
+ type = 'enum';
|
|
|
+ } else {
|
|
|
type = 'string';
|
|
|
}
|
|
|
|
|
|
return type;
|
|
|
},
|
|
|
|
|
|
- getDefaultFieldOperation: function(xtype) {
|
|
|
- var operation;
|
|
|
+ getDefaultFieldOperation: function (field) {
|
|
|
+ var me = this,
|
|
|
+ xtypes = field.getXTypes().split('/'),
|
|
|
+ operation;
|
|
|
|
|
|
- if(Ext.Array.contains(['numberfield'], xtype)) {
|
|
|
+ if (me.isContainsAny(xtypes, ['numberfield', 'datefield', 'dbfindtrigger'])) {
|
|
|
operation = '=';
|
|
|
- }else if(Ext.Array.contains(['datefield'], xtype)) {
|
|
|
- operation = '=';
|
|
|
- }else if(Ext.Array.contains(['condatefield'], xtype)) {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['condatefield', 'conmonthfield'])) {
|
|
|
operation = 'between';
|
|
|
- }else if(Ext.Array.contains(['combobox', 'multicombo', 'combo'], xtype)) {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['multidbfindtrigger', 'combobox', 'multicombo', 'combo'])) {
|
|
|
operation = 'in';
|
|
|
- }else {
|
|
|
+ } else {
|
|
|
operation = 'like';
|
|
|
}
|
|
|
|
|
|
@@ -395,32 +430,36 @@ Ext.define('saas.view.sys.account.DataList', {
|
|
|
/**
|
|
|
* 处理部分字段值
|
|
|
*/
|
|
|
- getConditionValue: function(xtype, value) {
|
|
|
- var conditionValue;
|
|
|
- if(xtype == 'datefield') {
|
|
|
+ getConditionValue: function (field, value) {
|
|
|
+ var me = this,
|
|
|
+ xtypes = field.getXTypes().split('/'),
|
|
|
+ conditionValue;
|
|
|
+ if (me.isContainsAny(xtypes, ['datefield'])) {
|
|
|
conditionValue = Ext.Date.format(new Date(from), 'Y-m-d H:i:s');
|
|
|
- }else if(xtype == 'condatefield') {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['conmonthfield'])) {
|
|
|
+ var from = value.from,
|
|
|
+ to = value.to;
|
|
|
+
|
|
|
+ conditionValue = from + ',' + to;
|
|
|
+ } else if (me.isContainsAny(xtypes, ['condatefield'])) {
|
|
|
var from = value.from,
|
|
|
- to = value.to;
|
|
|
+ to = value.to;
|
|
|
|
|
|
conditionValue = Ext.Date.format(new Date(from), 'Y-m-d 00:00:00') + ',' + Ext.Date.format(new Date(to), 'Y-m-d 23:59:59');
|
|
|
- }else if(xtype == 'combobox' || xtype == 'combo') {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['dbfindtrigger'])) {
|
|
|
+ conditionValue = value;
|
|
|
+ } else if (me.isContainsAny(xtypes, ['combobox', 'combo'])) {
|
|
|
conditionValue = '\'' + value + '\'';
|
|
|
- }else if(xtype == 'multicombo') {
|
|
|
- conditionValue = value.map(function(v) {
|
|
|
+ } else if (me.isContainsAny(xtypes, ['multicombo'])) {
|
|
|
+ conditionValue = value.map ? value.map(function (v) {
|
|
|
return '\'' + v.value + '\'';
|
|
|
- }).join(',');
|
|
|
- }else {
|
|
|
+ }).join(',') : '';
|
|
|
+ } else {
|
|
|
conditionValue = value;
|
|
|
}
|
|
|
|
|
|
return conditionValue;
|
|
|
- },
|
|
|
-
|
|
|
- refresh:function(){
|
|
|
- //debugger
|
|
|
}
|
|
|
-
|
|
|
})
|
|
|
|
|
|
|