matrix-react-sdk
Version:
SDK for matrix.org using React
120 lines (93 loc) • 12.9 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 _filesize = _interopRequireDefault(require("filesize"));
var _languageHandler = require("../../languageHandler");
var _actions = require("../../dispatcher/actions");
var _ProgressBar = _interopRequireDefault(require("../views/elements/ProgressBar"));
var _AccessibleButton = _interopRequireDefault(require("../views/elements/AccessibleButton"));
var _replaceableComponent = require("../../utils/replaceableComponent");
var _dec, _class, _temp;
let UploadBar = (_dec = (0, _replaceableComponent.replaceableComponent)("structures.UploadBar"), _dec(_class = (_temp = class UploadBar extends _react.default.Component
/*:: <IProps, IState>*/
{
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", void 0);
(0, _defineProperty2.default)(this, "onAction", (payload
/*: ActionPayload*/
) => {
switch (payload.action) {
case _actions.Action.UploadStarted:
case _actions.Action.UploadProgress:
case _actions.Action.UploadFinished:
case _actions.Action.UploadCanceled:
case _actions.Action.UploadFailed:
{
if (!this.mounted) return;
const uploadsHere = this.getUploadsInRoom();
this.setState({
currentUpload: uploadsHere[0],
uploadsHere
});
break;
}
}
});
(0, _defineProperty2.default)(this, "onCancelClick", ev => {
ev.preventDefault();
_ContentMessages.default.sharedInstance().cancelUpload(this.state.currentUpload.promise);
});
const _uploadsHere = this.getUploadsInRoom();
this.state = {
currentUpload: _uploadsHere[0],
uploadsHere: _uploadsHere
};
}
componentDidMount() {
this.dispatcherRef = _dispatcher.default.register(this.onAction);
this.mounted = true;
}
componentWillUnmount() {
this.mounted = false;
_dispatcher.default.unregister(this.dispatcherRef);
}
getUploadsInRoom()
/*: IUpload[]*/
{
const uploads = _ContentMessages.default.sharedInstance().getCurrentUploads();
return uploads.filter(u => u.roomId === this.props.room.roomId);
}
render() {
if (!this.state.currentUpload) {
return null;
} // MUST use var name 'count' for pluralization to kick in
const uploadText = (0, _languageHandler._t)("Uploading %(filename)s and %(count)s others", {
filename: this.state.currentUpload.fileName,
count: this.state.uploadsHere.length - 1
});
const uploadSize = (0, _filesize.default)(this.state.currentUpload.total);
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.currentUpload.loaded,
max: this.state.currentUpload.total
}));
}
}, _temp)) || _class);
exports.default = UploadBar;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/structures/UploadBar.tsx"],"names":["UploadBar","React","Component","constructor","props","payload","action","Action","UploadStarted","UploadProgress","UploadFinished","UploadCanceled","UploadFailed","mounted","uploadsHere","getUploadsInRoom","setState","currentUpload","ev","preventDefault","ContentMessages","sharedInstance","cancelUpload","state","promise","componentDidMount","dispatcherRef","dis","register","onAction","componentWillUnmount","unregister","uploads","getCurrentUploads","filter","u","roomId","room","render","uploadText","filename","fileName","count","length","uploadSize","total","onCancelClick","loaded"],"mappings":";;;;;;;;;;;AAgBA;;AAEA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AAEA;;;;IAYqBA,S,WADpB,gDAAqB,sBAArB,C,yBAAD,MACqBA,SADrB,SACuCC,eAAMC;AAD7C;AACuE;AAInEC,EAAAA,WAAW,CAACC,KAAD,EAAQ;AACf,UAAMA,KAAN,EADe,CAGf;AACA;;AAJe;AAAA;AAAA,oDAwBA,CAACC;AAAD;AAAA,SAA4B;AAC3C,cAAQA,OAAO,CAACC,MAAhB;AACI,aAAKC,gBAAOC,aAAZ;AACA,aAAKD,gBAAOE,cAAZ;AACA,aAAKF,gBAAOG,cAAZ;AACA,aAAKH,gBAAOI,cAAZ;AACA,aAAKJ,gBAAOK,YAAZ;AAA0B;AACtB,gBAAI,CAAC,KAAKC,OAAV,EAAmB;AACnB,kBAAMC,WAAW,GAAG,KAAKC,gBAAL,EAApB;AACA,iBAAKC,QAAL,CAAc;AAACC,cAAAA,aAAa,EAAEH,WAAW,CAAC,CAAD,CAA3B;AAAgCA,cAAAA;AAAhC,aAAd;AACA;AACH;AAVL;AAYH,KArCkB;AAAA,yDAuCMI,EAAD,IAAQ;AAC5BA,MAAAA,EAAE,CAACC,cAAH;;AACAC,+BAAgBC,cAAhB,GAAiCC,YAAjC,CAA8C,KAAKC,KAAL,CAAWN,aAAX,CAAyBO,OAAvE;AACH,KA1CkB;;AAKf,UAAMV,YAAW,GAAG,KAAKC,gBAAL,EAApB;;AACA,SAAKQ,KAAL,GAAa;AAACN,MAAAA,aAAa,EAAEH,YAAW,CAAC,CAAD,CAA3B;AAAgCA,MAAAA,WAAW,EAAXA;AAAhC,KAAb;AACH;;AAEDW,EAAAA,iBAAiB,GAAG;AAChB,SAAKC,aAAL,GAAqBC,oBAAIC,QAAJ,CAAa,KAAKC,QAAlB,CAArB;AACA,SAAKhB,OAAL,GAAe,IAAf;AACH;;AAEDiB,EAAAA,oBAAoB,GAAG;AACnB,SAAKjB,OAAL,GAAe,KAAf;;AACAc,wBAAII,UAAJ,CAAe,KAAKL,aAApB;AACH;;AAEOX,EAAAA,gBAAR;AAAA;AAAsC;AAClC,UAAMiB,OAAO,GAAGZ,yBAAgBC,cAAhB,GAAiCY,iBAAjC,EAAhB;;AACA,WAAOD,OAAO,CAACE,MAAR,CAAeC,CAAC,IAAIA,CAAC,CAACC,MAAF,KAAa,KAAKhC,KAAL,CAAWiC,IAAX,CAAgBD,MAAjD,CAAP;AACH;;AAsBDE,EAAAA,MAAM,GAAG;AACL,QAAI,CAAC,KAAKf,KAAL,CAAWN,aAAhB,EAA+B;AAC3B,aAAO,IAAP;AACH,KAHI,CAKL;;;AACA,UAAMsB,UAAU,GAAG,yBACf,6CADe,EACgC;AAC3CC,MAAAA,QAAQ,EAAE,KAAKjB,KAAL,CAAWN,aAAX,CAAyBwB,QADQ;AAE3CC,MAAAA,KAAK,EAAE,KAAKnB,KAAL,CAAWT,WAAX,CAAuB6B,MAAvB,GAAgC;AAFI,KADhC,CAAnB;AAOA,UAAMC,UAAU,GAAG,uBAAS,KAAKrB,KAAL,CAAWN,aAAX,CAAyB4B,KAAlC,CAAnB;AACA,wBACI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAK,MAAA,SAAS,EAAC;AAAf,OAAwCN,UAAxC,QAAsDK,UAAtD,MADJ,eAEI,6BAAC,yBAAD;AAAkB,MAAA,OAAO,EAAE,KAAKE,aAAhC;AAA+C,MAAA,SAAS,EAAC;AAAzD,MAFJ,eAGI,6BAAC,oBAAD;AAAa,MAAA,KAAK,EAAE,KAAKvB,KAAL,CAAWN,aAAX,CAAyB8B,MAA7C;AAAqD,MAAA,GAAG,EAAE,KAAKxB,KAAL,CAAWN,aAAX,CAAyB4B;AAAnF,MAHJ,CADJ;AAOH;;AArEkE,C","sourcesContent":["/*\nCopyright 2015, 2016, 2019, 2021 The Matrix.org Foundation C.I.C.\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 React from 'react';\nimport { Room } from \"matrix-js-sdk/src/models/room\";\nimport ContentMessages from '../../ContentMessages';\nimport dis from \"../../dispatcher/dispatcher\";\nimport filesize from \"filesize\";\nimport { _t } from '../../languageHandler';\nimport { ActionPayload } from \"../../dispatcher/payloads\";\nimport { Action } from \"../../dispatcher/actions\";\nimport ProgressBar from \"../views/elements/ProgressBar\";\nimport AccessibleButton from \"../views/elements/AccessibleButton\";\nimport { IUpload } from \"../../models/IUpload\";\nimport {replaceableComponent} from \"../../utils/replaceableComponent\";\n\ninterface IProps {\n    room: Room;\n}\n\ninterface IState {\n    currentUpload?: IUpload;\n    uploadsHere: IUpload[];\n}\n\n@replaceableComponent(\"structures.UploadBar\")\nexport default class UploadBar extends React.Component<IProps, IState> {\n    private dispatcherRef: string;\n    private mounted: boolean;\n\n    constructor(props) {\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        const uploadsHere = this.getUploadsInRoom();\n        this.state = {currentUpload: uploadsHere[0], uploadsHere};\n    }\n\n    componentDidMount() {\n        this.dispatcherRef = dis.register(this.onAction);\n        this.mounted = true;\n    }\n\n    componentWillUnmount() {\n        this.mounted = false;\n        dis.unregister(this.dispatcherRef);\n    }\n\n    private getUploadsInRoom(): IUpload[] {\n        const uploads = ContentMessages.sharedInstance().getCurrentUploads();\n        return uploads.filter(u => u.roomId === this.props.room.roomId);\n    }\n\n    private onAction = (payload: ActionPayload) => {\n        switch (payload.action) {\n            case Action.UploadStarted:\n            case Action.UploadProgress:\n            case Action.UploadFinished:\n            case Action.UploadCanceled:\n            case Action.UploadFailed: {\n                if (!this.mounted) return;\n                const uploadsHere = this.getUploadsInRoom();\n                this.setState({currentUpload: uploadsHere[0], uploadsHere});\n                break;\n            }\n        }\n    };\n\n    private onCancelClick = (ev) => {\n        ev.preventDefault();\n        ContentMessages.sharedInstance().cancelUpload(this.state.currentUpload.promise);\n    };\n\n    render() {\n        if (!this.state.currentUpload) {\n            return null;\n        }\n\n        // MUST use var name 'count' for pluralization to kick in\n        const uploadText = _t(\n            \"Uploading %(filename)s and %(count)s others\", {\n                filename: this.state.currentUpload.fileName,\n                count: this.state.uploadsHere.length - 1,\n            },\n        );\n\n        const uploadSize = filesize(this.state.currentUpload.total);\n        return (\n            <div className=\"mx_UploadBar\">\n                <div className=\"mx_UploadBar_filename\">{uploadText} ({uploadSize})</div>\n                <AccessibleButton onClick={this.onCancelClick} className='mx_UploadBar_cancel' />\n                <ProgressBar value={this.state.currentUpload.loaded} max={this.state.currentUpload.total} />\n            </div>\n        );\n    }\n}\n"]}