@humanspeak/svelte-headless-table
Version:
A powerful, headless table library for Svelte that provides complete control over table UI while handling complex data operations like sorting, filtering, pagination, grouping, and row expansion. Build custom, accessible data tables with zero styling opin
18 lines (17 loc) • 653 B
JavaScript
import { derived, writable } from 'svelte/store';
export const addHiddenColumns = ({ initialHiddenColumnIds = [] } = {}) => () => {
const hiddenColumnIds = writable(initialHiddenColumnIds);
const pluginState = { hiddenColumnIds };
const deriveFlatColumns = (flatColumns) => {
return derived([flatColumns, hiddenColumnIds], ([$flatColumns, $hiddenColumnIds]) => {
if ($hiddenColumnIds.length === 0) {
return $flatColumns;
}
return $flatColumns.filter((c) => !$hiddenColumnIds.includes(c.id));
});
};
return {
pluginState,
deriveFlatColumns
};
};