UNPKG

matrix-react-sdk

Version:
97 lines (94 loc) 15.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.EnterEmail = void 0; var _react = _interopRequireWildcard(require("react")); var _icons = require("@vector-im/compound-design-tokens/assets/web/icons"); var _languageHandler = require("../../../../languageHandler"); var _EmailField = _interopRequireDefault(require("../../../views/auth/EmailField")); var _ErrorMessage = require("../../ErrorMessage"); var _Spinner = _interopRequireDefault(require("../../../views/elements/Spinner")); var _AccessibleButton = _interopRequireDefault(require("../../../views/elements/AccessibleButton")); 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. */ /** * This component renders the email input view of the forgot password flow. */ const EnterEmail = ({ email, errorText, homeserver, loading, onInputChanged, onLoginClick, onSubmitForm }) => { const submitButtonChild = loading ? /*#__PURE__*/_react.default.createElement(_Spinner.default, { w: 16, h: 16 }) : (0, _languageHandler._t)("auth|forgot_password_send_email"); const emailFieldRef = (0, _react.useRef)(null); const onSubmit = async event => { if (await emailFieldRef.current?.validate({ allowEmpty: false })) { onSubmitForm(event); return; } emailFieldRef.current?.focus(); emailFieldRef.current?.validate({ allowEmpty: false, focused: true }); }; return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_icons.EmailSolidIcon, { className: "mx_AuthBody_icon" }), /*#__PURE__*/_react.default.createElement("h1", null, (0, _languageHandler._t)("auth|enter_email_heading")), /*#__PURE__*/_react.default.createElement("p", { className: "mx_AuthBody_text" }, (0, _languageHandler._t)("auth|enter_email_explainer", { homeserver }, { b: t => /*#__PURE__*/_react.default.createElement("strong", null, t) })), /*#__PURE__*/_react.default.createElement("form", { onSubmit: onSubmit }, /*#__PURE__*/_react.default.createElement("fieldset", { disabled: loading }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_AuthBody_fieldRow" }, /*#__PURE__*/_react.default.createElement(_EmailField.default, { name: "reset_email" // define a name so browser's password autofill gets less confused , label: (0, _languageHandler._td)("common|email_address"), labelRequired: (0, _languageHandler._td)("auth|forgot_password_email_required"), labelInvalid: (0, _languageHandler._td)("auth|forgot_password_email_invalid"), value: email, autoFocus: true, onChange: event => onInputChanged("email", event), fieldRef: emailFieldRef })), errorText && /*#__PURE__*/_react.default.createElement(_ErrorMessage.ErrorMessage, { message: errorText }), /*#__PURE__*/_react.default.createElement("button", { type: "submit", className: "mx_Login_submit" }, submitButtonChild), /*#__PURE__*/_react.default.createElement("div", { className: "mx_AuthBody_button-container" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_AuthBody_sign-in-instead-button", element: "button", kind: "link", onClick: e => { e.preventDefault(); onLoginClick(); } }, (0, _languageHandler._t)("auth|sign_in_instead")))))); }; exports.EnterEmail = EnterEmail; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_icons","_languageHandler","_EmailField","_interopRequireDefault","_ErrorMessage","_Spinner","_AccessibleButton","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","EnterEmail","email","errorText","homeserver","loading","onInputChanged","onLoginClick","onSubmitForm","submitButtonChild","createElement","w","h","_t","emailFieldRef","useRef","onSubmit","event","current","validate","allowEmpty","focus","focused","Fragment","EmailSolidIcon","className","b","disabled","name","label","_td","labelRequired","labelInvalid","value","autoFocus","onChange","fieldRef","ErrorMessage","message","type","element","kind","onClick","preventDefault","exports"],"sources":["../../../../../src/components/structures/auth/forgot-password/EnterEmail.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, { ReactNode, useRef } from \"react\";\nimport { EmailSolidIcon } from \"@vector-im/compound-design-tokens/assets/web/icons\";\n\nimport { _t, _td } from \"../../../../languageHandler\";\nimport EmailField from \"../../../views/auth/EmailField\";\nimport { ErrorMessage } from \"../../ErrorMessage\";\nimport Spinner from \"../../../views/elements/Spinner\";\nimport Field from \"../../../views/elements/Field\";\nimport AccessibleButton, { ButtonEvent } from \"../../../views/elements/AccessibleButton\";\n\ninterface EnterEmailProps {\n    email: string;\n    errorText: string | ReactNode | null;\n    homeserver: string;\n    loading: boolean;\n    onInputChanged: (stateKey: \"email\", ev: React.FormEvent<HTMLInputElement>) => void;\n    onLoginClick: () => void;\n    onSubmitForm: (ev: React.FormEvent) => void;\n}\n\n/**\n * This component renders the email input view of the forgot password flow.\n */\nexport const EnterEmail: React.FC<EnterEmailProps> = ({\n    email,\n    errorText,\n    homeserver,\n    loading,\n    onInputChanged,\n    onLoginClick,\n    onSubmitForm,\n}) => {\n    const submitButtonChild = loading ? <Spinner w={16} h={16} /> : _t(\"auth|forgot_password_send_email\");\n\n    const emailFieldRef = useRef<Field>(null);\n\n    const onSubmit = async (event: React.FormEvent): Promise<void> => {\n        if (await emailFieldRef.current?.validate({ allowEmpty: false })) {\n            onSubmitForm(event);\n            return;\n        }\n\n        emailFieldRef.current?.focus();\n        emailFieldRef.current?.validate({ allowEmpty: false, focused: true });\n    };\n\n    return (\n        <>\n            <EmailSolidIcon className=\"mx_AuthBody_icon\" />\n            <h1>{_t(\"auth|enter_email_heading\")}</h1>\n            <p className=\"mx_AuthBody_text\">\n                {_t(\"auth|enter_email_explainer\", { homeserver }, { b: (t) => <strong>{t}</strong> })}\n            </p>\n            <form onSubmit={onSubmit}>\n                <fieldset disabled={loading}>\n                    <div className=\"mx_AuthBody_fieldRow\">\n                        <EmailField\n                            name=\"reset_email\" // define a name so browser's password autofill gets less confused\n                            label={_td(\"common|email_address\")}\n                            labelRequired={_td(\"auth|forgot_password_email_required\")}\n                            labelInvalid={_td(\"auth|forgot_password_email_invalid\")}\n                            value={email}\n                            autoFocus={true}\n                            onChange={(event: React.FormEvent<HTMLInputElement>) => onInputChanged(\"email\", event)}\n                            fieldRef={emailFieldRef}\n                        />\n                    </div>\n                    {errorText && <ErrorMessage message={errorText} />}\n                    <button type=\"submit\" className=\"mx_Login_submit\">\n                        {submitButtonChild}\n                    </button>\n                    <div className=\"mx_AuthBody_button-container\">\n                        <AccessibleButton\n                            className=\"mx_AuthBody_sign-in-instead-button\"\n                            element=\"button\"\n                            kind=\"link\"\n                            onClick={(e: ButtonEvent) => {\n                                e.preventDefault();\n                                onLoginClick();\n                            }}\n                        >\n                            {_t(\"auth|sign_in_instead\")}\n                        </AccessibleButton>\n                    </div>\n                </fieldset>\n            </form>\n        </>\n    );\n};\n"],"mappings":"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","ignoreList":[]}