payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
115 lines (114 loc) • 16 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _react = /*#__PURE__*/ _interop_require_default(require("react"));
const _reacti18next = require("react-i18next");
const _reactrouterdom = require("react-router-dom");
const _Button = /*#__PURE__*/ _interop_require_default(require("../../elements/Button"));
const _Loading = require("../../elements/Loading");
const _Form = /*#__PURE__*/ _interop_require_default(require("../../forms/Form"));
const _Submit = /*#__PURE__*/ _interop_require_default(require("../../forms/Submit"));
const _Email = /*#__PURE__*/ _interop_require_default(require("../../forms/field-types/Email"));
const _Password = /*#__PURE__*/ _interop_require_default(require("../../forms/field-types/Password"));
const _Logo = /*#__PURE__*/ _interop_require_default(require("../../graphics/Logo"));
const _Minimal = /*#__PURE__*/ _interop_require_default(require("../../templates/Minimal"));
const _Auth = require("../../utilities/Auth");
const _Config = require("../../utilities/Config");
const _Meta = /*#__PURE__*/ _interop_require_default(require("../../utilities/Meta"));
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const baseClass = 'login';
const Login = ()=>{
const history = (0, _reactrouterdom.useHistory)();
const { t } = (0, _reacti18next.useTranslation)('authentication');
const { fetchFullUser, user } = (0, _Auth.useAuth)();
const config = (0, _Config.useConfig)();
const { admin: { autoLogin, components: { afterLogin, beforeLogin } = {}, logoutRoute, user: userSlug }, collections, routes: { admin, api }, serverURL } = config;
const collection = collections.find(({ slug })=>slug === userSlug);
// Fetch 'redirect' from the query string which denotes the URL the user originally tried to visit. This is set in the Routes.tsx file when a user tries to access a protected route and is redirected to the login screen.
const query = new URLSearchParams((0, _reactrouterdom.useLocation)().search);
const redirect = query.get('redirect');
const onSuccess = async (data)=>{
if (data.token) {
await fetchFullUser();
// Ensure the redirect always starts with the admin route, and concatenate the redirect path
history.push(admin + (redirect || ''));
}
};
const prefillForm = autoLogin && autoLogin.prefillOnly;
return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, user ? // Logout
/*#__PURE__*/ _react.default.createElement(_Minimal.default, {
className: baseClass
}, /*#__PURE__*/ _react.default.createElement(_Meta.default, {
description: t('loginUser'),
keywords: t('login'),
title: t('login')
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__wrap`
}, /*#__PURE__*/ _react.default.createElement("h1", null, t('alreadyLoggedIn')), /*#__PURE__*/ _react.default.createElement("p", null, /*#__PURE__*/ _react.default.createElement(_reacti18next.Trans, {
i18nKey: "loggedIn",
t: t
}, /*#__PURE__*/ _react.default.createElement(_reactrouterdom.Link, {
to: `${admin}${logoutRoute}`
}, t('logOut')))), /*#__PURE__*/ _react.default.createElement(_Button.default, {
buttonStyle: "secondary",
el: "link",
to: admin
}, t('general:backToDashboard')))) : // Login
/*#__PURE__*/ _react.default.createElement(_Minimal.default, {
className: baseClass
}, /*#__PURE__*/ _react.default.createElement(_Meta.default, {
description: t('loginUser'),
keywords: t('login'),
title: t('login')
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__brand`
}, /*#__PURE__*/ _react.default.createElement(_Logo.default, null)), Array.isArray(beforeLogin) && beforeLogin.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, {
key: i
})), !collection?.auth?.disableLocalStrategy && /*#__PURE__*/ _react.default.createElement(_Form.default, {
action: `${serverURL}${api}/${userSlug}/login`,
className: `${baseClass}__form`,
disableSuccessStatus: true,
initialData: prefillForm ? {
email: autoLogin.email,
password: autoLogin.password
} : undefined,
method: "post",
onSuccess: onSuccess,
waitForAutocomplete: true
}, /*#__PURE__*/ _react.default.createElement(_Loading.FormLoadingOverlayToggle, {
action: "loading",
name: "login-form"
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__inputWrap`
}, /*#__PURE__*/ _react.default.createElement(_Email.default, {
admin: {
autoComplete: 'email'
},
label: t('general:email'),
name: "email",
required: true
}), /*#__PURE__*/ _react.default.createElement(_Password.default, {
autoComplete: "off",
label: t('general:password'),
name: "password",
required: true
})), /*#__PURE__*/ _react.default.createElement(_reactrouterdom.Link, {
to: `${admin}/forgot`
}, t('forgotPasswordQuestion')), /*#__PURE__*/ _react.default.createElement(_Submit.default, null, t('login'))), Array.isArray(afterLogin) && afterLogin.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, {
key: i
}))));
};
const _default = Login;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/Login/index.tsx"],"sourcesContent":["import React from 'react'\nimport { Trans, useTranslation } from 'react-i18next'\nimport { Link, useHistory, useLocation } from 'react-router-dom'\n\nimport Button from '../../elements/Button'\nimport { FormLoadingOverlayToggle } from '../../elements/Loading'\nimport Form from '../../forms/Form'\nimport FormSubmit from '../../forms/Submit'\nimport Email from '../../forms/field-types/Email'\nimport Password from '../../forms/field-types/Password'\nimport Logo from '../../graphics/Logo'\nimport MinimalTemplate from '../../templates/Minimal'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport Meta from '../../utilities/Meta'\nimport './index.scss'\n\nconst baseClass = 'login'\n\nconst Login: React.FC = () => {\n  const history = useHistory()\n  const { t } = useTranslation('authentication')\n  const { fetchFullUser, user } = useAuth()\n  const config = useConfig()\n  const {\n    admin: { autoLogin, components: { afterLogin, beforeLogin } = {}, logoutRoute, user: userSlug },\n    collections,\n    routes: { admin, api },\n    serverURL,\n  } = config\n\n  const collection = collections.find(({ slug }) => slug === userSlug)\n\n  // Fetch 'redirect' from the query string which denotes the URL the user originally tried to visit. This is set in the Routes.tsx file when a user tries to access a protected route and is redirected to the login screen.\n  const query = new URLSearchParams(useLocation().search)\n  const redirect = query.get('redirect')\n\n  const onSuccess = async (data) => {\n    if (data.token) {\n      await fetchFullUser()\n\n      // Ensure the redirect always starts with the admin route, and concatenate the redirect path\n      history.push(admin + (redirect || ''))\n    }\n  }\n\n  const prefillForm = autoLogin && autoLogin.prefillOnly\n\n  return (\n    <React.Fragment>\n      {user ? (\n        // Logout\n        <MinimalTemplate className={baseClass}>\n          <Meta description={t('loginUser')} keywords={t('login')} title={t('login')} />\n          <div className={`${baseClass}__wrap`}>\n            <h1>{t('alreadyLoggedIn')}</h1>\n            <p>\n              <Trans i18nKey=\"loggedIn\" t={t}>\n                <Link to={`${admin}${logoutRoute}`}>{t('logOut')}</Link>\n              </Trans>\n            </p>\n            <Button buttonStyle=\"secondary\" el=\"link\" to={admin}>\n              {t('general:backToDashboard')}\n            </Button>\n          </div>\n        </MinimalTemplate>\n      ) : (\n        // Login\n        <MinimalTemplate className={baseClass}>\n          <Meta description={t('loginUser')} keywords={t('login')} title={t('login')} />\n          <div className={`${baseClass}__brand`}>\n            <Logo />\n          </div>\n          {Array.isArray(beforeLogin) && beforeLogin.map((Component, i) => <Component key={i} />)}\n          {!collection?.auth?.disableLocalStrategy && (\n            <Form\n              action={`${serverURL}${api}/${userSlug}/login`}\n              className={`${baseClass}__form`}\n              disableSuccessStatus\n              initialData={\n                prefillForm\n                  ? {\n                      email: autoLogin.email,\n                      password: autoLogin.password,\n                    }\n                  : undefined\n              }\n              method=\"post\"\n              onSuccess={onSuccess}\n              waitForAutocomplete\n            >\n              <FormLoadingOverlayToggle action=\"loading\" name=\"login-form\" />\n              <div className={`${baseClass}__inputWrap`}>\n                <Email\n                  admin={{ autoComplete: 'email' }}\n                  label={t('general:email')}\n                  name=\"email\"\n                  required\n                />\n                <Password\n                  autoComplete=\"off\"\n                  label={t('general:password')}\n                  name=\"password\"\n                  required\n                />\n              </div>\n              <Link to={`${admin}/forgot`}>{t('forgotPasswordQuestion')}</Link>\n              <FormSubmit>{t('login')}</FormSubmit>\n            </Form>\n          )}\n          {Array.isArray(afterLogin) && afterLogin.map((Component, i) => <Component key={i} />)}\n        </MinimalTemplate>\n      )}\n    </React.Fragment>\n  )\n}\n\nexport default Login\n"],"names":["baseClass","Login","history","useHistory","t","useTranslation","fetchFullUser","user","useAuth","config","useConfig","admin","autoLogin","components","afterLogin","beforeLogin","logoutRoute","userSlug","collections","routes","api","serverURL","collection","find","slug","query","URLSearchParams","useLocation","search","redirect","get","onSuccess","data","token","push","prefillForm","prefillOnly","React","Fragment","MinimalTemplate","className","Meta","description","keywords","title","div","h1","p","Trans","i18nKey","Link","to","Button","buttonStyle","el","Logo","Array","isArray","map","Component","i","key","auth","disableLocalStrategy","Form","action","disableSuccessStatus","initialData","email","password","undefined","method","waitForAutocomplete","FormLoadingOverlayToggle","name","Email","autoComplete","label","required","Password","FormSubmit"],"mappings":"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"}