discourse/app/assets/javascripts/admin/components/admin-web-hook-status.js.es6

32 lines
1.0 KiB
Plaintext
Raw Normal View History

import discourseComputed from "discourse-common/utils/decorators";
import Component from "@ember/component";
2018-06-15 23:03:24 +08:00
import { iconHTML } from "discourse-common/lib/icon-library";
2016-06-16 01:49:57 +08:00
export default Component.extend({
classes: ["text-muted", "text-danger", "text-successful", "text-muted"],
icons: ["far-circle", "times-circle", "circle", "circle"],
circleIcon: null,
deliveryStatus: null,
2016-06-16 01:49:57 +08:00
@discourseComputed("deliveryStatuses", "model.last_delivery_status")
status(deliveryStatuses, lastDeliveryStatus) {
return deliveryStatuses.find(s => s.id === lastDeliveryStatus);
},
2016-06-16 01:49:57 +08:00
@discourseComputed("status.id", "icons")
icon(statusId, icons) {
return icons[statusId - 1];
},
2016-06-16 01:49:57 +08:00
@discourseComputed("status.id", "classes")
class(statusId, classes) {
return classes[statusId - 1];
},
2016-06-16 01:49:57 +08:00
didReceiveAttrs() {
this._super(...arguments);
this.set("circleIcon", iconHTML(this.icon, { class: this.class }).htmlSafe());
this.set("deliveryStatus", I18n.t(`admin.web_hooks.delivery_status.${this.get("status.name")}`));
}
});