matrix-react-sdk
Version:
SDK for matrix.org using React
101 lines (97 loc) • 15.3 kB
JavaScript
"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":";;;;;;;;AAQA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAIA,IAAAC,gBAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,WAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AACA,IAAAK,YAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,iBAAA,GAAAP,sBAAA,CAAAC,OAAA;AAIA,IAAAO,UAAA,GAAAP,OAAA;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;;AA8BA,SAASQ,eAAeA,CAACC,OAAsB,EAA4B;EACvE,OAAO,CACHC,eAAM,CAACC,aAAa,EACpBD,eAAM,CAACE,cAAc,EACrBF,eAAM,CAACG,YAAY,EACnBH,eAAM,CAACI,cAAc,EACrBJ,eAAM,CAACK,cAAc,CACxB,CAACC,QAAQ,CAACP,OAAO,CAACQ,MAAgB,CAAC;AACxC;AAEe,MAAMC,SAAS,SAASC,cAAK,CAACC,aAAa,CAAiB;EAIhEC,WAAWA,CAACC,KAAa,EAAE;IAC9B,KAAK,CAACA,KAAK,CAAC;;IAEZ;IACA;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,mBANc,KAAK;IAAA,IAAAD,gBAAA,CAAAC,OAAA,oBAoCHf,OAAsB,IAAW;MACjD,IAAI,CAAC,IAAI,CAACgB,OAAO,EAAE;MACnB,IAAIjB,eAAe,CAACC,OAAO,CAAC,EAAE;QAC1B,IAAI,CAACiB,QAAQ,CAAC,IAAI,CAACC,cAAc,CAAC,CAAC,CAAC;MACxC;IACJ,CAAC;IAAA,IAAAJ,gBAAA,CAAAC,OAAA,yBAEwBI,EAAe,IAAW;MAC/CA,EAAE,CAACC,cAAc,CAAC,CAAC;MACnBC,wBAAe,CAACC,cAAc,CAAC,CAAC,CAACC,YAAY,CAAC,IAAI,CAACC,KAAK,CAACC,aAAc,CAAC;IAC5E,CAAC;IAvCG,IAAI,CAACD,KAAK,GAAG,IAAI,CAACN,cAAc,CAAC,CAAC;EACtC;EAEOQ,iBAAiBA,CAAA,EAAS;IAC7B,IAAI,CAACC,aAAa,GAAGC,mBAAG,CAACC,QAAQ,CAAC,IAAI,CAACC,QAAQ,CAAC;IAChD,IAAI,CAACd,OAAO,GAAG,IAAI;EACvB;EAEOe,oBAAoBA,CAAA,EAAS;IAChC,IAAI,CAACf,OAAO,GAAG,KAAK;IACpBY,mBAAG,CAACI,UAAU,CAAC,IAAI,CAACL,aAAc,CAAC;EACvC;EAEQM,gBAAgBA,CAAA,EAAiB;IACrC,MAAMC,OAAO,GAAGb,wBAAe,CAACC,cAAc,CAAC,CAAC,CAACa,iBAAiB,CAAC,IAAI,CAACtB,KAAK,CAACuB,QAAQ,CAAC;IACvF,OAAOF,OAAO,CAACG,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACC,MAAM,KAAK,IAAI,CAAC1B,KAAK,CAAC2B,IAAI,CAACD,MAAM,CAAC;EACrE;EAEQrB,cAAcA,CAAA,EAAW;IAC7B,MAAM,CAACO,aAAa,EAAE,GAAGgB,YAAY,CAAC,GAAG,IAAI,CAACR,gBAAgB,CAAC,CAAC;IAChE,OAAO;MACHR,aAAa;MACbiB,WAAW,EAAEjB,aAAa,EAAEkB,QAAQ;MACpCC,aAAa,EAAEnB,aAAa,EAAEoB,MAAM;MACpCC,YAAY,EAAErB,aAAa,EAAEsB,KAAK;MAClCC,UAAU,EAAEP,YAAY,CAACQ,MAAM,GAAG;IACtC,CAAC;EACL;EAcOC,MAAMA,CAAA,EAAoB;IAC7B,IAAI,CAAC,IAAI,CAAC1B,KAAK,CAACkB,WAAW,EAAE;MACzB,OAAO,IAAI;IACf;IAEA,IAAIS,UAAkB;IACtB,IAAI,IAAI,CAAC3B,KAAK,CAACwB,UAAU,GAAG,CAAC,EAAE;MAC3B;MACAG,UAAU,GAAG,IAAAC,mBAAE,EAAC,qCAAqC,EAAE;QACnDC,QAAQ,EAAE,IAAI,CAAC7B,KAAK,CAACkB,WAAW;QAChCY,KAAK,EAAE,IAAI,CAAC9B,KAAK,CAACwB,UAAU,GAAG;MACnC,CAAC,CAAC;IACN,CAAC,MAAM;MACHG,UAAU,GAAG,IAAAC,mBAAE,EAAC,mCAAmC,EAAE;QACjDC,QAAQ,EAAE,IAAI,CAAC7B,KAAK,CAACkB;MACzB,CAAC,CAAC;IACN;IAEA,MAAMa,UAAU,GAAG,IAAAC,mBAAQ,EAAC,IAAI,CAAChC,KAAK,CAACsB,YAAa,CAAC;IACrD,oBACIzD,MAAA,CAAA0B,OAAA,CAAA0C,aAAA;MAAKC,SAAS,EAAC;IAAc,gBACzBrE,MAAA,CAAA0B,OAAA,CAAA0C,aAAA;MAAKC,SAAS,EAAC;IAAuB,GACjCP,UAAU,EAAC,IAAE,EAACI,UAAU,EAAC,GACzB,CAAC,eACNlE,MAAA,CAAA0B,OAAA,CAAA0C,aAAA,CAAC5D,iBAAA,CAAAkB,OAAgB;MAAC4C,OAAO,EAAE,IAAI,CAACC,aAAc;MAACF,SAAS,EAAC;IAAqB,CAAE,CAAC,eACjFrE,MAAA,CAAA0B,OAAA,CAAA0C,aAAA,CAAC7D,YAAA,CAAAmB,OAAW;MAAC8C,KAAK,EAAE,IAAI,CAACrC,KAAK,CAACoB,aAAe;MAACkB,GAAG,EAAE,IAAI,CAACtC,KAAK,CAACsB;IAAc,CAAE,CAC9E,CAAC;EAEd;AACJ;AAACiB,OAAA,CAAAhD,OAAA,GAAAN,SAAA","ignoreList":[]}