UNPKG

matrix-react-sdk

Version:
269 lines (262 loc) 50.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _matrix = require("matrix-js-sdk/src/matrix"); var _logger = require("matrix-js-sdk/src/logger"); var _lodash = require("lodash"); var _languageHandler = require("../../../languageHandler"); var _DateUtils = require("../../../DateUtils"); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _actions = require("../../../dispatcher/actions"); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _UIFeature = require("../../../settings/UIFeature"); var _Modal = _interopRequireDefault(require("../../../Modal")); var _ErrorDialog = _interopRequireDefault(require("../dialogs/ErrorDialog")); var _BugReportDialog = _interopRequireDefault(require("../dialogs/BugReportDialog")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _RoomTile = require("../rooms/RoomTile"); var _ContextMenu = require("../../structures/ContextMenu"); var _IconizedContextMenu = _interopRequireWildcard(require("../context_menus/IconizedContextMenu")); var _JumpToDatePicker = _interopRequireDefault(require("./JumpToDatePicker")); var _SDKContext = require("../../../contexts/SDKContext"); var _TimelineSeparator = _interopRequireDefault(require("./TimelineSeparator")); 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 2015-2021 The Matrix.org Foundation C.I.C. Copyright 2018 Michael Telatynski <7t3chguy@gmail.com> SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ /** * Timeline separator component to render within a MessagePanel bearing the date of the ts given * * Has additional jump to date functionality when labs flag is enabled */ class DateSeparator extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "settingWatcherRef", void 0); (0, _defineProperty2.default)(this, "onContextMenuOpenClick", e => { e.preventDefault(); e.stopPropagation(); const target = e.target; this.setState({ contextMenuPosition: target.getBoundingClientRect() }); }); (0, _defineProperty2.default)(this, "onContextMenuCloseClick", () => { this.closeMenu(); }); (0, _defineProperty2.default)(this, "closeMenu", () => { this.setState({ contextMenuPosition: undefined }); }); (0, _defineProperty2.default)(this, "pickDate", async inputTimestamp => { const unixTimestamp = new Date(inputTimestamp).getTime(); const roomIdForJumpRequest = this.props.roomId; try { const cli = _MatrixClientPeg.MatrixClientPeg.safeGet(); const { event_id: eventId, origin_server_ts: originServerTs } = await cli.timestampToEvent(roomIdForJumpRequest, unixTimestamp, _matrix.Direction.Forward); _logger.logger.log(`/timestamp_to_event: ` + `found ${eventId} (${originServerTs}) for timestamp=${unixTimestamp} (looking forward)`); // Only try to navigate to the room if the user is still viewing the same // room. We don't want to jump someone back to a room after a slow request // if they've already navigated away to another room. const currentRoomId = _SDKContext.SdkContextClass.instance.roomViewStore.getRoomId(); if (currentRoomId === roomIdForJumpRequest) { _dispatcher.default.dispatch({ action: _actions.Action.ViewRoom, event_id: eventId, highlighted: true, room_id: roomIdForJumpRequest, metricsTrigger: undefined // room doesn't change }); } else { _logger.logger.debug(`No longer navigating to date in room (jump to date) because the user already switched ` + `to another room: currentRoomId=${currentRoomId}, roomIdForJumpRequest=${roomIdForJumpRequest}`); } } catch (err) { _logger.logger.error(`Error occured while trying to find event in ${roomIdForJumpRequest} ` + `at timestamp=${unixTimestamp}:`, err); // Only display an error if the user is still viewing the same room. We // don't want to worry someone about an error in a room they no longer care // about after a slow request if they've already navigated away to another // room. const currentRoomId = _SDKContext.SdkContextClass.instance.roomViewStore.getRoomId(); if (currentRoomId === roomIdForJumpRequest) { let friendlyErrorMessage = "An error occured while trying to find and jump to the given date."; let submitDebugLogsContent = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null); if (err instanceof _matrix.ConnectionError) { friendlyErrorMessage = (0, _languageHandler._t)("room|error_jump_to_date_connection"); } else if (err instanceof _matrix.MatrixError) { if (err?.errcode === "M_NOT_FOUND") { friendlyErrorMessage = (0, _languageHandler._t)("room|error_jump_to_date_not_found", { dateString: (0, _DateUtils.formatFullDateNoDay)(new Date(unixTimestamp)) }); } else { friendlyErrorMessage = (0, _languageHandler._t)("room|error_jump_to_date", { statusCode: err?.httpStatus || (0, _languageHandler._t)("room|unknown_status_code_for_timeline_jump"), errorCode: err?.errcode || (0, _languageHandler._t)("common|unavailable") }); } } else if (err instanceof _matrix.HTTPError) { friendlyErrorMessage = err.message; } else { // We only give the option to submit logs for actual errors, not network problems. submitDebugLogsContent = /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("room|error_jump_to_date_send_logs_prompt", {}, { debugLogsLink: sub => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default // This is by default a `<div>` which we // can't nest within a `<p>` here so update // this to a be a inline anchor element. , { element: "a", kind: "link", onClick: () => this.onBugReport(err instanceof Error ? err : undefined), "data-testid": "jump-to-date-error-submit-debug-logs-button" }, sub) })); } _Modal.default.createDialog(_ErrorDialog.default, { title: (0, _languageHandler._t)("room|error_jump_to_date_title"), description: /*#__PURE__*/_react.default.createElement("div", { "data-testid": "jump-to-date-error-content" }, /*#__PURE__*/_react.default.createElement("p", null, friendlyErrorMessage), submitDebugLogsContent, /*#__PURE__*/_react.default.createElement("details", null, /*#__PURE__*/_react.default.createElement("summary", null, (0, _languageHandler._t)("room|error_jump_to_date_details")), /*#__PURE__*/_react.default.createElement("p", null, String(err)))) }); } } }); (0, _defineProperty2.default)(this, "onBugReport", err => { _Modal.default.createDialog(_BugReportDialog.default, { error: err, initialText: "Error occured while using jump to date #jump-to-date" }); }); (0, _defineProperty2.default)(this, "onLastWeekClicked", () => { const date = new Date(); date.setDate(date.getDate() - 7); this.pickDate(date); this.closeMenu(); }); (0, _defineProperty2.default)(this, "onLastMonthClicked", () => { const date = new Date(); // Month numbers are 0 - 11 and `setMonth` handles the negative rollover date.setMonth(date.getMonth() - 1, 1); this.pickDate(date); this.closeMenu(); }); (0, _defineProperty2.default)(this, "onTheBeginningClicked", () => { const date = new Date(0); this.pickDate(date); this.closeMenu(); }); (0, _defineProperty2.default)(this, "onDatePicked", dateString => { this.pickDate(dateString); this.closeMenu(); }); this.state = { jumpToDateEnabled: _SettingsStore.default.getValue("feature_jump_to_date") }; // We're using a watcher so the date headers in the timeline are updated // when the lab setting is toggled. this.settingWatcherRef = _SettingsStore.default.watchSetting("feature_jump_to_date", null, (settingName, roomId, level, newValAtLevel, newVal) => { this.setState({ jumpToDateEnabled: newVal }); }); } componentWillUnmount() { if (this.settingWatcherRef) _SettingsStore.default.unwatchSetting(this.settingWatcherRef); } get relativeTimeFormat() { return new Intl.RelativeTimeFormat((0, _languageHandler.getUserLanguage)(), { style: "long", numeric: "auto" }); } getLabel() { const date = new Date(this.props.ts); const disableRelativeTimestamps = !_SettingsStore.default.getValue(_UIFeature.UIFeature.TimelineEnableRelativeDates); // During the time the archive is being viewed, a specific day might not make sense, so we return the full date if (this.props.forExport || disableRelativeTimestamps) return (0, _DateUtils.formatFullDateNoTime)(date); const today = new Date(); const yesterday = new Date(); const days = (0, _DateUtils.getDaysArray)("long"); yesterday.setDate(today.getDate() - 1); if (date.toDateString() === today.toDateString()) { return this.relativeTimeFormat.format(0, "day"); // Today } else if (date.toDateString() === yesterday.toDateString()) { return this.relativeTimeFormat.format(-1, "day"); // Yesterday } else if (today.getTime() - date.getTime() < 6 * 24 * 60 * 60 * 1000) { return days[date.getDay()]; // Sunday-Saturday } else { return (0, _DateUtils.formatFullDateNoTime)(date); } } renderJumpToDateMenu() { let contextMenu; if (this.state.contextMenuPosition) { const relativeTimeFormat = this.relativeTimeFormat; contextMenu = /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.default, (0, _extends2.default)({}, (0, _RoomTile.contextMenuBelow)(this.state.contextMenuPosition), { onFinished: this.onContextMenuCloseClick }), /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOptionList, { first: true }, /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOption, { label: (0, _lodash.capitalize)(relativeTimeFormat.format(-1, "week")), onClick: this.onLastWeekClicked, "data-testid": "jump-to-date-last-week" }), /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOption, { label: (0, _lodash.capitalize)(relativeTimeFormat.format(-1, "month")), onClick: this.onLastMonthClicked, "data-testid": "jump-to-date-last-month" }), /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOption, { label: (0, _languageHandler._t)("room|jump_to_date_beginning"), onClick: this.onTheBeginningClicked, "data-testid": "jump-to-date-beginning" })), /*#__PURE__*/_react.default.createElement(_IconizedContextMenu.IconizedContextMenuOptionList, null, /*#__PURE__*/_react.default.createElement(_JumpToDatePicker.default, { ts: this.props.ts, onDatePicked: this.onDatePicked }))); } return /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuTooltipButton, { className: "mx_DateSeparator_jumpToDateMenu mx_DateSeparator_dateContent", "data-testid": "jump-to-date-separator-button", onClick: this.onContextMenuOpenClick, isExpanded: !!this.state.contextMenuPosition, title: (0, _languageHandler._t)("room|jump_to_date") }, /*#__PURE__*/_react.default.createElement("h2", { className: "mx_DateSeparator_dateHeading", "aria-hidden": "true" }, this.getLabel()), /*#__PURE__*/_react.default.createElement("div", { className: "mx_DateSeparator_chevron" }), contextMenu); } render() { const label = this.getLabel(); let dateHeaderContent; if (this.state.jumpToDateEnabled) { dateHeaderContent = this.renderJumpToDateMenu(); } else { dateHeaderContent = /*#__PURE__*/_react.default.createElement("div", { className: "mx_DateSeparator_dateContent" }, /*#__PURE__*/_react.default.createElement("h2", { className: "mx_DateSeparator_dateHeading", "aria-hidden": "true" }, label)); } return /*#__PURE__*/_react.default.createElement(_TimelineSeparator.default, { label: label }, dateHeaderContent); } } exports.default = DateSeparator; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_logger","_lodash","_languageHandler","_DateUtils","_MatrixClientPeg","_dispatcher","_actions","_SettingsStore","_UIFeature","_Modal","_ErrorDialog","_BugReportDialog","_AccessibleButton","_RoomTile","_ContextMenu","_IconizedContextMenu","_interopRequireWildcard","_JumpToDatePicker","_SDKContext","_TimelineSeparator","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DateSeparator","React","Component","constructor","props","_defineProperty2","preventDefault","stopPropagation","target","setState","contextMenuPosition","getBoundingClientRect","closeMenu","undefined","inputTimestamp","unixTimestamp","Date","getTime","roomIdForJumpRequest","roomId","cli","MatrixClientPeg","safeGet","event_id","eventId","origin_server_ts","originServerTs","timestampToEvent","Direction","Forward","logger","log","currentRoomId","SdkContextClass","instance","roomViewStore","getRoomId","dispatcher","dispatch","action","Action","ViewRoom","highlighted","room_id","metricsTrigger","debug","err","error","friendlyErrorMessage","submitDebugLogsContent","createElement","Fragment","ConnectionError","_t","MatrixError","errcode","dateString","formatFullDateNoDay","statusCode","httpStatus","errorCode","HTTPError","message","debugLogsLink","sub","element","kind","onClick","onBugReport","Error","Modal","createDialog","ErrorDialog","title","description","String","BugReportDialog","initialText","date","setDate","getDate","pickDate","setMonth","getMonth","state","jumpToDateEnabled","SettingsStore","getValue","settingWatcherRef","watchSetting","settingName","level","newValAtLevel","newVal","componentWillUnmount","unwatchSetting","relativeTimeFormat","Intl","RelativeTimeFormat","getUserLanguage","style","numeric","getLabel","ts","disableRelativeTimestamps","UIFeature","TimelineEnableRelativeDates","forExport","formatFullDateNoTime","today","yesterday","days","getDaysArray","toDateString","format","getDay","renderJumpToDateMenu","contextMenu","_extends2","contextMenuBelow","onFinished","onContextMenuCloseClick","IconizedContextMenuOptionList","first","IconizedContextMenuOption","label","capitalize","onLastWeekClicked","onLastMonthClicked","onTheBeginningClicked","onDatePicked","ContextMenuTooltipButton","className","onContextMenuOpenClick","isExpanded","render","dateHeaderContent","exports"],"sources":["../../../../src/components/views/messages/DateSeparator.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2015-2021 The Matrix.org Foundation C.I.C.\nCopyright 2018 Michael Telatynski <7t3chguy@gmail.com>\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 { Direction, ConnectionError, MatrixError, HTTPError } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { capitalize } from \"lodash\";\n\nimport { _t, getUserLanguage } from \"../../../languageHandler\";\nimport { formatFullDateNoDay, formatFullDateNoTime, getDaysArray } from \"../../../DateUtils\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport dispatcher from \"../../../dispatcher/dispatcher\";\nimport { Action } from \"../../../dispatcher/actions\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { UIFeature } from \"../../../settings/UIFeature\";\nimport Modal from \"../../../Modal\";\nimport ErrorDialog from \"../dialogs/ErrorDialog\";\nimport BugReportDialog from \"../dialogs/BugReportDialog\";\nimport AccessibleButton, { ButtonEvent } from \"../elements/AccessibleButton\";\nimport { contextMenuBelow } from \"../rooms/RoomTile\";\nimport { ContextMenuTooltipButton } from \"../../structures/ContextMenu\";\nimport IconizedContextMenu, {\n    IconizedContextMenuOption,\n    IconizedContextMenuOptionList,\n} from \"../context_menus/IconizedContextMenu\";\nimport JumpToDatePicker from \"./JumpToDatePicker\";\nimport { ViewRoomPayload } from \"../../../dispatcher/payloads/ViewRoomPayload\";\nimport { SdkContextClass } from \"../../../contexts/SDKContext\";\nimport TimelineSeparator from \"./TimelineSeparator\";\n\ninterface IProps {\n    roomId: string;\n    ts: number;\n    forExport?: boolean;\n}\n\ninterface IState {\n    contextMenuPosition?: DOMRect;\n    jumpToDateEnabled: boolean;\n}\n\n/**\n * Timeline separator component to render within a MessagePanel bearing the date of the ts given\n *\n * Has additional jump to date functionality when labs flag is enabled\n */\nexport default class DateSeparator extends React.Component<IProps, IState> {\n    private settingWatcherRef?: string;\n\n    public constructor(props: IProps) {\n        super(props);\n        this.state = {\n            jumpToDateEnabled: SettingsStore.getValue(\"feature_jump_to_date\"),\n        };\n\n        // We're using a watcher so the date headers in the timeline are updated\n        // when the lab setting is toggled.\n        this.settingWatcherRef = SettingsStore.watchSetting(\n            \"feature_jump_to_date\",\n            null,\n            (settingName, roomId, level, newValAtLevel, newVal) => {\n                this.setState({ jumpToDateEnabled: newVal });\n            },\n        );\n    }\n\n    public componentWillUnmount(): void {\n        if (this.settingWatcherRef) SettingsStore.unwatchSetting(this.settingWatcherRef);\n    }\n\n    private onContextMenuOpenClick = (e: ButtonEvent): void => {\n        e.preventDefault();\n        e.stopPropagation();\n        const target = e.target as HTMLButtonElement;\n        this.setState({ contextMenuPosition: target.getBoundingClientRect() });\n    };\n\n    private onContextMenuCloseClick = (): void => {\n        this.closeMenu();\n    };\n\n    private closeMenu = (): void => {\n        this.setState({\n            contextMenuPosition: undefined,\n        });\n    };\n\n    private get relativeTimeFormat(): Intl.RelativeTimeFormat {\n        return new Intl.RelativeTimeFormat(getUserLanguage(), { style: \"long\", numeric: \"auto\" });\n    }\n\n    private getLabel(): string {\n        const date = new Date(this.props.ts);\n        const disableRelativeTimestamps = !SettingsStore.getValue(UIFeature.TimelineEnableRelativeDates);\n\n        // During the time the archive is being viewed, a specific day might not make sense, so we return the full date\n        if (this.props.forExport || disableRelativeTimestamps) return formatFullDateNoTime(date);\n\n        const today = new Date();\n        const yesterday = new Date();\n        const days = getDaysArray(\"long\");\n        yesterday.setDate(today.getDate() - 1);\n\n        if (date.toDateString() === today.toDateString()) {\n            return this.relativeTimeFormat.format(0, \"day\"); // Today\n        } else if (date.toDateString() === yesterday.toDateString()) {\n            return this.relativeTimeFormat.format(-1, \"day\"); // Yesterday\n        } else if (today.getTime() - date.getTime() < 6 * 24 * 60 * 60 * 1000) {\n            return days[date.getDay()]; // Sunday-Saturday\n        } else {\n            return formatFullDateNoTime(date);\n        }\n    }\n\n    private pickDate = async (inputTimestamp: number | string | Date): Promise<void> => {\n        const unixTimestamp = new Date(inputTimestamp).getTime();\n        const roomIdForJumpRequest = this.props.roomId;\n\n        try {\n            const cli = MatrixClientPeg.safeGet();\n            const { event_id: eventId, origin_server_ts: originServerTs } = await cli.timestampToEvent(\n                roomIdForJumpRequest,\n                unixTimestamp,\n                Direction.Forward,\n            );\n            logger.log(\n                `/timestamp_to_event: ` +\n                    `found ${eventId} (${originServerTs}) for timestamp=${unixTimestamp} (looking forward)`,\n            );\n\n            // Only try to navigate to the room if the user is still viewing the same\n            // room. We don't want to jump someone back to a room after a slow request\n            // if they've already navigated away to another room.\n            const currentRoomId = SdkContextClass.instance.roomViewStore.getRoomId();\n            if (currentRoomId === roomIdForJumpRequest) {\n                dispatcher.dispatch<ViewRoomPayload>({\n                    action: Action.ViewRoom,\n                    event_id: eventId,\n                    highlighted: true,\n                    room_id: roomIdForJumpRequest,\n                    metricsTrigger: undefined, // room doesn't change\n                });\n            } else {\n                logger.debug(\n                    `No longer navigating to date in room (jump to date) because the user already switched ` +\n                        `to another room: currentRoomId=${currentRoomId}, roomIdForJumpRequest=${roomIdForJumpRequest}`,\n                );\n            }\n        } catch (err) {\n            logger.error(\n                `Error occured while trying to find event in ${roomIdForJumpRequest} ` +\n                    `at timestamp=${unixTimestamp}:`,\n                err,\n            );\n\n            // Only display an error if the user is still viewing the same room. We\n            // don't want to worry someone about an error in a room they no longer care\n            // about after a slow request if they've already navigated away to another\n            // room.\n            const currentRoomId = SdkContextClass.instance.roomViewStore.getRoomId();\n            if (currentRoomId === roomIdForJumpRequest) {\n                let friendlyErrorMessage = \"An error occured while trying to find and jump to the given date.\";\n                let submitDebugLogsContent: JSX.Element = <></>;\n                if (err instanceof ConnectionError) {\n                    friendlyErrorMessage = _t(\"room|error_jump_to_date_connection\");\n                } else if (err instanceof MatrixError) {\n                    if (err?.errcode === \"M_NOT_FOUND\") {\n                        friendlyErrorMessage = _t(\"room|error_jump_to_date_not_found\", {\n                            dateString: formatFullDateNoDay(new Date(unixTimestamp)),\n                        });\n                    } else {\n                        friendlyErrorMessage = _t(\"room|error_jump_to_date\", {\n                            statusCode: err?.httpStatus || _t(\"room|unknown_status_code_for_timeline_jump\"),\n                            errorCode: err?.errcode || _t(\"common|unavailable\"),\n                        });\n                    }\n                } else if (err instanceof HTTPError) {\n                    friendlyErrorMessage = err.message;\n                } else {\n                    // We only give the option to submit logs for actual errors, not network problems.\n                    submitDebugLogsContent = (\n                        <p>\n                            {_t(\n                                \"room|error_jump_to_date_send_logs_prompt\",\n                                {},\n                                {\n                                    debugLogsLink: (sub) => (\n                                        <AccessibleButton\n                                            // This is by default a `<div>` which we\n                                            // can't nest within a `<p>` here so update\n                                            // this to a be a inline anchor element.\n                                            element=\"a\"\n                                            kind=\"link\"\n                                            onClick={() => this.onBugReport(err instanceof Error ? err : undefined)}\n                                            data-testid=\"jump-to-date-error-submit-debug-logs-button\"\n                                        >\n                                            {sub}\n                                        </AccessibleButton>\n                                    ),\n                                },\n                            )}\n                        </p>\n                    );\n                }\n\n                Modal.createDialog(ErrorDialog, {\n                    title: _t(\"room|error_jump_to_date_title\"),\n                    description: (\n                        <div data-testid=\"jump-to-date-error-content\">\n                            <p>{friendlyErrorMessage}</p>\n                            {submitDebugLogsContent}\n                            <details>\n                                <summary>{_t(\"room|error_jump_to_date_details\")}</summary>\n                                <p>{String(err)}</p>\n                            </details>\n                        </div>\n                    ),\n                });\n            }\n        }\n    };\n\n    private onBugReport = (err?: Error): void => {\n        Modal.createDialog(BugReportDialog, {\n            error: err,\n            initialText: \"Error occured while using jump to date #jump-to-date\",\n        });\n    };\n\n    private onLastWeekClicked = (): void => {\n        const date = new Date();\n        date.setDate(date.getDate() - 7);\n        this.pickDate(date);\n        this.closeMenu();\n    };\n\n    private onLastMonthClicked = (): void => {\n        const date = new Date();\n        // Month numbers are 0 - 11 and `setMonth` handles the negative rollover\n        date.setMonth(date.getMonth() - 1, 1);\n        this.pickDate(date);\n        this.closeMenu();\n    };\n\n    private onTheBeginningClicked = (): void => {\n        const date = new Date(0);\n        this.pickDate(date);\n        this.closeMenu();\n    };\n\n    private onDatePicked = (dateString: string): void => {\n        this.pickDate(dateString);\n        this.closeMenu();\n    };\n\n    private renderJumpToDateMenu(): React.ReactElement {\n        let contextMenu: JSX.Element | undefined;\n        if (this.state.contextMenuPosition) {\n            const relativeTimeFormat = this.relativeTimeFormat;\n            contextMenu = (\n                <IconizedContextMenu\n                    {...contextMenuBelow(this.state.contextMenuPosition)}\n                    onFinished={this.onContextMenuCloseClick}\n                >\n                    <IconizedContextMenuOptionList first>\n                        <IconizedContextMenuOption\n                            label={capitalize(relativeTimeFormat.format(-1, \"week\"))}\n                            onClick={this.onLastWeekClicked}\n                            data-testid=\"jump-to-date-last-week\"\n                        />\n                        <IconizedContextMenuOption\n                            label={capitalize(relativeTimeFormat.format(-1, \"month\"))}\n                            onClick={this.onLastMonthClicked}\n                            data-testid=\"jump-to-date-last-month\"\n                        />\n                        <IconizedContextMenuOption\n                            label={_t(\"room|jump_to_date_beginning\")}\n                            onClick={this.onTheBeginningClicked}\n                            data-testid=\"jump-to-date-beginning\"\n                        />\n                    </IconizedContextMenuOptionList>\n\n                    <IconizedContextMenuOptionList>\n                        <JumpToDatePicker ts={this.props.ts} onDatePicked={this.onDatePicked} />\n                    </IconizedContextMenuOptionList>\n                </IconizedContextMenu>\n            );\n        }\n\n        return (\n            <ContextMenuTooltipButton\n                className=\"mx_DateSeparator_jumpToDateMenu mx_DateSeparator_dateContent\"\n                data-testid=\"jump-to-date-separator-button\"\n                onClick={this.onContextMenuOpenClick}\n                isExpanded={!!this.state.contextMenuPosition}\n                title={_t(\"room|jump_to_date\")}\n            >\n                <h2 className=\"mx_DateSeparator_dateHeading\" aria-hidden=\"true\">\n                    {this.getLabel()}\n                </h2>\n                <div className=\"mx_DateSeparator_chevron\" />\n                {contextMenu}\n            </ContextMenuTooltipButton>\n        );\n    }\n\n    public render(): React.ReactNode {\n        const label = this.getLabel();\n\n        let dateHeaderContent: JSX.Element;\n        if (this.state.jumpToDateEnabled) {\n            dateHeaderContent = this.renderJumpToDateMenu();\n        } else {\n            dateHeaderContent = (\n                <div className=\"mx_DateSeparator_dateContent\">\n                    <h2 className=\"mx_DateSeparator_dateHeading\" aria-hidden=\"true\">\n                        {label}\n                    </h2>\n                </div>\n            );\n        }\n\n        return <TimelineSeparator label={label}>{dateHeaderContent}</TimelineSeparator>;\n    }\n}\n"],"mappings":"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