UNPKG

matrix-react-sdk

Version:
162 lines (145 loc) 18.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.ReleaseAnnouncementStore = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _matrix = require("matrix-js-sdk/src/matrix"); var _logger = require("matrix-js-sdk/src/logger"); var _lodash = require("lodash"); var _SettingsStore = _interopRequireDefault(require("../settings/SettingsStore")); var _SettingLevel = require("../settings/SettingLevel"); var _Settings = require("../settings/Settings"); /* * Copyright 2024 New Vector Ltd. * Copyright 2024 The Matrix.org Foundation C.I.C. * * SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only * Please see LICENSE files in the repository root for full details. */ /** * The features are shown in the array order. */ const FEATURES = ["threadsActivityCentre", "pinningMessageList"]; /** * All the features that can be shown in the release announcements. */ /** * The stored settings for the release announcements. * The boolean is at true when the user has viewed the feature */ /** * The events emitted by the ReleaseAnnouncementStore. */ /** * The handlers for the ReleaseAnnouncementStore events. */ /** * The ReleaseAnnouncementStore is responsible for managing the release announcements. * It keeps track of the viewed release announcements and emits events when the release announcement changes. */ class ReleaseAnnouncementStore extends _matrix.TypedEventEmitter { /** * The singleton instance of the ReleaseAnnouncementStore. */ static get instance() { if (!ReleaseAnnouncementStore.internalInstance) { ReleaseAnnouncementStore.internalInstance = new ReleaseAnnouncementStore(); } return ReleaseAnnouncementStore.internalInstance; } /** * Should be used only for testing purposes. * @internal */ constructor() { super(); /** * The index of the feature to show. * @private */ (0, _defineProperty2.default)(this, "index", 0); _SettingsStore.default.watchSetting("releaseAnnouncementData", null, () => { this.emit("releaseAnnouncementChanged", this.getReleaseAnnouncement()); }); } /** * Get the viewed release announcements from the settings. * @private */ getViewedReleaseAnnouncements() { // Clone the settings to avoid to mutate the internal stored value in the SettingsStore return (0, _lodash.cloneDeep)(_SettingsStore.default.getValue("releaseAnnouncementData")); } /** * Check if the release announcement is enabled. * @private */ isReleaseAnnouncementEnabled() { return _SettingsStore.default.getValue(_Settings.Features.ReleaseAnnouncement); } /** * Get the release announcement that should be displayed * @returns The feature to announce or null if there is no feature to announce */ getReleaseAnnouncement() { // Do nothing if the release announcement is disabled const isReleaseAnnouncementEnabled = this.isReleaseAnnouncementEnabled(); if (!isReleaseAnnouncementEnabled) return null; const viewedReleaseAnnouncements = this.getViewedReleaseAnnouncements(); // Find the first feature that has not been viewed for (let i = this.index; i < FEATURES.length; i++) { if (!viewedReleaseAnnouncements[FEATURES[i]]) { this.index = i; return FEATURES[this.index]; } } // All features have been viewed return null; } /** * Mark the current release announcement as viewed. * This will update the account settings * @private */ async markReleaseAnnouncementAsViewed() { // Do nothing if the release announcement is disabled const isReleaseAnnouncementEnabled = this.isReleaseAnnouncementEnabled(); if (!isReleaseAnnouncementEnabled) return; const viewedReleaseAnnouncements = this.getViewedReleaseAnnouncements(); // If the index is out of bounds, do nothing // Normally it shouldn't happen, but it's better to be safe const feature = FEATURES[this.index]; if (!feature) return; // Mark the feature as viewed viewedReleaseAnnouncements[FEATURES[this.index]] = true; this.index++; // Do sanity check if we can store the new value in the settings const isSupported = _SettingsStore.default.isLevelSupported(_SettingLevel.SettingLevel.ACCOUNT); if (!isSupported) return; const canSetValue = _SettingsStore.default.canSetValue("releaseAnnouncementData", null, _SettingLevel.SettingLevel.ACCOUNT); if (canSetValue) { try { await _SettingsStore.default.setValue("releaseAnnouncementData", null, _SettingLevel.SettingLevel.ACCOUNT, viewedReleaseAnnouncements); } catch (e) { _logger.logger.log("Failed to set release announcement settings", e); } } } /** * Mark the current release announcement as viewed and move to the next release announcement. * This will update the account settings and emit the `releaseAnnouncementChanged` event */ async nextReleaseAnnouncement() { await this.markReleaseAnnouncementAsViewed(); this.emit("releaseAnnouncementChanged", this.getReleaseAnnouncement()); } } exports.ReleaseAnnouncementStore = ReleaseAnnouncementStore; /** * The singleton instance of the ReleaseAnnouncementStore. * @private */ (0, _defineProperty2.default)(ReleaseAnnouncementStore, "internalInstance", void 0); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_matrix","require","_logger","_lodash","_SettingsStore","_interopRequireDefault","_SettingLevel","_Settings","FEATURES","ReleaseAnnouncementStore","TypedEventEmitter","instance","internalInstance","constructor","_defineProperty2","default","SettingsStore","watchSetting","emit","getReleaseAnnouncement","getViewedReleaseAnnouncements","cloneDeep","getValue","isReleaseAnnouncementEnabled","Features","ReleaseAnnouncement","viewedReleaseAnnouncements","i","index","length","markReleaseAnnouncementAsViewed","feature","isSupported","isLevelSupported","SettingLevel","ACCOUNT","canSetValue","setValue","e","logger","log","nextReleaseAnnouncement","exports"],"sources":["../../src/stores/ReleaseAnnouncementStore.ts"],"sourcesContent":["/*\n * Copyright 2024 New Vector Ltd.\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\n * Please see LICENSE files in the repository root for full details.\n */\n\nimport { TypedEventEmitter } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { cloneDeep } from \"lodash\";\n\nimport SettingsStore from \"../settings/SettingsStore\";\nimport { SettingLevel } from \"../settings/SettingLevel\";\nimport { Features } from \"../settings/Settings\";\n\n/**\n * The features are shown in the array order.\n */\nconst FEATURES = [\"threadsActivityCentre\", \"pinningMessageList\"] as const;\n/**\n * All the features that can be shown in the release announcements.\n */\nexport type Feature = (typeof FEATURES)[number];\n/**\n * The stored settings for the release announcements.\n * The boolean is at true when the user has viewed the feature\n */\ntype StoredSettings = Record<Feature, boolean>;\n\n/**\n * The events emitted by the ReleaseAnnouncementStore.\n */\ntype ReleaseAnnouncementStoreEvents = \"releaseAnnouncementChanged\";\n/**\n * The handlers for the ReleaseAnnouncementStore events.\n */\ntype HandlerMap = {\n    releaseAnnouncementChanged: (newFeature: Feature | null) => void;\n};\n\n/**\n * The ReleaseAnnouncementStore is responsible for managing the release announcements.\n * It keeps track of the viewed release announcements and emits events when the release announcement changes.\n */\nexport class ReleaseAnnouncementStore extends TypedEventEmitter<ReleaseAnnouncementStoreEvents, HandlerMap> {\n    /**\n     * The singleton instance of the ReleaseAnnouncementStore.\n     * @private\n     */\n    private static internalInstance: ReleaseAnnouncementStore;\n    /**\n     * The index of the feature to show.\n     * @private\n     */\n    private index = 0;\n\n    /**\n     * The singleton instance of the ReleaseAnnouncementStore.\n     */\n    public static get instance(): ReleaseAnnouncementStore {\n        if (!ReleaseAnnouncementStore.internalInstance) {\n            ReleaseAnnouncementStore.internalInstance = new ReleaseAnnouncementStore();\n        }\n        return ReleaseAnnouncementStore.internalInstance;\n    }\n\n    /**\n     * Should be used only for testing purposes.\n     * @internal\n     */\n    public constructor() {\n        super();\n        SettingsStore.watchSetting(\"releaseAnnouncementData\", null, () => {\n            this.emit(\"releaseAnnouncementChanged\", this.getReleaseAnnouncement());\n        });\n    }\n\n    /**\n     * Get the viewed release announcements from the settings.\n     * @private\n     */\n    private getViewedReleaseAnnouncements(): StoredSettings {\n        // Clone the settings to avoid to mutate the internal stored value in the SettingsStore\n        return cloneDeep(SettingsStore.getValue<StoredSettings>(\"releaseAnnouncementData\"));\n    }\n\n    /**\n     * Check if the release announcement is enabled.\n     * @private\n     */\n    private isReleaseAnnouncementEnabled(): boolean {\n        return SettingsStore.getValue<boolean>(Features.ReleaseAnnouncement);\n    }\n\n    /**\n     * Get the release announcement that should be displayed\n     * @returns The feature to announce or null if there is no feature to announce\n     */\n    public getReleaseAnnouncement(): Feature | null {\n        // Do nothing if the release announcement is disabled\n        const isReleaseAnnouncementEnabled = this.isReleaseAnnouncementEnabled();\n        if (!isReleaseAnnouncementEnabled) return null;\n\n        const viewedReleaseAnnouncements = this.getViewedReleaseAnnouncements();\n\n        // Find the first feature that has not been viewed\n        for (let i = this.index; i < FEATURES.length; i++) {\n            if (!viewedReleaseAnnouncements[FEATURES[i]]) {\n                this.index = i;\n                return FEATURES[this.index];\n            }\n        }\n\n        // All features have been viewed\n        return null;\n    }\n\n    /**\n     * Mark the current release announcement as viewed.\n     * This will update the account settings\n     * @private\n     */\n    private async markReleaseAnnouncementAsViewed(): Promise<void> {\n        // Do nothing if the release announcement is disabled\n        const isReleaseAnnouncementEnabled = this.isReleaseAnnouncementEnabled();\n        if (!isReleaseAnnouncementEnabled) return;\n\n        const viewedReleaseAnnouncements = this.getViewedReleaseAnnouncements();\n\n        // If the index is out of bounds, do nothing\n        // Normally it shouldn't happen, but it's better to be safe\n        const feature = FEATURES[this.index];\n        if (!feature) return;\n\n        // Mark the feature as viewed\n        viewedReleaseAnnouncements[FEATURES[this.index]] = true;\n        this.index++;\n\n        // Do sanity check if we can store the new value in the settings\n        const isSupported = SettingsStore.isLevelSupported(SettingLevel.ACCOUNT);\n        if (!isSupported) return;\n\n        const canSetValue = SettingsStore.canSetValue(\"releaseAnnouncementData\", null, SettingLevel.ACCOUNT);\n        if (canSetValue) {\n            try {\n                await SettingsStore.setValue(\n                    \"releaseAnnouncementData\",\n                    null,\n                    SettingLevel.ACCOUNT,\n                    viewedReleaseAnnouncements,\n                );\n            } catch (e) {\n                logger.log(\"Failed to set release announcement settings\", e);\n            }\n        }\n    }\n\n    /**\n     * Mark the current release announcement as viewed and move to the next release announcement.\n     * This will update the account settings and emit the `releaseAnnouncementChanged` event\n     */\n    public async nextReleaseAnnouncement(): Promise<void> {\n        await this.markReleaseAnnouncementAsViewed();\n\n        this.emit(\"releaseAnnouncementChanged\", this.getReleaseAnnouncement());\n    }\n}\n"],"mappings":"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","ignoreList":[]}