UNPKG

matrix-react-sdk

Version:
200 lines (197 loc) 37.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _logger = require("matrix-js-sdk/src/logger"); var _compoundWeb = require("@vector-im/compound-web"); var _popOut = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/pop-out")); var _signOut = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/sign-out")); var _languageHandler = require("../../../languageHandler"); var _OwnProfileStore = require("../../../stores/OwnProfileStore"); var _AvatarSetting = _interopRequireDefault(require("./AvatarSetting")); var _PosthogTrackers = _interopRequireDefault(require("../../../PosthogTrackers")); var _FormattingUtils = require("../../../utils/FormattingUtils"); var _ToastContext = require("../../../contexts/ToastContext"); var _InlineSpinner = _interopRequireDefault(require("../elements/InlineSpinner")); var _UserIdentifier = _interopRequireDefault(require("../../../customisations/UserIdentifier")); var _useId = require("../../../utils/useId"); var _CopyableText = _interopRequireDefault(require("../elements/CopyableText")); var _MatrixClientContext = require("../../../contexts/MatrixClientContext"); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _LogoutDialog = _interopRequireWildcard(require("../dialogs/LogoutDialog")); var _Modal = _interopRequireDefault(require("../../../Modal")); var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher")); var _Flex = require("../../utils/Flex"); 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 2019-2024 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 SpinnerToast = ({ children }) => /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_InlineSpinner.default, null), children); const UsernameBox = ({ username }) => { const labelId = (0, _useId.useId)(); return /*#__PURE__*/_react.default.createElement("div", { className: "mx_UserProfileSettings_profile_controls_userId" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_UserProfileSettings_profile_controls_userId_label", id: labelId }, (0, _languageHandler._t)("settings|general|username")), /*#__PURE__*/_react.default.createElement(_CopyableText.default, { getTextToCopy: () => username, "aria-labelledby": labelId }, username)); }; const ManageAccountButton = ({ externalAccountManagementUrl }) => /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: null, element: "a", kind: "primary", target: "_blank", rel: "noreferrer noopener", href: externalAccountManagementUrl, "data-testid": "external-account-management-link" }, /*#__PURE__*/_react.default.createElement(_popOut.default, { className: "mx_UserProfileSettings_accountmanageIcon", width: "24", height: "24" }), (0, _languageHandler._t)("settings|general|oidc_manage_button")); const SignOutButton = () => { const client = (0, _MatrixClientContext.useMatrixClientContext)(); const onClick = (0, _react.useCallback)(async () => { if (await (0, _LogoutDialog.shouldShowLogoutDialog)(client)) { _Modal.default.createDialog(_LogoutDialog.default); } else { _dispatcher.default.dispatch({ action: "logout" }); } }, [client]); return /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: onClick, kind: "danger_outline" }, /*#__PURE__*/_react.default.createElement(_signOut.default, { className: "mx_UserProfileSettings_accountmanageIcon", width: "24", height: "24" }), (0, _languageHandler._t)("action|sign_out")); }; /** * A group of settings views to allow the user to set their profile information. */ const UserProfileSettings = ({ externalAccountManagementUrl, canSetDisplayName, canSetAvatar }) => { const [avatarURL, setAvatarURL] = (0, _react.useState)(_OwnProfileStore.OwnProfileStore.instance.avatarMxc); const [displayName, setDisplayName] = (0, _react.useState)(_OwnProfileStore.OwnProfileStore.instance.displayName ?? ""); const [avatarError, setAvatarError] = (0, _react.useState)(false); const [maxUploadSize, setMaxUploadSize] = (0, _react.useState)(); const [displayNameError, setDisplayNameError] = (0, _react.useState)(false); const toastRack = (0, _ToastContext.useToastContext)(); const client = (0, _MatrixClientContext.useMatrixClientContext)(); (0, _react.useEffect)(() => { (async () => { try { const mediaConfig = await client.getMediaConfig(); setMaxUploadSize(mediaConfig["m.upload.size"]); } catch (e) { _logger.logger.warn("Failed to get media config", e); } })(); }, [client]); const onAvatarRemove = (0, _react.useCallback)(async () => { const removeToast = toastRack.displayToast( /*#__PURE__*/_react.default.createElement(SpinnerToast, null, (0, _languageHandler._t)("settings|general|avatar_remove_progress"))); try { await client.setAvatarUrl(""); // use empty string as Synapse 500s on undefined setAvatarURL(""); } finally { removeToast(); } }, [toastRack, client]); const onAvatarChange = (0, _react.useCallback)(async avatarFile => { _PosthogTrackers.default.trackInteraction("WebProfileSettingsAvatarUploadButton"); _logger.logger.log(`Uploading new avatar, ${avatarFile.name} of type ${avatarFile.type}, (${avatarFile.size}) bytes`); const removeToast = toastRack.displayToast( /*#__PURE__*/_react.default.createElement(SpinnerToast, null, (0, _languageHandler._t)("settings|general|avatar_save_progress"))); try { setAvatarError(false); const { content_uri: uri } = await client.uploadContent(avatarFile); await client.setAvatarUrl(uri); setAvatarURL(uri); } catch (e) { setAvatarError(true); } finally { removeToast(); } }, [toastRack, client]); const onDisplayNameChanged = (0, _react.useCallback)(e => { setDisplayName(e.target.value); }, []); const onDisplayNameCancel = (0, _react.useCallback)(() => { setDisplayName(_OwnProfileStore.OwnProfileStore.instance.displayName ?? ""); }, []); const onDisplayNameSave = (0, _react.useCallback)(async () => { try { setDisplayNameError(false); await client.setDisplayName(displayName); } catch (e) { setDisplayNameError(true); throw e; } }, [displayName, client]); const userIdentifier = (0, _react.useMemo)(() => _UserIdentifier.default.getDisplayUserIdentifier(client.getSafeUserId(), { withDisplayName: true }), [client]); const someFieldsDisabled = !canSetDisplayName || !canSetAvatar; return /*#__PURE__*/_react.default.createElement("div", { className: "mx_UserProfileSettings" }, /*#__PURE__*/_react.default.createElement("h2", null, (0, _languageHandler._t)("common|profile")), /*#__PURE__*/_react.default.createElement("div", null, someFieldsDisabled ? (0, _languageHandler._t)("settings|general|profile_subtitle_oidc") : (0, _languageHandler._t)("settings|general|profile_subtitle")), /*#__PURE__*/_react.default.createElement("div", { className: "mx_UserProfileSettings_profile" }, /*#__PURE__*/_react.default.createElement(_AvatarSetting.default, { avatar: avatarURL ?? undefined, avatarAltText: (0, _languageHandler._t)("common|user_avatar"), onChange: onAvatarChange, removeAvatar: avatarURL ? onAvatarRemove : undefined, placeholderName: displayName, placeholderId: client.getUserId() ?? "", disabled: !canSetAvatar }), /*#__PURE__*/_react.default.createElement(_compoundWeb.EditInPlace, { className: "mx_UserProfileSettings_profile_displayName", label: (0, _languageHandler._t)("settings|general|display_name"), value: displayName, saveButtonLabel: (0, _languageHandler._t)("common|save"), cancelButtonLabel: (0, _languageHandler._t)("common|cancel"), savedLabel: (0, _languageHandler._t)("common|saved"), savingLabel: (0, _languageHandler._t)("common|updating"), onChange: onDisplayNameChanged, onCancel: onDisplayNameCancel, onSave: onDisplayNameSave, disabled: !canSetDisplayName }, displayNameError && /*#__PURE__*/_react.default.createElement(_compoundWeb.ErrorMessage, null, (0, _languageHandler._t)("settings|general|display_name_error")))), avatarError && /*#__PURE__*/_react.default.createElement(_compoundWeb.Alert, { title: (0, _languageHandler._t)("settings|general|avatar_upload_error_title"), type: "critical" }, maxUploadSize === undefined ? (0, _languageHandler._t)("settings|general|avatar_upload_error_text_generic") : (0, _languageHandler._t)("settings|general|avatar_upload_error_text", { size: (0, _FormattingUtils.formatBytes)(maxUploadSize) })), userIdentifier && /*#__PURE__*/_react.default.createElement(UsernameBox, { username: userIdentifier }), /*#__PURE__*/_react.default.createElement(_Flex.Flex, { gap: "var(--cpd-space-4x)", className: "mx_UserProfileSettings_profile_buttons" }, externalAccountManagementUrl && /*#__PURE__*/_react.default.createElement(ManageAccountButton, { externalAccountManagementUrl: externalAccountManagementUrl }), /*#__PURE__*/_react.default.createElement(SignOutButton, null))); }; var _default = exports.default = UserProfileSettings; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_logger","_compoundWeb","_popOut","_interopRequireDefault","_signOut","_languageHandler","_OwnProfileStore","_AvatarSetting","_PosthogTrackers","_FormattingUtils","_ToastContext","_InlineSpinner","_UserIdentifier","_useId","_CopyableText","_MatrixClientContext","_AccessibleButton","_LogoutDialog","_Modal","_dispatcher","_Flex","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","SpinnerToast","children","createElement","Fragment","UsernameBox","username","labelId","useId","className","id","_t","getTextToCopy","ManageAccountButton","externalAccountManagementUrl","onClick","element","kind","target","rel","href","width","height","SignOutButton","client","useMatrixClientContext","useCallback","shouldShowLogoutDialog","Modal","createDialog","LogoutDialog","defaultDispatcher","dispatch","action","UserProfileSettings","canSetDisplayName","canSetAvatar","avatarURL","setAvatarURL","useState","OwnProfileStore","instance","avatarMxc","displayName","setDisplayName","avatarError","setAvatarError","maxUploadSize","setMaxUploadSize","displayNameError","setDisplayNameError","toastRack","useToastContext","useEffect","mediaConfig","getMediaConfig","logger","warn","onAvatarRemove","removeToast","displayToast","setAvatarUrl","onAvatarChange","avatarFile","PosthogTrackers","trackInteraction","log","name","type","size","content_uri","uri","uploadContent","onDisplayNameChanged","value","onDisplayNameCancel","onDisplayNameSave","userIdentifier","useMemo","UserIdentifierCustomisations","getDisplayUserIdentifier","getSafeUserId","withDisplayName","someFieldsDisabled","avatar","undefined","avatarAltText","onChange","removeAvatar","placeholderName","placeholderId","getUserId","disabled","EditInPlace","label","saveButtonLabel","cancelButtonLabel","savedLabel","savingLabel","onCancel","onSave","ErrorMessage","Alert","title","formatBytes","Flex","gap","_default","exports"],"sources":["../../../../src/components/views/settings/UserProfileSettings.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019-2024 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, ReactNode, useCallback, useEffect, useMemo, useState } from \"react\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { EditInPlace, Alert, ErrorMessage } from \"@vector-im/compound-web\";\nimport PopOutIcon from \"@vector-im/compound-design-tokens/assets/web/icons/pop-out\";\nimport SignOutIcon from \"@vector-im/compound-design-tokens/assets/web/icons/sign-out\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { OwnProfileStore } from \"../../../stores/OwnProfileStore\";\nimport AvatarSetting from \"./AvatarSetting\";\nimport PosthogTrackers from \"../../../PosthogTrackers\";\nimport { formatBytes } from \"../../../utils/FormattingUtils\";\nimport { useToastContext } from \"../../../contexts/ToastContext\";\nimport InlineSpinner from \"../elements/InlineSpinner\";\nimport UserIdentifierCustomisations from \"../../../customisations/UserIdentifier\";\nimport { useId } from \"../../../utils/useId\";\nimport CopyableText from \"../elements/CopyableText\";\nimport { useMatrixClientContext } from \"../../../contexts/MatrixClientContext\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport LogoutDialog, { shouldShowLogoutDialog } from \"../dialogs/LogoutDialog\";\nimport Modal from \"../../../Modal\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport { Flex } from \"../../utils/Flex\";\n\nconst SpinnerToast: React.FC<{ children?: ReactNode }> = ({ children }) => (\n    <>\n        <InlineSpinner />\n        {children}\n    </>\n);\n\ninterface UsernameBoxProps {\n    username: string;\n}\n\nconst UsernameBox: React.FC<UsernameBoxProps> = ({ username }) => {\n    const labelId = useId();\n    return (\n        <div className=\"mx_UserProfileSettings_profile_controls_userId\">\n            <div className=\"mx_UserProfileSettings_profile_controls_userId_label\" id={labelId}>\n                {_t(\"settings|general|username\")}\n            </div>\n            <CopyableText getTextToCopy={() => username} aria-labelledby={labelId}>\n                {username}\n            </CopyableText>\n        </div>\n    );\n};\n\ninterface ManageAccountButtonProps {\n    externalAccountManagementUrl: string;\n}\n\nconst ManageAccountButton: React.FC<ManageAccountButtonProps> = ({ externalAccountManagementUrl }) => (\n    <AccessibleButton\n        onClick={null}\n        element=\"a\"\n        kind=\"primary\"\n        target=\"_blank\"\n        rel=\"noreferrer noopener\"\n        href={externalAccountManagementUrl}\n        data-testid=\"external-account-management-link\"\n    >\n        <PopOutIcon className=\"mx_UserProfileSettings_accountmanageIcon\" width=\"24\" height=\"24\" />\n        {_t(\"settings|general|oidc_manage_button\")}\n    </AccessibleButton>\n);\n\nconst SignOutButton: React.FC = () => {\n    const client = useMatrixClientContext();\n\n    const onClick = useCallback(async () => {\n        if (await shouldShowLogoutDialog(client)) {\n            Modal.createDialog(LogoutDialog);\n        } else {\n            defaultDispatcher.dispatch({ action: \"logout\" });\n        }\n    }, [client]);\n\n    return (\n        <AccessibleButton onClick={onClick} kind=\"danger_outline\">\n            <SignOutIcon className=\"mx_UserProfileSettings_accountmanageIcon\" width=\"24\" height=\"24\" />\n            {_t(\"action|sign_out\")}\n        </AccessibleButton>\n    );\n};\n\ninterface UserProfileSettingsProps {\n    // The URL to redirect the user to in order to manage their account.\n    externalAccountManagementUrl?: string;\n    // Whether the homeserver allows the user to set their display name.\n    canSetDisplayName: boolean;\n    // Whether the homeserver allows the user to set their avatar.\n    canSetAvatar: boolean;\n}\n\n/**\n * A group of settings views to allow the user to set their profile information.\n */\nconst UserProfileSettings: React.FC<UserProfileSettingsProps> = ({\n    externalAccountManagementUrl,\n    canSetDisplayName,\n    canSetAvatar,\n}) => {\n    const [avatarURL, setAvatarURL] = useState(OwnProfileStore.instance.avatarMxc);\n    const [displayName, setDisplayName] = useState(OwnProfileStore.instance.displayName ?? \"\");\n    const [avatarError, setAvatarError] = useState<boolean>(false);\n    const [maxUploadSize, setMaxUploadSize] = useState<number | undefined>();\n    const [displayNameError, setDisplayNameError] = useState<boolean>(false);\n\n    const toastRack = useToastContext();\n\n    const client = useMatrixClientContext();\n\n    useEffect(() => {\n        (async () => {\n            try {\n                const mediaConfig = await client.getMediaConfig();\n                setMaxUploadSize(mediaConfig[\"m.upload.size\"]);\n            } catch (e) {\n                logger.warn(\"Failed to get media config\", e);\n            }\n        })();\n    }, [client]);\n\n    const onAvatarRemove = useCallback(async () => {\n        const removeToast = toastRack.displayToast(\n            <SpinnerToast>{_t(\"settings|general|avatar_remove_progress\")}</SpinnerToast>,\n        );\n        try {\n            await client.setAvatarUrl(\"\"); // use empty string as Synapse 500s on undefined\n            setAvatarURL(\"\");\n        } finally {\n            removeToast();\n        }\n    }, [toastRack, client]);\n\n    const onAvatarChange = useCallback(\n        async (avatarFile: File) => {\n            PosthogTrackers.trackInteraction(\"WebProfileSettingsAvatarUploadButton\");\n            logger.log(\n                `Uploading new avatar, ${avatarFile.name} of type ${avatarFile.type}, (${avatarFile.size}) bytes`,\n            );\n            const removeToast = toastRack.displayToast(\n                <SpinnerToast>{_t(\"settings|general|avatar_save_progress\")}</SpinnerToast>,\n            );\n            try {\n                setAvatarError(false);\n                const { content_uri: uri } = await client.uploadContent(avatarFile);\n                await client.setAvatarUrl(uri);\n                setAvatarURL(uri);\n            } catch (e) {\n                setAvatarError(true);\n            } finally {\n                removeToast();\n            }\n        },\n        [toastRack, client],\n    );\n\n    const onDisplayNameChanged = useCallback((e: ChangeEvent<HTMLInputElement>) => {\n        setDisplayName(e.target.value);\n    }, []);\n\n    const onDisplayNameCancel = useCallback(() => {\n        setDisplayName(OwnProfileStore.instance.displayName ?? \"\");\n    }, []);\n\n    const onDisplayNameSave = useCallback(async (): Promise<void> => {\n        try {\n            setDisplayNameError(false);\n            await client.setDisplayName(displayName);\n        } catch (e) {\n            setDisplayNameError(true);\n            throw e;\n        }\n    }, [displayName, client]);\n\n    const userIdentifier = useMemo(\n        () =>\n            UserIdentifierCustomisations.getDisplayUserIdentifier(client.getSafeUserId(), {\n                withDisplayName: true,\n            }),\n        [client],\n    );\n\n    const someFieldsDisabled = !canSetDisplayName || !canSetAvatar;\n\n    return (\n        <div className=\"mx_UserProfileSettings\">\n            <h2>{_t(\"common|profile\")}</h2>\n            <div>\n                {someFieldsDisabled\n                    ? _t(\"settings|general|profile_subtitle_oidc\")\n                    : _t(\"settings|general|profile_subtitle\")}\n            </div>\n            <div className=\"mx_UserProfileSettings_profile\">\n                <AvatarSetting\n                    avatar={avatarURL ?? undefined}\n                    avatarAltText={_t(\"common|user_avatar\")}\n                    onChange={onAvatarChange}\n                    removeAvatar={avatarURL ? onAvatarRemove : undefined}\n                    placeholderName={displayName}\n                    placeholderId={client.getUserId() ?? \"\"}\n                    disabled={!canSetAvatar}\n                />\n                <EditInPlace\n                    className=\"mx_UserProfileSettings_profile_displayName\"\n                    label={_t(\"settings|general|display_name\")}\n                    value={displayName}\n                    saveButtonLabel={_t(\"common|save\")}\n                    cancelButtonLabel={_t(\"common|cancel\")}\n                    savedLabel={_t(\"common|saved\")}\n                    savingLabel={_t(\"common|updating\")}\n                    onChange={onDisplayNameChanged}\n                    onCancel={onDisplayNameCancel}\n                    onSave={onDisplayNameSave}\n                    disabled={!canSetDisplayName}\n                >\n                    {displayNameError && <ErrorMessage>{_t(\"settings|general|display_name_error\")}</ErrorMessage>}\n                </EditInPlace>\n            </div>\n            {avatarError && (\n                <Alert title={_t(\"settings|general|avatar_upload_error_title\")} type=\"critical\">\n                    {maxUploadSize === undefined\n                        ? _t(\"settings|general|avatar_upload_error_text_generic\")\n                        : _t(\"settings|general|avatar_upload_error_text\", { size: formatBytes(maxUploadSize) })}\n                </Alert>\n            )}\n            {userIdentifier && <UsernameBox username={userIdentifier} />}\n            <Flex gap=\"var(--cpd-space-4x)\" className=\"mx_UserProfileSettings_profile_buttons\">\n                {externalAccountManagementUrl && (\n                    <ManageAccountButton externalAccountManagementUrl={externalAccountManagementUrl} />\n                )}\n                <SignOutButton />\n            </Flex>\n        </div>\n    );\n};\n\nexport default UserProfileSettings;\n"],"mappings":"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","ignoreList":[]}