matrix-react-sdk
Version:
SDK for matrix.org using React
129 lines (125 loc) • 19.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.SpaceAvatar = void 0;
var _react = _interopRequireWildcard(require("react"));
var _languageHandler = require("../../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _Field = _interopRequireDefault(require("../elements/Field"));
var _BrowserWorkarounds = require("../../../utils/BrowserWorkarounds");
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 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.
*/
const SpaceAvatar = ({
avatarUrl,
avatarDisabled = false,
setAvatar
}) => {
const avatarUploadRef = (0, _react.useRef)(null);
const [avatar, setAvatarDataUrl] = (0, _react.useState)(avatarUrl); // avatar data url cache
let avatarSection;
if (avatarDisabled) {
if (avatar) {
avatarSection = /*#__PURE__*/_react.default.createElement("img", {
className: "mx_SpaceBasicSettings_avatar",
src: avatar,
alt: ""
});
} else {
avatarSection = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SpaceBasicSettings_avatar"
});
}
} else {
if (avatar) {
avatarSection = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_SpaceBasicSettings_avatar",
onClick: () => avatarUploadRef.current?.click(),
element: "img",
src: avatar,
alt: ""
}), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: () => {
if (avatarUploadRef.current) avatarUploadRef.current.value = "";
setAvatarDataUrl(undefined);
setAvatar(undefined);
},
kind: "link",
className: "mx_SpaceBasicSettings_avatar_remove",
"aria-label": (0, _languageHandler._t)("room_settings|delete_avatar_label")
}, (0, _languageHandler._t)("action|delete")));
} else {
avatarSection = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_SpaceBasicSettings_avatar",
onClick: () => avatarUploadRef.current?.click(),
alt: ""
}), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: () => avatarUploadRef.current?.click(),
kind: "link",
"aria-label": (0, _languageHandler._t)("room_settings|upload_avatar_label")
}, (0, _languageHandler._t)("action|upload")));
}
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SpaceBasicSettings_avatarContainer"
}, avatarSection, /*#__PURE__*/_react.default.createElement("input", {
type: "file",
ref: avatarUploadRef,
onClick: _BrowserWorkarounds.chromeFileInputFix,
onChange: e => {
if (!e.target.files?.length) return;
const file = e.target.files[0];
setAvatar(file);
const reader = new FileReader();
reader.onload = ev => {
setAvatarDataUrl(ev.target?.result);
};
reader.readAsDataURL(file);
},
accept: "image/*"
}));
};
exports.SpaceAvatar = SpaceAvatar;
const SpaceBasicSettings = ({
avatarUrl,
avatarDisabled = false,
setAvatar,
name = "",
nameDisabled = false,
setName,
topic = "",
topicDisabled = false,
setTopic
}) => {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_SpaceBasicSettings"
}, /*#__PURE__*/_react.default.createElement(SpaceAvatar, {
avatarUrl: avatarUrl,
avatarDisabled: avatarDisabled,
setAvatar: setAvatar
}), /*#__PURE__*/_react.default.createElement(_Field.default, {
name: "spaceName",
label: (0, _languageHandler._t)("common|name"),
autoFocus: true,
value: name,
onChange: ev => setName(ev.target.value),
disabled: nameDisabled
}), /*#__PURE__*/_react.default.createElement(_Field.default, {
name: "spaceTopic",
element: "textarea",
label: (0, _languageHandler._t)("common|description"),
value: topic,
onChange: ev => setTopic(ev.target.value),
rows: 3,
disabled: topicDisabled
}));
};
var _default = exports.default = SpaceBasicSettings;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_languageHandler","_AccessibleButton","_interopRequireDefault","_Field","_BrowserWorkarounds","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SpaceAvatar","avatarUrl","avatarDisabled","setAvatar","avatarUploadRef","useRef","avatar","setAvatarDataUrl","useState","avatarSection","createElement","className","src","alt","Fragment","onClick","current","click","element","value","undefined","kind","_t","type","ref","chromeFileInputFix","onChange","target","files","length","file","reader","FileReader","onload","ev","result","readAsDataURL","accept","exports","SpaceBasicSettings","name","nameDisabled","setName","topic","topicDisabled","setTopic","label","autoFocus","disabled","rows","_default"],"sources":["../../../../src/components/views/spaces/SpaceBasicSettings.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 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, { ChangeEvent, useRef, useState } from \"react\";\n\nimport { _t } from \"../../../languageHandler\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport Field from \"../elements/Field\";\nimport { chromeFileInputFix } from \"../../../utils/BrowserWorkarounds\";\n\ninterface IProps {\n    avatarUrl?: string;\n    avatarDisabled?: boolean;\n    name: string;\n    nameDisabled?: boolean;\n    topic?: string;\n    topicDisabled?: boolean;\n    setAvatar(avatar?: File): void;\n    setName(name: string): void;\n    setTopic(topic: string): void;\n}\n\nexport const SpaceAvatar: React.FC<Pick<IProps, \"avatarUrl\" | \"avatarDisabled\" | \"setAvatar\">> = ({\n    avatarUrl,\n    avatarDisabled = false,\n    setAvatar,\n}) => {\n    const avatarUploadRef = useRef<HTMLInputElement>(null);\n    const [avatar, setAvatarDataUrl] = useState(avatarUrl); // avatar data url cache\n\n    let avatarSection;\n    if (avatarDisabled) {\n        if (avatar) {\n            avatarSection = <img className=\"mx_SpaceBasicSettings_avatar\" src={avatar} alt=\"\" />;\n        } else {\n            avatarSection = <div className=\"mx_SpaceBasicSettings_avatar\" />;\n        }\n    } else {\n        if (avatar) {\n            avatarSection = (\n                <React.Fragment>\n                    <AccessibleButton\n                        className=\"mx_SpaceBasicSettings_avatar\"\n                        onClick={() => avatarUploadRef.current?.click()}\n                        element=\"img\"\n                        src={avatar}\n                        alt=\"\"\n                    />\n                    <AccessibleButton\n                        onClick={() => {\n                            if (avatarUploadRef.current) avatarUploadRef.current.value = \"\";\n                            setAvatarDataUrl(undefined);\n                            setAvatar(undefined);\n                        }}\n                        kind=\"link\"\n                        className=\"mx_SpaceBasicSettings_avatar_remove\"\n                        aria-label={_t(\"room_settings|delete_avatar_label\")}\n                    >\n                        {_t(\"action|delete\")}\n                    </AccessibleButton>\n                </React.Fragment>\n            );\n        } else {\n            avatarSection = (\n                <React.Fragment>\n                    <AccessibleButton\n                        className=\"mx_SpaceBasicSettings_avatar\"\n                        onClick={() => avatarUploadRef.current?.click()}\n                        alt=\"\"\n                    />\n                    <AccessibleButton\n                        onClick={() => avatarUploadRef.current?.click()}\n                        kind=\"link\"\n                        aria-label={_t(\"room_settings|upload_avatar_label\")}\n                    >\n                        {_t(\"action|upload\")}\n                    </AccessibleButton>\n                </React.Fragment>\n            );\n        }\n    }\n\n    return (\n        <div className=\"mx_SpaceBasicSettings_avatarContainer\">\n            {avatarSection}\n            <input\n                type=\"file\"\n                ref={avatarUploadRef}\n                onClick={chromeFileInputFix}\n                onChange={(e) => {\n                    if (!e.target.files?.length) return;\n                    const file = e.target.files[0];\n                    setAvatar(file);\n                    const reader = new FileReader();\n                    reader.onload = (ev) => {\n                        setAvatarDataUrl(ev.target?.result as string);\n                    };\n                    reader.readAsDataURL(file);\n                }}\n                accept=\"image/*\"\n            />\n        </div>\n    );\n};\n\nconst SpaceBasicSettings: React.FC<IProps> = ({\n    avatarUrl,\n    avatarDisabled = false,\n    setAvatar,\n    name = \"\",\n    nameDisabled = false,\n    setName,\n    topic = \"\",\n    topicDisabled = false,\n    setTopic,\n}) => {\n    return (\n        <div className=\"mx_SpaceBasicSettings\">\n            <SpaceAvatar avatarUrl={avatarUrl} avatarDisabled={avatarDisabled} setAvatar={setAvatar} />\n\n            <Field\n                name=\"spaceName\"\n                label={_t(\"common|name\")}\n                autoFocus={true}\n                value={name}\n                onChange={(ev: ChangeEvent<HTMLInputElement>) => setName(ev.target.value)}\n                disabled={nameDisabled}\n            />\n\n            <Field\n                name=\"spaceTopic\"\n                element=\"textarea\"\n                label={_t(\"common|description\")}\n                value={topic}\n                onChange={(ev: ChangeEvent<HTMLTextAreaElement>) => setTopic(ev.target.value)}\n                rows={3}\n                disabled={topicDisabled}\n            />\n        </div>\n    );\n};\n\nexport default SpaceBasicSettings;\n"],"mappings":";;;;;;;AAQA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,gBAAA,GAAAD,OAAA;AACA,IAAAE,iBAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,MAAA,GAAAD,sBAAA,CAAAH,OAAA;AACA,IAAAK,mBAAA,GAAAL,OAAA;AAAuE,SAAAM,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAR,wBAAAQ,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAbvE;AACA;AACA;AACA;AACA;AACA;AACA;;AAqBO,MAAMW,WAAiF,GAAGA,CAAC;EAC9FC,SAAS;EACTC,cAAc,GAAG,KAAK;EACtBC;AACJ,CAAC,KAAK;EACF,MAAMC,eAAe,GAAG,IAAAC,aAAM,EAAmB,IAAI,CAAC;EACtD,MAAM,CAACC,MAAM,EAAEC,gBAAgB,CAAC,GAAG,IAAAC,eAAQ,EAACP,SAAS,CAAC,CAAC,CAAC;;EAExD,IAAIQ,aAAa;EACjB,IAAIP,cAAc,EAAE;IAChB,IAAII,MAAM,EAAE;MACRG,aAAa,gBAAGrC,MAAA,CAAAc,OAAA,CAAAwB,aAAA;QAAKC,SAAS,EAAC,8BAA8B;QAACC,GAAG,EAAEN,MAAO;QAACO,GAAG,EAAC;MAAE,CAAE,CAAC;IACxF,CAAC,MAAM;MACHJ,aAAa,gBAAGrC,MAAA,CAAAc,OAAA,CAAAwB,aAAA;QAAKC,SAAS,EAAC;MAA8B,CAAE,CAAC;IACpE;EACJ,CAAC,MAAM;IACH,IAAIL,MAAM,EAAE;MACRG,aAAa,gBACTrC,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAACtC,MAAA,CAAAc,OAAK,CAAC4B,QAAQ,qBACX1C,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAAClC,iBAAA,CAAAU,OAAgB;QACbyB,SAAS,EAAC,8BAA8B;QACxCI,OAAO,EAAEA,CAAA,KAAMX,eAAe,CAACY,OAAO,EAAEC,KAAK,CAAC,CAAE;QAChDC,OAAO,EAAC,KAAK;QACbN,GAAG,EAAEN,MAAO;QACZO,GAAG,EAAC;MAAE,CACT,CAAC,eACFzC,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAAClC,iBAAA,CAAAU,OAAgB;QACb6B,OAAO,EAAEA,CAAA,KAAM;UACX,IAAIX,eAAe,CAACY,OAAO,EAAEZ,eAAe,CAACY,OAAO,CAACG,KAAK,GAAG,EAAE;UAC/DZ,gBAAgB,CAACa,SAAS,CAAC;UAC3BjB,SAAS,CAACiB,SAAS,CAAC;QACxB,CAAE;QACFC,IAAI,EAAC,MAAM;QACXV,SAAS,EAAC,qCAAqC;QAC/C,cAAY,IAAAW,mBAAE,EAAC,mCAAmC;MAAE,GAEnD,IAAAA,mBAAE,EAAC,eAAe,CACL,CACN,CACnB;IACL,CAAC,MAAM;MACHb,aAAa,gBACTrC,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAACtC,MAAA,CAAAc,OAAK,CAAC4B,QAAQ,qBACX1C,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAAClC,iBAAA,CAAAU,OAAgB;QACbyB,SAAS,EAAC,8BAA8B;QACxCI,OAAO,EAAEA,CAAA,KAAMX,eAAe,CAACY,OAAO,EAAEC,KAAK,CAAC,CAAE;QAChDJ,GAAG,EAAC;MAAE,CACT,CAAC,eACFzC,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAAClC,iBAAA,CAAAU,OAAgB;QACb6B,OAAO,EAAEA,CAAA,KAAMX,eAAe,CAACY,OAAO,EAAEC,KAAK,CAAC,CAAE;QAChDI,IAAI,EAAC,MAAM;QACX,cAAY,IAAAC,mBAAE,EAAC,mCAAmC;MAAE,GAEnD,IAAAA,mBAAE,EAAC,eAAe,CACL,CACN,CACnB;IACL;EACJ;EAEA,oBACIlD,MAAA,CAAAc,OAAA,CAAAwB,aAAA;IAAKC,SAAS,EAAC;EAAuC,GACjDF,aAAa,eACdrC,MAAA,CAAAc,OAAA,CAAAwB,aAAA;IACIa,IAAI,EAAC,MAAM;IACXC,GAAG,EAAEpB,eAAgB;IACrBW,OAAO,EAAEU,sCAAmB;IAC5BC,QAAQ,EAAG7C,CAAC,IAAK;MACb,IAAI,CAACA,CAAC,CAAC8C,MAAM,CAACC,KAAK,EAAEC,MAAM,EAAE;MAC7B,MAAMC,IAAI,GAAGjD,CAAC,CAAC8C,MAAM,CAACC,KAAK,CAAC,CAAC,CAAC;MAC9BzB,SAAS,CAAC2B,IAAI,CAAC;MACf,MAAMC,MAAM,GAAG,IAAIC,UAAU,CAAC,CAAC;MAC/BD,MAAM,CAACE,MAAM,GAAIC,EAAE,IAAK;QACpB3B,gBAAgB,CAAC2B,EAAE,CAACP,MAAM,EAAEQ,MAAgB,CAAC;MACjD,CAAC;MACDJ,MAAM,CAACK,aAAa,CAACN,IAAI,CAAC;IAC9B,CAAE;IACFO,MAAM,EAAC;EAAS,CACnB,CACA,CAAC;AAEd,CAAC;AAACC,OAAA,CAAAtC,WAAA,GAAAA,WAAA;AAEF,MAAMuC,kBAAoC,GAAGA,CAAC;EAC1CtC,SAAS;EACTC,cAAc,GAAG,KAAK;EACtBC,SAAS;EACTqC,IAAI,GAAG,EAAE;EACTC,YAAY,GAAG,KAAK;EACpBC,OAAO;EACPC,KAAK,GAAG,EAAE;EACVC,aAAa,GAAG,KAAK;EACrBC;AACJ,CAAC,KAAK;EACF,oBACIzE,MAAA,CAAAc,OAAA,CAAAwB,aAAA;IAAKC,SAAS,EAAC;EAAuB,gBAClCvC,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAACV,WAAW;IAACC,SAAS,EAAEA,SAAU;IAACC,cAAc,EAAEA,cAAe;IAACC,SAAS,EAAEA;EAAU,CAAE,CAAC,eAE3F/B,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAAChC,MAAA,CAAAQ,OAAK;IACFsD,IAAI,EAAC,WAAW;IAChBM,KAAK,EAAE,IAAAxB,mBAAE,EAAC,aAAa,CAAE;IACzByB,SAAS,EAAE,IAAK;IAChB5B,KAAK,EAAEqB,IAAK;IACZd,QAAQ,EAAGQ,EAAiC,IAAKQ,OAAO,CAACR,EAAE,CAACP,MAAM,CAACR,KAAK,CAAE;IAC1E6B,QAAQ,EAAEP;EAAa,CAC1B,CAAC,eAEFrE,MAAA,CAAAc,OAAA,CAAAwB,aAAA,CAAChC,MAAA,CAAAQ,OAAK;IACFsD,IAAI,EAAC,YAAY;IACjBtB,OAAO,EAAC,UAAU;IAClB4B,KAAK,EAAE,IAAAxB,mBAAE,EAAC,oBAAoB,CAAE;IAChCH,KAAK,EAAEwB,KAAM;IACbjB,QAAQ,EAAGQ,EAAoC,IAAKW,QAAQ,CAACX,EAAE,CAACP,MAAM,CAACR,KAAK,CAAE;IAC9E8B,IAAI,EAAE,CAAE;IACRD,QAAQ,EAAEJ;EAAc,CAC3B,CACA,CAAC;AAEd,CAAC;AAAC,IAAAM,QAAA,GAAAZ,OAAA,CAAApD,OAAA,GAEaqD,kBAAkB","ignoreList":[]}