@economic/taco 2.45.0-alpha.2 → 2.45.0-alpha.25

Sign up to get free protection for your applications and to get access to all the features.
Files changed (316) 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/Combobox/Combobox.d.ts +1 -1
  17. package/dist/components/Hanger/Hanger.d.ts +1 -0
  18. package/dist/components/Icon/components/Autopay.d.ts +3 -0
  19. package/dist/components/Icon/components/AutopayPaused.d.ts +3 -0
  20. package/dist/components/Icon/components/Experiment.d.ts +3 -0
  21. package/dist/components/Icon/components/Person.d.ts +3 -0
  22. package/dist/components/Icon/components/PersonSolid.d.ts +3 -0
  23. package/dist/components/Icon/components/Wallet.d.ts +3 -0
  24. package/dist/components/Icon/components/index.d.ts +1 -1
  25. package/dist/components/Input/Input.d.ts +1 -1
  26. package/dist/components/Listbox/util.d.ts +1 -1
  27. package/dist/components/Menu/components/Content.d.ts +1 -1
  28. package/dist/components/Menu/components/Item.d.ts +1 -1
  29. package/dist/components/Menu/components/Link.d.ts +1 -1
  30. package/dist/components/Menu/components/SubMenu.d.ts +1 -1
  31. package/dist/components/Navigation2/components/Link.d.ts +1 -1
  32. package/dist/components/RadioGroup/RadioGroup.d.ts +3 -3
  33. package/dist/components/Report/Report.d.ts +4 -2
  34. package/dist/components/SearchInput2/SearchInput2.d.ts +2 -0
  35. package/dist/components/Select/Select.d.ts +5 -19
  36. package/dist/components/Select2/components/Option.d.ts +4 -4
  37. package/dist/components/Select2/components/Search.d.ts +1 -1
  38. package/dist/components/Table3/Table3.d.ts +4 -5
  39. package/dist/components/Table3/components/Columns/Internal/EditingActionsMenu.d.ts +2 -2
  40. package/dist/components/Table3/components/Row/Editing/CreateNewRow.d.ts +1 -3
  41. package/dist/components/Table3/components/Row/Editing/TemporaryRow.d.ts +1 -0
  42. package/dist/components/Table3/features/useEditingState.d.ts +23 -18
  43. package/dist/components/Table3/features/useTableEditing.d.ts +24 -19
  44. package/dist/components/Table3/types.d.ts +2 -0
  45. package/dist/components/Table3/util/editing.d.ts +3 -0
  46. package/dist/components/Tag/Tag.d.ts +1 -1
  47. package/dist/esm/index.css +74 -12
  48. package/dist/esm/packages/taco/src/charts/components/Area/AreaChart.js +67 -0
  49. package/dist/esm/packages/taco/src/charts/components/Area/AreaChart.js.map +1 -0
  50. package/dist/esm/packages/taco/src/charts/components/Bar/BarChart.js +120 -0
  51. package/dist/esm/packages/taco/src/charts/components/Bar/BarChart.js.map +1 -0
  52. package/dist/esm/packages/taco/src/charts/components/Donut/ActiveShape.js +47 -0
  53. package/dist/esm/packages/taco/src/charts/components/Donut/ActiveShape.js.map +1 -0
  54. package/dist/esm/packages/taco/src/charts/components/Donut/CenteredLabel.js +27 -0
  55. package/dist/esm/packages/taco/src/charts/components/Donut/CenteredLabel.js.map +1 -0
  56. package/dist/esm/packages/taco/src/charts/components/Donut/DonutChart.js +170 -0
  57. package/dist/esm/packages/taco/src/charts/components/Donut/DonutChart.js.map +1 -0
  58. package/dist/esm/packages/taco/src/charts/components/Donut/Legend.js +165 -0
  59. package/dist/esm/packages/taco/src/charts/components/Donut/Legend.js.map +1 -0
  60. package/dist/esm/packages/taco/src/charts/components/Donut/util.js +5 -0
  61. package/dist/esm/packages/taco/src/charts/components/Donut/util.js.map +1 -0
  62. package/dist/esm/packages/taco/src/charts/components/Legend.js +146 -0
  63. package/dist/esm/packages/taco/src/charts/components/Legend.js.map +1 -0
  64. package/dist/esm/packages/taco/src/charts/components/Line/LineChart.js +65 -0
  65. package/dist/esm/packages/taco/src/charts/components/Line/LineChart.js.map +1 -0
  66. package/dist/esm/packages/taco/src/charts/components/ResponsiveContainer.js +10 -0
  67. package/dist/esm/packages/taco/src/charts/components/ResponsiveContainer.js.map +1 -0
  68. package/dist/esm/packages/taco/src/charts/components/Tooltip.js +44 -0
  69. package/dist/esm/packages/taco/src/charts/components/Tooltip.js.map +1 -0
  70. package/dist/esm/packages/taco/src/charts/utils/color.js +24 -0
  71. package/dist/esm/packages/taco/src/charts/utils/color.js.map +1 -0
  72. package/dist/esm/packages/taco/src/charts/utils/common.js +34 -0
  73. package/dist/esm/packages/taco/src/charts/utils/common.js.map +1 -0
  74. package/dist/esm/packages/taco/src/components/Accordion/Accordion.js +6 -14
  75. package/dist/esm/packages/taco/src/components/Accordion/Accordion.js.map +1 -1
  76. package/dist/esm/packages/taco/src/components/Alert/Alert.js +2 -0
  77. package/dist/esm/packages/taco/src/components/Alert/Alert.js.map +1 -1
  78. package/dist/esm/packages/taco/src/components/Badge/Badge.js +9 -6
  79. package/dist/esm/packages/taco/src/components/Badge/Badge.js.map +1 -1
  80. package/dist/esm/packages/taco/src/components/Banner/util.js +5 -0
  81. package/dist/esm/packages/taco/src/components/Banner/util.js.map +1 -1
  82. package/dist/esm/packages/taco/src/components/Button/Button.js +2 -1
  83. package/dist/esm/packages/taco/src/components/Button/Button.js.map +1 -1
  84. package/dist/esm/packages/taco/src/components/Button/util.js +1 -1
  85. package/dist/esm/packages/taco/src/components/Button/util.js.map +1 -1
  86. package/dist/esm/packages/taco/src/components/Card/Card.js +2 -2
  87. package/dist/esm/packages/taco/src/components/Card/Card.js.map +1 -1
  88. package/dist/esm/packages/taco/src/components/Checkbox/Checkbox.js +3 -2
  89. package/dist/esm/packages/taco/src/components/Checkbox/Checkbox.js.map +1 -1
  90. package/dist/esm/packages/taco/src/components/Combobox/Combobox.js.map +1 -1
  91. package/dist/esm/packages/taco/src/components/Combobox/useCombobox.js +18 -17
  92. package/dist/esm/packages/taco/src/components/Combobox/useCombobox.js.map +1 -1
  93. package/dist/esm/packages/taco/src/components/Datepicker/Datepicker.js +13 -0
  94. package/dist/esm/packages/taco/src/components/Datepicker/Datepicker.js.map +1 -1
  95. package/dist/esm/packages/taco/src/components/Datepicker/useDatepicker.js +10 -1
  96. package/dist/esm/packages/taco/src/components/Datepicker/useDatepicker.js.map +1 -1
  97. package/dist/esm/packages/taco/src/components/Dialog/Dialog.js.map +1 -1
  98. package/dist/esm/packages/taco/src/components/Dialog/components/Content.js +4 -2
  99. package/dist/esm/packages/taco/src/components/Dialog/components/Content.js.map +1 -1
  100. package/dist/esm/packages/taco/src/components/Drawer/components/Content.js +2 -2
  101. package/dist/esm/packages/taco/src/components/Drawer/components/Content.js.map +1 -1
  102. package/dist/esm/packages/taco/src/components/Hanger/Hanger.js +4 -2
  103. package/dist/esm/packages/taco/src/components/Hanger/Hanger.js.map +1 -1
  104. package/dist/esm/packages/taco/src/components/Header/components/AgreementSelector.js +2 -4
  105. package/dist/esm/packages/taco/src/components/Header/components/AgreementSelector.js.map +1 -1
  106. package/dist/esm/packages/taco/src/components/Icon/components/Autopay.js +19 -0
  107. package/dist/esm/packages/taco/src/components/Icon/components/Autopay.js.map +1 -0
  108. package/dist/esm/packages/taco/src/components/Icon/components/AutopayPaused.js +19 -0
  109. package/dist/esm/packages/taco/src/components/Icon/components/AutopayPaused.js.map +1 -0
  110. package/dist/esm/packages/taco/src/components/Icon/components/Experiment.js +20 -0
  111. package/dist/esm/packages/taco/src/components/Icon/components/Experiment.js.map +1 -0
  112. package/dist/esm/packages/taco/src/components/Icon/components/Person.js +19 -0
  113. package/dist/esm/packages/taco/src/components/Icon/components/Person.js.map +1 -0
  114. package/dist/esm/packages/taco/src/components/Icon/components/PersonSolid.js +19 -0
  115. package/dist/esm/packages/taco/src/components/Icon/components/PersonSolid.js.map +1 -0
  116. package/dist/esm/packages/taco/src/components/Icon/components/Wallet.js +19 -0
  117. package/dist/esm/packages/taco/src/components/Icon/components/Wallet.js.map +1 -0
  118. package/dist/esm/packages/taco/src/components/Icon/components/index.js +12 -0
  119. package/dist/esm/packages/taco/src/components/Icon/components/index.js.map +1 -1
  120. package/dist/esm/packages/taco/src/components/Input/util.js +1 -1
  121. package/dist/esm/packages/taco/src/components/Input/util.js.map +1 -1
  122. package/dist/esm/packages/taco/src/components/Listbox/util.js +1 -7
  123. package/dist/esm/packages/taco/src/components/Listbox/util.js.map +1 -1
  124. package/dist/esm/packages/taco/src/components/Menu/components/Content.js +5 -0
  125. package/dist/esm/packages/taco/src/components/Menu/components/Content.js.map +1 -1
  126. package/dist/esm/packages/taco/src/components/RadioGroup/RadioGroup.js.map +1 -1
  127. package/dist/esm/packages/taco/src/components/Report/Report.js +2 -3
  128. package/dist/esm/packages/taco/src/components/Report/Report.js.map +1 -1
  129. package/dist/esm/packages/taco/src/components/SearchInput2/SearchInput2.js +6 -3
  130. package/dist/esm/packages/taco/src/components/SearchInput2/SearchInput2.js.map +1 -1
  131. package/dist/esm/packages/taco/src/components/Select/Select.js +0 -9
  132. package/dist/esm/packages/taco/src/components/Select/Select.js.map +1 -1
  133. package/dist/esm/packages/taco/src/components/Select2/Select2.js.map +1 -1
  134. package/dist/esm/packages/taco/src/components/Select2/components/Create.js +10 -11
  135. package/dist/esm/packages/taco/src/components/Select2/components/Create.js.map +1 -1
  136. package/dist/esm/packages/taco/src/components/Select2/components/Option.js +7 -5
  137. package/dist/esm/packages/taco/src/components/Select2/components/Option.js.map +1 -1
  138. package/dist/esm/packages/taco/src/components/Select2/components/Trigger.js +56 -19
  139. package/dist/esm/packages/taco/src/components/Select2/components/Trigger.js.map +1 -1
  140. package/dist/esm/packages/taco/src/components/Shortcut/Shortcut.js +1 -1
  141. package/dist/esm/packages/taco/src/components/Shortcut/Shortcut.js.map +1 -1
  142. package/dist/esm/packages/taco/src/components/Table/hooks/plugins/useRowActions.js +1 -1
  143. package/dist/esm/packages/taco/src/components/Table3/Table3.js +23 -12
  144. package/dist/esm/packages/taco/src/components/Table3/Table3.js.map +1 -1
  145. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js +25 -9
  146. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js.map +1 -1
  147. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Internal/EditingActionsMenu.js +4 -3
  148. package/dist/esm/packages/taco/src/components/Table3/components/Columns/Internal/EditingActionsMenu.js.map +1 -1
  149. package/dist/esm/packages/taco/src/components/Table3/components/Editing/Alert.js +18 -10
  150. package/dist/esm/packages/taco/src/components/Table3/components/Editing/Alert.js.map +1 -1
  151. package/dist/esm/packages/taco/src/components/Table3/components/Editing/DiscardChangesConfirmationDialog.js +0 -1
  152. package/dist/esm/packages/taco/src/components/Table3/components/Editing/DiscardChangesConfirmationDialog.js.map +1 -1
  153. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/CreateNewRow.js +6 -37
  154. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/CreateNewRow.js.map +1 -1
  155. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/TemporaryRow.js +7 -6
  156. package/dist/esm/packages/taco/src/components/Table3/components/Row/Editing/TemporaryRow.js.map +1 -1
  157. package/dist/esm/packages/taco/src/components/Table3/features/useEditingState.js +81 -81
  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 +70 -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 +16 -5
  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 +9 -1
  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/Tooltip/Tooltip.js +2 -2
  170. package/dist/esm/packages/taco/src/components/Tooltip/Tooltip.js.map +1 -1
  171. package/dist/esm/packages/taco/src/hooks/useLazyEffect.js +1 -1
  172. package/dist/esm/packages/taco/src/hooks/useLazyEffect.js.map +1 -1
  173. package/dist/esm/packages/taco/src/index.js +6 -1
  174. package/dist/esm/packages/taco/src/index.js.map +1 -1
  175. package/dist/esm/packages/taco/src/primitives/BubbleSelect.js +1 -1
  176. package/dist/esm/packages/taco/src/primitives/BubbleSelect.js.map +1 -1
  177. package/dist/esm/packages/taco/src/primitives/Collection/components/Root.js +5 -3
  178. package/dist/esm/packages/taco/src/primitives/Collection/components/Root.js.map +1 -1
  179. package/dist/esm/packages/taco/src/primitives/Sortable/components/Item.js.map +1 -1
  180. package/dist/esm/packages/taco/src/primitives/Table/Core/Table.js +7 -5
  181. package/dist/esm/packages/taco/src/primitives/Table/Core/Table.js.map +1 -1
  182. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Body/EmptyStateBody.js +15 -2
  183. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Body/EmptyStateBody.js.map +1 -1
  184. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Cell/BuiltIns/GroupedCell.js +23 -16
  185. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Cell/BuiltIns/GroupedCell.js.map +1 -1
  186. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Actions.js +6 -4
  187. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Actions.js.map +1 -1
  188. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Drag.js +7 -0
  189. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Drag.js.map +1 -1
  190. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Expansion.js +11 -0
  191. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Expansion.js.map +1 -1
  192. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Selection.js +10 -7
  193. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Columns/Internal/Selection.js.map +1 -1
  194. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Footer.js +7 -2
  195. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Footer.js.map +1 -1
  196. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Summary.js +7 -6
  197. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Footer/Summary.js.map +1 -1
  198. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/components/Menu.js +3 -1
  199. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Header/components/Menu.js.map +1 -1
  200. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/DisplayRow.js +5 -2
  201. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/DisplayRow.js.map +1 -1
  202. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/SkeletonRow.js +24 -22
  203. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/BuiltIns/SkeletonRow.js.map +1 -1
  204. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/Row.js +44 -5
  205. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/Row.js.map +1 -1
  206. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/RowContext.js +3 -2
  207. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Row/RowContext.js.map +1 -1
  208. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/FilterContext.js +6 -0
  209. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/FilterContext.js.map +1 -0
  210. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/ManageFiltersPopover.js +5 -3
  211. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/ManageFiltersPopover.js.map +1 -1
  212. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/Filter.js +0 -2
  213. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/Filter.js.map +1 -1
  214. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterColumn.js +2 -1
  215. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterColumn.js.map +1 -1
  216. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterComparator.js +4 -0
  217. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterComparator.js.map +1 -1
  218. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterValue.js +3 -1
  219. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterValue.js.map +1 -1
  220. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Print/Print.js +3 -1
  221. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Print/Print.js.map +1 -1
  222. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Search/Search.js +26 -4
  223. package/dist/esm/packages/taco/src/primitives/Table/Core/components/Toolbar/components/Search/Search.js.map +1 -1
  224. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableGlobalShortcuts.js +2 -2
  225. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableGlobalShortcuts.js.map +1 -1
  226. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableRenderer.js +43 -12
  227. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableRenderer.js.map +1 -1
  228. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableStyleGrid.js +2 -2
  229. package/dist/esm/packages/taco/src/primitives/Table/Core/features/useTableStyleGrid.js.map +1 -1
  230. package/dist/esm/packages/taco/src/primitives/Table/Core/useTable.js +1 -1
  231. package/dist/esm/packages/taco/src/primitives/Table/Core/useTable.js.map +1 -1
  232. package/dist/esm/packages/taco/src/primitives/Table/types.js +3 -7
  233. package/dist/esm/packages/taco/src/primitives/Table/types.js.map +1 -1
  234. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader.js +13 -12
  235. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader.js.map +1 -1
  236. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader2.js +224 -0
  237. package/dist/esm/packages/taco/src/primitives/Table/useTableDataLoader2.js.map +1 -0
  238. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActions.js +11 -0
  239. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActions.js.map +1 -1
  240. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActive.js +1 -1
  241. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowActive.js.map +1 -1
  242. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowExpansion.js +2 -1
  243. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableRowExpansion.js.map +1 -1
  244. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableSearch.js +3 -2
  245. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableSearch.js.map +1 -1
  246. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableServerLoading.js +18 -8
  247. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/features/useTableServerLoading.js.map +1 -1
  248. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableDataListener.js +3 -4
  249. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableDataListener.js.map +1 -1
  250. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFilterListener.js +3 -1
  251. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFilterListener.js.map +1 -1
  252. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFontSizeListener.js +2 -1
  253. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableFontSizeListener.js.map +1 -1
  254. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableRowSelectionListener.js +4 -4
  255. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableRowSelectionListener.js.map +1 -1
  256. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableSearchListener.js +14 -13
  257. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableSearchListener.js.map +1 -1
  258. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableServerLoadingListener.js +7 -3
  259. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/listeners/useTableServerLoadingListener.js.map +1 -1
  260. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/useTableManager.js +5 -5
  261. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/useTableManager.js.map +1 -1
  262. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/columns.js +4 -1
  263. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/columns.js.map +1 -1
  264. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/dataTypes.js +6 -2
  265. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/dataTypes.js.map +1 -1
  266. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/filtering.js +6 -0
  267. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/filtering.js.map +1 -1
  268. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/presets.js +7 -1
  269. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/presets.js.map +1 -1
  270. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/search.js +7 -1
  271. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/search.js.map +1 -1
  272. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/setup.js +16 -4
  273. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/setup.js.map +1 -1
  274. package/dist/esm/packages/taco/src/primitives/Table/useTableManager/util/sorting.js.map +1 -1
  275. package/dist/esm/packages/taco/src/types.js.map +1 -1
  276. package/dist/esm/packages/taco/src/utils/dom.js +12 -1
  277. package/dist/esm/packages/taco/src/utils/dom.js.map +1 -1
  278. package/dist/esm/packages/taco/src/utils/tailwind.js +2 -0
  279. package/dist/esm/packages/taco/src/utils/tailwind.js.map +1 -1
  280. package/dist/esm/packages/taco/tailwind.colors.js +122 -0
  281. package/dist/esm/packages/taco/tailwind.colors.js.map +1 -0
  282. package/dist/hooks/useLazyDebouncedEffect.d.ts +2 -0
  283. package/dist/index.css +74 -12
  284. package/dist/index.d.ts +6 -0
  285. package/dist/primitives/Table/Core/Table.d.ts +1 -0
  286. package/dist/primitives/Table/Core/components/Body/EmptyStateBody.d.ts +1 -0
  287. package/dist/primitives/Table/Core/components/Body/util.d.ts +4 -4
  288. package/dist/primitives/Table/Core/components/Row/BuiltIns/SkeletonRow.d.ts +2 -2
  289. package/dist/primitives/Table/Core/components/Row/Row.d.ts +2 -0
  290. package/dist/primitives/Table/Core/components/Row/RowContext.d.ts +2 -1
  291. package/dist/primitives/Table/Core/components/Toolbar/components/Filters/FilterContext.d.ts +3 -0
  292. package/dist/primitives/Table/Core/components/Toolbar/components/Filters/components/Filter.d.ts +0 -1
  293. package/dist/primitives/Table/Core/components/Toolbar/components/Filters/components/FilterColumn.d.ts +0 -3
  294. package/dist/primitives/Table/Core/features/useTableRenderer.d.ts +1 -1
  295. package/dist/primitives/Table/Core/types.d.ts +1 -0
  296. package/dist/primitives/Table/types.d.ts +18 -14
  297. package/dist/primitives/Table/useTableDataLoader.d.ts +2 -2
  298. package/dist/primitives/Table/useTableDataLoader2.d.ts +23 -0
  299. package/dist/primitives/Table/useTableManager/features/useTableRowActions.d.ts +2 -0
  300. package/dist/primitives/Table/useTableManager/features/useTableRowExpansion.d.ts +2 -1
  301. package/dist/primitives/Table/useTableManager/features/useTableSearch.d.ts +4 -2
  302. package/dist/primitives/Table/useTableManager/features/useTableServerLoading.d.ts +6 -3
  303. package/dist/primitives/Table/useTableManager/listeners/useTableDataListener.d.ts +1 -1
  304. package/dist/primitives/Table/useTableManager/listeners/useTableSearchListener.d.ts +1 -2
  305. package/dist/primitives/Table/useTableManager/util/columns.d.ts +2 -1
  306. package/dist/primitives/Table/useTableManager/util/dataTypes.d.ts +1 -1
  307. package/dist/taco.cjs.development.js +1988 -512
  308. package/dist/taco.cjs.development.js.map +1 -1
  309. package/dist/taco.cjs.production.min.js +1 -1
  310. package/dist/taco.cjs.production.min.js.map +1 -1
  311. package/dist/types.d.ts +1 -1
  312. package/dist/utils/dom.d.ts +2 -2
  313. package/package.json +14 -13
  314. package/tailwind.colors.js +121 -0
  315. package/tailwind.config.js +3 -2
  316. package/dist/components/Table3/components/Row/Editing/CreateRowButton.d.ts +0 -11
@@ -1,29 +1,34 @@
1
1
  import { Table as ReactTable, Cell as ReactTableCell } from '@tanstack/react-table';
2
- import { Table3EditingChangeHandler, Table3EditingSaveHandler, Table3EditingValidatorFn } from '../types';
2
+ import { Table3EditingChangeHandler, Table3EditingDiscardHandler, Table3EditingSaveHandler, Table3EditingValidatorFn } from '../types';
3
+ declare type EditingError = {
4
+ row: string;
5
+ cells: Record<string, string>;
6
+ shouldShowErrorAlert: boolean;
7
+ };
3
8
  declare type EditingSaveState = 'saving' | 'saved' | 'errored';
4
- export declare function usePendingChangesState<TType = unknown>(handleSave: Table3EditingSaveHandler<TType> | undefined, handleChange: Table3EditingChangeHandler<TType> | undefined, rowIdentityAccessor: keyof TType, validator: Table3EditingValidatorFn<TType> | undefined): {
5
- setRowValue: <T extends TType>(rowId: string, original: T, value: Partial<T>) => Promise<void>;
6
- getRowValue: (rowId: string) => any;
7
- getRowMoveReason: (rowId: string) => unknown;
9
+ export declare function usePendingChangesState<TType = unknown>(handleSave: Table3EditingSaveHandler<TType> | undefined, handleChange: Table3EditingChangeHandler<TType> | undefined, handleDiscard: Table3EditingDiscardHandler | undefined, rowIdentityAccessor: keyof TType, validator: Table3EditingValidatorFn<TType> | undefined): {
10
+ getRowValue: (rowId: string) => Partial<unknown>;
11
+ getRowMoveReason: (rowId: string) => "search" | "sorting" | "filter";
8
12
  hasRowErrors: (rowId: string) => boolean;
9
13
  hasRowErrorsShownInAlert: (rowId: string) => boolean;
10
- hasTemporaryRowErrors: <T_1 extends TType>() => boolean;
11
- getRowStatus: (rowId: string) => any;
14
+ hasTemporaryRowErrors: <T extends TType>() => boolean;
15
+ getRowStatus: (rowId: string) => EditingSaveState;
12
16
  setRowStatus: (rowId: string, status: EditingSaveState | undefined) => void;
13
- setCellValue: <T_2 extends TType>(cell: ReactTableCell<T_2, unknown>, value: unknown) => void;
14
- getCellValue: <T_3 extends TType>(cell: ReactTableCell<T_3, unknown>) => unknown | undefined;
15
- getCellError: <T_4 extends TType>(cell: ReactTableCell<T_4, unknown>) => string | undefined;
16
- onCellChanged: <T_5 extends TType>(cell: ReactTableCell<T_5, unknown>, rowIndex: number, shouldRunUpdaters?: boolean) => Promise<void>;
17
- getErrorsShownInAlert: <T_6 extends TType>() => {
17
+ setCellValue: <T_1 extends TType>(cell: ReactTableCell<T_1, unknown>, rowIndex: number, value: unknown) => void;
18
+ getCellValue: <T_2 extends TType>(cell: ReactTableCell<T_2, unknown>) => unknown | undefined;
19
+ getCellError: <T_3 extends TType>(cell: ReactTableCell<T_3, unknown>) => string | undefined;
20
+ onCellChanged: <T_4 extends TType>(cell: ReactTableCell<T_4, unknown>, rowIndex: number, nextValue: any, shouldRunUpdaters?: boolean) => Promise<void>;
21
+ getErrorsShownInAlert: <T_5 extends TType>() => {
18
22
  rowId: string;
19
- changes: Partial<T_6>;
20
- errors: any;
23
+ index: number;
24
+ changes: Partial<T_5>;
25
+ errors: EditingError;
21
26
  }[];
22
27
  hasChanges: (rowId?: string | undefined) => boolean;
23
- saveChanges: <T_7 extends TType>(table: ReactTable<T_7>, rowId?: string | undefined) => Promise<boolean>;
24
- discardChanges: <T_8 extends TType>(rowId: string, table: ReactTable<T_8>) => void;
28
+ saveChanges: <T_6 extends TType>(table: ReactTable<T_6>, rowId?: string | undefined) => Promise<boolean>;
29
+ discardChanges: <T_7 extends TType>(rowId: string, table: ReactTable<T_7>) => Promise<void>;
25
30
  hasSaved: () => boolean;
26
- createRow: <T_9 extends TType>(data: Partial<T_9>) => string;
27
- temporaryRows: any;
31
+ insertTemporaryRow: <T_8 extends TType>(data: Partial<T_8>, rowIndex: number) => string;
32
+ temporaryRows: unknown[];
28
33
  };
29
34
  export {};
@@ -1,36 +1,41 @@
1
1
  import React from 'react';
2
2
  import { Table as ReactTable } from '@tanstack/react-table';
3
- import { Table3EditingChangeHandler, Table3EditingSaveHandler, Table3EditingValidatorFn } from '../types';
4
- export declare function useTableEditing<TType = unknown>(isEnabled: boolean | undefined, handleSave: Table3EditingSaveHandler<TType> | undefined, handleChange: Table3EditingChangeHandler<TType> | undefined, rowIdentityAccessor: keyof TType | undefined, validator: Table3EditingValidatorFn<TType> | undefined): {
5
- setRowValue: <T extends TType>(rowId: string, original: T, value: Partial<T>) => Promise<void>;
6
- getRowValue: (rowId: string) => any;
7
- getRowMoveReason: (rowId: string) => unknown;
3
+ import { Table3EditingChangeHandler, Table3EditingCreateHandler, Table3EditingDiscardHandler, Table3EditingSaveHandler, Table3EditingValidatorFn } from '../types';
4
+ export declare function useTableEditing<TType = unknown>(isEnabled: boolean | undefined, handleSave: Table3EditingSaveHandler<TType> | undefined, handleChange: Table3EditingChangeHandler<TType> | undefined, handleCreate: Table3EditingCreateHandler<TType> | undefined, handleDiscard: Table3EditingDiscardHandler | undefined, rowIdentityAccessor: keyof TType | undefined, validator: Table3EditingValidatorFn<TType> | undefined): {
5
+ getRowValue: (rowId: string) => Partial<unknown>;
6
+ getRowMoveReason: (rowId: string) => "search" | "sorting" | "filter";
8
7
  hasRowErrors: (rowId: string) => boolean;
9
8
  hasRowErrorsShownInAlert: (rowId: string) => boolean;
10
- hasTemporaryRowErrors: <T_1 extends TType>() => boolean;
11
- getRowStatus: (rowId: string) => any;
9
+ hasTemporaryRowErrors: <T extends TType>() => boolean;
10
+ getRowStatus: (rowId: string) => "saving" | "saved" | "errored";
12
11
  setRowStatus: (rowId: string, status: "saving" | "saved" | "errored" | undefined) => void;
13
- setCellValue: <T_2 extends TType>(cell: import("@tanstack/react-table").Cell<T_2, unknown>, value: unknown) => void;
14
- getCellValue: <T_3 extends TType>(cell: import("@tanstack/react-table").Cell<T_3, unknown>) => unknown;
15
- getCellError: <T_4 extends TType>(cell: import("@tanstack/react-table").Cell<T_4, unknown>) => string | undefined;
16
- onCellChanged: <T_5 extends TType>(cell: import("@tanstack/react-table").Cell<T_5, unknown>, rowIndex: number, shouldRunUpdaters?: boolean) => Promise<void>;
17
- getErrorsShownInAlert: <T_6 extends TType>() => {
12
+ setCellValue: <T_1 extends TType>(cell: import("@tanstack/react-table").Cell<T_1, unknown>, rowIndex: number, value: unknown) => void;
13
+ getCellValue: <T_2 extends TType>(cell: import("@tanstack/react-table").Cell<T_2, unknown>) => unknown;
14
+ getCellError: <T_3 extends TType>(cell: import("@tanstack/react-table").Cell<T_3, unknown>) => string | undefined;
15
+ onCellChanged: <T_4 extends TType>(cell: import("@tanstack/react-table").Cell<T_4, unknown>, rowIndex: number, nextValue: any, shouldRunUpdaters?: boolean) => Promise<void>;
16
+ getErrorsShownInAlert: <T_5 extends TType>() => {
18
17
  rowId: string;
19
- changes: Partial<T_6>;
20
- errors: any;
18
+ index: number;
19
+ changes: Partial<T_5>;
20
+ errors: {
21
+ row: string;
22
+ cells: Record<string, string>;
23
+ shouldShowErrorAlert: boolean;
24
+ };
21
25
  }[];
22
26
  hasChanges: (rowId?: string | undefined) => boolean;
23
- saveChanges: <T_7 extends TType>(table: ReactTable<T_7>, rowId?: string | undefined) => Promise<boolean>;
24
- discardChanges: <T_8 extends TType>(rowId: string, table: ReactTable<T_8>) => void;
27
+ saveChanges: <T_6 extends TType>(table: ReactTable<T_6>, rowId?: string | undefined) => Promise<boolean>;
28
+ discardChanges: <T_7 extends TType>(rowId: string, table: ReactTable<T_7>) => Promise<void>;
25
29
  hasSaved: () => boolean;
26
- createRow: <T_9 extends TType>(data: Partial<T_9>) => string;
27
- temporaryRows: any;
30
+ insertTemporaryRow: <T_8 extends TType>(data: Partial<T_8>, rowIndex: number) => string;
31
+ temporaryRows: unknown[];
28
32
  isEnabled: boolean;
29
33
  isEditing: boolean;
30
34
  isDetailedMode: boolean;
31
35
  toggleDetailedMode: React.Dispatch<React.SetStateAction<boolean>>;
32
- toggleEditing: <T_10 extends TType>(enabled: React.SetStateAction<boolean>, table: ReactTable<T_10>, scrollToIndex: (index: number) => void) => void;
36
+ toggleEditing: <T_9 extends TType>(enabled: React.SetStateAction<boolean>, table: ReactTable<T_9>, scrollToIndex: (index: number) => void) => void;
33
37
  lastFocusedCellIndex: number | undefined;
34
38
  setLastFocusedCellIndex: React.Dispatch<React.SetStateAction<number | undefined>>;
39
+ createRow: <T_10 extends TType>(table: ReactTable<T_10>, row?: Partial<T_10> | undefined) => Promise<void>;
35
40
  createRowButtonRef: React.RefObject<HTMLButtonElement>;
36
41
  };
@@ -7,6 +7,7 @@ export declare type Table3Ref = TableRef & {
7
7
  };
8
8
  export declare type Table3EditingChangeHandler<TType = unknown> = (accessor: string, value: unknown, row: TType, prevRow: TType) => Promise<Partial<TType>> | undefined;
9
9
  export declare type Table3EditingCreateHandler<TType = unknown> = () => Partial<TType>;
10
+ export declare type Table3EditingDiscardHandler = () => void;
10
11
  export declare type Table3EditingSaveHandler<TType = unknown> = (row: TType) => Promise<void>;
11
12
  export declare type Table3EditingValidatorFn<TType = unknown> = (row: TType) => Promise<Partial<Record<keyof TType, string>> | undefined> | Partial<Record<keyof TType, string>> | undefined;
12
13
  export interface Table3FeatureProps<TType = unknown> extends TableFeatureProps<TType> {
@@ -15,6 +16,7 @@ export interface Table3FeatureProps<TType = unknown> extends TableFeatureProps<T
15
16
  export interface Table3CommonProps<TType = unknown> extends Table3FeatureProps<TType> {
16
17
  onEditingChange?: Table3EditingChangeHandler<TType>;
17
18
  onEditingCreate?: Table3EditingCreateHandler<TType>;
19
+ onEditingDiscard?: Table3EditingDiscardHandler;
18
20
  validator?: Table3EditingValidatorFn<TType>;
19
21
  }
20
22
  export interface Table3WithoutEditingWithClientProps<TType = unknown> extends Table3CommonProps<TType>, TableClientProps<TType> {
@@ -1,4 +1,6 @@
1
+ import React from 'react';
1
2
  import { Cell as ReactTableCell } from '@tanstack/react-table';
3
+ import { TableRef } from '../../../primitives/Table/types';
2
4
  import { Localization } from '../../Provider/Localization';
3
5
  export declare function willRowMove<TType = unknown>(cell: ReactTableCell<TType, unknown>, change: unknown, rowIndex: number, localization: Localization): "search" | "filter" | "sorting" | undefined;
4
6
  export declare const TEMPORARY_ROW_ID_PREFIX = "temp-";
@@ -8,3 +10,4 @@ export declare const shortcut: {
8
10
  meta: boolean;
9
11
  shift: boolean;
10
12
  };
13
+ export declare function isTableScrolled(ref: React.RefObject<TableRef>): boolean;
@@ -13,7 +13,7 @@ export declare const Tag: React.ForwardRefExoticComponent<Pick<React.HTMLAttribu
13
13
  children: string;
14
14
  color?: "green" | "yellow" | "red" | "blue" | "purple" | "brown" | "pink" | "orange" | "grey" | "transparent" | undefined;
15
15
  disabled?: boolean | undefined;
16
- icon?: "id" | React.ReactElement<IconProps, string | ((props: any, deprecatedLegacyContext?: any) => React.ReactElement<any, any> | null) | (new (props: any, deprecatedLegacyContext?: any) => React.Component<any, any, any>)> | "account-preview" | "accounting-year-cancel" | "accounting-year" | "accounting" | "ai-chat-solid" | "ai-stars" | "arrow-bottom" | "arrow-down" | "arrow-end" | "arrow-left" | "arrow-right" | "arrow-start" | "arrow-top" | "arrow-up" | "attach-auto" | "attach-cancel" | "attach-warning" | "attach" | "autotext-insert" | "autotext" | "basic-tabs" | "basic" | "bell-solid" | "book" | "booking" | "budget" | "calendar" | "cash-account" | "cash-reports" | "chart-area" | "chart-bar" | "chart-line" | "chart-pie" | "chart-table" | "chat-solid" | "chat" | "chevron-down-double" | "chevron-down-solid" | "chevron-down" | "chevron-left-double" | "chevron-left-solid" | "chevron-left" | "chevron-right-double" | "chevron-right-solid" | "chevron-right" | "chevron-up-double" | "chevron-up-solid" | "chevron-up" | "circle-close" | "circle-information" | "circle-minus" | "circle-plus" | "circle-questionmark" | "circle-tick" | "circle-warning" | "clamp-open" | "clamp" | "close" | "column-freeze" | "column-unfreeze" | "columns" | "connection-enable" | "connection-revoke" | "contacts" | "copy" | "courses" | "credit" | "delete-permanently" | "delete" | "depecriate" | "developer" | "distribution-template" | "document-approve" | "document-create-entry" | "document-cut" | "document-error" | "document-isolate-page" | "document-merge" | "document-move" | "document-preview" | "document-received" | "document-rejected-request" | "document-signed-solid" | "document-signed" | "document-split" | "document-time" | "document" | "download" | "drag" | "e-copedia" | "edit-simple" | "edit" | "ellipsis-horizontal" | "ellipsis-vertical" | "entries-on-account" | "entries-open" | "entries-warning" | "entry-type-customer-invoice" | "entry-type-customer-payment" | "entry-type-journal-entry" | "entry-type-manual-customer-invoice" | "entry-type-supplier-invoice" | "entry-type-supplier-payment" | "envelope-approved" | "envelope-solid" | "envelope" | "expand-view" | "expenses" | "export-to-excel" | "export-to-pdf" | "export" | "eye-off" | "eye-on" | "filter-solid" | "filter" | "font-size" | "graph-solid" | "hash" | "height-extra-tall" | "height-medium" | "height-short" | "height-tall" | "house-solid" | "house" | "images" | "import" | "inbox-einvoicing" | "inbox-scanning" | "inbox-smart" | "inbox" | "info" | "inventory-matrix" | "inventory" | "journal-pro" | "layout-both" | "layout-first" | "layout-last" | "layout-none" | "layout" | "ledger-card-customer-reminder" | "ledger-card-manual-customer-invoice" | "ledger-card-obsolete-stock" | "ledger-card-opening-entry" | "ledger-card-reserved-entry" | "ledger-card-shrinkage-pilferage" | "ledger-card-stock-adjustment" | "ledger-card-transferred-opening-entry" | "ledger-card" | "lightbulb" | "line" | "link-external" | "list-bulleted" | "list-search" | "list" | "location" | "lock-open" | "lock" | "log-out" | "log" | "market" | "mastercard-os" | "match-amount" | "match-entries" | "menu" | "mileage" | "modal-resize" | "modal-shrink" | "more-solid" | "more" | "move" | "navigation-list" | "note-follow-up" | "note-read" | "note" | "november-first" | "numbers" | "partner-api" | "payment-paid" | "payment-unpaid" | "period" | "person-change" | "person-minus" | "person-plus" | "person-tick" | "phone-solid" | "phone" | "play" | "plus-minus" | "print" | "process-payment" | "product-ledger-card" | "profile" | "project-cards" | "projects" | "question-mark-bold" | "question-mark" | "quicklinks" | "rating-bankruptcy" | "rating-payment-problems" | "reconciled" | "refresh" | "report-solid" | "report" | "restore" | "rotate-left" | "rotate-right" | "sales" | "search-bold" | "search" | "secure-tick" | "secure" | "settings-solid" | "settings" | "shortcuts" | "show-all" | "show-less" | "show-more" | "show-template" | "sliders" | "smartpay" | "sort-by" | "star-solid" | "star" | "subscriptions" | "system-entries" | "tag" | "template-override" | "templates" | "thumb-both" | "thumb-down-solid" | "thumb-down" | "thumb-up-solid" | "thumb-up" | "tick-bold" | "tick" | "time" | "transfer-cancel" | "transfer-locked" | "transfer" | "undo" | "undock" | "unreconciled" | "warning" | "webshop" | "website" | "workflow-template-basic" | "workflow" | "zoom" | undefined;
16
+ icon?: "id" | React.ReactElement<IconProps, string | ((props: any, deprecatedLegacyContext?: any) => React.ReactElement<any, any> | null) | (new (props: any, deprecatedLegacyContext?: any) => React.Component<any, any, any>)> | "account-preview" | "accounting-year-cancel" | "accounting-year" | "accounting" | "ai-chat-solid" | "ai-stars" | "arrow-bottom" | "arrow-down" | "arrow-end" | "arrow-left" | "arrow-right" | "arrow-start" | "arrow-top" | "arrow-up" | "attach-auto" | "attach-cancel" | "attach-warning" | "attach" | "autopay-paused" | "autopay" | "autotext-insert" | "autotext" | "basic-tabs" | "basic" | "bell-solid" | "book" | "booking" | "budget" | "calendar" | "cash-account" | "cash-reports" | "chart-area" | "chart-bar" | "chart-line" | "chart-pie" | "chart-table" | "chat-solid" | "chat" | "chevron-down-double" | "chevron-down-solid" | "chevron-down" | "chevron-left-double" | "chevron-left-solid" | "chevron-left" | "chevron-right-double" | "chevron-right-solid" | "chevron-right" | "chevron-up-double" | "chevron-up-solid" | "chevron-up" | "circle-close" | "circle-information" | "circle-minus" | "circle-plus" | "circle-questionmark" | "circle-tick" | "circle-warning" | "clamp-open" | "clamp" | "close" | "column-freeze" | "column-unfreeze" | "columns" | "connection-enable" | "connection-revoke" | "contacts" | "copy" | "courses" | "credit" | "delete-permanently" | "delete" | "depecriate" | "developer" | "distribution-template" | "document-approve" | "document-create-entry" | "document-cut" | "document-error" | "document-isolate-page" | "document-merge" | "document-move" | "document-preview" | "document-received" | "document-rejected-request" | "document-signed-solid" | "document-signed" | "document-split" | "document-time" | "document" | "download" | "drag" | "e-copedia" | "edit-simple" | "edit" | "ellipsis-horizontal" | "ellipsis-vertical" | "entries-on-account" | "entries-open" | "entries-warning" | "entry-type-customer-invoice" | "entry-type-customer-payment" | "entry-type-journal-entry" | "entry-type-manual-customer-invoice" | "entry-type-supplier-invoice" | "entry-type-supplier-payment" | "envelope-approved" | "envelope-solid" | "envelope" | "expand-view" | "expenses" | "experiment" | "export-to-excel" | "export-to-pdf" | "export" | "eye-off" | "eye-on" | "filter-solid" | "filter" | "font-size" | "graph-solid" | "hash" | "height-extra-tall" | "height-medium" | "height-short" | "height-tall" | "house-solid" | "house" | "images" | "import" | "inbox-einvoicing" | "inbox-scanning" | "inbox-smart" | "inbox" | "info" | "inventory-matrix" | "inventory" | "journal-pro" | "layout-both" | "layout-first" | "layout-last" | "layout-none" | "layout" | "ledger-card-customer-reminder" | "ledger-card-manual-customer-invoice" | "ledger-card-obsolete-stock" | "ledger-card-opening-entry" | "ledger-card-reserved-entry" | "ledger-card-shrinkage-pilferage" | "ledger-card-stock-adjustment" | "ledger-card-transferred-opening-entry" | "ledger-card" | "lightbulb" | "line" | "link-external" | "list-bulleted" | "list-search" | "list" | "location" | "lock-open" | "lock" | "log-out" | "log" | "market" | "mastercard-os" | "match-amount" | "match-entries" | "menu" | "mileage" | "modal-resize" | "modal-shrink" | "more-solid" | "more" | "move" | "navigation-list" | "note-follow-up" | "note-read" | "note" | "november-first" | "numbers" | "partner-api" | "payment-paid" | "payment-unpaid" | "period" | "person-change" | "person-minus" | "person-plus" | "person-solid" | "person-tick" | "person" | "phone-solid" | "phone" | "play" | "plus-minus" | "print" | "process-payment" | "product-ledger-card" | "profile" | "project-cards" | "projects" | "question-mark-bold" | "question-mark" | "quicklinks" | "rating-bankruptcy" | "rating-payment-problems" | "reconciled" | "refresh" | "report-solid" | "report" | "restore" | "rotate-left" | "rotate-right" | "sales" | "search-bold" | "search" | "secure-tick" | "secure" | "settings-solid" | "settings" | "shortcuts" | "show-all" | "show-less" | "show-more" | "show-template" | "sliders" | "smartpay" | "sort-by" | "star-solid" | "star" | "subscriptions" | "system-entries" | "tag" | "template-override" | "templates" | "thumb-both" | "thumb-down-solid" | "thumb-down" | "thumb-up-solid" | "thumb-up" | "tick-bold" | "tick" | "time" | "transfer-cancel" | "transfer-locked" | "transfer" | "undo" | "undock" | "unreconciled" | "wallet" | "warning" | "webshop" | "website" | "workflow-template-basic" | "workflow" | "zoom" | undefined;
17
17
  readOnly?: boolean | undefined;
18
18
  onDelete?: ((event: React.MouseEvent<SVGSVGElement>) => void) | undefined;
19
19
  } & React.RefAttributes<HTMLSpanElement>>;
@@ -166,6 +166,14 @@
166
166
  @apply invisible;
167
167
  }
168
168
 
169
+ /*
170
+ * While the dialog is open, all elements are aria-hidden except for the dialog content. This ensures that the
171
+ * print document contains only the dialog content.
172
+ */
173
+ [aria-hidden='true'] {
174
+ @apply print:!hidden;
175
+ }
176
+
169
177
  .wcag-transparent {
170
178
  @apply bg-black/[0.08] text-black;
171
179
  }
@@ -180,6 +188,24 @@
180
188
  }
181
189
  }
182
190
 
191
+ .recharts-cartesian-axis line,
192
+ .recharts-cartesian-grid-horizontal line {
193
+ stroke: #efefef !important;
194
+ }
195
+
196
+ .recharts-tooltip-cursor {
197
+ fill: transparent !important;
198
+ }
199
+
200
+ .recharts-legend-wrapper {
201
+ left: 0 !important;
202
+ width: 100% !important;
203
+ }
204
+
205
+ .recharts-wrapper > svg g {
206
+ outline: none !important;
207
+ }
208
+
183
209
  [data-taco='badge'] > [data-taco='spinner'] {
184
210
  @apply ml-2 h-3 w-3;
185
211
  }
@@ -393,6 +419,12 @@
393
419
  bottom: 3px;
394
420
  }
395
421
 
422
+ /* When dealing with nested dialogs, the dialog behind remains rendered because it only receives the [aria-hidden] attribute but not display: none.
423
+ As a result, tabs in the hidden dialog remain visible, as they still have the visible class assigned. To properly hide them, we need to override their visibility. */
424
+ [data-taco='backdrop'][aria-hidden='true'] [role='tablist'] [role='tab'].visible {
425
+ visibility: hidden;
426
+ }
427
+
396
428
  /* label inside label is invalid html, but the client is littered with it */
397
429
  [data-taco='label'] [data-taco='label'] {
398
430
  min-height: 0;
@@ -556,7 +588,7 @@ table[data-taco^='table'] {
556
588
 
557
589
  table[data-taco^='table'] thead {
558
590
  /* z-indexes & layout */
559
- @apply sticky top-0 isolate z-20;
591
+ @apply sticky top-0 isolate z-20 print:static;
560
592
  /* grid */
561
593
  @apply col-span-full grid auto-rows-min grid-cols-[subgrid];
562
594
  }
@@ -585,13 +617,17 @@ table[data-taco^='table'] thead tr:last-child {
585
617
 
586
618
  /* bottom border for column groups */
587
619
 
588
- table[data-taco^='table'] thead tr:not(:last-child) th:before {
589
- @apply bg-grey-300 absolute bottom-0 left-2 right-2 h-[2px] content-[''];
620
+ table[data-taco^='table'] thead tr:not(:last-child) th {
621
+ @apply print:border-grey-300 print:border-b;
590
622
  }
591
623
 
624
+ table[data-taco^='table'] thead tr:not(:last-child) th:before {
625
+ @apply bg-grey-300 absolute bottom-0 left-2 right-2 h-[2px] content-[''];
626
+ }
627
+
592
628
  table[data-taco^='table'] tfoot {
593
629
  /* z-indexes & layout */
594
- @apply sticky bottom-0 isolate z-20;
630
+ @apply sticky bottom-0 isolate z-20 print:static;
595
631
  /* grid */
596
632
  @apply col-span-full grid grid-cols-[subgrid];
597
633
  }
@@ -609,6 +645,10 @@ table[data-taco^='table'] tbody {
609
645
  @apply print:!h-auto;
610
646
  }
611
647
 
648
+ table[data-taco^='table']:has([data-taco='empty-state']) {
649
+ @apply overflow-x-hidden;
650
+ }
651
+
612
652
  table[data-taco^='table'] tr {
613
653
  /* styling */
614
654
  @apply relative bg-white outline-none;
@@ -632,13 +672,22 @@ table[data-taco^='table'] tr[data-row-group]:first-child {
632
672
  @apply pt-0;
633
673
  }
634
674
 
675
+ /* Only apply -mt-px when the row group header is sticked to the top of the table.
676
+ margin-top -1px is needed to hide a little gap between the group header and table and the edge of the table.
677
+ If we'll not do this, then it will be slightly visible how rows are moving behind it when scrolled.
678
+ */
679
+
680
+ table[data-taco^='table'] tr[data-row-group]:first-child td {
681
+ @apply -mt-px;
682
+ }
683
+
635
684
  table[data-taco^='table'] tr[data-row-group]:not(:first-child):before {
636
685
  content: '';
637
- @apply bg-grey-100 border-grey-300 absolute left-0 right-0 top-0 h-10 border-t print:top-0 print:h-[2px] print:border-t-2;
686
+ @apply bg-grey-100 border-grey-300 absolute -top-1 left-0 right-0 h-10 border-t print:top-0 print:h-[2px] print:border-t-2;
638
687
  }
639
688
 
640
689
  table[data-taco^='table'] tr[data-row-group] td {
641
- @apply -mt-px border-b-2 border-t-0 font-bold;
690
+ @apply border-b-2 border-t-0 font-bold;
642
691
  }
643
692
 
644
693
  table[data-taco^='table'] tr:first-child td {
@@ -734,14 +783,14 @@ table[data-taco^='table'] td:not([data-cell-truncate='true']) {
734
783
  }
735
784
 
736
785
  /* FOOTER */
737
- table[data-taco^='table'] tfoot td {
786
+ table[data-taco^='table'] tfoot tr:not([data-row-index]) td {
738
787
  /*
739
788
  * Since footer has sticky position, the top and bottom padding ensures that the inner content doesn't come over
740
789
  * the border of the footer row.
741
790
  */
742
791
  @apply border-b-0 !py-1 font-bold;
743
792
  }
744
- table[data-taco^='table'] tfoot td:first-child {
793
+ table[data-taco^='table'] tfoot tr:not([data-row-index]) td:first-child {
745
794
  @apply z-30 !pb-0 !pt-[2px];
746
795
  }
747
796
 
@@ -1117,19 +1166,19 @@ table[data-taco^='table'][data-table-pause-hover='true'] > tbody > tr:hover[data
1117
1166
 
1118
1167
  /* row metadata */
1119
1168
  table[data-taco^='table'] tbody tr[data-row-meta-layout='heading']:not([data-row-group='true']) td {
1120
- @apply !border-b-0 border-t font-bold;
1169
+ @apply border-b-0 border-t font-bold;
1121
1170
  }
1122
1171
 
1123
1172
  table[data-taco^='table'] tbody tr[data-row-group='true'] + tr[data-row-meta-layout='heading'] td {
1124
- @apply !border-t-0;
1173
+ @apply border-t-0;
1125
1174
  }
1126
1175
 
1127
1176
  table[data-taco^='table'] tbody tr[data-row-meta-layout='summary']:not([data-row-group='true']) td {
1128
- @apply !border-b-0 font-bold;
1177
+ @apply border-b-0 font-bold;
1129
1178
  }
1130
1179
 
1131
1180
  table[data-taco^='table'] tbody tr[data-row-meta-layout='item']:not([data-row-group='true']) td {
1132
- @apply !border-b-0;
1181
+ @apply border-b-0;
1133
1182
  }
1134
1183
 
1135
1184
  /* rows */
@@ -1292,6 +1341,14 @@ table[data-taco='table3'][data-table-editing-mode] tbody tr[data-row-editing-mov
1292
1341
  @apply border-r-2 border-blue-500 pr-[calc(var(--table-cell-padding-x)_-_2px)];
1293
1342
  }
1294
1343
 
1344
+ table[data-taco^='table3'][data-table-editing-mode] [data-cell-align='center'] > label {
1345
+ @apply flex-row justify-center text-center;
1346
+ }
1347
+
1348
+ table[data-taco^='table3'][data-table-editing-mode] [data-cell-align='right'] > label {
1349
+ @apply flex-row justify-end text-right;
1350
+ }
1351
+
1295
1352
  /* invalid rows */
1296
1353
 
1297
1354
  table[data-taco='table3'] > tbody > tr[data-row-editing-invalid='true'] > td,
@@ -1368,3 +1425,8 @@ table[data-taco^='table'][data-table-row-height='tall'] tr[data-row-create] td,
1368
1425
  table[data-taco^='table'][data-table-row-height='extra-tall'] tr[data-row-create] td {
1369
1426
  @apply !min-h-[41px] !pt-[10px];
1370
1427
  }
1428
+
1429
+ /* Hiding CreateNewRow using CSS to ensure higher specificity for hiding the row */
1430
+ table[data-taco^='table'] tr[data-row-create] {
1431
+ @apply print:hidden;
1432
+ }
@@ -0,0 +1,67 @@
1
+ import React__default, { useState } from 'react';
2
+ import { AreaChart as AreaChart$1, CartesianGrid, XAxis, YAxis, Legend, Tooltip, Area as Area$1 } from 'recharts';
3
+ import { getThemeColor } from '../../utils/color.js';
4
+ import { getCartesianGridProps, getXAxisProps, getYAxisProps, getLegendProps, getTooltipProps } from '../../utils/common.js';
5
+ import { ResponsiveContainer } from '../ResponsiveContainer.js';
6
+
7
+ const Area = _ => null;
8
+ const AreaChart = function AreaChart(externalProps) {
9
+ const {
10
+ children,
11
+ data,
12
+ formatter,
13
+ ...props
14
+ } = externalProps;
15
+ const [hoveredArea, setHoveredArea] = useState(null);
16
+ const [activeAreas, setActiveAreas] = useState(() => {
17
+ const areas = {};
18
+ React__default.Children.forEach(children, child => {
19
+ areas[child.props.accessor] = true;
20
+ });
21
+ return areas;
22
+ });
23
+ const handleLegendClick = entry => {
24
+ setHoveredArea(null);
25
+ setActiveAreas({
26
+ ...activeAreas,
27
+ [entry.dataKey]: !activeAreas[entry.dataKey]
28
+ });
29
+ };
30
+ return /*#__PURE__*/React__default.createElement(ResponsiveContainer, null, /*#__PURE__*/React__default.createElement(AreaChart$1, {
31
+ data: data,
32
+ margin: {
33
+ top: 10,
34
+ right: 0,
35
+ left: -25,
36
+ bottom: 0
37
+ }
38
+ }, /*#__PURE__*/React__default.createElement(CartesianGrid, Object.assign({}, getCartesianGridProps())), /*#__PURE__*/React__default.createElement(XAxis, Object.assign({}, getXAxisProps(props))), /*#__PURE__*/React__default.createElement(YAxis, Object.assign({}, getYAxisProps(props))), /*#__PURE__*/React__default.createElement(Legend, Object.assign({}, getLegendProps({
39
+ onClick: handleLegendClick,
40
+ onMouseEnter: entry => setHoveredArea(entry.dataKey),
41
+ onMouseLeave: () => setHoveredArea(null),
42
+ activeItems: activeAreas
43
+ }))), /*#__PURE__*/React__default.createElement(Tooltip, Object.assign({}, getTooltipProps(), {
44
+ formatter: formatter
45
+ })), React__default.Children.map(children, child => {
46
+ var _child$props$color, _child$props$color2, _child$props$color3;
47
+ return /*#__PURE__*/React__default.createElement(Area$1, {
48
+ activeDot: {
49
+ fill: getThemeColor((_child$props$color = child.props.color) !== null && _child$props$color !== void 0 ? _child$props$color : 'blue-300')
50
+ },
51
+ isAnimationActive: false,
52
+ dataKey: child.props.accessor,
53
+ dot: false,
54
+ fill: getThemeColor((_child$props$color2 = child.props.color) !== null && _child$props$color2 !== void 0 ? _child$props$color2 : 'grey-100'),
55
+ name: child.props.label,
56
+ strokeWidth: 2,
57
+ stroke: getThemeColor((_child$props$color3 = child.props.color) !== null && _child$props$color3 !== void 0 ? _child$props$color3 : 'grey-300'),
58
+ stackId: child.props.stackId,
59
+ hide: !activeAreas[child.props.accessor],
60
+ opacity: hoveredArea && child.props.accessor !== hoveredArea ? 0.3 : 1
61
+ });
62
+ })));
63
+ };
64
+ AreaChart.Area = Area;
65
+
66
+ export { AreaChart };
67
+ //# sourceMappingURL=AreaChart.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AreaChart.js","sources":["../../../../../../../../src/charts/components/Area/AreaChart.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport * as Recharts from 'recharts';\n\nimport { Color, getThemeColor } from '../../utils/color';\nimport {\n CommonChartProps,\n getCartesianGridProps,\n getXAxisProps,\n getYAxisProps,\n getLegendProps,\n getTooltipProps,\n} from '../../utils/common';\nimport { ResponsiveContainer } from '../ResponsiveContainer';\nimport { ActiveChartItems, PayloadType } from '../types';\n\ntype AreaChartBarProps<TType> = {\n accessor: keyof TType & string;\n color?: Color;\n label?: string;\n stackId?: string;\n};\n\nconst Area = (_: AreaChartBarProps<any>) => null;\n\ntype AreaChartProps<TType> = CommonChartProps<TType> & {\n children: React.ReactElement<AreaChartBarProps<TType>> | React.ReactElement<AreaChartBarProps<TType>>[];\n data: TType[];\n formatter?: (value: any) => string;\n};\n\nexport const AreaChart = function AreaChart<TType = unknown>(externalProps: AreaChartProps<TType>) {\n const { children, data, formatter, ...props } = externalProps;\n const [hoveredArea, setHoveredArea] = useState<(keyof TType & string) | null>(null);\n const [activeAreas, setActiveAreas] = useState<ActiveChartItems<TType>>(() => {\n const areas = {} as ActiveChartItems<TType>;\n\n React.Children.forEach(children, child => {\n areas[child.props.accessor] = true;\n });\n\n return areas;\n });\n\n const handleLegendClick = (entry: PayloadType<TType>): void => {\n setHoveredArea(null);\n setActiveAreas({ ...activeAreas, [entry.dataKey]: !activeAreas[entry.dataKey] });\n };\n\n return (\n <ResponsiveContainer>\n <Recharts.AreaChart data={data} margin={{ top: 10, right: 0, left: -25, bottom: 0 }}>\n <Recharts.CartesianGrid {...getCartesianGridProps()} />\n <Recharts.XAxis {...getXAxisProps<TType>(props)} />\n <Recharts.YAxis {...getYAxisProps<TType>(props)} />\n <Recharts.Legend\n {...getLegendProps({\n onClick: handleLegendClick,\n onMouseEnter: entry => setHoveredArea(entry.dataKey),\n onMouseLeave: () => setHoveredArea(null),\n activeItems: activeAreas,\n })}\n />\n <Recharts.Tooltip {...getTooltipProps()} formatter={formatter} />\n {React.Children.map(children, child => (\n <Recharts.Area\n activeDot={{\n fill: getThemeColor(child.props.color ?? 'blue-300'),\n }}\n isAnimationActive={false}\n dataKey={child.props.accessor}\n dot={false}\n fill={getThemeColor(child.props.color ?? 'grey-100')}\n name={child.props.label}\n strokeWidth={2}\n stroke={getThemeColor(child.props.color ?? 'grey-300')}\n stackId={child.props.stackId}\n hide={!activeAreas[child.props.accessor]}\n opacity={hoveredArea && child.props.accessor !== hoveredArea ? 0.3 : 1}\n />\n ))}\n </Recharts.AreaChart>\n </ResponsiveContainer>\n );\n};\nAreaChart.Area = Area;\n"],"names":["Area","_","AreaChart","externalProps","children","data","formatter","props","hoveredArea","setHoveredArea","useState","activeAreas","setActiveAreas","areas","React","Children","forEach","child","accessor","handleLegendClick","entry","dataKey","ResponsiveContainer","Recharts","margin","top","right","left","bottom","getCartesianGridProps","getXAxisProps","getYAxisProps","getLegendProps","onClick","onMouseEnter","onMouseLeave","activeItems","getTooltipProps","map","_child$props$color","_child$props$color2","_child$props$color3","activeDot","fill","getThemeColor","color","isAnimationActive","dot","name","label","strokeWidth","stroke","stackId","hide","opacity"],"mappings":"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"}
@@ -0,0 +1,120 @@
1
+ import React__default from 'react';
2
+ import { BarChart as BarChart$1, CartesianGrid, XAxis, YAxis, Legend, Tooltip, Bar as Bar$1, Cell } from 'recharts';
3
+ import { getThemeColor } from '../../utils/color.js';
4
+ import { getCartesianGridProps, getXAxisProps, getYAxisProps, getLegendProps, getTooltipProps } from '../../utils/common.js';
5
+ import { ResponsiveContainer } from '../ResponsiveContainer.js';
6
+
7
+ const Bar = _ => null;
8
+ const getXAxisVerticalProps = props => ({
9
+ ...getXAxisProps(props),
10
+ ...{
11
+ type: 'number',
12
+ dataKey: undefined
13
+ }
14
+ });
15
+ const getYAxisVerticalProps = props => ({
16
+ ...getYAxisProps(props),
17
+ ...{
18
+ dataKey: props.accessor,
19
+ type: 'category'
20
+ }
21
+ });
22
+ const BarChart = function BarChart(externalProps) {
23
+ const {
24
+ children,
25
+ data,
26
+ formatter,
27
+ layout = 'horizontal',
28
+ ...props
29
+ } = externalProps;
30
+ const [activeIndex, setActiveIndex] = React__default.useState(undefined);
31
+ const [hoveredBar, setHoveredBar] = React__default.useState(null);
32
+ const [activeBars, setActiveBars] = React__default.useState(() => {
33
+ const keys = {};
34
+ React__default.Children.forEach(children, child => {
35
+ keys[child.props.accessor] = true;
36
+ });
37
+ return keys;
38
+ });
39
+ // Recharts doesn't provide a way for us to know if a stacked bar is at the top or the bottom,
40
+ // so we can't set proper radiuses without some "magic"
41
+ const stacks = {};
42
+ React__default.Children.forEach(children, child => {
43
+ if (child.props.stackId) {
44
+ if (!stacks[child.props.stackId]) {
45
+ stacks[child.props.stackId] = [child.props.accessor];
46
+ } else {
47
+ stacks[child.props.stackId].push(child.props.accessor);
48
+ }
49
+ }
50
+ });
51
+ const handleLegendClick = entry => {
52
+ setHoveredBar(null);
53
+ setActiveBars({
54
+ ...activeBars,
55
+ [entry.dataKey]: !activeBars[entry.dataKey]
56
+ });
57
+ };
58
+ const handleLegendHover = (entry, index) => {
59
+ setHoveredBar(entry.dataKey);
60
+ setActiveIndex(index);
61
+ };
62
+ return /*#__PURE__*/React__default.createElement(ResponsiveContainer, null, /*#__PURE__*/React__default.createElement(BarChart$1, {
63
+ layout: layout,
64
+ data: data,
65
+ margin: {
66
+ top: 10,
67
+ right: 0,
68
+ left: layout === 'vertical' ? 0 : -25,
69
+ bottom: 0
70
+ },
71
+ onMouseMove: chartState => setActiveIndex(chartState.activeTooltipIndex),
72
+ onMouseLeave: () => setActiveIndex(undefined)
73
+ }, /*#__PURE__*/React__default.createElement(CartesianGrid, Object.assign({}, getCartesianGridProps())), /*#__PURE__*/React__default.createElement(XAxis, Object.assign({}, layout === 'vertical' ? getXAxisVerticalProps(props) : getXAxisProps(props))), /*#__PURE__*/React__default.createElement(YAxis, Object.assign({}, layout === 'vertical' ? getYAxisVerticalProps(props) : getYAxisProps(props))), /*#__PURE__*/React__default.createElement(Legend, Object.assign({}, getLegendProps({
74
+ onClick: handleLegendClick,
75
+ onMouseEnter: handleLegendHover,
76
+ onMouseLeave: () => setHoveredBar(null),
77
+ activeItems: activeBars
78
+ }))), /*#__PURE__*/React__default.createElement(Tooltip, Object.assign({}, getTooltipProps(), {
79
+ formatter: formatter
80
+ })), React__default.Children.map(children, child => (/*#__PURE__*/React__default.createElement(Bar$1, {
81
+ isAnimationActive: false,
82
+ barSize: 16,
83
+ dataKey: child.props.accessor,
84
+ name: child.props.label,
85
+ onMouseEnter: (_, index) => setActiveIndex(index),
86
+ onMouseLeave: () => setActiveIndex(undefined),
87
+ fill: getThemeColor(child.props.color ? `${child.props.color}` : `blue-300`),
88
+ radius: getBarRadius(stacks, child.props.accessor, child.props.stackId, activeBars),
89
+ stackId: child.props.stackId,
90
+ style: child.props.stackId ? {
91
+ stroke: '#fff',
92
+ strokeWidth: '2px'
93
+ } : undefined,
94
+ hide: !activeBars[child.props.accessor]
95
+ }, data.map((_, index) => (/*#__PURE__*/React__default.createElement(Cell, {
96
+ key: `cell-${index}`,
97
+ opacity: hoveredBar && child.props.accessor !== hoveredBar || activeIndex !== undefined && activeIndex !== index ? 0.3 : 1
98
+ }))))))));
99
+ };
100
+ BarChart.Bar = Bar;
101
+ const getBarRadius = (stacks, accessor, stackId, activeBars) => {
102
+ if (stackId && Array.isArray(stacks[stackId])) {
103
+ const length = stacks[stackId].length - 1;
104
+ const index = stacks[stackId].indexOf(accessor);
105
+ if (Object.entries(activeBars).filter(item => item[0] !== accessor).every(item => !item[1])) {
106
+ return [3, 3, 0, 0];
107
+ }
108
+ if (activeBars[stacks[stackId][index + 1]] === false) {
109
+ return [index === 0 ? 0 : 3, index === 0 ? 0 : 3, index === length - 1 ? 0 : 3, index === length - 1 ? 0 : 3];
110
+ }
111
+ if (index !== 0 && index !== length) {
112
+ return 0;
113
+ }
114
+ return [index === 0 ? 0 : 3, index === 0 ? 0 : 3, index === length ? 0 : 3, index === length ? 0 : 3];
115
+ }
116
+ return 3;
117
+ };
118
+
119
+ export { BarChart };
120
+ //# sourceMappingURL=BarChart.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BarChart.js","sources":["../../../../../../../../src/charts/components/Bar/BarChart.tsx"],"sourcesContent":["import React from 'react';\nimport * as Recharts from 'recharts';\n\nimport { Color, getThemeColor } from '../../utils/color';\nimport {\n CommonChartProps,\n getCartesianGridProps,\n getXAxisProps,\n getYAxisProps,\n getLegendProps,\n getTooltipProps,\n} from '../../utils/common';\nimport { ResponsiveContainer } from '../ResponsiveContainer';\nimport { ActiveChartItems, PayloadType } from '../types';\n\ntype StacksType<TType> = Record<string, Array<keyof TType & string>>;\n\ntype BarChartBarProps<TType> = {\n accessor: keyof TType & string;\n color?: Color;\n label?: string;\n stackId?: string;\n};\n\nconst Bar = (_: BarChartBarProps<any>) => null;\n\ntype BarChartProps<TType> = CommonChartProps<TType> & {\n children: React.ReactElement<BarChartBarProps<TType>> | React.ReactElement<BarChartBarProps<TType>>[];\n data: TType[];\n formatter?: (value: any) => string;\n layout?: 'horizontal' | 'vertical';\n};\n\nconst getXAxisVerticalProps = <TType,>(props: CommonChartProps<TType>) => ({\n ...getXAxisProps<TType>(props),\n ...{ type: 'number' as const, dataKey: undefined },\n});\n\nconst getYAxisVerticalProps = <TType,>(props: CommonChartProps<TType>) => ({\n ...getYAxisProps<TType>(props),\n ...{ dataKey: props.accessor, type: 'category' as const },\n});\n\nexport const BarChart = function BarChart<TType = unknown>(externalProps: BarChartProps<TType>) {\n const { children, data, formatter, layout = 'horizontal', ...props } = externalProps;\n const [activeIndex, setActiveIndex] = React.useState<number | undefined>(undefined);\n const [hoveredBar, setHoveredBar] = React.useState<(keyof TType & string) | null>(null);\n const [activeBars, setActiveBars] = React.useState<ActiveChartItems<TType>>(() => {\n const keys = {} as ActiveChartItems<TType>;\n\n React.Children.forEach(children, child => {\n keys[child.props.accessor] = true;\n });\n\n return keys;\n });\n\n // Recharts doesn't provide a way for us to know if a stacked bar is at the top or the bottom,\n // so we can't set proper radiuses without some \"magic\"\n const stacks = {} as StacksType<TType>;\n\n React.Children.forEach(children, child => {\n if (child.props.stackId) {\n if (!stacks[child.props.stackId]) {\n stacks[child.props.stackId] = [child.props.accessor];\n } else {\n stacks[child.props.stackId].push(child.props.accessor);\n }\n }\n });\n\n const handleLegendClick = (entry: PayloadType<TType>): void => {\n setHoveredBar(null);\n setActiveBars({ ...activeBars, [entry.dataKey]: !activeBars[entry.dataKey] });\n };\n\n const handleLegendHover = (entry: PayloadType<TType>, index: number): void => {\n setHoveredBar(entry.dataKey);\n setActiveIndex(index);\n };\n\n return (\n <ResponsiveContainer>\n <Recharts.BarChart\n layout={layout}\n data={data}\n margin={{ top: 10, right: 0, left: layout === 'vertical' ? 0 : -25, bottom: 0 }}\n onMouseMove={chartState => setActiveIndex(chartState.activeTooltipIndex)}\n onMouseLeave={() => setActiveIndex(undefined)}>\n <Recharts.CartesianGrid {...getCartesianGridProps()} />\n <Recharts.XAxis\n {...(layout === 'vertical' ? getXAxisVerticalProps<TType>(props) : getXAxisProps<TType>(props))}\n />\n <Recharts.YAxis\n {...(layout === 'vertical' ? getYAxisVerticalProps<TType>(props) : getYAxisProps<TType>(props))}\n />\n <Recharts.Legend\n {...getLegendProps({\n onClick: handleLegendClick,\n onMouseEnter: handleLegendHover,\n onMouseLeave: () => setHoveredBar(null),\n activeItems: activeBars,\n })}\n />\n <Recharts.Tooltip {...getTooltipProps()} formatter={formatter} />\n {React.Children.map(children, child => (\n <Recharts.Bar\n isAnimationActive={false}\n barSize={16}\n dataKey={child.props.accessor}\n name={child.props.label}\n onMouseEnter={(_, index) => setActiveIndex(index)}\n onMouseLeave={() => setActiveIndex(undefined)}\n fill={getThemeColor(child.props.color ? `${child.props.color}` : `blue-300`)}\n radius={getBarRadius<TType>(stacks, child.props.accessor, child.props.stackId, activeBars)}\n stackId={child.props.stackId}\n style={child.props.stackId ? { stroke: '#fff', strokeWidth: '2px' } : undefined}\n hide={!activeBars[child.props.accessor]}>\n {data.map((_, index) => (\n <Recharts.Cell\n key={`cell-${index}`}\n opacity={\n (hoveredBar && child.props.accessor !== hoveredBar) ||\n (activeIndex !== undefined && activeIndex !== index)\n ? 0.3\n : 1\n }\n />\n ))}\n </Recharts.Bar>\n ))}\n </Recharts.BarChart>\n </ResponsiveContainer>\n );\n};\nBarChart.Bar = Bar;\n\nconst getBarRadius = <TType,>(\n stacks: StacksType<TType>,\n accessor: keyof TType & string,\n stackId: string | undefined,\n activeBars: ActiveChartItems<TType>\n): number | [number, number, number, number] => {\n if (stackId && Array.isArray(stacks[stackId])) {\n const length = stacks[stackId].length - 1;\n const index: number = stacks[stackId].indexOf(accessor);\n\n if (\n Object.entries(activeBars)\n .filter(item => item[0] !== accessor)\n .every(item => !item[1])\n ) {\n return [3, 3, 0, 0];\n }\n\n if (activeBars[stacks[stackId][index + 1]] === false) {\n return [index === 0 ? 0 : 3, index === 0 ? 0 : 3, index === length - 1 ? 0 : 3, index === length - 1 ? 0 : 3];\n }\n\n if (index !== 0 && index !== length) {\n return 0;\n }\n\n return [index === 0 ? 0 : 3, index === 0 ? 0 : 3, index === length ? 0 : 3, index === length ? 0 : 3];\n }\n\n return 3;\n};\n"],"names":["Bar","_","getXAxisVerticalProps","props","getXAxisProps","type","dataKey","undefined","getYAxisVerticalProps","getYAxisProps","accessor","BarChart","externalProps","children","data","formatter","layout","activeIndex","setActiveIndex","React","useState","hoveredBar","setHoveredBar","activeBars","setActiveBars","keys","Children","forEach","child","stacks","stackId","push","handleLegendClick","entry","handleLegendHover","index","ResponsiveContainer","Recharts","margin","top","right","left","bottom","onMouseMove","chartState","activeTooltipIndex","onMouseLeave","getCartesianGridProps","getLegendProps","onClick","onMouseEnter","activeItems","getTooltipProps","map","isAnimationActive","barSize","name","label","fill","getThemeColor","color","radius","getBarRadius","style","stroke","strokeWidth","hide","key","opacity","Array","isArray","length","indexOf","Object","entries","filter","item","every"],"mappings":"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"}