mirror of
https://github.com/discourse/discourse.git
synced 2024-12-11 19:33:39 +08:00
0431942f3d
This new iteration of select-kit focuses on following best principales and disallowing mutations inside select-kit components. A best effort has been made to avoid breaking changes, however if you content was a flat array, eg: ["foo", "bar"] You will need to set valueProperty=null and nameProperty=null on the component. Also almost every component should have an `onChange` handler now to decide what to do with the updated data. **select-kit will not mutate your data by itself anymore**
25 lines
757 B
JavaScript
25 lines
757 B
JavaScript
import SelectKitHeaderComponent from "select-kit/components/select-kit/select-kit-header";
|
|
import { computed } from "@ember/object";
|
|
|
|
export default SelectKitHeaderComponent.extend({
|
|
classNames: ["multi-select-header"],
|
|
layoutName:
|
|
"select-kit/templates/components/multi-select/multi-select-header",
|
|
|
|
selectedNames: computed("selectedContent", function() {
|
|
return Ember.makeArray(this.selectedContent).map(c => this.getName(c));
|
|
}),
|
|
|
|
selectedValue: computed("selectedContent", function() {
|
|
return Ember.makeArray(this.selectedContent)
|
|
.map(c => {
|
|
if (this.getName(c) !== this.getName(this.selectKit.noneItem)) {
|
|
return this.getValue(c);
|
|
}
|
|
|
|
return null;
|
|
})
|
|
.filter(Boolean);
|
|
})
|
|
});
|