UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

224 lines (223 loc) • 20.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); function _export(target, all) { for(var name in all)Object.defineProperty(target, name, { enumerable: true, get: all[name] }); } _export(exports, { TableColumnContext: function() { return TableColumnContext; }, TableColumnsProvider: function() { return TableColumnsProvider; }, useTableColumns: function() { return useTableColumns; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _Preferences = require("../../utilities/Preferences"); const _formatFields = /*#__PURE__*/ _interop_require_default(require("../../views/collections/List/formatFields")); const _buildColumns = /*#__PURE__*/ _interop_require_default(require("./buildColumns")); const _columnReducer = require("./columnReducer"); const _getInitialColumns = /*#__PURE__*/ _interop_require_default(require("./getInitialColumns")); 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 TableColumnContext = /*#__PURE__*/ (0, _react.createContext)({}); const useTableColumns = ()=>(0, _react.useContext)(TableColumnContext); const TableColumnsProvider = ({ cellProps, children, collection: { admin: { defaultColumns, useAsTitle } }, collection })=>{ const preferenceKey = `${collection.slug}-list`; const prevCollection = (0, _react.useRef)(); const hasInitialized = (0, _react.useRef)(false); const { getPreference, setPreference } = (0, _Preferences.usePreferences)(); const [formattedFields] = (0, _react.useState)(()=>(0, _formatFields.default)(collection)); const [tableColumns, dispatchTableColumns] = (0, _react.useReducer)(_columnReducer.columnReducer, {}, ()=>{ const initialColumns = (0, _getInitialColumns.default)(formattedFields, useAsTitle, defaultColumns); return (0, _buildColumns.default)({ cellProps, collection, columns: initialColumns.map((column)=>({ accessor: column, active: true })) }); }); // ///////////////////////////////////// // Sync preferences on collection change // ///////////////////////////////////// (0, _react.useEffect)(()=>{ const sync = async ()=>{ const collectionHasChanged = prevCollection.current !== collection.slug; if (collectionHasChanged) { hasInitialized.current = false; const currentPreferences = await getPreference(preferenceKey); prevCollection.current = collection.slug; const initialColumns = (0, _getInitialColumns.default)(formattedFields, useAsTitle, defaultColumns); const newCols = currentPreferences?.columns || initialColumns; dispatchTableColumns({ payload: { cellProps, collection: { ...collection, fields: (0, _formatFields.default)(collection) }, columns: newCols.map((column)=>{ // 'string' is for backwards compatibility // the preference used to be stored as an array of strings if (typeof column === 'string') { return { accessor: column, active: true }; } return column; }) }, type: 'set' }); hasInitialized.current = true; } }; sync(); }, [ preferenceKey, setPreference, tableColumns, getPreference, useAsTitle, defaultColumns, collection, cellProps, formattedFields ]); // ///////////////////////////////////// // Set preferences on column change // ///////////////////////////////////// (0, _react.useEffect)(()=>{ if (!hasInitialized.current) return; const columns = tableColumns.map((c)=>({ accessor: c.accessor, active: c.active })); void setPreference(preferenceKey, { columns }, true); }, [ tableColumns, preferenceKey, setPreference, getPreference ]); const setActiveColumns = (0, _react.useCallback)((columns)=>{ dispatchTableColumns({ payload: { // onSelect, cellProps, collection: { ...collection, fields: (0, _formatFields.default)(collection) }, columns: columns.map((column)=>({ accessor: column, active: true })) }, type: 'set' }); }, [ collection, cellProps ]); const moveColumn = (0, _react.useCallback)((args)=>{ const { fromIndex, toIndex } = args; dispatchTableColumns({ payload: { cellProps, collection: { ...collection, fields: (0, _formatFields.default)(collection) }, fromIndex, toIndex }, type: 'move' }); }, [ collection, cellProps ]); const toggleColumn = (0, _react.useCallback)((column)=>{ dispatchTableColumns({ payload: { cellProps, collection: { ...collection, fields: (0, _formatFields.default)(collection) }, column }, type: 'toggle' }); }, [ collection, cellProps ]); return /*#__PURE__*/ _react.default.createElement(TableColumnContext.Provider, { value: { columns: tableColumns, dispatchTableColumns, moveColumn, setActiveColumns, toggleColumn } }, children); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/TableColumns/index.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useCallback,\n  useContext,\n  useEffect,\n  useReducer,\n  useRef,\n  useState,\n} from 'react'\n\nimport type { SanitizedCollectionConfig } from '../../../../collections/config/types'\nimport type { Field } from '../../../../fields/config/types'\nimport type { Props as CellProps } from '../../views/collections/List/Cell/types'\nimport type { ListPreferences } from '../../views/collections/List/types'\nimport type { Column } from '../Table/types'\nimport type { Action } from './columnReducer'\n\nimport { usePreferences } from '../../utilities/Preferences'\nimport formatFields from '../../views/collections/List/formatFields'\nimport buildColumns from './buildColumns'\nimport { columnReducer } from './columnReducer'\nimport getInitialColumnState from './getInitialColumns'\n\nexport interface ITableColumns {\n  columns: Column[]\n  dispatchTableColumns: React.Dispatch<Action>\n  moveColumn: (args: { fromIndex: number; toIndex: number }) => void\n  setActiveColumns: (columns: string[]) => void\n  toggleColumn: (column: string) => void\n}\n\nexport const TableColumnContext = createContext<ITableColumns>({} as ITableColumns)\n\nexport const useTableColumns = (): ITableColumns => useContext(TableColumnContext)\n\nexport const TableColumnsProvider: React.FC<{\n  cellProps?: Partial<CellProps>[]\n  children: React.ReactNode\n  collection: SanitizedCollectionConfig\n}> = ({\n  cellProps,\n  children,\n  collection: {\n    admin: { defaultColumns, useAsTitle },\n  },\n  collection,\n}) => {\n  const preferenceKey = `${collection.slug}-list`\n  const prevCollection = useRef<SanitizedCollectionConfig['slug']>()\n  const hasInitialized = useRef(false)\n  const { getPreference, setPreference } = usePreferences()\n  const [formattedFields] = useState<Field[]>(() => formatFields(collection))\n\n  const [tableColumns, dispatchTableColumns] = useReducer(columnReducer, {}, () => {\n    const initialColumns = getInitialColumnState(formattedFields, useAsTitle, defaultColumns)\n\n    return buildColumns({\n      cellProps,\n      collection,\n      columns: initialColumns.map((column) => ({\n        accessor: column,\n        active: true,\n      })),\n    })\n  })\n\n  // /////////////////////////////////////\n  // Sync preferences on collection change\n  // /////////////////////////////////////\n\n  useEffect(() => {\n    const sync = async () => {\n      const collectionHasChanged = prevCollection.current !== collection.slug\n\n      if (collectionHasChanged) {\n        hasInitialized.current = false\n\n        const currentPreferences = await getPreference<ListPreferences>(preferenceKey)\n        prevCollection.current = collection.slug\n        const initialColumns = getInitialColumnState(formattedFields, useAsTitle, defaultColumns)\n        const newCols = currentPreferences?.columns || initialColumns\n\n        dispatchTableColumns({\n          payload: {\n            cellProps,\n            collection: { ...collection, fields: formatFields(collection) },\n            columns: newCols.map((column) => {\n              // 'string' is for backwards compatibility\n              // the preference used to be stored as an array of strings\n              if (typeof column === 'string') {\n                return {\n                  accessor: column,\n                  active: true,\n                }\n              }\n              return column\n            }),\n          },\n          type: 'set',\n        })\n\n        hasInitialized.current = true\n      }\n    }\n\n    sync()\n  }, [\n    preferenceKey,\n    setPreference,\n    tableColumns,\n    getPreference,\n    useAsTitle,\n    defaultColumns,\n    collection,\n    cellProps,\n    formattedFields,\n  ])\n\n  // /////////////////////////////////////\n  // Set preferences on column change\n  // /////////////////////////////////////\n\n  useEffect(() => {\n    if (!hasInitialized.current) return\n    const columns = tableColumns.map((c) => ({\n      accessor: c.accessor,\n      active: c.active,\n    }))\n\n    void setPreference(preferenceKey, { columns }, true)\n  }, [tableColumns, preferenceKey, setPreference, getPreference])\n\n  const setActiveColumns = useCallback(\n    (columns: string[]) => {\n      dispatchTableColumns({\n        payload: {\n          // onSelect,\n          cellProps,\n          collection: { ...collection, fields: formatFields(collection) },\n          columns: columns.map((column) => ({\n            accessor: column,\n            active: true,\n          })),\n        },\n        type: 'set',\n      })\n    },\n    [collection, cellProps],\n  )\n\n  const moveColumn = useCallback(\n    (args: { fromIndex: number; toIndex: number }) => {\n      const { fromIndex, toIndex } = args\n\n      dispatchTableColumns({\n        payload: {\n          cellProps,\n          collection: { ...collection, fields: formatFields(collection) },\n          fromIndex,\n          toIndex,\n        },\n        type: 'move',\n      })\n    },\n    [collection, cellProps],\n  )\n\n  const toggleColumn = useCallback(\n    (column: string) => {\n      dispatchTableColumns({\n        payload: {\n          cellProps,\n          collection: { ...collection, fields: formatFields(collection) },\n          column,\n        },\n        type: 'toggle',\n      })\n    },\n    [collection, cellProps],\n  )\n\n  return (\n    <TableColumnContext.Provider\n      value={{\n        columns: tableColumns,\n        dispatchTableColumns,\n        moveColumn,\n        setActiveColumns,\n        toggleColumn,\n      }}\n    >\n      {children}\n    </TableColumnContext.Provider>\n  )\n}\n"],"names":["TableColumnContext","TableColumnsProvider","useTableColumns","createContext","useContext","cellProps","children","collection","admin","defaultColumns","useAsTitle","preferenceKey","slug","prevCollection","useRef","hasInitialized","getPreference","setPreference","usePreferences","formattedFields","useState","formatFields","tableColumns","dispatchTableColumns","useReducer","columnReducer","initialColumns","getInitialColumnState","buildColumns","columns","map","column","accessor","active","useEffect","sync","collectionHasChanged","current","currentPreferences","newCols","payload","fields","type","c","setActiveColumns","useCallback","moveColumn","args","fromIndex","toIndex","toggleColumn","Provider","value"],"mappings":"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"}