matrix-react-sdk
Version:
SDK for matrix.org using React
119 lines (116 loc) • 20.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.DeviceDetailHeading = void 0;
var _react = _interopRequireWildcard(require("react"));
var _languageHandler = require("../../../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("../../elements/AccessibleButton"));
var _Field = _interopRequireDefault(require("../../elements/Field"));
var _LearnMore = _interopRequireDefault(require("../../elements/LearnMore"));
var _Spinner = _interopRequireDefault(require("../../elements/Spinner"));
var _Caption = require("../../typography/Caption");
var _Heading = _interopRequireDefault(require("../../typography/Heading"));
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 2022 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 DeviceNameEditor = ({
device,
saveDeviceName,
stopEditing
}) => {
const [deviceName, setDeviceName] = (0, _react.useState)(device.display_name || "");
const [isLoading, setIsLoading] = (0, _react.useState)(false);
const [error, setError] = (0, _react.useState)(null);
(0, _react.useEffect)(() => {
setDeviceName(device.display_name || "");
}, [device.display_name]);
const onInputChange = event => setDeviceName(event.target.value);
const onSubmit = async event => {
setIsLoading(true);
setError(null);
event.preventDefault();
try {
await saveDeviceName(deviceName);
stopEditing();
} catch (error) {
setError((0, _languageHandler._t)("settings|sessions|error_set_name"));
setIsLoading(false);
}
};
const headingId = `device-rename-${device.device_id}`;
const descriptionId = `device-rename-description-${device.device_id}`;
return /*#__PURE__*/_react.default.createElement("form", {
"aria-disabled": isLoading,
className: "mx_DeviceDetailHeading_renameForm",
onSubmit: onSubmit,
method: "post"
}, /*#__PURE__*/_react.default.createElement("p", {
id: headingId,
className: "mx_DeviceDetailHeading_renameFormHeading"
}, (0, _languageHandler._t)("settings|sessions|rename_form_heading")), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_Field.default, {
"data-testid": "device-rename-input",
type: "text",
value: deviceName,
autoComplete: "off",
onChange: onInputChange,
autoFocus: true,
disabled: isLoading,
"aria-labelledby": headingId,
"aria-describedby": descriptionId,
className: "mx_DeviceDetailHeading_renameFormInput",
maxLength: 100
}), /*#__PURE__*/_react.default.createElement(_Caption.Caption, {
id: descriptionId
}, (0, _languageHandler._t)("settings|sessions|rename_form_caption"), /*#__PURE__*/_react.default.createElement(_LearnMore.default, {
title: (0, _languageHandler._t)("settings|sessions|rename_form_learn_more"),
description: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("settings|sessions|rename_form_learn_more_description_1")), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("settings|sessions|rename_form_learn_more_description_2")))
}), !!error && /*#__PURE__*/_react.default.createElement("span", {
"data-testid": "device-rename-error",
className: "mx_DeviceDetailHeading_renameFormError"
}, error))), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_DeviceDetailHeading_renameFormButtons"
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: onSubmit,
kind: "primary",
"data-testid": "device-rename-submit-cta",
disabled: isLoading
}, (0, _languageHandler._t)("action|save")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: stopEditing,
kind: "secondary",
"data-testid": "device-rename-cancel-cta",
disabled: isLoading
}, (0, _languageHandler._t)("action|cancel")), isLoading && /*#__PURE__*/_react.default.createElement(_Spinner.default, {
w: 16,
h: 16
})));
};
const DeviceDetailHeading = ({
device,
saveDeviceName
}) => {
const [isEditing, setIsEditing] = (0, _react.useState)(false);
return isEditing ? /*#__PURE__*/_react.default.createElement(DeviceNameEditor, {
device: device,
saveDeviceName: saveDeviceName,
stopEditing: () => setIsEditing(false)
}) : /*#__PURE__*/_react.default.createElement("div", {
className: "mx_DeviceDetailHeading",
"data-testid": "device-detail-heading"
}, /*#__PURE__*/_react.default.createElement(_Heading.default, {
size: "4"
}, device.display_name || device.device_id), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
kind: "link_inline",
onClick: () => setIsEditing(true),
className: "mx_DeviceDetailHeading_renameCta",
"data-testid": "device-heading-rename-cta"
}, (0, _languageHandler._t)("action|rename")));
};
exports.DeviceDetailHeading = DeviceDetailHeading;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_languageHandler","_AccessibleButton","_interopRequireDefault","_Field","_LearnMore","_Spinner","_Caption","_Heading","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DeviceNameEditor","device","saveDeviceName","stopEditing","deviceName","setDeviceName","useState","display_name","isLoading","setIsLoading","error","setError","useEffect","onInputChange","event","target","value","onSubmit","preventDefault","_t","headingId","device_id","descriptionId","createElement","className","method","id","type","autoComplete","onChange","autoFocus","disabled","maxLength","Caption","title","description","Fragment","onClick","kind","w","h","DeviceDetailHeading","isEditing","setIsEditing","size","exports"],"sources":["../../../../../src/components/views/settings/devices/DeviceDetailHeading.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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, { useEffect, useState } from \"react\";\n\nimport { _t } from \"../../../../languageHandler\";\nimport AccessibleButton, { ButtonEvent } from \"../../elements/AccessibleButton\";\nimport Field from \"../../elements/Field\";\nimport LearnMore from \"../../elements/LearnMore\";\nimport Spinner from \"../../elements/Spinner\";\nimport { Caption } from \"../../typography/Caption\";\nimport Heading from \"../../typography/Heading\";\nimport { ExtendedDevice } from \"./types\";\n\ninterface Props {\n    device: ExtendedDevice;\n    saveDeviceName: (deviceName: string) => Promise<void>;\n}\n\nconst DeviceNameEditor: React.FC<Props & { stopEditing: () => void }> = ({ device, saveDeviceName, stopEditing }) => {\n    const [deviceName, setDeviceName] = useState(device.display_name || \"\");\n    const [isLoading, setIsLoading] = useState(false);\n    const [error, setError] = useState<string | null>(null);\n\n    useEffect(() => {\n        setDeviceName(device.display_name || \"\");\n    }, [device.display_name]);\n\n    const onInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => setDeviceName(event.target.value);\n\n    const onSubmit = async (event: ButtonEvent): Promise<void> => {\n        setIsLoading(true);\n        setError(null);\n        event.preventDefault();\n        try {\n            await saveDeviceName(deviceName);\n            stopEditing();\n        } catch (error) {\n            setError(_t(\"settings|sessions|error_set_name\"));\n            setIsLoading(false);\n        }\n    };\n\n    const headingId = `device-rename-${device.device_id}`;\n    const descriptionId = `device-rename-description-${device.device_id}`;\n\n    return (\n        <form aria-disabled={isLoading} className=\"mx_DeviceDetailHeading_renameForm\" onSubmit={onSubmit} method=\"post\">\n            <p id={headingId} className=\"mx_DeviceDetailHeading_renameFormHeading\">\n                {_t(\"settings|sessions|rename_form_heading\")}\n            </p>\n            <div>\n                <Field\n                    data-testid=\"device-rename-input\"\n                    type=\"text\"\n                    value={deviceName}\n                    autoComplete=\"off\"\n                    onChange={onInputChange}\n                    autoFocus\n                    disabled={isLoading}\n                    aria-labelledby={headingId}\n                    aria-describedby={descriptionId}\n                    className=\"mx_DeviceDetailHeading_renameFormInput\"\n                    maxLength={100}\n                />\n                <Caption id={descriptionId}>\n                    {_t(\"settings|sessions|rename_form_caption\")}\n                    <LearnMore\n                        title={_t(\"settings|sessions|rename_form_learn_more\")}\n                        description={\n                            <>\n                                <p>{_t(\"settings|sessions|rename_form_learn_more_description_1\")}</p>\n                                <p>{_t(\"settings|sessions|rename_form_learn_more_description_2\")}</p>\n                            </>\n                        }\n                    />\n                    {!!error && (\n                        <span data-testid=\"device-rename-error\" className=\"mx_DeviceDetailHeading_renameFormError\">\n                            {error}\n                        </span>\n                    )}\n                </Caption>\n            </div>\n            <div className=\"mx_DeviceDetailHeading_renameFormButtons\">\n                <AccessibleButton\n                    onClick={onSubmit}\n                    kind=\"primary\"\n                    data-testid=\"device-rename-submit-cta\"\n                    disabled={isLoading}\n                >\n                    {_t(\"action|save\")}\n                </AccessibleButton>\n                <AccessibleButton\n                    onClick={stopEditing}\n                    kind=\"secondary\"\n                    data-testid=\"device-rename-cancel-cta\"\n                    disabled={isLoading}\n                >\n                    {_t(\"action|cancel\")}\n                </AccessibleButton>\n                {isLoading && <Spinner w={16} h={16} />}\n            </div>\n        </form>\n    );\n};\n\nexport const DeviceDetailHeading: React.FC<Props> = ({ device, saveDeviceName }) => {\n    const [isEditing, setIsEditing] = useState(false);\n\n    return isEditing ? (\n        <DeviceNameEditor device={device} saveDeviceName={saveDeviceName} stopEditing={() => setIsEditing(false)} />\n    ) : (\n        <div className=\"mx_DeviceDetailHeading\" data-testid=\"device-detail-heading\">\n            <Heading size=\"4\">{device.display_name || device.device_id}</Heading>\n            <AccessibleButton\n                kind=\"link_inline\"\n                onClick={() => setIsEditing(true)}\n                className=\"mx_DeviceDetailHeading_renameCta\"\n                data-testid=\"device-heading-rename-cta\"\n            >\n                {_t(\"action|rename\")}\n            </AccessibleButton>\n        </div>\n    );\n};\n"],"mappings":"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","ignoreList":[]}