UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

192 lines (191 loc) • 18.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _reacttoastify = require("react-toastify"); const _Button = /*#__PURE__*/ _interop_require_default(require("../../../../elements/Button")); const _context = require("../../../../forms/Form/context"); const _Checkbox = /*#__PURE__*/ _interop_require_default(require("../../../../forms/field-types/Checkbox")); const _ConfirmPassword = /*#__PURE__*/ _interop_require_default(require("../../../../forms/field-types/ConfirmPassword")); const _Email = /*#__PURE__*/ _interop_require_default(require("../../../../forms/field-types/Email")); const _Password = /*#__PURE__*/ _interop_require_default(require("../../../../forms/field-types/Password")); const _Config = require("../../../../utilities/Config"); const _APIKey = /*#__PURE__*/ _interop_require_default(require("./APIKey")); require("./index.scss"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interop_require_wildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = { __proto__: null }; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for(var key in obj){ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } const baseClass = 'auth-fields'; const Auth = (props)=>{ const { className, collection, collection: { slug }, email, operation, readOnly, requirePassword, useAPIKey, verify } = props; const [changingPassword, setChangingPassword] = (0, _react.useState)(requirePassword); const enableAPIKey = (0, _context.useFormFields)(([fields])=>fields.enableAPIKey); const dispatchFields = (0, _context.useFormFields)((reducer)=>reducer[1]); const modified = (0, _context.useFormModified)(); const { i18n, t } = (0, _reacti18next.useTranslation)('authentication'); const { routes: { api }, serverURL } = (0, _Config.useConfig)(); const handleChangePassword = (0, _react.useCallback)(async (state)=>{ if (!state) { dispatchFields({ path: 'password', type: 'REMOVE' }); dispatchFields({ path: 'confirm-password', type: 'REMOVE' }); } setChangingPassword(state); }, [ dispatchFields ]); const unlock = (0, _react.useCallback)(async ()=>{ const url = `${serverURL}${api}/${slug}/unlock`; const response = await fetch(url, { body: JSON.stringify({ email }), credentials: 'include', headers: { 'Accept-Language': i18n.language, 'Content-Type': 'application/json' }, method: 'post' }); if (response.status === 200) { _reacttoastify.toast.success(t('successfullyUnlocked'), { autoClose: 3000 }); } else { _reacttoastify.toast.error(t('failedToUnlock')); } }, [ i18n, serverURL, api, slug, email, t ]); (0, _react.useEffect)(()=>{ if (!modified) { setChangingPassword(false); } }, [ modified ]); if (collection.auth.disableLocalStrategy && !collection.auth.useAPIKey) { return null; } return /*#__PURE__*/ _react.default.createElement("div", { className: [ baseClass, className ].filter(Boolean).join(' ') }, !collection.auth.disableLocalStrategy && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_Email.default, { admin: { autoComplete: 'email', readOnly }, label: t('general:email'), name: "email", required: true }), (changingPassword || requirePassword) && /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__changing-password` }, /*#__PURE__*/ _react.default.createElement(_Password.default, { autoComplete: "off", disabled: readOnly, label: t('newPassword'), name: "password", required: true }), /*#__PURE__*/ _react.default.createElement(_ConfirmPassword.default, { disabled: readOnly }), !requirePassword && /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "secondary", disabled: readOnly, onClick: ()=>handleChangePassword(false), size: "small" }, t('general:cancel'))), (!changingPassword && !requirePassword || operation === 'update') && /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__controls` }, !changingPassword && !requirePassword && /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "secondary", disabled: readOnly, id: "change-password", onClick: ()=>handleChangePassword(true), size: "small" }, t('changePassword')), operation === 'update' && /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "secondary", disabled: readOnly, onClick: ()=>unlock(), size: "small" }, t('forceUnlock')))), useAPIKey && /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__api-key` }, /*#__PURE__*/ _react.default.createElement(_Checkbox.default, { admin: { readOnly }, label: t('enableAPIKey'), name: "enableAPIKey" }), enableAPIKey?.value && /*#__PURE__*/ _react.default.createElement(_APIKey.default, { readOnly: readOnly })), verify && /*#__PURE__*/ _react.default.createElement(_Checkbox.default, { admin: { readOnly }, label: t('verified'), name: "_verified" })); }; const _default = Auth; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/admin/components/views/collections/Edit/Auth/index.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { toast } from 'react-toastify'\n\nimport type { Props } from './types'\n\nimport Button from '../../../../elements/Button'\nimport { useFormFields, useFormModified } from '../../../../forms/Form/context'\nimport Checkbox from '../../../../forms/field-types/Checkbox'\nimport ConfirmPassword from '../../../../forms/field-types/ConfirmPassword'\nimport Email from '../../../../forms/field-types/Email'\nimport Password from '../../../../forms/field-types/Password'\nimport { useConfig } from '../../../../utilities/Config'\nimport APIKey from './APIKey'\nimport './index.scss'\n\nconst baseClass = 'auth-fields'\n\nconst Auth: React.FC<Props> = (props) => {\n  const {\n    className,\n    collection,\n    collection: { slug },\n    email,\n    operation,\n    readOnly,\n    requirePassword,\n    useAPIKey,\n    verify,\n  } = props\n\n  const [changingPassword, setChangingPassword] = useState(requirePassword)\n  const enableAPIKey = useFormFields(([fields]) => fields.enableAPIKey)\n  const dispatchFields = useFormFields((reducer) => reducer[1])\n  const modified = useFormModified()\n  const { i18n, t } = useTranslation('authentication')\n\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n\n  const handleChangePassword = useCallback(\n    async (state: boolean) => {\n      if (!state) {\n        dispatchFields({ path: 'password', type: 'REMOVE' })\n        dispatchFields({ path: 'confirm-password', type: 'REMOVE' })\n      }\n\n      setChangingPassword(state)\n    },\n    [dispatchFields],\n  )\n\n  const unlock = useCallback(async () => {\n    const url = `${serverURL}${api}/${slug}/unlock`\n    const response = await fetch(url, {\n      body: JSON.stringify({\n        email,\n      }),\n      credentials: 'include',\n      headers: {\n        'Accept-Language': i18n.language,\n        'Content-Type': 'application/json',\n      },\n      method: 'post',\n    })\n\n    if (response.status === 200) {\n      toast.success(t('successfullyUnlocked'), { autoClose: 3000 })\n    } else {\n      toast.error(t('failedToUnlock'))\n    }\n  }, [i18n, serverURL, api, slug, email, t])\n\n  useEffect(() => {\n    if (!modified) {\n      setChangingPassword(false)\n    }\n  }, [modified])\n\n  if (collection.auth.disableLocalStrategy && !collection.auth.useAPIKey) {\n    return null\n  }\n\n  return (\n    <div className={[baseClass, className].filter(Boolean).join(' ')}>\n      {!collection.auth.disableLocalStrategy && (\n        <React.Fragment>\n          <Email\n            admin={{ autoComplete: 'email', readOnly }}\n            label={t('general:email')}\n            name=\"email\"\n            required\n          />\n          {(changingPassword || requirePassword) && (\n            <div className={`${baseClass}__changing-password`}>\n              <Password\n                autoComplete=\"off\"\n                disabled={readOnly}\n                label={t('newPassword')}\n                name=\"password\"\n                required\n              />\n              <ConfirmPassword disabled={readOnly} />\n              {!requirePassword && (\n                <Button\n                  buttonStyle=\"secondary\"\n                  disabled={readOnly}\n                  onClick={() => handleChangePassword(false)}\n                  size=\"small\"\n                >\n                  {t('general:cancel')}\n                </Button>\n              )}\n            </div>\n          )}\n          {((!changingPassword && !requirePassword) || operation === 'update') && (\n            <div className={`${baseClass}__controls`}>\n              {!changingPassword && !requirePassword && (\n                <Button\n                  buttonStyle=\"secondary\"\n                  disabled={readOnly}\n                  id=\"change-password\"\n                  onClick={() => handleChangePassword(true)}\n                  size=\"small\"\n                >\n                  {t('changePassword')}\n                </Button>\n              )}\n              {operation === 'update' && (\n                <Button\n                  buttonStyle=\"secondary\"\n                  disabled={readOnly}\n                  onClick={() => unlock()}\n                  size=\"small\"\n                >\n                  {t('forceUnlock')}\n                </Button>\n              )}\n            </div>\n          )}\n        </React.Fragment>\n      )}\n      {useAPIKey && (\n        <div className={`${baseClass}__api-key`}>\n          <Checkbox admin={{ readOnly }} label={t('enableAPIKey')} name=\"enableAPIKey\" />\n          {enableAPIKey?.value && <APIKey readOnly={readOnly} />}\n        </div>\n      )}\n      {verify && <Checkbox admin={{ readOnly }} label={t('verified')} name=\"_verified\" />}\n    </div>\n  )\n}\n\nexport default Auth\n"],"names":["baseClass","Auth","props","className","collection","slug","email","operation","readOnly","requirePassword","useAPIKey","verify","changingPassword","setChangingPassword","useState","enableAPIKey","useFormFields","fields","dispatchFields","reducer","modified","useFormModified","i18n","t","useTranslation","routes","api","serverURL","useConfig","handleChangePassword","useCallback","state","path","type","unlock","url","response","fetch","body","JSON","stringify","credentials","headers","language","method","status","toast","success","autoClose","error","useEffect","auth","disableLocalStrategy","div","filter","Boolean","join","React","Fragment","Email","admin","autoComplete","label","name","required","Password","disabled","ConfirmPassword","Button","buttonStyle","onClick","size","id","Checkbox","value","APIKey"],"mappings":"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"}