UNPKG

matrix-react-sdk

Version:
112 lines (108 loc) 18.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.MPollEndBody = void 0; 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 _logger = require("matrix-js-sdk/src/logger"); var _poll = require("../../../../res/img/element-icons/room/composer/poll.svg"); var _MatrixClientContext = _interopRequireWildcard(require("../../../contexts/MatrixClientContext")); var _languageHandler = require("../../../languageHandler"); var _TextForEvent = require("../../../TextForEvent"); var _Caption = require("../typography/Caption"); var _MPollBody = _interopRequireDefault(require("./MPollBody")); const _excluded = ["mxEvent"]; /* Copyright 2024 New Vector Ltd. Copyright 2023 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; } const getRelatedPollStartEventId = event => { const relation = event.getRelation(); return relation?.event_id; }; /** * Attempt to retrieve the related poll start event for this end event * If the event already exists in the rooms timeline, return it * Otherwise try to fetch the event from the server * @param event * @returns */ const usePollStartEvent = event => { const matrixClient = (0, _react.useContext)(_MatrixClientContext.default); const [pollStartEvent, setPollStartEvent] = (0, _react.useState)(); const [isLoadingPollStartEvent, setIsLoadingPollStartEvent] = (0, _react.useState)(false); const pollStartEventId = getRelatedPollStartEventId(event); (0, _react.useEffect)(() => { const room = matrixClient.getRoom(event.getRoomId()); const fetchPollStartEvent = async (roomId, pollStartEventId) => { setIsLoadingPollStartEvent(true); try { const startEventJson = await matrixClient.fetchRoomEvent(roomId, pollStartEventId); const startEvent = new _matrix.MatrixEvent(startEventJson); // add the poll to the room polls state room?.processPollEvents([startEvent, event]); // end event is not a valid end to the related start event // if not sent by the same user if (startEvent.getSender() === event.getSender()) { setPollStartEvent(startEvent); } } catch (error) { _logger.logger.error("Failed to fetch related poll start event", error); } finally { setIsLoadingPollStartEvent(false); } }; if (pollStartEvent || !room || !pollStartEventId) { return; } const timelineSet = room.getUnfilteredTimelineSet(); const localEvent = timelineSet?.getTimelineForEvent(pollStartEventId)?.getEvents().find(e => e.getId() === pollStartEventId); if (localEvent) { // end event is not a valid end to the related start event // if not sent by the same user if (localEvent.getSender() === event.getSender()) { setPollStartEvent(localEvent); } } else { // pollStartEvent is not in the current timeline, // fetch it fetchPollStartEvent(room.roomId, pollStartEventId); } }, [event, pollStartEventId, pollStartEvent, matrixClient]); return { pollStartEvent, isLoadingPollStartEvent }; }; const MPollEndBody = exports.MPollEndBody = /*#__PURE__*/_react.default.forwardRef((_ref, ref) => { let { mxEvent } = _ref, props = (0, _objectWithoutProperties2.default)(_ref, _excluded); const cli = (0, _MatrixClientContext.useMatrixClientContext)(); const { pollStartEvent, isLoadingPollStartEvent } = usePollStartEvent(mxEvent); if (!pollStartEvent) { const pollEndFallbackMessage = _matrix.M_TEXT.findIn(mxEvent.getContent()) || (0, _TextForEvent.textForEvent)(mxEvent, cli); return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_poll.Icon, { className: "mx_MPollEndBody_icon" }), !isLoadingPollStartEvent && pollEndFallbackMessage); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_MPollEndBody", ref: ref }, /*#__PURE__*/_react.default.createElement(_Caption.Caption, null, (0, _languageHandler._t)("timeline|m.poll.end|ended")), /*#__PURE__*/_react.default.createElement(_MPollBody.default, (0, _extends2.default)({ mxEvent: pollStartEvent }, props))); }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_logger","_poll","_MatrixClientContext","_languageHandler","_TextForEvent","_Caption","_MPollBody","_interopRequireDefault","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","getRelatedPollStartEventId","event","relation","getRelation","event_id","usePollStartEvent","matrixClient","useContext","MatrixClientContext","pollStartEvent","setPollStartEvent","useState","isLoadingPollStartEvent","setIsLoadingPollStartEvent","pollStartEventId","useEffect","room","getRoom","getRoomId","fetchPollStartEvent","roomId","startEventJson","fetchRoomEvent","startEvent","MatrixEvent","processPollEvents","getSender","error","logger","timelineSet","getUnfilteredTimelineSet","localEvent","getTimelineForEvent","getEvents","find","getId","MPollEndBody","exports","React","forwardRef","_ref","ref","mxEvent","props","_objectWithoutProperties2","cli","useMatrixClientContext","pollEndFallbackMessage","M_TEXT","findIn","getContent","textForEvent","createElement","Fragment","Icon","className","Caption","_t","_extends2"],"sources":["../../../../src/components/views/messages/MPollEndBody.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2023 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, { useEffect, useState, useContext, ForwardRefExoticComponent } from \"react\";\nimport { MatrixEvent, M_TEXT } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport { Icon as PollIcon } from \"../../../../res/img/element-icons/room/composer/poll.svg\";\nimport MatrixClientContext, { useMatrixClientContext } from \"../../../contexts/MatrixClientContext\";\nimport { _t } from \"../../../languageHandler\";\nimport { textForEvent } from \"../../../TextForEvent\";\nimport { Caption } from \"../typography/Caption\";\nimport { IBodyProps } from \"./IBodyProps\";\nimport MPollBody from \"./MPollBody\";\n\nconst getRelatedPollStartEventId = (event: MatrixEvent): string | undefined => {\n    const relation = event.getRelation();\n    return relation?.event_id;\n};\n\n/**\n * Attempt to retrieve the related poll start event for this end event\n * If the event already exists in the rooms timeline, return it\n * Otherwise try to fetch the event from the server\n * @param event\n * @returns\n */\nconst usePollStartEvent = (event: MatrixEvent): { pollStartEvent?: MatrixEvent; isLoadingPollStartEvent: boolean } => {\n    const matrixClient = useContext(MatrixClientContext);\n    const [pollStartEvent, setPollStartEvent] = useState<MatrixEvent>();\n    const [isLoadingPollStartEvent, setIsLoadingPollStartEvent] = useState(false);\n\n    const pollStartEventId = getRelatedPollStartEventId(event);\n\n    useEffect(() => {\n        const room = matrixClient.getRoom(event.getRoomId());\n        const fetchPollStartEvent = async (roomId: string, pollStartEventId: string): Promise<void> => {\n            setIsLoadingPollStartEvent(true);\n            try {\n                const startEventJson = await matrixClient.fetchRoomEvent(roomId, pollStartEventId);\n                const startEvent = new MatrixEvent(startEventJson);\n                // add the poll to the room polls state\n                room?.processPollEvents([startEvent, event]);\n\n                // end event is not a valid end to the related start event\n                // if not sent by the same user\n                if (startEvent.getSender() === event.getSender()) {\n                    setPollStartEvent(startEvent);\n                }\n            } catch (error) {\n                logger.error(\"Failed to fetch related poll start event\", error);\n            } finally {\n                setIsLoadingPollStartEvent(false);\n            }\n        };\n\n        if (pollStartEvent || !room || !pollStartEventId) {\n            return;\n        }\n\n        const timelineSet = room.getUnfilteredTimelineSet();\n        const localEvent = timelineSet\n            ?.getTimelineForEvent(pollStartEventId)\n            ?.getEvents()\n            .find((e) => e.getId() === pollStartEventId);\n\n        if (localEvent) {\n            // end event is not a valid end to the related start event\n            // if not sent by the same user\n            if (localEvent.getSender() === event.getSender()) {\n                setPollStartEvent(localEvent);\n            }\n        } else {\n            // pollStartEvent is not in the current timeline,\n            // fetch it\n            fetchPollStartEvent(room.roomId, pollStartEventId);\n        }\n    }, [event, pollStartEventId, pollStartEvent, matrixClient]);\n\n    return { pollStartEvent, isLoadingPollStartEvent };\n};\n\nexport const MPollEndBody = React.forwardRef<any, IBodyProps>(({ mxEvent, ...props }, ref) => {\n    const cli = useMatrixClientContext();\n    const { pollStartEvent, isLoadingPollStartEvent } = usePollStartEvent(mxEvent);\n\n    if (!pollStartEvent) {\n        const pollEndFallbackMessage = M_TEXT.findIn(mxEvent.getContent()) || textForEvent(mxEvent, cli);\n        return (\n            <>\n                <PollIcon className=\"mx_MPollEndBody_icon\" />\n                {!isLoadingPollStartEvent && pollEndFallbackMessage}\n            </>\n        );\n    }\n\n    return (\n        <div className=\"mx_MPollEndBody\" ref={ref}>\n            <Caption>{_t(\"timeline|m.poll.end|ended\")}</Caption>\n            <MPollBody mxEvent={pollStartEvent} {...props} />\n        </div>\n    );\n}) as ForwardRefExoticComponent<IBodyProps>;\n"],"mappings":"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","ignoreList":[]}