UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

115 lines (114 loc) • 16 kB
"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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"}