diff --git a/demo/js/case/combo/demo.icon_combo.js b/demo/js/case/combo/demo.icon_combo.js index 6aee330c97..bdd90d4238 100644 --- a/demo/js/case/combo/demo.icon_combo.js +++ b/demo/js/case/combo/demo.icon_combo.js @@ -19,7 +19,7 @@ Demo.IconCombo = BI.inherit(BI.Widget, { ref: function (_ref) { self.refs = _ref; }, - iconCls: "search-font", + value: "第二项", items: [{ value: "第一项", iconCls: "close-font" diff --git a/dist/base.js b/dist/base.js index 760687a76b..6ba66fcd0c 100644 --- a/dist/base.js +++ b/dist/base.js @@ -3179,7 +3179,9 @@ BI.Combo = BI.inherit(BI.Widget, { // return; // } // BI-10290 公式combo双击公式内容会收起 - if (this.element.find(e.target).length > 0 || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 + if (this.element.find(e.target).length > 0 + || (this.popupView && this.popupView.element.find(e.target).length > 0) + || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 return; } var isHide = this.options.hideChecker.apply(this, [e]); diff --git a/dist/bundle.js b/dist/bundle.js index d9944107d3..5717c60a2e 100644 --- a/dist/bundle.js +++ b/dist/bundle.js @@ -29052,7 +29052,9 @@ BI.Combo = BI.inherit(BI.Widget, { // return; // } // BI-10290 公式combo双击公式内容会收起 - if (this.element.find(e.target).length > 0 || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 + if (this.element.find(e.target).length > 0 + || (this.popupView && this.popupView.element.find(e.target).length > 0) + || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 return; } var isHide = this.options.hideChecker.apply(this, [e]); @@ -67502,7 +67504,6 @@ BI.IconCombo = BI.inherit(BI.Widget, { baseCls: "bi-icon-combo", width: 24, height: 24, - iconCls: "", el: {}, popup: {}, minWidth: 100, @@ -67528,12 +67529,14 @@ BI.IconCombo = BI.inherit(BI.Widget, { width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + value: o.value }); this.popup = BI.createWidget(o.popup, { type: "bi.icon_combo_popup", chooseType: o.chooseType, - items: o.items + items: o.items, + value: o.value }); this.popup.on(BI.IconComboPopup.EVENT_CHANGE, function () { self.setValue(self.popup.getValue()); @@ -67611,7 +67614,8 @@ BI.IconComboPopup = BI.inherit(BI.Pane, { chooseType: o.chooseType, layouts: [{ type: "bi.vertical" - }] + }], + value: o.value }); this.popup.on(BI.Controller.EVENT_CHANGE, function (type, val, obj) { @@ -67662,28 +67666,35 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { iconCls: "", width: 25, height: 25, - isShowDown: true + isShowDown: true, + value: "" }); }, _init: function () { BI.IconComboTrigger.superclass._init.apply(this, arguments); var o = this.options, self = this; + var iconCls = ""; + if(BI.isKey(o.value)){ + iconCls = this._digest(o.value, o.items); + } this.button = BI.createWidget(o.el, { type: "bi.icon_change_button", - cls: "icon-combo-trigger-icon " + o.iconCls, + cls: "icon-combo-trigger-icon " + iconCls, disableSelected: true, width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + selected: BI.isNotEmptyString(iconCls) }); this.down = BI.createWidget({ type: "bi.icon_button", disableSelected: true, cls: "icon-combo-down-icon trigger-triangle-font", width: 12, - height: 8 + height: 8, + selected: BI.isNotEmptyString(iconCls) }); this.down.setVisible(o.isShowDown); BI.createWidget({ @@ -67701,9 +67712,18 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { bottom: 0 }] }); - if (BI.isKey(o.value)) { - this.setValue(o.value); - } + }, + + _digest: function (v, items) { + var iconCls = ""; + v = BI.isArray(v) ? v[0] : v; + BI.any(items, function (i, item) { + if (v === item.value) { + iconCls = item.iconCls; + return true; + } + }); + return iconCls; }, populate: function (items) { @@ -67717,14 +67737,9 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { setValue: function (v) { BI.IconComboTrigger.superclass.setValue.apply(this, arguments); var o = this.options; - var iconCls = ""; + var iconCls = this._digest(v, this.options.items); v = BI.isArray(v) ? v[0] : v; - if (BI.any(this.options.items, function (i, item) { - if (v === item.value) { - iconCls = item.iconCls; - return true; - } - })) { + if (BI.isNotEmptyString(iconCls)) { this.button.setIcon(iconCls); this.button.setSelected(true); this.down.setSelected(true); diff --git a/dist/case.js b/dist/case.js index ed169fcb2f..8ad70c5e83 100644 --- a/dist/case.js +++ b/dist/case.js @@ -5214,7 +5214,6 @@ BI.IconCombo = BI.inherit(BI.Widget, { baseCls: "bi-icon-combo", width: 24, height: 24, - iconCls: "", el: {}, popup: {}, minWidth: 100, @@ -5240,12 +5239,14 @@ BI.IconCombo = BI.inherit(BI.Widget, { width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + value: o.value }); this.popup = BI.createWidget(o.popup, { type: "bi.icon_combo_popup", chooseType: o.chooseType, - items: o.items + items: o.items, + value: o.value }); this.popup.on(BI.IconComboPopup.EVENT_CHANGE, function () { self.setValue(self.popup.getValue()); @@ -5323,7 +5324,8 @@ BI.IconComboPopup = BI.inherit(BI.Pane, { chooseType: o.chooseType, layouts: [{ type: "bi.vertical" - }] + }], + value: o.value }); this.popup.on(BI.Controller.EVENT_CHANGE, function (type, val, obj) { @@ -5374,28 +5376,35 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { iconCls: "", width: 25, height: 25, - isShowDown: true + isShowDown: true, + value: "" }); }, _init: function () { BI.IconComboTrigger.superclass._init.apply(this, arguments); var o = this.options, self = this; + var iconCls = ""; + if(BI.isKey(o.value)){ + iconCls = this._digest(o.value, o.items); + } this.button = BI.createWidget(o.el, { type: "bi.icon_change_button", - cls: "icon-combo-trigger-icon " + o.iconCls, + cls: "icon-combo-trigger-icon " + iconCls, disableSelected: true, width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + selected: BI.isNotEmptyString(iconCls) }); this.down = BI.createWidget({ type: "bi.icon_button", disableSelected: true, cls: "icon-combo-down-icon trigger-triangle-font", width: 12, - height: 8 + height: 8, + selected: BI.isNotEmptyString(iconCls) }); this.down.setVisible(o.isShowDown); BI.createWidget({ @@ -5413,9 +5422,18 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { bottom: 0 }] }); - if (BI.isKey(o.value)) { - this.setValue(o.value); - } + }, + + _digest: function (v, items) { + var iconCls = ""; + v = BI.isArray(v) ? v[0] : v; + BI.any(items, function (i, item) { + if (v === item.value) { + iconCls = item.iconCls; + return true; + } + }); + return iconCls; }, populate: function (items) { @@ -5429,14 +5447,9 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { setValue: function (v) { BI.IconComboTrigger.superclass.setValue.apply(this, arguments); var o = this.options; - var iconCls = ""; + var iconCls = this._digest(v, this.options.items); v = BI.isArray(v) ? v[0] : v; - if (BI.any(this.options.items, function (i, item) { - if (v === item.value) { - iconCls = item.iconCls; - return true; - } - })) { + if (BI.isNotEmptyString(iconCls)) { this.button.setIcon(iconCls); this.button.setSelected(true); this.down.setSelected(true); diff --git a/dist/demo.js b/dist/demo.js index 3adfe4f222..2401228fb2 100644 --- a/dist/demo.js +++ b/dist/demo.js @@ -1801,7 +1801,7 @@ Demo.IconCombo = BI.inherit(BI.Widget, { ref: function (_ref) { self.refs = _ref; }, - iconCls: "search-font", + value: "第二项", items: [{ value: "第一项", iconCls: "close-font" diff --git a/dist/fineui.js b/dist/fineui.js index c4ec48a057..b80b774dee 100644 --- a/dist/fineui.js +++ b/dist/fineui.js @@ -30746,7 +30746,9 @@ BI.Combo = BI.inherit(BI.Widget, { // return; // } // BI-10290 公式combo双击公式内容会收起 - if (this.element.find(e.target).length > 0 || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 + if (this.element.find(e.target).length > 0 + || (this.popupView && this.popupView.element.find(e.target).length > 0) + || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 return; } var isHide = this.options.hideChecker.apply(this, [e]); @@ -69196,7 +69198,6 @@ BI.IconCombo = BI.inherit(BI.Widget, { baseCls: "bi-icon-combo", width: 24, height: 24, - iconCls: "", el: {}, popup: {}, minWidth: 100, @@ -69222,12 +69223,14 @@ BI.IconCombo = BI.inherit(BI.Widget, { width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + value: o.value }); this.popup = BI.createWidget(o.popup, { type: "bi.icon_combo_popup", chooseType: o.chooseType, - items: o.items + items: o.items, + value: o.value }); this.popup.on(BI.IconComboPopup.EVENT_CHANGE, function () { self.setValue(self.popup.getValue()); @@ -69305,7 +69308,8 @@ BI.IconComboPopup = BI.inherit(BI.Pane, { chooseType: o.chooseType, layouts: [{ type: "bi.vertical" - }] + }], + value: o.value }); this.popup.on(BI.Controller.EVENT_CHANGE, function (type, val, obj) { @@ -69356,28 +69360,35 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { iconCls: "", width: 25, height: 25, - isShowDown: true + isShowDown: true, + value: "" }); }, _init: function () { BI.IconComboTrigger.superclass._init.apply(this, arguments); var o = this.options, self = this; + var iconCls = ""; + if(BI.isKey(o.value)){ + iconCls = this._digest(o.value, o.items); + } this.button = BI.createWidget(o.el, { type: "bi.icon_change_button", - cls: "icon-combo-trigger-icon " + o.iconCls, + cls: "icon-combo-trigger-icon " + iconCls, disableSelected: true, width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + selected: BI.isNotEmptyString(iconCls) }); this.down = BI.createWidget({ type: "bi.icon_button", disableSelected: true, cls: "icon-combo-down-icon trigger-triangle-font", width: 12, - height: 8 + height: 8, + selected: BI.isNotEmptyString(iconCls) }); this.down.setVisible(o.isShowDown); BI.createWidget({ @@ -69395,9 +69406,18 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { bottom: 0 }] }); - if (BI.isKey(o.value)) { - this.setValue(o.value); - } + }, + + _digest: function (v, items) { + var iconCls = ""; + v = BI.isArray(v) ? v[0] : v; + BI.any(items, function (i, item) { + if (v === item.value) { + iconCls = item.iconCls; + return true; + } + }); + return iconCls; }, populate: function (items) { @@ -69411,14 +69431,9 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { setValue: function (v) { BI.IconComboTrigger.superclass.setValue.apply(this, arguments); var o = this.options; - var iconCls = ""; + var iconCls = this._digest(v, this.options.items); v = BI.isArray(v) ? v[0] : v; - if (BI.any(this.options.items, function (i, item) { - if (v === item.value) { - iconCls = item.iconCls; - return true; - } - })) { + if (BI.isNotEmptyString(iconCls)) { this.button.setIcon(iconCls); this.button.setSelected(true); this.down.setSelected(true); diff --git a/src/base/combination/combo.js b/src/base/combination/combo.js index e6ac9d0a3e..3ea38211a5 100644 --- a/src/base/combination/combo.js +++ b/src/base/combination/combo.js @@ -255,7 +255,9 @@ BI.Combo = BI.inherit(BI.Widget, { // return; // } // BI-10290 公式combo双击公式内容会收起 - if (this.element.find(e.target).length > 0 || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 + if (this.element.find(e.target).length > 0 + || (this.popupView && this.popupView.element.find(e.target).length > 0) + || e.target.className === "CodeMirror-cursor" || $(e.target).closest(".CodeMirror-hints").length > 0) {// BI-9887 CodeMirror的公式弹框需要特殊处理下 return; } var isHide = this.options.hideChecker.apply(this, [e]); diff --git a/src/case/combo/iconcombo/combo.icon.js b/src/case/combo/iconcombo/combo.icon.js index 00f556c2d4..39799527f8 100644 --- a/src/case/combo/iconcombo/combo.icon.js +++ b/src/case/combo/iconcombo/combo.icon.js @@ -10,7 +10,6 @@ BI.IconCombo = BI.inherit(BI.Widget, { baseCls: "bi-icon-combo", width: 24, height: 24, - iconCls: "", el: {}, popup: {}, minWidth: 100, @@ -36,12 +35,14 @@ BI.IconCombo = BI.inherit(BI.Widget, { width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + value: o.value }); this.popup = BI.createWidget(o.popup, { type: "bi.icon_combo_popup", chooseType: o.chooseType, - items: o.items + items: o.items, + value: o.value }); this.popup.on(BI.IconComboPopup.EVENT_CHANGE, function () { self.setValue(self.popup.getValue()); diff --git a/src/case/combo/iconcombo/popup.iconcombo.js b/src/case/combo/iconcombo/popup.iconcombo.js index 419c85d41b..1bcccefa76 100644 --- a/src/case/combo/iconcombo/popup.iconcombo.js +++ b/src/case/combo/iconcombo/popup.iconcombo.js @@ -24,7 +24,8 @@ BI.IconComboPopup = BI.inherit(BI.Pane, { chooseType: o.chooseType, layouts: [{ type: "bi.vertical" - }] + }], + value: o.value }); this.popup.on(BI.Controller.EVENT_CHANGE, function (type, val, obj) { diff --git a/src/case/combo/iconcombo/trigger.iconcombo.js b/src/case/combo/iconcombo/trigger.iconcombo.js index 09d0f66d8c..0f3f7d6357 100644 --- a/src/case/combo/iconcombo/trigger.iconcombo.js +++ b/src/case/combo/iconcombo/trigger.iconcombo.js @@ -13,28 +13,35 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { iconCls: "", width: 25, height: 25, - isShowDown: true + isShowDown: true, + value: "" }); }, _init: function () { BI.IconComboTrigger.superclass._init.apply(this, arguments); var o = this.options, self = this; + var iconCls = ""; + if(BI.isKey(o.value)){ + iconCls = this._digest(o.value, o.items); + } this.button = BI.createWidget(o.el, { type: "bi.icon_change_button", - cls: "icon-combo-trigger-icon " + o.iconCls, + cls: "icon-combo-trigger-icon " + iconCls, disableSelected: true, width: o.width, height: o.height, iconWidth: o.iconWidth, - iconHeight: o.iconHeight + iconHeight: o.iconHeight, + selected: BI.isNotEmptyString(iconCls) }); this.down = BI.createWidget({ type: "bi.icon_button", disableSelected: true, cls: "icon-combo-down-icon trigger-triangle-font", width: 12, - height: 8 + height: 8, + selected: BI.isNotEmptyString(iconCls) }); this.down.setVisible(o.isShowDown); BI.createWidget({ @@ -52,9 +59,18 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { bottom: 0 }] }); - if (BI.isKey(o.value)) { - this.setValue(o.value); - } + }, + + _digest: function (v, items) { + var iconCls = ""; + v = BI.isArray(v) ? v[0] : v; + BI.any(items, function (i, item) { + if (v === item.value) { + iconCls = item.iconCls; + return true; + } + }); + return iconCls; }, populate: function (items) { @@ -68,14 +84,9 @@ BI.IconComboTrigger = BI.inherit(BI.Trigger, { setValue: function (v) { BI.IconComboTrigger.superclass.setValue.apply(this, arguments); var o = this.options; - var iconCls = ""; + var iconCls = this._digest(v, this.options.items); v = BI.isArray(v) ? v[0] : v; - if (BI.any(this.options.items, function (i, item) { - if (v === item.value) { - iconCls = item.iconCls; - return true; - } - })) { + if (BI.isNotEmptyString(iconCls)) { this.button.setIcon(iconCls); this.button.setSelected(true); this.down.setSelected(true);