UNPKG

matrix-react-sdk

Version:
115 lines (98 loc) 15 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _filesize = _interopRequireDefault(require("filesize")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var sdk = _interopRequireWildcard(require("../../../index")); var _languageHandler = require("../../../languageHandler"); var _ContentMessages = _interopRequireDefault(require("../../../ContentMessages")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; let UploadFailureDialog = ( /* * 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. */ _dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.UploadFailureDialog"), _dec(_class = (_temp = _class2 = 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() { const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog'); const DialogButtons = sdk.getComponent('views.elements.DialogButtons'); let message; let preview; let buttons; if (this.props.totalFiles === 1 && this.props.badFiles.length === 1) { message = (0, _languageHandler._t)("This file is <b>too large</b> to upload. " + "The file size limit is %(limit)s but this file is %(sizeOfThisFile)s.", { limit: (0, _filesize.default)(this.props.contentMessages.getUploadLimit()), sizeOfThisFile: (0, _filesize.default)(this.props.badFiles[0].size) }, { b: sub => /*#__PURE__*/_react.default.createElement("b", null, sub) }); buttons = /*#__PURE__*/_react.default.createElement(DialogButtons, { primaryButton: (0, _languageHandler._t)('OK'), hasCancel: false, onPrimaryButtonClick: this._onCancelClick, focus: true }); } else if (this.props.totalFiles === this.props.badFiles.length) { message = (0, _languageHandler._t)("These files are <b>too large</b> to upload. " + "The file size limit is %(limit)s.", { limit: (0, _filesize.default)(this.props.contentMessages.getUploadLimit()) }, { b: sub => /*#__PURE__*/_react.default.createElement("b", null, sub) }); buttons = /*#__PURE__*/_react.default.createElement(DialogButtons, { primaryButton: (0, _languageHandler._t)('OK'), hasCancel: false, onPrimaryButtonClick: this._onCancelClick, focus: true }); } else { message = (0, _languageHandler._t)("Some files are <b>too large</b> to be uploaded. " + "The file size limit is %(limit)s.", { limit: (0, _filesize.default)(this.props.contentMessages.getUploadLimit()) }, { b: sub => /*#__PURE__*/_react.default.createElement("b", null, sub) }); const howManyOthers = this.props.totalFiles - this.props.badFiles.length; buttons = /*#__PURE__*/_react.default.createElement(DialogButtons, { primaryButton: (0, _languageHandler._t)('Upload %(count)s other files', { count: howManyOthers }), onPrimaryButtonClick: this._onUploadClick, hasCancel: true, cancelButton: (0, _languageHandler._t)("Cancel All"), onCancel: this._onCancelClick, focus: true }); } return /*#__PURE__*/_react.default.createElement(BaseDialog, { className: "mx_UploadFailureDialog", onFinished: this._onCancelClick, title: (0, _languageHandler._t)("Upload Error"), contentId: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { id: "mx_Dialog_content" }, message, preview), buttons); } }, (0, _defineProperty2.default)(_class2, "propTypes", { badFiles: _propTypes.default.arrayOf(_propTypes.default.object).isRequired, totalFiles: _propTypes.default.number.isRequired, contentMessages: _propTypes.default.instanceOf(_ContentMessages.default).isRequired, onFinished: _propTypes.default.func.isRequired }), _temp)) || _class); exports.default = UploadFailureDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/UploadFailureDialog.js"],"names":["UploadFailureDialog","React","Component","props","onFinished","render","BaseDialog","sdk","getComponent","DialogButtons","message","preview","buttons","totalFiles","badFiles","length","limit","contentMessages","getUploadLimit","sizeOfThisFile","size","b","sub","_onCancelClick","howManyOthers","count","_onUploadClick","PropTypes","arrayOf","object","isRequired","number","instanceOf","ContentMessages","func"],"mappings":"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","sourcesContent":["/*\nCopyright 2019 New Vector Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport filesize from 'filesize';\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport * as sdk from '../../../index';\nimport { _t } from '../../../languageHandler';\nimport ContentMessages from '../../../ContentMessages';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\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 */\n@replaceableComponent(\"views.dialogs.UploadFailureDialog\")\nexport default class UploadFailureDialog extends React.Component {\n    static propTypes = {\n        badFiles: PropTypes.arrayOf(PropTypes.object).isRequired,\n        totalFiles: PropTypes.number.isRequired,\n        contentMessages: PropTypes.instanceOf(ContentMessages).isRequired,\n        onFinished: PropTypes.func.isRequired,\n    }\n\n    _onCancelClick = () => {\n        this.props.onFinished(false);\n    }\n\n    _onUploadClick = () => {\n        this.props.onFinished(true);\n    }\n\n    render() {\n        const BaseDialog = sdk.getComponent('views.dialogs.BaseDialog');\n        const DialogButtons = sdk.getComponent('views.elements.DialogButtons');\n\n        let message;\n        let preview;\n        let buttons;\n        if (this.props.totalFiles === 1 && this.props.badFiles.length === 1) {\n            message = _t(\n                \"This file is <b>too large</b> to upload. \" +\n                \"The file size limit is %(limit)s but this file is %(sizeOfThisFile)s.\",\n                {\n                    limit: filesize(this.props.contentMessages.getUploadLimit()),\n                    sizeOfThisFile: filesize(this.props.badFiles[0].size),\n                }, {\n                    b: sub => <b>{sub}</b>,\n                },\n            );\n            buttons = <DialogButtons primaryButton={_t('OK')}\n                hasCancel={false}\n                onPrimaryButtonClick={this._onCancelClick}\n                focus={true}\n            />;\n        } else if (this.props.totalFiles === this.props.badFiles.length) {\n            message = _t(\n                \"These files are <b>too large</b> to upload. \" +\n                \"The file size limit is %(limit)s.\",\n                {\n                    limit: filesize(this.props.contentMessages.getUploadLimit()),\n                }, {\n                    b: sub => <b>{sub}</b>,\n                },\n            );\n            buttons = <DialogButtons primaryButton={_t('OK')}\n                hasCancel={false}\n                onPrimaryButtonClick={this._onCancelClick}\n                focus={true}\n            />;\n        } else {\n            message = _t(\n                \"Some files are <b>too large</b> to be uploaded. \" +\n                \"The file size limit is %(limit)s.\",\n                {\n                    limit: filesize(this.props.contentMessages.getUploadLimit()),\n                }, {\n                    b: sub => <b>{sub}</b>,\n                },\n            );\n            const howManyOthers = this.props.totalFiles - this.props.badFiles.length;\n            buttons = <DialogButtons\n                primaryButton={_t('Upload %(count)s other files', { count: howManyOthers })}\n                onPrimaryButtonClick={this._onUploadClick}\n                hasCancel={true}\n                cancelButton={_t(\"Cancel All\")}\n                onCancel={this._onCancelClick}\n                focus={true}\n            />;\n        }\n\n        return (\n            <BaseDialog className='mx_UploadFailureDialog'\n                onFinished={this._onCancelClick}\n                title={_t(\"Upload Error\")}\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"]}