UNPKG

matrix-react-sdk

Version:
94 lines (91 loc) 13.9 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 _languageHandler = require("../../../languageHandler"); var _BaseDialog = _interopRequireDefault(require("./BaseDialog")); var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons")); var _FileUtils = require("../../../utils/FileUtils"); /* Copyright 2019-2024 New Vector Ltd. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ /* * Tells the user about files we know cannot be uploaded before we even try uploading * them. This is named fairly generically but the only thing we check right now is * the size of the file. */ class UploadFailureDialog extends _react.default.Component { constructor(...args) { super(...args); (0, _defineProperty2.default)(this, "onCancelClick", () => { this.props.onFinished(false); }); (0, _defineProperty2.default)(this, "onUploadClick", () => { this.props.onFinished(true); }); } render() { let message; let preview; let buttons; if (this.props.totalFiles === 1 && this.props.badFiles.length === 1) { message = (0, _languageHandler._t)("upload_file|error_file_too_large", { limit: (0, _FileUtils.fileSize)(this.props.contentMessages.getUploadLimit()), sizeOfThisFile: (0, _FileUtils.fileSize)(this.props.badFiles[0].size) }, { b: sub => /*#__PURE__*/_react.default.createElement("strong", null, sub) }); buttons = /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: (0, _languageHandler._t)("action|ok"), hasCancel: false, onPrimaryButtonClick: this.onCancelClick, focus: true }); } else if (this.props.totalFiles === this.props.badFiles.length) { message = (0, _languageHandler._t)("upload_file|error_files_too_large", { limit: (0, _FileUtils.fileSize)(this.props.contentMessages.getUploadLimit()) }, { b: sub => /*#__PURE__*/_react.default.createElement("strong", null, sub) }); buttons = /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: (0, _languageHandler._t)("action|ok"), hasCancel: false, onPrimaryButtonClick: this.onCancelClick, focus: true }); } else { message = (0, _languageHandler._t)("upload_file|error_some_files_too_large", { limit: (0, _FileUtils.fileSize)(this.props.contentMessages.getUploadLimit()) }, { b: sub => /*#__PURE__*/_react.default.createElement("strong", null, sub) }); const howManyOthers = this.props.totalFiles - this.props.badFiles.length; buttons = /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: (0, _languageHandler._t)("upload_file|upload_n_others_button", { count: howManyOthers }), onPrimaryButtonClick: this.onUploadClick, hasCancel: true, cancelButton: (0, _languageHandler._t)("upload_file|cancel_all_button"), onCancel: this.onCancelClick, focus: true }); } return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, { className: "mx_UploadFailureDialog", onFinished: this.onCancelClick, title: (0, _languageHandler._t)("upload_file|error_title"), contentId: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { id: "mx_Dialog_content" }, message, preview), buttons); } } exports.default = UploadFailureDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_languageHandler","_BaseDialog","_DialogButtons","_FileUtils","UploadFailureDialog","React","Component","constructor","args","_defineProperty2","default","props","onFinished","render","message","preview","buttons","totalFiles","badFiles","length","_t","limit","fileSize","contentMessages","getUploadLimit","sizeOfThisFile","size","b","sub","createElement","primaryButton","hasCancel","onPrimaryButtonClick","onCancelClick","focus","howManyOthers","count","onUploadClick","cancelButton","onCancel","className","title","contentId","id","exports"],"sources":["../../../../src/components/views/dialogs/UploadFailureDialog.tsx"],"sourcesContent":["/*\nCopyright 2019-2024 New Vector Ltd.\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\";\n\nimport { _t } from \"../../../languageHandler\";\nimport ContentMessages from \"../../../ContentMessages\";\nimport BaseDialog from \"./BaseDialog\";\nimport DialogButtons from \"../elements/DialogButtons\";\nimport { fileSize } from \"../../../utils/FileUtils\";\n\ninterface IProps {\n    badFiles: File[];\n    totalFiles: number;\n    contentMessages: ContentMessages;\n    onFinished(upload?: boolean): void;\n}\n\n/*\n * Tells the user about files we know cannot be uploaded before we even try uploading\n * them. This is named fairly generically but the only thing we check right now is\n * the size of the file.\n */\nexport default class UploadFailureDialog extends React.Component<IProps> {\n    private onCancelClick = (): void => {\n        this.props.onFinished(false);\n    };\n\n    private onUploadClick = (): void => {\n        this.props.onFinished(true);\n    };\n\n    public render(): React.ReactNode {\n        let message;\n        let preview;\n        let buttons;\n        if (this.props.totalFiles === 1 && this.props.badFiles.length === 1) {\n            message = _t(\n                \"upload_file|error_file_too_large\",\n                {\n                    limit: fileSize(this.props.contentMessages.getUploadLimit()!),\n                    sizeOfThisFile: fileSize(this.props.badFiles[0].size),\n                },\n                {\n                    b: (sub) => <strong>{sub}</strong>,\n                },\n            );\n            buttons = (\n                <DialogButtons\n                    primaryButton={_t(\"action|ok\")}\n                    hasCancel={false}\n                    onPrimaryButtonClick={this.onCancelClick}\n                    focus={true}\n                />\n            );\n        } else if (this.props.totalFiles === this.props.badFiles.length) {\n            message = _t(\n                \"upload_file|error_files_too_large\",\n                {\n                    limit: fileSize(this.props.contentMessages.getUploadLimit()!),\n                },\n                {\n                    b: (sub) => <strong>{sub}</strong>,\n                },\n            );\n            buttons = (\n                <DialogButtons\n                    primaryButton={_t(\"action|ok\")}\n                    hasCancel={false}\n                    onPrimaryButtonClick={this.onCancelClick}\n                    focus={true}\n                />\n            );\n        } else {\n            message = _t(\n                \"upload_file|error_some_files_too_large\",\n                {\n                    limit: fileSize(this.props.contentMessages.getUploadLimit()!),\n                },\n                {\n                    b: (sub) => <strong>{sub}</strong>,\n                },\n            );\n            const howManyOthers = this.props.totalFiles - this.props.badFiles.length;\n            buttons = (\n                <DialogButtons\n                    primaryButton={_t(\"upload_file|upload_n_others_button\", { count: howManyOthers })}\n                    onPrimaryButtonClick={this.onUploadClick}\n                    hasCancel={true}\n                    cancelButton={_t(\"upload_file|cancel_all_button\")}\n                    onCancel={this.onCancelClick}\n                    focus={true}\n                />\n            );\n        }\n\n        return (\n            <BaseDialog\n                className=\"mx_UploadFailureDialog\"\n                onFinished={this.onCancelClick}\n                title={_t(\"upload_file|error_title\")}\n                contentId=\"mx_Dialog_content\"\n            >\n                <div id=\"mx_Dialog_content\">\n                    {message}\n                    {preview}\n                </div>\n\n                {buttons}\n            </BaseDialog>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}