UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

161 lines (160 loc) • 17.1 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 _types = require("../../../../fields/config/types"); const _getTranslation = require("../../../../utilities/getTranslation"); const _useIntersect = /*#__PURE__*/ _interop_require_default(require("../../../hooks/useIntersect")); const _OperationProvider = require("../../utilities/OperationProvider"); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../utilities/RenderCustomComponent")); const _filterFields = require("./filterFields"); 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 = 'render-fields'; const intersectionObserverOptions = { rootMargin: '1000px' }; /** * If you send `fields` through, it will render those fields explicitly * Otherwise, it will reduce your fields using the other provided props * This is so that we can conditionally render fields before reducing them, if desired * See the sidebar in '../collections/Edit/Default/index.tsx' for an example * * The state/data for the fields it renders is not managed by this component. Instead, every component it renders has * their own handling of their own value, usually through the useField hook. This hook will get the field's value * from the Form the field is in, using the field's path. * * Thus, if you would like to set the value of a field you render here, you must do so in the Form that contains the field, or in the * Field component itself. * * All this component does is render the field's Field Components, and pass them the props they need to function. **/ const RenderFields = (props)=>{ const { className, fieldTypes, forceRender, margins } = props; const { i18n, t } = (0, _reacti18next.useTranslation)('general'); const [hasRendered, setHasRendered] = (0, _react.useState)(Boolean(forceRender)); const [intersectionRef, entry] = (0, _useIntersect.default)(intersectionObserverOptions, forceRender); const isIntersecting = Boolean(entry?.isIntersecting); const isAboveViewport = entry?.boundingClientRect?.top < 0; const shouldRender = forceRender || isIntersecting || isAboveViewport; const operation = (0, _OperationProvider.useOperation)(); (0, _react.useEffect)(()=>{ if (shouldRender && !hasRendered) { setHasRendered(true); } }, [ shouldRender, hasRendered ]); let fieldsToRender = 'fields' in props ? props?.fields : null; if (!fieldsToRender && 'fieldSchema' in props) { const { fieldSchema, fieldTypes, filter, permissions, readOnly: readOnlyOverride } = props; fieldsToRender = (0, _filterFields.filterFields)({ fieldSchema, fieldTypes, filter, operation, permissions, readOnly: readOnlyOverride }); } if (fieldsToRender) { return /*#__PURE__*/ _react.default.createElement("div", { className: [ baseClass, className, margins && `${baseClass}--margins-${margins}`, margins === false && `${baseClass}--margins-none` ].filter(Boolean).join(' '), ref: intersectionRef }, hasRendered && fieldsToRender.map((reducedField, fieldIndex)=>{ const { FieldComponent, field, fieldIsPresentational, fieldPermissions, isFieldAffectingData, readOnly } = reducedField; if (fieldIsPresentational) { return /*#__PURE__*/ _react.default.createElement(FieldComponent, { key: fieldIndex, ...field }); } if (field) { return /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: field?.admin?.components?.Field, DefaultComponent: FieldComponent, componentProps: { ...field, admin: { ...field.admin || {}, readOnly }, fieldTypes, forceRender, indexPath: 'indexPath' in props ? `${props?.indexPath}.${fieldIndex}` : `${fieldIndex}`, path: field.path || (isFieldAffectingData && 'name' in field ? field.name : ''), permissions: fieldPermissions }, key: fieldIndex }); } return /*#__PURE__*/ _react.default.createElement("div", { className: "missing-field", key: fieldIndex }, t('error:noMatchedField', { label: (0, _types.fieldAffectsData)(field) ? (0, _getTranslation.getTranslation)(field.label || field.name, i18n) : field.path })); })); } return null; }; const _default = RenderFields; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/forms/RenderFields/index.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport { fieldAffectsData } from '../../../../fields/config/types'\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport useIntersect from '../../../hooks/useIntersect'\nimport { useOperation } from '../../utilities/OperationProvider'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport { filterFields } from './filterFields'\nimport './index.scss'\n\nconst baseClass = 'render-fields'\n\nconst intersectionObserverOptions = {\n  rootMargin: '1000px',\n}\n\n/**\n * If you send `fields` through, it will render those fields explicitly\n * Otherwise, it will reduce your fields using the other provided props\n * This is so that we can conditionally render fields before reducing them, if desired\n * See the sidebar in '../collections/Edit/Default/index.tsx' for an example\n *\n * The state/data for the fields it renders is not managed by this component. Instead, every component it renders has\n * their own handling of their own value, usually through the useField hook. This hook will get the field's value\n * from the Form the field is in, using the field's path.\n *\n * Thus, if you would like to set the value of a field you render here, you must do so in the Form that contains the field, or in the\n * Field component itself.\n *\n * All this component does is render the field's Field Components, and pass them the props they need to function.\n **/\nconst RenderFields: React.FC<Props> = (props) => {\n  const { className, fieldTypes, forceRender, margins } = props\n\n  const { i18n, t } = useTranslation('general')\n  const [hasRendered, setHasRendered] = useState(Boolean(forceRender))\n  const [intersectionRef, entry] = useIntersect(intersectionObserverOptions, forceRender)\n\n  const isIntersecting = Boolean(entry?.isIntersecting)\n  const isAboveViewport = entry?.boundingClientRect?.top < 0\n  const shouldRender = forceRender || isIntersecting || isAboveViewport\n  const operation = useOperation()\n\n  useEffect(() => {\n    if (shouldRender && !hasRendered) {\n      setHasRendered(true)\n    }\n  }, [shouldRender, hasRendered])\n\n  let fieldsToRender = 'fields' in props ? props?.fields : null\n\n  if (!fieldsToRender && 'fieldSchema' in props) {\n    const { fieldSchema, fieldTypes, filter, permissions, readOnly: readOnlyOverride } = props\n\n    fieldsToRender = filterFields({\n      fieldSchema,\n      fieldTypes,\n      filter,\n      operation,\n      permissions,\n      readOnly: readOnlyOverride,\n    })\n  }\n\n  if (fieldsToRender) {\n    return (\n      <div\n        className={[\n          baseClass,\n          className,\n          margins && `${baseClass}--margins-${margins}`,\n          margins === false && `${baseClass}--margins-none`,\n        ]\n          .filter(Boolean)\n          .join(' ')}\n        ref={intersectionRef}\n      >\n        {hasRendered &&\n          fieldsToRender.map((reducedField, fieldIndex) => {\n            const {\n              FieldComponent,\n              field,\n              fieldIsPresentational,\n              fieldPermissions,\n              isFieldAffectingData,\n              readOnly,\n            } = reducedField\n\n            if (fieldIsPresentational) {\n              return <FieldComponent key={fieldIndex} {...field} />\n            }\n\n            if (field) {\n              return (\n                <RenderCustomComponent\n                  CustomComponent={field?.admin?.components?.Field}\n                  DefaultComponent={FieldComponent}\n                  componentProps={{\n                    ...field,\n                    admin: {\n                      ...(field.admin || {}),\n                      readOnly,\n                    },\n                    fieldTypes,\n                    forceRender,\n                    indexPath:\n                      'indexPath' in props ? `${props?.indexPath}.${fieldIndex}` : `${fieldIndex}`,\n                    path: field.path || (isFieldAffectingData && 'name' in field ? field.name : ''),\n                    permissions: fieldPermissions,\n                  }}\n                  key={fieldIndex}\n                />\n              )\n            }\n\n            return (\n              <div className=\"missing-field\" key={fieldIndex}>\n                {t('error:noMatchedField', {\n                  label: fieldAffectsData(field)\n                    ? getTranslation(field.label || field.name, i18n)\n                    : field.path,\n                })}\n              </div>\n            )\n          })}\n      </div>\n    )\n  }\n\n  return null\n}\n\nexport default RenderFields\n"],"names":["baseClass","intersectionObserverOptions","rootMargin","RenderFields","props","className","fieldTypes","forceRender","margins","i18n","t","useTranslation","hasRendered","setHasRendered","useState","Boolean","intersectionRef","entry","useIntersect","isIntersecting","isAboveViewport","boundingClientRect","top","shouldRender","operation","useOperation","useEffect","fieldsToRender","fields","fieldSchema","filter","permissions","readOnly","readOnlyOverride","filterFields","div","join","ref","map","reducedField","fieldIndex","FieldComponent","field","fieldIsPresentational","fieldPermissions","isFieldAffectingData","key","RenderCustomComponent","CustomComponent","admin","components","Field","DefaultComponent","componentProps","indexPath","path","name","label","fieldAffectsData","getTranslation"],"mappings":"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"}