discourse/app/assets/javascripts/admin/components/inline-edit-checkbox.js.es6

45 lines
847 B
Plaintext
Raw Normal View History

import Component from "@ember/component";
2018-06-15 23:03:24 +08:00
import {
default as discourseComputed,
2018-06-15 23:03:24 +08:00
observes
} from "discourse-common/utils/decorators";
export default Component.extend({
classNames: ["inline-edit"],
checked: null,
checkedInternal: null,
2018-06-15 23:03:24 +08:00
init() {
this._super(...arguments);
this.set("checkedInternal", this.checked);
},
@observes("checked")
checkedChanged() {
this.set("checkedInternal", this.checked);
},
@discourseComputed("labelKey")
label(key) {
return I18n.t(key);
},
@discourseComputed("checked", "checkedInternal")
changed(checked, checkedInternal) {
2018-06-15 23:03:24 +08:00
return !!checked !== !!checkedInternal;
},
actions: {
2018-06-15 23:03:24 +08:00
cancelled() {
this.set("checkedInternal", this.checked);
},
2018-06-15 23:03:24 +08:00
finished() {
this.set("checked", this.checkedInternal);
this.action();
}
}
});