Skip to content

Commit

Permalink
Merge pull request #144 from bryanmylee/optional-col-filter-render
Browse files Browse the repository at this point in the history
Optional `render` column option for addColumnFilters
  • Loading branch information
bryanmylee authored Aug 10, 2023
2 parents 1142c88 + 2f87265 commit 2559f92
Show file tree
Hide file tree
Showing 6 changed files with 8 additions and 7 deletions.
1 change: 1 addition & 0 deletions .github/workflows/coverage.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ jobs:
- uses: actions/setup-node@v1
with:
node-version: 16
- run: npm install svelte
- run: npm ci
- run: npm test
- uses: coverallsapp/github-action@master
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ Defines the filter behavior for the column.

Receives `filterValue` and the column cell `value`, and returns `true` if the cell should be visible.

### `render: (renderProps) => RenderConfig`
### `render?: (renderProps) => RenderConfig`

Defines the component to render on `HeaderCell->props.[pluginName].render`.

Expand Down
6 changes: 3 additions & 3 deletions src/lib/plugins/addColumnFilters.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export interface ColumnFiltersState<Item> {
export interface ColumnFiltersColumnOptions<Item, FilterValue = any> {
fn: ColumnFilterFn<FilterValue>;
initialFilterValue?: FilterValue;
render: (props: ColumnRenderConfigPropArgs<Item, FilterValue>) => RenderConfig;
render?: (props: ColumnRenderConfigPropArgs<Item, FilterValue>) => RenderConfig;
}

// eslint-disable-next-line @typescript-eslint/no-explicit-any
Expand All @@ -46,7 +46,7 @@ export type ColumnFilterFnProps<FilterValue = any, Value = any> = {
export type ColumnFiltersPropSet = NewTablePropSet<{
'thead.tr.th':
| {
render: RenderConfig;
render?: RenderConfig;
}
| undefined;
}>;
Expand Down Expand Up @@ -151,7 +151,7 @@ export const addColumnFilters =
}
return [];
});
const render = columnOption.render({
const render = columnOption.render?.({
id: headerCell.id,
filterValue,
...tableState,
Expand Down
2 changes: 1 addition & 1 deletion src/lib/plugins/addFlatten.test.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { createTable } from '../createTable';
import type { Sample } from 'src/routes/_createSamples';
import type { Sample } from '../../routes/_createSamples';
import { get, readable } from 'svelte/store';
import { addFlatten } from './addFlatten';
import { addSubRows } from './addSubRows';
Expand Down
2 changes: 1 addition & 1 deletion src/lib/plugins/addGroupBy.test.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { createTable } from '../createTable';
import type { Sample } from 'src/routes/_createSamples';
import type { Sample } from '../../routes/_createSamples';
import { get, readable } from 'svelte/store';
import { addGroupBy } from './addGroupBy';
import { addSubRows } from './addSubRows';
Expand Down
2 changes: 1 addition & 1 deletion src/lib/plugins/addSelectedRows.test.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/* eslint-disable @typescript-eslint/no-non-null-assertion */
import { createTable } from '../createTable';
import type { Sample } from 'src/routes/_createSamples';
import type { Sample } from '../../routes/_createSamples';
import { derived, get, readable } from 'svelte/store';
import { addSelectedRows } from './addSelectedRows';
import { addSubRows } from './addSubRows';
Expand Down

0 comments on commit 2559f92

Please sign in to comment.