FIX: better headerText handling on select-box

This commit is contained in:
Joffrey JAFFEUX 2017-08-24 18:31:33 +02:00 committed by GitHub
parent a6251f717b
commit d05df4a337
3 changed files with 49 additions and 3 deletions

View File

@ -17,6 +17,7 @@ export default Ember.Component.extend({
caretUpIcon: "caret-up", caretUpIcon: "caret-up",
caretDownIcon: "caret-down", caretDownIcon: "caret-down",
headerText: null, headerText: null,
dynamicHeaderText: true,
icon: null, icon: null,
value: null, value: null,
@ -145,7 +146,7 @@ export default Ember.Component.extend({
} }
}, },
@observes("content.[]") @observes("content.[]", "value")
@on("didReceiveAttrs") @on("didReceiveAttrs")
_contentChanged: function() { _contentChanged: function() {
if (!Ember.isNone(this.get("value"))) { if (!Ember.isNone(this.get("value"))) {
@ -157,9 +158,11 @@ export default Ember.Component.extend({
this.set("filteredContent", this._remapContent(this.get("content"))); this.set("filteredContent", this._remapContent(this.get("content")));
this._setSelectedContent(this.get("content")); this._setSelectedContent(this.get("content"));
if (Ember.isNone(this.get("headerText"))) { if (this.get("dynamicHeaderText") === true) {
if (!Ember.isNone(this.get("selectedContent.text"))) {
this.set("headerText", this.get("selectedContent.text")); this.set("headerText", this.get("selectedContent.text"));
} }
}
}, },
@on("didInsertElement") @on("didInsertElement")

View File

@ -6,6 +6,8 @@ export default SelectBoxComponent.extend({
headerText: I18n.t("topic.controls"), headerText: I18n.t("topic.controls"),
dynamicHeaderText: false,
maxCollectionHeight: 300, maxCollectionHeight: 300,
init() { init() {

View File

@ -272,3 +272,44 @@ componentTest('supports converting select value to integer', {
}); });
} }
}); });
componentTest('dynamic headerText', {
template: '{{select-box value=1 content=content}}',
beforeEach() {
this.set("content", [{ id: 1, text: "robin" }, { id: 2, text: "regis" }]);
},
test(assert) {
click(".select-box-header");
andThen(() => {
assert.equal(find(".select-box-header .current-selection").html().trim(), "robin");
});
click(".select-box-row[title='regis']");
andThen(() => {
assert.equal(find(".select-box-header .current-selection").html().trim(), "regis", "it changes header text");
});
}
});
componentTest('static headerText', {
template: '{{select-box value=1 content=content dynamicHeaderText=false headerText=headerText}}',
beforeEach() {
this.set("content", [{ id: 1, text: "robin" }, { id: 2, text: "regis" }]);
this.set("headerText", "Choose...");
},
test(assert) {
click(".select-box-header");
andThen(() => {
assert.equal(find(".select-box-header .current-selection").html().trim(), "Choose...");
});
click(".select-box-row[title='regis']");
andThen(() => {
assert.equal(find(".select-box-header .current-selection").html().trim(), "Choose...", "it doesnt change header text");
});
}
});