@tsed/react-formio 2.1.2 → 2.2.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 (80) hide show
  1. package/coverage.json +4 -4
  2. package/dist/components/actions-table/actionsTable.component.d.ts +3 -2
  3. package/dist/components/actions-table/actionsTable.stories.d.ts +2 -1
  4. package/dist/components/alert/alert.component.d.ts +2 -1
  5. package/dist/components/alert/alert.stories.d.ts +2 -1
  6. package/dist/components/card/card.component.d.ts +1 -1
  7. package/dist/components/card/card.stories.d.ts +2 -1
  8. package/dist/components/form/form.component.d.ts +2 -1
  9. package/dist/components/form/form.stories.d.ts +5 -4
  10. package/dist/components/form-access/formAccess.stories.d.ts +2 -1
  11. package/dist/components/form-access/formAccess.utils.d.ts +3 -3
  12. package/dist/components/form-action/formAction.stories.d.ts +2 -1
  13. package/dist/components/form-builder/formBuilder.component.d.ts +1 -1
  14. package/dist/components/form-builder/formBuilder.stories.d.ts +7 -6
  15. package/dist/components/form-control/formControl.component.d.ts +1 -1
  16. package/dist/components/form-control/formControl.stories.d.ts +11 -10
  17. package/dist/components/form-edit/formEdit.component.d.ts +2 -1
  18. package/dist/components/form-edit/formEdit.stories.d.ts +17 -16
  19. package/dist/components/form-settings/formSettings.component.d.ts +2 -1
  20. package/dist/components/form-settings/formSettings.stories.d.ts +2 -1
  21. package/dist/components/form-settings/formSettings.utils.d.ts +1 -1
  22. package/dist/components/forms-table/components/formCell.component.d.ts +2 -1
  23. package/dist/components/forms-table/formsTable.component.d.ts +3 -2
  24. package/dist/components/forms-table/formsTable.stories.d.ts +3 -2
  25. package/dist/components/input-tags/inputTags.component.d.ts +2 -1
  26. package/dist/components/input-tags/inputTags.stories.d.ts +4 -3
  27. package/dist/components/input-text/inputText.component.d.ts +2 -1
  28. package/dist/components/input-text/inputText.stories.d.ts +6 -5
  29. package/dist/components/loader/loader.component.d.ts +2 -2
  30. package/dist/components/loader/loader.stories.d.ts +2 -1
  31. package/dist/components/modal/modal.component.d.ts +1 -1
  32. package/dist/components/modal/modal.stories.d.ts +5 -4
  33. package/dist/components/modal/removeModal.component.d.ts +2 -2
  34. package/dist/components/pagination/pagination.component.d.ts +4 -2
  35. package/dist/components/pagination/pagination.stories.d.ts +2 -1
  36. package/dist/components/react-component/reactComponent.component.d.ts +1 -1
  37. package/dist/components/select/select.stories.d.ts +9 -8
  38. package/dist/components/submissions-table/submissionsTable.component.d.ts +3 -2
  39. package/dist/components/submissions-table/submissionsTable.stories.d.ts +2 -1
  40. package/dist/components/table/components/defaultArrowSort.component.d.ts +2 -1
  41. package/dist/components/table/components/defaultCellHeader.component.d.ts +2 -1
  42. package/dist/components/table/components/defaultCellOperations.component.d.ts +2 -1
  43. package/dist/components/table/components/defaultCells.component.d.ts +2 -1
  44. package/dist/components/table/components/defaultOperationButton.component.d.ts +2 -1
  45. package/dist/components/table/components/defaultRow.component.d.ts +3 -3
  46. package/dist/components/table/components/dragNDropContainer.d.ts +2 -2
  47. package/dist/components/table/filters/defaultColumnFilter.component.d.ts +2 -1
  48. package/dist/components/table/filters/selectColumnFilter.component.d.ts +2 -1
  49. package/dist/components/table/filters/sliderColumnFilter.component.d.ts +2 -1
  50. package/dist/components/table/hooks/useCustomTable.hook.d.ts +5 -83
  51. package/dist/components/table/hooks/useDragnDropRow.hook.d.ts +25 -18
  52. package/dist/components/table/hooks/useOperations.hook.d.ts +1 -1
  53. package/dist/components/table/index.d.ts +3 -0
  54. package/dist/components/table/table.component.d.ts +2 -2
  55. package/dist/components/table/table.stories.d.ts +3 -2
  56. package/dist/components/tabs/tabs.component.d.ts +3 -3
  57. package/dist/components/tabs/tabs.component.stories.d.ts +3 -2
  58. package/dist/index.js +451 -494
  59. package/dist/index.js.map +1 -1
  60. package/dist/index.modern.js +66 -103
  61. package/dist/index.modern.js.map +1 -1
  62. package/dist/interfaces/FormSchema.d.ts +1 -1
  63. package/dist/interfaces/Operation.d.ts +2 -2
  64. package/dist/interfaces/QueryOptions.d.ts +1 -1
  65. package/package.json +4 -3
  66. package/readme.md +17 -195
  67. package/src/components/form/form.stories.tsx +128 -122
  68. package/src/components/form/useForm.hook.ts +1 -1
  69. package/src/components/form-builder/formBuilder.stories.tsx +3540 -3537
  70. package/src/components/form-edit/formEdit.stories.tsx +320 -317
  71. package/src/components/forms-table/formsTable.component.tsx +1 -1
  72. package/src/components/modal/removeModal.component.tsx +3 -4
  73. package/src/components/pagination/pagination.component.spec.tsx +8 -0
  74. package/src/components/pagination/pagination.component.tsx +14 -2
  75. package/src/components/table/components/defaultCellHeader.component.tsx +3 -3
  76. package/src/components/table/components/defaultCells.component.tsx +1 -1
  77. package/src/components/table/filters/defaultColumnFilter.component.tsx +1 -1
  78. package/src/components/table/hooks/useCustomTable.hook.tsx +4 -4
  79. package/src/components/table/index.ts +3 -0
  80. package/tsconfig.json +2 -1
@@ -38,9 +38,10 @@ export interface PaginationProps {
38
38
  canNextPage: boolean;
39
39
  pageCount: number;
40
40
  pageIndex: number;
41
- pageOptions?: any;
41
+ pageOptions?: number[];
42
42
  pageSize: number;
43
43
  setPageSize: any;
44
+ totalLength?: number;
44
45
  i18n?: (f: string) => string;
45
46
  }
46
47
 
@@ -58,6 +59,7 @@ export function Pagination(props: PaginationProps) {
58
59
  pageOptions,
59
60
  pageSize,
60
61
  setPageSize,
62
+ totalLength,
61
63
  i18n = (f: string) => f
62
64
  } = props;
63
65
 
@@ -115,11 +117,21 @@ export function Pagination(props: PaginationProps) {
115
117
  <span className={"ml-3"}>{i18n("items per page")}</span>
116
118
  </li>
117
119
  {pageOptions && (
118
- <li className={"mb-3 flex items-center"}>
120
+ <li className={"mb-3 mr-3 flex items-center"}>
119
121
  <span>{i18n("Page")}&nbsp;</span>
120
122
  <strong>
121
123
  {pageIndex + 1} of {pageOptions.length}
122
124
  </strong>
125
+ {totalLength !== undefined && (
126
+ <span className='ml-3'>
127
+ {i18n("Totals")}: <strong>{new Intl.NumberFormat(undefined).format(totalLength)}</strong> {i18n("items")}
128
+ </span>
129
+ )}
130
+ </li>
131
+ )}
132
+ {totalLength !== undefined && (
133
+ <li className={"mb-3 flex items-center"} data-testid='pagination-total-items'>
134
+ {i18n("Totals")}: <strong>{new Intl.NumberFormat(undefined).format(totalLength)}</strong> {i18n("items")}
123
135
  </li>
124
136
  )}
125
137
  </nav>
@@ -9,11 +9,11 @@ export function DefaultCellHeader<Data extends Record<string, unknown> = {}>({ c
9
9
  return (
10
10
  <div className={"table-cell-header"}>
11
11
  <div className='table-cell-header__label' {...column.getSortByToggleProps()}>
12
- <span>{column.render("Header")}</span>
12
+ <span>{column.render("Header") as any}</span>
13
13
 
14
- {column.render("ArrowSort")}
14
+ {column.render("ArrowSort") as any}
15
15
  </div>
16
- {column.canFilter ? <div className='table-cell-header__filter'>{column.render("Filter")}</div> : null}
16
+ {column.canFilter ? <div className='table-cell-header__filter'>{column.render("Filter") as any}</div> : null}
17
17
  </div>
18
18
  );
19
19
  }
@@ -13,7 +13,7 @@ export function DefaultCells<Data extends object = {}>({ row }: { row: Row<Data>
13
13
 
14
14
  return (
15
15
  <td colSpan={colspan} {...cell.getCellProps()} key={`tableInstance.page.cells.${cell.value || "value"}.${i}`}>
16
- {cell.render("Cell")}
16
+ {cell.render("Cell") as any}
17
17
  </td>
18
18
  );
19
19
  })}
@@ -15,7 +15,7 @@ export function DefaultColumnFilter<D extends Record<string, unknown> = {}>(
15
15
  const [value, setValue] = useState(filterValue || "");
16
16
 
17
17
  const onChange = useCallback(
18
- (name, value) => {
18
+ (name: string, value: any) => {
19
19
  setValue(value);
20
20
  setFilterId(id);
21
21
  setFilter(value || undefined);
@@ -156,7 +156,7 @@ export function useCustomTable<Data extends object = {}>(props: PropsWithChildre
156
156
  const [filterId, setFilterId] = React.useState(controlledFilterId);
157
157
 
158
158
  // DND
159
- const [records, setRecords] = useState<Data[]>(data);
159
+ const [records, setRecords] = useState<readonly Data[]>(data);
160
160
 
161
161
  useEffect(() => {
162
162
  setRecords(data);
@@ -212,12 +212,10 @@ export function useCustomTable<Data extends object = {}>(props: PropsWithChildre
212
212
  }, [onChange, pageIndex, pageSize, sortBy, filters, filterId]);
213
213
 
214
214
  return {
215
- ...props,
216
215
  className,
217
216
  tableInstance,
218
217
  CellHeader,
219
218
  isLoading,
220
- onClick: _onClick,
221
219
  Loader,
222
220
  EmptyData,
223
221
  Row,
@@ -230,7 +228,9 @@ export function useCustomTable<Data extends object = {}>(props: PropsWithChildre
230
228
  setPageSize,
231
229
  i18n,
232
230
  children,
231
+ onClick: _onClick as any,
233
232
  onDrag: _onDrag,
234
- onDrop: onDrop
233
+ onDrop: onDrop,
234
+ enableDragNDrop: props.enableDragNDrop
235
235
  };
236
236
  }
@@ -10,3 +10,6 @@ export * from "./filters/sliderColumnFilter.component";
10
10
  export * from "./hooks/useCustomTable.hook";
11
11
  export * from "./hooks/useOperations.hook";
12
12
  export * from "./table.component";
13
+ export * from "./utils/getPageNumbers";
14
+ export * from "./utils/mapFormToColumns";
15
+ export * from "./utils/swapElements";
package/tsconfig.json CHANGED
@@ -1,7 +1,8 @@
1
1
  {
2
2
  "extends": "@tsed/config/tsconfig.web.json",
3
3
  "compilerOptions": {
4
- "rootDir": "src"
4
+ "rootDir": "src",
5
+ "moduleResolution": "node"
5
6
  },
6
7
  "include": ["src"],
7
8
  "references": [