@economic/taco 2.45.0-alpha.3 → 2.45.0-alpha.31

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 (335) hide show
  1. package/dist/charts/components/Area/AreaChart.d.ts +19 -0
  2. package/dist/charts/components/Bar/BarChart.d.ts +20 -0
  3. package/dist/charts/components/Donut/ActiveShape.d.ts +8 -0
  4. package/dist/charts/components/Donut/CenteredLabel.d.ts +11 -0
  5. package/dist/charts/components/Donut/DonutChart.d.ts +21 -0
  6. package/dist/charts/components/Donut/Legend.d.ts +13 -0
  7. package/dist/charts/components/Donut/util.d.ts +2 -0
  8. package/dist/charts/components/Legend.d.ts +16 -0
  9. package/dist/charts/components/Line/LineChart.d.ts +18 -0
  10. package/dist/charts/components/ResponsiveContainer.d.ts +5 -0
  11. package/dist/charts/components/Tooltip.d.ts +10 -0
  12. package/dist/charts/components/types.d.ts +5 -0
  13. package/dist/charts/utils/color.d.ts +3 -0
  14. package/dist/charts/utils/common.d.ts +37 -0
  15. package/dist/components/Alert/Alert.d.ts +1 -1
  16. package/dist/components/Hanger/Hanger.d.ts +1 -0
  17. package/dist/components/Icon/components/Autopay.d.ts +3 -0
  18. package/dist/components/Icon/components/AutopayPaused.d.ts +3 -0
  19. package/dist/components/Icon/components/Experiment.d.ts +3 -0
  20. package/dist/components/Icon/components/Person.d.ts +3 -0
  21. package/dist/components/Icon/components/PersonSolid.d.ts +3 -0
  22. package/dist/components/Icon/components/Wallet.d.ts +3 -0
  23. package/dist/components/Icon/components/index.d.ts +1 -1
  24. package/dist/components/Input/Input.d.ts +1 -1
  25. package/dist/components/Input/util.d.ts +5 -9
  26. package/dist/components/Listbox/util.d.ts +1 -1
  27. package/dist/components/Menu/components/Item.d.ts +1 -1
  28. package/dist/components/Menu/components/Link.d.ts +1 -1
  29. package/dist/components/Navigation2/components/Link.d.ts +1 -1
  30. package/dist/components/RadioGroup/RadioGroup.d.ts +3 -3
  31. package/dist/components/Report/Report.d.ts +4 -2
  32. package/dist/components/SearchInput2/SearchInput2.d.ts +2 -0
  33. package/dist/components/Select2/components/Option.d.ts +4 -4
  34. package/dist/components/Select2/components/Search.d.ts +1 -1
  35. package/dist/components/Table3/Table3.d.ts +3 -4
  36. package/dist/components/Table3/components/Row/Editing/CreateNewRow.d.ts +1 -3
  37. package/dist/components/Table3/components/Row/Editing/TemporaryRow.d.ts +1 -0
  38. package/dist/components/Table3/features/useEditingState.d.ts +13 -13
  39. package/dist/components/Table3/features/useTableEditing.d.ts +15 -14
  40. package/dist/components/Table3/types.d.ts +2 -0
  41. package/dist/components/Table3/util/editing.d.ts +3 -0
  42. package/dist/components/Tag/Tag.d.ts +1 -1
  43. package/dist/components/Tour/Tour.d.ts +2 -2
  44. package/dist/esm/index.css +148 -16
  45. package/dist/esm/packages/taco/src/charts/components/Area/AreaChart.js +67 -0
  46. package/dist/esm/packages/taco/src/charts/components/Area/AreaChart.js.map +1 -0
  47. package/dist/esm/packages/taco/src/charts/components/Bar/BarChart.js +120 -0
  48. package/dist/esm/packages/taco/src/charts/components/Bar/BarChart.js.map +1 -0
  49. package/dist/esm/packages/taco/src/charts/components/Donut/ActiveShape.js +47 -0
  50. package/dist/esm/packages/taco/src/charts/components/Donut/ActiveShape.js.map +1 -0
  51. package/dist/esm/packages/taco/src/charts/components/Donut/CenteredLabel.js +27 -0
  52. package/dist/esm/packages/taco/src/charts/components/Donut/CenteredLabel.js.map +1 -0
  53. package/dist/esm/packages/taco/src/charts/components/Donut/DonutChart.js +170 -0
  54. package/dist/esm/packages/taco/src/charts/components/Donut/DonutChart.js.map +1 -0
  55. package/dist/esm/packages/taco/src/charts/components/Donut/Legend.js +165 -0
  56. package/dist/esm/packages/taco/src/charts/components/Donut/Legend.js.map +1 -0
  57. package/dist/esm/packages/taco/src/charts/components/Donut/util.js +5 -0
  58. package/dist/esm/packages/taco/src/charts/components/Donut/util.js.map +1 -0
  59. package/dist/esm/packages/taco/src/charts/components/Legend.js +146 -0
  60. package/dist/esm/packages/taco/src/charts/components/Legend.js.map +1 -0
  61. package/dist/esm/packages/taco/src/charts/components/Line/LineChart.js +65 -0
  62. package/dist/esm/packages/taco/src/charts/components/Line/LineChart.js.map +1 -0
  63. package/dist/esm/packages/taco/src/charts/components/ResponsiveContainer.js +10 -0
  64. package/dist/esm/packages/taco/src/charts/components/ResponsiveContainer.js.map +1 -0
  65. package/dist/esm/packages/taco/src/charts/components/Tooltip.js +44 -0
  66. package/dist/esm/packages/taco/src/charts/components/Tooltip.js.map +1 -0
  67. package/dist/esm/packages/taco/src/charts/utils/color.js +24 -0
  68. package/dist/esm/packages/taco/src/charts/utils/color.js.map +1 -0
  69. package/dist/esm/packages/taco/src/charts/utils/common.js +34 -0
  70. package/dist/esm/packages/taco/src/charts/utils/common.js.map +1 -0
  71. package/dist/esm/packages/taco/src/components/Accordion/Accordion.js +6 -14
  72. package/dist/esm/packages/taco/src/components/Accordion/Accordion.js.map +1 -1
  73. package/dist/esm/packages/taco/src/components/Alert/Alert.js +2 -0
  74. package/dist/esm/packages/taco/src/components/Alert/Alert.js.map +1 -1
  75. package/dist/esm/packages/taco/src/components/Badge/Badge.js +9 -6
  76. package/dist/esm/packages/taco/src/components/Badge/Badge.js.map +1 -1
  77. package/dist/esm/packages/taco/src/components/Banner/util.js +5 -0
  78. package/dist/esm/packages/taco/src/components/Banner/util.js.map +1 -1
  79. package/dist/esm/packages/taco/src/components/Button/Button.js +2 -1
  80. package/dist/esm/packages/taco/src/components/Button/Button.js.map +1 -1
  81. package/dist/esm/packages/taco/src/components/Card/Card.js +2 -2
  82. package/dist/esm/packages/taco/src/components/Card/Card.js.map +1 -1
  83. package/dist/esm/packages/taco/src/components/Checkbox/Checkbox.js +3 -2
  84. package/dist/esm/packages/taco/src/components/Checkbox/Checkbox.js.map +1 -1
  85. package/dist/esm/packages/taco/src/components/Combobox/useCombobox.js +9 -6
  86. package/dist/esm/packages/taco/src/components/Combobox/useCombobox.js.map +1 -1
  87. package/dist/esm/packages/taco/src/components/Datepicker/Datepicker.js +13 -0
  88. package/dist/esm/packages/taco/src/components/Datepicker/Datepicker.js.map +1 -1
  89. package/dist/esm/packages/taco/src/components/Datepicker/useDatepicker.js +9 -1
  90. package/dist/esm/packages/taco/src/components/Datepicker/useDatepicker.js.map +1 -1
  91. package/dist/esm/packages/taco/src/components/Dialog/Dialog.js.map +1 -1
  92. package/dist/esm/packages/taco/src/components/Dialog/components/Content.js +7 -5
  93. package/dist/esm/packages/taco/src/components/Dialog/components/Content.js.map +1 -1
  94. package/dist/esm/packages/taco/src/components/Hanger/Hanger.js +4 -2
  95. package/dist/esm/packages/taco/src/components/Hanger/Hanger.js.map +1 -1
  96. package/dist/esm/packages/taco/src/components/Header/components/Agreement/Avatar.js.map +1 -1
  97. package/dist/esm/packages/taco/src/components/Header/components/AgreementSelector.js +2 -4
  98. package/dist/esm/packages/taco/src/components/Header/components/AgreementSelector.js.map +1 -1
  99. package/dist/esm/packages/taco/src/components/Icon/components/Autopay.js +19 -0
  100. package/dist/esm/packages/taco/src/components/Icon/components/Autopay.js.map +1 -0
  101. package/dist/esm/packages/taco/src/components/Icon/components/AutopayPaused.js +19 -0
  102. package/dist/esm/packages/taco/src/components/Icon/components/AutopayPaused.js.map +1 -0
  103. package/dist/esm/packages/taco/src/components/Icon/components/Experiment.js +20 -0
  104. package/dist/esm/packages/taco/src/components/Icon/components/Experiment.js.map +1 -0
  105. package/dist/esm/packages/taco/src/components/Icon/components/Person.js +19 -0
  106. package/dist/esm/packages/taco/src/components/Icon/components/Person.js.map +1 -0
  107. package/dist/esm/packages/taco/src/components/Icon/components/PersonSolid.js +19 -0
  108. package/dist/esm/packages/taco/src/components/Icon/components/PersonSolid.js.map +1 -0
  109. package/dist/esm/packages/taco/src/components/Icon/components/Wallet.js +19 -0
  110. package/dist/esm/packages/taco/src/components/Icon/components/Wallet.js.map +1 -0
  111. package/dist/esm/packages/taco/src/components/Icon/components/index.js +12 -0
  112. package/dist/esm/packages/taco/src/components/Icon/components/index.js.map +1 -1
  113. package/dist/esm/packages/taco/src/components/Input/util.js +1 -1
  114. package/dist/esm/packages/taco/src/components/Input/util.js.map +1 -1
  115. package/dist/esm/packages/taco/src/components/Listbox/util.js +1 -7
  116. package/dist/esm/packages/taco/src/components/Listbox/util.js.map +1 -1
  117. package/dist/esm/packages/taco/src/components/Menu/components/Content.js +5 -0
  118. package/dist/esm/packages/taco/src/components/Menu/components/Content.js.map +1 -1
  119. package/dist/esm/packages/taco/src/components/Menu/components/Item.js.map +1 -1
  120. package/dist/esm/packages/taco/src/components/OverflowGroup/OverflowGroup.js.map +1 -1
  121. package/dist/esm/packages/taco/src/components/RadioGroup/RadioGroup.js.map +1 -1
  122. package/dist/esm/packages/taco/src/components/Report/Report.js +2 -3
  123. package/dist/esm/packages/taco/src/components/Report/Report.js.map +1 -1
  124. package/dist/esm/packages/taco/src/components/ScrollArea/ScrollArea.js.map +1 -1
  125. package/dist/esm/packages/taco/src/components/SearchInput2/SearchInput2.js +6 -3
  126. package/dist/esm/packages/taco/src/components/SearchInput2/SearchInput2.js.map +1 -1
  127. package/dist/esm/packages/taco/src/components/Select/Select.js.map +1 -1
  128. package/dist/esm/packages/taco/src/components/Select/useSelect.js.map +1 -1
  129. package/dist/esm/packages/taco/src/components/Select2/components/Create.js +10 -11
  130. package/dist/esm/packages/taco/src/components/Select2/components/Create.js.map +1 -1
  131. package/dist/esm/packages/taco/src/components/Select2/components/Edit.js.map +1 -1
  132. package/dist/esm/packages/taco/src/components/Select2/components/Option.js +7 -5
  133. package/dist/esm/packages/taco/src/components/Select2/components/Option.js.map +1 -1
  134. package/dist/esm/packages/taco/src/components/Select2/components/Trigger.js +56 -19
  135. package/dist/esm/packages/taco/src/components/Select2/components/Trigger.js.map +1 -1
  136. package/dist/esm/packages/taco/src/components/Shortcut/Shortcut.js +1 -1
  137. package/dist/esm/packages/taco/src/components/Shortcut/Shortcut.js.map +1 -1
  138. package/dist/esm/packages/taco/src/components/Table/components/WindowedTable.js.map +1 -1
  139. package/dist/esm/packages/taco/src/components/Table/hooks/plugins/useRowActions.js +1 -1
  140. package/dist/esm/packages/taco/src/components/Table/hooks/plugins/useRowSelect.js.map +1 -1
  141. package/dist/esm/packages/taco/src/components/Table3/Table3.js +23 -12
  142. package/dist/esm/packages/taco/src/components/Table3/Table3.js.map +1 -1
  143. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/Editing/RowMoveIndicator.js.map +1 -1
  144. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js +61 -36
  145. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js.map +1 -1
  146. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Internal/EditingActionsMenu.js.map +1 -1
  147. package/dist/esm/packages/taco/src/components/Table3/components/Editing/Alert.js +18 -10
  148. package/dist/esm/packages/taco/src/components/Table3/components/Editing/Alert.js.map +1 -1
  149. package/dist/esm/packages/taco/src/components/Table3/components/Editing/DiscardChangesConfirmationDialog.js +0 -1
  150. package/dist/esm/packages/taco/src/components/Table3/components/Editing/DiscardChangesConfirmationDialog.js.map +1 -1
  151. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/CreateNewRow.js +6 -38
  152. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/CreateNewRow.js.map +1 -1
  153. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/TemporaryRow.js +7 -6
  154. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/TemporaryRow.js.map +1 -1
  155. package/dist/esm/packages/taco/src/components/Table3/components/Toolbar/Editing/Editing.js +4 -0
  156. package/dist/esm/packages/taco/src/components/Table3/components/Toolbar/Editing/Editing.js.map +1 -1
  157. package/dist/esm/packages/taco/src/components/Table3/features/useEditingState.js +80 -80
  158. package/dist/esm/packages/taco/src/components/Table3/features/useEditingState.js.map +1 -1
  159. package/dist/esm/packages/taco/src/components/Table3/features/useTableEditing.js +69 -14
  160. package/dist/esm/packages/taco/src/components/Table3/features/useTableEditing.js.map +1 -1
  161. package/dist/esm/packages/taco/src/components/Table3/listeners/useTableEditingListener.js +16 -22
  162. package/dist/esm/packages/taco/src/components/Table3/listeners/useTableEditingListener.js.map +1 -1
  163. package/dist/esm/packages/taco/src/components/Table3/useTable3.js +8 -6
  164. package/dist/esm/packages/taco/src/components/Table3/useTable3.js.map +1 -1
  165. package/dist/esm/packages/taco/src/components/Table3/util/editing.js +11 -4
  166. package/dist/esm/packages/taco/src/components/Table3/util/editing.js.map +1 -1
  167. package/dist/esm/packages/taco/src/components/Tag/Tag.js +6 -4
  168. package/dist/esm/packages/taco/src/components/Tag/Tag.js.map +1 -1
  169. package/dist/esm/packages/taco/src/components/Toast/Toaster.js +16 -2
  170. package/dist/esm/packages/taco/src/components/Toast/Toaster.js.map +1 -1
  171. package/dist/esm/packages/taco/src/components/Tooltip/Tooltip.js +2 -2
  172. package/dist/esm/packages/taco/src/components/Tooltip/Tooltip.js.map +1 -1
  173. package/dist/esm/packages/taco/src/components/Tour/Tour.js +2 -2
  174. package/dist/esm/packages/taco/src/components/Tour/Tour.js.map +1 -1
  175. package/dist/esm/packages/taco/src/hooks/useGlobalKeyDown.js.map +1 -1
  176. package/dist/esm/packages/taco/src/hooks/useIntersectionObserver.js.map +1 -1
  177. package/dist/esm/packages/taco/src/hooks/useLazyEffect.js +1 -1
  178. package/dist/esm/packages/taco/src/hooks/useLazyEffect.js.map +1 -1
  179. package/dist/esm/packages/taco/src/index.js +6 -1
  180. package/dist/esm/packages/taco/src/index.js.map +1 -1
  181. package/dist/esm/packages/taco/src/primitives/BubbleSelect.js +1 -1
  182. package/dist/esm/packages/taco/src/primitives/BubbleSelect.js.map +1 -1
  183. package/dist/esm/packages/taco/src/primitives/Collection/components/Root.js +5 -3
  184. package/dist/esm/packages/taco/src/primitives/Collection/components/Root.js.map +1 -1
  185. package/dist/esm/packages/taco/src/primitives/Sortable/components/Container.js +1 -1
  186. package/dist/esm/packages/taco/src/primitives/Sortable/components/Container.js.map +1 -1
  187. package/dist/esm/packages/taco/src/primitives/Sortable/components/Item.js.map +1 -1
  188. package/dist/esm/packages/taco/src/primitives/Table/Core/Table.js +8 -10
  189. package/dist/esm/packages/taco/src/primitives/Table/Core/Table.js.map +1 -1
  190. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Body/Body.js +2 -0
  191. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Body/Body.js.map +1 -1
  192. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Body/EmptyStateBody.js +15 -2
  193. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Body/EmptyStateBody.js.map +1 -1
  194. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Actions.js +4 -3
  195. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Actions.js.map +1 -1
  196. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Drag.js +7 -0
  197. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Drag.js.map +1 -1
  198. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Expansion.js +11 -0
  199. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Expansion.js.map +1 -1
  200. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Selection.js +10 -7
  201. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Selection.js.map +1 -1
  202. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Footer.js +23 -6
  203. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Footer.js.map +1 -1
  204. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Summary.js +7 -6
  205. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Summary.js.map +1 -1
  206. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/Header.js +20 -6
  207. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/Header.js.map +1 -1
  208. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/components/Goto.js.map +1 -1
  209. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/components/Resizer.js.map +1 -1
  210. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/components/SortIndicator.js.map +1 -1
  211. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/util.js.map +1 -1
  212. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/DisplayRow.js +7 -15
  213. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/DisplayRow.js.map +1 -1
  214. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/SkeletonRow.js +24 -22
  215. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/SkeletonRow.js.map +1 -1
  216. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/Row.js +44 -5
  217. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/Row.js.map +1 -1
  218. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/RowContext.js +3 -2
  219. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/RowContext.js.map +1 -1
  220. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/FilterContext.js +6 -0
  221. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/FilterContext.js.map +1 -0
  222. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/ManageFiltersPopover.js +5 -3
  223. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/ManageFiltersPopover.js.map +1 -1
  224. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/Filter.js +0 -2
  225. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/Filter.js.map +1 -1
  226. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterColumn.js +2 -1
  227. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterColumn.js.map +1 -1
  228. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterComparator.js +4 -0
  229. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterComparator.js.map +1 -1
  230. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterValue.js +4 -4
  231. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterValue.js.map +1 -1
  232. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Print/Print.js +3 -1
  233. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Print/Print.js.map +1 -1
  234. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Search/Search.js +26 -4
  235. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Search/Search.js.map +1 -1
  236. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableGlobalShortcuts.js +2 -2
  237. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableGlobalShortcuts.js.map +1 -1
  238. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableRenderer.js +54 -56
  239. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableRenderer.js.map +1 -1
  240. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableStyleGrid.js +2 -2
  241. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableStyleGrid.js.map +1 -1
  242. package/dist/esm/packages/taco/src/primitives/Table/Core/useTable.js +1 -1
  243. package/dist/esm/packages/taco/src/primitives/Table/Core/useTable.js.map +1 -1
  244. package/dist/esm/packages/taco/src/primitives/Table/types.js +3 -7
  245. package/dist/esm/packages/taco/src/primitives/Table/types.js.map +1 -1
  246. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader.js +13 -12
  247. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader.js.map +1 -1
  248. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader2.js +224 -0
  249. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader2.js.map +1 -0
  250. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActions.js +11 -0
  251. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActions.js.map +1 -1
  252. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActive.js +1 -1
  253. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActive.js.map +1 -1
  254. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowExpansion.js +2 -1
  255. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowExpansion.js.map +1 -1
  256. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableSearch.js +3 -2
  257. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableSearch.js.map +1 -1
  258. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableServerLoading.js +18 -8
  259. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableServerLoading.js.map +1 -1
  260. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableDataListener.js +3 -4
  261. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableDataListener.js.map +1 -1
  262. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFilterListener.js +3 -1
  263. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFilterListener.js.map +1 -1
  264. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFontSizeListener.js +2 -1
  265. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFontSizeListener.js.map +1 -1
  266. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableRowSelectionListener.js +4 -4
  267. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableRowSelectionListener.js.map +1 -1
  268. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableSearchListener.js +14 -13
  269. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableSearchListener.js.map +1 -1
  270. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableServerLoadingListener.js +7 -3
  271. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableServerLoadingListener.js.map +1 -1
  272. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableSettingsListener.js.map +1 -1
  273. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/useTableManager.js +6 -5
  274. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/useTableManager.js.map +1 -1
  275. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/columns.js +4 -1
  276. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/columns.js.map +1 -1
  277. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/dataTypes.js +6 -2
  278. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/dataTypes.js.map +1 -1
  279. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/filtering.js +6 -0
  280. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/filtering.js.map +1 -1
  281. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/presets.js +7 -1
  282. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/presets.js.map +1 -1
  283. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/search.js +7 -1
  284. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/search.js.map +1 -1
  285. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/settings.js.map +1 -1
  286. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/setup.js +20 -5
  287. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/setup.js.map +1 -1
  288. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/sorting.js.map +1 -1
  289. package/dist/esm/packages/taco/src/types.js.map +1 -1
  290. package/dist/esm/packages/taco/src/utils/dom.js +12 -1
  291. package/dist/esm/packages/taco/src/utils/dom.js.map +1 -1
  292. package/dist/esm/packages/taco/src/utils/tailwind.js +2 -0
  293. package/dist/esm/packages/taco/src/utils/tailwind.js.map +1 -1
  294. package/dist/esm/packages/taco/tailwind.colors.js +122 -0
  295. package/dist/esm/packages/taco/tailwind.colors.js.map +1 -0
  296. package/dist/hooks/useLazyDebouncedEffect.d.ts +2 -0
  297. package/dist/index.css +148 -16
  298. package/dist/index.d.ts +6 -0
  299. package/dist/primitives/Sortable/components/Container.d.ts +1 -1
  300. package/dist/primitives/Table/Core/Table.d.ts +1 -0
  301. package/dist/primitives/Table/Core/components/Body/EmptyStateBody.d.ts +1 -0
  302. package/dist/primitives/Table/Core/components/Body/util.d.ts +4 -4
  303. package/dist/primitives/Table/Core/components/Footer/Footer.d.ts +2 -2
  304. package/dist/primitives/Table/Core/components/Header/components/SortIndicator.d.ts +2 -2
  305. package/dist/primitives/Table/Core/components/Row/BuiltIns/SkeletonRow.d.ts +2 -2
  306. package/dist/primitives/Table/Core/components/Row/Row.d.ts +2 -0
  307. package/dist/primitives/Table/Core/components/Row/RowContext.d.ts +2 -1
  308. package/dist/primitives/Table/Core/components/Toolbar/components/Filters/FilterContext.d.ts +3 -0
  309. package/dist/primitives/Table/Core/components/Toolbar/components/Filters/components/Filter.d.ts +0 -1
  310. package/dist/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterColumn.d.ts +0 -3
  311. package/dist/primitives/Table/Core/features/useTableRenderer.d.ts +1 -1
  312. package/dist/primitives/Table/Core/types.d.ts +2 -1
  313. package/dist/primitives/Table/types.d.ts +24 -16
  314. package/dist/primitives/Table/useTableDataLoader.d.ts +2 -2
  315. package/dist/primitives/Table/useTableDataLoader2.d.ts +23 -0
  316. package/dist/primitives/Table/useTableManager/features/useTableRowActions.d.ts +2 -0
  317. package/dist/primitives/Table/useTableManager/features/useTableRowExpansion.d.ts +2 -1
  318. package/dist/primitives/Table/useTableManager/features/useTableSearch.d.ts +4 -2
  319. package/dist/primitives/Table/useTableManager/features/useTableServerLoading.d.ts +6 -3
  320. package/dist/primitives/Table/useTableManager/listeners/useTableDataListener.d.ts +1 -1
  321. package/dist/primitives/Table/useTableManager/listeners/useTableSearchListener.d.ts +1 -2
  322. package/dist/primitives/Table/useTableManager/useTableManager.d.ts +2 -1
  323. package/dist/primitives/Table/useTableManager/util/columns.d.ts +2 -1
  324. package/dist/primitives/Table/useTableManager/util/dataTypes.d.ts +1 -1
  325. package/dist/primitives/Table/useTableManager/util/settings.d.ts +1 -1
  326. package/dist/taco.cjs.development.js +2055 -585
  327. package/dist/taco.cjs.development.js.map +1 -1
  328. package/dist/taco.cjs.production.min.js +1 -1
  329. package/dist/taco.cjs.production.min.js.map +1 -1
  330. package/dist/types.d.ts +1 -1
  331. package/dist/utils/dom.d.ts +2 -2
  332. package/package.json +9 -8
  333. package/tailwind.colors.js +121 -0
  334. package/tailwind.config.js +3 -2
  335. package/dist/components/Table3/components/Row/Editing/CreateRowButton.d.ts +0 -11
@@ -6,14 +6,12 @@ import { Button } from '../../../../Button/Button.js';
6
6
  import { Shortcut } from '../../../../Shortcut/Shortcut.js';
7
7
 
8
8
  function CreateNewRow(props) {
9
- var _temporaryRows$0$tabl, _temporaryRows$, _table$getState$colum, _tableRef$current2;
9
+ var _temporaryRows$0$tabl, _temporaryRows$, _table$getState$colum;
10
10
  const {
11
11
  buttonRef,
12
- onEditingCreate: handleEditingCreate,
13
- scrollToIndex,
12
+ isScrolled,
14
13
  table,
15
- tableMeta,
16
- tableRef
14
+ tableMeta
17
15
  } = props;
18
16
  const {
19
17
  texts
@@ -22,44 +20,16 @@ function CreateNewRow(props) {
22
20
  const temporaryRowId = (_temporaryRows$0$tabl = (_temporaryRows$ = temporaryRows[0]) === null || _temporaryRows$ === void 0 ? void 0 : _temporaryRows$[tableMeta.rowIdentityAccessor]) !== null && _temporaryRows$0$tabl !== void 0 ? _temporaryRows$0$tabl : '';
23
21
  const isDisabled = !!table.getState().globalFilter || !!((_table$getState$colum = table.getState().columnFilters) !== null && _table$getState$colum !== void 0 && _table$getState$colum.length) || !!temporaryRowId && !!tableMeta.editing.hasRowErrors(temporaryRowId);
24
22
  const isSaving = !!temporaryRowId && tableMeta.editing.getRowStatus(temporaryRowId) === 'saving';
25
- const createRow = function (row) {
23
+ const handleCreate = function () {
26
24
  try {
27
- if (!handleEditingCreate || isDisabled) {
25
+ if (isDisabled) {
28
26
  return Promise.resolve();
29
27
  }
30
- return Promise.resolve(tableMeta.editing.saveChanges(table)).then(function (saved) {
31
- if (!saved) {
32
- return;
33
- }
34
- const changeset = row !== null && row !== void 0 ? row : handleEditingCreate();
35
- try {
36
- if (changeset) {
37
- const rowId = tableMeta.editing.createRow(changeset);
38
- table.getRow(rowId).pin('bottom');
39
- // set the active row to the new row before toggling editing on
40
- const nextRowIndex = temporaryRows.length ? tableMeta.length + 1 : tableMeta.length;
41
- tableMeta.rowActive.setRowActiveIndex(nextRowIndex);
42
- tableMeta.editing.toggleEditing(true, table, scrollToIndex);
43
- tableMeta.editing.setLastFocusedCellIndex(0);
44
- }
45
- } catch (error) {
46
- console.error(error);
47
- }
48
- });
28
+ return Promise.resolve(tableMeta.editing.createRow(table)).then(function () {});
49
29
  } catch (e) {
50
30
  return Promise.reject(e);
51
31
  }
52
32
  };
53
- // allow programmatic access to creating rows from outside the table
54
- React__default.useEffect(() => {
55
- var _tableRef$current;
56
- if (tableRef !== null && tableRef !== void 0 && (_tableRef$current = tableRef.current) !== null && _tableRef$current !== void 0 && _tableRef$current.instance) {
57
- tableRef.current.instance.createRow = createRow;
58
- }
59
- }, [tableRef === null || tableRef === void 0 ? void 0 : (_tableRef$current2 = tableRef.current) === null || _tableRef$current2 === void 0 ? void 0 : _tableRef$current2.instance, createRow]);
60
- const handleCreate = function () {
61
- return createRow();
62
- };
63
33
  const shortcut = {
64
34
  key: 'Enter',
65
35
  meta: true
@@ -74,11 +44,9 @@ function CreateNewRow(props) {
74
44
  keys: shortcut
75
45
  });
76
46
  }
77
- const isScrolled = tableRef.current ? tableRef.current.scrollHeight > tableRef.current.clientHeight : false;
78
47
  const className = cn('group/row border-grey-300 !sticky z-[21]', {
79
48
  'bottom-10': tableMeta.footer.isEnabled,
80
49
  'bottom-0': !tableMeta.footer.isEnabled,
81
- 'border-t-2': isScrolled,
82
50
  'border-b': !isScrolled
83
51
  });
84
52
  return /*#__PURE__*/React__default.createElement("tr", {
@@ -1 +1 @@
1
- {"version":3,"file":"CreateNewRow.js","sources":["../../../../../../../../../../src/components/Table3/components/Row/Editing/CreateNewRow.tsx"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, TableMeta as ReactTableMeta } from '@tanstack/react-table';\nimport { Button } from '../../../../Button/Button';\nimport { useLocalization } from '../../../../Provider/Localization';\nimport { Icon } from '../../../../Icon/Icon';\nimport { Table3EditingCreateHandler, Table3Ref } from '../../../types';\nimport { TableRef } from '../../../../../primitives/Table/types';\nimport { Shortcut } from '../../../../Shortcut/Shortcut';\nimport clsx from 'clsx';\n\ntype CreateNewRowProps<TType = unknown> = {\n buttonRef: React.Ref<HTMLButtonElement>;\n onEditingCreate?: Table3EditingCreateHandler<TType>;\n scrollToIndex: (index: number) => void;\n table: ReactTable<TType>;\n tableMeta: ReactTableMeta<TType>;\n tableRef: React.RefObject<TableRef>;\n};\n\nexport function CreateNewRow<TType = unknown>(props: CreateNewRowProps<TType>) {\n const { buttonRef, onEditingCreate: handleEditingCreate, scrollToIndex, table, tableMeta, tableRef } = props;\n const { texts } = useLocalization();\n\n const temporaryRows = tableMeta.editing.temporaryRows as TType[];\n const temporaryRowId: string = temporaryRows[0]?.[tableMeta.rowIdentityAccessor as string] ?? '';\n\n const isDisabled =\n !!table.getState().globalFilter ||\n !!table.getState().columnFilters?.length ||\n (!!temporaryRowId && !!tableMeta.editing.hasRowErrors(temporaryRowId));\n const isSaving = !!temporaryRowId && tableMeta.editing.getRowStatus(temporaryRowId) === 'saving';\n\n const createRow = async (row?: Partial<TType>) => {\n if (!handleEditingCreate || isDisabled) {\n return;\n }\n\n const saved = await tableMeta.editing.saveChanges(table);\n\n if (!saved) {\n return;\n }\n\n const changeset = row ?? handleEditingCreate();\n\n try {\n if (changeset) {\n const rowId = tableMeta.editing.createRow(changeset);\n table.getRow(rowId).pin('bottom');\n\n // set the active row to the new row before toggling editing on\n const nextRowIndex = temporaryRows.length ? tableMeta.length + 1 : tableMeta.length;\n tableMeta.rowActive.setRowActiveIndex(nextRowIndex);\n\n tableMeta.editing.toggleEditing(true, table, scrollToIndex);\n tableMeta.editing.setLastFocusedCellIndex(0);\n }\n } catch (error) {\n console.error(error);\n }\n };\n\n // allow programmatic access to creating rows from outside the table\n React.useEffect(() => {\n if (tableRef?.current?.instance) {\n (tableRef.current as Table3Ref).instance.createRow = createRow as (row: unknown) => Promise<void>;\n }\n }, [tableRef?.current?.instance, createRow]);\n\n const handleCreate = async () => createRow();\n const shortcut = { key: 'Enter', meta: true };\n\n let tooltip;\n\n if (isSaving) {\n tooltip = texts.table3.editing.buttons.create.saving;\n } else if (isDisabled) {\n tooltip = texts.table3.editing.buttons.create.disabled;\n } else {\n tooltip = <Shortcut keys={shortcut} />;\n }\n\n const isScrolled = tableRef.current ? tableRef.current.scrollHeight > tableRef.current.clientHeight : false;\n\n const className = clsx('group/row border-grey-300 !sticky z-[21]', {\n 'bottom-10': tableMeta.footer.isEnabled,\n 'bottom-0': !tableMeta.footer.isEnabled,\n 'border-t-2': isScrolled,\n 'border-b': !isScrolled,\n });\n\n return (\n <tr data-row-create className={className} tabIndex={-1}>\n <td className=\"!bg-grey-50 col-span-full !border-b-0 !px-1\">\n <Button\n appearance=\"transparent\"\n className=\"group-hover:bg-grey-200 sticky left-[4px]\"\n disabled={isDisabled}\n onClick={handleCreate}\n ref={buttonRef}\n shortcut={shortcut}\n tooltip={tooltip}>\n <Icon name=\"circle-plus\" />\n {texts.table3.editing.buttons.create.label}\n </Button>\n </td>\n </tr>\n );\n}\n"],"names":["CreateNewRow","props","buttonRef","onEditingCreate","handleEditingCreate","scrollToIndex","table","tableMeta","tableRef","texts","useLocalization","temporaryRows","editing","temporaryRowId","_temporaryRows$0$tabl","_temporaryRows$","rowIdentityAccessor","isDisabled","getState","globalFilter","_table$getState$colum","columnFilters","length","hasRowErrors","isSaving","getRowStatus","createRow","row","Promise","resolve","saveChanges","then","saved","changeset","rowId","getRow","pin","nextRowIndex","rowActive","setRowActiveIndex","toggleEditing","setLastFocusedCellIndex","error","console","e","reject","React","useEffect","_tableRef$current","current","instance","_tableRef$current2","handleCreate","shortcut","key","meta","tooltip","table3","buttons","create","saving","disabled","Shortcut","keys","isScrolled","scrollHeight","clientHeight","className","clsx","footer","isEnabled","tabIndex","Button","appearance","onClick","ref","Icon","name","label"],"mappings":"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"}
1
+ {"version":3,"file":"CreateNewRow.js","sources":["../../../../../../../../../../src/components/Table3/components/Row/Editing/CreateNewRow.tsx"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, TableMeta as ReactTableMeta } from '@tanstack/react-table';\nimport clsx from 'clsx';\nimport { Button } from '../../../../Button/Button';\nimport { useLocalization } from '../../../../Provider/Localization';\nimport { Icon } from '../../../../Icon/Icon';\nimport { Table3EditingCreateHandler } from '../../../types';\nimport { Shortcut } from '../../../../Shortcut/Shortcut';\n\ntype CreateNewRowProps<TType = unknown> = {\n buttonRef: React.Ref<HTMLButtonElement>;\n isScrolled: boolean;\n onEditingCreate?: Table3EditingCreateHandler<TType>;\n table: ReactTable<TType>;\n tableMeta: ReactTableMeta<TType>;\n};\n\nexport function CreateNewRow<TType = unknown>(props: CreateNewRowProps<TType>) {\n const { buttonRef, isScrolled, table, tableMeta } = props;\n const { texts } = useLocalization();\n\n const temporaryRows = tableMeta.editing.temporaryRows as TType[];\n const temporaryRowId: string = temporaryRows[0]?.[tableMeta.rowIdentityAccessor as string] ?? '';\n\n const isDisabled =\n !!table.getState().globalFilter ||\n !!table.getState().columnFilters?.length ||\n (!!temporaryRowId && !!tableMeta.editing.hasRowErrors(temporaryRowId));\n const isSaving = !!temporaryRowId && tableMeta.editing.getRowStatus(temporaryRowId) === 'saving';\n\n const handleCreate = async () => {\n if (isDisabled) {\n return;\n }\n\n await tableMeta.editing.createRow(table);\n };\n const shortcut = { key: 'Enter', meta: true };\n\n let tooltip;\n\n if (isSaving) {\n tooltip = texts.table3.editing.buttons.create.saving;\n } else if (isDisabled) {\n tooltip = texts.table3.editing.buttons.create.disabled;\n } else {\n tooltip = <Shortcut keys={shortcut} />;\n }\n\n const className = clsx('group/row border-grey-300 !sticky z-[21]', {\n 'bottom-10': tableMeta.footer.isEnabled,\n 'bottom-0': !tableMeta.footer.isEnabled,\n 'border-b': !isScrolled,\n });\n\n return (\n <tr data-row-create className={className} tabIndex={-1}>\n <td className=\"!bg-grey-50 col-span-full !border-b-0 !px-1\">\n <Button\n appearance=\"transparent\"\n className=\"group-hover:bg-grey-200 sticky left-[4px]\"\n disabled={isDisabled}\n onClick={handleCreate}\n ref={buttonRef}\n shortcut={shortcut}\n tooltip={tooltip}>\n <Icon name=\"circle-plus\" />\n {texts.table3.editing.buttons.create.label}\n </Button>\n </td>\n </tr>\n );\n}\n"],"names":["CreateNewRow","props","buttonRef","isScrolled","table","tableMeta","texts","useLocalization","temporaryRows","editing","temporaryRowId","_temporaryRows$0$tabl","_temporaryRows$","rowIdentityAccessor","isDisabled","getState","globalFilter","_table$getState$colum","columnFilters","length","hasRowErrors","isSaving","getRowStatus","handleCreate","Promise","resolve","createRow","then","e","reject","shortcut","key","meta","tooltip","table3","buttons","create","saving","disabled","React","Shortcut","keys","className","clsx","footer","isEnabled","tabIndex","Button","appearance","onClick","ref","Icon","name","label"],"mappings":";;;;;;;SAiBgBA,YAAYA,CAAkBC,KAA+B;;EACzE,MAAM;IAAEC,SAAS;IAAEC,UAAU;IAAEC,KAAK;IAAEC;GAAW,GAAGJ,KAAK;EACzD,MAAM;IAAEK;GAAO,GAAGC,eAAe,EAAE;EAEnC,MAAMC,aAAa,GAAGH,SAAS,CAACI,OAAO,CAACD,aAAwB;EAChE,MAAME,cAAc,IAAAC,qBAAA,IAAAC,eAAA,GAAWJ,aAAa,CAAC,CAAC,CAAC,cAAAI,eAAA,uBAAhBA,eAAA,CAAmBP,SAAS,CAACQ,mBAA6B,CAAC,cAAAF,qBAAA,cAAAA,qBAAA,GAAI,EAAE;EAEhG,MAAMG,UAAU,GACZ,CAAC,CAACV,KAAK,CAACW,QAAQ,EAAE,CAACC,YAAY,IAC/B,CAAC,GAAAC,qBAAA,GAACb,KAAK,CAACW,QAAQ,EAAE,CAACG,aAAa,cAAAD,qBAAA,eAA9BA,qBAAA,CAAgCE,MAAM,KACvC,CAAC,CAACT,cAAc,IAAI,CAAC,CAACL,SAAS,CAACI,OAAO,CAACW,YAAY,CAACV,cAAc,CAAE;EAC1E,MAAMW,QAAQ,GAAG,CAAC,CAACX,cAAc,IAAIL,SAAS,CAACI,OAAO,CAACa,YAAY,CAACZ,cAAc,CAAC,KAAK,QAAQ;EAEhG,MAAMa,YAAY;IAAA;MACd,IAAIT,UAAU,EAAE;QACZ,OAAAU,OAAA,CAAAC,OAAA;;MACH,OAAAD,OAAA,CAAAC,OAAA,CAEKpB,SAAS,CAACI,OAAO,CAACiB,SAAS,CAACtB,KAAK,CAAC,EAAAuB,IAAA;KAC3C,QAAAC,CAAA;MAAA,OAAAJ,OAAA,CAAAK,MAAA,CAAAD,CAAA;;;EACD,MAAME,QAAQ,GAAG;IAAEC,GAAG,EAAE,OAAO;IAAEC,IAAI,EAAE;GAAM;EAE7C,IAAIC,OAAO;EAEX,IAAIZ,QAAQ,EAAE;IACVY,OAAO,GAAG3B,KAAK,CAAC4B,MAAM,CAACzB,OAAO,CAAC0B,OAAO,CAACC,MAAM,CAACC,MAAM;GACvD,MAAM,IAAIvB,UAAU,EAAE;IACnBmB,OAAO,GAAG3B,KAAK,CAAC4B,MAAM,CAACzB,OAAO,CAAC0B,OAAO,CAACC,MAAM,CAACE,QAAQ;GACzD,MAAM;IACHL,OAAO,gBAAGM,6BAACC,QAAQ;MAACC,IAAI,EAAEX;MAAY;;EAG1C,MAAMY,SAAS,GAAGC,EAAI,CAAC,0CAA0C,EAAE;IAC/D,WAAW,EAAEtC,SAAS,CAACuC,MAAM,CAACC,SAAS;IACvC,UAAU,EAAE,CAACxC,SAAS,CAACuC,MAAM,CAACC,SAAS;IACvC,UAAU,EAAE,CAAC1C;GAChB,CAAC;EAEF,oBACIoC;;IAAoBG,SAAS,EAAEA,SAAS;IAAEI,QAAQ,EAAE,CAAC;kBACjDP;IAAIG,SAAS,EAAC;kBACVH,6BAACQ,MAAM;IACHC,UAAU,EAAC,aAAa;IACxBN,SAAS,EAAC,2CAA2C;IACrDJ,QAAQ,EAAExB,UAAU;IACpBmC,OAAO,EAAE1B,YAAY;IACrB2B,GAAG,EAAEhD,SAAS;IACd4B,QAAQ,EAAEA,QAAQ;IAClBG,OAAO,EAAEA;kBACTM,6BAACY,IAAI;IAACC,IAAI,EAAC;IAAgB,EAC1B9C,KAAK,CAAC4B,MAAM,CAACzB,OAAO,CAAC0B,OAAO,CAACC,MAAM,CAACiB,KAAK,CACrC,CACR,CACJ;AAEb;;;;"}
@@ -8,6 +8,7 @@ import { RENDERERS } from '../../../useTable3.js';
8
8
  function TemporaryRow(props) {
9
9
  const {
10
10
  createRowButtonRef,
11
+ isScrolled,
11
12
  table,
12
13
  tableMeta,
13
14
  tableRef
@@ -70,10 +71,9 @@ function TemporaryRow(props) {
70
71
  }
71
72
  }
72
73
  };
73
- const isScrolled = tableRef.current ? tableRef.current.scrollHeight > tableRef.current.clientHeight : false;
74
- const className = cn('group/row border-grey-300 !sticky z-[22]', {
75
- 'bottom-[calc(5rem_+_3px)] data-[row-editing-move]:bottom-[calc(5rem_+_2px)]': tableMeta.footer.isEnabled,
76
- 'bottom-[calc(2.5rem_+_3px)] data-[row-editing-move]:bottom-[calc(2.5rem_+_2px)]': !tableMeta.footer.isEnabled,
74
+ const className = cn('group/row border-grey-300 !sticky z-[22] print:hidden', {
75
+ 'bottom-[calc(5rem_+_2px)] data-[row-editing-move]:bottom-[calc(5rem_+_2px)]': tableMeta.footer.isEnabled,
76
+ 'bottom-[calc(2.5rem_+_2px)] data-[row-editing-move]:bottom-[calc(2.5rem_+_2px)]': !tableMeta.footer.isEnabled,
77
77
  'border-t-2 shadow-[0px_-5px_20px_0px_rgba(0,0,0,0.1)] [&>td]:!border-b-0': isScrolled
78
78
  });
79
79
  return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, table.getBottomRows().map(row => (/*#__PURE__*/React__default.createElement(Row, {
@@ -87,8 +87,9 @@ function TemporaryRow(props) {
87
87
  className: className,
88
88
  onKeyDown: handleKeyDown,
89
89
  onKeyDownCapture: handleKeyDownCapture,
90
- // Row actions should only be hidden on temporary rows when editing is turned off
91
- hideRowActions: !tableMeta.editing.isEditing
90
+ hideInternalColumns: true,
91
+ hideRowActions: !tableMeta.editing.isEditing,
92
+ skipPageLoading: true
92
93
  }))));
93
94
  }
94
95
 
@@ -1 +1 @@
1
- {"version":3,"file":"TemporaryRow.js","sources":["../../../../../../../../../../src/components/Table3/components/Row/Editing/TemporaryRow.tsx"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, TableMeta as ReactTableMeta } from '@tanstack/react-table';\nimport clsx from 'clsx';\nimport { Row } from '../../../../../primitives/Table/Core/components/Row/Row';\nimport { RENDERERS } from '../../../useTable3';\nimport { isElementTriggeredFromContainer } from '../../../../../utils/dom';\nimport { TableRef } from '../../../../../primitives/Table/types';\nimport { TEMPORARY_ROW_ID_PREFIX } from '../../../util/editing';\n\ntype TemporaryRowProps<TType = unknown> = {\n createRowButtonRef: React.RefObject<HTMLButtonElement>;\n table: ReactTable<TType>;\n tableMeta: ReactTableMeta<TType>;\n tableRef: React.RefObject<TableRef>;\n};\n\nexport function TemporaryRow<TType = unknown>(props: TemporaryRowProps<TType>) {\n const { createRowButtonRef, table, tableMeta, tableRef } = props;\n\n const handleKeyDown = async (event: React.KeyboardEvent<HTMLTableRowElement>) => {\n if (event.key === 'ArrowDown') {\n event.preventDefault();\n\n if (!isElementTriggeredFromContainer(event.target as Element, event.currentTarget)) {\n const saved = await tableMeta.editing.saveChanges(table);\n\n if (saved) {\n createRowButtonRef.current?.focus();\n }\n }\n } else if (event.key === 'ArrowUp') {\n event.preventDefault();\n event.stopPropagation();\n\n if (tableRef.current) {\n const availableRows = Array.from(\n tableRef.current.querySelectorAll(`tbody tr:not([data-row-id^='${TEMPORARY_ROW_ID_PREFIX}'])`) ?? []\n );\n\n const footerHeight = tableRef.current.querySelector('tfoot')?.getBoundingClientRect().height ?? 0;\n const newRowHeight = event.currentTarget.getBoundingClientRect().height;\n const visibleHeight = tableRef.current.clientHeight - footerHeight - newRowHeight;\n const tableTopOffset = tableRef.current.getBoundingClientRect().top;\n\n let nextRowIndex;\n\n // iterate available rows in reverse order, since we're working at the bottom\n for (let index = availableRows.length - 1; index >= 0; index--) {\n const rowRect = availableRows[index].getBoundingClientRect();\n const topPlusHalfRow = rowRect.top + rowRect.height / 2;\n\n if (topPlusHalfRow - tableTopOffset <= visibleHeight) {\n nextRowIndex = index;\n break;\n }\n }\n\n if (nextRowIndex) {\n tableMeta.rowActive.setRowActiveIndex(\n Number(availableRows[nextRowIndex < 0 ? 0 : nextRowIndex].getAttribute('data-row-index'))\n );\n }\n }\n }\n };\n\n const handleKeyDownCapture = (event: React.KeyboardEvent<HTMLTableRowElement>) => {\n if (event.key === 'ArrowLeft' && tableMeta.editing.lastFocusedCellIndex === 0) {\n event.preventDefault();\n event.stopPropagation();\n } else if (event.key === 'ArrowRight' && tableMeta.editing.lastFocusedCellIndex) {\n if (tableMeta.editing.lastFocusedCellIndex === table.getVisibleFlatColumns().length - 1) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n };\n\n const isScrolled = tableRef.current ? tableRef.current.scrollHeight > tableRef.current.clientHeight : false;\n\n const className = clsx('group/row border-grey-300 !sticky z-[22]', {\n 'bottom-[calc(5rem_+_3px)] data-[row-editing-move]:bottom-[calc(5rem_+_2px)]': tableMeta.footer.isEnabled,\n 'bottom-[calc(2.5rem_+_3px)] data-[row-editing-move]:bottom-[calc(2.5rem_+_2px)]': !tableMeta.footer.isEnabled,\n 'border-t-2 shadow-[0px_-5px_20px_0px_rgba(0,0,0,0.1)] [&>td]:!border-b-0': isScrolled,\n });\n\n return (\n <>\n {table.getBottomRows().map(row => (\n <Row<TType>\n key={row.id}\n cellRenderer={RENDERERS.cell}\n index={tableMeta.length}\n measureRow={() => null}\n renderer={RENDERERS.row}\n row={row}\n table={table}\n className={className}\n onKeyDown={handleKeyDown}\n onKeyDownCapture={handleKeyDownCapture}\n // Row actions should only be hidden on temporary rows when editing is turned off\n hideRowActions={!tableMeta.editing.isEditing}\n />\n ))}\n </>\n );\n}\n"],"names":["TemporaryRow","props","createRowButtonRef","table","tableMeta","tableRef","handleKeyDown","event","key","preventDefault","_temp","isElementTriggeredFromContainer","target","currentTarget","Promise","resolve","editing","saveChanges","then","saved","_createRowButtonRef$c","current","focus","stopPropagation","_tableRef$current$que","_tableRef$current$que2","_tableRef$current$que3","availableRows","Array","from","querySelectorAll","TEMPORARY_ROW_ID_PREFIX","footerHeight","querySelector","getBoundingClientRect","height","newRowHeight","visibleHeight","clientHeight","tableTopOffset","top","nextRowIndex","index","length","rowRect","topPlusHalfRow","rowActive","setRowActiveIndex","Number","getAttribute","_temp2","e","reject","handleKeyDownCapture","lastFocusedCellIndex","getVisibleFlatColumns","isScrolled","scrollHeight","className","clsx","footer","isEnabled","React","getBottomRows","map","row","Row","id","cellRenderer","RENDERERS","cell","measureRow","renderer","onKeyDown","onKeyDownCapture","hideRowActions","isEditing"],"mappings":"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"}
1
+ {"version":3,"file":"TemporaryRow.js","sources":["../../../../../../../../../../src/components/Table3/components/Row/Editing/TemporaryRow.tsx"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, TableMeta as ReactTableMeta } from '@tanstack/react-table';\nimport clsx from 'clsx';\nimport { Row } from '../../../../../primitives/Table/Core/components/Row/Row';\nimport { RENDERERS } from '../../../useTable3';\nimport { isElementTriggeredFromContainer } from '../../../../../utils/dom';\nimport { TableRef } from '../../../../../primitives/Table/types';\nimport { TEMPORARY_ROW_ID_PREFIX } from '../../../util/editing';\n\ntype TemporaryRowProps<TType = unknown> = {\n createRowButtonRef: React.RefObject<HTMLButtonElement>;\n isScrolled: boolean;\n table: ReactTable<TType>;\n tableMeta: ReactTableMeta<TType>;\n tableRef: React.RefObject<TableRef>;\n};\n\nexport function TemporaryRow<TType = unknown>(props: TemporaryRowProps<TType>) {\n const { createRowButtonRef, isScrolled, table, tableMeta, tableRef } = props;\n\n const handleKeyDown = async (event: React.KeyboardEvent<HTMLTableRowElement>) => {\n if (event.key === 'ArrowDown') {\n event.preventDefault();\n\n if (!isElementTriggeredFromContainer(event.target as Element, event.currentTarget)) {\n const saved = await tableMeta.editing.saveChanges(table);\n\n if (saved) {\n createRowButtonRef.current?.focus();\n }\n }\n } else if (event.key === 'ArrowUp') {\n event.preventDefault();\n event.stopPropagation();\n\n if (tableRef.current) {\n const availableRows = Array.from(\n tableRef.current.querySelectorAll(`tbody tr:not([data-row-id^='${TEMPORARY_ROW_ID_PREFIX}'])`) ?? []\n );\n\n const footerHeight = tableRef.current.querySelector('tfoot')?.getBoundingClientRect().height ?? 0;\n const newRowHeight = event.currentTarget.getBoundingClientRect().height;\n const visibleHeight = tableRef.current.clientHeight - footerHeight - newRowHeight;\n const tableTopOffset = tableRef.current.getBoundingClientRect().top;\n\n let nextRowIndex;\n\n // iterate available rows in reverse order, since we're working at the bottom\n for (let index = availableRows.length - 1; index >= 0; index--) {\n const rowRect = availableRows[index].getBoundingClientRect();\n const topPlusHalfRow = rowRect.top + rowRect.height / 2;\n\n if (topPlusHalfRow - tableTopOffset <= visibleHeight) {\n nextRowIndex = index;\n break;\n }\n }\n\n if (nextRowIndex) {\n tableMeta.rowActive.setRowActiveIndex(\n Number(availableRows[nextRowIndex < 0 ? 0 : nextRowIndex].getAttribute('data-row-index'))\n );\n }\n }\n }\n };\n\n const handleKeyDownCapture = (event: React.KeyboardEvent<HTMLTableRowElement>) => {\n if (event.key === 'ArrowLeft' && tableMeta.editing.lastFocusedCellIndex === 0) {\n event.preventDefault();\n event.stopPropagation();\n } else if (event.key === 'ArrowRight' && tableMeta.editing.lastFocusedCellIndex) {\n if (tableMeta.editing.lastFocusedCellIndex === table.getVisibleFlatColumns().length - 1) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n };\n\n const className = clsx('group/row border-grey-300 !sticky z-[22] print:hidden', {\n 'bottom-[calc(5rem_+_2px)] data-[row-editing-move]:bottom-[calc(5rem_+_2px)]': tableMeta.footer.isEnabled,\n 'bottom-[calc(2.5rem_+_2px)] data-[row-editing-move]:bottom-[calc(2.5rem_+_2px)]': !tableMeta.footer.isEnabled,\n 'border-t-2 shadow-[0px_-5px_20px_0px_rgba(0,0,0,0.1)] [&>td]:!border-b-0': isScrolled,\n });\n\n return (\n <>\n {table.getBottomRows().map(row => (\n <Row<TType>\n key={row.id}\n cellRenderer={RENDERERS.cell}\n index={tableMeta.length}\n measureRow={() => null}\n renderer={RENDERERS.row}\n row={row}\n table={table}\n className={className}\n onKeyDown={handleKeyDown}\n onKeyDownCapture={handleKeyDownCapture}\n hideInternalColumns\n hideRowActions={!tableMeta.editing.isEditing}\n skipPageLoading\n />\n ))}\n </>\n );\n}\n"],"names":["TemporaryRow","props","createRowButtonRef","isScrolled","table","tableMeta","tableRef","handleKeyDown","event","key","preventDefault","_temp","isElementTriggeredFromContainer","target","currentTarget","Promise","resolve","editing","saveChanges","then","saved","_createRowButtonRef$c","current","focus","stopPropagation","_tableRef$current$que","_tableRef$current$que2","_tableRef$current$que3","availableRows","Array","from","querySelectorAll","TEMPORARY_ROW_ID_PREFIX","footerHeight","querySelector","getBoundingClientRect","height","newRowHeight","visibleHeight","clientHeight","tableTopOffset","top","nextRowIndex","index","length","rowRect","topPlusHalfRow","rowActive","setRowActiveIndex","Number","getAttribute","_temp2","e","reject","handleKeyDownCapture","lastFocusedCellIndex","getVisibleFlatColumns","className","clsx","footer","isEnabled","React","getBottomRows","map","row","Row","id","cellRenderer","RENDERERS","cell","measureRow","renderer","onKeyDown","onKeyDownCapture","hideInternalColumns","hideRowActions","isEditing","skipPageLoading"],"mappings":"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"}
@@ -16,7 +16,11 @@ function Editing(props) {
16
16
  const ref = React__default.useRef(null);
17
17
  const tableMeta = table.options.meta;
18
18
  const handleChange = enabled => {
19
+ var _tableMeta$onEvent;
19
20
  tableMeta.editing.toggleEditing(enabled, table, scrollToIndex);
21
+ (_tableMeta$onEvent = tableMeta.onEvent) === null || _tableMeta$onEvent === void 0 ? void 0 : _tableMeta$onEvent.call(tableMeta, 'editing-mode', {
22
+ enabled
23
+ });
20
24
  };
21
25
  const tooltip = /*#__PURE__*/React__default.createElement(React__default.Fragment, null, texts.table3.editing.buttons.edit.tooltip, /*#__PURE__*/React__default.createElement(Shortcut, {
22
26
  className: "ml-2",
@@ -1 +1 @@
1
- {"version":3,"file":"Editing.js","sources":["../../../../../../../../../../src/components/Table3/components/Toolbar/Editing/Editing.tsx"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, TableMeta as ReactTableMeta } from '@tanstack/react-table';\nimport { useLocalization } from '../../../../Provider/Localization';\nimport { Tooltip } from '../../../../Tooltip/Tooltip';\nimport { ModeSwitch } from '../../../../ModeSwitch/ModeSwitch';\nimport { Shortcut } from '../../../../Shortcut/Shortcut';\nimport { shortcut } from '../../../util/editing';\n\ntype EditingProps<TType = unknown> = React.HTMLAttributes<HTMLButtonElement> & {\n scrollToIndex: any;\n table: ReactTable<TType>;\n};\n\nexport function Editing<TType = unknown>(props: EditingProps<TType>) {\n const { scrollToIndex, table } = props;\n const { texts } = useLocalization();\n const ref = React.useRef<HTMLButtonElement>(null);\n const tableMeta = table.options.meta as ReactTableMeta<TType>;\n\n const handleChange = (enabled: boolean) => {\n tableMeta.editing.toggleEditing(enabled, table, scrollToIndex);\n };\n\n const tooltip = (\n <>\n {texts.table3.editing.buttons.edit.tooltip}\n <Shortcut className=\"ml-2\" keys={shortcut} />\n </>\n );\n\n return (\n <Tooltip title={tooltip}>\n <ModeSwitch data-table=\"editing-toggle\" checked={tableMeta.editing.isEditing} onChange={handleChange} ref={ref} />\n </Tooltip>\n );\n}\n"],"names":["Editing","props","scrollToIndex","table","texts","useLocalization","ref","React","useRef","tableMeta","options","meta","handleChange","enabled","editing","toggleEditing","tooltip","table3","buttons","edit","Shortcut","className","keys","shortcut","Tooltip","title","ModeSwitch","checked","isEditing","onChange"],"mappings":";;;;;;;SAagBA,OAAOA,CAAkBC,KAA0B;EAC/D,MAAM;IAAEC,aAAa;IAAEC;GAAO,GAAGF,KAAK;EACtC,MAAM;IAAEG;GAAO,GAAGC,eAAe,EAAE;EACnC,MAAMC,GAAG,GAAGC,cAAK,CAACC,MAAM,CAAoB,IAAI,CAAC;EACjD,MAAMC,SAAS,GAAGN,KAAK,CAACO,OAAO,CAACC,IAA6B;EAE7D,MAAMC,YAAY,GAAIC,OAAgB;IAClCJ,SAAS,CAACK,OAAO,CAACC,aAAa,CAACF,OAAO,EAAEV,KAAK,EAAED,aAAa,CAAC;GACjE;EAED,MAAMc,OAAO,gBACTT,4DACKH,KAAK,CAACa,MAAM,CAACH,OAAO,CAACI,OAAO,CAACC,IAAI,CAACH,OAAO,eAC1CT,6BAACa,QAAQ;IAACC,SAAS,EAAC,MAAM;IAACC,IAAI,EAAEC;IAAY,CAEpD;EAED,oBACIhB,6BAACiB,OAAO;IAACC,KAAK,EAAET;kBACZT,6BAACmB,UAAU;kBAAY,gBAAgB;IAACC,OAAO,EAAElB,SAAS,CAACK,OAAO,CAACc,SAAS;IAAEC,QAAQ,EAAEjB,YAAY;IAAEN,GAAG,EAAEA;IAAO,CAC5G;AAElB;;;;"}
1
+ {"version":3,"file":"Editing.js","sources":["../../../../../../../../../../src/components/Table3/components/Toolbar/Editing/Editing.tsx"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, TableMeta as ReactTableMeta } from '@tanstack/react-table';\nimport { useLocalization } from '../../../../Provider/Localization';\nimport { Tooltip } from '../../../../Tooltip/Tooltip';\nimport { ModeSwitch } from '../../../../ModeSwitch/ModeSwitch';\nimport { Shortcut } from '../../../../Shortcut/Shortcut';\nimport { shortcut } from '../../../util/editing';\n\ntype EditingProps<TType = unknown> = React.HTMLAttributes<HTMLButtonElement> & {\n scrollToIndex: any;\n table: ReactTable<TType>;\n};\n\nexport function Editing<TType = unknown>(props: EditingProps<TType>) {\n const { scrollToIndex, table } = props;\n const { texts } = useLocalization();\n const ref = React.useRef<HTMLButtonElement>(null);\n const tableMeta = table.options.meta as ReactTableMeta<TType>;\n\n const handleChange = (enabled: boolean) => {\n tableMeta.editing.toggleEditing(enabled, table, scrollToIndex);\n tableMeta.onEvent?.('editing-mode', { enabled });\n };\n\n const tooltip = (\n <>\n {texts.table3.editing.buttons.edit.tooltip}\n <Shortcut className=\"ml-2\" keys={shortcut} />\n </>\n );\n\n return (\n <Tooltip title={tooltip}>\n <ModeSwitch data-table=\"editing-toggle\" checked={tableMeta.editing.isEditing} onChange={handleChange} ref={ref} />\n </Tooltip>\n );\n}\n"],"names":["Editing","props","scrollToIndex","table","texts","useLocalization","ref","React","useRef","tableMeta","options","meta","handleChange","enabled","editing","toggleEditing","_tableMeta$onEvent","onEvent","call","tooltip","table3","buttons","edit","Shortcut","className","keys","shortcut","Tooltip","title","ModeSwitch","checked","isEditing","onChange"],"mappings":";;;;;;;SAagBA,OAAOA,CAAkBC,KAA0B;EAC/D,MAAM;IAAEC,aAAa;IAAEC;GAAO,GAAGF,KAAK;EACtC,MAAM;IAAEG;GAAO,GAAGC,eAAe,EAAE;EACnC,MAAMC,GAAG,GAAGC,cAAK,CAACC,MAAM,CAAoB,IAAI,CAAC;EACjD,MAAMC,SAAS,GAAGN,KAAK,CAACO,OAAO,CAACC,IAA6B;EAE7D,MAAMC,YAAY,GAAIC,OAAgB;;IAClCJ,SAAS,CAACK,OAAO,CAACC,aAAa,CAACF,OAAO,EAAEV,KAAK,EAAED,aAAa,CAAC;IAC9D,CAAAc,kBAAA,GAAAP,SAAS,CAACQ,OAAO,cAAAD,kBAAA,uBAAjBA,kBAAA,CAAAE,IAAA,CAAAT,SAAS,EAAW,cAAc,EAAE;MAAEI;KAAS,CAAC;GACnD;EAED,MAAMM,OAAO,gBACTZ,4DACKH,KAAK,CAACgB,MAAM,CAACN,OAAO,CAACO,OAAO,CAACC,IAAI,CAACH,OAAO,eAC1CZ,6BAACgB,QAAQ;IAACC,SAAS,EAAC,MAAM;IAACC,IAAI,EAAEC;IAAY,CAEpD;EAED,oBACInB,6BAACoB,OAAO;IAACC,KAAK,EAAET;kBACZZ,6BAACsB,UAAU;kBAAY,gBAAgB;IAACC,OAAO,EAAErB,SAAS,CAACK,OAAO,CAACiB,SAAS;IAAEC,QAAQ,EAAEpB,YAAY;IAAEN,GAAG,EAAEA;IAAO,CAC5G;AAElB;;;;"}
@@ -18,6 +18,7 @@ function reducer(state, action) {
18
18
  {
19
19
  const {
20
20
  columnId,
21
+ index,
21
22
  row,
22
23
  value
23
24
  } = payload;
@@ -27,7 +28,8 @@ function reducer(state, action) {
27
28
  ...state.changes,
28
29
  rows: setWith(state.changes.rows, `${rowId}.${columnId}`, value, Object),
29
30
  originals: setWith(state.changes.originals, rowId, row, Object)
30
- }
31
+ },
32
+ indexes: setWith(state.indexes, rowId, index, Object)
31
33
  };
32
34
  }
33
35
  case 'removeCellValue':
@@ -61,6 +63,7 @@ function reducer(state, action) {
61
63
  {
62
64
  const {
63
65
  cellErrors,
66
+ index,
64
67
  moveReasons,
65
68
  original,
66
69
  value
@@ -75,7 +78,8 @@ function reducer(state, action) {
75
78
  moveReasons: setWith(state.changes.moveReasons, rowId, moveReasons !== null && moveReasons !== void 0 ? moveReasons : state.changes.moveReasons[rowId], Object),
76
79
  // status can be undefined, so don't use ??
77
80
  status: setWith(state.changes.status, rowId, undefined, Object)
78
- }
81
+ },
82
+ indexes: setWith(state.indexes, rowId, index, Object)
79
83
  };
80
84
  }
81
85
  case 'removeRow':
@@ -93,6 +97,7 @@ function reducer(state, action) {
93
97
  originals: omit(state.changes.originals, rowId),
94
98
  status: omit(state.changes.status, rowId)
95
99
  },
100
+ indexes: omit(state.indexes, rowId),
96
101
  temporaryRows: state.temporaryRows.filter(row => row[rowIdentityAccessor] !== rowId)
97
102
  };
98
103
  }
@@ -122,9 +127,10 @@ function reducer(state, action) {
122
127
  }
123
128
  };
124
129
  }
125
- case 'createRow':
130
+ case 'insertTemporaryRow':
126
131
  {
127
132
  const {
133
+ index,
128
134
  value
129
135
  } = payload;
130
136
  return {
@@ -134,14 +140,36 @@ function reducer(state, action) {
134
140
  ...state.changes,
135
141
  rows: setWith(state.changes.rows, rowId, value, Object),
136
142
  originals: setWith(state.changes.originals, rowId, value, Object)
137
- }
143
+ },
144
+ indexes: setWith(state.indexes, rowId, index, Object)
138
145
  };
139
146
  }
140
147
  default:
141
148
  return state;
142
149
  }
143
150
  }
144
- function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, validator) {
151
+ function usePendingChangesState(handleSave, handleChange, handleDiscard, rowIdentityAccessor, validator) {
152
+ const discardChanges = function (rowId, table) {
153
+ try {
154
+ // remove any new rows from pinned state before discarding them
155
+ table.resetRowPinning(true);
156
+ dispatch({
157
+ type: 'removeRow',
158
+ rowId,
159
+ payload: {
160
+ rowIdentityAccessor
161
+ }
162
+ });
163
+ const _temp8 = function () {
164
+ if (typeof handleDiscard === 'function') {
165
+ return Promise.resolve(handleDiscard()).then(function () {});
166
+ }
167
+ }();
168
+ return Promise.resolve(_temp8 && _temp8.then ? _temp8.then(function () {}) : void 0);
169
+ } catch (e) {
170
+ return Promise.reject(e);
171
+ }
172
+ };
145
173
  const saveChanges = function (table, rowId = undefined) {
146
174
  try {
147
175
  let _exit = false;
@@ -154,35 +182,38 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
154
182
  [rowId]: state.changes.rows[rowId]
155
183
  } : state.changes.rows;
156
184
  let completed = true;
157
- const _temp9 = _forOf(Object.keys(changes), function (rowId) {
185
+ const _temp7 = _forOf(Object.keys(changes), function (rowId) {
158
186
  const status = getRowStatus(rowId);
159
187
  return _catch(function () {
160
- function _temp8(_result) {
188
+ var _changes$rowId;
189
+ function _temp6(_result) {
161
190
  return _exit ? _result : Promise.resolve(handleSave(changeSet)).then(function () {
162
191
  // cleanup changes, we don't need them after saving
163
- discardChanges(rowId, table);
164
- // show the saved status, then remove it after a delay
165
- setRowStatus(rowId, 'saved');
166
- setTimeout(() => {
167
- setRowStatus(rowId, undefined);
168
- }, DELAY_BEFORE_REMOVING_SAVE_STATUS);
192
+ return Promise.resolve(discardChanges(rowId, table)).then(function () {
193
+ // show the saved status, then remove it after a delay
194
+ setRowStatus(rowId, 'saved');
195
+ setTimeout(() => {
196
+ setRowStatus(rowId, undefined);
197
+ }, DELAY_BEFORE_REMOVING_SAVE_STATUS);
198
+ });
169
199
  });
170
200
  }
201
+ const rowChanges = (_changes$rowId = changes[rowId]) !== null && _changes$rowId !== void 0 ? _changes$rowId : {};
171
202
  // don't try to save if - already saving, or there are known errors
172
- if (status === 'saving' || status === 'errored') {
203
+ if (!Object.keys(rowChanges).length || status === 'saving' || status === 'errored') {
173
204
  return;
174
205
  }
175
206
  setRowStatus(rowId, 'saving');
176
207
  const changeSet = {
177
208
  ...state.changes.originals[rowId],
178
- ...changes[rowId]
209
+ ...rowChanges
179
210
  };
180
211
  // if we had to create a temporary id, delete it first - it's our data, not theirs
181
212
  if (isTemporaryRow(changeSet[rowIdentityAccessor])) {
182
213
  delete changeSet[rowIdentityAccessor];
183
214
  }
184
215
  // re-run validation, maybe a cell is already invalid but has never been blurred
185
- const _temp7 = function () {
216
+ const _temp5 = function () {
186
217
  if (validator) {
187
218
  return Promise.resolve(validator(changeSet)).then(function (errors) {
188
219
  if (errors && Object.keys(errors).length) {
@@ -191,7 +222,7 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
191
222
  });
192
223
  }
193
224
  }();
194
- return _temp7 && _temp7.then ? _temp7.then(_temp8) : _temp8(_temp7); // send new data to the server
225
+ return _temp5 && _temp5.then ? _temp5.then(_temp6) : _temp6(_temp5); // send new data to the server
195
226
  }, function (error) {
196
227
  var _error$response;
197
228
  if (error instanceof ReferenceError || error instanceof TypeError || (error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : _error$response.status) >= 500) {
@@ -231,18 +262,18 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
231
262
  }, function () {
232
263
  return _exit;
233
264
  });
234
- return Promise.resolve(_temp9 && _temp9.then ? _temp9.then(function (_result3) {
265
+ return Promise.resolve(_temp7 && _temp7.then ? _temp7.then(function (_result3) {
235
266
  return _exit ? _result3 : completed;
236
- }) : _exit ? _temp9 : completed);
267
+ }) : _exit ? _temp7 : completed);
237
268
  } catch (e) {
238
269
  return Promise.reject(e);
239
270
  }
240
271
  };
241
- const onCellChanged = function (cell, rowIndex, shouldRunUpdaters = true) {
272
+ const onCellChanged = function (cell, rowIndex, nextValue, shouldRunUpdaters = true) {
242
273
  try {
243
- function _temp6() {
274
+ function _temp4() {
244
275
  var _state$changes$errors11;
245
- function _temp4() {
276
+ function _temp2() {
246
277
  // only set errors and move reasons for the cells we're currently acting on
247
278
  // why? because the UX is not good if we set them for cells the user hasn't touched yet
248
279
  const cellsToActOn = [cell.column.id, ...Object.keys(updatesForOtherCells)];
@@ -273,6 +304,7 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
273
304
  rowId: cell.row.id,
274
305
  payload: {
275
306
  cellErrors: nextCellErrors,
307
+ index: rowIndex,
276
308
  moveReasons: nextMoveReasons,
277
309
  value: nextChanges
278
310
  }
@@ -280,7 +312,7 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
280
312
  }
281
313
  // create a projection of the next state, so we can act against it
282
314
  const nextChanges = {
283
- ...state.changes.rows[cell.row.id],
315
+ ...changes,
284
316
  ...updatesForOtherCells
285
317
  };
286
318
  const nextMoveReasons = {
@@ -289,29 +321,35 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
289
321
  const nextCellErrors = {
290
322
  ...((_state$changes$errors11 = state.changes.errors[cell.row.id]) === null || _state$changes$errors11 === void 0 ? void 0 : _state$changes$errors11.cells)
291
323
  };
292
- // run validation
324
+ // run validation - if there are changes, and if there is an original stored
293
325
  let validationErrors = {};
294
- const _temp3 = function () {
295
- if (validator) {
326
+ const _temp = function () {
327
+ if (validator && Object.keys(nextChanges).length && state.changes.originals[cell.row.id]) {
328
+ // merge with the original so we get a full row
296
329
  const nextRowValue = {
297
330
  ...state.changes.originals[cell.row.id],
298
331
  ...changes,
299
332
  ...updatesForOtherCells
300
333
  };
301
- return Promise.resolve(validator(nextRowValue)).then(function (_validator2) {
302
- validationErrors = _validator2 !== null && _validator2 !== void 0 ? _validator2 : {};
334
+ return Promise.resolve(validator(nextRowValue)).then(function (_validator) {
335
+ validationErrors = _validator !== null && _validator !== void 0 ? _validator : {};
303
336
  });
304
337
  }
305
338
  }();
306
- return _temp3 && _temp3.then ? _temp3.then(_temp4) : _temp4(_temp3);
339
+ return _temp && _temp.then ? _temp.then(_temp2) : _temp2(_temp);
307
340
  }
308
- const changes = state.changes.rows[cell.row.id];
309
- if (!changes) {
341
+ const changes = nextValue !== undefined ? {
342
+ ...state.changes.rows[cell.row.id],
343
+ [cell.column.id]: nextValue
344
+ } : {
345
+ ...state.changes.rows[cell.row.id]
346
+ };
347
+ if (!Object.keys(changes).length) {
310
348
  return Promise.resolve();
311
349
  }
312
350
  let updatesForOtherCells = {};
313
351
  // run the updater handler if there is one, to see if there are any other cells to update
314
- const _temp5 = function () {
352
+ const _temp3 = function () {
315
353
  if (typeof handleChange === 'function' && shouldRunUpdaters) {
316
354
  const previousRowValue = {
317
355
  ...state.changes.originals[cell.row.id]
@@ -325,42 +363,11 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
325
363
  });
326
364
  }
327
365
  }();
328
- return Promise.resolve(_temp5 && _temp5.then ? _temp5.then(_temp6) : _temp6(_temp5));
366
+ return Promise.resolve(_temp3 && _temp3.then ? _temp3.then(_temp4) : _temp4(_temp3));
329
367
  } catch (e) {
330
368
  return Promise.reject(e);
331
369
  }
332
370
  }; // general
333
- // rows
334
- const setRowValue = function (rowId, original, value) {
335
- try {
336
- function _temp2() {
337
- dispatch({
338
- type: 'updateRow',
339
- rowId,
340
- payload: {
341
- cellErrors,
342
- original,
343
- value
344
- }
345
- });
346
- }
347
- let cellErrors;
348
- const _temp = function () {
349
- if (validator) {
350
- const row = {
351
- ...original,
352
- ...value
353
- };
354
- return Promise.resolve(validator(row)).then(function (_validator) {
355
- cellErrors = _validator !== null && _validator !== void 0 ? _validator : {};
356
- });
357
- }
358
- }();
359
- return Promise.resolve(_temp && _temp.then ? _temp.then(_temp2) : _temp2(_temp));
360
- } catch (e) {
361
- return Promise.reject(e);
362
- }
363
- };
364
371
  const localization = useLocalization();
365
372
  const [state, dispatch] = React__default.useReducer(reducer, {
366
373
  changes: {
@@ -370,8 +377,10 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
370
377
  originals: {},
371
378
  status: {}
372
379
  },
380
+ indexes: {},
373
381
  temporaryRows: []
374
382
  });
383
+ // rows
375
384
  function getRowValue(rowId) {
376
385
  var _state$changes$rows$r, _state$changes$rows;
377
386
  return (_state$changes$rows$r = (_state$changes$rows = state.changes.rows) === null || _state$changes$rows === void 0 ? void 0 : _state$changes$rows[rowId]) !== null && _state$changes$rows$r !== void 0 ? _state$changes$rows$r : undefined;
@@ -409,23 +418,24 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
409
418
  }
410
419
  });
411
420
  }
412
- function createRow(data) {
421
+ function insertTemporaryRow(data, rowIndex) {
413
422
  const newRowId = `${TEMPORARY_ROW_ID_PREFIX}${v4()}`;
414
423
  const value = {
415
424
  ...data,
416
425
  [rowIdentityAccessor]: newRowId
417
426
  };
418
427
  dispatch({
419
- type: 'createRow',
428
+ type: 'insertTemporaryRow',
420
429
  rowId: newRowId,
421
430
  payload: {
431
+ index: rowIndex,
422
432
  value
423
433
  }
424
434
  });
425
435
  return newRowId;
426
436
  }
427
437
  // cells
428
- function setCellValue(cell, value) {
438
+ function setCellValue(cell, rowIndex, value) {
429
439
  const rowId = cell.row.id;
430
440
  const columnId = cell.column.id;
431
441
  // update if the change is different to the original value
@@ -435,6 +445,7 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
435
445
  rowId,
436
446
  payload: {
437
447
  columnId,
448
+ index: rowIndex,
438
449
  row: cell.row.original,
439
450
  value
440
451
  }
@@ -467,6 +478,7 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
467
478
  }
468
479
  return rowsWithErrors.filter(hasRowErrorsShownInAlert).map(rowId => ({
469
480
  rowId,
481
+ index: state.indexes[rowId],
470
482
  changes: state.changes.rows[rowId],
471
483
  errors: state.changes.errors[rowId]
472
484
  }));
@@ -477,20 +489,8 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
477
489
  function hasChanges(rowId) {
478
490
  return rowId ? !!state.changes.rows[rowId] : !!Object.keys(state.changes.rows).length;
479
491
  }
480
- function discardChanges(rowId, table) {
481
- // remove any new rows from pinned state before discarding them
482
- table.resetRowPinning(true);
483
- dispatch({
484
- type: 'removeRow',
485
- rowId,
486
- payload: {
487
- rowIdentityAccessor
488
- }
489
- });
490
- }
491
492
  return {
492
493
  // row
493
- setRowValue,
494
494
  getRowValue,
495
495
  getRowMoveReason,
496
496
  hasRowErrors,
@@ -510,7 +510,7 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
510
510
  discardChanges,
511
511
  hasSaved,
512
512
  // new rows
513
- createRow,
513
+ insertTemporaryRow,
514
514
  temporaryRows: state.temporaryRows
515
515
  };
516
516
  }