UNPKG

matrix-react-sdk

Version:
88 lines (85 loc) 16.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _matrix = require("matrix-js-sdk/src/matrix"); var _logger = require("matrix-js-sdk/src/logger"); var _close = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/close")); var _useStateToggle = require("../../../hooks/useStateToggle"); var _LinkPreviewWidget = _interopRequireDefault(require("./LinkPreviewWidget")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _languageHandler = require("../../../languageHandler"); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _useAsyncMemo = require("../../../hooks/useAsyncMemo"); 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 2021 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. */ const INITIAL_NUM_PREVIEWS = 2; const LinkPreviewGroup = ({ links, mxEvent, onCancelClick, onHeightChanged }) => { const cli = (0, _react.useContext)(_MatrixClientContext.default); const [expanded, toggleExpanded] = (0, _useStateToggle.useStateToggle)(); const ts = mxEvent.getTs(); const previews = (0, _useAsyncMemo.useAsyncMemo)(async () => { return fetchPreviews(cli, links, ts); }, [links, ts], []); (0, _react.useEffect)(() => { onHeightChanged?.(); }, [onHeightChanged, expanded, previews]); const showPreviews = expanded ? previews : previews.slice(0, INITIAL_NUM_PREVIEWS); let toggleButton; if (previews.length > INITIAL_NUM_PREVIEWS) { toggleButton = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: toggleExpanded }, expanded ? (0, _languageHandler._t)("action|collapse") : (0, _languageHandler._t)("timeline|url_preview|show_n_more", { count: previews.length - showPreviews.length })); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_LinkPreviewGroup" }, showPreviews.map(([link, preview], i) => /*#__PURE__*/_react.default.createElement(_LinkPreviewWidget.default, { key: link, link: link, preview: preview, mxEvent: mxEvent }, i === 0 ? /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_LinkPreviewGroup_hide", onClick: onCancelClick, "aria-label": (0, _languageHandler._t)("timeline|url_preview|close") }, /*#__PURE__*/_react.default.createElement(_close.default, { width: "20px", height: "20px" })) : undefined)), toggleButton); }; const fetchPreviews = (cli, links, ts) => { return Promise.all(links.map(async link => { try { const preview = await cli.getUrlPreview(link, ts); // Ensure at least one of the rendered fields is truthy if (preview?.["og:image"]?.startsWith("mxc://") || !!preview?.["og:description"] || !!preview?.["og:title"]) { return [link, preview]; } } catch (error) { if (error instanceof _matrix.MatrixError && error.httpStatus === 404) { // Quieten 404 Not found errors, not all URLs can have a preview generated _logger.logger.debug("Failed to get URL preview: ", error); } else { _logger.logger.error("Failed to get URL preview: ", error); } } })).then(a => a.filter(Boolean)); }; var _default = exports.default = LinkPreviewGroup; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_logger","_close","_interopRequireDefault","_useStateToggle","_LinkPreviewWidget","_AccessibleButton","_languageHandler","_MatrixClientContext","_useAsyncMemo","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","INITIAL_NUM_PREVIEWS","LinkPreviewGroup","links","mxEvent","onCancelClick","onHeightChanged","cli","useContext","MatrixClientContext","expanded","toggleExpanded","useStateToggle","ts","getTs","previews","useAsyncMemo","fetchPreviews","useEffect","showPreviews","slice","toggleButton","length","createElement","onClick","_t","count","className","map","link","preview","key","width","height","undefined","Promise","all","getUrlPreview","startsWith","error","MatrixError","httpStatus","logger","debug","then","filter","Boolean","_default","exports"],"sources":["../../../../src/components/views/rooms/LinkPreviewGroup.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 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, { useContext, useEffect } from \"react\";\nimport { MatrixEvent, MatrixError, IPreviewUrlResponse, MatrixClient } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport CloseIcon from \"@vector-im/compound-design-tokens/assets/web/icons/close\";\n\nimport { useStateToggle } from \"../../../hooks/useStateToggle\";\nimport LinkPreviewWidget from \"./LinkPreviewWidget\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { _t } from \"../../../languageHandler\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { useAsyncMemo } from \"../../../hooks/useAsyncMemo\";\n\nconst INITIAL_NUM_PREVIEWS = 2;\n\ninterface IProps {\n    links: string[]; // the URLs to be previewed\n    mxEvent: MatrixEvent; // the Event associated with the preview\n    onCancelClick(): void; // called when the preview's cancel ('hide') button is clicked\n    onHeightChanged?(): void; // called when the preview's contents has loaded\n}\n\nconst LinkPreviewGroup: React.FC<IProps> = ({ links, mxEvent, onCancelClick, onHeightChanged }) => {\n    const cli = useContext(MatrixClientContext);\n    const [expanded, toggleExpanded] = useStateToggle();\n\n    const ts = mxEvent.getTs();\n    const previews = useAsyncMemo<[string, IPreviewUrlResponse][]>(\n        async () => {\n            return fetchPreviews(cli, links, ts);\n        },\n        [links, ts],\n        [],\n    );\n\n    useEffect(() => {\n        onHeightChanged?.();\n    }, [onHeightChanged, expanded, previews]);\n\n    const showPreviews = expanded ? previews : previews.slice(0, INITIAL_NUM_PREVIEWS);\n\n    let toggleButton: JSX.Element | undefined;\n    if (previews.length > INITIAL_NUM_PREVIEWS) {\n        toggleButton = (\n            <AccessibleButton onClick={toggleExpanded}>\n                {expanded\n                    ? _t(\"action|collapse\")\n                    : _t(\"timeline|url_preview|show_n_more\", { count: previews.length - showPreviews.length })}\n            </AccessibleButton>\n        );\n    }\n\n    return (\n        <div className=\"mx_LinkPreviewGroup\">\n            {showPreviews.map(([link, preview], i) => (\n                <LinkPreviewWidget key={link} link={link} preview={preview} mxEvent={mxEvent}>\n                    {i === 0 ? (\n                        <AccessibleButton\n                            className=\"mx_LinkPreviewGroup_hide\"\n                            onClick={onCancelClick}\n                            aria-label={_t(\"timeline|url_preview|close\")}\n                        >\n                            <CloseIcon width=\"20px\" height=\"20px\" />\n                        </AccessibleButton>\n                    ) : undefined}\n                </LinkPreviewWidget>\n            ))}\n            {toggleButton}\n        </div>\n    );\n};\n\nconst fetchPreviews = (cli: MatrixClient, links: string[], ts: number): Promise<[string, IPreviewUrlResponse][]> => {\n    return Promise.all<[string, IPreviewUrlResponse] | void>(\n        links.map(async (link): Promise<[string, IPreviewUrlResponse] | undefined> => {\n            try {\n                const preview = await cli.getUrlPreview(link, ts);\n                // Ensure at least one of the rendered fields is truthy\n                if (\n                    preview?.[\"og:image\"]?.startsWith(\"mxc://\") ||\n                    !!preview?.[\"og:description\"] ||\n                    !!preview?.[\"og:title\"]\n                ) {\n                    return [link, preview];\n                }\n            } catch (error) {\n                if (error instanceof MatrixError && error.httpStatus === 404) {\n                    // Quieten 404 Not found errors, not all URLs can have a preview generated\n                    logger.debug(\"Failed to get URL preview: \", error);\n                } else {\n                    logger.error(\"Failed to get URL preview: \", error);\n                }\n            }\n        }),\n    ).then((a) => a.filter(Boolean)) as Promise<[string, IPreviewUrlResponse][]>;\n};\n\nexport default LinkPreviewGroup;\n"],"mappings":"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","ignoreList":[]}