UNPKG

matrix-react-sdk

Version:
205 lines (203 loc) 39.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _matrix = require("matrix-js-sdk/src/matrix"); var _types = require("matrix-js-sdk/src/types"); var _BaseCard = _interopRequireDefault(require("./BaseCard")); var _MessageComposer = _interopRequireDefault(require("../rooms/MessageComposer")); var _Layout = require("../../../settings/enums/Layout"); var _TimelinePanel = _interopRequireDefault(require("../../structures/TimelinePanel")); var _EditorStateTransfer = _interopRequireDefault(require("../../../utils/EditorStateTransfer")); var _RoomContext = _interopRequireDefault(require("../../../contexts/RoomContext")); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _languageHandler = require("../../../languageHandler"); var _actions = require("../../../dispatcher/actions"); var _ContentMessages = _interopRequireDefault(require("../../../ContentMessages")); var _UploadBar = _interopRequireDefault(require("../../structures/UploadBar")); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _JumpToBottomButton = _interopRequireDefault(require("../rooms/JumpToBottomButton")); var _Measured = _interopRequireDefault(require("../elements/Measured")); var _AsyncStore = require("../../../stores/AsyncStore"); var _SDKContext = require("../../../contexts/SDKContext"); function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /* 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. */ class TimelineCard extends _react.default.Component { constructor(props, context) { super(props, context); (0, _defineProperty2.default)(this, "dispatcherRef", void 0); (0, _defineProperty2.default)(this, "layoutWatcherRef", void 0); (0, _defineProperty2.default)(this, "timelinePanel", /*#__PURE__*/_react.default.createRef()); (0, _defineProperty2.default)(this, "card", /*#__PURE__*/_react.default.createRef()); (0, _defineProperty2.default)(this, "readReceiptsSettingWatcher", void 0); (0, _defineProperty2.default)(this, "onRoomViewStoreUpdate", async _initial => { const newState = { initialEventId: _SDKContext.SdkContextClass.instance.roomViewStore.getInitialEventId(), isInitialEventHighlighted: _SDKContext.SdkContextClass.instance.roomViewStore.isInitialEventHighlighted(), replyToEvent: _SDKContext.SdkContextClass.instance.roomViewStore.getQuotingEvent() }; this.setState(newState); }); (0, _defineProperty2.default)(this, "onAction", payload => { switch (payload.action) { case _actions.Action.EditEvent: this.setState({ editState: payload.event ? new _EditorStateTransfer.default(payload.event) : undefined }, () => { if (payload.event) { this.timelinePanel.current?.scrollToEventIfNeeded(payload.event.getId()); } }); break; default: break; } }); (0, _defineProperty2.default)(this, "onScroll", () => { const timelinePanel = this.timelinePanel.current; if (!timelinePanel) return; if (timelinePanel.isAtEndOfLiveTimeline()) { this.setState({ atEndOfLiveTimeline: true }); } else { this.setState({ atEndOfLiveTimeline: false }); } if (this.state.initialEventId && this.state.isInitialEventHighlighted) { _dispatcher.default.dispatch({ action: _actions.Action.ViewRoom, room_id: this.props.room.roomId, event_id: this.state.initialEventId, highlighted: false, replyingToEvent: this.state.replyToEvent, metricsTrigger: undefined // room doesn't change }); } }); (0, _defineProperty2.default)(this, "onMeasurement", narrow => { this.setState({ narrow }); }); (0, _defineProperty2.default)(this, "jumpToLiveTimeline", () => { if (this.state.initialEventId && this.state.isInitialEventHighlighted) { // If we were viewing a highlighted event, firing view_room without // an event will take care of both clearing the URL fragment and // jumping to the bottom _dispatcher.default.dispatch({ action: _actions.Action.ViewRoom, room_id: this.props.room.roomId }); } else { // Otherwise we have to jump manually this.timelinePanel.current?.jumpToLiveTimeline(); _dispatcher.default.fire(_actions.Action.FocusSendMessageComposer); } }); this.state = { showReadReceipts: _SettingsStore.default.getValue("showReadReceipts", props.room.roomId), layout: _SettingsStore.default.getValue("layout"), atEndOfLiveTimeline: true, narrow: false }; } componentDidMount() { _SDKContext.SdkContextClass.instance.roomViewStore.addListener(_AsyncStore.UPDATE_EVENT, this.onRoomViewStoreUpdate); this.dispatcherRef = _dispatcher.default.register(this.onAction); this.readReceiptsSettingWatcher = _SettingsStore.default.watchSetting("showReadReceipts", null, (...[,,, value]) => this.setState({ showReadReceipts: value })); this.layoutWatcherRef = _SettingsStore.default.watchSetting("layout", null, (...[,,, value]) => this.setState({ layout: value })); } componentWillUnmount() { _SDKContext.SdkContextClass.instance.roomViewStore.removeListener(_AsyncStore.UPDATE_EVENT, this.onRoomViewStoreUpdate); if (this.readReceiptsSettingWatcher) { _SettingsStore.default.unwatchSetting(this.readReceiptsSettingWatcher); } if (this.layoutWatcherRef) { _SettingsStore.default.unwatchSetting(this.layoutWatcherRef); } if (this.dispatcherRef) _dispatcher.default.unregister(this.dispatcherRef); } render() { const highlightedEventId = this.state.isInitialEventHighlighted ? this.state.initialEventId : undefined; let jumpToBottom; if (!this.state.atEndOfLiveTimeline) { jumpToBottom = /*#__PURE__*/_react.default.createElement(_JumpToBottomButton.default, { highlight: this.props.room.getUnreadNotificationCount(_matrix.NotificationCountType.Highlight) > 0, onScrollToBottomClick: this.jumpToLiveTimeline }); } const isUploading = _ContentMessages.default.sharedInstance().getCurrentUploads(this.props.composerRelation).length > 0; const myMembership = this.props.room.getMyMembership(); const showComposer = myMembership === _types.KnownMembership.Join; return /*#__PURE__*/_react.default.createElement(_RoomContext.default.Provider, { value: _objectSpread(_objectSpread({}, this.context), {}, { timelineRenderingType: this.props.timelineRenderingType ?? this.context.timelineRenderingType, liveTimeline: this.props.timelineSet?.getLiveTimeline(), narrow: this.state.narrow }) }, /*#__PURE__*/_react.default.createElement(_BaseCard.default, { className: this.props.classNames, onClose: this.props.onClose, withoutScrollContainer: true, header: (0, _languageHandler._t)("right_panel|video_room_chat|title"), ref: this.card }, this.card.current && /*#__PURE__*/_react.default.createElement(_Measured.default, { sensor: this.card.current, onMeasurement: this.onMeasurement }), /*#__PURE__*/_react.default.createElement("div", { className: "mx_TimelineCard_timeline" }, jumpToBottom, /*#__PURE__*/_react.default.createElement(_TimelinePanel.default, { ref: this.timelinePanel, showReadReceipts: this.state.showReadReceipts, manageReadReceipts: true, manageReadMarkers: false // No RM support in the TimelineCard , sendReadReceiptOnLoad: true, timelineSet: this.props.timelineSet, showUrlPreview: this.context.showUrlPreview // The right panel timeline (and therefore threads) don't support IRC layout at this time , layout: this.state.layout === _Layout.Layout.Bubble ? _Layout.Layout.Bubble : _Layout.Layout.Group, hideThreadedMessages: false, hidden: false, showReactions: true, className: "mx_RoomView_messagePanel", permalinkCreator: this.props.permalinkCreator, membersLoaded: true, editState: this.state.editState, eventId: this.state.initialEventId, resizeNotifier: this.props.resizeNotifier, highlightedEventId: highlightedEventId, onScroll: this.onScroll })), isUploading && /*#__PURE__*/_react.default.createElement(_UploadBar.default, { room: this.props.room, relation: this.props.composerRelation }), showComposer && /*#__PURE__*/_react.default.createElement(_MessageComposer.default, { room: this.props.room, relation: this.props.composerRelation, resizeNotifier: this.props.resizeNotifier, replyToEvent: this.state.replyToEvent, permalinkCreator: this.props.permalinkCreator, e2eStatus: this.props.e2eStatus, compact: true }))); } } exports.default = TimelineCard; (0, _defineProperty2.default)(TimelineCard, "contextType", _RoomContext.default); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_types","_BaseCard","_MessageComposer","_Layout","_TimelinePanel","_EditorStateTransfer","_RoomContext","_dispatcher","_languageHandler","_actions","_ContentMessages","_UploadBar","_SettingsStore","_JumpToBottomButton","_Measured","_AsyncStore","_SDKContext","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","TimelineCard","React","Component","constructor","props","context","createRef","_initial","newState","initialEventId","SdkContextClass","instance","roomViewStore","getInitialEventId","isInitialEventHighlighted","replyToEvent","getQuotingEvent","setState","payload","action","Action","EditEvent","editState","event","EditorStateTransfer","undefined","timelinePanel","current","scrollToEventIfNeeded","getId","isAtEndOfLiveTimeline","atEndOfLiveTimeline","state","dis","dispatch","ViewRoom","room_id","room","roomId","event_id","highlighted","replyingToEvent","metricsTrigger","narrow","jumpToLiveTimeline","fire","FocusSendMessageComposer","showReadReceipts","SettingsStore","getValue","layout","componentDidMount","addListener","UPDATE_EVENT","onRoomViewStoreUpdate","dispatcherRef","register","onAction","readReceiptsSettingWatcher","watchSetting","value","layoutWatcherRef","componentWillUnmount","removeListener","unwatchSetting","unregister","render","highlightedEventId","jumpToBottom","createElement","highlight","getUnreadNotificationCount","NotificationCountType","Highlight","onScrollToBottomClick","isUploading","ContentMessages","sharedInstance","getCurrentUploads","composerRelation","myMembership","getMyMembership","showComposer","KnownMembership","Join","Provider","timelineRenderingType","liveTimeline","timelineSet","getLiveTimeline","className","classNames","onClose","withoutScrollContainer","header","_t","ref","card","sensor","onMeasurement","manageReadReceipts","manageReadMarkers","sendReadReceiptOnLoad","showUrlPreview","Layout","Bubble","Group","hideThreadedMessages","hidden","showReactions","permalinkCreator","membersLoaded","eventId","resizeNotifier","onScroll","relation","e2eStatus","compact","exports","RoomContext"],"sources":["../../../../src/components/views/right_panel/TimelineCard.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 from \"react\";\nimport {\n    IEventRelation,\n    MatrixEvent,\n    NotificationCountType,\n    Room,\n    EventTimelineSet,\n    Thread,\n} from \"matrix-js-sdk/src/matrix\";\nimport { KnownMembership } from \"matrix-js-sdk/src/types\";\n\nimport BaseCard from \"./BaseCard\";\nimport ResizeNotifier from \"../../../utils/ResizeNotifier\";\nimport MessageComposer from \"../rooms/MessageComposer\";\nimport { RoomPermalinkCreator } from \"../../../utils/permalinks/Permalinks\";\nimport { Layout } from \"../../../settings/enums/Layout\";\nimport TimelinePanel from \"../../structures/TimelinePanel\";\nimport { E2EStatus } from \"../../../utils/ShieldUtils\";\nimport EditorStateTransfer from \"../../../utils/EditorStateTransfer\";\nimport RoomContext, { TimelineRenderingType } from \"../../../contexts/RoomContext\";\nimport dis from \"../../../dispatcher/dispatcher\";\nimport { _t } from \"../../../languageHandler\";\nimport { ActionPayload } from \"../../../dispatcher/payloads\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport ContentMessages from \"../../../ContentMessages\";\nimport UploadBar from \"../../structures/UploadBar\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport JumpToBottomButton from \"../rooms/JumpToBottomButton\";\nimport { ViewRoomPayload } from \"../../../dispatcher/payloads/ViewRoomPayload\";\nimport Measured from \"../elements/Measured\";\nimport { UPDATE_EVENT } from \"../../../stores/AsyncStore\";\nimport { SdkContextClass } from \"../../../contexts/SDKContext\";\n\ninterface IProps {\n    room: Room;\n    onClose: () => void;\n    resizeNotifier: ResizeNotifier;\n    permalinkCreator: RoomPermalinkCreator;\n    e2eStatus?: E2EStatus;\n    classNames?: string;\n    timelineSet: EventTimelineSet;\n    timelineRenderingType?: TimelineRenderingType;\n    showComposer?: boolean;\n    composerRelation?: IEventRelation;\n}\n\ninterface IState {\n    thread?: Thread;\n    editState?: EditorStateTransfer;\n    replyToEvent?: MatrixEvent;\n    initialEventId?: string;\n    isInitialEventHighlighted?: boolean;\n    layout: Layout;\n    atEndOfLiveTimeline: boolean;\n    narrow: boolean;\n\n    // settings:\n    showReadReceipts?: boolean;\n}\n\nexport default class TimelineCard extends React.Component<IProps, IState> {\n    public static contextType = RoomContext;\n    public declare context: React.ContextType<typeof RoomContext>;\n\n    private dispatcherRef?: string;\n    private layoutWatcherRef?: string;\n    private timelinePanel = React.createRef<TimelinePanel>();\n    private card = React.createRef<HTMLDivElement>();\n    private readReceiptsSettingWatcher: string | undefined;\n\n    public constructor(props: IProps, context: React.ContextType<typeof RoomContext>) {\n        super(props, context);\n        this.state = {\n            showReadReceipts: SettingsStore.getValue(\"showReadReceipts\", props.room.roomId),\n            layout: SettingsStore.getValue(\"layout\"),\n            atEndOfLiveTimeline: true,\n            narrow: false,\n        };\n    }\n\n    public componentDidMount(): void {\n        SdkContextClass.instance.roomViewStore.addListener(UPDATE_EVENT, this.onRoomViewStoreUpdate);\n        this.dispatcherRef = dis.register(this.onAction);\n        this.readReceiptsSettingWatcher = SettingsStore.watchSetting(\"showReadReceipts\", null, (...[, , , value]) =>\n            this.setState({ showReadReceipts: value as boolean }),\n        );\n        this.layoutWatcherRef = SettingsStore.watchSetting(\"layout\", null, (...[, , , value]) =>\n            this.setState({ layout: value as Layout }),\n        );\n    }\n\n    public componentWillUnmount(): void {\n        SdkContextClass.instance.roomViewStore.removeListener(UPDATE_EVENT, this.onRoomViewStoreUpdate);\n\n        if (this.readReceiptsSettingWatcher) {\n            SettingsStore.unwatchSetting(this.readReceiptsSettingWatcher);\n        }\n        if (this.layoutWatcherRef) {\n            SettingsStore.unwatchSetting(this.layoutWatcherRef);\n        }\n\n        if (this.dispatcherRef) dis.unregister(this.dispatcherRef);\n    }\n\n    private onRoomViewStoreUpdate = async (_initial?: boolean): Promise<void> => {\n        const newState: Pick<IState, any> = {\n            initialEventId: SdkContextClass.instance.roomViewStore.getInitialEventId(),\n            isInitialEventHighlighted: SdkContextClass.instance.roomViewStore.isInitialEventHighlighted(),\n            replyToEvent: SdkContextClass.instance.roomViewStore.getQuotingEvent(),\n        };\n\n        this.setState(newState);\n    };\n\n    private onAction = (payload: ActionPayload): void => {\n        switch (payload.action) {\n            case Action.EditEvent:\n                this.setState(\n                    {\n                        editState: payload.event ? new EditorStateTransfer(payload.event) : undefined,\n                    },\n                    () => {\n                        if (payload.event) {\n                            this.timelinePanel.current?.scrollToEventIfNeeded(payload.event.getId());\n                        }\n                    },\n                );\n                break;\n            default:\n                break;\n        }\n    };\n\n    private onScroll = (): void => {\n        const timelinePanel = this.timelinePanel.current;\n        if (!timelinePanel) return;\n        if (timelinePanel.isAtEndOfLiveTimeline()) {\n            this.setState({\n                atEndOfLiveTimeline: true,\n            });\n        } else {\n            this.setState({\n                atEndOfLiveTimeline: false,\n            });\n        }\n\n        if (this.state.initialEventId && this.state.isInitialEventHighlighted) {\n            dis.dispatch<ViewRoomPayload>({\n                action: Action.ViewRoom,\n                room_id: this.props.room.roomId,\n                event_id: this.state.initialEventId,\n                highlighted: false,\n                replyingToEvent: this.state.replyToEvent,\n                metricsTrigger: undefined, // room doesn't change\n            });\n        }\n    };\n\n    private onMeasurement = (narrow: boolean): void => {\n        this.setState({ narrow });\n    };\n\n    private jumpToLiveTimeline = (): void => {\n        if (this.state.initialEventId && this.state.isInitialEventHighlighted) {\n            // If we were viewing a highlighted event, firing view_room without\n            // an event will take care of both clearing the URL fragment and\n            // jumping to the bottom\n            dis.dispatch({\n                action: Action.ViewRoom,\n                room_id: this.props.room.roomId,\n            });\n        } else {\n            // Otherwise we have to jump manually\n            this.timelinePanel.current?.jumpToLiveTimeline();\n            dis.fire(Action.FocusSendMessageComposer);\n        }\n    };\n\n    public render(): React.ReactNode {\n        const highlightedEventId = this.state.isInitialEventHighlighted ? this.state.initialEventId : undefined;\n\n        let jumpToBottom;\n        if (!this.state.atEndOfLiveTimeline) {\n            jumpToBottom = (\n                <JumpToBottomButton\n                    highlight={this.props.room.getUnreadNotificationCount(NotificationCountType.Highlight) > 0}\n                    onScrollToBottomClick={this.jumpToLiveTimeline}\n                />\n            );\n        }\n\n        const isUploading = ContentMessages.sharedInstance().getCurrentUploads(this.props.composerRelation).length > 0;\n\n        const myMembership = this.props.room.getMyMembership();\n        const showComposer = myMembership === KnownMembership.Join;\n\n        return (\n            <RoomContext.Provider\n                value={{\n                    ...this.context,\n                    timelineRenderingType: this.props.timelineRenderingType ?? this.context.timelineRenderingType,\n                    liveTimeline: this.props.timelineSet?.getLiveTimeline(),\n                    narrow: this.state.narrow,\n                }}\n            >\n                <BaseCard\n                    className={this.props.classNames}\n                    onClose={this.props.onClose}\n                    withoutScrollContainer={true}\n                    header={_t(\"right_panel|video_room_chat|title\")}\n                    ref={this.card}\n                >\n                    {this.card.current && <Measured sensor={this.card.current} onMeasurement={this.onMeasurement} />}\n                    <div className=\"mx_TimelineCard_timeline\">\n                        {jumpToBottom}\n                        <TimelinePanel\n                            ref={this.timelinePanel}\n                            showReadReceipts={this.state.showReadReceipts}\n                            manageReadReceipts={true}\n                            manageReadMarkers={false} // No RM support in the TimelineCard\n                            sendReadReceiptOnLoad={true}\n                            timelineSet={this.props.timelineSet}\n                            showUrlPreview={this.context.showUrlPreview}\n                            // The right panel timeline (and therefore threads) don't support IRC layout at this time\n                            layout={this.state.layout === Layout.Bubble ? Layout.Bubble : Layout.Group}\n                            hideThreadedMessages={false}\n                            hidden={false}\n                            showReactions={true}\n                            className=\"mx_RoomView_messagePanel\"\n                            permalinkCreator={this.props.permalinkCreator}\n                            membersLoaded={true}\n                            editState={this.state.editState}\n                            eventId={this.state.initialEventId}\n                            resizeNotifier={this.props.resizeNotifier}\n                            highlightedEventId={highlightedEventId}\n                            onScroll={this.onScroll}\n                        />\n                    </div>\n\n                    {isUploading && <UploadBar room={this.props.room} relation={this.props.composerRelation} />}\n\n                    {showComposer && (\n                        <MessageComposer\n                            room={this.props.room}\n                            relation={this.props.composerRelation}\n                            resizeNotifier={this.props.resizeNotifier}\n                            replyToEvent={this.state.replyToEvent}\n                            permalinkCreator={this.props.permalinkCreator}\n                            e2eStatus={this.props.e2eStatus}\n                            compact={true}\n                        />\n                    )}\n                </BaseCard>\n            </RoomContext.Provider>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}