matrix-react-sdk
Version:
SDK for matrix.org using React
146 lines (140 loc) • 26.5 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ThreadsActivityCentre = ThreadsActivityCentre;
var _react = _interopRequireWildcard(require("react"));
var _compoundWeb = require("@vector-im/compound-web");
var _ThreadsActivityCentreButton = require("./ThreadsActivityCentreButton");
var _languageHandler = require("../../../../languageHandler");
var _DecoratedRoomAvatar = _interopRequireDefault(require("../../avatars/DecoratedRoomAvatar"));
var _actions = require("../../../../dispatcher/actions");
var _dispatcher = _interopRequireDefault(require("../../../../dispatcher/dispatcher"));
var _RightPanelStore = _interopRequireDefault(require("../../../../stores/right-panel/RightPanelStore"));
var _RightPanelStorePhases = require("../../../../stores/right-panel/RightPanelStorePhases");
var _useUnreadThreadRooms = require("./useUnreadThreadRooms");
var _StatelessNotificationBadge = require("../../rooms/NotificationBadge/StatelessNotificationBadge");
var _PosthogTrackers = _interopRequireDefault(require("../../../../PosthogTrackers"));
var _KeyBindingsManager = require("../../../../KeyBindingsManager");
var _KeyboardShortcuts = require("../../../../accessibility/KeyboardShortcuts");
var _ReleaseAnnouncement = require("../../../structures/ReleaseAnnouncement");
var _useIsReleaseAnnouncementOpen = require("../../../../hooks/useIsReleaseAnnouncementOpen");
var _useSettings = require("../../../../hooks/useSettings");
var _ReleaseAnnouncementStore = require("../../../../stores/ReleaseAnnouncementStore");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
* 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.
*/
/**
* Display in a popup the list of rooms with unread threads.
* The popup is displayed when the user clicks on the `Threads` button.
*/
function ThreadsActivityCentre({
displayButtonLabel
}) {
const [open, setOpen] = (0, _react.useState)(false);
const roomsAndNotifications = (0, _useUnreadThreadRooms.useUnreadThreadRooms)(open);
const isReleaseAnnouncementOpen = (0, _useIsReleaseAnnouncementOpen.useIsReleaseAnnouncementOpen)("threadsActivityCentre");
const settingTACOnlyNotifs = (0, _useSettings.useSettingValue)("Notifications.tac_only_notifications");
const emptyCaption = settingTACOnlyNotifs ? (0, _languageHandler._t)("threads_activity_centre|no_rooms_with_threads_notifs") : (0, _languageHandler._t)("threads_activity_centre|no_rooms_with_unread_threads");
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadsActivityCentre_container",
onKeyDown: evt => {
// Do nothing if the TAC is closed
if (!open) return;
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getNavigationAction(evt);
// Block spotlight opening
if (action === _KeyboardShortcuts.KeyBindingAction.FilterRooms) {
evt.stopPropagation();
}
}
}, isReleaseAnnouncementOpen ? /*#__PURE__*/_react.default.createElement(_ReleaseAnnouncement.ReleaseAnnouncement, {
feature: "threadsActivityCentre",
header: (0, _languageHandler._t)("threads_activity_centre|release_announcement_header"),
description: (0, _languageHandler._t)("threads_activity_centre|release_announcement_description"),
closeLabel: (0, _languageHandler._t)("action|ok")
}, /*#__PURE__*/_react.default.createElement(_ThreadsActivityCentreButton.ThreadsActivityCentreButton, {
disableTooltip: true,
displayLabel: displayButtonLabel,
notificationLevel: roomsAndNotifications.greatestNotificationLevel,
onClick: async () => {
// Open the TAC after the release announcement closing
setOpen(true);
await _ReleaseAnnouncementStore.ReleaseAnnouncementStore.instance.nextReleaseAnnouncement();
}
})) : /*#__PURE__*/_react.default.createElement(_compoundWeb.Menu, {
align: "start",
side: "top",
open: open,
onOpenChange: newOpen => {
// Track only when the Threads Activity Centre is opened
if (newOpen) _PosthogTrackers.default.trackInteraction("WebThreadsActivityCentreButton");
setOpen(newOpen);
},
title: (0, _languageHandler._t)("threads_activity_centre|header"),
trigger: /*#__PURE__*/_react.default.createElement(_ThreadsActivityCentreButton.ThreadsActivityCentreButton, {
displayLabel: displayButtonLabel,
notificationLevel: roomsAndNotifications.greatestNotificationLevel
})
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadsActivityCentre_rows"
}, roomsAndNotifications.rooms.map(({
room,
notificationLevel
}) => /*#__PURE__*/_react.default.createElement(ThreadsActivityCentreRow, {
key: room.roomId,
room: room,
notificationLevel: notificationLevel,
onClick: () => setOpen(false)
})), roomsAndNotifications.rooms.length === 0 && /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ThreadsActivityCentre_emptyCaption"
}, emptyCaption))));
}
/**
* Display a room with unread threads.
*/
function ThreadsActivityCentreRow({
room,
onClick,
notificationLevel
}) {
return /*#__PURE__*/_react.default.createElement(_compoundWeb.MenuItem, {
className: "mx_ThreadsActivityCentreRow",
onSelect: event => {
onClick();
// Set the right panel card for that room so the threads panel is open before we dispatch,
// so it will open once the room appears.
_RightPanelStore.default.instance.setCard({
phase: _RightPanelStorePhases.RightPanelPhases.ThreadPanel
}, true, room.roomId);
// Track the click on the room
_PosthogTrackers.default.trackInteraction("WebThreadsActivityCentreRoomItem", event);
// Display the selected room in the timeline
_dispatcher.default.dispatch({
action: _actions.Action.ViewRoom,
show_room_tile: true,
// make sure the room is visible in the list
room_id: room.roomId,
metricsTrigger: "WebThreadsActivityCentre",
focusNext: "threadsPanel"
});
},
label: room.name,
Icon: /*#__PURE__*/_react.default.createElement(_DecoratedRoomAvatar.default, {
room: room,
size: "32px"
})
}, /*#__PURE__*/_react.default.createElement(_StatelessNotificationBadge.StatelessNotificationBadge, {
level: notificationLevel,
count: 0,
symbol: null,
forceDot: true
}));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_compoundWeb","_ThreadsActivityCentreButton","_languageHandler","_DecoratedRoomAvatar","_interopRequireDefault","_actions","_dispatcher","_RightPanelStore","_RightPanelStorePhases","_useUnreadThreadRooms","_StatelessNotificationBadge","_PosthogTrackers","_KeyBindingsManager","_KeyboardShortcuts","_ReleaseAnnouncement","_useIsReleaseAnnouncementOpen","_useSettings","_ReleaseAnnouncementStore","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ThreadsActivityCentre","displayButtonLabel","open","setOpen","useState","roomsAndNotifications","useUnreadThreadRooms","isReleaseAnnouncementOpen","useIsReleaseAnnouncementOpen","settingTACOnlyNotifs","useSettingValue","emptyCaption","_t","createElement","className","onKeyDown","evt","action","getKeyBindingsManager","getNavigationAction","KeyBindingAction","FilterRooms","stopPropagation","ReleaseAnnouncement","feature","header","description","closeLabel","ThreadsActivityCentreButton","disableTooltip","displayLabel","notificationLevel","greatestNotificationLevel","onClick","ReleaseAnnouncementStore","instance","nextReleaseAnnouncement","Menu","align","side","onOpenChange","newOpen","PosthogTrackers","trackInteraction","title","trigger","rooms","map","room","ThreadsActivityCentreRow","key","roomId","length","MenuItem","onSelect","event","RightPanelStore","setCard","phase","RightPanelPhases","ThreadPanel","defaultDispatcher","dispatch","Action","ViewRoom","show_room_tile","room_id","metricsTrigger","focusNext","label","name","Icon","size","StatelessNotificationBadge","level","count","symbol","forceDot"],"sources":["../../../../../src/components/views/spaces/threads-activity-centre/ThreadsActivityCentre.tsx"],"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 React, { JSX, useState } from \"react\";\nimport { Menu, MenuItem } from \"@vector-im/compound-web\";\nimport { Room } from \"matrix-js-sdk/src/matrix\";\n\nimport { ThreadsActivityCentreButton } from \"./ThreadsActivityCentreButton\";\nimport { _t } from \"../../../../languageHandler\";\nimport DecoratedRoomAvatar from \"../../avatars/DecoratedRoomAvatar\";\nimport { Action } from \"../../../../dispatcher/actions\";\nimport defaultDispatcher from \"../../../../dispatcher/dispatcher\";\nimport { ViewRoomPayload } from \"../../../../dispatcher/payloads/ViewRoomPayload\";\nimport RightPanelStore from \"../../../../stores/right-panel/RightPanelStore\";\nimport { RightPanelPhases } from \"../../../../stores/right-panel/RightPanelStorePhases\";\nimport { useUnreadThreadRooms } from \"./useUnreadThreadRooms\";\nimport { StatelessNotificationBadge } from \"../../rooms/NotificationBadge/StatelessNotificationBadge\";\nimport { NotificationLevel } from \"../../../../stores/notifications/NotificationLevel\";\nimport PosthogTrackers from \"../../../../PosthogTrackers\";\nimport { getKeyBindingsManager } from \"../../../../KeyBindingsManager\";\nimport { KeyBindingAction } from \"../../../../accessibility/KeyboardShortcuts\";\nimport { ReleaseAnnouncement } from \"../../../structures/ReleaseAnnouncement\";\nimport { useIsReleaseAnnouncementOpen } from \"../../../../hooks/useIsReleaseAnnouncementOpen\";\nimport { useSettingValue } from \"../../../../hooks/useSettings\";\nimport { ReleaseAnnouncementStore } from \"../../../../stores/ReleaseAnnouncementStore\";\n\ninterface ThreadsActivityCentreProps {\n    /**\n     * Display the `Treads` label next to the icon.\n     */\n    displayButtonLabel?: boolean;\n}\n\n/**\n * Display in a popup the list of rooms with unread threads.\n * The popup is displayed when the user clicks on the `Threads` button.\n */\nexport function ThreadsActivityCentre({ displayButtonLabel }: ThreadsActivityCentreProps): JSX.Element {\n    const [open, setOpen] = useState(false);\n    const roomsAndNotifications = useUnreadThreadRooms(open);\n    const isReleaseAnnouncementOpen = useIsReleaseAnnouncementOpen(\"threadsActivityCentre\");\n    const settingTACOnlyNotifs = useSettingValue<boolean>(\"Notifications.tac_only_notifications\");\n\n    const emptyCaption = settingTACOnlyNotifs\n        ? _t(\"threads_activity_centre|no_rooms_with_threads_notifs\")\n        : _t(\"threads_activity_centre|no_rooms_with_unread_threads\");\n\n    return (\n        <div\n            className=\"mx_ThreadsActivityCentre_container\"\n            onKeyDown={(evt) => {\n                // Do nothing if the TAC is closed\n                if (!open) return;\n\n                const action = getKeyBindingsManager().getNavigationAction(evt);\n\n                // Block spotlight opening\n                if (action === KeyBindingAction.FilterRooms) {\n                    evt.stopPropagation();\n                }\n            }}\n        >\n            {isReleaseAnnouncementOpen ? (\n                <ReleaseAnnouncement\n                    feature=\"threadsActivityCentre\"\n                    header={_t(\"threads_activity_centre|release_announcement_header\")}\n                    description={_t(\"threads_activity_centre|release_announcement_description\")}\n                    closeLabel={_t(\"action|ok\")}\n                >\n                    <ThreadsActivityCentreButton\n                        disableTooltip={true}\n                        displayLabel={displayButtonLabel}\n                        notificationLevel={roomsAndNotifications.greatestNotificationLevel}\n                        onClick={async () => {\n                            // Open the TAC after the release announcement closing\n                            setOpen(true);\n                            await ReleaseAnnouncementStore.instance.nextReleaseAnnouncement();\n                        }}\n                    />\n                </ReleaseAnnouncement>\n            ) : (\n                <Menu\n                    align=\"start\"\n                    side=\"top\"\n                    open={open}\n                    onOpenChange={(newOpen) => {\n                        // Track only when the Threads Activity Centre is opened\n                        if (newOpen) PosthogTrackers.trackInteraction(\"WebThreadsActivityCentreButton\");\n\n                        setOpen(newOpen);\n                    }}\n                    title={_t(\"threads_activity_centre|header\")}\n                    trigger={\n                        <ThreadsActivityCentreButton\n                            displayLabel={displayButtonLabel}\n                            notificationLevel={roomsAndNotifications.greatestNotificationLevel}\n                        />\n                    }\n                >\n                    {/* Make the content of the pop-up scrollable */}\n                    <div className=\"mx_ThreadsActivityCentre_rows\">\n                        {roomsAndNotifications.rooms.map(({ room, notificationLevel }) => (\n                            <ThreadsActivityCentreRow\n                                key={room.roomId}\n                                room={room}\n                                notificationLevel={notificationLevel}\n                                onClick={() => setOpen(false)}\n                            />\n                        ))}\n                        {roomsAndNotifications.rooms.length === 0 && (\n                            <div className=\"mx_ThreadsActivityCentre_emptyCaption\">{emptyCaption}</div>\n                        )}\n                    </div>\n                </Menu>\n            )}\n        </div>\n    );\n}\n\ninterface ThreadsActivityRow {\n    /**\n     * The room with unread threads.\n     */\n    room: Room;\n    /**\n     * The notification level.\n     */\n    notificationLevel: NotificationLevel;\n    /**\n     * Callback when the user clicks on the row.\n     */\n    onClick: () => void;\n}\n\n/**\n * Display a room with unread threads.\n */\nfunction ThreadsActivityCentreRow({ room, onClick, notificationLevel }: ThreadsActivityRow): JSX.Element {\n    return (\n        <MenuItem\n            className=\"mx_ThreadsActivityCentreRow\"\n            onSelect={(event: Event) => {\n                onClick();\n\n                // Set the right panel card for that room so the threads panel is open before we dispatch,\n                // so it will open once the room appears.\n                RightPanelStore.instance.setCard({ phase: RightPanelPhases.ThreadPanel }, true, room.roomId);\n\n                // Track the click on the room\n                PosthogTrackers.trackInteraction(\"WebThreadsActivityCentreRoomItem\", event);\n\n                // Display the selected room in the timeline\n                defaultDispatcher.dispatch<ViewRoomPayload>({\n                    action: Action.ViewRoom,\n                    show_room_tile: true, // make sure the room is visible in the list\n                    room_id: room.roomId,\n                    metricsTrigger: \"WebThreadsActivityCentre\",\n                    focusNext: \"threadsPanel\",\n                });\n            }}\n            label={room.name}\n            Icon={<DecoratedRoomAvatar room={room} size=\"32px\" />}\n        >\n            <StatelessNotificationBadge level={notificationLevel} count={0} symbol={null} forceDot={true} />\n        </MenuItem>\n    );\n}\n"],"mappings":"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","ignoreList":[]}