UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

158 lines (157 loc) • 16.4 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = require("react"); const _reacti18next = require("react-i18next"); const _useThrottledEffect = /*#__PURE__*/ _interop_require_default(require("../../../hooks/useThrottledEffect")); const _Auth = require("../../utilities/Auth"); const _Config = require("../../utilities/Config"); const _DocumentInfo = require("../../utilities/DocumentInfo"); const _OperationProvider = require("../../utilities/OperationProvider"); const _context = require("../Form/context"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * Get and set the value of a form field. * * @see https://payloadcms.com/docs/admin/hooks#usefield */ const useField = (options)=>{ const { condition, disableFormData = false, hasRows, path, validate } = options; const submitted = (0, _context.useFormSubmitted)(); const processing = (0, _context.useFormProcessing)(); const { user } = (0, _Auth.useAuth)(); const { id } = (0, _DocumentInfo.useDocumentInfo)(); const operation = (0, _OperationProvider.useOperation)(); const field = (0, _context.useFormFields)(([fields])=>fields[path]); const { t } = (0, _reacti18next.useTranslation)(); const dispatchField = (0, _context.useFormFields)(([_, dispatch])=>dispatch); const config = (0, _Config.useConfig)(); const { getData, getDataByPath, getSiblingData, setModified } = (0, _context.useForm)(); const value = field?.value; const initialValue = field?.initialValue; const valid = typeof field?.valid === 'boolean' ? field.valid : true; const showError = valid === false && submitted; const prevValid = (0, _react.useRef)(valid); // Method to return from `useField`, used to // update field values from field component(s) const setValue = (0, _react.useCallback)((e, disableModifyingForm = false)=>{ const val = e && e.target ? e.target.value : e; if (!disableModifyingForm) { if (typeof setModified === 'function') { // Update modified state after field value comes back // to avoid cursor jump caused by state value / DOM mismatch setTimeout(()=>{ setModified(true); }, 10); } } dispatchField({ disableFormData: disableFormData || hasRows && val > 0, path, type: 'UPDATE', value: val }); }, [ setModified, path, dispatchField, disableFormData, hasRows ]); // Store result from hook as ref // to prevent unnecessary rerenders const result = (0, _react.useMemo)(()=>({ errorMessage: field?.errorMessage, formProcessing: processing, formSubmitted: submitted, initialValue, rows: field?.rows, setValue, showError, valid: field?.valid, value }), [ field?.errorMessage, field?.rows, field?.valid, processing, setValue, showError, submitted, value, initialValue ]); // Throttle the validate function (0, _useThrottledEffect.default)(()=>{ const validateField = async ()=>{ let valueToValidate = value; if (field?.rows && Array.isArray(field.rows)) { valueToValidate = getDataByPath(path); } let errorMessage; let valid = false; const validationResult = typeof validate === 'function' ? await validate(valueToValidate, { id, config, data: getData(), operation, siblingData: getSiblingData(path), t, user }) : true; if (typeof validationResult === 'string') { errorMessage = validationResult; valid = false; } else { valid = validationResult; errorMessage = undefined; } // Only dispatch if the validation result has changed // This will prevent unnecessary rerenders if (valid !== prevValid.current) { prevValid.current = valid; if (typeof dispatchField === 'function') { dispatchField({ condition, disableFormData: disableFormData || (hasRows ? typeof value === 'number' && value > 0 : false), errorMessage, path, rows: field?.rows, type: 'UPDATE', valid, validate, value }); } } }; void validateField(); }, 150, [ value, condition, disableFormData, dispatchField, getData, getSiblingData, getDataByPath, id, operation, path, user, validate, field?.rows ]); return result; }; const _default = useField; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/forms/useField/index.tsx"],"sourcesContent":["import { useCallback, useMemo, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { FieldType, Options } from './types'\n\nimport useThrottledEffect from '../../../hooks/useThrottledEffect'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { useOperation } from '../../utilities/OperationProvider'\nimport { useForm, useFormFields, useFormProcessing, useFormSubmitted } from '../Form/context'\n\n/**\n * Get and set the value of a form field.\n *\n * @see https://payloadcms.com/docs/admin/hooks#usefield\n */\nconst useField = <T,>(options: Options): FieldType<T> => {\n  const { condition, disableFormData = false, hasRows, path, validate } = options\n\n  const submitted = useFormSubmitted()\n  const processing = useFormProcessing()\n  const { user } = useAuth()\n  const { id } = useDocumentInfo()\n  const operation = useOperation()\n  const field = useFormFields(([fields]) => fields[path])\n  const { t } = useTranslation()\n  const dispatchField = useFormFields(([_, dispatch]) => dispatch)\n  const config = useConfig()\n\n  const { getData, getDataByPath, getSiblingData, setModified } = useForm()\n\n  const value = field?.value as T\n  const initialValue = field?.initialValue as T\n  const valid = typeof field?.valid === 'boolean' ? field.valid : true\n  const showError = valid === false && submitted\n\n  const prevValid = useRef(valid)\n\n  // Method to return from `useField`, used to\n  // update field values from field component(s)\n  const setValue = useCallback(\n    (e, disableModifyingForm = false) => {\n      const val = e && e.target ? e.target.value : e\n\n      if (!disableModifyingForm) {\n        if (typeof setModified === 'function') {\n          // Update modified state after field value comes back\n          // to avoid cursor jump caused by state value / DOM mismatch\n          setTimeout(() => {\n            setModified(true)\n          }, 10)\n        }\n      }\n\n      dispatchField({\n        disableFormData: disableFormData || (hasRows && val > 0),\n        path,\n        type: 'UPDATE',\n        value: val,\n      })\n    },\n    [setModified, path, dispatchField, disableFormData, hasRows],\n  )\n\n  // Store result from hook as ref\n  // to prevent unnecessary rerenders\n  const result: FieldType<T> = useMemo(\n    () => ({\n      errorMessage: field?.errorMessage,\n      formProcessing: processing,\n      formSubmitted: submitted,\n      initialValue,\n      rows: field?.rows,\n      setValue,\n      showError,\n      valid: field?.valid,\n      value,\n    }),\n    [\n      field?.errorMessage,\n      field?.rows,\n      field?.valid,\n      processing,\n      setValue,\n      showError,\n      submitted,\n      value,\n      initialValue,\n    ],\n  )\n\n  // Throttle the validate function\n  useThrottledEffect(\n    () => {\n      const validateField = async () => {\n        let valueToValidate = value\n\n        if (field?.rows && Array.isArray(field.rows)) {\n          valueToValidate = getDataByPath(path)\n        }\n\n        let errorMessage: string | undefined\n        let valid: boolean | string = false\n\n        const validationResult =\n          typeof validate === 'function'\n            ? await validate(valueToValidate, {\n                id,\n                config,\n                data: getData(),\n                operation,\n                siblingData: getSiblingData(path),\n                t,\n                user,\n              })\n            : true\n\n        if (typeof validationResult === 'string') {\n          errorMessage = validationResult\n          valid = false\n        } else {\n          valid = validationResult\n          errorMessage = undefined\n        }\n\n        // Only dispatch if the validation result has changed\n        // This will prevent unnecessary rerenders\n        if (valid !== prevValid.current) {\n          prevValid.current = valid\n\n          if (typeof dispatchField === 'function') {\n            dispatchField({\n              condition,\n              disableFormData:\n                disableFormData || (hasRows ? typeof value === 'number' && value > 0 : false),\n              errorMessage,\n              path,\n              rows: field?.rows,\n              type: 'UPDATE',\n              valid,\n              validate,\n              value,\n            })\n          }\n        }\n      }\n\n      void validateField()\n    },\n    150,\n    [\n      value,\n      condition,\n      disableFormData,\n      dispatchField,\n      getData,\n      getSiblingData,\n      getDataByPath,\n      id,\n      operation,\n      path,\n      user,\n      validate,\n      field?.rows,\n    ],\n  )\n\n  return result\n}\n\nexport default useField\n"],"names":["useField","options","condition","disableFormData","hasRows","path","validate","submitted","useFormSubmitted","processing","useFormProcessing","user","useAuth","id","useDocumentInfo","operation","useOperation","field","useFormFields","fields","t","useTranslation","dispatchField","_","dispatch","config","useConfig","getData","getDataByPath","getSiblingData","setModified","useForm","value","initialValue","valid","showError","prevValid","useRef","setValue","useCallback","e","disableModifyingForm","val","target","setTimeout","type","result","useMemo","errorMessage","formProcessing","formSubmitted","rows","useThrottledEffect","validateField","valueToValidate","Array","isArray","validationResult","data","siblingData","undefined","current"],"mappings":";;;;+BA2KA;;;eAAA;;;uBA3K6C;8BACd;2EAIA;sBACP;wBACE;8BACM;mCACH;yBAC+C;;;;;;AAE5E;;;;CAIC,GACD,MAAMA,WAAW,CAAKC;IACpB,MAAM,EAAEC,SAAS,EAAEC,kBAAkB,KAAK,EAAEC,OAAO,EAAEC,IAAI,EAAEC,QAAQ,EAAE,GAAGL;IAExE,MAAMM,YAAYC,IAAAA,yBAAgB;IAClC,MAAMC,aAAaC,IAAAA,0BAAiB;IACpC,MAAM,EAAEC,IAAI,EAAE,GAAGC,IAAAA,aAAO;IACxB,MAAM,EAAEC,EAAE,EAAE,GAAGC,IAAAA,6BAAe;IAC9B,MAAMC,YAAYC,IAAAA,+BAAY;IAC9B,MAAMC,QAAQC,IAAAA,sBAAa,EAAC,CAAC,CAACC,OAAO,GAAKA,MAAM,CAACd,KAAK;IACtD,MAAM,EAAEe,CAAC,EAAE,GAAGC,IAAAA,4BAAc;IAC5B,MAAMC,gBAAgBJ,IAAAA,sBAAa,EAAC,CAAC,CAACK,GAAGC,SAAS,GAAKA;IACvD,MAAMC,SAASC,IAAAA,iBAAS;IAExB,MAAM,EAAEC,OAAO,EAAEC,aAAa,EAAEC,cAAc,EAAEC,WAAW,EAAE,GAAGC,IAAAA,gBAAO;IAEvE,MAAMC,QAAQf,OAAOe;IACrB,MAAMC,eAAehB,OAAOgB;IAC5B,MAAMC,QAAQ,OAAOjB,OAAOiB,UAAU,YAAYjB,MAAMiB,KAAK,GAAG;IAChE,MAAMC,YAAYD,UAAU,SAAS3B;IAErC,MAAM6B,YAAYC,IAAAA,aAAM,EAACH;IAEzB,4CAA4C;IAC5C,8CAA8C;IAC9C,MAAMI,WAAWC,IAAAA,kBAAW,EAC1B,CAACC,GAAGC,uBAAuB,KAAK;QAC9B,MAAMC,MAAMF,KAAKA,EAAEG,MAAM,GAAGH,EAAEG,MAAM,CAACX,KAAK,GAAGQ;QAE7C,IAAI,CAACC,sBAAsB;YACzB,IAAI,OAAOX,gBAAgB,YAAY;gBACrC,qDAAqD;gBACrD,4DAA4D;gBAC5Dc,WAAW;oBACTd,YAAY;gBACd,GAAG;YACL;QACF;QAEAR,cAAc;YACZnB,iBAAiBA,mBAAoBC,WAAWsC,MAAM;YACtDrC;YACAwC,MAAM;YACNb,OAAOU;QACT;IACF,GACA;QAACZ;QAAazB;QAAMiB;QAAenB;QAAiBC;KAAQ;IAG9D,gCAAgC;IAChC,mCAAmC;IACnC,MAAM0C,SAAuBC,IAAAA,cAAO,EAClC,IAAO,CAAA;YACLC,cAAc/B,OAAO+B;YACrBC,gBAAgBxC;YAChByC,eAAe3C;YACf0B;YACAkB,MAAMlC,OAAOkC;YACbb;YACAH;YACAD,OAAOjB,OAAOiB;YACdF;QACF,CAAA,GACA;QACEf,OAAO+B;QACP/B,OAAOkC;QACPlC,OAAOiB;QACPzB;QACA6B;QACAH;QACA5B;QACAyB;QACAC;KACD;IAGH,iCAAiC;IACjCmB,IAAAA,2BAAkB,EAChB;QACE,MAAMC,gBAAgB;YACpB,IAAIC,kBAAkBtB;YAEtB,IAAIf,OAAOkC,QAAQI,MAAMC,OAAO,CAACvC,MAAMkC,IAAI,GAAG;gBAC5CG,kBAAkB1B,cAAcvB;YAClC;YAEA,IAAI2C;YACJ,IAAId,QAA0B;YAE9B,MAAMuB,mBACJ,OAAOnD,aAAa,aAChB,MAAMA,SAASgD,iBAAiB;gBAC9BzC;gBACAY;gBACAiC,MAAM/B;gBACNZ;gBACA4C,aAAa9B,eAAexB;gBAC5Be;gBACAT;YACF,KACA;YAEN,IAAI,OAAO8C,qBAAqB,UAAU;gBACxCT,eAAeS;gBACfvB,QAAQ;YACV,OAAO;gBACLA,QAAQuB;gBACRT,eAAeY;YACjB;YAEA,qDAAqD;YACrD,0CAA0C;YAC1C,IAAI1B,UAAUE,UAAUyB,OAAO,EAAE;gBAC/BzB,UAAUyB,OAAO,GAAG3B;gBAEpB,IAAI,OAAOZ,kBAAkB,YAAY;oBACvCA,cAAc;wBACZpB;wBACAC,iBACEA,mBAAoBC,CAAAA,UAAU,OAAO4B,UAAU,YAAYA,QAAQ,IAAI,KAAI;wBAC7EgB;wBACA3C;wBACA8C,MAAMlC,OAAOkC;wBACbN,MAAM;wBACNX;wBACA5B;wBACA0B;oBACF;gBACF;YACF;QACF;QAEA,KAAKqB;IACP,GACA,KACA;QACErB;QACA9B;QACAC;QACAmB;QACAK;QACAE;QACAD;QACAf;QACAE;QACAV;QACAM;QACAL;QACAW,OAAOkC;KACR;IAGH,OAAOL;AACT;MAEA,WAAe9C"}