UNPKG

matrix-react-sdk

Version:
116 lines (113 loc) 20 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = RoomTopic; exports.onRoomTopicLinkClick = onRoomTopicLinkClick; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _react = _interopRequireWildcard(require("react")); var _matrix = require("matrix-js-sdk/src/matrix"); var _classnames = _interopRequireDefault(require("classnames")); var _compoundWeb = require("@vector-im/compound-web"); var _useTopic = require("../../../hooks/room/useTopic"); var _languageHandler = require("../../../languageHandler"); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _actions = require("../../../dispatcher/actions"); var _Modal = _interopRequireDefault(require("../../../Modal")); var _InfoDialog = _interopRequireDefault(require("../dialogs/InfoDialog")); var _useDispatcher = require("../../../hooks/useDispatcher"); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton")); var _HtmlUtils = require("../../../HtmlUtils"); var _Permalinks = require("../../../utils/permalinks/Permalinks"); const _excluded = ["room", "className"]; /* Copyright 2024 New Vector Ltd. Copyright 2021, 2022 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. */ 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; } function onRoomTopicLinkClick(e) { const anchor = e.target; const localHref = (0, _Permalinks.tryTransformPermalinkToLocalHref)(anchor.href); if (localHref !== anchor.href) { // it could be converted to a localHref -> therefore handle locally e.preventDefault(); window.location.hash = localHref; } } function RoomTopic(_ref) { let { room, className } = _ref, props = (0, _objectWithoutProperties2.default)(_ref, _excluded); const client = (0, _react.useContext)(_MatrixClientContext.default); const [disableTooltip, setDisableTooltip] = (0, _react.useState)(false); const topic = (0, _useTopic.useTopic)(room); const body = (0, _HtmlUtils.topicToHtml)(topic?.text, topic?.html); const onClick = (0, _react.useCallback)(e => { props.onClick?.(e); const target = e.target; if (target.tagName.toUpperCase() !== "A") { _dispatcher.default.fire(_actions.Action.ShowRoomTopic); return; } onRoomTopicLinkClick(e); }, [props]); const onHover = ev => { setDisableTooltip(ev.target.tagName.toUpperCase() === "A"); }; (0, _useDispatcher.useDispatcher)(_dispatcher.default, payload => { if (payload.action === _actions.Action.ShowRoomTopic) { const canSetTopic = room.currentState.maySendStateEvent(_matrix.EventType.RoomTopic, client.getSafeUserId()); const body = (0, _HtmlUtils.topicToHtml)(topic?.text, topic?.html, undefined, true); const modal = _Modal.default.createDialog(_InfoDialog.default, { title: room.name, description: /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_HtmlUtils.Linkify, { options: { attributes: { onClick(e) { onClick(e); modal.close(); } } }, as: "p" }, body), canSetTopic && /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "primary_outline", onClick: () => { modal.close(); _dispatcher.default.dispatch({ action: "open_room_settings" }); } }, (0, _languageHandler._t)("room|edit_topic"))), hasCloseButton: true, button: false }); } }); // Do not render the tooltip if the topic is empty // We still need to have a div for the header buttons to be displayed correctly if (!body) return /*#__PURE__*/_react.default.createElement("div", { className: (0, _classnames.default)(className, "mx_RoomTopic") }); return /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, { description: (0, _languageHandler._t)("room|read_topic"), disabled: disableTooltip }, /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, props, { tabIndex: 0, role: "button", onClick: onClick, className: (0, _classnames.default)(className, "mx_RoomTopic"), onMouseOver: onHover, onFocus: onHover, "aria-label": (0, _languageHandler._t)("room|read_topic") }), /*#__PURE__*/_react.default.createElement(_HtmlUtils.Linkify, null, body))); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_classnames","_interopRequireDefault","_compoundWeb","_useTopic","_languageHandler","_dispatcher","_actions","_Modal","_InfoDialog","_useDispatcher","_MatrixClientContext","_AccessibleButton","_HtmlUtils","_Permalinks","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","onRoomTopicLinkClick","anchor","target","localHref","tryTransformPermalinkToLocalHref","href","preventDefault","window","location","hash","RoomTopic","_ref","room","className","props","_objectWithoutProperties2","client","useContext","MatrixClientContext","disableTooltip","setDisableTooltip","useState","topic","useTopic","body","topicToHtml","text","html","onClick","useCallback","tagName","toUpperCase","dis","fire","Action","ShowRoomTopic","onHover","ev","useDispatcher","payload","action","canSetTopic","currentState","maySendStateEvent","EventType","getSafeUserId","undefined","modal","Modal","createDialog","InfoDialog","title","name","description","createElement","Linkify","options","attributes","close","as","kind","dispatch","_t","hasCloseButton","button","classNames","Tooltip","disabled","_extends2","tabIndex","role","onMouseOver","onFocus"],"sources":["../../../../src/components/views/elements/RoomTopic.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021, 2022 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { useCallback, useContext, useState } from \"react\";\nimport { Room, EventType } from \"matrix-js-sdk/src/matrix\";\nimport classNames from \"classnames\";\nimport { Tooltip } from \"@vector-im/compound-web\";\n\nimport { useTopic } from \"../../../hooks/room/useTopic\";\nimport { _t } from \"../../../languageHandler\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport Modal from \"../../../Modal\";\nimport InfoDialog from \"../dialogs/InfoDialog\";\nimport { useDispatcher } from \"../../../hooks/useDispatcher\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport AccessibleButton from \"./AccessibleButton\";\nimport { Linkify, topicToHtml } from \"../../../HtmlUtils\";\nimport { tryTransformPermalinkToLocalHref } from \"../../../utils/permalinks/Permalinks\";\n\ninterface IProps extends React.HTMLProps<HTMLDivElement> {\n    room: Room;\n}\n\nexport function onRoomTopicLinkClick(e: React.MouseEvent): void {\n    const anchor = e.target as HTMLLinkElement;\n    const localHref = tryTransformPermalinkToLocalHref(anchor.href);\n\n    if (localHref !== anchor.href) {\n        // it could be converted to a localHref -> therefore handle locally\n        e.preventDefault();\n        window.location.hash = localHref;\n    }\n}\n\nexport default function RoomTopic({ room, className, ...props }: IProps): JSX.Element {\n    const client = useContext(MatrixClientContext);\n    const [disableTooltip, setDisableTooltip] = useState(false);\n\n    const topic = useTopic(room);\n    const body = topicToHtml(topic?.text, topic?.html);\n\n    const onClick = useCallback(\n        (e: React.MouseEvent<HTMLDivElement>) => {\n            props.onClick?.(e);\n\n            const target = e.target as HTMLElement;\n\n            if (target.tagName.toUpperCase() !== \"A\") {\n                dis.fire(Action.ShowRoomTopic);\n                return;\n            }\n\n            onRoomTopicLinkClick(e);\n        },\n        [props],\n    );\n\n    const onHover = (ev: React.MouseEvent | React.FocusEvent): void => {\n        setDisableTooltip((ev.target as HTMLElement).tagName.toUpperCase() === \"A\");\n    };\n\n    useDispatcher(dis, (payload) => {\n        if (payload.action === Action.ShowRoomTopic) {\n            const canSetTopic = room.currentState.maySendStateEvent(EventType.RoomTopic, client.getSafeUserId());\n            const body = topicToHtml(topic?.text, topic?.html, undefined, true);\n\n            const modal = Modal.createDialog(InfoDialog, {\n                title: room.name,\n                description: (\n                    <div>\n                        <Linkify\n                            options={{\n                                attributes: {\n                                    onClick(e: React.MouseEvent<HTMLDivElement>) {\n                                        onClick(e);\n                                        modal.close();\n                                    },\n                                },\n                            }}\n                            as=\"p\"\n                        >\n                            {body}\n                        </Linkify>\n                        {canSetTopic && (\n                            <AccessibleButton\n                                kind=\"primary_outline\"\n                                onClick={() => {\n                                    modal.close();\n                                    dis.dispatch({ action: \"open_room_settings\" });\n                                }}\n                            >\n                                {_t(\"room|edit_topic\")}\n                            </AccessibleButton>\n                        )}\n                    </div>\n                ),\n                hasCloseButton: true,\n                button: false,\n            });\n        }\n    });\n\n    // Do not render the tooltip if the topic is empty\n    // We still need to have a div for the header buttons to be displayed correctly\n    if (!body) return <div className={classNames(className, \"mx_RoomTopic\")} />;\n\n    return (\n        <Tooltip description={_t(\"room|read_topic\")} disabled={disableTooltip}>\n            <div\n                {...props}\n                tabIndex={0}\n                role=\"button\"\n                onClick={onClick}\n                className={classNames(className, \"mx_RoomTopic\")}\n                onMouseOver={onHover}\n                onFocus={onHover}\n                aria-label={_t(\"room|read_topic\")}\n            >\n                <Linkify>{body}</Linkify>\n            </div>\n        </Tooltip>\n    );\n}\n"],"mappings":"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","ignoreList":[]}