UNPKG

matrix-react-sdk

Version:
101 lines (98 loc) 14.2 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 _download = require("../../../../res/img/download.svg"); var _RovingTabIndex = require("../../../accessibility/RovingTabIndex"); var _Spinner = _interopRequireDefault(require("../elements/Spinner")); var _languageHandler = require("../../../languageHandler"); var _FileDownloader = require("../../../utils/FileDownloader"); var _Modal = _interopRequireDefault(require("../../../Modal")); var _ErrorDialog = _interopRequireDefault(require("../dialogs/ErrorDialog")); /* Copyright 2024 New Vector Ltd. Copyright 2021 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 DownloadActionButton extends _react.default.PureComponent { constructor(props) { super(props); (0, _defineProperty2.default)(this, "downloader", new _FileDownloader.FileDownloader()); (0, _defineProperty2.default)(this, "onDownloadClick", async () => { try { await this.doDownload(); } catch (e) { _Modal.default.createDialog(_ErrorDialog.default, { title: (0, _languageHandler._t)("timeline|download_failed"), description: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("timeline|download_failed_description")), /*#__PURE__*/_react.default.createElement("div", null, e instanceof Error ? e.toString() : "")) }); this.setState({ loading: false }); } }); this.state = { loading: false, tooltip: (0, _languageHandler._td)("timeline|download_action_downloading") }; } async doDownload() { const mediaEventHelper = this.props.mediaEventHelperGet(); if (this.state.loading || !mediaEventHelper) return; if (mediaEventHelper.media.isEncrypted) { this.setState({ tooltip: (0, _languageHandler._td)("timeline|download_action_decrypting") }); } this.setState({ loading: true }); if (this.state.blob) { // Cheat and trigger a download, again. return this.downloadBlob(this.state.blob); } const blob = await mediaEventHelper.sourceBlob.value; this.setState({ blob }); await this.downloadBlob(blob); } async downloadBlob(blob) { await this.downloader.download({ blob, name: this.props.mediaEventHelperGet().fileName }); this.setState({ loading: false }); } render() { let spinner; if (this.state.loading) { spinner = /*#__PURE__*/_react.default.createElement(_Spinner.default, { w: 18, h: 18 }); } const classes = (0, _classnames.default)({ mx_MessageActionBar_iconButton: true, mx_MessageActionBar_downloadButton: true, mx_MessageActionBar_downloadSpinnerButton: !!spinner }); return /*#__PURE__*/_react.default.createElement(_RovingTabIndex.RovingAccessibleButton, { className: classes, title: spinner ? (0, _languageHandler._t)(this.state.tooltip) : (0, _languageHandler._t)("action|download"), onClick: this.onDownloadClick, disabled: !!spinner, placement: "left" }, /*#__PURE__*/_react.default.createElement(_download.Icon, null), spinner); } } exports.default = DownloadActionButton; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_download","_RovingTabIndex","_Spinner","_languageHandler","_FileDownloader","_Modal","_ErrorDialog","DownloadActionButton","React","PureComponent","constructor","props","_defineProperty2","default","FileDownloader","doDownload","e","Modal","createDialog","ErrorDialog","title","_t","description","createElement","Fragment","Error","toString","setState","loading","state","tooltip","_td","mediaEventHelper","mediaEventHelperGet","media","isEncrypted","blob","downloadBlob","sourceBlob","value","downloader","download","name","fileName","render","spinner","w","h","classes","classNames","mx_MessageActionBar_iconButton","mx_MessageActionBar_downloadButton","mx_MessageActionBar_downloadSpinnerButton","RovingAccessibleButton","className","onClick","onDownloadClick","disabled","placement","Icon","exports"],"sources":["../../../../src/components/views/messages/DownloadActionButton.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 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 { MatrixEvent } from \"matrix-js-sdk/src/matrix\";\nimport React from \"react\";\nimport classNames from \"classnames\";\n\nimport { Icon as DownloadIcon } from \"../../../../res/img/download.svg\";\nimport { MediaEventHelper } from \"../../../utils/MediaEventHelper\";\nimport { RovingAccessibleButton } from \"../../../accessibility/RovingTabIndex\";\nimport Spinner from \"../elements/Spinner\";\nimport { _t, _td, TranslationKey } from \"../../../languageHandler\";\nimport { FileDownloader } from \"../../../utils/FileDownloader\";\nimport Modal from \"../../../Modal\";\nimport ErrorDialog from \"../dialogs/ErrorDialog\";\n\ninterface IProps {\n    mxEvent: MatrixEvent;\n\n    // XXX: It can take a cycle or two for the MessageActionBar to have all the props/setup\n    // required to get us a MediaEventHelper, so we use a getter function instead to prod for\n    // one.\n    mediaEventHelperGet: () => MediaEventHelper | undefined;\n}\n\ninterface IState {\n    loading: boolean;\n    blob?: Blob;\n    tooltip: TranslationKey;\n}\n\nexport default class DownloadActionButton extends React.PureComponent<IProps, IState> {\n    private downloader = new FileDownloader();\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            loading: false,\n            tooltip: _td(\"timeline|download_action_downloading\"),\n        };\n    }\n\n    private onDownloadClick = async (): Promise<void> => {\n        try {\n            await this.doDownload();\n        } catch (e) {\n            Modal.createDialog(ErrorDialog, {\n                title: _t(\"timeline|download_failed\"),\n                description: (\n                    <>\n                        <div>{_t(\"timeline|download_failed_description\")}</div>\n                        <div>{e instanceof Error ? e.toString() : \"\"}</div>\n                    </>\n                ),\n            });\n            this.setState({ loading: false });\n        }\n    };\n\n    private async doDownload(): Promise<void> {\n        const mediaEventHelper = this.props.mediaEventHelperGet();\n        if (this.state.loading || !mediaEventHelper) return;\n\n        if (mediaEventHelper.media.isEncrypted) {\n            this.setState({ tooltip: _td(\"timeline|download_action_decrypting\") });\n        }\n\n        this.setState({ loading: true });\n\n        if (this.state.blob) {\n            // Cheat and trigger a download, again.\n            return this.downloadBlob(this.state.blob);\n        }\n\n        const blob = await mediaEventHelper.sourceBlob.value;\n        this.setState({ blob });\n        await this.downloadBlob(blob);\n    }\n\n    private async downloadBlob(blob: Blob): Promise<void> {\n        await this.downloader.download({\n            blob,\n            name: this.props.mediaEventHelperGet()!.fileName,\n        });\n        this.setState({ loading: false });\n    }\n\n    public render(): React.ReactNode {\n        let spinner: JSX.Element | undefined;\n        if (this.state.loading) {\n            spinner = <Spinner w={18} h={18} />;\n        }\n\n        const classes = classNames({\n            mx_MessageActionBar_iconButton: true,\n            mx_MessageActionBar_downloadButton: true,\n            mx_MessageActionBar_downloadSpinnerButton: !!spinner,\n        });\n\n        return (\n            <RovingAccessibleButton\n                className={classes}\n                title={spinner ? _t(this.state.tooltip) : _t(\"action|download\")}\n                onClick={this.onDownloadClick}\n                disabled={!!spinner}\n                placement=\"left\"\n            >\n                <DownloadIcon />\n                {spinner}\n            </RovingAccessibleButton>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}