UNPKG

matrix-react-sdk

Version:
117 lines (113 loc) 16.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 _files = require("../../../../res/img/feather-customised/files.svg"); var _languageHandler = require("../../../languageHandler"); var _blobs = require("../../../utils/blobs"); var _BaseDialog = _interopRequireDefault(require("./BaseDialog")); var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons")); var _FileUtils = require("../../../utils/FileUtils"); /* Copyright 2024 New Vector Ltd. Copyright 2019-2021 The Matrix.org Foundation C.I.C. Copyright 2019 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. */ class UploadConfirmDialog extends _react.default.Component { constructor(props) { super(props); // Create a fresh `Blob` for previewing (even though `File` already is // one) so we can adjust the MIME type if needed. (0, _defineProperty2.default)(this, "objectUrl", void 0); (0, _defineProperty2.default)(this, "mimeType", void 0); (0, _defineProperty2.default)(this, "onCancelClick", () => { this.props.onFinished(false); }); (0, _defineProperty2.default)(this, "onUploadClick", () => { this.props.onFinished(true); }); (0, _defineProperty2.default)(this, "onUploadAllClick", () => { this.props.onFinished(true, true); }); this.mimeType = (0, _blobs.getBlobSafeMimeType)(props.file.type); const blob = new Blob([props.file], { type: this.mimeType }); this.objectUrl = URL.createObjectURL(blob); } componentWillUnmount() { if (this.objectUrl) URL.revokeObjectURL(this.objectUrl); } render() { let title; if (this.props.totalFiles > 1 && this.props.currentIndex !== undefined) { title = (0, _languageHandler._t)("upload_file|title_progress", { current: this.props.currentIndex + 1, total: this.props.totalFiles }); } else { title = (0, _languageHandler._t)("upload_file|title"); } const fileId = `mx-uploadconfirmdialog-${this.props.file.name}`; let preview; let placeholder; if (this.mimeType.startsWith("image/")) { preview = /*#__PURE__*/_react.default.createElement("img", { className: "mx_UploadConfirmDialog_imagePreview", src: this.objectUrl, "aria-labelledby": fileId }); } else if (this.mimeType.startsWith("video/")) { preview = /*#__PURE__*/_react.default.createElement("video", { className: "mx_UploadConfirmDialog_imagePreview", src: this.objectUrl, playsInline: true, controls: false }); } else { placeholder = /*#__PURE__*/_react.default.createElement(_files.Icon, { className: "mx_UploadConfirmDialog_fileIcon", height: 18, width: 18 }); } let uploadAllButton; if (this.props.currentIndex + 1 < this.props.totalFiles) { uploadAllButton = /*#__PURE__*/_react.default.createElement("button", { onClick: this.onUploadAllClick }, (0, _languageHandler._t)("upload_file|upload_all_button")); } return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, { className: "mx_UploadConfirmDialog", fixedWidth: false, onFinished: this.onCancelClick, title: title, contentId: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { id: "mx_Dialog_content" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_UploadConfirmDialog_previewOuter" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_UploadConfirmDialog_previewInner" }, preview && /*#__PURE__*/_react.default.createElement("div", null, preview), /*#__PURE__*/_react.default.createElement("div", { id: fileId }, placeholder, this.props.file.name, " (", (0, _FileUtils.fileSize)(this.props.file.size), ")")))), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, { primaryButton: (0, _languageHandler._t)("action|upload"), hasCancel: false, onPrimaryButtonClick: this.onUploadClick, focus: true }, uploadAllButton)); } } exports.default = UploadConfirmDialog; (0, _defineProperty2.default)(UploadConfirmDialog, "defaultProps", { totalFiles: 1, currentIndex: 0 }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_files","_languageHandler","_blobs","_BaseDialog","_DialogButtons","_FileUtils","UploadConfirmDialog","React","Component","constructor","props","_defineProperty2","default","onFinished","mimeType","getBlobSafeMimeType","file","type","blob","Blob","objectUrl","URL","createObjectURL","componentWillUnmount","revokeObjectURL","render","title","totalFiles","currentIndex","undefined","_t","current","total","fileId","name","preview","placeholder","startsWith","createElement","className","src","playsInline","controls","Icon","height","width","uploadAllButton","onClick","onUploadAllClick","fixedWidth","onCancelClick","contentId","id","fileSize","size","primaryButton","hasCancel","onPrimaryButtonClick","onUploadClick","focus","exports"],"sources":["../../../../src/components/views/dialogs/UploadConfirmDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019-2021 The Matrix.org Foundation C.I.C.\nCopyright 2019 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\";\n\nimport { Icon as FileIcon } from \"../../../../res/img/feather-customised/files.svg\";\nimport { _t } from \"../../../languageHandler\";\nimport { getBlobSafeMimeType } from \"../../../utils/blobs\";\nimport BaseDialog from \"./BaseDialog\";\nimport DialogButtons from \"../elements/DialogButtons\";\nimport { fileSize } from \"../../../utils/FileUtils\";\n\ninterface IProps {\n    file: File;\n    currentIndex: number;\n    totalFiles: number;\n    onFinished: (uploadConfirmed: boolean, uploadAll?: boolean) => void;\n}\n\nexport default class UploadConfirmDialog extends React.Component<IProps> {\n    private readonly objectUrl: string;\n    private readonly mimeType: string;\n\n    public static defaultProps: Partial<IProps> = {\n        totalFiles: 1,\n        currentIndex: 0,\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        // Create a fresh `Blob` for previewing (even though `File` already is\n        // one) so we can adjust the MIME type if needed.\n        this.mimeType = getBlobSafeMimeType(props.file.type);\n        const blob = new Blob([props.file], { type: this.mimeType });\n        this.objectUrl = URL.createObjectURL(blob);\n    }\n\n    public componentWillUnmount(): void {\n        if (this.objectUrl) URL.revokeObjectURL(this.objectUrl);\n    }\n\n    private onCancelClick = (): void => {\n        this.props.onFinished(false);\n    };\n\n    private onUploadClick = (): void => {\n        this.props.onFinished(true);\n    };\n\n    private onUploadAllClick = (): void => {\n        this.props.onFinished(true, true);\n    };\n\n    public render(): React.ReactNode {\n        let title: string;\n        if (this.props.totalFiles > 1 && this.props.currentIndex !== undefined) {\n            title = _t(\"upload_file|title_progress\", {\n                current: this.props.currentIndex + 1,\n                total: this.props.totalFiles,\n            });\n        } else {\n            title = _t(\"upload_file|title\");\n        }\n\n        const fileId = `mx-uploadconfirmdialog-${this.props.file.name}`;\n        let preview: JSX.Element | undefined;\n        let placeholder: JSX.Element | undefined;\n        if (this.mimeType.startsWith(\"image/\")) {\n            preview = (\n                <img className=\"mx_UploadConfirmDialog_imagePreview\" src={this.objectUrl} aria-labelledby={fileId} />\n            );\n        } else if (this.mimeType.startsWith(\"video/\")) {\n            preview = (\n                <video\n                    className=\"mx_UploadConfirmDialog_imagePreview\"\n                    src={this.objectUrl}\n                    playsInline\n                    controls={false}\n                />\n            );\n        } else {\n            placeholder = <FileIcon className=\"mx_UploadConfirmDialog_fileIcon\" height={18} width={18} />;\n        }\n\n        let uploadAllButton: JSX.Element | undefined;\n        if (this.props.currentIndex + 1 < this.props.totalFiles) {\n            uploadAllButton = <button onClick={this.onUploadAllClick}>{_t(\"upload_file|upload_all_button\")}</button>;\n        }\n\n        return (\n            <BaseDialog\n                className=\"mx_UploadConfirmDialog\"\n                fixedWidth={false}\n                onFinished={this.onCancelClick}\n                title={title}\n                contentId=\"mx_Dialog_content\"\n            >\n                <div id=\"mx_Dialog_content\">\n                    <div className=\"mx_UploadConfirmDialog_previewOuter\">\n                        <div className=\"mx_UploadConfirmDialog_previewInner\">\n                            {preview && <div>{preview}</div>}\n                            <div id={fileId}>\n                                {placeholder}\n                                {this.props.file.name} ({fileSize(this.props.file.size)})\n                            </div>\n                        </div>\n                    </div>\n                </div>\n\n                <DialogButtons\n                    primaryButton={_t(\"action|upload\")}\n                    hasCancel={false}\n                    onPrimaryButtonClick={this.onUploadClick}\n                    focus={true}\n                >\n                    {uploadAllButton}\n                </DialogButtons>\n            </BaseDialog>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}