DEV: Move rerender on 'do not disturb' change to mixin (#11529)

This commit is contained in:
Mark VanLandingham 2020-12-18 10:35:43 -06:00 committed by GitHub
parent 649ed24bb4
commit d8e2b497f7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 379 additions and 360 deletions

View File

@ -6,15 +6,18 @@ import PanEvents, {
import { cancel, later, schedule } from "@ember/runloop"; import { cancel, later, schedule } from "@ember/runloop";
import Docking from "discourse/mixins/docking"; import Docking from "discourse/mixins/docking";
import MountWidget from "discourse/components/mount-widget"; import MountWidget from "discourse/components/mount-widget";
import { isTesting } from "discourse-common/config/environment"; import RerenderOnDoNotDisturbChange from "discourse/mixins/rerender-on-do-not-disturb-change";
import { observes } from "discourse-common/utils/decorators"; import { observes } from "discourse-common/utils/decorators";
import { topicTitleDecorators } from "discourse/components/topic-title"; import { topicTitleDecorators } from "discourse/components/topic-title";
const SiteHeaderComponent = MountWidget.extend(Docking, PanEvents, { const SiteHeaderComponent = MountWidget.extend(
Docking,
PanEvents,
RerenderOnDoNotDisturbChange,
{
widget: "header", widget: "header",
docAt: null, docAt: null,
dockedHeader: null, dockedHeader: null,
_listenToDoNotDisturbLoop: null,
_animate: false, _animate: false,
_isPanning: false, _isPanning: false,
_panMenuOrigin: "right", _panMenuOrigin: "right",
@ -196,32 +199,12 @@ const SiteHeaderComponent = MountWidget.extend(Docking, PanEvents, {
} }
}, },
listenForDoNotDisturbChanges() {
if (this.currentUser && !this.currentUser.isInDoNotDisturb()) {
this.queueRerender();
} else {
cancel(this._listenToDoNotDisturbLoop);
this._listenToDoNotDisturbLoop = later(
this,
() => {
this.listenForDoNotDisturbChanges();
},
10000
);
}
},
didInsertElement() { didInsertElement() {
this._super(...arguments); this._super(...arguments);
$(window).on("resize.discourse-menu-panel", () => this.afterRender()); $(window).on("resize.discourse-menu-panel", () => this.afterRender());
this.appEvents.on("header:show-topic", this, "setTopic"); this.appEvents.on("header:show-topic", this, "setTopic");
this.appEvents.on("header:hide-topic", this, "setTopic"); this.appEvents.on("header:hide-topic", this, "setTopic");
this.appEvents.on("do-not-disturb:changed", () => this.queueRerender());
if (!isTesting()) {
this.listenForDoNotDisturbChanges();
}
this.dispatch("notifications:changed", "user-notifications"); this.dispatch("notifications:changed", "user-notifications");
this.dispatch("header:keyboard-trigger", "header"); this.dispatch("header:keyboard-trigger", "header");
@ -272,7 +255,6 @@ const SiteHeaderComponent = MountWidget.extend(Docking, PanEvents, {
this.appEvents.off("dom:clean", this, "_cleanDom"); this.appEvents.off("dom:clean", this, "_cleanDom");
cancel(this._scheduledRemoveAnimate); cancel(this._scheduledRemoveAnimate);
cancel(this._listenToDoNotDisturbLoop);
window.cancelAnimationFrame(this._scheduledMovingAnimation); window.cancelAnimationFrame(this._scheduledMovingAnimation);
document.removeEventListener("click", this._dismissFirstNotification); document.removeEventListener("click", this._dismissFirstNotification);
@ -403,7 +385,8 @@ const SiteHeaderComponent = MountWidget.extend(Docking, PanEvents, {
this._animate = false; this._animate = false;
}); });
}, },
}); }
);
export default SiteHeaderComponent.extend({ export default SiteHeaderComponent.extend({
classNames: ["d-header-wrap"], classNames: ["d-header-wrap"],

View File

@ -0,0 +1,36 @@
import { cancel, later } from "@ember/runloop";
import Mixin from "@ember/object/mixin";
import { isTesting } from "discourse-common/config/environment";
export default Mixin.create({
_listenToDoNotDisturbLoop: null,
listenForDoNotDisturbChanges() {
if (this.currentUser && !this.currentUser.isInDoNotDisturb()) {
this.queueRerender();
} else {
cancel(this._listenToDoNotDisturbLoop);
this._listenToDoNotDisturbLoop = later(
this,
() => {
this.listenForDoNotDisturbChanges();
},
10000
);
}
},
didInsertElement() {
this._super(...arguments);
this.appEvents.on("do-not-disturb:changed", () => this.queueRerender());
if (!isTesting()) {
this.listenForDoNotDisturbChanges();
}
},
willDestroyElement() {
this._super(...arguments);
cancel(this._listenToDoNotDisturbLoop);
},
});