@economic/taco 1.1.13-alpha.0 → 1.3.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 (224) hide show
  1. package/dist/components/Group/Group.d.ts +11 -1
  2. package/dist/components/Icon/components/ChevronLeftSolid.d.ts +3 -0
  3. package/dist/components/Icon/components/ChevronRightSolid.d.ts +3 -0
  4. package/dist/components/Icon/components/index.d.ts +1 -1
  5. package/dist/components/Input/Input.d.ts +1 -1
  6. package/dist/components/Menu/Menu.d.ts +2 -2
  7. package/dist/components/Menu/components/Item.d.ts +1 -1
  8. package/dist/components/Menu/components/Link.d.ts +1 -1
  9. package/dist/components/Toast/Toast.d.ts +2 -2
  10. package/dist/components/Toast/Toaster.d.ts +2 -2
  11. package/dist/esm/components/Accordion/Accordion.js +31 -34
  12. package/dist/esm/components/Accordion/Accordion.js.map +1 -1
  13. package/dist/esm/components/Backdrop/Backdrop.js +2 -2
  14. package/dist/esm/components/Backdrop/Backdrop.js.map +1 -1
  15. package/dist/esm/components/Badge/Badge.js +14 -14
  16. package/dist/esm/components/Badge/Badge.js.map +1 -1
  17. package/dist/esm/components/Banner/Banner.js +7 -5
  18. package/dist/esm/components/Banner/Banner.js.map +1 -1
  19. package/dist/esm/components/Banner/util.js +1 -1
  20. package/dist/esm/components/Banner/util.js.map +1 -1
  21. package/dist/esm/components/Button/Button.js +12 -13
  22. package/dist/esm/components/Button/Button.js.map +1 -1
  23. package/dist/esm/components/Button/util.js +18 -23
  24. package/dist/esm/components/Button/util.js.map +1 -1
  25. package/dist/esm/components/Calendar/Calendar.js +56 -71
  26. package/dist/esm/components/Calendar/Calendar.js.map +1 -1
  27. package/dist/esm/components/Card/Card.js +13 -12
  28. package/dist/esm/components/Card/Card.js.map +1 -1
  29. package/dist/esm/components/Checkbox/Checkbox.js +15 -18
  30. package/dist/esm/components/Checkbox/Checkbox.js.map +1 -1
  31. package/dist/esm/components/Combobox/Combobox.js +23 -25
  32. package/dist/esm/components/Combobox/Combobox.js.map +1 -1
  33. package/dist/esm/components/Combobox/useCombobox.js +78 -99
  34. package/dist/esm/components/Combobox/useCombobox.js.map +1 -1
  35. package/dist/esm/components/Datepicker/Datepicker.js +48 -52
  36. package/dist/esm/components/Datepicker/Datepicker.js.map +1 -1
  37. package/dist/esm/components/Datepicker/useDatepicker.js +27 -34
  38. package/dist/esm/components/Datepicker/useDatepicker.js.map +1 -1
  39. package/dist/esm/components/Dialog/Context.js +4 -4
  40. package/dist/esm/components/Dialog/Context.js.map +1 -1
  41. package/dist/esm/components/Dialog/Dialog.js +39 -58
  42. package/dist/esm/components/Dialog/Dialog.js.map +1 -1
  43. package/dist/esm/components/Dialog/components/Content.js +39 -44
  44. package/dist/esm/components/Dialog/components/Content.js.map +1 -1
  45. package/dist/esm/components/Dialog/components/Drawer.js +3 -3
  46. package/dist/esm/components/Dialog/components/Drawer.js.map +1 -1
  47. package/dist/esm/components/Dialog/components/Extra.js +2 -2
  48. package/dist/esm/components/Dialog/components/Extra.js.map +1 -1
  49. package/dist/esm/components/Dialog/components/Trigger.js +2 -2
  50. package/dist/esm/components/Dialog/components/Trigger.js.map +1 -1
  51. package/dist/esm/components/Field/Field.js +10 -12
  52. package/dist/esm/components/Field/Field.js.map +1 -1
  53. package/dist/esm/components/Form/Form.js +6 -8
  54. package/dist/esm/components/Form/Form.js.map +1 -1
  55. package/dist/esm/components/Group/Group.js +9 -8
  56. package/dist/esm/components/Group/Group.js.map +1 -1
  57. package/dist/esm/components/Hanger/Hanger.js +27 -35
  58. package/dist/esm/components/Hanger/Hanger.js.map +1 -1
  59. package/dist/esm/components/HoverCard/HoverCard.js +8 -9
  60. package/dist/esm/components/HoverCard/HoverCard.js.map +1 -1
  61. package/dist/esm/components/Icon/Icon.js +7 -8
  62. package/dist/esm/components/Icon/Icon.js.map +1 -1
  63. package/dist/esm/components/Icon/components/ChevronLeftSolid.js +20 -0
  64. package/dist/esm/components/Icon/components/ChevronLeftSolid.js.map +1 -0
  65. package/dist/esm/components/Icon/components/ChevronRightSolid.js +20 -0
  66. package/dist/esm/components/Icon/components/ChevronRightSolid.js.map +1 -0
  67. package/dist/esm/components/Icon/components/index.js +8 -4
  68. package/dist/esm/components/Icon/components/index.js.map +1 -1
  69. package/dist/esm/components/IconButton/IconButton.js +9 -11
  70. package/dist/esm/components/IconButton/IconButton.js.map +1 -1
  71. package/dist/esm/components/Input/Input.js +25 -25
  72. package/dist/esm/components/Input/Input.js.map +1 -1
  73. package/dist/esm/components/Input/util.js +2 -2
  74. package/dist/esm/components/Input/util.js.map +1 -1
  75. package/dist/esm/components/Listbox/Listbox.js +24 -25
  76. package/dist/esm/components/Listbox/Listbox.js.map +1 -1
  77. package/dist/esm/components/Listbox/ScrollableList.js +65 -84
  78. package/dist/esm/components/Listbox/ScrollableList.js.map +1 -1
  79. package/dist/esm/components/Listbox/useListbox.js +53 -61
  80. package/dist/esm/components/Listbox/useListbox.js.map +1 -1
  81. package/dist/esm/components/Listbox/useMultiListbox.js +69 -96
  82. package/dist/esm/components/Listbox/useMultiListbox.js.map +1 -1
  83. package/dist/esm/components/Listbox/useTypeahead.js +10 -9
  84. package/dist/esm/components/Listbox/useTypeahead.js.map +1 -1
  85. package/dist/esm/components/Listbox/util.js +48 -85
  86. package/dist/esm/components/Listbox/util.js.map +1 -1
  87. package/dist/esm/components/Menu/Context.js +2 -2
  88. package/dist/esm/components/Menu/Context.js.map +1 -1
  89. package/dist/esm/components/Menu/Menu.js +16 -34
  90. package/dist/esm/components/Menu/Menu.js.map +1 -1
  91. package/dist/esm/components/Menu/components/Checkbox.js +9 -10
  92. package/dist/esm/components/Menu/components/Checkbox.js.map +1 -1
  93. package/dist/esm/components/Menu/components/Content.js +9 -11
  94. package/dist/esm/components/Menu/components/Content.js.map +1 -1
  95. package/dist/esm/components/Menu/components/Header.js +3 -3
  96. package/dist/esm/components/Menu/components/Header.js.map +1 -1
  97. package/dist/esm/components/Menu/components/Item.js +30 -31
  98. package/dist/esm/components/Menu/components/Item.js.map +1 -1
  99. package/dist/esm/components/Menu/components/Link.js +10 -11
  100. package/dist/esm/components/Menu/components/Link.js.map +1 -1
  101. package/dist/esm/components/Menu/components/RadioGroup.js +17 -19
  102. package/dist/esm/components/Menu/components/RadioGroup.js.map +1 -1
  103. package/dist/esm/components/Menu/components/Separator.js +1 -1
  104. package/dist/esm/components/Menu/components/Separator.js.map +1 -1
  105. package/dist/esm/components/Menu/components/Trigger.js +4 -4
  106. package/dist/esm/components/Menu/components/Trigger.js.map +1 -1
  107. package/dist/esm/components/Navigation/Navigation.js +35 -44
  108. package/dist/esm/components/Navigation/Navigation.js.map +1 -1
  109. package/dist/esm/components/Pagination/PageNumbers.js +23 -28
  110. package/dist/esm/components/Pagination/PageNumbers.js.map +1 -1
  111. package/dist/esm/components/Pagination/Pagination.js +39 -56
  112. package/dist/esm/components/Pagination/Pagination.js.map +1 -1
  113. package/dist/esm/components/Pagination/usePagination.js +7 -21
  114. package/dist/esm/components/Pagination/usePagination.js.map +1 -1
  115. package/dist/esm/components/Pagination/usePaginationShortcuts.js +13 -14
  116. package/dist/esm/components/Pagination/usePaginationShortcuts.js.map +1 -1
  117. package/dist/esm/components/Popover/Popover.js +29 -34
  118. package/dist/esm/components/Popover/Popover.js.map +1 -1
  119. package/dist/esm/components/Popover/Primitives.js +7 -8
  120. package/dist/esm/components/Popover/Primitives.js.map +1 -1
  121. package/dist/esm/components/Progress/Progress.js +11 -15
  122. package/dist/esm/components/Progress/Progress.js.map +1 -1
  123. package/dist/esm/components/Provider/Provider.js +13 -18
  124. package/dist/esm/components/Provider/Provider.js.map +1 -1
  125. package/dist/esm/components/RadioGroup/RadioGroup.js +45 -57
  126. package/dist/esm/components/RadioGroup/RadioGroup.js.map +1 -1
  127. package/dist/esm/components/SearchInput/SearchInput.js +10 -12
  128. package/dist/esm/components/SearchInput/SearchInput.js.map +1 -1
  129. package/dist/esm/components/Select/Select.js +30 -31
  130. package/dist/esm/components/Select/Select.js.map +1 -1
  131. package/dist/esm/components/Select/useSelect.js +69 -88
  132. package/dist/esm/components/Select/useSelect.js.map +1 -1
  133. package/dist/esm/components/Spinner/Spinner.js +12 -19
  134. package/dist/esm/components/Spinner/Spinner.js.map +1 -1
  135. package/dist/esm/components/Switch/Switch.js +9 -10
  136. package/dist/esm/components/Switch/Switch.js.map +1 -1
  137. package/dist/esm/components/Table/components/BaseTable.js +23 -30
  138. package/dist/esm/components/Table/components/BaseTable.js.map +1 -1
  139. package/dist/esm/components/Table/components/PaginatedTable.js +3 -7
  140. package/dist/esm/components/Table/components/PaginatedTable.js.map +1 -1
  141. package/dist/esm/components/Table/components/Table.js +18 -25
  142. package/dist/esm/components/Table/components/Table.js.map +1 -1
  143. package/dist/esm/components/Table/components/WindowedTable.js +89 -109
  144. package/dist/esm/components/Table/components/WindowedTable.js.map +1 -1
  145. package/dist/esm/components/Table/hooks/plugins/useRowActions.js +123 -148
  146. package/dist/esm/components/Table/hooks/plugins/useRowActions.js.map +1 -1
  147. package/dist/esm/components/Table/hooks/plugins/useRowDraggable.js +57 -61
  148. package/dist/esm/components/Table/hooks/plugins/useRowDraggable.js.map +1 -1
  149. package/dist/esm/components/Table/hooks/plugins/useRowEditing.js +39 -36
  150. package/dist/esm/components/Table/hooks/plugins/useRowEditing.js.map +1 -1
  151. package/dist/esm/components/Table/hooks/plugins/useRowSelect.js +79 -89
  152. package/dist/esm/components/Table/hooks/plugins/useRowSelect.js.map +1 -1
  153. package/dist/esm/components/Table/hooks/useRowCreation.js +29 -64
  154. package/dist/esm/components/Table/hooks/useRowCreation.js.map +1 -1
  155. package/dist/esm/components/Table/hooks/useTable.js +123 -141
  156. package/dist/esm/components/Table/hooks/useTable.js.map +1 -1
  157. package/dist/esm/components/Table/hooks/useTableKeyboardNavigation.js +23 -27
  158. package/dist/esm/components/Table/hooks/useTableKeyboardNavigation.js.map +1 -1
  159. package/dist/esm/components/Table/util/renderColumn.js +10 -10
  160. package/dist/esm/components/Table/util/renderColumn.js.map +1 -1
  161. package/dist/esm/components/Table/util/renderRow.js +37 -46
  162. package/dist/esm/components/Table/util/renderRow.js.map +1 -1
  163. package/dist/esm/components/Table/util/rowIndexPath.js +14 -16
  164. package/dist/esm/components/Table/util/rowIndexPath.js.map +1 -1
  165. package/dist/esm/components/Table/util/sortTypes.js +23 -31
  166. package/dist/esm/components/Table/util/sortTypes.js.map +1 -1
  167. package/dist/esm/components/Table/util.js +29 -41
  168. package/dist/esm/components/Table/util.js.map +1 -1
  169. package/dist/esm/components/Tabs/Tabs.js +25 -27
  170. package/dist/esm/components/Tabs/Tabs.js.map +1 -1
  171. package/dist/esm/components/Textarea/Textarea.js +11 -9
  172. package/dist/esm/components/Textarea/Textarea.js.map +1 -1
  173. package/dist/esm/components/Toast/Toast.js +27 -23
  174. package/dist/esm/components/Toast/Toast.js.map +1 -1
  175. package/dist/esm/components/Toast/Toaster.js +88 -118
  176. package/dist/esm/components/Toast/Toaster.js.map +1 -1
  177. package/dist/esm/components/Toast/util.js +2 -2
  178. package/dist/esm/components/Toast/util.js.map +1 -1
  179. package/dist/esm/components/Tooltip/Tooltip.js +7 -8
  180. package/dist/esm/components/Tooltip/Tooltip.js.map +1 -1
  181. package/dist/esm/components/Tour/Tour.js +46 -53
  182. package/dist/esm/components/Tour/Tour.js.map +1 -1
  183. package/dist/esm/components/Treeview/Treeview.js +26 -36
  184. package/dist/esm/components/Treeview/Treeview.js.map +1 -1
  185. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js +1 -1
  186. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js.map +1 -1
  187. package/dist/esm/index.css +1 -9
  188. package/dist/esm/index.js +1 -1
  189. package/dist/esm/primitives/Button.js +9 -13
  190. package/dist/esm/primitives/Button.js.map +1 -1
  191. package/dist/esm/utils/date.js +20 -40
  192. package/dist/esm/utils/date.js.map +1 -1
  193. package/dist/esm/utils/hooks/useBoundingClientRectListener.js +12 -20
  194. package/dist/esm/utils/hooks/useBoundingClientRectListener.js.map +1 -1
  195. package/dist/esm/utils/hooks/useDraggable.js +16 -17
  196. package/dist/esm/utils/hooks/useDraggable.js.map +1 -1
  197. package/dist/esm/utils/hooks/useDropTarget.js +7 -10
  198. package/dist/esm/utils/hooks/useDropTarget.js.map +1 -1
  199. package/dist/esm/utils/hooks/useListKeyboardNavigation.js +15 -30
  200. package/dist/esm/utils/hooks/useListKeyboardNavigation.js.map +1 -1
  201. package/dist/esm/utils/hooks/useListScrollTo.js +9 -9
  202. package/dist/esm/utils/hooks/useListScrollTo.js.map +1 -1
  203. package/dist/esm/utils/hooks/useOnClickOutside.js +6 -8
  204. package/dist/esm/utils/hooks/useOnClickOutside.js.map +1 -1
  205. package/dist/esm/utils/hooks/useProxiedRef.js +3 -3
  206. package/dist/esm/utils/hooks/useProxiedRef.js.map +1 -1
  207. package/dist/esm/utils/hooks/useTimer.js +9 -17
  208. package/dist/esm/utils/hooks/useTimer.js.map +1 -1
  209. package/dist/esm/utils/input.js +8 -12
  210. package/dist/esm/utils/input.js.map +1 -1
  211. package/dist/esm/utils/mergeRefs.js +2 -2
  212. package/dist/esm/utils/mergeRefs.js.map +1 -1
  213. package/dist/esm/utils/taillwind.js +2 -2
  214. package/dist/esm/utils/taillwind.js.map +1 -1
  215. package/dist/index.css +1 -9
  216. package/dist/taco.cjs.development.js +2368 -2883
  217. package/dist/taco.cjs.development.js.map +1 -1
  218. package/dist/taco.cjs.production.min.js +1 -1
  219. package/dist/taco.cjs.production.min.js.map +1 -1
  220. package/dist/utils/hooks/useListKeyboardNavigation.d.ts +1 -1
  221. package/package.json +4 -5
  222. package/types.json +13 -4
  223. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js +0 -34
  224. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"useRowCreation.js","sources":["../../../../../src/components/Table/hooks/useRowCreation.tsx"],"sourcesContent":["import React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport set from 'lodash/set';\nimport unset from 'lodash/unset';\nimport get from 'lodash/get';\nimport compact from 'lodash/compact';\nimport pullAt from 'lodash/pullAt';\n\nimport { convertRowIndexPathToNumberArray, getByRowIndexPath, getParentRowIndexPath } from '../util/rowIndexPath';\nimport { Row, RowIndexPath, TableRef } from '../types';\n\nexport const insertChildTableRow = <TRow,>(\n data: Row<TRow>[],\n rowIndexPath: RowIndexPath = undefined,\n values: any = {}\n): [Row<TRow>[], RowIndexPath] => {\n const nexTRow: Row<TRow>[] = JSON.parse(JSON.stringify(data));\n\n let childRowIndexPath;\n\n if (rowIndexPath) {\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const currentRow = getByRowIndexPath(nexTRow, rowIndexes.join('.'));\n const nextSubRows = currentRow?.subRows ?? [];\n\n const path = rowIndexes.map(i => `[${i}]`).join('.subRows') + '.subRows';\n nextSubRows.unshift(values);\n set(nexTRow, path, nextSubRows);\n\n // rebuild the new id\n rowIndexes.push(0);\n childRowIndexPath = rowIndexes.join('.');\n } else {\n nexTRow.unshift(values);\n childRowIndexPath = '0';\n }\n\n return [nexTRow, childRowIndexPath];\n};\n\nexport const removeChildTableRow = <TRow,>(data: Row<TRow>[], rowIndexPath: RowIndexPath): Row<TRow>[] => {\n const nexTRow = JSON.parse(JSON.stringify(data));\n\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const rootIndex = Number(rowIndexes.shift());\n\n if (rowIndexes.length) {\n // unset\n const unsetPath = rowIndexes.map(index => `subRows[${index}]`).join('.');\n unset(nexTRow[rootIndex], unsetPath);\n\n // remove empty value from subRows\n rowIndexes.pop();\n const setPath = rowIndexes.length ? rowIndexes.map(index => `subRows[${index}]`).join('.') + '.subRows' : 'subRows';\n set(nexTRow[rootIndex], setPath, compact(get(nexTRow[rootIndex], setPath)));\n } else {\n pullAt(nexTRow, rootIndex);\n }\n\n return nexTRow;\n};\n\nexport type useTableRowCreation<TRow> = {\n data: Row<TRow>[];\n create: (rowIndexPath: RowIndexPath, values?: object | undefined) => RowIndexPath;\n remove: (rowIndexPath: RowIndexPath) => void;\n isCreating: boolean;\n};\n\nexport const useTableRowCreation = <TRow,>(data: Row<TRow>[], tableRef: React.RefObject<TableRef>): useTableRowCreation<TRow> => {\n const [internalData, setInternalData] = React.useState(JSON.parse(JSON.stringify(data)));\n const [activeRowIndexPath, setActiveRowIndexPath] = React.useState<string | undefined>(undefined);\n\n React.useEffect(() => {\n if (activeRowIndexPath !== undefined) {\n // keep the same edit key, so that we don't remount the row/form\n const currentRow: any = getByRowIndexPath(internalData, activeRowIndexPath);\n\n // get the active creation rows parent\n const parentId = getParentRowIndexPath(activeRowIndexPath);\n\n // insert a new empty row in the external data (with the same key)\n const [nexTRow, newRowIndexPath] = insertChildTableRow(JSON.parse(JSON.stringify(data)), parentId, currentRow);\n\n // update and set that row as active, we basically just changed it's position in our internal data\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(currentRow?._createKey);\n }\n } else {\n setInternalData(data);\n }\n }, [JSON.stringify(data)]);\n\n const create = (rowIndexPath: RowIndexPath = undefined, values: object | undefined = {}): RowIndexPath => {\n const _createKey = uuid();\n const [nexTRow, newRowIndexPath] = insertChildTableRow(internalData, rowIndexPath, { ...values, _createKey });\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(_createKey);\n }\n\n return newRowIndexPath;\n };\n\n const remove = (rowIndexPath: any): void => {\n const nexTRow = removeChildTableRow(internalData, rowIndexPath);\n setInternalData(nexTRow);\n setActiveRowIndexPath(undefined);\n };\n\n return {\n data: internalData,\n create,\n remove,\n isCreating: activeRowIndexPath !== undefined,\n };\n};\n"],"names":["insertChildTableRow","data","rowIndexPath","values","undefined","nexTRow","JSON","parse","stringify","childRowIndexPath","rowIndexes","convertRowIndexPathToNumberArray","currentRow","getByRowIndexPath","join","nextSubRows","subRows","path","map","i","unshift","set","push","removeChildTableRow","rootIndex","Number","shift","length","unsetPath","index","unset","pop","setPath","compact","get","pullAt","useTableRowCreation","tableRef","React","useState","internalData","setInternalData","activeRowIndexPath","setActiveRowIndexPath","useEffect","parentId","getParentRowIndexPath","newRowIndexPath","current","instance","toggleRowEditing","_createKey","create","uuid","remove","isCreating"],"mappings":"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"}
1
+ {"version":3,"file":"useRowCreation.js","sources":["../../../../../src/components/Table/hooks/useRowCreation.tsx"],"sourcesContent":["import React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport set from 'lodash/set';\nimport unset from 'lodash/unset';\nimport get from 'lodash/get';\nimport compact from 'lodash/compact';\nimport pullAt from 'lodash/pullAt';\n\nimport { convertRowIndexPathToNumberArray, getByRowIndexPath, getParentRowIndexPath } from '../util/rowIndexPath';\nimport { Row, RowIndexPath, TableRef } from '../types';\n\nexport const insertChildTableRow = <TRow,>(\n data: Row<TRow>[],\n rowIndexPath: RowIndexPath = undefined,\n values: any = {}\n): [Row<TRow>[], RowIndexPath] => {\n const nexTRow: Row<TRow>[] = JSON.parse(JSON.stringify(data));\n\n let childRowIndexPath;\n\n if (rowIndexPath) {\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const currentRow = getByRowIndexPath(nexTRow, rowIndexes.join('.'));\n const nextSubRows = currentRow?.subRows ?? [];\n\n const path = rowIndexes.map(i => `[${i}]`).join('.subRows') + '.subRows';\n nextSubRows.unshift(values);\n set(nexTRow, path, nextSubRows);\n\n // rebuild the new id\n rowIndexes.push(0);\n childRowIndexPath = rowIndexes.join('.');\n } else {\n nexTRow.unshift(values);\n childRowIndexPath = '0';\n }\n\n return [nexTRow, childRowIndexPath];\n};\n\nexport const removeChildTableRow = <TRow,>(data: Row<TRow>[], rowIndexPath: RowIndexPath): Row<TRow>[] => {\n const nexTRow = JSON.parse(JSON.stringify(data));\n\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const rootIndex = Number(rowIndexes.shift());\n\n if (rowIndexes.length) {\n // unset\n const unsetPath = rowIndexes.map(index => `subRows[${index}]`).join('.');\n unset(nexTRow[rootIndex], unsetPath);\n\n // remove empty value from subRows\n rowIndexes.pop();\n const setPath = rowIndexes.length ? rowIndexes.map(index => `subRows[${index}]`).join('.') + '.subRows' : 'subRows';\n set(nexTRow[rootIndex], setPath, compact(get(nexTRow[rootIndex], setPath)));\n } else {\n pullAt(nexTRow, rootIndex);\n }\n\n return nexTRow;\n};\n\nexport type useTableRowCreation<TRow> = {\n data: Row<TRow>[];\n create: (rowIndexPath: RowIndexPath, values?: object | undefined) => RowIndexPath;\n remove: (rowIndexPath: RowIndexPath) => void;\n isCreating: boolean;\n};\n\nexport const useTableRowCreation = <TRow,>(data: Row<TRow>[], tableRef: React.RefObject<TableRef>): useTableRowCreation<TRow> => {\n const [internalData, setInternalData] = React.useState(JSON.parse(JSON.stringify(data)));\n const [activeRowIndexPath, setActiveRowIndexPath] = React.useState<string | undefined>(undefined);\n\n React.useEffect(() => {\n if (activeRowIndexPath !== undefined) {\n // keep the same edit key, so that we don't remount the row/form\n const currentRow: any = getByRowIndexPath(internalData, activeRowIndexPath);\n\n // get the active creation rows parent\n const parentId = getParentRowIndexPath(activeRowIndexPath);\n\n // insert a new empty row in the external data (with the same key)\n const [nexTRow, newRowIndexPath] = insertChildTableRow(JSON.parse(JSON.stringify(data)), parentId, currentRow);\n\n // update and set that row as active, we basically just changed it's position in our internal data\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(currentRow?._createKey);\n }\n } else {\n setInternalData(data);\n }\n }, [JSON.stringify(data)]);\n\n const create = (rowIndexPath: RowIndexPath = undefined, values: object | undefined = {}): RowIndexPath => {\n const _createKey = uuid();\n const [nexTRow, newRowIndexPath] = insertChildTableRow(internalData, rowIndexPath, { ...values, _createKey });\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(_createKey);\n }\n\n return newRowIndexPath;\n };\n\n const remove = (rowIndexPath: any): void => {\n const nexTRow = removeChildTableRow(internalData, rowIndexPath);\n setInternalData(nexTRow);\n setActiveRowIndexPath(undefined);\n };\n\n return {\n data: internalData,\n create,\n remove,\n isCreating: activeRowIndexPath !== undefined,\n };\n};\n"],"names":["insertChildTableRow","data","rowIndexPath","undefined","values","nexTRow","JSON","parse","stringify","childRowIndexPath","rowIndexes","convertRowIndexPathToNumberArray","currentRow","getByRowIndexPath","join","nextSubRows","subRows","path","map","i","unshift","set","push","removeChildTableRow","rootIndex","Number","shift","length","unsetPath","index","unset","pop","setPath","compact","get","pullAt","useTableRowCreation","tableRef","internalData","setInternalData","React","useState","activeRowIndexPath","setActiveRowIndexPath","useEffect","parentId","getParentRowIndexPath","newRowIndexPath","current","instance","toggleRowEditing","_createKey","create","uuid","remove","isCreating"],"mappings":"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"}
@@ -1,4 +1,3 @@
1
- import { extends as _extends, objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose } from '../../../_virtual/_rollupPluginBabelHelpers.js';
2
1
  import React__default from 'react';
3
2
  import { useLocalization } from '../../Provider/Provider.js';
4
3
  import { useTable as useTable$1, useRowState, useSortBy, useExpanded, usePagination } from 'react-table';
@@ -10,36 +9,31 @@ import { useRowSelect } from './plugins/useRowSelect.js';
10
9
  import { useTableKeyboardNavigation } from './useTableKeyboardNavigation.js';
11
10
  import { useRowDraggable } from './plugins/useRowDraggable.js';
12
11
 
13
- var _excluded = ["children", "data", "dangerouslyHijackGlobalKeyboardNavigation", "onRowClick", "onRowDrag", "onSelectedRows", "rowClassName", "rowExpansionRenderer", "rowHeight", "selectedRows", "disableSorting", "manualSorting", "onSort", "sortRules", "disablePagination", "length", "onPaginate", "pageSize", "pageIndex", "inlineEditingUniqueId", "onRowCreate", "actions", "onRowEdit", "onRowCopy", "onRowDelete", "onRowActive", "windowed"],
14
- _excluded2 = ["headerGroups", "rows", "sortedRows", "prepareRow", "state", "page", "gotoPage", "setPageSize"];
15
-
16
- var useTableRowActive = function useTableRowActive(activeIndex, rows, rowExpansionRenderer, handleonRowActive) {
17
- React__default.useEffect(function () {
12
+ const useTableRowActive = (activeIndex, rows, rowExpansionRenderer, handleonRowActive) => {
13
+ React__default.useEffect(() => {
18
14
  if (activeIndex !== undefined && rows.length && handleonRowActive) {
19
- var focusedRow = rows[activeIndex];
15
+ const focusedRow = rows[activeIndex];
20
16
 
21
17
  if (focusedRow) {
22
- var sanitizedFocusedRow = sanitizeRowProps(focusedRow, rowExpansionRenderer);
18
+ const sanitizedFocusedRow = sanitizeRowProps(focusedRow, rowExpansionRenderer);
23
19
  handleonRowActive(sanitizedFocusedRow);
24
20
  }
25
21
  }
26
22
  }, [activeIndex, rows]);
27
23
  };
28
24
 
29
- var useTableInstance = function useTableInstance(instance, ref) {
30
- var sanitizedInstance = React__default.useMemo(function () {
31
- return {
32
- toggleAllRowsExpanded: instance.toggleAllRowsExpanded,
33
- toggleHideAllColumns: instance.toggleHideAllColumns,
34
- toggleHideColumn: instance.toggleHideColumn,
35
- toggleEditing: instance.toggleEditing,
36
- toggleRowEditing: instance.toggleRowEditing,
37
- resetRowEditing: instance.resetRowEditing,
38
- toggleRowExpanded: instance.toggleRowExpanded,
39
- toggleSortBy: instance.toggleSortBy
40
- };
41
- }, []);
42
- React__default.useEffect(function () {
25
+ const useTableInstance = (instance, ref) => {
26
+ const sanitizedInstance = React__default.useMemo(() => ({
27
+ toggleAllRowsExpanded: instance.toggleAllRowsExpanded,
28
+ toggleHideAllColumns: instance.toggleHideAllColumns,
29
+ toggleHideColumn: instance.toggleHideColumn,
30
+ toggleEditing: instance.toggleEditing,
31
+ toggleRowEditing: instance.toggleRowEditing,
32
+ resetRowEditing: instance.resetRowEditing,
33
+ toggleRowExpanded: instance.toggleRowExpanded,
34
+ toggleSortBy: instance.toggleSortBy
35
+ }), []);
36
+ React__default.useEffect(() => {
43
37
  if (ref !== null && ref !== void 0 && ref.current) {
44
38
  ref.current.instance = sanitizedInstance;
45
39
  }
@@ -47,33 +41,29 @@ var useTableInstance = function useTableInstance(instance, ref) {
47
41
  return sanitizedInstance;
48
42
  };
49
43
 
50
- var useTablePaginationListener = function useTablePaginationListener(disablePagination, onPaginate, state) {
51
- React__default.useEffect(function () {
44
+ const useTablePaginationListener = (disablePagination, onPaginate, state) => {
45
+ React__default.useEffect(() => {
52
46
  if (!disablePagination && onPaginate) {
53
47
  onPaginate(state.pageIndex, state.pageSize);
54
48
  }
55
49
  }, [state.pageIndex, state.pageSize]);
56
50
  };
57
51
 
58
- var useTableSortingListener = function useTableSortingListener(data, sortedRows, onSort, manualSorting, state) {
59
- React__default.useEffect(function () {
52
+ const useTableSortingListener = (data, sortedRows, onSort, manualSorting, state) => {
53
+ React__default.useEffect(() => {
60
54
  if (onSort) {
61
- var sortRules = state.sortBy.map(function (rule) {
62
- return {
63
- accessor: rule.id,
64
- desc: rule.desc
65
- };
66
- });
55
+ const sortRules = state.sortBy.map(rule => ({
56
+ accessor: rule.id,
57
+ desc: rule.desc
58
+ }));
67
59
 
68
60
  if (manualSorting) {
69
61
  onSort(sortRules);
70
62
  } else {
71
- var sortedData;
63
+ let sortedData;
72
64
 
73
65
  if (sortRules.length && sortedRows !== null && sortedRows !== void 0 && sortedRows.length) {
74
- sortedData = sortedRows.map(function (row) {
75
- return row.original;
76
- });
66
+ sortedData = sortedRows.map(row => row.original);
77
67
  }
78
68
 
79
69
  onSort(sortRules, sortedData || data);
@@ -82,61 +72,75 @@ var useTableSortingListener = function useTableSortingListener(data, sortedRows,
82
72
  }, [onSort && JSON.stringify(state.sortBy), manualSorting]);
83
73
  };
84
74
 
85
- var DEFAULT_PAGE_SIZE = 10;
86
- var useTable = function useTable(props, ref) {
75
+ const DEFAULT_PAGE_SIZE = 10;
76
+ const useTable = (props, ref) => {
87
77
  var _otherProps$tabIndex;
88
78
 
89
- var children = props.children,
90
- data = props.data,
91
- onRowClick = props.onRowClick,
92
- onRowDrag = props.onRowDrag,
93
- onSelectedRows = props.onSelectedRows,
94
- rowClassName = props.rowClassName,
95
- rowExpansionRenderer = props.rowExpansionRenderer,
96
- rowHeight = props.rowHeight,
97
- selectedRows = props.selectedRows,
98
- disableSorting = props.disableSorting,
99
- manualSorting = props.manualSorting,
100
- onSort = props.onSort,
101
- sortRules = props.sortRules,
102
- _props$disablePaginat = props.disablePagination,
103
- disablePagination = _props$disablePaginat === void 0 ? true : _props$disablePaginat,
104
- length = props.length,
105
- onPaginate = props.onPaginate,
106
- _props$pageSize = props.pageSize,
107
- pageSize = _props$pageSize === void 0 ? DEFAULT_PAGE_SIZE : _props$pageSize,
108
- _props$pageIndex = props.pageIndex,
109
- pageIndex = _props$pageIndex === void 0 ? 0 : _props$pageIndex,
110
- _props$inlineEditingU = props.inlineEditingUniqueId,
111
- inlineEditingUniqueId = _props$inlineEditingU === void 0 ? undefined : _props$inlineEditingU,
112
- onRowCreate = props.onRowCreate,
113
- actions = props.actions,
114
- onRowEdit = props.onRowEdit,
115
- onRowCopy = props.onRowCopy,
116
- onRowDelete = props.onRowDelete,
117
- onRowActive = props.onRowActive,
118
- _props$windowed = props.windowed,
119
- windowed = _props$windowed === void 0 ? false : _props$windowed,
120
- otherProps = _objectWithoutPropertiesLoose(props, _excluded);
79
+ const {
80
+ children,
81
+ data,
82
+ dangerouslyHijackGlobalKeyboardNavigation: _,
83
+ onRowClick,
84
+ onRowDrag,
85
+ onSelectedRows,
86
+ rowClassName,
87
+ rowExpansionRenderer,
88
+ rowHeight,
89
+ selectedRows,
90
+ // sorting
91
+ disableSorting,
92
+ manualSorting,
93
+ onSort,
94
+ sortRules,
95
+ //index
96
+ activeIndex: _1,
97
+ defaultActiveIndex: _2,
98
+ onChangeActiveIndex: _3,
99
+ // pagination
100
+ disablePagination = true,
101
+ length,
102
+ onPaginate,
103
+ pageSize = DEFAULT_PAGE_SIZE,
104
+ pageIndex = 0,
105
+ // row editing
106
+ inlineEditingUniqueId = undefined,
107
+ onRowCreate,
108
+ // actions
109
+ actions,
110
+ onRowEdit,
111
+ onRowCopy,
112
+ onRowDelete,
113
+ onRowActive,
114
+ windowed = false,
115
+ ...otherProps
116
+ } = props;
121
117
 
122
118
  if (onSelectedRows && !selectedRows || !onSelectedRows && selectedRows) {
123
119
  throw new Error('Selected rows in a Table component are fully controlled - you must pass both the `onSelectedRows` and `selectedRows` props when using row selection');
124
120
  }
125
121
 
126
- var _useLocalization = useLocalization(),
127
- texts = _useLocalization.texts;
128
-
129
- var _React$useMemo = React__default.useMemo(function () {
130
- return getColumnsFromChildren(children, rowExpansionRenderer);
131
- }, [children, rowExpansionRenderer]),
132
- columns = _React$useMemo.columns,
133
- defaultSortRules = _React$useMemo.sortRules;
134
-
135
- var manualPagination = !disablePagination && !!onPaginate && !!length;
136
-
137
- var _useReactTable = useTable$1({
138
- columns: columns,
139
- data: data,
122
+ const {
123
+ texts
124
+ } = useLocalization();
125
+ const {
126
+ columns,
127
+ sortRules: defaultSortRules
128
+ } = React__default.useMemo(() => getColumnsFromChildren(children, rowExpansionRenderer), [children, rowExpansionRenderer]);
129
+ const manualPagination = !disablePagination && !!onPaginate && !!length;
130
+ const {
131
+ headerGroups,
132
+ rows,
133
+ sortedRows,
134
+ prepareRow: prepareBaseRow,
135
+ state,
136
+ // pagination
137
+ page,
138
+ gotoPage,
139
+ setPageSize,
140
+ ...instance
141
+ } = useTable$1({
142
+ columns,
143
+ data,
140
144
  initialState: {
141
145
  // eslint-disable-next-line
142
146
  // @ts-ignore: not sure how to type this correctly right now
@@ -144,7 +148,7 @@ var useTable = function useTable(props, ref) {
144
148
  pageSize: !disablePagination ? pageSize : undefined,
145
149
  pageIndex: !disablePagination ? pageIndex : undefined
146
150
  },
147
- manualPagination: manualPagination,
151
+ manualPagination,
148
152
  pageCount: manualPagination && length ? Math.ceil(length / pageSize) : -1,
149
153
  manualSortBy: manualSorting,
150
154
  disableSortBy: disableSorting,
@@ -153,75 +157,53 @@ var useTable = function useTable(props, ref) {
153
157
  autoResetSelectedRows: false,
154
158
  autoResetSortBy: false,
155
159
  autoResetPage: false,
156
- sortTypes: React__default.useMemo(function () {
157
- return sortTypes;
158
- }, []),
159
- useControlledState: function useControlledState(currentState) {
160
- return React__default.useMemo(function () {
161
- return _extends({}, currentState, {
162
- selectedRowIds: selectedRows || []
163
- });
164
- }, [currentState, selectedRows]);
160
+ sortTypes: React__default.useMemo(() => sortTypes, []),
161
+ useControlledState: currentState => {
162
+ return React__default.useMemo(() => ({ ...currentState,
163
+ selectedRowIds: selectedRows || []
164
+ }), [currentState, selectedRows]);
165
165
  }
166
166
  }, useRowState, useSortBy, useExpanded, usePagination, useRowSelect(onSelectedRows), useRowDraggable(onRowDrag), useRowEditing(inlineEditingUniqueId), useRowActions(inlineEditingUniqueId, {
167
- onRowCreate: onRowCreate,
168
- onRowEdit: onRowEdit,
169
- onRowCopy: onRowCopy,
170
- onRowDelete: onRowDelete
171
- }, actions, rowExpansionRenderer, texts, windowed)),
172
- headerGroups = _useReactTable.headerGroups,
173
- rows = _useReactTable.rows,
174
- sortedRows = _useReactTable.sortedRows,
175
- prepareBaseRow = _useReactTable.prepareRow,
176
- state = _useReactTable.state,
177
- page = _useReactTable.page,
178
- gotoPage = _useReactTable.gotoPage,
179
- setPageSize = _useReactTable.setPageSize,
180
- instance = _objectWithoutPropertiesLoose(_useReactTable, _excluded2);
181
-
167
+ onRowCreate,
168
+ onRowEdit,
169
+ onRowCopy,
170
+ onRowDelete
171
+ }, actions, rowExpansionRenderer, texts, windowed));
182
172
  useTablePaginationListener(disablePagination, onPaginate, state);
183
173
  useTableSortingListener(data, sortedRows, onSort, !!manualSorting, state);
184
- var sanitizedInstance = useTableInstance(instance, ref);
185
- var visibleRows = !disablePagination && !manualPagination ? page : rows;
186
-
187
- var _useTableKeyboardNavi = useTableKeyboardNavigation(props, visibleRows, {
188
- onRowClick: onRowClick,
189
- onRowCreate: onRowCreate,
190
- onRowEdit: onRowEdit,
191
- onRowCopy: onRowCopy,
192
- onRowDelete: onRowDelete,
193
- rowExpansionRenderer: rowExpansionRenderer
194
- }, ref),
195
- activeIndex = _useTableKeyboardNavi[0],
196
- setActiveIndex = _useTableKeyboardNavi[1],
197
- handleKeyDown = _useTableKeyboardNavi[2],
198
- handleFocus = _useTableKeyboardNavi[3];
199
-
174
+ const sanitizedInstance = useTableInstance(instance, ref);
175
+ const visibleRows = !disablePagination && !manualPagination ? page : rows;
176
+ const [activeIndex, setActiveIndex, handleKeyDown, handleFocus] = useTableKeyboardNavigation(props, visibleRows, {
177
+ onRowClick,
178
+ onRowCreate,
179
+ onRowEdit,
180
+ onRowCopy,
181
+ onRowDelete,
182
+ rowExpansionRenderer
183
+ }, ref);
200
184
  useTableRowActive(activeIndex, rows, rowExpansionRenderer, onRowActive);
201
- var prepareRow = React__default.useCallback(function (row, index) {
185
+ const prepareRow = React__default.useCallback((row, index) => {
202
186
  prepareBaseRow(row);
203
187
 
204
- row.setActive = function () {
205
- return setActiveIndex(index);
206
- };
188
+ row.setActive = () => setActiveIndex(index);
207
189
  }, [prepareBaseRow, setActiveIndex]);
208
190
  return {
209
191
  rowProps: {
210
- activeIndex: activeIndex,
211
- setActiveIndex: setActiveIndex,
212
- onRowClick: onRowClick,
213
- rowClassName: rowClassName,
214
- rowExpansionRenderer: rowExpansionRenderer,
215
- rowHeight: rowHeight,
216
- inlineEditingUniqueId: inlineEditingUniqueId
192
+ activeIndex,
193
+ setActiveIndex,
194
+ onRowClick,
195
+ rowClassName,
196
+ rowExpansionRenderer,
197
+ rowHeight,
198
+ inlineEditingUniqueId
217
199
  },
218
- tableProps: _extends({}, otherProps, {
219
- headerGroups: headerGroups,
200
+ tableProps: { ...otherProps,
201
+ headerGroups,
220
202
  onFocus: handleFocus,
221
203
  onKeyDown: handleKeyDown,
222
204
  tabIndex: (_otherProps$tabIndex = otherProps.tabIndex) !== null && _otherProps$tabIndex !== void 0 ? _otherProps$tabIndex : 0
223
- }),
224
- state: state,
205
+ },
206
+ state,
225
207
  pagination: !disablePagination ? {
226
208
  length: manualPagination && length ? length : data.length,
227
209
  pageIndex: state.pageIndex,
@@ -230,7 +212,7 @@ var useTable = function useTable(props, ref) {
230
212
  setPageSize: setPageSize
231
213
  } : null,
232
214
  rows: visibleRows,
233
- prepareRow: prepareRow,
215
+ prepareRow,
234
216
  instance: sanitizedInstance
235
217
  };
236
218
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useTable.js","sources":["../../../../../src/components/Table/hooks/useTable.tsx"],"sourcesContent":["import React from 'react';\nimport { useTable as useReactTable, useExpanded, useSortBy, usePagination, useRowState } from 'react-table';\nimport { getColumnsFromChildren, getInternalSortRules } from '../util';\nimport { sortTypes } from '../util/sortTypes';\nimport { useRowEditing } from './plugins/useRowEditing';\nimport { useRowActions } from './plugins/useRowActions';\nimport { useRowSelect } from './plugins/useRowSelect';\nimport {\n InternalTable,\n InternalTableRow,\n PaginationHandler,\n RowActiveHandler,\n SortHandler,\n TableProps,\n TableRef,\n} from '../types';\nimport { useTableKeyboardNavigation } from './useTableKeyboardNavigation';\nimport { useLocalization } from '../../Provider/Provider';\nimport { useRowDraggable } from './plugins/useRowDraggable';\nimport { sanitizeRowProps } from '../util';\n\nconst useTableRowActive = (\n activeIndex: number | undefined,\n rows: InternalTableRow[],\n rowExpansionRenderer: TableProps<any>['rowExpansionRenderer'],\n handleonRowActive: RowActiveHandler<any> | undefined\n) => {\n React.useEffect(() => {\n if (activeIndex !== undefined && rows.length && handleonRowActive) {\n const focusedRow = rows[activeIndex];\n if (focusedRow) {\n const sanitizedFocusedRow = sanitizeRowProps(focusedRow, rowExpansionRenderer);\n handleonRowActive(sanitizedFocusedRow);\n }\n }\n }, [activeIndex, rows]);\n};\n\nconst useTableInstance = (instance: any, ref: React.RefObject<TableRef>): object => {\n const sanitizedInstance = React.useMemo(\n () => ({\n toggleAllRowsExpanded: instance.toggleAllRowsExpanded,\n toggleHideAllColumns: instance.toggleHideAllColumns,\n toggleHideColumn: instance.toggleHideColumn,\n toggleEditing: instance.toggleEditing,\n toggleRowEditing: instance.toggleRowEditing,\n resetRowEditing: instance.resetRowEditing,\n toggleRowExpanded: instance.toggleRowExpanded,\n toggleSortBy: instance.toggleSortBy,\n }),\n []\n );\n\n React.useEffect(() => {\n if (ref?.current) {\n ref.current.instance = sanitizedInstance;\n }\n }, [ref]);\n\n return sanitizedInstance;\n};\n\nconst useTablePaginationListener = (disablePagination: boolean, onPaginate: PaginationHandler | undefined, state: any): void => {\n React.useEffect(() => {\n if (!disablePagination && onPaginate) {\n onPaginate(state.pageIndex, state.pageSize);\n }\n }, [state.pageIndex, state.pageSize]);\n};\n\nconst useTableSortingListener = (\n data: any[],\n sortedRows: any[],\n onSort: SortHandler<any> | undefined,\n manualSorting: boolean,\n state: any\n): void => {\n React.useEffect(() => {\n if (onSort) {\n const sortRules = state.sortBy.map((rule: any) => ({ accessor: rule.id, desc: rule.desc }));\n\n if (manualSorting) {\n onSort(sortRules);\n } else {\n let sortedData;\n\n if (sortRules.length && sortedRows?.length) {\n sortedData = sortedRows.map((row: any) => row.original);\n }\n\n onSort(sortRules, sortedData || data);\n }\n }\n }, [onSort && JSON.stringify(state.sortBy), manualSorting]);\n};\n\nconst DEFAULT_PAGE_SIZE = 10;\n\nexport const useTable = <T extends {}>(\n props: TableProps<T> & { windowed?: boolean },\n ref: React.RefObject<TableRef>\n): InternalTable => {\n const {\n children,\n data,\n dangerouslyHijackGlobalKeyboardNavigation: _1,\n onRowClick,\n onRowDrag,\n onSelectedRows,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n selectedRows,\n\n // sorting\n disableSorting,\n manualSorting,\n onSort,\n sortRules,\n\n // pagination\n disablePagination = true,\n length,\n onPaginate,\n pageSize = DEFAULT_PAGE_SIZE,\n pageIndex = 0,\n\n // row editing\n inlineEditingUniqueId = undefined,\n onRowCreate,\n\n // actions\n actions,\n onRowEdit,\n onRowCopy,\n onRowDelete,\n onRowActive,\n\n windowed = false,\n\n ...otherProps\n } = props;\n\n if ((onSelectedRows && !selectedRows) || (!onSelectedRows && selectedRows)) {\n throw new Error(\n 'Selected rows in a Table component are fully controlled - you must pass both the `onSelectedRows` and `selectedRows` props when using row selection'\n );\n }\n\n const { texts } = useLocalization();\n const { columns, sortRules: defaultSortRules } = React.useMemo(\n () => getColumnsFromChildren(children, rowExpansionRenderer),\n [children, rowExpansionRenderer]\n );\n\n const manualPagination = !disablePagination && !!onPaginate && !!length;\n\n const {\n headerGroups,\n rows,\n sortedRows,\n prepareRow: prepareBaseRow,\n state,\n // pagination\n page,\n gotoPage,\n setPageSize,\n ...instance\n }: any = useReactTable(\n {\n columns,\n data,\n initialState: {\n // eslint-disable-next-line\n // @ts-ignore: not sure how to type this correctly right now\n sortBy: getInternalSortRules(sortRules) || defaultSortRules,\n pageSize: !disablePagination ? pageSize : undefined,\n pageIndex: !disablePagination ? pageIndex : undefined,\n },\n manualPagination,\n pageCount: manualPagination && length ? Math.ceil(length / pageSize) : -1,\n manualSortBy: manualSorting,\n disableSortBy: disableSorting,\n // most of these resets preventions are needed for editing mode\n autoResetExpanded: false,\n autoResetSelectedRows: false,\n autoResetSortBy: false,\n autoResetPage: false,\n sortTypes: React.useMemo(() => sortTypes, []),\n useControlledState: currentState => {\n return React.useMemo(\n () => ({\n ...currentState,\n selectedRowIds: selectedRows || [],\n }),\n [currentState, selectedRows]\n );\n },\n },\n useRowState,\n useSortBy,\n useExpanded,\n usePagination,\n useRowSelect(onSelectedRows),\n useRowDraggable(onRowDrag),\n useRowEditing(inlineEditingUniqueId),\n useRowActions(\n inlineEditingUniqueId,\n { onRowCreate, onRowEdit, onRowCopy, onRowDelete },\n actions,\n rowExpansionRenderer,\n texts,\n windowed\n )\n );\n\n useTablePaginationListener(disablePagination, onPaginate, state);\n useTableSortingListener(data, sortedRows, onSort, !!manualSorting, state);\n\n const sanitizedInstance = useTableInstance(instance, ref);\n\n const visibleRows = !disablePagination && !manualPagination ? page : rows;\n\n const [activeIndex, setActiveIndex, handleKeyDown, handleFocus] = useTableKeyboardNavigation<T>(\n props,\n visibleRows,\n { onRowClick, onRowCreate, onRowEdit, onRowCopy, onRowDelete, rowExpansionRenderer },\n ref\n );\n\n useTableRowActive(activeIndex, rows, rowExpansionRenderer, onRowActive);\n\n const prepareRow = React.useCallback(\n (row: any, index: number) => {\n prepareBaseRow(row);\n row.setActive = () => setActiveIndex(index);\n },\n [prepareBaseRow, setActiveIndex]\n );\n\n return {\n rowProps: {\n activeIndex,\n setActiveIndex,\n onRowClick,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n inlineEditingUniqueId,\n },\n tableProps: {\n ...otherProps,\n headerGroups,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n tabIndex: otherProps.tabIndex ?? 0,\n },\n state,\n pagination: !disablePagination\n ? {\n length: manualPagination && length ? length : data.length,\n pageIndex: state.pageIndex,\n pageSize: state.pageSize,\n setPageIndex: gotoPage,\n setPageSize: setPageSize,\n }\n : null,\n rows: visibleRows,\n prepareRow,\n instance: sanitizedInstance,\n };\n};\n"],"names":["useTableRowActive","activeIndex","rows","rowExpansionRenderer","handleonRowActive","React","useEffect","undefined","length","focusedRow","sanitizedFocusedRow","sanitizeRowProps","useTableInstance","instance","ref","sanitizedInstance","useMemo","toggleAllRowsExpanded","toggleHideAllColumns","toggleHideColumn","toggleEditing","toggleRowEditing","resetRowEditing","toggleRowExpanded","toggleSortBy","current","useTablePaginationListener","disablePagination","onPaginate","state","pageIndex","pageSize","useTableSortingListener","data","sortedRows","onSort","manualSorting","sortRules","sortBy","map","rule","accessor","id","desc","sortedData","row","original","JSON","stringify","DEFAULT_PAGE_SIZE","useTable","props","children","onRowClick","onRowDrag","onSelectedRows","rowClassName","rowHeight","selectedRows","disableSorting","inlineEditingUniqueId","onRowCreate","actions","onRowEdit","onRowCopy","onRowDelete","onRowActive","windowed","otherProps","Error","useLocalization","texts","getColumnsFromChildren","columns","defaultSortRules","manualPagination","useReactTable","initialState","getInternalSortRules","pageCount","Math","ceil","manualSortBy","disableSortBy","autoResetExpanded","autoResetSelectedRows","autoResetSortBy","autoResetPage","sortTypes","useControlledState","currentState","selectedRowIds","useRowState","useSortBy","useExpanded","usePagination","useRowSelect","useRowDraggable","useRowEditing","useRowActions","headerGroups","prepareBaseRow","prepareRow","page","gotoPage","setPageSize","visibleRows","useTableKeyboardNavigation","setActiveIndex","handleKeyDown","handleFocus","useCallback","index","setActive","rowProps","tableProps","onFocus","onKeyDown","tabIndex","pagination","setPageIndex"],"mappings":"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"}
1
+ {"version":3,"file":"useTable.js","sources":["../../../../../src/components/Table/hooks/useTable.tsx"],"sourcesContent":["import React from 'react';\nimport { useTable as useReactTable, useExpanded, useSortBy, usePagination, useRowState } from 'react-table';\nimport { getColumnsFromChildren, getInternalSortRules } from '../util';\nimport { sortTypes } from '../util/sortTypes';\nimport { useRowEditing } from './plugins/useRowEditing';\nimport { useRowActions } from './plugins/useRowActions';\nimport { useRowSelect } from './plugins/useRowSelect';\nimport {\n InternalTable,\n InternalTableRow,\n PaginationHandler,\n RowActiveHandler,\n SortHandler,\n TableProps,\n TableRef,\n} from '../types';\nimport { useTableKeyboardNavigation } from './useTableKeyboardNavigation';\nimport { useLocalization } from '../../Provider/Provider';\nimport { useRowDraggable } from './plugins/useRowDraggable';\nimport { sanitizeRowProps } from '../util';\n\nconst useTableRowActive = (\n activeIndex: number | undefined,\n rows: InternalTableRow[],\n rowExpansionRenderer: TableProps<any>['rowExpansionRenderer'],\n handleonRowActive: RowActiveHandler<any> | undefined\n) => {\n React.useEffect(() => {\n if (activeIndex !== undefined && rows.length && handleonRowActive) {\n const focusedRow = rows[activeIndex];\n if (focusedRow) {\n const sanitizedFocusedRow = sanitizeRowProps(focusedRow, rowExpansionRenderer);\n handleonRowActive(sanitizedFocusedRow);\n }\n }\n }, [activeIndex, rows]);\n};\n\nconst useTableInstance = (instance: any, ref: React.RefObject<TableRef>): object => {\n const sanitizedInstance = React.useMemo(\n () => ({\n toggleAllRowsExpanded: instance.toggleAllRowsExpanded,\n toggleHideAllColumns: instance.toggleHideAllColumns,\n toggleHideColumn: instance.toggleHideColumn,\n toggleEditing: instance.toggleEditing,\n toggleRowEditing: instance.toggleRowEditing,\n resetRowEditing: instance.resetRowEditing,\n toggleRowExpanded: instance.toggleRowExpanded,\n toggleSortBy: instance.toggleSortBy,\n }),\n []\n );\n\n React.useEffect(() => {\n if (ref?.current) {\n ref.current.instance = sanitizedInstance;\n }\n }, [ref]);\n\n return sanitizedInstance;\n};\n\nconst useTablePaginationListener = (disablePagination: boolean, onPaginate: PaginationHandler | undefined, state: any): void => {\n React.useEffect(() => {\n if (!disablePagination && onPaginate) {\n onPaginate(state.pageIndex, state.pageSize);\n }\n }, [state.pageIndex, state.pageSize]);\n};\n\nconst useTableSortingListener = (\n data: any[],\n sortedRows: any[],\n onSort: SortHandler<any> | undefined,\n manualSorting: boolean,\n state: any\n): void => {\n React.useEffect(() => {\n if (onSort) {\n const sortRules = state.sortBy.map((rule: any) => ({ accessor: rule.id, desc: rule.desc }));\n\n if (manualSorting) {\n onSort(sortRules);\n } else {\n let sortedData;\n\n if (sortRules.length && sortedRows?.length) {\n sortedData = sortedRows.map((row: any) => row.original);\n }\n\n onSort(sortRules, sortedData || data);\n }\n }\n }, [onSort && JSON.stringify(state.sortBy), manualSorting]);\n};\n\nconst DEFAULT_PAGE_SIZE = 10;\n\nexport const useTable = <T extends {}>(\n props: TableProps<T> & { windowed?: boolean },\n ref: React.RefObject<TableRef>\n): InternalTable => {\n const {\n children,\n data,\n dangerouslyHijackGlobalKeyboardNavigation: _,\n onRowClick,\n onRowDrag,\n onSelectedRows,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n selectedRows,\n\n // sorting\n disableSorting,\n manualSorting,\n onSort,\n sortRules,\n\n //index\n activeIndex: _1,\n defaultActiveIndex: _2,\n onChangeActiveIndex: _3,\n\n // pagination\n disablePagination = true,\n length,\n onPaginate,\n pageSize = DEFAULT_PAGE_SIZE,\n pageIndex = 0,\n\n // row editing\n inlineEditingUniqueId = undefined,\n onRowCreate,\n\n // actions\n actions,\n onRowEdit,\n onRowCopy,\n onRowDelete,\n onRowActive,\n\n windowed = false,\n\n ...otherProps\n } = props;\n\n if ((onSelectedRows && !selectedRows) || (!onSelectedRows && selectedRows)) {\n throw new Error(\n 'Selected rows in a Table component are fully controlled - you must pass both the `onSelectedRows` and `selectedRows` props when using row selection'\n );\n }\n\n const { texts } = useLocalization();\n const { columns, sortRules: defaultSortRules } = React.useMemo(\n () => getColumnsFromChildren(children, rowExpansionRenderer),\n [children, rowExpansionRenderer]\n );\n\n const manualPagination = !disablePagination && !!onPaginate && !!length;\n\n const {\n headerGroups,\n rows,\n sortedRows,\n prepareRow: prepareBaseRow,\n state,\n // pagination\n page,\n gotoPage,\n setPageSize,\n ...instance\n }: any = useReactTable(\n {\n columns,\n data,\n initialState: {\n // eslint-disable-next-line\n // @ts-ignore: not sure how to type this correctly right now\n sortBy: getInternalSortRules(sortRules) || defaultSortRules,\n pageSize: !disablePagination ? pageSize : undefined,\n pageIndex: !disablePagination ? pageIndex : undefined,\n },\n manualPagination,\n pageCount: manualPagination && length ? Math.ceil(length / pageSize) : -1,\n manualSortBy: manualSorting,\n disableSortBy: disableSorting,\n // most of these resets preventions are needed for editing mode\n autoResetExpanded: false,\n autoResetSelectedRows: false,\n autoResetSortBy: false,\n autoResetPage: false,\n sortTypes: React.useMemo(() => sortTypes, []),\n useControlledState: currentState => {\n return React.useMemo(\n () => ({\n ...currentState,\n selectedRowIds: selectedRows || [],\n }),\n [currentState, selectedRows]\n );\n },\n },\n useRowState,\n useSortBy,\n useExpanded,\n usePagination,\n useRowSelect(onSelectedRows),\n useRowDraggable(onRowDrag),\n useRowEditing(inlineEditingUniqueId),\n useRowActions(\n inlineEditingUniqueId,\n { onRowCreate, onRowEdit, onRowCopy, onRowDelete },\n actions,\n rowExpansionRenderer,\n texts,\n windowed\n )\n );\n\n useTablePaginationListener(disablePagination, onPaginate, state);\n useTableSortingListener(data, sortedRows, onSort, !!manualSorting, state);\n\n const sanitizedInstance = useTableInstance(instance, ref);\n\n const visibleRows = !disablePagination && !manualPagination ? page : rows;\n\n const [activeIndex, setActiveIndex, handleKeyDown, handleFocus] = useTableKeyboardNavigation<T>(\n props,\n visibleRows,\n { onRowClick, onRowCreate, onRowEdit, onRowCopy, onRowDelete, rowExpansionRenderer },\n ref\n );\n\n useTableRowActive(activeIndex, rows, rowExpansionRenderer, onRowActive);\n\n const prepareRow = React.useCallback(\n (row: any, index: number) => {\n prepareBaseRow(row);\n row.setActive = () => setActiveIndex(index);\n },\n [prepareBaseRow, setActiveIndex]\n );\n\n return {\n rowProps: {\n activeIndex,\n setActiveIndex,\n onRowClick,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n inlineEditingUniqueId,\n },\n tableProps: {\n ...otherProps,\n headerGroups,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n tabIndex: otherProps.tabIndex ?? 0,\n },\n state,\n pagination: !disablePagination\n ? {\n length: manualPagination && length ? length : data.length,\n pageIndex: state.pageIndex,\n pageSize: state.pageSize,\n setPageIndex: gotoPage,\n setPageSize: setPageSize,\n }\n : null,\n rows: visibleRows,\n prepareRow,\n instance: sanitizedInstance,\n };\n};\n"],"names":["useTableRowActive","activeIndex","rows","rowExpansionRenderer","handleonRowActive","React","useEffect","undefined","length","focusedRow","sanitizedFocusedRow","sanitizeRowProps","useTableInstance","instance","ref","sanitizedInstance","useMemo","toggleAllRowsExpanded","toggleHideAllColumns","toggleHideColumn","toggleEditing","toggleRowEditing","resetRowEditing","toggleRowExpanded","toggleSortBy","current","useTablePaginationListener","disablePagination","onPaginate","state","pageIndex","pageSize","useTableSortingListener","data","sortedRows","onSort","manualSorting","sortRules","sortBy","map","rule","accessor","id","desc","sortedData","row","original","JSON","stringify","DEFAULT_PAGE_SIZE","useTable","props","children","dangerouslyHijackGlobalKeyboardNavigation","_","onRowClick","onRowDrag","onSelectedRows","rowClassName","rowHeight","selectedRows","disableSorting","_1","defaultActiveIndex","_2","onChangeActiveIndex","_3","inlineEditingUniqueId","onRowCreate","actions","onRowEdit","onRowCopy","onRowDelete","onRowActive","windowed","otherProps","Error","texts","useLocalization","columns","defaultSortRules","getColumnsFromChildren","manualPagination","headerGroups","prepareRow","prepareBaseRow","page","gotoPage","setPageSize","useReactTable","initialState","getInternalSortRules","pageCount","Math","ceil","manualSortBy","disableSortBy","autoResetExpanded","autoResetSelectedRows","autoResetSortBy","autoResetPage","sortTypes","useControlledState","currentState","selectedRowIds","useRowState","useSortBy","useExpanded","usePagination","useRowSelect","useRowDraggable","useRowEditing","useRowActions","visibleRows","setActiveIndex","handleKeyDown","handleFocus","useTableKeyboardNavigation","useCallback","index","setActive","rowProps","tableProps","onFocus","onKeyDown","tabIndex","pagination","setPageIndex"],"mappings":"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"}
@@ -1,24 +1,20 @@
1
1
  import React__default from 'react';
2
- import keycode from 'keycode';
3
- import { getNextIndexFromKeycode } from '../../../utils/hooks/useListKeyboardNavigation.js';
2
+ import { getNextIndexFromKey } from '../../../utils/hooks/useListKeyboardNavigation.js';
4
3
  import { sanitizeRowProps } from '../util.js';
5
4
  import { useControllableState } from '@radix-ui/react-use-controllable-state';
6
5
 
7
- var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows, rowProps, ref) {
8
- var useGlobalKeyboardNavigation = props.dangerouslyHijackGlobalKeyboardNavigation;
9
-
10
- var _useControllableState = useControllableState({
6
+ const useTableKeyboardNavigation = (props, rows, rowProps, ref) => {
7
+ const useGlobalKeyboardNavigation = props.dangerouslyHijackGlobalKeyboardNavigation;
8
+ const [activeIndex, setActiveIndex] = useControllableState({
11
9
  prop: props.activeIndex,
12
10
  defaultProp: props.defaultActiveIndex !== undefined ? props.defaultActiveIndex : useGlobalKeyboardNavigation ? 0 : undefined,
13
11
  onChange: props.onChangeActiveIndex
14
- }),
15
- activeIndex = _useControllableState[0],
16
- setActiveIndex = _useControllableState[1];
12
+ });
17
13
 
18
- var onKeyDown = function onKeyDown(event) {
14
+ const onKeyDown = event => {
19
15
  var _document$activeEleme;
20
16
 
21
- var isModifierKeyPressed = event.metaKey || event.ctrlKey || event.altKey || event.shiftKey;
17
+ const isModifierKeyPressed = event.metaKey || event.ctrlKey || event.altKey || event.shiftKey;
22
18
 
23
19
  if (useGlobalKeyboardNavigation && document.activeElement !== ref.current && ((_document$activeEleme = document.activeElement) === null || _document$activeEleme === void 0 ? void 0 : _document$activeEleme.getAttribute('type')) !== 'search' && document.activeElement !== document.body) {
24
20
  return;
@@ -30,29 +26,29 @@ var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows
30
26
  }
31
27
 
32
28
  if (activeIndex !== undefined) {
33
- var currentRow = rows[activeIndex];
29
+ const currentRow = rows[activeIndex];
34
30
 
35
31
  if (currentRow) {
36
- var sanitizedRow = sanitizeRowProps(currentRow, rowProps.rowExpansionRenderer);
32
+ const sanitizedRow = sanitizeRowProps(currentRow, rowProps.rowExpansionRenderer);
37
33
 
38
- if (rowProps.onRowClick && event.keyCode === keycode('enter')) {
34
+ if (rowProps.onRowClick && event.key === 'Enter') {
39
35
  event.preventDefault();
40
36
  rowProps.onRowClick(sanitizedRow);
41
37
  return;
42
38
  }
43
39
 
44
- if (currentRow.toggleRowSelected && event.keyCode === keycode('space')) {
40
+ if (currentRow.toggleRowSelected && event.key === ' ') {
45
41
  event.preventDefault();
46
42
  currentRow.toggleRowSelected();
47
43
  return;
48
44
  }
49
45
 
50
46
  if (currentRow.toggleRowExpanded) {
51
- if (currentRow.isExpanded && event.keyCode === keycode('left')) {
47
+ if (currentRow.isExpanded && event.key === 'ArrowLeft') {
52
48
  event.preventDefault();
53
49
  currentRow.toggleRowExpanded();
54
50
  return;
55
- } else if (!currentRow.isExpanded && event.keyCode === keycode('right')) {
51
+ } else if (!currentRow.isExpanded && event.key === 'ArrowRight') {
56
52
  event.preventDefault();
57
53
  currentRow.toggleRowExpanded();
58
54
  return;
@@ -62,7 +58,7 @@ var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows
62
58
 
63
59
  if (currentRow.toggleRowEditing) {
64
60
  if (currentRow.canEdit && !currentRow.isEditing) {
65
- if (rowProps.onRowCreate && event.shiftKey && event.keyCode === keycode('n')) {
61
+ if (rowProps.onRowCreate && event.shiftKey && event.key === 'n') {
66
62
  event.preventDefault();
67
63
 
68
64
  if (!currentRow.isExpanded) {
@@ -73,7 +69,7 @@ var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows
73
69
  return;
74
70
  }
75
71
 
76
- if (event.keyCode === keycode('e')) {
72
+ if (event.key === 'e') {
77
73
  event.preventDefault();
78
74
  currentRow.toggleRowEditing();
79
75
  return;
@@ -81,19 +77,19 @@ var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows
81
77
  }
82
78
  }
83
79
 
84
- if (rowProps.onRowEdit && event.keyCode === keycode('e') && !isModifierKeyPressed) {
80
+ if (rowProps.onRowEdit && event.key === 'e' && !isModifierKeyPressed) {
85
81
  event.preventDefault();
86
82
  rowProps.onRowEdit(sanitizedRow, event);
87
83
  return;
88
84
  }
89
85
 
90
- if (rowProps.onRowCopy && event.keyCode === keycode('c') && !isModifierKeyPressed) {
86
+ if (rowProps.onRowCopy && event.key === 'c' && !isModifierKeyPressed) {
91
87
  event.preventDefault();
92
88
  rowProps.onRowCopy(sanitizedRow, event);
93
89
  return;
94
90
  }
95
91
 
96
- if (rowProps.onRowDelete && event.keyCode === keycode('delete') && !isModifierKeyPressed) {
92
+ if (rowProps.onRowDelete && event.key === 'Delete' && !isModifierKeyPressed) {
97
93
  event.preventDefault();
98
94
  rowProps.onRowDelete(sanitizedRow, event);
99
95
  return;
@@ -101,7 +97,7 @@ var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows
101
97
  }
102
98
  }
103
99
 
104
- var nextIndex = getNextIndexFromKeycode(event.keyCode, rows.length, activeIndex);
100
+ const nextIndex = getNextIndexFromKey(event.key, rows.length, activeIndex);
105
101
 
106
102
  if (nextIndex !== undefined) {
107
103
  event.preventDefault();
@@ -109,25 +105,25 @@ var useTableKeyboardNavigation = function useTableKeyboardNavigation(props, rows
109
105
  }
110
106
  };
111
107
 
112
- var handleKeyDown = function handleKeyDown(event) {
108
+ const handleKeyDown = event => {
113
109
  if (!useGlobalKeyboardNavigation) {
114
110
  onKeyDown(event.nativeEvent);
115
111
  }
116
112
  };
117
113
 
118
- React__default.useEffect(function () {
114
+ React__default.useEffect(() => {
119
115
  if (useGlobalKeyboardNavigation) {
120
116
  window.addEventListener('keydown', onKeyDown);
121
117
  }
122
118
 
123
- return function () {
119
+ return () => {
124
120
  if (useGlobalKeyboardNavigation) {
125
121
  window.removeEventListener('keydown', onKeyDown);
126
122
  }
127
123
  };
128
124
  }, [onKeyDown]);
129
125
 
130
- var handleFocus = function handleFocus() {
126
+ const handleFocus = () => {
131
127
  if (activeIndex === undefined && rows.length) {
132
128
  setActiveIndex(0);
133
129
  }