UNPKG

matrix-react-sdk

Version:
324 lines (251 loc) 36.1 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _utils = require("flux/utils"); var _dispatcher = _interopRequireDefault(require("../dispatcher/dispatcher")); var _GroupStore = _interopRequireDefault(require("./GroupStore")); var _Analytics = _interopRequireDefault(require("../Analytics")); var RoomNotifs = _interopRequireWildcard(require("../RoomNotifs")); var _MatrixClientPeg = require("../MatrixClientPeg"); var _SettingsStore = _interopRequireDefault(require("../settings/SettingsStore")); /* Copyright 2017 New Vector Ltd Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ const INITIAL_STATE = { orderedTags: null, orderedTagsAccountData: null, hasSynced: false, joinedGroupIds: null, selectedTags: [], // Last selected tag when shift was not being pressed anchorTag: null }; /** * A class for storing application state for ordering tags in the GroupFilterPanel. */ class GroupFilterOrderStore extends _utils.Store { constructor() { super(_dispatcher.default); // Initialise state this._state = Object.assign({}, INITIAL_STATE); _SettingsStore.default.monitorSetting("TagPanel.enableTagPanel", null); } _setState(newState) { this._state = Object.assign(this._state, newState); this.__emitChange(); } __onDispatch(payload) { switch (payload.action) { // Initialise state after initial sync case 'view_room': { const relatedGroupIds = _GroupStore.default.getGroupIdsForRoomId(payload.room_id); this._updateBadges(relatedGroupIds); break; } case 'MatrixActions.sync': { if (payload.state === 'SYNCING' || payload.state === 'PREPARED') { this._updateBadges(); } if (!(payload.prevState !== 'PREPARED' && payload.state === 'PREPARED')) { break; } const tagOrderingEvent = payload.matrixClient.getAccountData('im.vector.web.tag_ordering'); const tagOrderingEventContent = tagOrderingEvent ? tagOrderingEvent.getContent() : {}; this._setState({ orderedTagsAccountData: tagOrderingEventContent.tags || null, removedTagsAccountData: tagOrderingEventContent.removedTags || null, hasSynced: true }); this._updateOrderedTags(); break; } // Get ordering from account data case 'MatrixActions.accountData': { if (payload.event_type !== 'im.vector.web.tag_ordering') break; // Ignore remote echos caused by this store so as to avoid setting // state back to old state. if (payload.event_content._storeId === this.getStoreId()) break; this._setState({ orderedTagsAccountData: payload.event_content ? payload.event_content.tags : null, removedTagsAccountData: payload.event_content ? payload.event_content.removedTags : null }); this._updateOrderedTags(); break; } // Initialise the state such that if account data is unset, default to joined groups case 'GroupActions.fetchJoinedGroups.success': { this._setState({ joinedGroupIds: payload.result.groups.sort(), // Sort lexically hasFetchedJoinedGroups: true }); this._updateOrderedTags(); break; } case 'TagOrderActions.moveTag.pending': { // Optimistic update of a moved tag this._setState({ orderedTags: payload.request.tags, removedTagsAccountData: payload.request.removedTags }); break; } case 'TagOrderActions.removeTag.pending': { // Optimistic update of a removed tag this._setState({ removedTagsAccountData: payload.request.removedTags }); this._updateOrderedTags(); break; } case 'select_tag': { const allowMultiple = !_SettingsStore.default.getValue("feature_communities_v2_prototypes"); let newTags = []; // Shift-click semantics if (payload.shiftKey && allowMultiple) { // Select range of tags let start = this._state.orderedTags.indexOf(this._state.anchorTag); let end = this._state.orderedTags.indexOf(payload.tag); if (start === -1) { start = end; } if (start > end) { const temp = start; start = end; end = temp; } newTags = payload.ctrlOrCmdKey ? this._state.selectedTags : []; newTags = [...new Set(this._state.orderedTags.slice(start, end + 1).concat(newTags))]; } else { if (payload.ctrlOrCmdKey && allowMultiple) { // Toggle individual tag if (this._state.selectedTags.includes(payload.tag)) { newTags = this._state.selectedTags.filter(t => t !== payload.tag); } else { newTags = [...this._state.selectedTags, payload.tag]; } } else { if (this._state.selectedTags.length === 1 && this._state.selectedTags.includes(payload.tag)) { // Existing (only) selected tag is being normally clicked again, clear tags newTags = []; } else { // Select individual tag newTags = [payload.tag]; } } // Only set the anchor tag if the tag was previously unselected, otherwise // the next range starts with an unselected tag. if (!this._state.selectedTags.includes(payload.tag)) { this._setState({ anchorTag: payload.tag }); } } this._setState({ selectedTags: newTags }); _Analytics.default.trackEvent('FilterStore', 'select_tag'); } break; case 'deselect_tags': if (payload.tag) { // if a tag is passed, only deselect that tag this._setState({ selectedTags: this._state.selectedTags.filter(tag => tag !== payload.tag) }); } else { this._setState({ selectedTags: [] }); } _Analytics.default.trackEvent('FilterStore', 'deselect_tags'); break; case 'on_client_not_viable': case 'on_logged_out': { // Reset state without pushing an update to the view, which generally assumes that // the matrix client isn't `null` and so causing a re-render will cause NPEs. this._state = Object.assign({}, INITIAL_STATE); break; } case 'setting_updated': if (payload.settingName === 'TagPanel.enableTagPanel' && !payload.newValue) { this._setState({ selectedTags: [] }); _Analytics.default.trackEvent('FilterStore', 'disable_tags'); } break; } } _updateBadges(groupIds = this._state.joinedGroupIds) { if (groupIds && groupIds.length) { const client = _MatrixClientPeg.MatrixClientPeg.get(); const changedBadges = {}; groupIds.forEach(groupId => { const rooms = _GroupStore.default.getGroupRooms(groupId).map(r => client.getRoom(r.roomId)) // to Room objects .filter(r => r !== null && r !== undefined); // filter out rooms we haven't joined from the group const badge = rooms && RoomNotifs.aggregateNotificationCount(rooms); changedBadges[groupId] = badge && badge.count !== 0 ? badge : undefined; }); const newBadges = Object.assign({}, this._state.badges, changedBadges); this._setState({ badges: newBadges }); } } _updateOrderedTags() { this._setState({ orderedTags: this._state.hasSynced && this._state.hasFetchedJoinedGroups ? this._mergeGroupsAndTags() : null }); } _mergeGroupsAndTags() { const groupIds = this._state.joinedGroupIds || []; const tags = this._state.orderedTagsAccountData || []; const removedTags = new Set(this._state.removedTagsAccountData || []); const tagsToKeep = tags.filter(t => (t[0] !== '+' || groupIds.includes(t)) && !removedTags.has(t)); const groupIdsToAdd = groupIds.filter(groupId => !tags.includes(groupId) && !removedTags.has(groupId)); return tagsToKeep.concat(groupIdsToAdd); } getGroupBadge(groupId) { const badges = this._state.badges; return badges && badges[groupId]; } getOrderedTags() { return this._state.orderedTags; } getRemovedTagsAccountData() { return this._state.removedTagsAccountData; } getStoreId() { // Generate a random ID to prevent this store from clobbering its // state with redundant remote echos. if (!this._id) this._id = Math.random().toString(16).slice(2, 10); return this._id; } getSelectedTags() { return this._state.selectedTags; } } if (global.singletonGroupFilterOrderStore === undefined) { global.singletonGroupFilterOrderStore = new GroupFilterOrderStore(); } var _default = global.singletonGroupFilterOrderStore; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/stores/GroupFilterOrderStore.js"],"names":["INITIAL_STATE","orderedTags","orderedTagsAccountData","hasSynced","joinedGroupIds","selectedTags","anchorTag","GroupFilterOrderStore","Store","constructor","dis","_state","Object","assign","SettingsStore","monitorSetting","_setState","newState","__emitChange","__onDispatch","payload","action","relatedGroupIds","GroupStore","getGroupIdsForRoomId","room_id","_updateBadges","state","prevState","tagOrderingEvent","matrixClient","getAccountData","tagOrderingEventContent","getContent","tags","removedTagsAccountData","removedTags","_updateOrderedTags","event_type","event_content","_storeId","getStoreId","result","groups","sort","hasFetchedJoinedGroups","request","allowMultiple","getValue","newTags","shiftKey","start","indexOf","end","tag","temp","ctrlOrCmdKey","Set","slice","concat","includes","filter","t","length","Analytics","trackEvent","settingName","newValue","groupIds","client","MatrixClientPeg","get","changedBadges","forEach","groupId","rooms","getGroupRooms","map","r","getRoom","roomId","undefined","badge","RoomNotifs","aggregateNotificationCount","count","newBadges","badges","_mergeGroupsAndTags","tagsToKeep","has","groupIdsToAdd","getGroupBadge","getOrderedTags","getRemovedTagsAccountData","_id","Math","random","toString","getSelectedTags","global","singletonGroupFilterOrderStore"],"mappings":"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","sourcesContent":["/*\nCopyright 2017 New Vector Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\nimport {Store} from 'flux/utils';\nimport dis from '../dispatcher/dispatcher';\nimport GroupStore from './GroupStore';\nimport Analytics from '../Analytics';\nimport * as RoomNotifs from \"../RoomNotifs\";\nimport {MatrixClientPeg} from '../MatrixClientPeg';\nimport SettingsStore from \"../settings/SettingsStore\";\n\nconst INITIAL_STATE = {\n    orderedTags: null,\n    orderedTagsAccountData: null,\n    hasSynced: false,\n    joinedGroupIds: null,\n\n    selectedTags: [],\n    // Last selected tag when shift was not being pressed\n    anchorTag: null,\n};\n\n/**\n * A class for storing application state for ordering tags in the GroupFilterPanel.\n */\nclass GroupFilterOrderStore extends Store {\n    constructor() {\n        super(dis);\n\n        // Initialise state\n        this._state = Object.assign({}, INITIAL_STATE);\n        SettingsStore.monitorSetting(\"TagPanel.enableTagPanel\", null);\n    }\n\n    _setState(newState) {\n        this._state = Object.assign(this._state, newState);\n        this.__emitChange();\n    }\n\n    __onDispatch(payload) {\n        switch (payload.action) {\n            // Initialise state after initial sync\n            case 'view_room': {\n                const relatedGroupIds = GroupStore.getGroupIdsForRoomId(payload.room_id);\n                this._updateBadges(relatedGroupIds);\n                break;\n            }\n            case 'MatrixActions.sync': {\n                if (payload.state === 'SYNCING' || payload.state === 'PREPARED') {\n                    this._updateBadges();\n                }\n                if (!(payload.prevState !== 'PREPARED' && payload.state === 'PREPARED')) {\n                    break;\n                }\n                const tagOrderingEvent = payload.matrixClient.getAccountData('im.vector.web.tag_ordering');\n                const tagOrderingEventContent = tagOrderingEvent ? tagOrderingEvent.getContent() : {};\n                this._setState({\n                    orderedTagsAccountData: tagOrderingEventContent.tags || null,\n                    removedTagsAccountData: tagOrderingEventContent.removedTags || null,\n                    hasSynced: true,\n                });\n                this._updateOrderedTags();\n                break;\n            }\n            // Get ordering from account data\n            case 'MatrixActions.accountData': {\n                if (payload.event_type !== 'im.vector.web.tag_ordering') break;\n\n                // Ignore remote echos caused by this store so as to avoid setting\n                // state back to old state.\n                if (payload.event_content._storeId === this.getStoreId()) break;\n\n                this._setState({\n                    orderedTagsAccountData: payload.event_content ? payload.event_content.tags : null,\n                    removedTagsAccountData: payload.event_content ? payload.event_content.removedTags : null,\n                });\n                this._updateOrderedTags();\n                break;\n            }\n            // Initialise the state such that if account data is unset, default to joined groups\n            case 'GroupActions.fetchJoinedGroups.success': {\n                this._setState({\n                    joinedGroupIds: payload.result.groups.sort(), // Sort lexically\n                    hasFetchedJoinedGroups: true,\n                });\n                this._updateOrderedTags();\n                break;\n            }\n            case 'TagOrderActions.moveTag.pending': {\n                // Optimistic update of a moved tag\n                this._setState({\n                    orderedTags: payload.request.tags,\n                    removedTagsAccountData: payload.request.removedTags,\n                });\n                break;\n            }\n            case 'TagOrderActions.removeTag.pending': {\n                // Optimistic update of a removed tag\n                this._setState({\n                    removedTagsAccountData: payload.request.removedTags,\n                });\n                this._updateOrderedTags();\n                break;\n            }\n            case 'select_tag': {\n                const allowMultiple = !SettingsStore.getValue(\"feature_communities_v2_prototypes\");\n\n                let newTags = [];\n                // Shift-click semantics\n                if (payload.shiftKey && allowMultiple) {\n                    // Select range of tags\n                    let start = this._state.orderedTags.indexOf(this._state.anchorTag);\n                    let end = this._state.orderedTags.indexOf(payload.tag);\n\n                    if (start === -1) {\n                        start = end;\n                    }\n                    if (start > end) {\n                        const temp = start;\n                        start = end;\n                        end = temp;\n                    }\n                    newTags = payload.ctrlOrCmdKey ? this._state.selectedTags : [];\n                    newTags = [...new Set(\n                        this._state.orderedTags.slice(start, end + 1).concat(newTags),\n                    )];\n                } else {\n                    if (payload.ctrlOrCmdKey && allowMultiple) {\n                        // Toggle individual tag\n                        if (this._state.selectedTags.includes(payload.tag)) {\n                            newTags = this._state.selectedTags.filter((t) => t !== payload.tag);\n                        } else {\n                            newTags = [...this._state.selectedTags, payload.tag];\n                        }\n                    } else {\n                        if (this._state.selectedTags.length === 1 && this._state.selectedTags.includes(payload.tag)) {\n                            // Existing (only) selected tag is being normally clicked again, clear tags\n                            newTags = [];\n                        } else {\n                            // Select individual tag\n                            newTags = [payload.tag];\n                        }\n                    }\n                    // Only set the anchor tag if the tag was previously unselected, otherwise\n                    // the next range starts with an unselected tag.\n                    if (!this._state.selectedTags.includes(payload.tag)) {\n                        this._setState({\n                            anchorTag: payload.tag,\n                        });\n                    }\n                }\n\n                this._setState({\n                    selectedTags: newTags,\n                });\n\n                Analytics.trackEvent('FilterStore', 'select_tag');\n            }\n                break;\n            case 'deselect_tags':\n                if (payload.tag) {\n                    // if a tag is passed, only deselect that tag\n                    this._setState({\n                        selectedTags: this._state.selectedTags.filter(tag => tag !== payload.tag),\n                    });\n                } else {\n                    this._setState({\n                        selectedTags: [],\n                    });\n                }\n                Analytics.trackEvent('FilterStore', 'deselect_tags');\n                break;\n            case 'on_client_not_viable':\n            case 'on_logged_out': {\n                // Reset state without pushing an update to the view, which generally assumes that\n                // the matrix client isn't `null` and so causing a re-render will cause NPEs.\n                this._state = Object.assign({}, INITIAL_STATE);\n                break;\n            }\n            case 'setting_updated':\n                if (payload.settingName === 'TagPanel.enableTagPanel' && !payload.newValue) {\n                    this._setState({\n                        selectedTags: [],\n                    });\n                    Analytics.trackEvent('FilterStore', 'disable_tags');\n                }\n                break;\n        }\n    }\n\n    _updateBadges(groupIds = this._state.joinedGroupIds) {\n        if (groupIds && groupIds.length) {\n            const client = MatrixClientPeg.get();\n            const changedBadges = {};\n            groupIds.forEach(groupId => {\n                const rooms =\n                    GroupStore.getGroupRooms(groupId)\n                        .map(r => client.getRoom(r.roomId)) // to Room objects\n                        .filter(r => r !== null && r !== undefined);   // filter out rooms we haven't joined from the group\n                const badge = rooms && RoomNotifs.aggregateNotificationCount(rooms);\n                changedBadges[groupId] = (badge && badge.count !== 0) ? badge : undefined;\n            });\n            const newBadges = Object.assign({}, this._state.badges, changedBadges);\n            this._setState({badges: newBadges});\n        }\n    }\n\n    _updateOrderedTags() {\n        this._setState({\n            orderedTags:\n                this._state.hasSynced &&\n                this._state.hasFetchedJoinedGroups ?\n                    this._mergeGroupsAndTags() : null,\n        });\n    }\n\n    _mergeGroupsAndTags() {\n        const groupIds = this._state.joinedGroupIds || [];\n        const tags = this._state.orderedTagsAccountData || [];\n        const removedTags = new Set(this._state.removedTagsAccountData || []);\n\n\n        const tagsToKeep = tags.filter(\n            (t) => (t[0] !== '+' || groupIds.includes(t)) && !removedTags.has(t),\n        );\n\n        const groupIdsToAdd = groupIds.filter(\n            (groupId) => !tags.includes(groupId) && !removedTags.has(groupId),\n        );\n\n        return tagsToKeep.concat(groupIdsToAdd);\n    }\n\n    getGroupBadge(groupId) {\n        const badges = this._state.badges;\n        return badges && badges[groupId];\n    }\n\n    getOrderedTags() {\n        return this._state.orderedTags;\n    }\n\n    getRemovedTagsAccountData() {\n        return this._state.removedTagsAccountData;\n    }\n\n    getStoreId() {\n        // Generate a random ID to prevent this store from clobbering its\n        // state with redundant remote echos.\n        if (!this._id) this._id = Math.random().toString(16).slice(2, 10);\n        return this._id;\n    }\n\n    getSelectedTags() {\n        return this._state.selectedTags;\n    }\n}\n\nif (global.singletonGroupFilterOrderStore === undefined) {\n    global.singletonGroupFilterOrderStore = new GroupFilterOrderStore();\n}\nexport default global.singletonGroupFilterOrderStore;\n"]}