payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
192 lines (191 loc) • 18.8 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_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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"}