UNPKG

matrix-react-sdk

Version:
103 lines (99 loc) 17.2 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.AVATAR_SIZE = void 0; var _classnames = _interopRequireDefault(require("classnames")); var _matrix = require("matrix-js-sdk/src/matrix"); var _react = _interopRequireWildcard(require("react")); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _RoomContext = _interopRequireDefault(require("../../../contexts/RoomContext")); var _useTimeout = require("../../../hooks/useTimeout"); var _BrowserWorkarounds = require("../../../utils/BrowserWorkarounds"); var _AccessibleButton = _interopRequireDefault(require("./AccessibleButton")); var _Spinner = _interopRequireDefault(require("./Spinner")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /* Copyright 2024 New Vector Ltd. Copyright 2020 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. */ const AVATAR_SIZE = exports.AVATAR_SIZE = "52px"; const MiniAvatarUploader = ({ hasAvatar, hasAvatarLabel, noAvatarLabel, setAvatarUrl, isUserAvatar, children, onClick }) => { const cli = (0, _react.useContext)(_MatrixClientContext.default); const [busy, setBusy] = (0, _react.useState)(false); const [hover, setHover] = (0, _react.useState)(false); const [show, setShow] = (0, _react.useState)(false); (0, _useTimeout.useTimeout)(() => { setShow(true); }, 3000); // show after 3 seconds (0, _useTimeout.useTimeout)(() => { setShow(false); }, 13000); // hide after being shown for 10 seconds const uploadRef = (0, _react.useRef)(null); const label = hasAvatar || busy ? hasAvatarLabel : noAvatarLabel; const { room } = (0, _react.useContext)(_RoomContext.default); const canSetAvatar = isUserAvatar || room?.currentState?.maySendStateEvent(_matrix.EventType.RoomAvatar, cli.getSafeUserId()); if (!canSetAvatar) return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, children); const visible = !!label && (hover || show); return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("input", { type: "file", ref: uploadRef, className: "mx_MiniAvatarUploader_input", onClick: ev => { (0, _BrowserWorkarounds.chromeFileInputFix)(ev); onClick?.(ev); }, onChange: async ev => { if (!ev.target.files?.length) return; setBusy(true); const file = ev.target.files[0]; const { content_uri: uri } = await cli.uploadContent(file); await setAvatarUrl(uri); setBusy(false); }, accept: "image/*" }), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: (0, _classnames.default)("mx_MiniAvatarUploader", { mx_MiniAvatarUploader_busy: busy, mx_MiniAvatarUploader_hasAvatar: hasAvatar }), disabled: busy, onClick: () => { uploadRef.current?.click(); }, onMouseOver: () => setHover(true), onMouseLeave: () => setHover(false) }, children, /*#__PURE__*/_react.default.createElement("div", { className: "mx_MiniAvatarUploader_indicator" }, busy ? /*#__PURE__*/_react.default.createElement(_Spinner.default, { w: 20, h: 20 }) : /*#__PURE__*/_react.default.createElement("div", { className: "mx_MiniAvatarUploader_cameraIcon" })), /*#__PURE__*/_react.default.createElement("div", { className: (0, _classnames.default)("mx_Tooltip", { mx_Tooltip_visible: visible, mx_Tooltip_invisible: !visible }) }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_Tooltip_chevron" }), label))); }; var _default = exports.default = MiniAvatarUploader; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_classnames","_interopRequireDefault","require","_matrix","_react","_interopRequireWildcard","_MatrixClientContext","_RoomContext","_useTimeout","_BrowserWorkarounds","_AccessibleButton","_Spinner","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AVATAR_SIZE","exports","MiniAvatarUploader","hasAvatar","hasAvatarLabel","noAvatarLabel","setAvatarUrl","isUserAvatar","children","onClick","cli","useContext","MatrixClientContext","busy","setBusy","useState","hover","setHover","show","setShow","useTimeout","uploadRef","useRef","label","room","RoomContext","canSetAvatar","currentState","maySendStateEvent","EventType","RoomAvatar","getSafeUserId","createElement","Fragment","visible","type","ref","className","ev","chromeFileInputFix","onChange","target","files","length","file","content_uri","uri","uploadContent","accept","classNames","mx_MiniAvatarUploader_busy","mx_MiniAvatarUploader_hasAvatar","disabled","current","click","onMouseOver","onMouseLeave","w","h","mx_Tooltip_visible","mx_Tooltip_invisible","_default"],"sources":["../../../../src/components/views/elements/MiniAvatarUploader.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 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 classNames from \"classnames\";\nimport { EventType } from \"matrix-js-sdk/src/matrix\";\nimport React, { useContext, useRef, useState, MouseEvent, ReactNode } from \"react\";\n\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport RoomContext from \"../../../contexts/RoomContext\";\nimport { useTimeout } from \"../../../hooks/useTimeout\";\nimport { TranslatedString } from \"../../../languageHandler\";\nimport { chromeFileInputFix } from \"../../../utils/BrowserWorkarounds\";\nimport AccessibleButton from \"./AccessibleButton\";\nimport Spinner from \"./Spinner\";\n\nexport const AVATAR_SIZE = \"52px\";\n\ninterface IProps {\n    hasAvatar: boolean;\n    noAvatarLabel?: TranslatedString;\n    hasAvatarLabel?: TranslatedString;\n    setAvatarUrl(url: string): Promise<unknown>;\n    isUserAvatar?: boolean;\n    onClick?(ev: MouseEvent<HTMLInputElement>): void;\n    children?: ReactNode;\n}\n\nconst MiniAvatarUploader: React.FC<IProps> = ({\n    hasAvatar,\n    hasAvatarLabel,\n    noAvatarLabel,\n    setAvatarUrl,\n    isUserAvatar,\n    children,\n    onClick,\n}) => {\n    const cli = useContext(MatrixClientContext);\n    const [busy, setBusy] = useState(false);\n    const [hover, setHover] = useState(false);\n    const [show, setShow] = useState(false);\n\n    useTimeout(() => {\n        setShow(true);\n    }, 3000); // show after 3 seconds\n    useTimeout(() => {\n        setShow(false);\n    }, 13000); // hide after being shown for 10 seconds\n\n    const uploadRef = useRef<HTMLInputElement>(null);\n\n    const label = hasAvatar || busy ? hasAvatarLabel : noAvatarLabel;\n\n    const { room } = useContext(RoomContext);\n    const canSetAvatar =\n        isUserAvatar || room?.currentState?.maySendStateEvent(EventType.RoomAvatar, cli.getSafeUserId());\n    if (!canSetAvatar) return <React.Fragment>{children}</React.Fragment>;\n\n    const visible = !!label && (hover || show);\n    return (\n        <React.Fragment>\n            <input\n                type=\"file\"\n                ref={uploadRef}\n                className=\"mx_MiniAvatarUploader_input\"\n                onClick={(ev) => {\n                    chromeFileInputFix(ev);\n                    onClick?.(ev);\n                }}\n                onChange={async (ev): Promise<void> => {\n                    if (!ev.target.files?.length) return;\n                    setBusy(true);\n                    const file = ev.target.files[0];\n                    const { content_uri: uri } = await cli.uploadContent(file);\n                    await setAvatarUrl(uri);\n                    setBusy(false);\n                }}\n                accept=\"image/*\"\n            />\n\n            <AccessibleButton\n                className={classNames(\"mx_MiniAvatarUploader\", {\n                    mx_MiniAvatarUploader_busy: busy,\n                    mx_MiniAvatarUploader_hasAvatar: hasAvatar,\n                })}\n                disabled={busy}\n                onClick={() => {\n                    uploadRef.current?.click();\n                }}\n                onMouseOver={() => setHover(true)}\n                onMouseLeave={() => setHover(false)}\n            >\n                {children}\n\n                <div className=\"mx_MiniAvatarUploader_indicator\">\n                    {busy ? <Spinner w={20} h={20} /> : <div className=\"mx_MiniAvatarUploader_cameraIcon\" />}\n                </div>\n\n                <div\n                    className={classNames(\"mx_Tooltip\", {\n                        mx_Tooltip_visible: visible,\n                        mx_Tooltip_invisible: !visible,\n                    })}\n                >\n                    <div className=\"mx_Tooltip_chevron\" />\n                    {label}\n                </div>\n            </AccessibleButton>\n        </React.Fragment>\n    );\n};\n\nexport default MiniAvatarUploader;\n"],"mappings":"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","ignoreList":[]}