@cratis/components 0.1.9

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 (577) hide show
  1. package/.storybook/main.ts +24 -0
  2. package/CommandDialog/CommandDialog.stories.tsx +25 -0
  3. package/CommandDialog/CommandDialog.tsx +161 -0
  4. package/CommandDialog/index.ts +4 -0
  5. package/CommandForm/CommandForm.stories.tsx +24 -0
  6. package/CommandForm/CommandForm.tsx +266 -0
  7. package/CommandForm/CommandFormField.tsx +27 -0
  8. package/CommandForm/CommandFormFields.tsx +142 -0
  9. package/CommandForm/DatePickerField.tsx +57 -0
  10. package/CommandForm/DropdownField.tsx +65 -0
  11. package/CommandForm/InputTextField.tsx +62 -0
  12. package/CommandForm/SliderField.tsx +68 -0
  13. package/CommandForm/index.ts +10 -0
  14. package/Common/ErrorBoundary.stories.tsx +10 -0
  15. package/Common/ErrorBoundary.tsx +41 -0
  16. package/Common/FormElement.stories.tsx +10 -0
  17. package/Common/FormElement.tsx +20 -0
  18. package/Common/Page.stories.tsx +10 -0
  19. package/Common/Page.tsx +21 -0
  20. package/Common/index.ts +6 -0
  21. package/DataPage/DataPage.stories.tsx +10 -0
  22. package/DataPage/DataPage.tsx +191 -0
  23. package/DataPage/index.ts +4 -0
  24. package/DataTables/DataTableForObservableQuery.stories.tsx +10 -0
  25. package/DataTables/DataTableForObservableQuery.tsx +97 -0
  26. package/DataTables/DataTableForQuery.stories.tsx +10 -0
  27. package/DataTables/DataTableForQuery.tsx +97 -0
  28. package/DataTables/index.ts +5 -0
  29. package/Dialogs/BusyIndicatorDialog.stories.tsx +26 -0
  30. package/Dialogs/BusyIndicatorDialog.tsx +26 -0
  31. package/Dialogs/ConfirmationDialog.stories.tsx +36 -0
  32. package/Dialogs/ConfirmationDialog.tsx +75 -0
  33. package/Dialogs/index.ts +5 -0
  34. package/Dropdown/Dropdown.tsx +23 -0
  35. package/Dropdown/index.ts +4 -0
  36. package/PivotViewer/PivotViewer.stories.tsx +24 -0
  37. package/PivotViewer/PivotViewer.tsx +791 -0
  38. package/PivotViewer/components/AxisLabels.tsx +69 -0
  39. package/PivotViewer/components/DetailPanel.tsx +108 -0
  40. package/PivotViewer/components/FilterPanel.tsx +189 -0
  41. package/PivotViewer/components/FilterPanelContainer.tsx +10 -0
  42. package/PivotViewer/components/PivotCanvas.tsx +660 -0
  43. package/PivotViewer/components/PivotViewerMain.tsx +229 -0
  44. package/PivotViewer/components/RangeHistogramFilter.tsx +220 -0
  45. package/PivotViewer/components/Spinner.tsx +21 -0
  46. package/PivotViewer/components/Toolbar.tsx +130 -0
  47. package/PivotViewer/components/ToolbarContainer.tsx +10 -0
  48. package/PivotViewer/components/index.ts +12 -0
  49. package/PivotViewer/components/pivot/animation.ts +108 -0
  50. package/PivotViewer/components/pivot/buckets.ts +152 -0
  51. package/PivotViewer/components/pivot/colorResolver.ts +67 -0
  52. package/PivotViewer/components/pivot/constants.ts +46 -0
  53. package/PivotViewer/components/pivot/sprites.ts +265 -0
  54. package/PivotViewer/components/pivot/visibility.ts +319 -0
  55. package/PivotViewer/constants.ts +9 -0
  56. package/PivotViewer/engine/layout.ts +149 -0
  57. package/PivotViewer/engine/pivot.worker.ts +86 -0
  58. package/PivotViewer/engine/store.ts +437 -0
  59. package/PivotViewer/engine/types.ts +255 -0
  60. package/PivotViewer/hooks/index.ts +13 -0
  61. package/PivotViewer/hooks/useContainerDimensions.ts +45 -0
  62. package/PivotViewer/hooks/useDimensionState.ts +53 -0
  63. package/PivotViewer/hooks/useFilterOptions.ts +36 -0
  64. package/PivotViewer/hooks/useFilterPanelDrag.ts +49 -0
  65. package/PivotViewer/hooks/useFilterState.ts +106 -0
  66. package/PivotViewer/hooks/useFilteredData.ts +119 -0
  67. package/PivotViewer/hooks/usePanning.ts +163 -0
  68. package/PivotViewer/hooks/usePivotEngine.ts +252 -0
  69. package/PivotViewer/hooks/useSelectedItem.ts +402 -0
  70. package/PivotViewer/hooks/useWheelZoom.ts +114 -0
  71. package/PivotViewer/hooks/useZoomState.ts +34 -0
  72. package/PivotViewer/index.ts +7 -0
  73. package/PivotViewer/types.ts +59 -0
  74. package/PivotViewer/utils/animations.ts +249 -0
  75. package/PivotViewer/utils/constants.ts +20 -0
  76. package/PivotViewer/utils/index.ts +6 -0
  77. package/PivotViewer/utils/selection.ts +292 -0
  78. package/PivotViewer/utils/utils.ts +259 -0
  79. package/README.md +1 -0
  80. package/TimeMachine/EventsView.stories.tsx +10 -0
  81. package/TimeMachine/EventsView.tsx +119 -0
  82. package/TimeMachine/Properties.stories.tsx +10 -0
  83. package/TimeMachine/Properties.tsx +98 -0
  84. package/TimeMachine/ReadModelView.stories.tsx +10 -0
  85. package/TimeMachine/ReadModelView.tsx +143 -0
  86. package/TimeMachine/TimeMachine.stories.tsx +10 -0
  87. package/TimeMachine/TimeMachine.tsx +244 -0
  88. package/TimeMachine/index.ts +8 -0
  89. package/TimeMachine/types.ts +23 -0
  90. package/dist/cjs/CommandDialog/CommandDialog.js +71 -0
  91. package/dist/cjs/CommandDialog/CommandDialog.js.map +1 -0
  92. package/dist/cjs/CommandDialog/index.js +9 -0
  93. package/dist/cjs/CommandDialog/index.js.map +1 -0
  94. package/dist/cjs/CommandForm/CommandForm.js +179 -0
  95. package/dist/cjs/CommandForm/CommandForm.js.map +1 -0
  96. package/dist/cjs/CommandForm/CommandFormField.js +11 -0
  97. package/dist/cjs/CommandForm/CommandFormField.js.map +1 -0
  98. package/dist/cjs/CommandForm/CommandFormFields.js +67 -0
  99. package/dist/cjs/CommandForm/CommandFormFields.js.map +1 -0
  100. package/dist/cjs/CommandForm/DatePickerField.js +31 -0
  101. package/dist/cjs/CommandForm/DatePickerField.js.map +1 -0
  102. package/dist/cjs/CommandForm/DropdownField.js +31 -0
  103. package/dist/cjs/CommandForm/DropdownField.js.map +1 -0
  104. package/dist/cjs/CommandForm/InputTextField.js +32 -0
  105. package/dist/cjs/CommandForm/InputTextField.js.map +1 -0
  106. package/dist/cjs/CommandForm/SliderField.js +34 -0
  107. package/dist/cjs/CommandForm/SliderField.js.map +1 -0
  108. package/dist/cjs/CommandForm/index.js +23 -0
  109. package/dist/cjs/CommandForm/index.js.map +1 -0
  110. package/dist/cjs/Common/Page.js +10 -0
  111. package/dist/cjs/Common/Page.js.map +1 -0
  112. package/dist/cjs/DataPage/DataPage.js +64 -0
  113. package/dist/cjs/DataPage/DataPage.js.map +1 -0
  114. package/dist/cjs/DataPage/index.js +11 -0
  115. package/dist/cjs/DataPage/index.js.map +1 -0
  116. package/dist/cjs/DataTables/DataTableForObservableQuery.js +17 -0
  117. package/dist/cjs/DataTables/DataTableForObservableQuery.js.map +1 -0
  118. package/dist/cjs/DataTables/DataTableForQuery.js +17 -0
  119. package/dist/cjs/DataTables/DataTableForQuery.js.map +1 -0
  120. package/dist/cjs/DataTables/index.js +10 -0
  121. package/dist/cjs/DataTables/index.js.map +1 -0
  122. package/dist/cjs/Dialogs/BusyIndicatorDialog.js +13 -0
  123. package/dist/cjs/Dialogs/BusyIndicatorDialog.js.map +1 -0
  124. package/dist/cjs/Dialogs/ConfirmationDialog.js +33 -0
  125. package/dist/cjs/Dialogs/ConfirmationDialog.js.map +1 -0
  126. package/dist/cjs/Dialogs/index.js +10 -0
  127. package/dist/cjs/Dialogs/index.js.map +1 -0
  128. package/dist/cjs/Dropdown/Dropdown.js +15 -0
  129. package/dist/cjs/Dropdown/Dropdown.js.map +1 -0
  130. package/dist/cjs/Dropdown/index.js +8 -0
  131. package/dist/cjs/Dropdown/index.js.map +1 -0
  132. package/dist/cjs/PivotViewer/PivotViewer.js +525 -0
  133. package/dist/cjs/PivotViewer/PivotViewer.js.map +1 -0
  134. package/dist/cjs/PivotViewer/components/AxisLabels.js +27 -0
  135. package/dist/cjs/PivotViewer/components/AxisLabels.js.map +1 -0
  136. package/dist/cjs/PivotViewer/components/DetailPanel.js +35 -0
  137. package/dist/cjs/PivotViewer/components/DetailPanel.js.map +1 -0
  138. package/dist/cjs/PivotViewer/components/FilterPanel.js +59 -0
  139. package/dist/cjs/PivotViewer/components/FilterPanel.js.map +1 -0
  140. package/dist/cjs/PivotViewer/components/FilterPanelContainer.js +11 -0
  141. package/dist/cjs/PivotViewer/components/FilterPanelContainer.js.map +1 -0
  142. package/dist/cjs/PivotViewer/components/PivotCanvas.js +394 -0
  143. package/dist/cjs/PivotViewer/components/PivotCanvas.js.map +1 -0
  144. package/dist/cjs/PivotViewer/components/PivotViewerMain.js +81 -0
  145. package/dist/cjs/PivotViewer/components/PivotViewerMain.js.map +1 -0
  146. package/dist/cjs/PivotViewer/components/RangeHistogramFilter.js +124 -0
  147. package/dist/cjs/PivotViewer/components/RangeHistogramFilter.js.map +1 -0
  148. package/dist/cjs/PivotViewer/components/Spinner.js +11 -0
  149. package/dist/cjs/PivotViewer/components/Spinner.js.map +1 -0
  150. package/dist/cjs/PivotViewer/components/Toolbar.js +12 -0
  151. package/dist/cjs/PivotViewer/components/Toolbar.js.map +1 -0
  152. package/dist/cjs/PivotViewer/components/ToolbarContainer.js +11 -0
  153. package/dist/cjs/PivotViewer/components/ToolbarContainer.js.map +1 -0
  154. package/dist/cjs/PivotViewer/components/pivot/animation.js +82 -0
  155. package/dist/cjs/PivotViewer/components/pivot/animation.js.map +1 -0
  156. package/dist/cjs/PivotViewer/components/pivot/buckets.js +124 -0
  157. package/dist/cjs/PivotViewer/components/pivot/buckets.js.map +1 -0
  158. package/dist/cjs/PivotViewer/components/pivot/colorResolver.js +64 -0
  159. package/dist/cjs/PivotViewer/components/pivot/colorResolver.js.map +1 -0
  160. package/dist/cjs/PivotViewer/components/pivot/constants.js +19 -0
  161. package/dist/cjs/PivotViewer/components/pivot/constants.js.map +1 -0
  162. package/dist/cjs/PivotViewer/components/pivot/sprites.js +227 -0
  163. package/dist/cjs/PivotViewer/components/pivot/sprites.js.map +1 -0
  164. package/dist/cjs/PivotViewer/components/pivot/visibility.js +223 -0
  165. package/dist/cjs/PivotViewer/components/pivot/visibility.js.map +1 -0
  166. package/dist/cjs/PivotViewer/constants.js +16 -0
  167. package/dist/cjs/PivotViewer/constants.js.map +1 -0
  168. package/dist/cjs/PivotViewer/engine/layout.js +95 -0
  169. package/dist/cjs/PivotViewer/engine/layout.js.map +1 -0
  170. package/dist/cjs/PivotViewer/engine/store.js +336 -0
  171. package/dist/cjs/PivotViewer/engine/store.js.map +1 -0
  172. package/dist/cjs/PivotViewer/hooks/useContainerDimensions.js +30 -0
  173. package/dist/cjs/PivotViewer/hooks/useContainerDimensions.js.map +1 -0
  174. package/dist/cjs/PivotViewer/hooks/useDimensionState.js +43 -0
  175. package/dist/cjs/PivotViewer/hooks/useDimensionState.js.map +1 -0
  176. package/dist/cjs/PivotViewer/hooks/useFilterOptions.js +24 -0
  177. package/dist/cjs/PivotViewer/hooks/useFilterOptions.js.map +1 -0
  178. package/dist/cjs/PivotViewer/hooks/useFilterState.js +96 -0
  179. package/dist/cjs/PivotViewer/hooks/useFilterState.js.map +1 -0
  180. package/dist/cjs/PivotViewer/hooks/usePanning.js +120 -0
  181. package/dist/cjs/PivotViewer/hooks/usePanning.js.map +1 -0
  182. package/dist/cjs/PivotViewer/hooks/usePivotEngine.js +183 -0
  183. package/dist/cjs/PivotViewer/hooks/usePivotEngine.js.map +1 -0
  184. package/dist/cjs/PivotViewer/hooks/useWheelZoom.js +93 -0
  185. package/dist/cjs/PivotViewer/hooks/useWheelZoom.js.map +1 -0
  186. package/dist/cjs/PivotViewer/hooks/useZoomState.js +31 -0
  187. package/dist/cjs/PivotViewer/hooks/useZoomState.js.map +1 -0
  188. package/dist/cjs/PivotViewer/index.js +9 -0
  189. package/dist/cjs/PivotViewer/index.js.map +1 -0
  190. package/dist/cjs/PivotViewer/utils/animations.js +144 -0
  191. package/dist/cjs/PivotViewer/utils/animations.js.map +1 -0
  192. package/dist/cjs/PivotViewer/utils/constants.js +12 -0
  193. package/dist/cjs/PivotViewer/utils/constants.js.map +1 -0
  194. package/dist/cjs/PivotViewer/utils/selection.js +136 -0
  195. package/dist/cjs/PivotViewer/utils/selection.js.map +1 -0
  196. package/dist/cjs/PivotViewer/utils/utils.js +150 -0
  197. package/dist/cjs/PivotViewer/utils/utils.js.map +1 -0
  198. package/dist/cjs/TimeMachine/EventsView.js +57 -0
  199. package/dist/cjs/TimeMachine/EventsView.js.map +1 -0
  200. package/dist/cjs/TimeMachine/Properties.js +58 -0
  201. package/dist/cjs/TimeMachine/Properties.js.map +1 -0
  202. package/dist/cjs/TimeMachine/ReadModelView.js +40 -0
  203. package/dist/cjs/TimeMachine/ReadModelView.js.map +1 -0
  204. package/dist/cjs/TimeMachine/TimeMachine.js +98 -0
  205. package/dist/cjs/TimeMachine/TimeMachine.js.map +1 -0
  206. package/dist/cjs/TimeMachine/index.js +14 -0
  207. package/dist/cjs/TimeMachine/index.js.map +1 -0
  208. package/dist/cjs/index.js +22 -0
  209. package/dist/cjs/index.js.map +1 -0
  210. package/dist/cjs/useOverlayZIndex.js +24 -0
  211. package/dist/cjs/useOverlayZIndex.js.map +1 -0
  212. package/dist/esm/CommandDialog/CommandDialog.d.ts +45 -0
  213. package/dist/esm/CommandDialog/CommandDialog.d.ts.map +1 -0
  214. package/dist/esm/CommandDialog/CommandDialog.js +68 -0
  215. package/dist/esm/CommandDialog/CommandDialog.js.map +1 -0
  216. package/dist/esm/CommandDialog/CommandDialog.stories.d.ts +7 -0
  217. package/dist/esm/CommandDialog/CommandDialog.stories.d.ts.map +1 -0
  218. package/dist/esm/CommandDialog/CommandDialog.stories.js +12 -0
  219. package/dist/esm/CommandDialog/CommandDialog.stories.js.map +1 -0
  220. package/dist/esm/CommandDialog/index.d.ts +2 -0
  221. package/dist/esm/CommandDialog/index.d.ts.map +1 -0
  222. package/dist/esm/CommandDialog/index.js +2 -0
  223. package/dist/esm/CommandDialog/index.js.map +1 -0
  224. package/dist/esm/CommandForm/CommandForm.d.ts +49 -0
  225. package/dist/esm/CommandForm/CommandForm.d.ts.map +1 -0
  226. package/dist/esm/CommandForm/CommandForm.js +174 -0
  227. package/dist/esm/CommandForm/CommandForm.js.map +1 -0
  228. package/dist/esm/CommandForm/CommandForm.stories.d.ts +7 -0
  229. package/dist/esm/CommandForm/CommandForm.stories.d.ts.map +1 -0
  230. package/dist/esm/CommandForm/CommandForm.stories.js +12 -0
  231. package/dist/esm/CommandForm/CommandForm.stories.js.map +1 -0
  232. package/dist/esm/CommandForm/CommandFormField.d.ts +18 -0
  233. package/dist/esm/CommandForm/CommandFormField.d.ts.map +1 -0
  234. package/dist/esm/CommandForm/CommandFormField.js +9 -0
  235. package/dist/esm/CommandForm/CommandFormField.js.map +1 -0
  236. package/dist/esm/CommandForm/CommandFormFields.d.ts +11 -0
  237. package/dist/esm/CommandForm/CommandFormFields.d.ts.map +1 -0
  238. package/dist/esm/CommandForm/CommandFormFields.js +65 -0
  239. package/dist/esm/CommandForm/CommandFormFields.js.map +1 -0
  240. package/dist/esm/CommandForm/DatePickerField.d.ts +20 -0
  241. package/dist/esm/CommandForm/DatePickerField.d.ts.map +1 -0
  242. package/dist/esm/CommandForm/DatePickerField.js +29 -0
  243. package/dist/esm/CommandForm/DatePickerField.js.map +1 -0
  244. package/dist/esm/CommandForm/DropdownField.d.ts +24 -0
  245. package/dist/esm/CommandForm/DropdownField.d.ts.map +1 -0
  246. package/dist/esm/CommandForm/DropdownField.js +29 -0
  247. package/dist/esm/CommandForm/DropdownField.js.map +1 -0
  248. package/dist/esm/CommandForm/InputTextField.d.ts +20 -0
  249. package/dist/esm/CommandForm/InputTextField.d.ts.map +1 -0
  250. package/dist/esm/CommandForm/InputTextField.js +30 -0
  251. package/dist/esm/CommandForm/InputTextField.js.map +1 -0
  252. package/dist/esm/CommandForm/SliderField.d.ts +23 -0
  253. package/dist/esm/CommandForm/SliderField.d.ts.map +1 -0
  254. package/dist/esm/CommandForm/SliderField.js +32 -0
  255. package/dist/esm/CommandForm/SliderField.js.map +1 -0
  256. package/dist/esm/CommandForm/index.d.ts +8 -0
  257. package/dist/esm/CommandForm/index.d.ts.map +1 -0
  258. package/dist/esm/CommandForm/index.js +8 -0
  259. package/dist/esm/CommandForm/index.js.map +1 -0
  260. package/dist/esm/Common/ErrorBoundary.d.ts +16 -0
  261. package/dist/esm/Common/ErrorBoundary.d.ts.map +1 -0
  262. package/dist/esm/Common/ErrorBoundary.js +21 -0
  263. package/dist/esm/Common/ErrorBoundary.js.map +1 -0
  264. package/dist/esm/Common/ErrorBoundary.stories.d.ts +8 -0
  265. package/dist/esm/Common/ErrorBoundary.stories.d.ts.map +1 -0
  266. package/dist/esm/Common/ErrorBoundary.stories.js +6 -0
  267. package/dist/esm/Common/ErrorBoundary.stories.js.map +1 -0
  268. package/dist/esm/Common/FormElement.d.ts +6 -0
  269. package/dist/esm/Common/FormElement.d.ts.map +1 -0
  270. package/dist/esm/Common/FormElement.js +5 -0
  271. package/dist/esm/Common/FormElement.js.map +1 -0
  272. package/dist/esm/Common/FormElement.stories.d.ts +8 -0
  273. package/dist/esm/Common/FormElement.stories.d.ts.map +1 -0
  274. package/dist/esm/Common/FormElement.stories.js +6 -0
  275. package/dist/esm/Common/FormElement.stories.js.map +1 -0
  276. package/dist/esm/Common/Page.d.ts +8 -0
  277. package/dist/esm/Common/Page.d.ts.map +1 -0
  278. package/dist/esm/Common/Page.js +8 -0
  279. package/dist/esm/Common/Page.js.map +1 -0
  280. package/dist/esm/Common/Page.stories.d.ts +8 -0
  281. package/dist/esm/Common/Page.stories.d.ts.map +1 -0
  282. package/dist/esm/Common/Page.stories.js +6 -0
  283. package/dist/esm/Common/Page.stories.js.map +1 -0
  284. package/dist/esm/Common/index.d.ts +4 -0
  285. package/dist/esm/Common/index.d.ts.map +1 -0
  286. package/dist/esm/Common/index.js +4 -0
  287. package/dist/esm/Common/index.js.map +1 -0
  288. package/dist/esm/DataPage/DataPage.d.ts +41 -0
  289. package/dist/esm/DataPage/DataPage.d.ts.map +1 -0
  290. package/dist/esm/DataPage/DataPage.js +59 -0
  291. package/dist/esm/DataPage/DataPage.js.map +1 -0
  292. package/dist/esm/DataPage/DataPage.stories.d.ts +8 -0
  293. package/dist/esm/DataPage/DataPage.stories.d.ts.map +1 -0
  294. package/dist/esm/DataPage/DataPage.stories.js +6 -0
  295. package/dist/esm/DataPage/DataPage.stories.js.map +1 -0
  296. package/dist/esm/DataPage/index.d.ts +2 -0
  297. package/dist/esm/DataPage/index.d.ts.map +1 -0
  298. package/dist/esm/DataPage/index.js +2 -0
  299. package/dist/esm/DataPage/index.js.map +1 -0
  300. package/dist/esm/DataTables/DataTableForObservableQuery.d.ts +17 -0
  301. package/dist/esm/DataTables/DataTableForObservableQuery.d.ts.map +1 -0
  302. package/dist/esm/DataTables/DataTableForObservableQuery.js +15 -0
  303. package/dist/esm/DataTables/DataTableForObservableQuery.js.map +1 -0
  304. package/dist/esm/DataTables/DataTableForObservableQuery.stories.d.ts +8 -0
  305. package/dist/esm/DataTables/DataTableForObservableQuery.stories.d.ts.map +1 -0
  306. package/dist/esm/DataTables/DataTableForObservableQuery.stories.js +6 -0
  307. package/dist/esm/DataTables/DataTableForObservableQuery.stories.js.map +1 -0
  308. package/dist/esm/DataTables/DataTableForQuery.d.ts +17 -0
  309. package/dist/esm/DataTables/DataTableForQuery.d.ts.map +1 -0
  310. package/dist/esm/DataTables/DataTableForQuery.js +15 -0
  311. package/dist/esm/DataTables/DataTableForQuery.js.map +1 -0
  312. package/dist/esm/DataTables/DataTableForQuery.stories.d.ts +8 -0
  313. package/dist/esm/DataTables/DataTableForQuery.stories.d.ts.map +1 -0
  314. package/dist/esm/DataTables/DataTableForQuery.stories.js +6 -0
  315. package/dist/esm/DataTables/DataTableForQuery.stories.js.map +1 -0
  316. package/dist/esm/DataTables/index.d.ts +3 -0
  317. package/dist/esm/DataTables/index.d.ts.map +1 -0
  318. package/dist/esm/DataTables/index.js +3 -0
  319. package/dist/esm/DataTables/index.js.map +1 -0
  320. package/dist/esm/Dialogs/BusyIndicatorDialog.d.ts +3 -0
  321. package/dist/esm/Dialogs/BusyIndicatorDialog.d.ts.map +1 -0
  322. package/dist/esm/Dialogs/BusyIndicatorDialog.js +11 -0
  323. package/dist/esm/Dialogs/BusyIndicatorDialog.js.map +1 -0
  324. package/dist/esm/Dialogs/BusyIndicatorDialog.stories.d.ts +7 -0
  325. package/dist/esm/Dialogs/BusyIndicatorDialog.stories.d.ts.map +1 -0
  326. package/dist/esm/Dialogs/BusyIndicatorDialog.stories.js +15 -0
  327. package/dist/esm/Dialogs/BusyIndicatorDialog.stories.js.map +1 -0
  328. package/dist/esm/Dialogs/ConfirmationDialog.d.ts +2 -0
  329. package/dist/esm/Dialogs/ConfirmationDialog.d.ts.map +1 -0
  330. package/dist/esm/Dialogs/ConfirmationDialog.js +31 -0
  331. package/dist/esm/Dialogs/ConfirmationDialog.js.map +1 -0
  332. package/dist/esm/Dialogs/ConfirmationDialog.stories.d.ts +7 -0
  333. package/dist/esm/Dialogs/ConfirmationDialog.stories.d.ts.map +1 -0
  334. package/dist/esm/Dialogs/ConfirmationDialog.stories.js +20 -0
  335. package/dist/esm/Dialogs/ConfirmationDialog.stories.js.map +1 -0
  336. package/dist/esm/Dialogs/index.d.ts +3 -0
  337. package/dist/esm/Dialogs/index.d.ts.map +1 -0
  338. package/dist/esm/Dialogs/index.js +3 -0
  339. package/dist/esm/Dialogs/index.js.map +1 -0
  340. package/dist/esm/Dropdown/Dropdown.d.ts +5 -0
  341. package/dist/esm/Dropdown/Dropdown.d.ts.map +1 -0
  342. package/dist/esm/Dropdown/Dropdown.js +13 -0
  343. package/dist/esm/Dropdown/Dropdown.js.map +1 -0
  344. package/dist/esm/Dropdown/index.d.ts +2 -0
  345. package/dist/esm/Dropdown/index.d.ts.map +1 -0
  346. package/dist/esm/Dropdown/index.js +2 -0
  347. package/dist/esm/Dropdown/index.js.map +1 -0
  348. package/dist/esm/PivotViewer/PivotViewer.d.ts +4 -0
  349. package/dist/esm/PivotViewer/PivotViewer.d.ts.map +1 -0
  350. package/dist/esm/PivotViewer/PivotViewer.js +523 -0
  351. package/dist/esm/PivotViewer/PivotViewer.js.map +1 -0
  352. package/dist/esm/PivotViewer/PivotViewer.stories.d.ts +7 -0
  353. package/dist/esm/PivotViewer/PivotViewer.stories.d.ts.map +1 -0
  354. package/dist/esm/PivotViewer/PivotViewer.stories.js +12 -0
  355. package/dist/esm/PivotViewer/PivotViewer.stories.js.map +1 -0
  356. package/dist/esm/PivotViewer/components/AxisLabels.d.ts +13 -0
  357. package/dist/esm/PivotViewer/components/AxisLabels.d.ts.map +1 -0
  358. package/dist/esm/PivotViewer/components/AxisLabels.js +25 -0
  359. package/dist/esm/PivotViewer/components/AxisLabels.js.map +1 -0
  360. package/dist/esm/PivotViewer/components/DetailPanel.d.ts +6 -0
  361. package/dist/esm/PivotViewer/components/DetailPanel.d.ts.map +1 -0
  362. package/dist/esm/PivotViewer/components/DetailPanel.js +33 -0
  363. package/dist/esm/PivotViewer/components/DetailPanel.js.map +1 -0
  364. package/dist/esm/PivotViewer/components/FilterPanel.d.ts +27 -0
  365. package/dist/esm/PivotViewer/components/FilterPanel.d.ts.map +1 -0
  366. package/dist/esm/PivotViewer/components/FilterPanel.js +57 -0
  367. package/dist/esm/PivotViewer/components/FilterPanel.js.map +1 -0
  368. package/dist/esm/PivotViewer/components/FilterPanelContainer.d.ts +4 -0
  369. package/dist/esm/PivotViewer/components/FilterPanelContainer.d.ts.map +1 -0
  370. package/dist/esm/PivotViewer/components/FilterPanelContainer.js +9 -0
  371. package/dist/esm/PivotViewer/components/FilterPanelContainer.js.map +1 -0
  372. package/dist/esm/PivotViewer/components/PivotCanvas.d.ts +29 -0
  373. package/dist/esm/PivotViewer/components/PivotCanvas.d.ts.map +1 -0
  374. package/dist/esm/PivotViewer/components/PivotCanvas.js +373 -0
  375. package/dist/esm/PivotViewer/components/PivotCanvas.js.map +1 -0
  376. package/dist/esm/PivotViewer/components/PivotViewerMain.d.ts +43 -0
  377. package/dist/esm/PivotViewer/components/PivotViewerMain.d.ts.map +1 -0
  378. package/dist/esm/PivotViewer/components/PivotViewerMain.js +79 -0
  379. package/dist/esm/PivotViewer/components/PivotViewerMain.js.map +1 -0
  380. package/dist/esm/PivotViewer/components/RangeHistogramFilter.d.ts +11 -0
  381. package/dist/esm/PivotViewer/components/RangeHistogramFilter.d.ts.map +1 -0
  382. package/dist/esm/PivotViewer/components/RangeHistogramFilter.js +122 -0
  383. package/dist/esm/PivotViewer/components/RangeHistogramFilter.js.map +1 -0
  384. package/dist/esm/PivotViewer/components/Spinner.d.ts +3 -0
  385. package/dist/esm/PivotViewer/components/Spinner.d.ts.map +1 -0
  386. package/dist/esm/PivotViewer/components/Spinner.js +9 -0
  387. package/dist/esm/PivotViewer/components/Spinner.js.map +1 -0
  388. package/dist/esm/PivotViewer/components/Toolbar.d.ts +21 -0
  389. package/dist/esm/PivotViewer/components/Toolbar.d.ts.map +1 -0
  390. package/dist/esm/PivotViewer/components/Toolbar.js +10 -0
  391. package/dist/esm/PivotViewer/components/Toolbar.js.map +1 -0
  392. package/dist/esm/PivotViewer/components/ToolbarContainer.d.ts +4 -0
  393. package/dist/esm/PivotViewer/components/ToolbarContainer.d.ts.map +1 -0
  394. package/dist/esm/PivotViewer/components/ToolbarContainer.js +9 -0
  395. package/dist/esm/PivotViewer/components/ToolbarContainer.js.map +1 -0
  396. package/dist/esm/PivotViewer/components/index.d.ts +9 -0
  397. package/dist/esm/PivotViewer/components/index.d.ts.map +1 -0
  398. package/dist/esm/PivotViewer/components/index.js +8 -0
  399. package/dist/esm/PivotViewer/components/index.js.map +1 -0
  400. package/dist/esm/PivotViewer/components/pivot/animation.d.ts +29 -0
  401. package/dist/esm/PivotViewer/components/pivot/animation.d.ts.map +1 -0
  402. package/dist/esm/PivotViewer/components/pivot/animation.js +79 -0
  403. package/dist/esm/PivotViewer/components/pivot/animation.js.map +1 -0
  404. package/dist/esm/PivotViewer/components/pivot/buckets.d.ts +6 -0
  405. package/dist/esm/PivotViewer/components/pivot/buckets.d.ts.map +1 -0
  406. package/dist/esm/PivotViewer/components/pivot/buckets.js +102 -0
  407. package/dist/esm/PivotViewer/components/pivot/buckets.js.map +1 -0
  408. package/dist/esm/PivotViewer/components/pivot/colorResolver.d.ts +4 -0
  409. package/dist/esm/PivotViewer/components/pivot/colorResolver.d.ts.map +1 -0
  410. package/dist/esm/PivotViewer/components/pivot/colorResolver.js +61 -0
  411. package/dist/esm/PivotViewer/components/pivot/colorResolver.js.map +1 -0
  412. package/dist/esm/PivotViewer/components/pivot/constants.d.ts +38 -0
  413. package/dist/esm/PivotViewer/components/pivot/constants.d.ts.map +1 -0
  414. package/dist/esm/PivotViewer/components/pivot/constants.js +14 -0
  415. package/dist/esm/PivotViewer/components/pivot/constants.js.map +1 -0
  416. package/dist/esm/PivotViewer/components/pivot/sprites.d.ts +6 -0
  417. package/dist/esm/PivotViewer/components/pivot/sprites.d.ts.map +1 -0
  418. package/dist/esm/PivotViewer/components/pivot/sprites.js +203 -0
  419. package/dist/esm/PivotViewer/components/pivot/sprites.js.map +1 -0
  420. package/dist/esm/PivotViewer/components/pivot/visibility.d.ts +26 -0
  421. package/dist/esm/PivotViewer/components/pivot/visibility.d.ts.map +1 -0
  422. package/dist/esm/PivotViewer/components/pivot/visibility.js +221 -0
  423. package/dist/esm/PivotViewer/components/pivot/visibility.js.map +1 -0
  424. package/dist/esm/PivotViewer/constants.d.ts +7 -0
  425. package/dist/esm/PivotViewer/constants.d.ts.map +1 -0
  426. package/dist/esm/PivotViewer/constants.js +9 -0
  427. package/dist/esm/PivotViewer/constants.js.map +1 -0
  428. package/dist/esm/PivotViewer/engine/layout.d.ts +3 -0
  429. package/dist/esm/PivotViewer/engine/layout.d.ts.map +1 -0
  430. package/dist/esm/PivotViewer/engine/layout.js +93 -0
  431. package/dist/esm/PivotViewer/engine/layout.js.map +1 -0
  432. package/dist/esm/PivotViewer/engine/pivot.worker.d.ts +2 -0
  433. package/dist/esm/PivotViewer/engine/pivot.worker.d.ts.map +1 -0
  434. package/dist/esm/PivotViewer/engine/pivot.worker.js +58 -0
  435. package/dist/esm/PivotViewer/engine/pivot.worker.js.map +1 -0
  436. package/dist/esm/PivotViewer/engine/store.d.ts +9 -0
  437. package/dist/esm/PivotViewer/engine/store.d.ts.map +1 -0
  438. package/dist/esm/PivotViewer/engine/store.js +328 -0
  439. package/dist/esm/PivotViewer/engine/store.js.map +1 -0
  440. package/dist/esm/PivotViewer/engine/types.d.ts +125 -0
  441. package/dist/esm/PivotViewer/engine/types.d.ts.map +1 -0
  442. package/dist/esm/PivotViewer/engine/types.js +2 -0
  443. package/dist/esm/PivotViewer/engine/types.js.map +1 -0
  444. package/dist/esm/PivotViewer/hooks/index.d.ts +11 -0
  445. package/dist/esm/PivotViewer/hooks/index.d.ts.map +1 -0
  446. package/dist/esm/PivotViewer/hooks/index.js +11 -0
  447. package/dist/esm/PivotViewer/hooks/index.js.map +1 -0
  448. package/dist/esm/PivotViewer/hooks/useContainerDimensions.d.ts +5 -0
  449. package/dist/esm/PivotViewer/hooks/useContainerDimensions.d.ts.map +1 -0
  450. package/dist/esm/PivotViewer/hooks/useContainerDimensions.js +28 -0
  451. package/dist/esm/PivotViewer/hooks/useContainerDimensions.js.map +1 -0
  452. package/dist/esm/PivotViewer/hooks/useDimensionState.d.ts +11 -0
  453. package/dist/esm/PivotViewer/hooks/useDimensionState.d.ts.map +1 -0
  454. package/dist/esm/PivotViewer/hooks/useDimensionState.js +41 -0
  455. package/dist/esm/PivotViewer/hooks/useDimensionState.js.map +1 -0
  456. package/dist/esm/PivotViewer/hooks/useFilterOptions.d.ts +12 -0
  457. package/dist/esm/PivotViewer/hooks/useFilterOptions.d.ts.map +1 -0
  458. package/dist/esm/PivotViewer/hooks/useFilterOptions.js +22 -0
  459. package/dist/esm/PivotViewer/hooks/useFilterOptions.js.map +1 -0
  460. package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.d.ts +9 -0
  461. package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.d.ts.map +1 -0
  462. package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.js +42 -0
  463. package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.js.map +1 -0
  464. package/dist/esm/PivotViewer/hooks/useFilterState.d.ts +11 -0
  465. package/dist/esm/PivotViewer/hooks/useFilterState.d.ts.map +1 -0
  466. package/dist/esm/PivotViewer/hooks/useFilterState.js +94 -0
  467. package/dist/esm/PivotViewer/hooks/useFilterState.js.map +1 -0
  468. package/dist/esm/PivotViewer/hooks/useFilteredData.d.ts +9 -0
  469. package/dist/esm/PivotViewer/hooks/useFilteredData.d.ts.map +1 -0
  470. package/dist/esm/PivotViewer/hooks/useFilteredData.js +85 -0
  471. package/dist/esm/PivotViewer/hooks/useFilteredData.js.map +1 -0
  472. package/dist/esm/PivotViewer/hooks/usePanning.d.ts +10 -0
  473. package/dist/esm/PivotViewer/hooks/usePanning.d.ts.map +1 -0
  474. package/dist/esm/PivotViewer/hooks/usePanning.js +118 -0
  475. package/dist/esm/PivotViewer/hooks/usePanning.js.map +1 -0
  476. package/dist/esm/PivotViewer/hooks/usePivotEngine.d.ts +14 -0
  477. package/dist/esm/PivotViewer/hooks/usePivotEngine.d.ts.map +1 -0
  478. package/dist/esm/PivotViewer/hooks/usePivotEngine.js +180 -0
  479. package/dist/esm/PivotViewer/hooks/usePivotEngine.js.map +1 -0
  480. package/dist/esm/PivotViewer/hooks/useSelectedItem.d.ts +8 -0
  481. package/dist/esm/PivotViewer/hooks/useSelectedItem.d.ts.map +1 -0
  482. package/dist/esm/PivotViewer/hooks/useSelectedItem.js +322 -0
  483. package/dist/esm/PivotViewer/hooks/useSelectedItem.js.map +1 -0
  484. package/dist/esm/PivotViewer/hooks/useWheelZoom.d.ts +2 -0
  485. package/dist/esm/PivotViewer/hooks/useWheelZoom.d.ts.map +1 -0
  486. package/dist/esm/PivotViewer/hooks/useWheelZoom.js +91 -0
  487. package/dist/esm/PivotViewer/hooks/useWheelZoom.js.map +1 -0
  488. package/dist/esm/PivotViewer/hooks/useZoomState.d.ts +9 -0
  489. package/dist/esm/PivotViewer/hooks/useZoomState.d.ts.map +1 -0
  490. package/dist/esm/PivotViewer/hooks/useZoomState.js +29 -0
  491. package/dist/esm/PivotViewer/hooks/useZoomState.js.map +1 -0
  492. package/dist/esm/PivotViewer/index.d.ts +4 -0
  493. package/dist/esm/PivotViewer/index.d.ts.map +1 -0
  494. package/dist/esm/PivotViewer/index.js +2 -0
  495. package/dist/esm/PivotViewer/index.js.map +1 -0
  496. package/dist/esm/PivotViewer/types.d.ts +47 -0
  497. package/dist/esm/PivotViewer/types.d.ts.map +1 -0
  498. package/dist/esm/PivotViewer/types.js +2 -0
  499. package/dist/esm/PivotViewer/types.js.map +1 -0
  500. package/dist/esm/PivotViewer/utils/animations.d.ts +54 -0
  501. package/dist/esm/PivotViewer/utils/animations.d.ts.map +1 -0
  502. package/dist/esm/PivotViewer/utils/animations.js +139 -0
  503. package/dist/esm/PivotViewer/utils/animations.js.map +1 -0
  504. package/dist/esm/PivotViewer/utils/constants.d.ts +13 -0
  505. package/dist/esm/PivotViewer/utils/constants.d.ts.map +1 -0
  506. package/dist/esm/PivotViewer/utils/constants.js +7 -0
  507. package/dist/esm/PivotViewer/utils/constants.js.map +1 -0
  508. package/dist/esm/PivotViewer/utils/index.d.ts +4 -0
  509. package/dist/esm/PivotViewer/utils/index.d.ts.map +1 -0
  510. package/dist/esm/PivotViewer/utils/index.js +4 -0
  511. package/dist/esm/PivotViewer/utils/index.js.map +1 -0
  512. package/dist/esm/PivotViewer/utils/selection.d.ts +50 -0
  513. package/dist/esm/PivotViewer/utils/selection.d.ts.map +1 -0
  514. package/dist/esm/PivotViewer/utils/selection.js +134 -0
  515. package/dist/esm/PivotViewer/utils/selection.js.map +1 -0
  516. package/dist/esm/PivotViewer/utils/utils.d.ts +24 -0
  517. package/dist/esm/PivotViewer/utils/utils.d.ts.map +1 -0
  518. package/dist/esm/PivotViewer/utils/utils.js +138 -0
  519. package/dist/esm/PivotViewer/utils/utils.js.map +1 -0
  520. package/dist/esm/TimeMachine/EventsView.d.ts +9 -0
  521. package/dist/esm/TimeMachine/EventsView.d.ts.map +1 -0
  522. package/dist/esm/TimeMachine/EventsView.js +55 -0
  523. package/dist/esm/TimeMachine/EventsView.js.map +1 -0
  524. package/dist/esm/TimeMachine/EventsView.stories.d.ts +8 -0
  525. package/dist/esm/TimeMachine/EventsView.stories.d.ts.map +1 -0
  526. package/dist/esm/TimeMachine/EventsView.stories.js +6 -0
  527. package/dist/esm/TimeMachine/EventsView.stories.js.map +1 -0
  528. package/dist/esm/TimeMachine/Properties.d.ts +9 -0
  529. package/dist/esm/TimeMachine/Properties.d.ts.map +1 -0
  530. package/dist/esm/TimeMachine/Properties.js +56 -0
  531. package/dist/esm/TimeMachine/Properties.js.map +1 -0
  532. package/dist/esm/TimeMachine/Properties.stories.d.ts +8 -0
  533. package/dist/esm/TimeMachine/Properties.stories.d.ts.map +1 -0
  534. package/dist/esm/TimeMachine/Properties.stories.js +6 -0
  535. package/dist/esm/TimeMachine/Properties.stories.js.map +1 -0
  536. package/dist/esm/TimeMachine/ReadModelView.d.ts +12 -0
  537. package/dist/esm/TimeMachine/ReadModelView.d.ts.map +1 -0
  538. package/dist/esm/TimeMachine/ReadModelView.js +38 -0
  539. package/dist/esm/TimeMachine/ReadModelView.js.map +1 -0
  540. package/dist/esm/TimeMachine/ReadModelView.stories.d.ts +8 -0
  541. package/dist/esm/TimeMachine/ReadModelView.stories.d.ts.map +1 -0
  542. package/dist/esm/TimeMachine/ReadModelView.stories.js +6 -0
  543. package/dist/esm/TimeMachine/ReadModelView.stories.js.map +1 -0
  544. package/dist/esm/TimeMachine/TimeMachine.d.ts +12 -0
  545. package/dist/esm/TimeMachine/TimeMachine.d.ts.map +1 -0
  546. package/dist/esm/TimeMachine/TimeMachine.js +93 -0
  547. package/dist/esm/TimeMachine/TimeMachine.js.map +1 -0
  548. package/dist/esm/TimeMachine/TimeMachine.stories.d.ts +8 -0
  549. package/dist/esm/TimeMachine/TimeMachine.stories.d.ts.map +1 -0
  550. package/dist/esm/TimeMachine/TimeMachine.stories.js +6 -0
  551. package/dist/esm/TimeMachine/TimeMachine.stories.js.map +1 -0
  552. package/dist/esm/TimeMachine/index.d.ts +6 -0
  553. package/dist/esm/TimeMachine/index.d.ts.map +1 -0
  554. package/dist/esm/TimeMachine/index.js +5 -0
  555. package/dist/esm/TimeMachine/index.js.map +1 -0
  556. package/dist/esm/TimeMachine/types.d.ts +19 -0
  557. package/dist/esm/TimeMachine/types.d.ts.map +1 -0
  558. package/dist/esm/TimeMachine/types.js +2 -0
  559. package/dist/esm/TimeMachine/types.js.map +1 -0
  560. package/dist/esm/index.d.ts +10 -0
  561. package/dist/esm/index.d.ts.map +1 -0
  562. package/dist/esm/index.js +17 -0
  563. package/dist/esm/index.js.map +1 -0
  564. package/dist/esm/tsconfig.tsbuildinfo +1 -0
  565. package/dist/esm/useOverlayZIndex.d.ts +2 -0
  566. package/dist/esm/useOverlayZIndex.d.ts.map +1 -0
  567. package/dist/esm/useOverlayZIndex.js +22 -0
  568. package/dist/esm/useOverlayZIndex.js.map +1 -0
  569. package/dist/esm/vite.config.d.ts +3 -0
  570. package/dist/esm/vite.config.d.ts.map +1 -0
  571. package/dist/esm/vite.config.js +76 -0
  572. package/dist/esm/vite.config.js.map +1 -0
  573. package/global.d.ts +11 -0
  574. package/index.ts +22 -0
  575. package/package.json +160 -0
  576. package/useOverlayZIndex.ts +32 -0
  577. package/vite.config.ts +80 -0
@@ -0,0 +1,229 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import type { ReactNode } from 'react';
5
+ import type { ItemId, LayoutResult, GroupingResult } from '../engine/types';
6
+ import type { ViewMode } from './Toolbar';
7
+ import type { PivotDimensionFilter } from '../hooks/useDimensionState';
8
+ import { Spinner } from './Spinner';
9
+ import { PivotCanvas } from './PivotCanvas';
10
+ import { AxisLabels } from './AxisLabels';
11
+ import { DetailPanel } from './DetailPanel';
12
+
13
+ export interface PivotViewerMainProps<TItem extends object> {
14
+ data: TItem[];
15
+ ready: boolean;
16
+ isLoading: boolean;
17
+ visibleIds: Uint32Array;
18
+ grouping: GroupingResult;
19
+ layout: LayoutResult;
20
+ cardWidth: number;
21
+ cardHeight: number;
22
+ zoomLevel: number;
23
+ scrollPosition: { x: number; y: number };
24
+ containerDimensions: { width: number; height: number };
25
+ selectedItem: TItem | null;
26
+ hoveredGroupIndex: number | null;
27
+ isZooming: boolean;
28
+ viewMode: ViewMode;
29
+ cardRenderer?: (item: TItem) => ReactNode;
30
+ resolveId: (item: TItem, index: number) => ItemId;
31
+ emptyContent?: ReactNode;
32
+ dimensionFilter: PivotDimensionFilter;
33
+ onCardClick: (item: TItem, e: MouseEvent, id: number | string) => void;
34
+ onPanStart: (e: React.MouseEvent) => void;
35
+ onPanMove: (e: React.MouseEvent) => void;
36
+ onPanEnd: () => void;
37
+ onGroupHover: (index: number | null) => void;
38
+ onAxisLabelClick: (value: string) => void;
39
+ onCloseDetail: () => void;
40
+ containerRef: React.RefObject<HTMLDivElement | null>;
41
+ axisLabelsRef: React.RefObject<HTMLDivElement | null>;
42
+ spacerRef: React.RefObject<HTMLDivElement | null>;
43
+ }
44
+
45
+ export function PivotViewerMain<TItem extends object>({
46
+ data,
47
+ ready,
48
+ isLoading,
49
+ visibleIds,
50
+ grouping,
51
+ layout,
52
+ cardWidth,
53
+ cardHeight,
54
+ zoomLevel,
55
+ scrollPosition,
56
+ containerDimensions,
57
+ selectedItem,
58
+ hoveredGroupIndex,
59
+ isZooming,
60
+ viewMode,
61
+ cardRenderer,
62
+ resolveId,
63
+ emptyContent,
64
+ dimensionFilter,
65
+ onCardClick,
66
+ onPanStart,
67
+ onPanMove,
68
+ onPanEnd,
69
+ onGroupHover,
70
+ onAxisLabelClick,
71
+ onCloseDetail,
72
+ containerRef,
73
+ axisLabelsRef,
74
+ spacerRef,
75
+ }: PivotViewerMainProps<TItem>) {
76
+ const handleViewportClick = (e: React.MouseEvent) => {
77
+ if (isZooming || !containerRef.current) return;
78
+
79
+ const container = containerRef.current;
80
+ const rect = container.getBoundingClientRect();
81
+ // Use live DOM scroll position for accurate hit testing
82
+ const scrollLeft = container.scrollLeft;
83
+ const scrollTop = container.scrollTop;
84
+
85
+ const clickX = e.clientX - rect.left + scrollLeft;
86
+ const clickY = e.clientY - rect.top + scrollTop;
87
+
88
+ const worldX = clickX / zoomLevel;
89
+ const worldY = clickY / zoomLevel;
90
+
91
+ // Check visible items
92
+ for (let i = 0; i < visibleIds.length; i++) {
93
+ const id = visibleIds[i];
94
+ const pos = layout.positions.get(id);
95
+ if (pos) {
96
+ if (worldX >= pos.x && worldX <= pos.x + cardWidth &&
97
+ worldY >= pos.y && worldY <= pos.y + cardHeight) {
98
+ const item = data[id];
99
+ if (item) {
100
+ onCardClick(item, e.nativeEvent as unknown as MouseEvent, id);
101
+ }
102
+ return;
103
+ }
104
+ }
105
+ }
106
+ };
107
+
108
+ const handleViewportMouseMove = (e: React.MouseEvent) => {
109
+ if (isZooming || !containerRef.current) return;
110
+
111
+ const container = containerRef.current;
112
+ const rect = container.getBoundingClientRect();
113
+ const scrollLeft = container.scrollLeft;
114
+ const scrollTop = container.scrollTop;
115
+
116
+ const mouseX = e.clientX - rect.left + scrollLeft;
117
+ const mouseY = e.clientY - rect.top + scrollTop;
118
+
119
+ const worldX = mouseX / zoomLevel;
120
+ const worldY = mouseY / zoomLevel;
121
+
122
+ let isOverCard = false;
123
+ for (let i = 0; i < visibleIds.length; i++) {
124
+ const id = visibleIds[i];
125
+ const pos = layout.positions.get(id);
126
+ if (pos) {
127
+ if (worldX >= pos.x && worldX <= pos.x + cardWidth &&
128
+ worldY >= pos.y && worldY <= pos.y + cardHeight) {
129
+ isOverCard = true;
130
+ break;
131
+ }
132
+ }
133
+ }
134
+
135
+ container.style.cursor = isOverCard ? 'pointer' : 'default';
136
+ };
137
+
138
+ return isLoading ? (
139
+ <Spinner />
140
+ ) : (
141
+ <div className="pv-groups-wrapper">
142
+ <div style={{ position: 'relative', flex: 1, display: 'flex', flexDirection: 'column', minHeight: 0 }}>
143
+ <div
144
+ className={`pv-viewport ${isZooming ? 'pv-zooming' : ''}`}
145
+ ref={containerRef}
146
+ style={{ overflow: 'auto', position: 'absolute', top: 0, left: 0, right: 0, bottom: 0, zIndex: 1 }}
147
+ onClick={handleViewportClick}
148
+ onMouseMove={handleViewportMouseMove}
149
+ >
150
+ {/* Spacer for scrolling - explicitly rendered to allow synchronous updates during animation */}
151
+ <div
152
+ ref={spacerRef}
153
+ style={{
154
+ position: 'absolute',
155
+ top: 0,
156
+ left: 0,
157
+ width: layout.totalWidth * zoomLevel,
158
+ height: layout.totalHeight * zoomLevel,
159
+ pointerEvents: 'none'
160
+ }}
161
+ />
162
+
163
+ {!ready && (
164
+ <div className="pv-loading">Building indexes...</div>
165
+ )}
166
+
167
+ {ready && visibleIds.length === 0 && (
168
+ <div className="pv-empty">
169
+ {emptyContent ?? 'No items to display.'}
170
+ </div>
171
+ )}
172
+
173
+ {ready && visibleIds.length > 0 && (
174
+ <PivotCanvas
175
+ items={data}
176
+ layout={layout}
177
+ grouping={grouping}
178
+ visibleIds={visibleIds}
179
+ cardWidth={cardWidth}
180
+ cardHeight={cardHeight}
181
+ zoomLevel={zoomLevel}
182
+ panX={scrollPosition.x}
183
+ panY={scrollPosition.y}
184
+ viewportWidth={containerDimensions.width}
185
+ viewportHeight={containerDimensions.height}
186
+ selectedId={selectedItem ? resolveId(selectedItem, 0) : null}
187
+ hoveredGroupIndex={hoveredGroupIndex}
188
+ isZooming={isZooming}
189
+ cardRenderer={cardRenderer}
190
+ resolveId={resolveId}
191
+ onCardClick={onCardClick}
192
+ onPanStart={onPanStart as any}
193
+ onPanMove={onPanMove as any}
194
+ onPanEnd={onPanEnd}
195
+ containerRef={containerRef}
196
+ viewMode={viewMode}
197
+ />
198
+ )}
199
+ </div>
200
+ <DetailPanel
201
+ selectedItem={selectedItem}
202
+ onClose={onCloseDetail}
203
+ />
204
+ </div>
205
+
206
+ {viewMode === 'grouped' && grouping.groups.length > 0 && (
207
+ <AxisLabels
208
+ groups={grouping.groups.map((g) => ({
209
+ key: g.key,
210
+ value: g.value,
211
+ label: String(g.value),
212
+ items: [],
213
+ count: g.ids.length,
214
+ }))}
215
+ bucketWidths={layout.bucketWidths || []}
216
+ zoomLevel={zoomLevel}
217
+ dimensionFilter={dimensionFilter}
218
+ hoveredGroup={hoveredGroupIndex !== null ? String(grouping.groups[hoveredGroupIndex]?.value) : null}
219
+ onHover={(label) => {
220
+ const index = grouping.groups.findIndex(g => String(g.value) === label);
221
+ onGroupHover(index >= 0 ? index : null);
222
+ }}
223
+ onClick={onAxisLabelClick}
224
+ containerRef={axisLabelsRef}
225
+ />
226
+ )}
227
+ </div>
228
+ );
229
+ }
@@ -0,0 +1,220 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import { useCallback, useEffect, useMemo, useRef, useState } from 'react';
5
+ import type { PivotPrimitive } from '../types';
6
+
7
+ export interface RangeHistogramFilterProps {
8
+ values: PivotPrimitive[];
9
+ min: number;
10
+ max: number;
11
+ buckets?: number;
12
+ selectedRange: [number, number] | null;
13
+ onChange: (range: [number, number] | null) => void;
14
+ }
15
+
16
+ interface HistogramBucket {
17
+ start: number;
18
+ end: number;
19
+ count: number;
20
+ maxCount: number;
21
+ }
22
+
23
+ export function RangeHistogramFilter({
24
+ values,
25
+ min,
26
+ max,
27
+ buckets = 20,
28
+ selectedRange,
29
+ onChange,
30
+ }: RangeHistogramFilterProps) {
31
+ const containerRef = useRef<HTMLDivElement>(null);
32
+ const [isDragging, setIsDragging] = useState<'left' | 'right' | 'range' | null>(null);
33
+ const [dragStart, setDragStart] = useState<{ x: number; range: [number, number] } | null>(null);
34
+
35
+ const numericValues = useMemo(() => {
36
+ return values
37
+ .map((v) => {
38
+ if (typeof v === 'number') return v;
39
+ if (v instanceof Date) return v.getTime();
40
+ const parsed = Number(v);
41
+ return Number.isNaN(parsed) ? null : parsed;
42
+ })
43
+ .filter((v): v is number => v !== null);
44
+ }, [values]);
45
+
46
+ const histogram = useMemo((): HistogramBucket[] => {
47
+ const range = max - min;
48
+ if (range <= 0 || numericValues.length === 0) {
49
+ return [];
50
+ }
51
+
52
+ const bucketSize = range / buckets;
53
+ const bucketCounts: number[] = Array(buckets).fill(0);
54
+
55
+ numericValues.forEach((value) => {
56
+ const bucketIndex = Math.min(
57
+ Math.floor((value - min) / bucketSize),
58
+ buckets - 1
59
+ );
60
+ if (bucketIndex >= 0 && bucketIndex < buckets) {
61
+ bucketCounts[bucketIndex]++;
62
+ }
63
+ });
64
+
65
+ const maxCount = Math.max(...bucketCounts, 1);
66
+
67
+ return bucketCounts.map((count, i) => ({
68
+ start: min + i * bucketSize,
69
+ end: min + (i + 1) * bucketSize,
70
+ count,
71
+ maxCount,
72
+ }));
73
+ }, [numericValues, min, max, buckets]);
74
+
75
+ const currentRange = selectedRange ?? [min, max];
76
+
77
+ const getPositionFromValue = useCallback(
78
+ (value: number) => {
79
+ const range = max - min;
80
+ if (range <= 0) return 0;
81
+ return ((value - min) / range) * 100;
82
+ },
83
+ [min, max]
84
+ );
85
+
86
+ const handleMouseDown = (
87
+ e: React.MouseEvent,
88
+ handle: 'left' | 'right' | 'range'
89
+ ) => {
90
+ (e as any).preventDefault?.();
91
+ setIsDragging(handle);
92
+ setDragStart({ x: e.clientX, range: [...currentRange] as [number, number] });
93
+ };
94
+
95
+ useEffect(() => {
96
+ if (!isDragging || !dragStart || !containerRef.current) return;
97
+
98
+ const container = containerRef.current;
99
+ const rect = container.getBoundingClientRect();
100
+ const range = max - min;
101
+
102
+ const handleMouseMove = (e: MouseEvent) => {
103
+ const deltaX = e.clientX - dragStart.x;
104
+ const deltaPercent = (deltaX / rect.width) * 100;
105
+ const deltaValue = (deltaPercent / 100) * range;
106
+
107
+ let newRange: [number, number] = [...dragStart.range];
108
+
109
+ if (isDragging === 'left') {
110
+ newRange[0] = Math.max(min, Math.min(dragStart.range[0] + deltaValue, newRange[1] - range * 0.01));
111
+ } else if (isDragging === 'right') {
112
+ newRange[1] = Math.min(max, Math.max(dragStart.range[1] + deltaValue, newRange[0] + range * 0.01));
113
+ } else if (isDragging === 'range') {
114
+ const rangeWidth = dragStart.range[1] - dragStart.range[0];
115
+ let newStart = dragStart.range[0] + deltaValue;
116
+ let newEnd = dragStart.range[1] + deltaValue;
117
+
118
+ if (newStart < min) {
119
+ newStart = min;
120
+ newEnd = min + rangeWidth;
121
+ }
122
+ if (newEnd > max) {
123
+ newEnd = max;
124
+ newStart = max - rangeWidth;
125
+ }
126
+
127
+ newRange = [newStart, newEnd];
128
+ }
129
+
130
+ onChange(newRange);
131
+ };
132
+
133
+ const handleMouseUp = () => {
134
+ setIsDragging(null);
135
+ setDragStart(null);
136
+ };
137
+
138
+ document.addEventListener('mousemove', handleMouseMove);
139
+ document.addEventListener('mouseup', handleMouseUp);
140
+
141
+ return () => {
142
+ document.removeEventListener('mousemove', handleMouseMove);
143
+ document.removeEventListener('mouseup', handleMouseUp);
144
+ };
145
+ }, [isDragging, dragStart, min, max, onChange]);
146
+
147
+ const handleBarClick = (bucket: HistogramBucket) => {
148
+ onChange([bucket.start, bucket.end]);
149
+ };
150
+
151
+ const handleClear = () => {
152
+ onChange(null);
153
+ };
154
+
155
+ const leftPos = getPositionFromValue(currentRange[0]);
156
+ const rightPos = getPositionFromValue(currentRange[1]);
157
+
158
+ const formatValue = (value: number) => {
159
+ if (Number.isInteger(value)) return value.toString();
160
+ return value.toFixed(1);
161
+ };
162
+
163
+ return (
164
+ <div className="pv-range-histogram" ref={containerRef}>
165
+ <div className="pv-histogram-bars">
166
+ {histogram.map((bucket, i) => {
167
+ const heightPercent = (bucket.count / bucket.maxCount) * 100;
168
+ const isInRange =
169
+ bucket.start >= currentRange[0] && bucket.end <= currentRange[1];
170
+ const isPartiallyInRange =
171
+ bucket.end > currentRange[0] && bucket.start < currentRange[1];
172
+
173
+ return (
174
+ <button
175
+ key={i}
176
+ className={`pv-histogram-bar ${isInRange ? 'in-range' : ''} ${isPartiallyInRange && !isInRange ? 'partial' : ''}`}
177
+ style={{ height: `${heightPercent}%` }}
178
+ onClick={() => handleBarClick(bucket)}
179
+ title={`${formatValue(bucket.start)} - ${formatValue(bucket.end)}: ${bucket.count} items`}
180
+ type="button"
181
+ />
182
+ );
183
+ })}
184
+ </div>
185
+
186
+ <div className="pv-range-slider">
187
+ <div className="pv-range-track" />
188
+ <div
189
+ className="pv-range-selection"
190
+ style={{
191
+ left: `${leftPos}%`,
192
+ width: `${rightPos - leftPos}%`,
193
+ }}
194
+ onMouseDown={(e) => handleMouseDown(e, 'range')}
195
+ />
196
+ <div
197
+ className="pv-range-handle pv-range-handle-left"
198
+ style={{ left: `${leftPos}%` }}
199
+ onMouseDown={(e) => handleMouseDown(e, 'left')}
200
+ />
201
+ <div
202
+ className="pv-range-handle pv-range-handle-right"
203
+ style={{ left: `${rightPos}%` }}
204
+ onMouseDown={(e) => handleMouseDown(e, 'right')}
205
+ />
206
+ </div>
207
+
208
+ <div className="pv-range-labels">
209
+ <span className="pv-range-value">{formatValue(currentRange[0])}</span>
210
+ <span className="pv-range-value">{formatValue(currentRange[1])}</span>
211
+ </div>
212
+
213
+ {selectedRange && (
214
+ <button type="button" className="pv-range-clear" onClick={handleClear}>
215
+ Clear Range
216
+ </button>
217
+ )}
218
+ </div>
219
+ );
220
+ }
@@ -0,0 +1,21 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import './Spinner.css';
5
+
6
+ export function Spinner() {
7
+ return (
8
+ <div className="pv-loading">
9
+ <div className="pv-spinner">
10
+ <div className="pv-spinner-ring" />
11
+ <div className="pv-spinner-ring" />
12
+ <div className="pv-spinner-ring" />
13
+ <div className="pv-spinner-ring" />
14
+ <div className="pv-spinner-ring" />
15
+ <div className="pv-spinner-ring" />
16
+ <div className="pv-spinner-ring" />
17
+ <div className="pv-spinner-ring" />
18
+ </div>
19
+ </div>
20
+ );
21
+ }
@@ -0,0 +1,130 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import type { PivotDimension } from '../types';
5
+ import { ZOOM_MIN, ZOOM_MAX, ZOOM_STEP } from '../utils/utils';
6
+
7
+ export type ViewMode = 'collection' | 'grouped';
8
+
9
+ export interface ToolbarProps<TItem extends object> {
10
+ hasFilters: boolean;
11
+ filtersOpen: boolean;
12
+ filteredCount: number;
13
+ viewMode: ViewMode;
14
+ zoomLevel: number;
15
+ activeDimensionKey: string;
16
+ dimensions: PivotDimension<TItem>[];
17
+ activeFilterCount: number;
18
+ onFiltersToggle: () => void;
19
+ onViewModeChange: (mode: ViewMode) => void;
20
+ onZoomIn: () => void;
21
+ onZoomOut: () => void;
22
+ onZoomSlider: (e: React.ChangeEvent<HTMLInputElement>) => void;
23
+ onDimensionChange: (key: string) => void;
24
+ filterButtonRef: React.RefObject<HTMLButtonElement | null>;
25
+ }
26
+
27
+ export function Toolbar<TItem extends object>({
28
+ hasFilters,
29
+ filtersOpen,
30
+ filteredCount,
31
+ viewMode,
32
+ zoomLevel,
33
+ activeDimensionKey,
34
+ dimensions,
35
+ activeFilterCount,
36
+ onFiltersToggle,
37
+ onViewModeChange,
38
+ onZoomIn,
39
+ onZoomOut,
40
+ onZoomSlider,
41
+ onDimensionChange,
42
+ filterButtonRef,
43
+ }: ToolbarProps<TItem>) {
44
+ const labelText = 'Sort by';
45
+
46
+ return (
47
+ <header className="pv-toolbar">
48
+ <div className="pv-toolbar-left">
49
+ {hasFilters && (
50
+ <button
51
+ ref={filterButtonRef}
52
+ type="button"
53
+ className={`pv-filter-icon-button ${filtersOpen ? 'active' : ''}`}
54
+ onClick={onFiltersToggle}
55
+ title="Filters"
56
+ >
57
+ <svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round">
58
+ <polygon points="22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3" />
59
+ </svg>
60
+ {activeFilterCount > 0 && (
61
+ <span className="pv-filter-badge">{activeFilterCount}</span>
62
+ )}
63
+ </button>
64
+ )}
65
+ <h1>Pivot Viewer</h1>
66
+ <span className="pv-count">{filteredCount} events</span>
67
+ </div>
68
+ <div className="pv-toolbar-right">
69
+ <div className="pv-zoom-controls">
70
+ <button
71
+ type="button"
72
+ onClick={onZoomOut}
73
+ disabled={zoomLevel <= ZOOM_MIN}
74
+ title="Zoom out"
75
+ >
76
+
77
+ </button>
78
+ <input
79
+ type="range"
80
+ className="pv-zoom-slider"
81
+ min={ZOOM_MIN}
82
+ max={ZOOM_MAX}
83
+ step={ZOOM_STEP}
84
+ value={zoomLevel}
85
+ onChange={onZoomSlider}
86
+ title={`Zoom: ${Math.round(zoomLevel * 100)}%`}
87
+ />
88
+ <span className="pv-zoom-level">{Math.round(zoomLevel * 100)}%</span>
89
+ <button
90
+ type="button"
91
+ onClick={onZoomIn}
92
+ disabled={zoomLevel >= ZOOM_MAX}
93
+ title="Zoom in"
94
+ >
95
+ +
96
+ </button>
97
+ </div>
98
+ <div className="pv-view-toggle">
99
+ <button
100
+ type="button"
101
+ className={viewMode === 'collection' ? 'active' : ''}
102
+ onClick={() => onViewModeChange('collection')}
103
+ >
104
+ Collection
105
+ </button>
106
+ <button
107
+ type="button"
108
+ className={viewMode === 'grouped' ? 'active' : ''}
109
+ onClick={() => onViewModeChange('grouped')}
110
+ >
111
+ Buckets
112
+ </button>
113
+ </div>
114
+ <label className="pv-dimension-select">
115
+ <span>{labelText}</span>
116
+ <select
117
+ value={activeDimensionKey}
118
+ onChange={(event) => onDimensionChange(event.target.value)}
119
+ >
120
+ {dimensions.map((dimension) => (
121
+ <option key={dimension.key} value={dimension.key}>
122
+ {dimension.label}
123
+ </option>
124
+ ))}
125
+ </select>
126
+ </label>
127
+ </div>
128
+ </header>
129
+ );
130
+ }
@@ -0,0 +1,10 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ import { Toolbar, type ToolbarProps } from './Toolbar';
5
+
6
+ export type ToolbarContainerProps<TItem extends object> = ToolbarProps<TItem>;
7
+
8
+ export function ToolbarContainer<TItem extends object>(props: ToolbarContainerProps<TItem>) {
9
+ return <Toolbar {...props} />;
10
+ }
@@ -0,0 +1,12 @@
1
+ // Copyright (c) Cratis. All rights reserved.
2
+ // Licensed under the MIT license. See LICENSE file in the project root for full license information.
3
+
4
+ export { PivotCanvas } from './PivotCanvas';
5
+ export { FilterPanel } from './FilterPanel';
6
+ export { Toolbar } from './Toolbar';
7
+ export { DetailPanel } from './DetailPanel';
8
+ export { AxisLabels } from './AxisLabels';
9
+ export { Spinner } from './Spinner';
10
+ export { RangeHistogramFilter } from './RangeHistogramFilter';
11
+
12
+ export type { ViewMode } from './Toolbar';