forked from fanruan/fineui
windy
8 years ago
8 changed files with 719 additions and 0 deletions
@ -0,0 +1,45 @@ |
|||||||
|
/** |
||||||
|
* Created by User on 2017/3/29. |
||||||
|
*/ |
||||||
|
Demo.FilterPane = BI.inherit(BI.Widget, { |
||||||
|
props: { |
||||||
|
baseCls: "demo-filter-pane" |
||||||
|
}, |
||||||
|
|
||||||
|
_createFilter: function () { |
||||||
|
var filter = BI.createWidget({ |
||||||
|
type: "bi.filter", |
||||||
|
width: 600, |
||||||
|
height: 300, |
||||||
|
itemCreator: function(item){ |
||||||
|
if(item.value === BICst.FILTER_TYPE.EMPTY_CONDITION || item.value === BICst.FILTER_TYPE.EMPTY_FORMULA){ |
||||||
|
item.type = "bi.label"; |
||||||
|
item.value = "这是一个新添的数据"; |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
return filter; |
||||||
|
}, |
||||||
|
|
||||||
|
render: function () { |
||||||
|
var filter = this._createFilter(); |
||||||
|
|
||||||
|
return { |
||||||
|
type: "bi.vertical", |
||||||
|
hgap: 30, |
||||||
|
vgap: 20, |
||||||
|
items: [{ |
||||||
|
el: filter |
||||||
|
}, { |
||||||
|
type: "bi.button", |
||||||
|
text: "过滤结构getValue()", |
||||||
|
height: 30, |
||||||
|
handler: function () { |
||||||
|
BI.Msg.alert("过滤结构", JSON.stringify(filter.getValue())); |
||||||
|
} |
||||||
|
}] |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
BI.shortcut("demo.filter_pane", Demo.FilterPane); |
@ -0,0 +1,49 @@ |
|||||||
|
/** |
||||||
|
* 过滤条件抽象类 |
||||||
|
* |
||||||
|
* @class BI.AbstractFilterItem |
||||||
|
* @extend BI.Widget |
||||||
|
*/ |
||||||
|
BI.AbstractFilterItem = BI.inherit(BI.Widget, { |
||||||
|
|
||||||
|
_defaultConfig: function () { |
||||||
|
return BI.extend(BI.AbstractFilterItem.superclass._defaultConfig.apply(this, arguments), { |
||||||
|
baseCls: "bi-filter-item" |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
_init: function () { |
||||||
|
BI.AbstractFilterItem.superclass._init.apply(this, arguments); |
||||||
|
}, |
||||||
|
|
||||||
|
isSelectedCondition: function () { |
||||||
|
return this.emptyItem && this.emptyItem.isVisible(); |
||||||
|
}, |
||||||
|
|
||||||
|
setSelectedCondition: function (b) { |
||||||
|
if (!!b) { |
||||||
|
if (!this.emptyItem) { |
||||||
|
this.emptyItem = BI.createWidget({ |
||||||
|
type: "bi.absolute", |
||||||
|
height: 40, |
||||||
|
cls: "filter-item-empty-item", |
||||||
|
items: [{ |
||||||
|
el: { |
||||||
|
type: "bi.center_adapt", |
||||||
|
cls: "empty-filter-item-leaf" |
||||||
|
} |
||||||
|
}], |
||||||
|
hgap: 10, |
||||||
|
vgap: 5 |
||||||
|
}); |
||||||
|
BI.createWidget({ |
||||||
|
type: "bi.vertical", |
||||||
|
element: this, |
||||||
|
items: [this.emptyItem], |
||||||
|
scrolly: false |
||||||
|
}); |
||||||
|
} |
||||||
|
} |
||||||
|
this.emptyItem && this.emptyItem.setVisible(b); |
||||||
|
} |
||||||
|
}); |
@ -0,0 +1,79 @@ |
|||||||
|
/** |
||||||
|
* @class BI.FilterExpander |
||||||
|
* @extend BI.AbstractFilterItem |
||||||
|
* 过滤树的一个expander节点 |
||||||
|
*/ |
||||||
|
BI.FilterExpander = BI.inherit(BI.AbstractFilterItem, { |
||||||
|
|
||||||
|
_constant: { |
||||||
|
EXPANDER_WIDTH: 20 |
||||||
|
}, |
||||||
|
|
||||||
|
_defaultConfig: function () { |
||||||
|
var conf = BI.FilterExpander.superclass._defaultConfig.apply(this, arguments); |
||||||
|
return BI.extend(conf, { |
||||||
|
baseCls: (conf.baseCls || "") + " bi-filter-expander", |
||||||
|
el: {}, |
||||||
|
popup: {} |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
_init: function () { |
||||||
|
BI.FilterExpander.superclass._init.apply(this, arguments); |
||||||
|
this._initExpander(); |
||||||
|
this._initConditionsView(); |
||||||
|
BI.createWidget({ |
||||||
|
type: "bi.horizontal_adapt", |
||||||
|
element: this, |
||||||
|
items: [this.expander, this.conditionsView] |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
_initExpander: function () { |
||||||
|
var self = this, o = this.options; |
||||||
|
var value = o.value, text = ""; |
||||||
|
if (value === BICst.FILTER_TYPE.AND) { |
||||||
|
text = BI.i18nText("BI-Basic_And"); |
||||||
|
} else { |
||||||
|
text = BI.i18nText("BI-Basic_Or"); |
||||||
|
} |
||||||
|
this.expander = BI.createWidget({ |
||||||
|
type: "bi.text_button", |
||||||
|
cls: "condition-and-or", |
||||||
|
text: text, |
||||||
|
value: value, |
||||||
|
id: o.id, |
||||||
|
width: this._constant.EXPANDER_WIDTH, |
||||||
|
height: "100%" |
||||||
|
}); |
||||||
|
this.expander.on(BI.Controller.EVENT_CHANGE, function (type) { |
||||||
|
arguments[2] = self; |
||||||
|
self.fireEvent(BI.Controller.EVENT_CHANGE, arguments); |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
_initConditionsView: function () { |
||||||
|
var self = this, popup = this.options.popup; |
||||||
|
this.conditionsView = BI.createWidget(popup); |
||||||
|
this.conditionsView.on(BI.Controller.EVENT_CHANGE, function () { |
||||||
|
self.fireEvent(BI.Controller.EVENT_CHANGE, arguments); |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
getValue: function () { |
||||||
|
return { |
||||||
|
type: this.expander.getValue(), |
||||||
|
value: this.conditionsView.getValue(), |
||||||
|
id: this.options.id |
||||||
|
}; |
||||||
|
}, |
||||||
|
|
||||||
|
setValue: function () { |
||||||
|
|
||||||
|
}, |
||||||
|
|
||||||
|
populate: function (items) { |
||||||
|
this.conditionsView.populate.apply(this.conditionsView, arguments); |
||||||
|
} |
||||||
|
}); |
||||||
|
BI.shortcut("bi.filter_expander", BI.FilterExpander); |
@ -0,0 +1,188 @@ |
|||||||
|
/** |
||||||
|
* 过滤 |
||||||
|
* |
||||||
|
* Created by GUY on 2015/11/20. |
||||||
|
* @class BI.Filter |
||||||
|
* @extend BI.Widget |
||||||
|
*/ |
||||||
|
BI.Filter = BI.inherit(BI.Widget, { |
||||||
|
|
||||||
|
constants: { |
||||||
|
FIELD_TYPE_NUMBER: 1, |
||||||
|
FIELD_TYPE_STRING: 0, |
||||||
|
FIELD_TYPE_DATE: 2 |
||||||
|
}, |
||||||
|
|
||||||
|
_defaultConfig: function () { |
||||||
|
return BI.extend(BI.Filter.superclass._defaultConfig.apply(this, arguments), { |
||||||
|
baseCls: "bi-filter", |
||||||
|
expander: {}, |
||||||
|
items: [], |
||||||
|
el: {}, |
||||||
|
itemCreator: BI.empty |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
_init: function () { |
||||||
|
BI.Filter.superclass._init.apply(this, arguments); |
||||||
|
var self = this, o = this.options; |
||||||
|
this.filter = BI.createWidget(o.el,{ |
||||||
|
type: "bi.filter_operation", |
||||||
|
expander: o.expander, |
||||||
|
items: o.items, |
||||||
|
element: this |
||||||
|
}); |
||||||
|
this.filter.on(BI.FilterOperation.EVENT_OPERATION, function (type) { |
||||||
|
switch (type) { |
||||||
|
case BICst.FILTER_OPERATION_CONDITION: |
||||||
|
case BICst.FILTER_OPERATION_CONDITION_AND: |
||||||
|
self._addAndOrCondition(BICst.FILTER_TYPE.EMPTY_CONDITION); |
||||||
|
break; |
||||||
|
case BICst.FILTER_OPERATION_CONDITION_OR: |
||||||
|
self._addAndOrCondition(BICst.FILTER_TYPE.EMPTY_CONDITION, 1); |
||||||
|
break; |
||||||
|
case BICst.FILTER_OPERATION_FORMULA: |
||||||
|
case BICst.FILTER_OPERATION_FORMULA_AND: |
||||||
|
self._addAndOrCondition(BICst.FILTER_TYPE.EMPTY_FORMULA); |
||||||
|
break; |
||||||
|
case BICst.FILTER_OPERATION_FORMULA_OR: |
||||||
|
self._addAndOrCondition(BICst.FILTER_TYPE.EMPTY_FORMULA, 1); |
||||||
|
break; |
||||||
|
} |
||||||
|
}); |
||||||
|
this.filter.on(BI.FilterOperation.EVENT_DESTROY_ITEM, function (id) { |
||||||
|
self._removeCondition(id); |
||||||
|
}); |
||||||
|
|
||||||
|
this.tree = new BI.Tree(); |
||||||
|
this.tree.initTree(o.items); |
||||||
|
}, |
||||||
|
|
||||||
|
_removeCondition: function (id) { |
||||||
|
var finded = this.tree.search(id); |
||||||
|
if (BI.isNotNull(finded)) { |
||||||
|
var parent = finded.getParent(); |
||||||
|
parent.removeChild(id); |
||||||
|
if (parent.getChildrenLength() <= 1) { |
||||||
|
var prev = parent.getParent(); |
||||||
|
if (BI.isNotNull(prev)) { |
||||||
|
var index = prev.getChildIndex(parent.id); |
||||||
|
prev.removeChildByIndex(index); |
||||||
|
if (parent.getChildrenLength() === 1) { |
||||||
|
prev.addChild(parent.getFirstChild(), index); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
this._populate(this.tree.toJSONWithNode()); |
||||||
|
this.fireEvent(BI.Filter.EVENT_CHANGE); |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
_createEmptyNode: function (type) { |
||||||
|
var node = new BI.Node(BI.UUID()); |
||||||
|
node.set("data", { |
||||||
|
value: type |
||||||
|
}); |
||||||
|
return node; |
||||||
|
}, |
||||||
|
|
||||||
|
_insertAndOrCondition: function (id, formulaOrField, type) { |
||||||
|
var ANDOR = ["AND", "OR"]; |
||||||
|
type || (type = 0); |
||||||
|
var finded = this.tree.search(id); |
||||||
|
if (BI.isNotNull(finded)) { |
||||||
|
var data = finded.get("data"); |
||||||
|
var parent = finded.getParent(); |
||||||
|
var index = parent.getChildIndex(finded.id); |
||||||
|
var pdata = parent.get("data") || {}; |
||||||
|
var node = this._createEmptyNode(formulaOrField); |
||||||
|
if (data.value === BICst.FILTER_TYPE[ANDOR[type]]) { |
||||||
|
this.tree.addNode(finded, node); |
||||||
|
return; |
||||||
|
} |
||||||
|
if (data.value === BICst.FILTER_TYPE[ANDOR[1 - type]]) { |
||||||
|
if (pdata.value === BICst.FILTER_TYPE[ANDOR[type]]) { |
||||||
|
parent.addChild(node, index + 1); |
||||||
|
return; |
||||||
|
} |
||||||
|
} |
||||||
|
if ((data.value === BICst.FILTER_TYPE[ANDOR[1 - type]] && pdata.value !== BICst.FILTER_TYPE[ANDOR[type]]) |
||||||
|
|| pdata.value === BICst.FILTER_TYPE[ANDOR[1 - type]] |
||||||
|
|| (pdata.value !== BICst.FILTER_TYPE.AND && pdata.value !== BICst.FILTER_TYPE.OR)) { |
||||||
|
var andor = new BI.Node(BI.UUID()); |
||||||
|
andor.set("data", { |
||||||
|
value: BICst.FILTER_TYPE[ANDOR[type]], |
||||||
|
children: [finded.get("data"), node.get("data")] |
||||||
|
}); |
||||||
|
parent.removeChildByIndex(index); |
||||||
|
parent.addChild(andor, index); |
||||||
|
andor.addChild(finded); |
||||||
|
andor.addChild(node); |
||||||
|
return; |
||||||
|
} |
||||||
|
parent.addChild(node, index + 1); |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
_addAndOrCondition: function (formulaOrField, type) { |
||||||
|
var ANDOR = ["AND", "OR"]; |
||||||
|
type || (type = 0); |
||||||
|
var o = this.options; |
||||||
|
var currentSelectItem = this.filter.getCurrentSelectItem(); |
||||||
|
if (BI.isNotNull(currentSelectItem)) { |
||||||
|
var id = currentSelectItem.attr("id"); |
||||||
|
this._insertAndOrCondition(id, formulaOrField, type); |
||||||
|
} else { |
||||||
|
var node = this._createEmptyNode(formulaOrField); |
||||||
|
var root = this.tree.getRoot(); |
||||||
|
var child = root.getLastChild(); |
||||||
|
if (BI.isNotNull(child)) { |
||||||
|
var data = child.get("data"); |
||||||
|
if (data.value === BICst.FILTER_TYPE[ANDOR[type]]) { |
||||||
|
this.tree.addNode(child, node); |
||||||
|
} else { |
||||||
|
var andor = new BI.Node(BI.UUID()); |
||||||
|
andor.set("data", { |
||||||
|
value: BICst.FILTER_TYPE[ANDOR[type]], |
||||||
|
children: [child.get("data"), node.get("data")] |
||||||
|
}); |
||||||
|
root.removeChild(child.id); |
||||||
|
this.tree.addNode(andor); |
||||||
|
this.tree.addNode(andor, child); |
||||||
|
this.tree.addNode(andor, node); |
||||||
|
} |
||||||
|
} else { |
||||||
|
this.tree.addNode(node); |
||||||
|
} |
||||||
|
} |
||||||
|
this._populate(this.tree.toJSONWithNode()); |
||||||
|
this.fireEvent(BI.Filter.EVENT_CHANGE); |
||||||
|
}, |
||||||
|
|
||||||
|
_populate: function (items) { |
||||||
|
var self = this, o = this.options; |
||||||
|
o.items = items; |
||||||
|
ArrayUtils.traversal(items, function (i, item) { |
||||||
|
o.itemCreator(item); |
||||||
|
}); |
||||||
|
this.filter.populate.apply(this.filter, [items]); |
||||||
|
}, |
||||||
|
|
||||||
|
populate: function (conditions) { |
||||||
|
this.tree.initTree(conditions); |
||||||
|
this._populate(this.tree.toJSONWithNode()); |
||||||
|
}, |
||||||
|
|
||||||
|
getValue: function () { |
||||||
|
return this.filter.getValue(); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
BICst.FILTER_TYPE = {}; |
||||||
|
BICst.FILTER_TYPE.AND = 80; |
||||||
|
BICst.FILTER_TYPE.OR = 81; |
||||||
|
BICst.FILTER_TYPE.FORMULA = 82; |
||||||
|
BICst.FILTER_TYPE.EMPTY_FORMULA = 90; |
||||||
|
BICst.FILTER_TYPE.EMPTY_CONDITION = 91; |
||||||
|
BI.Filter.EVENT_CHANGE = "EVENT_CHANGE"; |
||||||
|
BI.shortcut("bi.filter", BI.Filter); |
@ -0,0 +1,59 @@ |
|||||||
|
/** |
||||||
|
* Created by windy on 2017/3/28. |
||||||
|
*/ |
||||||
|
BI.FilterList = BI.inherit(BI.Widget, { |
||||||
|
_defaultConfig: function () { |
||||||
|
return BI.extend(BI.FilterList.superclass._defaultConfig.apply(this, arguments), { |
||||||
|
baseCls: "bi-filter-list", |
||||||
|
expander: {}, |
||||||
|
items: [], |
||||||
|
itemsCreator: BI.emptyFn |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
render: function(){ |
||||||
|
var self = this, o = this.options; |
||||||
|
this.group = null; |
||||||
|
return { |
||||||
|
type: "bi.virtual_group", |
||||||
|
ref: function(_ref){ |
||||||
|
self.group = _ref; |
||||||
|
}, |
||||||
|
items: BI.createItems(o.items, { |
||||||
|
listeners: [{ |
||||||
|
eventName: BI.Controller.EVENT_CHANGE, |
||||||
|
action: function () { |
||||||
|
self.fireEvent(BI.Controller.EVENT_CHANGE); |
||||||
|
} |
||||||
|
}] |
||||||
|
}), |
||||||
|
layouts: [{ |
||||||
|
type: "bi.vertical", |
||||||
|
scrolly: false |
||||||
|
}] |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
populate: function (items) { |
||||||
|
var self = this; |
||||||
|
this.group.populate(BI.map(items, function(idx, item){ |
||||||
|
return BI.extend(item, { |
||||||
|
listeners: [{ |
||||||
|
eventName: BI.Controller.EVENT_CHANGE, |
||||||
|
action: function () { |
||||||
|
self.fireEvent(BI.Controller.EVENT_CHANGE, arguments); |
||||||
|
} |
||||||
|
}] |
||||||
|
}); |
||||||
|
})); |
||||||
|
}, |
||||||
|
|
||||||
|
setValue: function (v) { |
||||||
|
this.group.setValue(v); |
||||||
|
}, |
||||||
|
|
||||||
|
getValue: function () { |
||||||
|
return this.group.getValue(); |
||||||
|
} |
||||||
|
}); |
||||||
|
BI.shortcut("bi.filter_list", BI.FilterList); |
@ -0,0 +1,240 @@ |
|||||||
|
/** |
||||||
|
* 过滤条件 |
||||||
|
* |
||||||
|
* Created by GUY on 2015/9/25. |
||||||
|
* @class BI.FilterOperation |
||||||
|
* @extend BI.Widget |
||||||
|
*/ |
||||||
|
BI.FilterOperation = BI.inherit(BI.Widget, { |
||||||
|
_defaultConfig: function () { |
||||||
|
return BI.extend(BI.FilterOperation.superclass._defaultConfig.apply(this, arguments), { |
||||||
|
baseCls: "bi-filter-operation", |
||||||
|
expander: {}, |
||||||
|
items: [], |
||||||
|
selections: [BICst.FILTER_OPERATION_CONDITION, BICst.FILTER_OPERATION_FORMULA], |
||||||
|
itemsCreator: BI.emptyFn |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
_defaultState: function () { |
||||||
|
if (BI.isNotNull(this.currentSelected)) { |
||||||
|
this.currentSelected.setSelectedCondition(false); |
||||||
|
} |
||||||
|
this.buttonComboTab.setSelect(BI.FilterOperation.OPERATION_ADD_CONDITION); |
||||||
|
}, |
||||||
|
|
||||||
|
_init: function () { |
||||||
|
BI.FilterOperation.superclass._init.apply(this, arguments); |
||||||
|
var self = this, o = this.options; |
||||||
|
this.currentSelected = null; |
||||||
|
|
||||||
|
this.filter = BI.createWidget({ |
||||||
|
type: "bi.filter_pane", |
||||||
|
expander: o.expander, |
||||||
|
items: o.items, |
||||||
|
itemsCreator: o.itemsCreator |
||||||
|
}); |
||||||
|
this.filter.on(BI.Controller.EVENT_CHANGE, function (type, value, obj) { |
||||||
|
if (type === BI.Events.CLICK) { |
||||||
|
if (BI.isNotNull(self.currentSelected) && self.currentSelected === obj) { |
||||||
|
obj.setSelectedCondition(!obj.isSelectedCondition()); |
||||||
|
} else { |
||||||
|
if (BI.isNotNull(self.currentSelected)) { |
||||||
|
self.currentSelected.setSelectedCondition(false); |
||||||
|
} |
||||||
|
self.currentSelected = obj; |
||||||
|
obj.setSelectedCondition(true); |
||||||
|
} |
||||||
|
if (self.currentSelected.isSelectedCondition()) { |
||||||
|
self.buttonComboTab.setSelect(BI.FilterOperation.OPERATION_ADD_ANDOR_CONDITION); |
||||||
|
} else { |
||||||
|
self.buttonComboTab.setSelect(BI.FilterOperation.OPERATION_ADD_CONDITION); |
||||||
|
} |
||||||
|
} |
||||||
|
if (type === BI.Events.DESTROY) { |
||||||
|
if (self.currentSelected === obj) { |
||||||
|
self.currentSelected = null; |
||||||
|
self.buttonComboTab.setSelect(BI.FilterOperation.OPERATION_ADD_CONDITION); |
||||||
|
} |
||||||
|
self.fireEvent(BI.FilterOperation.EVENT_DESTROY_ITEM, value, obj); |
||||||
|
} |
||||||
|
}); |
||||||
|
this.filter.on(BI.FilterPane.EVENT_CHANGE, function () { |
||||||
|
self.fireEvent(BI.FilterOperation.EVENT_CHANGE, arguments); |
||||||
|
}); |
||||||
|
var operation = this._buildOperationTab(); |
||||||
|
|
||||||
|
BI.createWidget({ |
||||||
|
type: "bi.vtape", |
||||||
|
element: this, |
||||||
|
items: [{ |
||||||
|
el: operation, |
||||||
|
height: 40 |
||||||
|
}, { |
||||||
|
el: { |
||||||
|
type: "bi.absolute", |
||||||
|
scrollable: true, |
||||||
|
items: [{ |
||||||
|
el: { |
||||||
|
type: "bi.left", |
||||||
|
items: [ |
||||||
|
this.filter |
||||||
|
] |
||||||
|
}, |
||||||
|
top: 0, |
||||||
|
right: 2, |
||||||
|
bottom: 0, |
||||||
|
left: 0 |
||||||
|
}] |
||||||
|
} |
||||||
|
}] |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
_buildOperationTab: function () { |
||||||
|
this.buttonComboTab = BI.createWidget({ |
||||||
|
type: "bi.tab", |
||||||
|
tab: null, |
||||||
|
cardCreator: BI.bind(this._createTabs, this) |
||||||
|
}); |
||||||
|
this.buttonComboTab.setSelect(BI.FilterOperation.OPERATION_ADD_CONDITION); |
||||||
|
return this.buttonComboTab; |
||||||
|
}, |
||||||
|
|
||||||
|
_createTabs: function (v) { |
||||||
|
var self = this; |
||||||
|
switch (v) { |
||||||
|
case BI.FilterOperation.OPERATION_ADD_CONDITION: |
||||||
|
var btnGroup = BI.createWidget({ |
||||||
|
type: "bi.button_group", |
||||||
|
items: BI.createItems(self._createButtons(), { |
||||||
|
type: "bi.button", |
||||||
|
forceNotSelected: true, |
||||||
|
level: "ignore", |
||||||
|
height: 25 |
||||||
|
}), |
||||||
|
chooseType: BI.ButtonGroup.CHOOSE_TYPE_DEFAULT, |
||||||
|
layouts: [{ |
||||||
|
type: "bi.right", |
||||||
|
hgap: 10, |
||||||
|
vgap: 5 |
||||||
|
}] |
||||||
|
}); |
||||||
|
btnGroup.on(BI.ButtonGroup.EVENT_CHANGE, function (value, obj) { |
||||||
|
self.fireEvent(BI.FilterOperation.EVENT_OPERATION, obj.getValue()); |
||||||
|
self._defaultState(); |
||||||
|
}); |
||||||
|
return btnGroup; |
||||||
|
case BI.FilterOperation.OPERATION_ADD_ANDOR_CONDITION: |
||||||
|
var btnGroup = BI.createWidget({ |
||||||
|
type: "bi.button_group", |
||||||
|
chooseType: BI.ButtonGroup.CHOOSE_TYPE_DEFAULT, |
||||||
|
items: self._createCombos(), |
||||||
|
layouts: [{ |
||||||
|
type: "bi.right", |
||||||
|
hgap: 10, |
||||||
|
vgap: 5 |
||||||
|
}] |
||||||
|
}); |
||||||
|
return btnGroup; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
_createButtons: function(){ |
||||||
|
var buttons = []; |
||||||
|
BI.each(this.options.selections, function(i, type){ |
||||||
|
switch (type){ |
||||||
|
case BICst.FILTER_OPERATION_FORMULA: |
||||||
|
buttons.push({ |
||||||
|
text: BI.i18nText("BI-Add_Formula"), |
||||||
|
value: BICst.FILTER_OPERATION_FORMULA |
||||||
|
}); |
||||||
|
break; |
||||||
|
case BICst.FILTER_OPERATION_CONDITION: |
||||||
|
buttons.push({ |
||||||
|
text: BI.i18nText("BI-Add_Condition"), |
||||||
|
value: BICst.FILTER_OPERATION_CONDITION |
||||||
|
}); |
||||||
|
break; |
||||||
|
} |
||||||
|
}); |
||||||
|
return buttons; |
||||||
|
}, |
||||||
|
|
||||||
|
_createCombos: function () { |
||||||
|
var self = this, combos = []; |
||||||
|
BI.each(this.options.selections, function(i, type){ |
||||||
|
var text = "", items = []; |
||||||
|
switch (type) { |
||||||
|
case BICst.FILTER_OPERATION_FORMULA: |
||||||
|
text = BI.i18nText("BI-Add_Formula"); |
||||||
|
items = BICst.FILTER_ADD_FORMULA_COMBO; |
||||||
|
break; |
||||||
|
case BICst.FILTER_OPERATION_CONDITION: |
||||||
|
text = BI.i18nText("BI-Add_Condition"); |
||||||
|
items = BICst.FILTER_ADD_CONDITION_COMBO; |
||||||
|
break; |
||||||
|
} |
||||||
|
var addCombo = BI.createWidget({ |
||||||
|
type: "bi.static_combo", |
||||||
|
text: text, |
||||||
|
width: 90, |
||||||
|
chooseType: BI.ButtonGroup.CHOOSE_TYPE_NONE, |
||||||
|
items: BI.createItems(items, { |
||||||
|
type: "bi.single_select_item", |
||||||
|
height: 25 |
||||||
|
}) |
||||||
|
}); |
||||||
|
addCombo.on(BI.Combo.EVENT_CHANGE, function (value, obj) { |
||||||
|
self.fireEvent(BI.FilterOperation.EVENT_OPERATION, obj.getValue()); |
||||||
|
self._defaultState(); |
||||||
|
}); |
||||||
|
combos.push(addCombo); |
||||||
|
}); |
||||||
|
return combos; |
||||||
|
}, |
||||||
|
|
||||||
|
getCurrentSelectItem: function () { |
||||||
|
if (BI.isNotNull(this.currentSelected) && this.currentSelected.isSelectedCondition()) { |
||||||
|
return this.currentSelected; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
populate: function (items) { |
||||||
|
|
||||||
|
this.filter.populate.apply(this.filter, arguments); |
||||||
|
}, |
||||||
|
|
||||||
|
getValue: function () { |
||||||
|
return this.filter.getValue(); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
BICst.FILTER_ADD_FORMULA_COMBO = [{ |
||||||
|
text: BI.i18nText("BI-Condition_Expression_And"), value: BICst.FILTER_OPERATION_FORMULA_AND |
||||||
|
}, { |
||||||
|
text: BI.i18nText("BI-Condition_Expression_Or"), value: BICst.FILTER_OPERATION_FORMULA_OR |
||||||
|
}]; |
||||||
|
|
||||||
|
//添加条件combo
|
||||||
|
BICst.FILTER_ADD_CONDITION_COMBO = [{ |
||||||
|
text: BI.i18nText("BI-Condition_And"), value: BICst.FILTER_OPERATION_CONDITION_AND |
||||||
|
}, { |
||||||
|
text: BI.i18nText("BI-Condition_Or"), value: BICst.FILTER_OPERATION_CONDITION_OR |
||||||
|
}]; |
||||||
|
|
||||||
|
BICst.FILTER_OPERATION_FORMULA = 1; |
||||||
|
BICst.FILTER_OPERATION_CONDITION = 2; |
||||||
|
BICst.FILTER_OPERATION_CONDITION_AND = 3; |
||||||
|
BICst.FILTER_OPERATION_CONDITION_OR = 4; |
||||||
|
BICst.FILTER_OPERATION_FORMULA_AND = 5; |
||||||
|
BICst.FILTER_OPERATION_FORMULA_OR = 6; |
||||||
|
|
||||||
|
BI.extend(BI.FilterOperation, { |
||||||
|
OPERATION_ADD_CONDITION: 0, |
||||||
|
OPERATION_ADD_ANDOR_CONDITION: 1 |
||||||
|
}); |
||||||
|
BI.FilterOperation.EVENT_OPERATION = "EVENT_OPERATION"; |
||||||
|
BI.FilterOperation.EVENT_CHANGE = "EVENT_CHANGE"; |
||||||
|
BI.FilterOperation.EVENT_DESTROY_ITEM = "BI.FilterOperation.EVENT_DESTROY_ITEM"; |
||||||
|
BI.shortcut("bi.filter_operation", BI.FilterOperation); |
@ -0,0 +1,55 @@ |
|||||||
|
/** |
||||||
|
* @class BI.FilterPane |
||||||
|
* @extend BI.Widget |
||||||
|
* 过滤面板 |
||||||
|
*/ |
||||||
|
BI.FilterPane = BI.inherit(BI.Widget, { |
||||||
|
_defaultConfig: function () { |
||||||
|
return BI.extend(BI.FilterPane.superclass._defaultConfig.apply(this, arguments), { |
||||||
|
baseCls: "bi-filter-pane", |
||||||
|
expander: {}, |
||||||
|
items: [], |
||||||
|
itemsCreator: BI.emptyFn |
||||||
|
}) |
||||||
|
}, |
||||||
|
|
||||||
|
_init: function () { |
||||||
|
BI.FilterPane.superclass._init.apply(this, arguments); |
||||||
|
var self = this, o = this.options; |
||||||
|
this.tree = BI.createWidget({ |
||||||
|
type: "bi.custom_tree", |
||||||
|
element: this, |
||||||
|
expander: BI.extend({ |
||||||
|
type: "bi.filter_expander", |
||||||
|
el: {}, |
||||||
|
popup: { |
||||||
|
type: "bi.custom_tree" |
||||||
|
} |
||||||
|
}, o.expander), |
||||||
|
el: { |
||||||
|
type: "bi.filter_list" |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
this.tree.on(BI.Controller.EVENT_CHANGE, function (type) { |
||||||
|
self.fireEvent(BI.Controller.EVENT_CHANGE, arguments); |
||||||
|
if (type === BI.Events.CLICK) { |
||||||
|
self.fireEvent(BI.FilterPane.EVENT_CHANGE, [].slice.call(arguments, 1)); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
if (BI.isNotEmptyArray(o.items)) { |
||||||
|
this.populate(o.items); |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
populate: function (items) { |
||||||
|
this.tree.populate.apply(this.tree, arguments); |
||||||
|
}, |
||||||
|
|
||||||
|
getValue: function () { |
||||||
|
return this.tree.getValue(); |
||||||
|
} |
||||||
|
}); |
||||||
|
BI.FilterPane.EVENT_CHANGE = "EVENT_CHANGE"; |
||||||
|
BI.shortcut("bi.filter_pane", BI.FilterPane); |
Loading…
Reference in new issue