@rtbjs/use-state
Version:
`@rtbjs/use-state` is a state management tool that can act as a local state and be easily turned into a global redux state. It is an innovative approach to state management that combines the advantages of both React's useState and Redux's state management
60 lines • 3.55 kB
JavaScript
"use strict";
exports.__esModule = true;
var tslib_1 = require("tslib");
var jsx_runtime_1 = require("react/jsx-runtime");
var react_1 = require("react");
var react_router_dom_1 = require("react-router-dom");
var react_toastify_1 = require("react-toastify");
var auth_api_1 = require("../redux/api/auth-api");
var react_router_dom_2 = require("react-router-dom");
var antd_1 = require("antd");
var use_is_form_submittable_1 = require("../components/ui/form/use-is-form-submittable");
var login_page_styles_1 = require("./login.page/login.page.styles");
var icons_1 = require("@ant-design/icons");
var ForgotPasswordPage = function () {
var form = antd_1.Form.useForm()[0];
// 👇 API Login Mutation
var _a = (0, auth_api_1.useForgotPasswordMutation)(), forgotPassword = _a[0], _b = _a[1], isLoading = _b.isLoading, isError = _b.isError, error = _b.error, isSuccess = _b.isSuccess;
var navigate = (0, react_router_dom_2.useNavigate)();
(0, react_1.useEffect)(function () {
if (isSuccess) {
react_toastify_1.toast.success("We've sent you a token for resetting password.");
navigate('/resetpassword');
}
if (isError) {
if (Array.isArray(error.data.error)) {
error.data.error.forEach(function (el) {
return react_toastify_1.toast.error(el.message, {
position: 'top-right'
});
});
}
else {
react_toastify_1.toast.error(error.data.message, {
position: 'top-right'
});
}
}
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [isLoading]);
var onSubmitHandler = function (_a) {
var email = _a.email;
// 👇 Executing the forgotPassword Mutation
forgotPassword({ email: email });
};
var isSubmittable = (0, use_is_form_submittable_1.useIsFormSubmittable)({ form: form }).isSubmittable;
return ((0, jsx_runtime_1.jsxs)(login_page_styles_1.Container, { children: [(0, jsx_runtime_1.jsx)(antd_1.Typography.Title, { children: "Reset Password" }), (0, jsx_runtime_1.jsxs)(antd_1.Form, tslib_1.__assign({ name: "login", style: {
maxWidth: 300
}, onFinish: onSubmitHandler, autoComplete: "off", form: form }, { children: [(0, jsx_runtime_1.jsx)(antd_1.Form.Item, tslib_1.__assign({ name: "email", messageVariables: { name: 'Email' }, rules: [
{
type: 'email',
message: 'The input is not valid E-mail!'
},
{
required: true,
message: 'Please input your E-mail!'
},
] }, { children: (0, jsx_runtime_1.jsx)(antd_1.Input, { prefix: (0, jsx_runtime_1.jsx)(icons_1.MailOutlined, {}), placeholder: "Email" }) })), (0, jsx_runtime_1.jsx)(antd_1.Form.Item, { children: (0, jsx_runtime_1.jsx)(login_page_styles_1.SubmitButton, tslib_1.__assign({ type: "primary", htmlType: "submit", disabled: !isSubmittable }, { children: "Retrieve password" })) }), "Or", ' ', (0, jsx_runtime_1.jsx)(antd_1.Typography.Link, { children: (0, jsx_runtime_1.jsx)(react_router_dom_1.Link, tslib_1.__assign({ to: "/login" }, { children: "Back to login" })) })] }))] }));
};
exports["default"] = ForgotPasswordPage;
//# sourceMappingURL=forgot-password.page.js.map