matrix-react-sdk
Version:
SDK for matrix.org using React
98 lines (95 loc) • 11.8 kB
JavaScript
;
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 _languageHandler = require("../../../languageHandler");
var _ConfirmRedactDialog = _interopRequireDefault(require("./ConfirmRedactDialog"));
var _ErrorDialog = _interopRequireDefault(require("./ErrorDialog"));
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _Spinner = _interopRequireDefault(require("../elements/Spinner"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2019 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.
*/
/*
* A dialog for confirming a redaction.
* Also shows a spinner (and possible error) while the redaction is ongoing,
* and only closes the dialog when the redaction is done or failed.
*
* This is done to prevent the edit history dialog racing with the redaction:
* if this dialog closes and the MessageEditHistoryDialog is shown again,
* it will fetch the relations again, which will race with the ongoing /redact request.
* which will cause the edit to appear unredacted.
*
* To avoid this, we keep the dialog open as long as /redact is in progress.
*/
class ConfirmAndWaitRedactDialog extends _react.default.PureComponent {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onParentFinished", async proceed => {
if (proceed) {
this.setState({
isRedacting: true
});
try {
await this.props.redact();
this.props.onFinished(true);
} catch (error) {
let code;
if (error instanceof _matrix.MatrixError) {
code = error.errcode;
} else if (error instanceof _matrix.HTTPError) {
code = error.httpStatus;
}
if (typeof code !== "undefined") {
this.setState({
redactionErrorCode: code
});
} else {
this.props.onFinished(true);
}
}
} else {
this.props.onFinished(false);
}
});
this.state = {
isRedacting: false,
redactionErrorCode: null
};
}
render() {
if (this.state.isRedacting) {
if (this.state.redactionErrorCode) {
const code = this.state.redactionErrorCode;
return /*#__PURE__*/_react.default.createElement(_ErrorDialog.default, {
onFinished: this.props.onFinished,
title: (0, _languageHandler._t)("common|error"),
description: (0, _languageHandler._t)("redact|error", {
code
})
});
} else {
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
onFinished: this.props.onFinished,
hasCancel: false,
title: (0, _languageHandler._t)("redact|ongoing")
}, /*#__PURE__*/_react.default.createElement(_Spinner.default, null));
}
} else {
return /*#__PURE__*/_react.default.createElement(_ConfirmRedactDialog.default, {
event: this.props.event,
onFinished: this.onParentFinished
});
}
}
}
exports.default = ConfirmAndWaitRedactDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_languageHandler","_ConfirmRedactDialog","_ErrorDialog","_BaseDialog","_Spinner","ConfirmAndWaitRedactDialog","React","PureComponent","constructor","props","_defineProperty2","default","proceed","setState","isRedacting","redact","onFinished","error","code","MatrixError","errcode","HTTPError","httpStatus","redactionErrorCode","state","render","createElement","title","_t","description","hasCancel","event","onParentFinished","exports"],"sources":["../../../../src/components/views/dialogs/ConfirmAndWaitRedactDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 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 { MatrixEvent, HTTPError, MatrixError } from \"matrix-js-sdk/src/matrix\";\n\nimport { _t } from \"../../../languageHandler\";\nimport ConfirmRedactDialog from \"./ConfirmRedactDialog\";\nimport ErrorDialog from \"./ErrorDialog\";\nimport BaseDialog from \"./BaseDialog\";\nimport Spinner from \"../elements/Spinner\";\n\ninterface IProps {\n    event: MatrixEvent;\n    redact: () => Promise<void>;\n    onFinished: (success?: boolean) => void;\n}\n\ninterface IState {\n    isRedacting: boolean;\n    redactionErrorCode: string | number | null;\n}\n\n/*\n * A dialog for confirming a redaction.\n * Also shows a spinner (and possible error) while the redaction is ongoing,\n * and only closes the dialog when the redaction is done or failed.\n *\n * This is done to prevent the edit history dialog racing with the redaction:\n * if this dialog closes and the MessageEditHistoryDialog is shown again,\n * it will fetch the relations again, which will race with the ongoing /redact request.\n * which will cause the edit to appear unredacted.\n *\n * To avoid this, we keep the dialog open as long as /redact is in progress.\n */\nexport default class ConfirmAndWaitRedactDialog extends React.PureComponent<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n        this.state = {\n            isRedacting: false,\n            redactionErrorCode: null,\n        };\n    }\n\n    public onParentFinished = async (proceed?: boolean): Promise<void> => {\n        if (proceed) {\n            this.setState({ isRedacting: true });\n            try {\n                await this.props.redact();\n                this.props.onFinished(true);\n            } catch (error) {\n                let code: string | number | undefined;\n                if (error instanceof MatrixError) {\n                    code = error.errcode;\n                } else if (error instanceof HTTPError) {\n                    code = error.httpStatus;\n                }\n\n                if (typeof code !== \"undefined\") {\n                    this.setState({ redactionErrorCode: code });\n                } else {\n                    this.props.onFinished(true);\n                }\n            }\n        } else {\n            this.props.onFinished(false);\n        }\n    };\n\n    public render(): React.ReactNode {\n        if (this.state.isRedacting) {\n            if (this.state.redactionErrorCode) {\n                const code = this.state.redactionErrorCode;\n                return (\n                    <ErrorDialog\n                        onFinished={this.props.onFinished}\n                        title={_t(\"common|error\")}\n                        description={_t(\"redact|error\", { code })}\n                    />\n                );\n            } else {\n                return (\n                    <BaseDialog onFinished={this.props.onFinished} hasCancel={false} title={_t(\"redact|ongoing\")}>\n                        <Spinner />\n                    </BaseDialog>\n                );\n            }\n        } else {\n            return <ConfirmRedactDialog event={this.props.event} onFinished={this.onParentFinished} />;\n        }\n    }\n}\n"],"mappings":"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","ignoreList":[]}