matrix-react-sdk
Version:
SDK for matrix.org using React
103 lines (99 loc) • 17.2 kB
JavaScript
;
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":[]}