Update bindDataExplorerActions to use middleware service
[arvados.git] / src / store / data-explorer / data-explorer-action.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { default as unionize, ofType, UnionOf } from "unionize";
6 import { DataTableFilterItem } from "../../components/data-table-filters/data-table-filters";
7 import { DataColumns } from "../../components/data-table/data-table";
8 import { DataExplorerMiddlewareService } from "./data-explorer-middleware-service";
9
10 export const dataExplorerActions = unionize({
11     RESET_PAGINATION: ofType<{ id: string }>(),
12     REQUEST_ITEMS: ofType<{ id: string }>(),
13     SET_COLUMNS: ofType<{ id: string, columns: DataColumns<any> }>(),
14     SET_FILTERS: ofType<{ id: string, columnName: string, filters: DataTableFilterItem[] }>(),
15     SET_ITEMS: ofType<{ id: string, items: any[], page: number, rowsPerPage: number, itemsAvailable: number }>(),
16     SET_PAGE: ofType<{ id: string, page: number }>(),
17     SET_ROWS_PER_PAGE: ofType<{ id: string, rowsPerPage: number }>(),
18     TOGGLE_COLUMN: ofType<{ id: string, columnName: string }>(),
19     TOGGLE_SORT: ofType<{ id: string, columnName: string }>(),
20     SET_SEARCH_VALUE: ofType<{ id: string, searchValue: string }>(),
21 }, { tag: "type", value: "payload" });
22
23 export type DataExplorerAction = UnionOf<typeof dataExplorerActions>;
24
25 export const bindDataExplorerActions = ({ Id: id }: DataExplorerMiddlewareService) => ({
26     ...dataExplorerActions,
27     RESET_PAGINATION: () =>
28         dataExplorerActions.RESET_PAGINATION({ id }),
29     REQUEST_ITEMS: () =>
30         dataExplorerActions.REQUEST_ITEMS({ id }),
31     SET_COLUMNS: (payload: { columns: DataColumns<any> }) =>
32         dataExplorerActions.SET_COLUMNS({ ...payload, id }),
33     SET_FILTERS: (payload: { columnName: string, filters: DataTableFilterItem[] }) =>
34         dataExplorerActions.SET_FILTERS({ ...payload, id }),
35     SET_ITEMS: (payload: { items: any[], page: number, rowsPerPage: number, itemsAvailable: number }) =>
36         dataExplorerActions.SET_ITEMS({ ...payload, id }),
37     SET_PAGE: (payload: { page: number }) =>
38         dataExplorerActions.SET_PAGE({ ...payload, id }),
39     SET_ROWS_PER_PAGE: (payload: { rowsPerPage: number }) =>
40         dataExplorerActions.SET_ROWS_PER_PAGE({ ...payload, id }),
41     TOGGLE_COLUMN: (payload: { columnName: string }) =>
42         dataExplorerActions.TOGGLE_COLUMN({ ...payload, id }),
43     TOGGLE_SORT: (payload: { columnName: string }) =>
44         dataExplorerActions.TOGGLE_SORT({ ...payload, id }),
45     SET_SEARCH_VALUE: (payload: { searchValue: string }) =>
46         dataExplorerActions.SET_SEARCH_VALUE({ ...payload, id }),
47 });