UNPKG

matrix-react-sdk

Version:
85 lines (82 loc) 12.7 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 _classnames = _interopRequireDefault(require("classnames")); var _languageHandler = require("../../../languageHandler"); var _Modal = _interopRequireDefault(require("../../../Modal")); var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig")); var _BugReportDialog = _interopRequireDefault(require("../dialogs/BugReportDialog")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore")); var _ViewSource = _interopRequireDefault(require("../../structures/ViewSource")); /* Copyright 2024 New Vector Ltd. Copyright 2020-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 TileErrorBoundary extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "onBugReport", () => { _Modal.default.createDialog(_BugReportDialog.default, { label: "react-soft-crash-tile", error: this.state.error }); }); (0, _defineProperty2.default)(this, "onViewSource", () => { _Modal.default.createDialog(_ViewSource.default, { mxEvent: this.props.mxEvent }, "mx_Dialog_viewsource"); }); this.state = {}; } static getDerivedStateFromError(error) { // Side effects are not permitted here, so we only update the state so // that the next render shows an error message. return { error }; } render() { if (this.state.error) { const { mxEvent } = this.props; const classes = { mx_EventTile: true, mx_EventTile_info: true, mx_EventTile_content: true, mx_EventTile_tileError: true }; let submitLogsButton; if (_SdkConfig.default.get().bug_report_endpoint_url) { submitLogsButton = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "\xA0", /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "link", onClick: this.onBugReport }, (0, _languageHandler._t)("bug_reporting|submit_debug_logs"))); } let viewSourceButton; if (mxEvent && _SettingsStore.default.getValue("developerMode")) { viewSourceButton = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, "\xA0", /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onViewSource, kind: "link" }, (0, _languageHandler._t)("action|view_source"))); } return /*#__PURE__*/_react.default.createElement("li", { className: (0, _classnames.default)(classes), "data-layout": this.props.layout }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_EventTile_line" }, /*#__PURE__*/_react.default.createElement("span", null, (0, _languageHandler._t)("timeline|error_rendering_message"), mxEvent && ` (${mxEvent.getType()})`, submitLogsButton, viewSourceButton))); } return this.props.children; } } exports.default = TileErrorBoundary; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_languageHandler","_Modal","_SdkConfig","_BugReportDialog","_AccessibleButton","_SettingsStore","_ViewSource","TileErrorBoundary","React","Component","constructor","props","_defineProperty2","default","Modal","createDialog","BugReportDialog","label","error","state","ViewSource","mxEvent","getDerivedStateFromError","render","classes","mx_EventTile","mx_EventTile_info","mx_EventTile_content","mx_EventTile_tileError","submitLogsButton","SdkConfig","get","bug_report_endpoint_url","createElement","Fragment","kind","onClick","onBugReport","_t","viewSourceButton","SettingsStore","getValue","onViewSource","className","classNames","layout","getType","children","exports"],"sources":["../../../../src/components/views/messages/TileErrorBoundary.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020-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, { ReactNode } from \"react\";\nimport classNames from \"classnames\";\nimport { MatrixEvent } from \"matrix-js-sdk/src/matrix\";\n\nimport { _t } from \"../../../languageHandler\";\nimport Modal from \"../../../Modal\";\nimport SdkConfig from \"../../../SdkConfig\";\nimport BugReportDialog from \"../dialogs/BugReportDialog\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport ViewSource from \"../../structures/ViewSource\";\nimport { Layout } from \"../../../settings/enums/Layout\";\n\ninterface IProps {\n    mxEvent: MatrixEvent;\n    layout: Layout;\n    children: ReactNode;\n}\n\ninterface IState {\n    error?: Error;\n}\n\nexport default class TileErrorBoundary extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {};\n    }\n\n    public static getDerivedStateFromError(error: Error): Partial<IState> {\n        // Side effects are not permitted here, so we only update the state so\n        // that the next render shows an error message.\n        return { error };\n    }\n\n    private onBugReport = (): void => {\n        Modal.createDialog(BugReportDialog, {\n            label: \"react-soft-crash-tile\",\n            error: this.state.error,\n        });\n    };\n\n    private onViewSource = (): void => {\n        Modal.createDialog(\n            ViewSource,\n            {\n                mxEvent: this.props.mxEvent,\n            },\n            \"mx_Dialog_viewsource\",\n        );\n    };\n\n    public render(): ReactNode {\n        if (this.state.error) {\n            const { mxEvent } = this.props;\n            const classes = {\n                mx_EventTile: true,\n                mx_EventTile_info: true,\n                mx_EventTile_content: true,\n                mx_EventTile_tileError: true,\n            };\n\n            let submitLogsButton;\n            if (SdkConfig.get().bug_report_endpoint_url) {\n                submitLogsButton = (\n                    <>\n                        &nbsp;\n                        <AccessibleButton kind=\"link\" onClick={this.onBugReport}>\n                            {_t(\"bug_reporting|submit_debug_logs\")}\n                        </AccessibleButton>\n                    </>\n                );\n            }\n\n            let viewSourceButton;\n            if (mxEvent && SettingsStore.getValue(\"developerMode\")) {\n                viewSourceButton = (\n                    <>\n                        &nbsp;\n                        <AccessibleButton onClick={this.onViewSource} kind=\"link\">\n                            {_t(\"action|view_source\")}\n                        </AccessibleButton>\n                    </>\n                );\n            }\n\n            return (\n                <li className={classNames(classes)} data-layout={this.props.layout}>\n                    <div className=\"mx_EventTile_line\">\n                        <span>\n                            {_t(\"timeline|error_rendering_message\")}\n                            {mxEvent && ` (${mxEvent.getType()})`}\n                            {submitLogsButton}\n                            {viewSourceButton}\n                        </span>\n                    </div>\n                </li>\n            );\n        }\n\n        return this.props.children;\n    }\n}\n"],"mappings":"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","ignoreList":[]}