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