payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
161 lines (160 loc) • 17.1 kB
JavaScript
;
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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"}