UNPKG

matrix-react-sdk

Version:
101 lines (97 loc) 15.3 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 _ContentMessages = _interopRequireDefault(require("../../ContentMessages")); var _dispatcher = _interopRequireDefault(require("../../dispatcher/dispatcher")); var _languageHandler = require("../../languageHandler"); var _actions = require("../../dispatcher/actions"); var _ProgressBar = _interopRequireDefault(require("../views/elements/ProgressBar")); var _AccessibleButton = _interopRequireDefault(require("../views/elements/AccessibleButton")); var _FileUtils = require("../../utils/FileUtils"); /* Copyright 2024 New Vector Ltd. Copyright 2015, 2016 , 2019, 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. */ function isUploadPayload(payload) { return [_actions.Action.UploadStarted, _actions.Action.UploadProgress, _actions.Action.UploadFailed, _actions.Action.UploadFinished, _actions.Action.UploadCanceled].includes(payload.action); } class UploadBar extends _react.default.PureComponent { constructor(props) { super(props); // Set initial state to any available upload in this room - we might be mounting // earlier than the first progress event, so should show something relevant. (0, _defineProperty2.default)(this, "dispatcherRef", void 0); (0, _defineProperty2.default)(this, "mounted", false); (0, _defineProperty2.default)(this, "onAction", payload => { if (!this.mounted) return; if (isUploadPayload(payload)) { this.setState(this.calculateState()); } }); (0, _defineProperty2.default)(this, "onCancelClick", ev => { ev.preventDefault(); _ContentMessages.default.sharedInstance().cancelUpload(this.state.currentUpload); }); this.state = this.calculateState(); } componentDidMount() { this.dispatcherRef = _dispatcher.default.register(this.onAction); this.mounted = true; } componentWillUnmount() { this.mounted = false; _dispatcher.default.unregister(this.dispatcherRef); } getUploadsInRoom() { const uploads = _ContentMessages.default.sharedInstance().getCurrentUploads(this.props.relation); return uploads.filter(u => u.roomId === this.props.room.roomId); } calculateState() { const [currentUpload, ...otherUploads] = this.getUploadsInRoom(); return { currentUpload, currentFile: currentUpload?.fileName, currentLoaded: currentUpload?.loaded, currentTotal: currentUpload?.total, countFiles: otherUploads.length + 1 }; } render() { if (!this.state.currentFile) { return null; } let uploadText; if (this.state.countFiles > 1) { // MUST use var name 'count' for pluralization to kick in uploadText = (0, _languageHandler._t)("room|upload|uploading_multiple_file", { filename: this.state.currentFile, count: this.state.countFiles - 1 }); } else { uploadText = (0, _languageHandler._t)("room|upload|uploading_single_file", { filename: this.state.currentFile }); } const uploadSize = (0, _FileUtils.fileSize)(this.state.currentTotal); return /*#__PURE__*/_react.default.createElement("div", { className: "mx_UploadBar" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_UploadBar_filename" }, uploadText, " (", uploadSize, ")"), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onCancelClick, className: "mx_UploadBar_cancel" }), /*#__PURE__*/_react.default.createElement(_ProgressBar.default, { value: this.state.currentLoaded, max: this.state.currentTotal })); } } exports.default = UploadBar; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_ContentMessages","_dispatcher","_languageHandler","_actions","_ProgressBar","_AccessibleButton","_FileUtils","isUploadPayload","payload","Action","UploadStarted","UploadProgress","UploadFailed","UploadFinished","UploadCanceled","includes","action","UploadBar","React","PureComponent","constructor","props","_defineProperty2","default","mounted","setState","calculateState","ev","preventDefault","ContentMessages","sharedInstance","cancelUpload","state","currentUpload","componentDidMount","dispatcherRef","dis","register","onAction","componentWillUnmount","unregister","getUploadsInRoom","uploads","getCurrentUploads","relation","filter","u","roomId","room","otherUploads","currentFile","fileName","currentLoaded","loaded","currentTotal","total","countFiles","length","render","uploadText","_t","filename","count","uploadSize","fileSize","createElement","className","onClick","onCancelClick","value","max","exports"],"sources":["../../../src/components/structures/UploadBar.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2015, 2016 , 2019, 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 React from \"react\";\nimport { Room, IEventRelation } from \"matrix-js-sdk/src/matrix\";\nimport { Optional } from \"matrix-events-sdk\";\n\nimport ContentMessages from \"../../ContentMessages\";\nimport dis from \"../../dispatcher/dispatcher\";\nimport { _t } from \"../../languageHandler\";\nimport { Action } from \"../../dispatcher/actions\";\nimport ProgressBar from \"../views/elements/ProgressBar\";\nimport AccessibleButton, { ButtonEvent } from \"../views/elements/AccessibleButton\";\nimport { RoomUpload } from \"../../models/RoomUpload\";\nimport { ActionPayload } from \"../../dispatcher/payloads\";\nimport { UploadPayload } from \"../../dispatcher/payloads/UploadPayload\";\nimport { fileSize } from \"../../utils/FileUtils\";\n\ninterface IProps {\n    room: Room;\n    relation?: IEventRelation;\n}\n\ninterface IState {\n    currentFile?: string;\n    currentUpload?: RoomUpload;\n    currentLoaded?: number;\n    currentTotal?: number;\n    countFiles: number;\n}\n\nfunction isUploadPayload(payload: ActionPayload): payload is UploadPayload {\n    return [\n        Action.UploadStarted,\n        Action.UploadProgress,\n        Action.UploadFailed,\n        Action.UploadFinished,\n        Action.UploadCanceled,\n    ].includes(payload.action as Action);\n}\n\nexport default class UploadBar extends React.PureComponent<IProps, IState> {\n    private dispatcherRef: Optional<string>;\n    private mounted = false;\n\n    public constructor(props: IProps) {\n        super(props);\n\n        // Set initial state to any available upload in this room - we might be mounting\n        // earlier than the first progress event, so should show something relevant.\n        this.state = this.calculateState();\n    }\n\n    public componentDidMount(): void {\n        this.dispatcherRef = dis.register(this.onAction);\n        this.mounted = true;\n    }\n\n    public componentWillUnmount(): void {\n        this.mounted = false;\n        dis.unregister(this.dispatcherRef!);\n    }\n\n    private getUploadsInRoom(): RoomUpload[] {\n        const uploads = ContentMessages.sharedInstance().getCurrentUploads(this.props.relation);\n        return uploads.filter((u) => u.roomId === this.props.room.roomId);\n    }\n\n    private calculateState(): IState {\n        const [currentUpload, ...otherUploads] = this.getUploadsInRoom();\n        return {\n            currentUpload,\n            currentFile: currentUpload?.fileName,\n            currentLoaded: currentUpload?.loaded,\n            currentTotal: currentUpload?.total,\n            countFiles: otherUploads.length + 1,\n        };\n    }\n\n    private onAction = (payload: ActionPayload): void => {\n        if (!this.mounted) return;\n        if (isUploadPayload(payload)) {\n            this.setState(this.calculateState());\n        }\n    };\n\n    private onCancelClick = (ev: ButtonEvent): void => {\n        ev.preventDefault();\n        ContentMessages.sharedInstance().cancelUpload(this.state.currentUpload!);\n    };\n\n    public render(): React.ReactNode {\n        if (!this.state.currentFile) {\n            return null;\n        }\n\n        let uploadText: string;\n        if (this.state.countFiles > 1) {\n            // MUST use var name 'count' for pluralization to kick in\n            uploadText = _t(\"room|upload|uploading_multiple_file\", {\n                filename: this.state.currentFile,\n                count: this.state.countFiles - 1,\n            });\n        } else {\n            uploadText = _t(\"room|upload|uploading_single_file\", {\n                filename: this.state.currentFile,\n            });\n        }\n\n        const uploadSize = fileSize(this.state.currentTotal!);\n        return (\n            <div className=\"mx_UploadBar\">\n                <div className=\"mx_UploadBar_filename\">\n                    {uploadText} ({uploadSize})\n                </div>\n                <AccessibleButton onClick={this.onCancelClick} className=\"mx_UploadBar_cancel\" />\n                <ProgressBar value={this.state.currentLoaded!} max={this.state.currentTotal!} />\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}