|
|
@@ -6,9 +6,6 @@ Ext.define('saas.view.core.base.BasePanel', {
|
|
|
viewModel: 'core-base-basepanel',
|
|
|
|
|
|
cls:'core-base-basepanel',
|
|
|
- //工具类
|
|
|
- FormUtil: Ext.create('saas.util.FormUtil'),
|
|
|
- BaseUtil: Ext.create('saas.util.BaseUtil'),
|
|
|
|
|
|
//基础属性
|
|
|
frame:false,
|
|
|
@@ -35,43 +32,37 @@ Ext.define('saas.view.core.base.BasePanel', {
|
|
|
|
|
|
var me = this,
|
|
|
gridConfig = me.gridConfig,
|
|
|
- gridDataUrl = gridConfig.dataUrl,
|
|
|
- gridIdField = gridConfig.idField,
|
|
|
- gridCodeField = gridConfig.codeField,
|
|
|
- gridStatusCodeField = gridConfig.statusCodeField,
|
|
|
- gridColumns = Ext.Array.clone(gridConfig.columns),
|
|
|
- deleteMsg = gridConfig.deleteMsg;
|
|
|
+ gridColumns = Ext.Array.clone(gridConfig.columns);
|
|
|
+
|
|
|
+ var gridcfg = {
|
|
|
+ layout: 'fit',
|
|
|
+ xtype: 'core-base-gridpanel',
|
|
|
+ padding: '8 12',
|
|
|
+ _columns: gridColumns.map(function(c) {
|
|
|
+ return Object.assign({}, c);
|
|
|
+ }),
|
|
|
+ };
|
|
|
+ Ext.apply(gridcfg ,me.gridConfig);
|
|
|
|
|
|
Ext.apply(me, {
|
|
|
dockedItems: [{
|
|
|
frame:false,
|
|
|
xtype: 'toolbar',
|
|
|
dock: 'top',
|
|
|
+ layout: 'column',
|
|
|
style: {
|
|
|
- // 'border-bottom': '1px solid #35baf6 !important',
|
|
|
margin: '0 0 12px 0',
|
|
|
padding: '10px 0 14px 8px',
|
|
|
},
|
|
|
items: me.searchField.concat([{
|
|
|
- // cls:'x-formpanel-btn-orange',
|
|
|
xtype: 'button',
|
|
|
text: '查询',
|
|
|
- handler: 'query'
|
|
|
+ handler: function() {
|
|
|
+ me.onQuery()
|
|
|
+ }
|
|
|
}])
|
|
|
}],
|
|
|
- items: [{
|
|
|
- layout: 'fit',
|
|
|
- xtype: 'core-base-gridpanel',
|
|
|
- padding: '8 12',
|
|
|
- dataUrl: gridDataUrl,
|
|
|
- idField: gridIdField,
|
|
|
- codeField: gridCodeField,
|
|
|
- _columns: gridColumns.map(function(c) {
|
|
|
- return Object.assign({}, c);
|
|
|
- }),
|
|
|
- statusCodeField : gridStatusCodeField,
|
|
|
- deleteMsg: deleteMsg
|
|
|
- }]
|
|
|
+ items: [gridcfg]
|
|
|
});
|
|
|
me.callParent(arguments);
|
|
|
},
|
|
|
@@ -83,20 +74,168 @@ Ext.define('saas.view.core.base.BasePanel', {
|
|
|
Ext.Array.each(searchField, function(f) {
|
|
|
var name = f.name;
|
|
|
var field = form.getForm().findField(name);
|
|
|
- field.enableKeyEvents = true;
|
|
|
- field.on && field.on({
|
|
|
- keydown: {
|
|
|
- fn: function(th, e, eOpts) {
|
|
|
- if(e.keyCode == 13) {
|
|
|
- form.getController().query()
|
|
|
+
|
|
|
+ if(field) {
|
|
|
+ field.enableKeyEvents = true;
|
|
|
+ field.on && field.on({
|
|
|
+ keydown: {
|
|
|
+ fn: function(th, e, eOpts) {
|
|
|
+ if(e.keyCode == 13) {
|
|
|
+ form.onQuery()
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
- });
|
|
|
+ });
|
|
|
+ }
|
|
|
});
|
|
|
}
|
|
|
},
|
|
|
|
|
|
+ onQuery: function() {
|
|
|
+ var me = this;
|
|
|
+ var grid = me.down('core-base-gridpanel');
|
|
|
+
|
|
|
+ grid.store.loadPage(1);
|
|
|
+ },
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获得过滤条件
|
|
|
+ */
|
|
|
+ getConditions: function() {
|
|
|
+ var me = this;
|
|
|
+ var items = me.dockedItems.items[0].items.items;
|
|
|
+ var conditions = [];
|
|
|
+
|
|
|
+ for(let i = 0; i < items.length; i++) {
|
|
|
+ var item = items[i];
|
|
|
+ var field = item.name,
|
|
|
+ func = item.getCondition,
|
|
|
+ value = item.value,
|
|
|
+ condition;
|
|
|
+
|
|
|
+ if(value&&value!=''){
|
|
|
+ if(typeof func == 'function') {
|
|
|
+ condition = {
|
|
|
+ type: 'condition',
|
|
|
+ value: func(value)
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ var type = item.fieldType || me.getDefaultFieldType(item),
|
|
|
+ operation = item.operation || me.getDefaultFieldOperation(item),
|
|
|
+ conditionValue = me.getConditionValue(item, value);
|
|
|
+
|
|
|
+ if(!conditionValue) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ condition = {
|
|
|
+ type: type,
|
|
|
+ field: field,
|
|
|
+ operation: operation,
|
|
|
+ value: conditionValue
|
|
|
+ }
|
|
|
+ }
|
|
|
+ conditions.push(condition);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return conditions;
|
|
|
+ },
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 只要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 (me.isContainsAny(xtypes, ['numberfield'])) {
|
|
|
+ type = 'number';
|
|
|
+ } else if (me.isContainsAny(xtypes, ['datefield', 'condatefield', 'conmonthfield'])) {
|
|
|
+ type = 'date';
|
|
|
+ } else if (me.isContainsAny(xtypes, ['dbfindtrigger'])) {
|
|
|
+ type = 'enum';
|
|
|
+ } else if (me.isContainsAny(xtypes, ['combobox', 'multicombo', 'combo', 'radiofield', 'radio'])) {
|
|
|
+ type = 'enum';
|
|
|
+ } else {
|
|
|
+ type = 'string';
|
|
|
+ }
|
|
|
+
|
|
|
+ return type;
|
|
|
+ },
|
|
|
+
|
|
|
+ getDefaultFieldOperation: function (field) {
|
|
|
+ var me = this,
|
|
|
+ xtypes = field.getXTypes().split('/'),
|
|
|
+ operation;
|
|
|
+
|
|
|
+ if (me.isContainsAny(xtypes, ['numberfield', 'datefield', 'dbfindtrigger'])) {
|
|
|
+ operation = '=';
|
|
|
+ } else if (me.isContainsAny(xtypes, ['condatefield', 'conmonthfield'])) {
|
|
|
+ operation = 'between';
|
|
|
+ } else if (me.isContainsAny(xtypes, ['multidbfindtrigger', 'combobox', 'multicombo', 'combo'])) {
|
|
|
+ operation = 'in';
|
|
|
+ } else {
|
|
|
+ operation = 'like';
|
|
|
+ }
|
|
|
+
|
|
|
+ return operation;
|
|
|
+ },
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 处理部分字段值
|
|
|
+ */
|
|
|
+ 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 (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;
|
|
|
+
|
|
|
+ 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 (me.isContainsAny(xtypes, ['dbfindtrigger'])) {
|
|
|
+ conditionValue = value;
|
|
|
+ } else if (me.isContainsAny(xtypes, ['combobox', 'combo'])) {
|
|
|
+ conditionValue = '\'' + value + '\'';
|
|
|
+ } else if (me.isContainsAny(xtypes, ['multicombo'])) {
|
|
|
+ conditionValue = value.map ? value.map(function (v) {
|
|
|
+ return '\'' + v.value + '\'';
|
|
|
+ }).join(',') : '';
|
|
|
+ } else {
|
|
|
+ conditionValue = value;
|
|
|
+ }
|
|
|
+
|
|
|
+ return conditionValue;
|
|
|
+ },
|
|
|
+
|
|
|
+ getExtraParams: function(store, op, condition) {
|
|
|
+ return {
|
|
|
+ number: store.exportNumber?store.exportNumber:op._page,
|
|
|
+ size: store.exportPageSize?store.exportPageSize:store.pageSize,
|
|
|
+ condition: JSON.stringify(condition)
|
|
|
+ };
|
|
|
+ },
|
|
|
+
|
|
|
refresh: function () {
|
|
|
this.items.items[0].store.load()
|
|
|
},
|