@tsed/react-formio 2.0.3 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/coverage.json +4 -4
  2. package/dist/components/actions-table/actionsTable.component.d.ts +1 -1
  3. package/dist/components/form-access/formAccess.component.d.ts +1 -1
  4. package/dist/components/form-edit/formEdit.stories.d.ts +1 -1
  5. package/dist/components/forms-table/formsTable.component.d.ts +1 -1
  6. package/dist/components/submissions-table/submissionsTable.component.d.ts +1 -1
  7. package/dist/components/table/components/defaultCells.component.d.ts +4 -0
  8. package/dist/components/table/components/defaultRow.component.d.ts +12 -0
  9. package/dist/components/table/components/dragNDropContainer.d.ts +4 -0
  10. package/dist/components/table/hooks/useCustomTable.hook.d.ts +187 -0
  11. package/dist/components/table/hooks/useDragnDropRow.hook.d.ts +266 -0
  12. package/dist/components/table/index.d.ts +2 -1
  13. package/dist/components/table/table.component.d.ts +2 -71
  14. package/dist/components/table/table.stories.d.ts +25 -0
  15. package/dist/components/table/utils/swapElements.d.ts +1 -0
  16. package/dist/components/table/utils/swapElements.spec.d.ts +1 -0
  17. package/dist/index.js +315 -88
  18. package/dist/index.js.map +1 -1
  19. package/dist/index.modern.js +445 -225
  20. package/dist/index.modern.js.map +1 -1
  21. package/package.json +5 -3
  22. package/src/components/actions-table/actionsTable.component.tsx +2 -1
  23. package/src/components/form-access/formAccess.component.tsx +1 -1
  24. package/src/components/form-edit/formEdit.stories.tsx +2 -2
  25. package/src/components/forms-table/formsTable.component.tsx +2 -1
  26. package/src/components/forms-table/formsTable.stories.tsx +2 -2
  27. package/src/components/submissions-table/submissionsTable.component.tsx +2 -1
  28. package/src/components/table/components/defaultCells.component.tsx +21 -0
  29. package/src/components/table/components/defaultRow.component.tsx +50 -0
  30. package/src/components/table/components/dragNDropContainer.tsx +7 -0
  31. package/src/components/table/hooks/useCustomTable.hook.tsx +231 -0
  32. package/src/components/table/hooks/useDragnDropRow.hook.ts +80 -0
  33. package/src/components/table/index.ts +2 -1
  34. package/src/components/table/table.component.tsx +83 -233
  35. package/src/components/table/table.stories.tsx +56 -0
  36. package/src/components/table/utils/swapElements.spec.ts +7 -0
  37. package/src/components/table/utils/swapElements.ts +7 -0
  38. /package/dist/components/table/{utils → hooks}/useOperations.hook.d.ts +0 -0
  39. /package/src/components/table/{utils → hooks}/useOperations.hook.tsx +0 -0
package/coverage.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
- "statements": 57.05,
3
- "branches": 47.58,
4
- "functions": 51.6,
5
- "lines": 57.04
2
+ "statements": 56.11,
3
+ "branches": 46.65,
4
+ "functions": 51.31,
5
+ "lines": 56.1
6
6
  }
@@ -1,5 +1,5 @@
1
1
  import { ActionSchema } from "../../interfaces";
2
- import { TableProps } from "../table/table.component";
2
+ import { TableProps } from "../table/hooks/useCustomTable.hook";
3
3
  export declare type ActionsTableProps = Omit<TableProps<ActionSchema>, "columns"> & {
4
4
  onAddAction?: (actionName: string) => void;
5
5
  availableActions?: {
@@ -1,6 +1,6 @@
1
1
  import PropTypes from "prop-types";
2
2
  import { PropsWithChildren, ReactElement } from "react";
3
- import { FormOptions, FormSchema } from "../../interfaces";
3
+ import type { FormOptions, FormSchema } from "../../interfaces";
4
4
  export interface FormAccessProps {
5
5
  form: Partial<FormSchema>;
6
6
  roles: any;
@@ -1,4 +1,4 @@
1
- import { FormEdit } from "../../index";
1
+ import { FormEdit } from "./formEdit.component";
2
2
  declare const _default: {
3
3
  title: string;
4
4
  component: typeof FormEdit;
@@ -1,5 +1,5 @@
1
1
  import { FormSchema } from "../../interfaces";
2
- import { TableProps } from "../table/table.component";
2
+ import { TableProps } from "../table/hooks/useCustomTable.hook";
3
3
  export declare type FormsTableProps = Omit<TableProps<FormSchema>, "columns"> & {
4
4
  icon?: string;
5
5
  tags?: {
@@ -1,5 +1,5 @@
1
1
  import { FormSchema, Submission } from "../../interfaces";
2
- import { TableProps } from "../table/table.component";
2
+ import { TableProps } from "../table/hooks/useCustomTable.hook";
3
3
  export declare type SubmissionsTableProps = Omit<TableProps<Submission>, "columns"> & {
4
4
  form?: FormSchema;
5
5
  };
@@ -0,0 +1,4 @@
1
+ import { Row } from "react-table";
2
+ export declare function DefaultCells<Data extends object = {}>({ row }: {
3
+ row: Row<Data>;
4
+ }): JSX.Element;
@@ -0,0 +1,12 @@
1
+ import { DetailedHTMLProps, HTMLAttributes } from "react";
2
+ import { Row } from "react-table";
3
+ export interface DefaultRowProps<Data extends object = {}> extends Omit<DetailedHTMLProps<HTMLAttributes<HTMLTableRowElement>, HTMLTableRowElement>, "onClick" | "onDrag" | "onDrop"> {
4
+ onClick: (data: any, action: string) => void;
5
+ row: Row<Data>;
6
+ index: number;
7
+ onDrop: (item: Data) => void;
8
+ onDrag: (index: number, hoverIndex: number) => void;
9
+ enableDragNDrop?: boolean;
10
+ }
11
+ export declare function DefaultDndRow<Data extends object = {}>(props: DefaultRowProps<Data>): JSX.Element;
12
+ export declare function DefaultRow<Data extends object = {}>({ onClick, row, enableDragNDrop, onDrop, onDrag, ...props }: DefaultRowProps<Data>): JSX.Element;
@@ -0,0 +1,4 @@
1
+ import { PropsWithChildren } from "react";
2
+ export declare function DrapNDropContainer({ enableDragNDrop, children }: PropsWithChildren<{
3
+ enableDragNDrop?: boolean;
4
+ }>): JSX.Element;
@@ -0,0 +1,187 @@
1
+ import React, { PropsWithChildren } from "react";
2
+ import { CellProps, FilterProps, Renderer, TableOptions } from "react-table";
3
+ import { OnClickOperation, Operation, QueryOptions } from "../../../interfaces";
4
+ import { Pagination as DefaultPagination } from "../../pagination/pagination.component";
5
+ import { DefaultCellHeaderProps } from "../components/defaultCellHeader.component";
6
+ import { DefaultRow, DefaultRowProps } from "../components/defaultRow.component";
7
+ export interface TableProps<Data extends object = any> extends TableOptions<Data>, Partial<QueryOptions> {
8
+ className?: string;
9
+ /**
10
+ * Call the listener when a filter / pagination / sort change.
11
+ */
12
+ onChange?: (query: QueryOptions) => void;
13
+ /**
14
+ * Call the listener when a line is clicked.
15
+ */
16
+ onClick?: OnClickOperation<Data>;
17
+ /**
18
+ * Pagination steps list
19
+ */
20
+ pageSizes?: number[];
21
+ /**
22
+ *
23
+ */
24
+ isLoading?: boolean;
25
+ /**
26
+ * Custom EmptyData displayed when there is no data
27
+ */
28
+ EmptyData?: React.ComponentType;
29
+ /**
30
+ * Custom ArrowSort
31
+ */
32
+ ArrowSort?: React.ComponentType;
33
+ /**
34
+ * Custom default ColumnFilter
35
+ */
36
+ ColumnFilter?: Renderer<FilterProps<Data>>;
37
+ /**
38
+ * Custom cell
39
+ */
40
+ Cell?: React.ComponentType<CellProps<Data>>;
41
+ /**
42
+ * Custom Row
43
+ */
44
+ Row?: React.ComponentType<DefaultRowProps<Data>>;
45
+ /**
46
+ *
47
+ */
48
+ CellHeader?: React.ComponentType<DefaultCellHeaderProps<Data>>;
49
+ /**
50
+ *
51
+ */
52
+ CellOperations?: React.ComponentType;
53
+ /**
54
+ * Custom Loader
55
+ */
56
+ Loader?: React.ComponentType;
57
+ /**
58
+ * Custom Loader
59
+ */
60
+ Pagination?: React.ComponentType;
61
+ /**
62
+ * Disable filters
63
+ */
64
+ disableFilters?: boolean;
65
+ /**
66
+ * Disable pagination
67
+ */
68
+ disablePagination?: boolean;
69
+ manualPagination?: boolean;
70
+ manualSortBy?: boolean;
71
+ manualFilters?: boolean;
72
+ /**
73
+ * Configuration operation for each line.
74
+ */
75
+ operations?: Operation[];
76
+ i18n?: (f: string) => string;
77
+ /**
78
+ * Enable drag and drop rows
79
+ */
80
+ enableDragNDrop?: boolean;
81
+ onDrag?: (data: Data[]) => void;
82
+ onDrop?: (item: Data) => void;
83
+ }
84
+ export declare function getOperationCallback(operations: Operation[], onClick: OnClickOperation): (data: any, action: string) => void;
85
+ declare function DefaultLoader(): JSX.Element;
86
+ declare function DefaultEmptyData(): JSX.Element;
87
+ export declare function useCustomTable<Data extends object = {}>(props: PropsWithChildren<TableProps<Data>>): {
88
+ className: string;
89
+ tableInstance: import("react-table").TableInstance<Data>;
90
+ CellHeader: any;
91
+ isLoading: boolean | undefined;
92
+ onClick: (data: any, action: string) => void;
93
+ Loader: React.ComponentType<{}> | typeof DefaultLoader;
94
+ EmptyData: React.ComponentType<{}> | typeof DefaultEmptyData;
95
+ Row: React.ComponentType<DefaultRowProps<Data>> | typeof DefaultRow;
96
+ data: Data[];
97
+ disablePagination: boolean | undefined;
98
+ Pagination: React.ComponentType<{}> | typeof DefaultPagination;
99
+ pageIndex: number;
100
+ pageSize: number;
101
+ pageSizes: number[];
102
+ setPageSize: (pageSize: number) => void;
103
+ i18n: (f: string) => string;
104
+ children: React.ReactNode;
105
+ onDrag: (dragIndex: number, hoverIndex: number) => void;
106
+ onDrop: (...args: any[]) => void;
107
+ /**
108
+ * Call the listener when a filter / pagination / sort change.
109
+ */
110
+ onChange?: ((query: QueryOptions) => void) | undefined;
111
+ /**
112
+ * Custom ArrowSort
113
+ */
114
+ ArrowSort?: React.ComponentType<{}> | undefined;
115
+ /**
116
+ * Custom default ColumnFilter
117
+ */
118
+ ColumnFilter?: Renderer<FilterProps<Data>> | undefined;
119
+ /**
120
+ * Custom cell
121
+ */
122
+ Cell?: React.ComponentType<CellProps<Data, any>> | undefined;
123
+ /**
124
+ *
125
+ */
126
+ CellOperations?: React.ComponentType<{}> | undefined;
127
+ /**
128
+ * Disable filters
129
+ */
130
+ disableFilters?: boolean | undefined;
131
+ manualPagination?: boolean | undefined;
132
+ manualSortBy?: boolean | undefined;
133
+ manualFilters?: boolean | undefined;
134
+ /**
135
+ * Configuration operation for each line.
136
+ */
137
+ operations?: Operation<any>[] | undefined;
138
+ /**
139
+ * Enable drag and drop rows
140
+ */
141
+ enableDragNDrop?: boolean | undefined;
142
+ columns: import("react-table").Column<Data>[];
143
+ initialState?: Partial<import("react-table").TableState<Data>> | undefined;
144
+ stateReducer?: ((newState: import("react-table").TableState<Data>, action: import("react-table").ActionType, previousState: import("react-table").TableState<Data>, instance?: import("react-table").TableInstance<Data> | undefined) => import("react-table").TableState<Data>) | undefined;
145
+ useControlledState?: ((state: import("react-table").TableState<Data>, meta: import("react-table").MetaBase<Data>) => import("react-table").TableState<Data>) | undefined;
146
+ defaultColumn?: Partial<import("react-table").Column<Data>> | undefined;
147
+ getSubRows?: ((originalRow: Data, relativeIndex: number) => Data[]) | undefined;
148
+ getRowId?: ((originalRow: Data, relativeIndex: number, parent?: import("react-table").Row<Data> | undefined) => string) | undefined;
149
+ autoResetHiddenColumns?: boolean | undefined;
150
+ manualExpandedKey?: import("react-table").IdType<Data> | undefined;
151
+ paginateExpandedRows?: boolean | undefined;
152
+ expandSubRows?: boolean | undefined;
153
+ autoResetExpanded?: boolean | undefined;
154
+ defaultCanFilter?: boolean | undefined;
155
+ filterTypes?: import("react-table").FilterTypes<Data> | undefined;
156
+ autoResetFilters?: boolean | undefined;
157
+ globalFilter?: string | ((rows: import("react-table").Row<Data>[], columnIds: import("react-table").IdType<Data>[], filterValue: any) => import("react-table").Row<Data>[]) | undefined;
158
+ manualGlobalFilter?: boolean | undefined;
159
+ autoResetGlobalFilter?: boolean | undefined;
160
+ disableGlobalFilter?: boolean | undefined;
161
+ manualGroupBy?: boolean | undefined;
162
+ disableGroupBy?: boolean | undefined;
163
+ defaultCanGroupBy?: boolean | undefined;
164
+ aggregations?: Record<string, import("react-table").AggregatorFn<Data>> | undefined;
165
+ groupByFn?: ((rows: import("react-table").Row<Data>[], columnId: import("react-table").IdType<Data>) => Record<string, import("react-table").Row<Data>[]>) | undefined;
166
+ autoResetGroupBy?: boolean | undefined;
167
+ pageCount?: number | undefined;
168
+ autoResetPage?: boolean | undefined;
169
+ disableResizing?: boolean | undefined;
170
+ manualRowSelectedKey?: import("react-table").IdType<Data> | undefined;
171
+ autoResetSelectedRows?: boolean | undefined;
172
+ selectSubRows?: boolean | undefined;
173
+ disableSortBy?: boolean | undefined;
174
+ defaultCanSort?: boolean | undefined;
175
+ disableMultiSort?: boolean | undefined;
176
+ isMultiSortEvent?: ((e: React.MouseEvent<Element, MouseEvent>) => boolean) | undefined;
177
+ maxMultiSortColCount?: number | undefined;
178
+ disableSortRemove?: boolean | undefined;
179
+ disabledMultiRemove?: boolean | undefined;
180
+ orderByFn?: ((rows: import("react-table").Row<Data>[], sortFns: import("react-table").SortByFn<Data>[], directions: boolean[]) => import("react-table").Row<Data>[]) | undefined;
181
+ sortTypes?: Record<string, import("react-table").SortByFn<Data>> | undefined;
182
+ autoResetSortBy?: boolean | undefined;
183
+ sortBy?: import("../../../interfaces").ColumnIdentifier[] | undefined;
184
+ filters?: import("../../../interfaces").ColumnIdentifier[] | undefined;
185
+ filterId?: string | undefined;
186
+ };
187
+ export {};
@@ -0,0 +1,266 @@
1
+ /// <reference types="react" />
2
+ import { DefaultRowProps } from "../components/defaultRow.component";
3
+ export declare function useDndRow<Data extends object = {}>({ onDrag, onDrop, index, ...props }: DefaultRowProps<Data>): {
4
+ opacity: number;
5
+ isDragging: boolean;
6
+ dropRef: import("react").RefObject<HTMLTableRowElement>;
7
+ dragRef: import("react").RefObject<HTMLTableDataCellElement>;
8
+ onClick: (data: any, action: string) => void;
9
+ row: import("react-table").Row<Data>;
10
+ enableDragNDrop?: boolean | undefined;
11
+ ref?: import("react").LegacyRef<HTMLTableRowElement> | undefined;
12
+ key?: import("react").Key | null | undefined;
13
+ defaultChecked?: boolean | undefined;
14
+ defaultValue?: string | number | readonly string[] | undefined;
15
+ suppressContentEditableWarning?: boolean | undefined;
16
+ suppressHydrationWarning?: boolean | undefined;
17
+ accessKey?: string | undefined;
18
+ className?: string | undefined;
19
+ contentEditable?: (boolean | "true" | "false") | "inherit" | undefined;
20
+ contextMenu?: string | undefined;
21
+ dir?: string | undefined;
22
+ draggable?: (boolean | "true" | "false") | undefined;
23
+ hidden?: boolean | undefined;
24
+ id?: string | undefined;
25
+ lang?: string | undefined;
26
+ placeholder?: string | undefined;
27
+ slot?: string | undefined;
28
+ spellCheck?: (boolean | "true" | "false") | undefined;
29
+ style?: import("react").CSSProperties | undefined;
30
+ tabIndex?: number | undefined;
31
+ title?: string | undefined;
32
+ translate?: "yes" | "no" | undefined;
33
+ radioGroup?: string | undefined;
34
+ role?: string | undefined;
35
+ about?: string | undefined;
36
+ datatype?: string | undefined;
37
+ inlist?: any;
38
+ prefix?: string | undefined;
39
+ property?: string | undefined;
40
+ resource?: string | undefined;
41
+ typeof?: string | undefined;
42
+ vocab?: string | undefined;
43
+ autoCapitalize?: string | undefined;
44
+ autoCorrect?: string | undefined;
45
+ autoSave?: string | undefined;
46
+ color?: string | undefined;
47
+ itemProp?: string | undefined;
48
+ itemScope?: boolean | undefined;
49
+ itemType?: string | undefined;
50
+ itemID?: string | undefined;
51
+ itemRef?: string | undefined;
52
+ results?: number | undefined;
53
+ security?: string | undefined;
54
+ unselectable?: "on" | "off" | undefined;
55
+ inputMode?: "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined;
56
+ is?: string | undefined;
57
+ 'aria-activedescendant'?: string | undefined;
58
+ 'aria-atomic'?: boolean | "true" | "false" | undefined;
59
+ 'aria-autocomplete'?: "none" | "inline" | "list" | "both" | undefined;
60
+ 'aria-busy'?: boolean | "true" | "false" | undefined;
61
+ 'aria-checked'?: boolean | "true" | "false" | "mixed" | undefined;
62
+ 'aria-colcount'?: number | undefined;
63
+ 'aria-colindex'?: number | undefined;
64
+ 'aria-colspan'?: number | undefined;
65
+ 'aria-controls'?: string | undefined;
66
+ 'aria-current'?: boolean | "true" | "false" | "page" | "step" | "location" | "date" | "time" | undefined;
67
+ 'aria-describedby'?: string | undefined;
68
+ 'aria-details'?: string | undefined;
69
+ 'aria-disabled'?: boolean | "true" | "false" | undefined;
70
+ 'aria-dropeffect'?: "none" | "copy" | "execute" | "link" | "move" | "popup" | undefined;
71
+ 'aria-errormessage'?: string | undefined;
72
+ 'aria-expanded'?: boolean | "true" | "false" | undefined;
73
+ 'aria-flowto'?: string | undefined;
74
+ 'aria-grabbed'?: boolean | "true" | "false" | undefined;
75
+ 'aria-haspopup'?: boolean | "true" | "false" | "menu" | "listbox" | "tree" | "grid" | "dialog" | undefined;
76
+ 'aria-hidden'?: boolean | "true" | "false" | undefined;
77
+ 'aria-invalid'?: boolean | "true" | "false" | "grammar" | "spelling" | undefined;
78
+ 'aria-keyshortcuts'?: string | undefined;
79
+ 'aria-label'?: string | undefined;
80
+ 'aria-labelledby'?: string | undefined;
81
+ 'aria-level'?: number | undefined;
82
+ 'aria-live'?: "off" | "assertive" | "polite" | undefined;
83
+ 'aria-modal'?: boolean | "true" | "false" | undefined;
84
+ 'aria-multiline'?: boolean | "true" | "false" | undefined;
85
+ 'aria-multiselectable'?: boolean | "true" | "false" | undefined;
86
+ 'aria-orientation'?: "horizontal" | "vertical" | undefined;
87
+ 'aria-owns'?: string | undefined;
88
+ 'aria-placeholder'?: string | undefined;
89
+ 'aria-posinset'?: number | undefined;
90
+ 'aria-pressed'?: boolean | "true" | "false" | "mixed" | undefined;
91
+ 'aria-readonly'?: boolean | "true" | "false" | undefined;
92
+ 'aria-relevant'?: "text" | "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text additions" | "text removals" | undefined;
93
+ 'aria-required'?: boolean | "true" | "false" | undefined;
94
+ 'aria-roledescription'?: string | undefined;
95
+ 'aria-rowcount'?: number | undefined;
96
+ 'aria-rowindex'?: number | undefined;
97
+ 'aria-rowspan'?: number | undefined;
98
+ 'aria-selected'?: boolean | "true" | "false" | undefined;
99
+ 'aria-setsize'?: number | undefined;
100
+ 'aria-sort'?: "none" | "ascending" | "descending" | "other" | undefined;
101
+ 'aria-valuemax'?: number | undefined;
102
+ 'aria-valuemin'?: number | undefined;
103
+ 'aria-valuenow'?: number | undefined;
104
+ 'aria-valuetext'?: string | undefined;
105
+ children?: import("react").ReactNode;
106
+ dangerouslySetInnerHTML?: {
107
+ __html: string;
108
+ } | undefined;
109
+ onCopy?: import("react").ClipboardEventHandler<HTMLTableRowElement> | undefined;
110
+ onCopyCapture?: import("react").ClipboardEventHandler<HTMLTableRowElement> | undefined;
111
+ onCut?: import("react").ClipboardEventHandler<HTMLTableRowElement> | undefined;
112
+ onCutCapture?: import("react").ClipboardEventHandler<HTMLTableRowElement> | undefined;
113
+ onPaste?: import("react").ClipboardEventHandler<HTMLTableRowElement> | undefined;
114
+ onPasteCapture?: import("react").ClipboardEventHandler<HTMLTableRowElement> | undefined;
115
+ onCompositionEnd?: import("react").CompositionEventHandler<HTMLTableRowElement> | undefined;
116
+ onCompositionEndCapture?: import("react").CompositionEventHandler<HTMLTableRowElement> | undefined;
117
+ onCompositionStart?: import("react").CompositionEventHandler<HTMLTableRowElement> | undefined;
118
+ onCompositionStartCapture?: import("react").CompositionEventHandler<HTMLTableRowElement> | undefined;
119
+ onCompositionUpdate?: import("react").CompositionEventHandler<HTMLTableRowElement> | undefined;
120
+ onCompositionUpdateCapture?: import("react").CompositionEventHandler<HTMLTableRowElement> | undefined;
121
+ onFocus?: import("react").FocusEventHandler<HTMLTableRowElement> | undefined;
122
+ onFocusCapture?: import("react").FocusEventHandler<HTMLTableRowElement> | undefined;
123
+ onBlur?: import("react").FocusEventHandler<HTMLTableRowElement> | undefined;
124
+ onBlurCapture?: import("react").FocusEventHandler<HTMLTableRowElement> | undefined;
125
+ onChange?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
126
+ onChangeCapture?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
127
+ onBeforeInput?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
128
+ onBeforeInputCapture?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
129
+ onInput?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
130
+ onInputCapture?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
131
+ onReset?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
132
+ onResetCapture?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
133
+ onSubmit?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
134
+ onSubmitCapture?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
135
+ onInvalid?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
136
+ onInvalidCapture?: import("react").FormEventHandler<HTMLTableRowElement> | undefined;
137
+ onLoad?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
138
+ onLoadCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
139
+ onError?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
140
+ onErrorCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
141
+ onKeyDown?: import("react").KeyboardEventHandler<HTMLTableRowElement> | undefined;
142
+ onKeyDownCapture?: import("react").KeyboardEventHandler<HTMLTableRowElement> | undefined;
143
+ onKeyPress?: import("react").KeyboardEventHandler<HTMLTableRowElement> | undefined;
144
+ onKeyPressCapture?: import("react").KeyboardEventHandler<HTMLTableRowElement> | undefined;
145
+ onKeyUp?: import("react").KeyboardEventHandler<HTMLTableRowElement> | undefined;
146
+ onKeyUpCapture?: import("react").KeyboardEventHandler<HTMLTableRowElement> | undefined;
147
+ onAbort?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
148
+ onAbortCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
149
+ onCanPlay?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
150
+ onCanPlayCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
151
+ onCanPlayThrough?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
152
+ onCanPlayThroughCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
153
+ onDurationChange?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
154
+ onDurationChangeCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
155
+ onEmptied?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
156
+ onEmptiedCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
157
+ onEncrypted?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
158
+ onEncryptedCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
159
+ onEnded?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
160
+ onEndedCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
161
+ onLoadedData?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
162
+ onLoadedDataCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
163
+ onLoadedMetadata?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
164
+ onLoadedMetadataCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
165
+ onLoadStart?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
166
+ onLoadStartCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
167
+ onPause?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
168
+ onPauseCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
169
+ onPlay?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
170
+ onPlayCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
171
+ onPlaying?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
172
+ onPlayingCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
173
+ onProgress?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
174
+ onProgressCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
175
+ onRateChange?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
176
+ onRateChangeCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
177
+ onSeeked?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
178
+ onSeekedCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
179
+ onSeeking?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
180
+ onSeekingCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
181
+ onStalled?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
182
+ onStalledCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
183
+ onSuspend?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
184
+ onSuspendCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
185
+ onTimeUpdate?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
186
+ onTimeUpdateCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
187
+ onVolumeChange?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
188
+ onVolumeChangeCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
189
+ onWaiting?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
190
+ onWaitingCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
191
+ onAuxClick?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
192
+ onAuxClickCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
193
+ onClickCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
194
+ onContextMenu?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
195
+ onContextMenuCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
196
+ onDoubleClick?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
197
+ onDoubleClickCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
198
+ onDragCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
199
+ onDragEnd?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
200
+ onDragEndCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
201
+ onDragEnter?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
202
+ onDragEnterCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
203
+ onDragExit?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
204
+ onDragExitCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
205
+ onDragLeave?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
206
+ onDragLeaveCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
207
+ onDragOver?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
208
+ onDragOverCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
209
+ onDragStart?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
210
+ onDragStartCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
211
+ onDropCapture?: import("react").DragEventHandler<HTMLTableRowElement> | undefined;
212
+ onMouseDown?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
213
+ onMouseDownCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
214
+ onMouseEnter?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
215
+ onMouseLeave?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
216
+ onMouseMove?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
217
+ onMouseMoveCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
218
+ onMouseOut?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
219
+ onMouseOutCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
220
+ onMouseOver?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
221
+ onMouseOverCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
222
+ onMouseUp?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
223
+ onMouseUpCapture?: import("react").MouseEventHandler<HTMLTableRowElement> | undefined;
224
+ onSelect?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
225
+ onSelectCapture?: import("react").ReactEventHandler<HTMLTableRowElement> | undefined;
226
+ onTouchCancel?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
227
+ onTouchCancelCapture?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
228
+ onTouchEnd?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
229
+ onTouchEndCapture?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
230
+ onTouchMove?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
231
+ onTouchMoveCapture?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
232
+ onTouchStart?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
233
+ onTouchStartCapture?: import("react").TouchEventHandler<HTMLTableRowElement> | undefined;
234
+ onPointerDown?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
235
+ onPointerDownCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
236
+ onPointerMove?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
237
+ onPointerMoveCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
238
+ onPointerUp?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
239
+ onPointerUpCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
240
+ onPointerCancel?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
241
+ onPointerCancelCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
242
+ onPointerEnter?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
243
+ onPointerEnterCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
244
+ onPointerLeave?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
245
+ onPointerLeaveCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
246
+ onPointerOver?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
247
+ onPointerOverCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
248
+ onPointerOut?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
249
+ onPointerOutCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
250
+ onGotPointerCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
251
+ onGotPointerCaptureCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
252
+ onLostPointerCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
253
+ onLostPointerCaptureCapture?: import("react").PointerEventHandler<HTMLTableRowElement> | undefined;
254
+ onScroll?: import("react").UIEventHandler<HTMLTableRowElement> | undefined;
255
+ onScrollCapture?: import("react").UIEventHandler<HTMLTableRowElement> | undefined;
256
+ onWheel?: import("react").WheelEventHandler<HTMLTableRowElement> | undefined;
257
+ onWheelCapture?: import("react").WheelEventHandler<HTMLTableRowElement> | undefined;
258
+ onAnimationStart?: import("react").AnimationEventHandler<HTMLTableRowElement> | undefined;
259
+ onAnimationStartCapture?: import("react").AnimationEventHandler<HTMLTableRowElement> | undefined;
260
+ onAnimationEnd?: import("react").AnimationEventHandler<HTMLTableRowElement> | undefined;
261
+ onAnimationEndCapture?: import("react").AnimationEventHandler<HTMLTableRowElement> | undefined;
262
+ onAnimationIteration?: import("react").AnimationEventHandler<HTMLTableRowElement> | undefined;
263
+ onAnimationIterationCapture?: import("react").AnimationEventHandler<HTMLTableRowElement> | undefined;
264
+ onTransitionEnd?: import("react").TransitionEventHandler<HTMLTableRowElement> | undefined;
265
+ onTransitionEndCapture?: import("react").TransitionEventHandler<HTMLTableRowElement> | undefined;
266
+ };
@@ -7,5 +7,6 @@ export * from "./components/defaultOperationButton.component";
7
7
  export * from "./filters/defaultColumnFilter.component";
8
8
  export * from "./filters/selectColumnFilter.component";
9
9
  export * from "./filters/sliderColumnFilter.component";
10
+ export * from "./hooks/useCustomTable.hook";
11
+ export * from "./hooks/useOperations.hook";
10
12
  export * from "./table.component";
11
- export * from "./utils/useOperations.hook";
@@ -1,72 +1,3 @@
1
- import React, { PropsWithChildren } from "react";
2
- import { CellProps, FilterProps, Renderer, TableOptions } from "react-table";
3
- import { OnClickOperation, Operation, QueryOptions } from "../../interfaces";
4
- import { DefaultCellHeaderProps } from "./components/defaultCellHeader.component";
5
- export interface TableProps<Data extends object = any> extends TableOptions<Data>, Partial<QueryOptions> {
6
- className?: string;
7
- /**
8
- * Call the listener when a filter / pagination / sort change.
9
- */
10
- onChange?: (query: QueryOptions) => void;
11
- /**
12
- * Call the listener when a line is clicked.
13
- */
14
- onClick?: OnClickOperation<Data>;
15
- /**
16
- * Pagination steps list
17
- */
18
- pageSizes?: number[];
19
- /**
20
- *
21
- */
22
- isLoading?: boolean;
23
- /**
24
- * Custom EmptyData displayed when there is no data
25
- */
26
- EmptyData?: React.ComponentType;
27
- /**
28
- * Custom ArrowSort
29
- */
30
- ArrowSort?: React.ComponentType;
31
- /**
32
- * Custom default ColumnFilter
33
- */
34
- ColumnFilter?: Renderer<FilterProps<Data>>;
35
- /**
36
- * Custom cell
37
- */
38
- Cell?: React.ComponentType<CellProps<Data>>;
39
- /**
40
- *
41
- */
42
- CellHeader?: React.ComponentType<DefaultCellHeaderProps<Data>>;
43
- /**
44
- *
45
- */
46
- CellOperations?: React.ComponentType;
47
- /**
48
- * Custom Loader
49
- */
50
- Loader?: React.ComponentType;
51
- /**
52
- * Custom Loader
53
- */
54
- Pagination?: React.ComponentType;
55
- /**
56
- * Disable filters
57
- */
58
- disableFilters?: boolean;
59
- /**
60
- * Disable pagination
61
- */
62
- disablePagination?: boolean;
63
- manualPagination?: boolean;
64
- manualSortBy?: boolean;
65
- manualFilters?: boolean;
66
- /**
67
- * Configuration operation for each line.
68
- */
69
- operations?: Operation[];
70
- i18n?: (f: string) => string;
71
- }
1
+ import { PropsWithChildren } from "react";
2
+ import { TableProps } from "./hooks/useCustomTable.hook";
72
3
  export declare function Table<Data extends object = any>(props: PropsWithChildren<TableProps<Data>>): JSX.Element;
@@ -43,3 +43,28 @@ export declare const Sandbox: {
43
43
  })[];
44
44
  };
45
45
  };
46
+ export declare const TableWithDragNDrop: {
47
+ (args: any): JSX.Element;
48
+ args: {
49
+ enableDragNDrop: boolean;
50
+ data: never[];
51
+ columns: import("react-table").Column<{}>[];
52
+ operations: ({
53
+ title: string;
54
+ action: string;
55
+ alias: string;
56
+ path: string;
57
+ icon: string;
58
+ permissionsResolver(): boolean;
59
+ buttonType?: undefined;
60
+ } | {
61
+ action: string;
62
+ path: string;
63
+ icon: string;
64
+ buttonType: string;
65
+ permissionsResolver(): boolean;
66
+ title?: undefined;
67
+ alias?: undefined;
68
+ })[];
69
+ };
70
+ };
@@ -0,0 +1 @@
1
+ export declare const swapElements: <T = any>(myArray: T[], index1: number, index2: number) => T[];