FIX: Move consts and translations for bookmark auto delete prefs (#10295)

This commit is contained in:
Martin Brennan
2020-07-23 13:12:28 +10:00
committed by GitHub
parent 7559758e10
commit e027acd367
4 changed files with 41 additions and 38 deletions
@@ -12,6 +12,7 @@ import { popupAjaxError } from "discourse/lib/ajax-error";
import { ajax } from "discourse/lib/ajax";
import KeyboardShortcuts from "discourse/lib/keyboard-shortcuts";
import { formattedReminderTime, REMINDER_TYPES } from "discourse/lib/bookmark";
import { AUTO_DELETE_PREFERENCES } from "discourse/models/bookmark";
// global shortcuts that interfere with these modal shortcuts, they are rebound when the
// modal is closed
@@ -27,21 +28,6 @@ const LATER_TODAY_CUTOFF_HOUR = 17;
const LATER_TODAY_MAX_HOUR = 18;
const MOMENT_MONDAY = 1;
const MOMENT_THURSDAY = 4;
const AUTO_DELETE_PREFERENCES = [
{
id: 0,
name: I18n.t("bookmarks.auto_delete_preference.never")
},
{
id: 1,
name: I18n.t("bookmarks.auto_delete_preference.when_reminder_sent")
},
{
id: 2,
name: I18n.t("bookmarks.auto_delete_preference.on_owner_reply")
}
];
const BOOKMARK_BINDINGS = {
enter: { handler: "saveAndClose" },
"l t": { handler: "selectReminderType", args: [REMINDER_TYPES.LATER_TODAY] },
@@ -238,7 +224,12 @@ export default Controller.extend(ModalFunctionality, {
@discourseComputed()
autoDeletePreferences: () => {
return AUTO_DELETE_PREFERENCES;
return Object.keys(AUTO_DELETE_PREFERENCES).map(key => {
return {
id: AUTO_DELETE_PREFERENCES[key],
name: I18n.t(`bookmarks.auto_delete_preference.${key.toLowerCase()}`)
};
});
},
showLastCustom: and("lastCustomReminderTime", "lastCustomReminderDate"),
@@ -23,6 +23,7 @@ import showModal from "discourse/lib/show-modal";
import TopicTimer from "discourse/models/topic-timer";
import { Promise } from "rsvp";
import { escapeExpression } from "discourse/lib/utilities";
import { AUTO_DELETE_PREFERENCES } from "discourse/models/bookmark";
let customPostMessageCallbacks = {};
@@ -190,7 +191,12 @@ export default Controller.extend(bufferedProperty("model"), {
_removeDeleteOnOwnerReplyBookmarks() {
let posts = this.model.get("postStream").posts;
posts
.filter(p => p.bookmarked && p.bookmark_auto_delete_preference === 2) // 2 is on_owner_reply
.filter(
p =>
p.bookmarked &&
p.bookmark_auto_delete_preference ===
AUTO_DELETE_PREFERENCES.ON_OWNER_REPLY
)
.forEach(p => {
p.clearBookmark();
});
@@ -15,6 +15,12 @@ import RestModel from "discourse/models/rest";
import discourseComputed from "discourse-common/utils/decorators";
import { formattedReminderTime } from "discourse/lib/bookmark";
export const AUTO_DELETE_PREFERENCES = {
NEVER: 0,
WHEN_REMINDER_SENT: 1,
ON_OWNER_REPLY: 2
};
const Bookmark = RestModel.extend({
newBookmark: none("id"),