UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

138 lines (137 loc) • 13.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "FieldSelect", { enumerable: true, get: function() { return FieldSelect; } }); 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 _context = require("../../forms/Form/context"); const _createNestedFieldPath = require("../../forms/Form/createNestedFieldPath"); const _Label = /*#__PURE__*/ _interop_require_default(require("../../forms/Label")); const _ReactSelect = /*#__PURE__*/ _interop_require_default(require("../ReactSelect")); 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 = 'field-select'; const combineLabel = (prefix, field, i18n)=>`${prefix === '' ? '' : `${prefix} > `}${(0, _getTranslation.getTranslation)(field.label || field.name, i18n) || ''}`; const reduceFields = (fields, i18n, path = '', labelPrefix = '')=>fields.reduce((fieldsToUse, field)=>{ // escape for a variety of reasons if ((0, _types.fieldAffectsData)(field) && (field.admin?.disableBulkEdit || field.unique || field.hidden || field.admin?.hidden || field.admin?.readOnly)) { return fieldsToUse; } if (!(field.type === 'array' || field.type === 'blocks') && (0, _types.fieldHasSubFields)(field)) { return [ ...fieldsToUse, ...reduceFields(field.fields, i18n, (0, _createNestedFieldPath.createNestedFieldPath)(path, field), combineLabel(labelPrefix, field, i18n)) ]; } if (field.type === 'tabs') { return [ ...fieldsToUse, ...field.tabs.reduce((tabFields, tab)=>{ return [ ...tabFields, ...reduceFields(tab.fields, i18n, (0, _types.tabHasName)(tab) ? (0, _createNestedFieldPath.createNestedFieldPath)(path, field) : path, combineLabel(labelPrefix, field, i18n)) ]; }, []) ]; } const formattedField = { label: combineLabel(labelPrefix, field, i18n), value: { ...field, path: (0, _createNestedFieldPath.createNestedFieldPath)(path, field) } }; return [ ...fieldsToUse, formattedField ]; }, []); const FieldSelect = ({ fields, setSelected })=>{ const { i18n, t } = (0, _reacti18next.useTranslation)('general'); const [options] = (0, _react.useState)(()=>reduceFields(fields, i18n)); const { dispatchFields, getFields } = (0, _context.useForm)(); const handleChange = (selected)=>{ const activeFields = getFields(); if (selected === null) { setSelected([]); } else { setSelected(selected.map(({ value })=>value)); } // remove deselected values from form state if (selected === null || Object.keys(activeFields).length > selected.length) { Object.keys(activeFields).forEach((path)=>{ if (selected === null || !selected.find((field)=>{ return field.value.path === path; })) { dispatchFields({ path, type: 'REMOVE' }); } }); } }; return /*#__PURE__*/ _react.default.createElement("div", { className: baseClass }, /*#__PURE__*/ _react.default.createElement(_Label.default, { label: t('fields:selectFieldsToEdit') }), /*#__PURE__*/ _react.default.createElement(_ReactSelect.default, { isMulti: true, onChange: handleChange, options: options })); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/FieldSelect/index.tsx"],"sourcesContent":["import React, { useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Field, FieldWithPath } from '../../../../fields/config/types'\n\nimport { fieldAffectsData, fieldHasSubFields, tabHasName } from '../../../../fields/config/types'\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport { useForm } from '../../forms/Form/context'\nimport { createNestedFieldPath } from '../../forms/Form/createNestedFieldPath'\nimport Label from '../../forms/Label'\nimport ReactSelect from '../ReactSelect'\nimport './index.scss'\n\nconst baseClass = 'field-select'\n\ntype Props = {\n  fields: Field[]\n  setSelected: (fields: FieldWithPath[]) => void\n}\n\nconst combineLabel = (prefix, field, i18n): string =>\n  `${prefix === '' ? '' : `${prefix} > `}${getTranslation(field.label || field.name, i18n) || ''}`\nconst reduceFields = (\n  fields: Field[],\n  i18n,\n  path = '',\n  labelPrefix = '',\n): { label: string; value: FieldWithPath }[] =>\n  fields.reduce((fieldsToUse, field) => {\n    // escape for a variety of reasons\n    if (\n      fieldAffectsData(field) &&\n      (field.admin?.disableBulkEdit ||\n        field.unique ||\n        field.hidden ||\n        field.admin?.hidden ||\n        field.admin?.readOnly)\n    ) {\n      return fieldsToUse\n    }\n    if (!(field.type === 'array' || field.type === 'blocks') && fieldHasSubFields(field)) {\n      return [\n        ...fieldsToUse,\n        ...reduceFields(\n          field.fields,\n          i18n,\n          createNestedFieldPath(path, field),\n          combineLabel(labelPrefix, field, i18n),\n        ),\n      ]\n    }\n    if (field.type === 'tabs') {\n      return [\n        ...fieldsToUse,\n        ...field.tabs.reduce((tabFields, tab) => {\n          return [\n            ...tabFields,\n            ...reduceFields(\n              tab.fields,\n              i18n,\n              tabHasName(tab) ? createNestedFieldPath(path, field) : path,\n              combineLabel(labelPrefix, field, i18n),\n            ),\n          ]\n        }, []),\n      ]\n    }\n    const formattedField = {\n      label: combineLabel(labelPrefix, field, i18n),\n      value: {\n        ...field,\n        path: createNestedFieldPath(path, field),\n      },\n    }\n\n    return [...fieldsToUse, formattedField]\n  }, [])\nexport const FieldSelect: React.FC<Props> = ({ fields, setSelected }) => {\n  const { i18n, t } = useTranslation('general')\n  const [options] = useState(() => reduceFields(fields, i18n))\n  const { dispatchFields, getFields } = useForm()\n  const handleChange = (selected) => {\n    const activeFields = getFields()\n    if (selected === null) {\n      setSelected([])\n    } else {\n      setSelected(selected.map(({ value }) => value))\n    }\n    // remove deselected values from form state\n    if (selected === null || Object.keys(activeFields).length > selected.length) {\n      Object.keys(activeFields).forEach((path) => {\n        if (\n          selected === null ||\n          !selected.find((field) => {\n            return field.value.path === path\n          })\n        ) {\n          dispatchFields({\n            path,\n            type: 'REMOVE',\n          })\n        }\n      })\n    }\n  }\n\n  return (\n    <div className={baseClass}>\n      <Label label={t('fields:selectFieldsToEdit')} />\n      <ReactSelect isMulti onChange={handleChange} options={options} />\n    </div>\n  )\n}\n"],"names":["FieldSelect","baseClass","combineLabel","prefix","field","i18n","getTranslation","label","name","reduceFields","fields","path","labelPrefix","reduce","fieldsToUse","fieldAffectsData","admin","disableBulkEdit","unique","hidden","readOnly","type","fieldHasSubFields","createNestedFieldPath","tabs","tabFields","tab","tabHasName","formattedField","value","setSelected","t","useTranslation","options","useState","dispatchFields","getFields","useForm","handleChange","selected","activeFields","map","Object","keys","length","forEach","find","div","className","Label","ReactSelect","isMulti","onChange"],"mappings":"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"}