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