matrix-react-sdk
Version:
SDK for matrix.org using React
76 lines (73 loc) • 11.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.VerifyEmailModal = void 0;
var _react = _interopRequireDefault(require("react"));
var _compoundWeb = require("@vector-im/compound-web");
var _languageHandler = require("../../../../languageHandler");
var _AccessibleButton = _interopRequireDefault(require("../../../views/elements/AccessibleButton"));
var _retry16px = require("../../../../../res/img/compound/retry-16px.svg");
var _emailPrompt = require("../../../../../res/img/element-icons/email-prompt.svg");
var _useTimeoutToggle = require("../../../../hooks/useTimeoutToggle");
var _ErrorMessage = require("../../ErrorMessage");
/*
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 VerifyEmailModal = ({
email,
errorText,
onCloseClick,
onReEnterEmailClick,
onResendClick
}) => {
const {
toggle: toggleTooltipVisible,
value: tooltipVisible
} = (0, _useTimeoutToggle.useTimeoutToggle)(false, 2500);
const onResendClickFn = async () => {
await onResendClick();
toggleTooltipVisible();
};
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_emailPrompt.Icon, {
className: "mx_AuthBody_emailPromptIcon"
}), /*#__PURE__*/_react.default.createElement("h1", null, (0, _languageHandler._t)("auth|verify_email_heading")), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("auth|verify_email_explainer", {
email
}, {
b: sub => /*#__PURE__*/_react.default.createElement("strong", null, sub)
})), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AuthBody_did-not-receive"
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_VerifyEMailDialog_text-light"
}, (0, _languageHandler._t)("auth|check_email_resend_prompt")), /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, {
description: (0, _languageHandler._t)("auth|check_email_resend_tooltip"),
placement: "top",
open: tooltipVisible
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_AuthBody_resend-button",
kind: "link",
onClick: onResendClickFn
}, /*#__PURE__*/_react.default.createElement(_retry16px.Icon, {
className: "mx_Icon mx_Icon_16"
}), (0, _languageHandler._t)("action|resend"))), errorText && /*#__PURE__*/_react.default.createElement(_ErrorMessage.ErrorMessage, {
message: errorText
})), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AuthBody_did-not-receive"
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_VerifyEMailDialog_text-light"
}, (0, _languageHandler._t)("auth|check_email_wrong_email_prompt")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_AuthBody_resend-button",
kind: "link",
onClick: onReEnterEmailClick
}, (0, _languageHandler._t)("auth|check_email_wrong_email_button"))), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: onCloseClick,
className: "mx_Dialog_cancelButton",
"aria-label": (0, _languageHandler._t)("dialog_close_label")
}));
};
exports.VerifyEmailModal = VerifyEmailModal;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_compoundWeb","_languageHandler","_AccessibleButton","_retry16px","_emailPrompt","_useTimeoutToggle","_ErrorMessage","VerifyEmailModal","email","errorText","onCloseClick","onReEnterEmailClick","onResendClick","toggle","toggleTooltipVisible","value","tooltipVisible","useTimeoutToggle","onResendClickFn","default","createElement","Fragment","Icon","className","_t","b","sub","Tooltip","description","placement","open","kind","onClick","ErrorMessage","message","exports"],"sources":["../../../../../src/components/structures/auth/forgot-password/VerifyEmailModal.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 } from \"react\";\nimport { Tooltip } from \"@vector-im/compound-web\";\n\nimport { _t } from \"../../../../languageHandler\";\nimport AccessibleButton from \"../../../views/elements/AccessibleButton\";\nimport { Icon as RetryIcon } from \"../../../../../res/img/compound/retry-16px.svg\";\nimport { Icon as EmailPromptIcon } from \"../../../../../res/img/element-icons/email-prompt.svg\";\nimport { useTimeoutToggle } from \"../../../../hooks/useTimeoutToggle\";\nimport { ErrorMessage } from \"../../ErrorMessage\";\n\ninterface Props {\n    email: string;\n    errorText: ReactNode | null;\n    onFinished(): void; // This modal is weird in that the way you close it signals intent\n    onCloseClick: () => void;\n    onReEnterEmailClick: () => void;\n    onResendClick: () => Promise<boolean>;\n}\n\nexport const VerifyEmailModal: React.FC<Props> = ({\n    email,\n    errorText,\n    onCloseClick,\n    onReEnterEmailClick,\n    onResendClick,\n}) => {\n    const { toggle: toggleTooltipVisible, value: tooltipVisible } = useTimeoutToggle(false, 2500);\n\n    const onResendClickFn = async (): Promise<void> => {\n        await onResendClick();\n        toggleTooltipVisible();\n    };\n\n    return (\n        <>\n            <EmailPromptIcon className=\"mx_AuthBody_emailPromptIcon\" />\n            <h1>{_t(\"auth|verify_email_heading\")}</h1>\n            <p>\n                {_t(\n                    \"auth|verify_email_explainer\",\n                    {\n                        email,\n                    },\n                    {\n                        b: (sub) => <strong>{sub}</strong>,\n                    },\n                )}\n            </p>\n\n            <div className=\"mx_AuthBody_did-not-receive\">\n                <span className=\"mx_VerifyEMailDialog_text-light\">{_t(\"auth|check_email_resend_prompt\")}</span>\n                <Tooltip description={_t(\"auth|check_email_resend_tooltip\")} placement=\"top\" open={tooltipVisible}>\n                    <AccessibleButton className=\"mx_AuthBody_resend-button\" kind=\"link\" onClick={onResendClickFn}>\n                        <RetryIcon className=\"mx_Icon mx_Icon_16\" />\n                        {_t(\"action|resend\")}\n                    </AccessibleButton>\n                </Tooltip>\n                {errorText && <ErrorMessage message={errorText} />}\n            </div>\n\n            <div className=\"mx_AuthBody_did-not-receive\">\n                <span className=\"mx_VerifyEMailDialog_text-light\">{_t(\"auth|check_email_wrong_email_prompt\")}</span>\n                <AccessibleButton className=\"mx_AuthBody_resend-button\" kind=\"link\" onClick={onReEnterEmailClick}>\n                    {_t(\"auth|check_email_wrong_email_button\")}\n                </AccessibleButton>\n            </div>\n\n            <AccessibleButton\n                onClick={onCloseClick}\n                className=\"mx_Dialog_cancelButton\"\n                aria-label={_t(\"dialog_close_label\")}\n            />\n        </>\n    );\n};\n"],"mappings":";;;;;;;AAQA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AAEA,IAAAE,gBAAA,GAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,UAAA,GAAAJ,OAAA;AACA,IAAAK,YAAA,GAAAL,OAAA;AACA,IAAAM,iBAAA,GAAAN,OAAA;AACA,IAAAO,aAAA,GAAAP,OAAA;AAhBA;AACA;AACA;AACA;AACA;AACA;AACA;;AAqBO,MAAMQ,gBAAiC,GAAGA,CAAC;EAC9CC,KAAK;EACLC,SAAS;EACTC,YAAY;EACZC,mBAAmB;EACnBC;AACJ,CAAC,KAAK;EACF,MAAM;IAAEC,MAAM,EAAEC,oBAAoB;IAAEC,KAAK,EAAEC;EAAe,CAAC,GAAG,IAAAC,kCAAgB,EAAC,KAAK,EAAE,IAAI,CAAC;EAE7F,MAAMC,eAAe,GAAG,MAAAA,CAAA,KAA2B;IAC/C,MAAMN,aAAa,CAAC,CAAC;IACrBE,oBAAoB,CAAC,CAAC;EAC1B,CAAC;EAED,oBACIjB,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAAAvB,MAAA,CAAAsB,OAAA,CAAAE,QAAA,qBACIxB,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAAChB,YAAA,CAAAkB,IAAe;IAACC,SAAS,EAAC;EAA6B,CAAE,CAAC,eAC3D1B,MAAA,CAAAsB,OAAA,CAAAC,aAAA,aAAK,IAAAI,mBAAE,EAAC,2BAA2B,CAAM,CAAC,eAC1C3B,MAAA,CAAAsB,OAAA,CAAAC,aAAA,YACK,IAAAI,mBAAE,EACC,6BAA6B,EAC7B;IACIhB;EACJ,CAAC,EACD;IACIiB,CAAC,EAAGC,GAAG,iBAAK7B,MAAA,CAAAsB,OAAA,CAAAC,aAAA,iBAASM,GAAY;EACrC,CACJ,CACD,CAAC,eAEJ7B,MAAA,CAAAsB,OAAA,CAAAC,aAAA;IAAKG,SAAS,EAAC;EAA6B,gBACxC1B,MAAA,CAAAsB,OAAA,CAAAC,aAAA;IAAMG,SAAS,EAAC;EAAiC,GAAE,IAAAC,mBAAE,EAAC,gCAAgC,CAAQ,CAAC,eAC/F3B,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAACpB,YAAA,CAAA2B,OAAO;IAACC,WAAW,EAAE,IAAAJ,mBAAE,EAAC,iCAAiC,CAAE;IAACK,SAAS,EAAC,KAAK;IAACC,IAAI,EAAEd;EAAe,gBAC9FnB,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAAClB,iBAAA,CAAAiB,OAAgB;IAACI,SAAS,EAAC,2BAA2B;IAACQ,IAAI,EAAC,MAAM;IAACC,OAAO,EAAEd;EAAgB,gBACzFrB,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAACjB,UAAA,CAAAmB,IAAS;IAACC,SAAS,EAAC;EAAoB,CAAE,CAAC,EAC3C,IAAAC,mBAAE,EAAC,eAAe,CACL,CACb,CAAC,EACTf,SAAS,iBAAIZ,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAACd,aAAA,CAAA2B,YAAY;IAACC,OAAO,EAAEzB;EAAU,CAAE,CAChD,CAAC,eAENZ,MAAA,CAAAsB,OAAA,CAAAC,aAAA;IAAKG,SAAS,EAAC;EAA6B,gBACxC1B,MAAA,CAAAsB,OAAA,CAAAC,aAAA;IAAMG,SAAS,EAAC;EAAiC,GAAE,IAAAC,mBAAE,EAAC,qCAAqC,CAAQ,CAAC,eACpG3B,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAAClB,iBAAA,CAAAiB,OAAgB;IAACI,SAAS,EAAC,2BAA2B;IAACQ,IAAI,EAAC,MAAM;IAACC,OAAO,EAAErB;EAAoB,GAC5F,IAAAa,mBAAE,EAAC,qCAAqC,CAC3B,CACjB,CAAC,eAEN3B,MAAA,CAAAsB,OAAA,CAAAC,aAAA,CAAClB,iBAAA,CAAAiB,OAAgB;IACba,OAAO,EAAEtB,YAAa;IACtBa,SAAS,EAAC,wBAAwB;IAClC,cAAY,IAAAC,mBAAE,EAAC,oBAAoB;EAAE,CACxC,CACH,CAAC;AAEX,CAAC;AAACW,OAAA,CAAA5B,gBAAA,GAAAA,gBAAA","ignoreList":[]}