@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,292 @@
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 { animateZoomAndScroll, calculateCenterScrollPosition, smoothScrollTo } from './animations';
5
+ import { ZOOM_MAX, MIN_ZOOM_ON_SELECT, ZOOM_MULTIPLIER, DETAIL_PANEL_WIDTH } from './constants';
6
+ import type { ViewMode } from '../components/Toolbar';
7
+
8
+ export interface SelectionState {
9
+ zoom: number;
10
+ scrollLeft: number;
11
+ scrollTop: number;
12
+ }
13
+
14
+ export interface CardClickHandlerParams<TItem> {
15
+ item: TItem;
16
+ itemId: string | number;
17
+ selectedItemId: string | number | null;
18
+ container: HTMLElement;
19
+ cardPosition: { x: number; y: number; width: number; height: number } | null;
20
+ targetCardPosition?: { x: number; y: number; width: number; height: number } | null;
21
+ getCardPositionAtZoom?: (zoom: number) => { x: number; y: number; width: number; height: number } | null;
22
+ getLayoutSizeAtZoom?: (zoom: number) => { width: number; height: number };
23
+ spacer?: HTMLElement | null;
24
+ viewMode: ViewMode;
25
+ zoomLevel: number;
26
+ totalHeight?: number;
27
+ preSelectionState: SelectionState | null;
28
+ startScrollPosition?: { x: number; y: number };
29
+ setZoomLevel: (zoom: number) => void;
30
+ setIsZooming: (isZooming: boolean) => void;
31
+ setSelectedItem: (item: TItem | null) => void;
32
+ setPreSelectionState: (state: SelectionState | null) => void;
33
+ }
34
+
35
+ /**
36
+ * Handle card click for selection with zoom and scroll animation
37
+ */
38
+ export function handleCardSelection<TItem>({
39
+ itemId,
40
+ selectedItemId,
41
+ container,
42
+ cardPosition,
43
+ targetCardPosition,
44
+ getCardPositionAtZoom,
45
+ getLayoutSizeAtZoom,
46
+ spacer,
47
+ viewMode,
48
+ zoomLevel,
49
+ totalHeight,
50
+ preSelectionState,
51
+ startScrollPosition,
52
+ setZoomLevel,
53
+ setIsZooming,
54
+ setSelectedItem,
55
+ setPreSelectionState,
56
+ item,
57
+ }: CardClickHandlerParams<TItem>): void {
58
+ // Clicking the same card - deselect
59
+ if (selectedItemId === itemId) {
60
+ deselectCard({
61
+ container,
62
+ cardPosition,
63
+ targetCardPosition,
64
+ getCardPositionAtZoom,
65
+ getLayoutSizeAtZoom,
66
+ spacer,
67
+ viewMode,
68
+ zoomLevel,
69
+ preSelectionState,
70
+ setZoomLevel,
71
+ setIsZooming,
72
+ setSelectedItem,
73
+ setPreSelectionState,
74
+ });
75
+ return;
76
+ }
77
+
78
+ // First selection - save state and zoom in
79
+ const isFirstSelection = selectedItemId === null;
80
+
81
+ if (isFirstSelection) {
82
+ setPreSelectionState({
83
+ zoom: zoomLevel,
84
+ scrollLeft: container.scrollLeft,
85
+ scrollTop: container.scrollTop,
86
+ });
87
+ }
88
+
89
+ setSelectedItem(item);
90
+
91
+ if (isFirstSelection) {
92
+ if (viewMode === 'collection') {
93
+ // Collection mode: just smooth scroll to center, no zoom
94
+ if (cardPosition) {
95
+ // In collection mode, we don't have a detail panel width offset because the panel is an overlay or separate
96
+ // But if we want to center it, we should consider if the detail panel pushes content
97
+ // For now, assume 0 offset as per original code
98
+ const { scrollLeft, scrollTop } = calculateCenterScrollPosition(container, cardPosition, zoomLevel, 0, totalHeight);
99
+ smoothScrollTo(container, scrollLeft, scrollTop, true);
100
+ }
101
+ } else {
102
+ // Grouped mode: animate zoom and scroll
103
+ zoomAndCenterCard({
104
+ container,
105
+ cardPosition,
106
+ targetCardPosition,
107
+ getCardPositionAtZoom,
108
+ getLayoutSizeAtZoom,
109
+ spacer,
110
+ itemId,
111
+ zoomLevel,
112
+ totalHeight,
113
+ startScrollPosition,
114
+ setZoomLevel,
115
+ setIsZooming,
116
+ });
117
+ }
118
+ } else {
119
+ // Subsequent selections: just center the new card
120
+ if (cardPosition) {
121
+ // In collection mode, we don't zoom, so we just center.
122
+ // In grouped mode, we might be zoomed in, so we center with offset.
123
+ const detailWidth = viewMode === 'collection' ? 0 : DETAIL_PANEL_WIDTH;
124
+ const { scrollLeft, scrollTop } = calculateCenterScrollPosition(container, cardPosition, zoomLevel, detailWidth, totalHeight);
125
+ smoothScrollTo(container, scrollLeft, scrollTop, true);
126
+ }
127
+ }
128
+ }
129
+
130
+ interface DeselectParams {
131
+ container: HTMLElement;
132
+ cardPosition: { x: number; y: number; width: number; height: number } | null;
133
+ targetCardPosition?: { x: number; y: number; width: number; height: number } | null;
134
+ getCardPositionAtZoom?: (zoom: number) => { x: number; y: number; width: number; height: number } | null;
135
+ getLayoutSizeAtZoom?: (zoom: number) => { width: number; height: number };
136
+ spacer?: HTMLElement | null;
137
+ viewMode: ViewMode;
138
+ zoomLevel: number;
139
+ preSelectionState: SelectionState | null;
140
+ setZoomLevel: (zoom: number) => void;
141
+ setIsZooming: (isZooming: boolean) => void;
142
+ setSelectedItem: (item: null) => void;
143
+ setPreSelectionState: (state: SelectionState | null) => void;
144
+ }
145
+
146
+ /**
147
+ * Deselect card with zoom-out animation if needed
148
+ */
149
+ function deselectCard({
150
+ container,
151
+ cardPosition,
152
+ targetCardPosition,
153
+ getCardPositionAtZoom,
154
+ getLayoutSizeAtZoom,
155
+ spacer,
156
+ viewMode,
157
+ zoomLevel,
158
+ preSelectionState,
159
+ setZoomLevel,
160
+ setIsZooming,
161
+ setSelectedItem,
162
+ setPreSelectionState,
163
+ }: DeselectParams): void {
164
+ if (!preSelectionState) {
165
+ setSelectedItem(null);
166
+ return;
167
+ }
168
+
169
+ // Collection mode: just scroll back
170
+ if (viewMode === 'collection') {
171
+ setSelectedItem(null);
172
+ smoothScrollTo(container, preSelectionState.scrollLeft, preSelectionState.scrollTop, true);
173
+ setPreSelectionState(null);
174
+ return;
175
+ }
176
+
177
+ // Grouped mode: check if zoom changed
178
+ const zoomChanged = Math.abs(preSelectionState.zoom - zoomLevel) > 0.001;
179
+
180
+ if (!zoomChanged || !cardPosition) {
181
+ setSelectedItem(null);
182
+ smoothScrollTo(container, preSelectionState.scrollLeft, preSelectionState.scrollTop, true);
183
+ setPreSelectionState(null);
184
+ return;
185
+ }
186
+
187
+ // Animate zoom out
188
+ setIsZooming(true);
189
+
190
+ animateZoomAndScroll({
191
+ container,
192
+ cardPosition,
193
+ targetCardPosition,
194
+ getCardPositionAtZoom,
195
+ getLayoutSizeAtZoom,
196
+ spacer,
197
+ startZoom: zoomLevel,
198
+ targetZoom: preSelectionState.zoom,
199
+ targetScrollLeft: preSelectionState.scrollLeft,
200
+ targetScrollTop: preSelectionState.scrollTop,
201
+ onUpdate: setZoomLevel,
202
+ onComplete: () => {
203
+ setIsZooming(false);
204
+ setSelectedItem(null);
205
+ setPreSelectionState(null);
206
+ },
207
+ });
208
+ }
209
+
210
+ interface ZoomAndCenterParams {
211
+ container: HTMLElement;
212
+ cardPosition: { x: number; y: number; width: number; height: number } | null;
213
+ targetCardPosition?: { x: number; y: number; width: number; height: number } | null;
214
+ getCardPositionAtZoom?: (zoom: number) => { x: number; y: number; width: number; height: number } | null;
215
+ getLayoutSizeAtZoom?: (zoom: number) => { width: number; height: number };
216
+ spacer?: HTMLElement | null;
217
+ itemId: string | number;
218
+ zoomLevel: number;
219
+ totalHeight?: number;
220
+ startScrollPosition?: { x: number; y: number };
221
+ setZoomLevel: (zoom: number) => void;
222
+ setIsZooming: (isZooming: boolean) => void;
223
+ }
224
+
225
+ /**
226
+ * Zoom in and center a card
227
+ */
228
+ function zoomAndCenterCard({
229
+ container,
230
+ cardPosition,
231
+ targetCardPosition,
232
+ getCardPositionAtZoom,
233
+ getLayoutSizeAtZoom,
234
+ spacer,
235
+ zoomLevel,
236
+ totalHeight,
237
+ startScrollPosition,
238
+ setZoomLevel,
239
+ setIsZooming,
240
+ }: ZoomAndCenterParams): void {
241
+ const targetZoom = Math.min(ZOOM_MAX, Math.max(MIN_ZOOM_ON_SELECT, zoomLevel * ZOOM_MULTIPLIER));
242
+ const shouldZoom = Math.abs(targetZoom - zoomLevel) > 0.001;
243
+
244
+ if (!shouldZoom || !cardPosition) {
245
+ if (cardPosition) {
246
+ const { scrollLeft, scrollTop } = calculateCenterScrollPosition(container, cardPosition, zoomLevel, DETAIL_PANEL_WIDTH, totalHeight);
247
+ smoothScrollTo(container, scrollLeft, scrollTop, true);
248
+ }
249
+ return;
250
+ }
251
+
252
+ setIsZooming(true);
253
+
254
+ // Use targetCardPosition if available, otherwise fallback to cardPosition
255
+ const { scrollLeft: targetScrollLeft, scrollTop: targetScrollTop } = calculateCenterScrollPosition(
256
+ container,
257
+ targetCardPosition || cardPosition,
258
+ targetZoom,
259
+ DETAIL_PANEL_WIDTH,
260
+ totalHeight
261
+ );
262
+
263
+ animateZoomAndScroll({
264
+ container,
265
+ cardPosition,
266
+ targetCardPosition,
267
+ getCardPositionAtZoom,
268
+ getLayoutSizeAtZoom,
269
+ spacer,
270
+ startZoom: zoomLevel,
271
+ targetZoom,
272
+ targetScrollLeft,
273
+ targetScrollTop,
274
+ startScrollLeft: startScrollPosition?.x,
275
+ startScrollTop: startScrollPosition?.y,
276
+ onUpdate: setZoomLevel,
277
+ onComplete: () => {
278
+ setIsZooming(false);
279
+ },
280
+ });
281
+ }
282
+
283
+ /**
284
+ * Get card element by ID from container
285
+ */
286
+ export function getCardElementById(_container: HTMLElement, _itemId: string | number): HTMLElement | null {
287
+ // Deprecated: Pixi renderer doesn't use DOM elements for cards
288
+ // Keep parameter names prefixed to indicate intentional non-use.
289
+ void _container;
290
+ void _itemId;
291
+ return null;
292
+ }
@@ -0,0 +1,259 @@
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 {
5
+ PivotDimension,
6
+ PivotFilter,
7
+ PivotFilterOption,
8
+ PivotGroup,
9
+ PivotPrimitive,
10
+ } from '../types';
11
+
12
+ export type FilterState = Record<string, Set<string>>;
13
+ export type RangeFilterState = Record<string, [number, number] | null>;
14
+
15
+ // Zoom configuration
16
+ export const ZOOM_MIN = 0.1;
17
+ export const ZOOM_MAX = 3;
18
+ export const ZOOM_STEP = 0.05;
19
+ export const CARDS_PER_COLUMN = 5;
20
+ export const BASE_CARD_WIDTH = 180;
21
+ export const BASE_CARD_HEIGHT = 140;
22
+
23
+ export const toKey = (value: PivotPrimitive): string => {
24
+ if (value === undefined) return 'undefined';
25
+ if (value === null) return 'null';
26
+ if (value instanceof Date) return value.toISOString();
27
+ if (typeof value === 'number' && Number.isNaN(value)) return 'nan';
28
+ return String(value);
29
+ };
30
+
31
+ export const defaultFormat = (value: PivotPrimitive): string => {
32
+ if (value === undefined) return 'Unknown';
33
+ if (value === null) return 'None';
34
+ if (value instanceof Date) return value.toLocaleString();
35
+ if (typeof value === 'boolean') return value ? 'Yes' : 'No';
36
+ return String(value);
37
+ };
38
+
39
+ export const buildFilterState = <TItem extends object>(
40
+ filters: PivotFilter<TItem>[] | undefined,
41
+ ): FilterState => {
42
+ const state: FilterState = {};
43
+ filters?.forEach((filter) => {
44
+ state[filter.key] = new Set<string>();
45
+ });
46
+ return state;
47
+ };
48
+
49
+ export const buildRangeFilterState = <TItem extends object>(
50
+ filters: PivotFilter<TItem>[] | undefined,
51
+ ): RangeFilterState => {
52
+ const state: RangeFilterState = {};
53
+ filters?.forEach((filter) => {
54
+ if (filter.type === 'number') {
55
+ state[filter.key] = null;
56
+ }
57
+ });
58
+ return state;
59
+ };
60
+
61
+ export const applyFilters = <TItem extends object>(
62
+ data: TItem[],
63
+ filters: PivotFilter<TItem>[] | undefined,
64
+ state: FilterState,
65
+ rangeState: RangeFilterState,
66
+ skipKey?: string,
67
+ ): TItem[] => {
68
+ if (!filters?.length) {
69
+ return data;
70
+ }
71
+
72
+ // Pre-compute active filters to avoid checking empty Sets repeatedly
73
+ const activeFilters: Array<{
74
+ filter: PivotFilter<TItem>;
75
+ selections?: Set<string>;
76
+ range?: [number, number];
77
+ }> = [];
78
+
79
+ for (const filter of filters) {
80
+ if (filter.key === skipKey) {
81
+ continue;
82
+ }
83
+
84
+ if (filter.type === 'number') {
85
+ const range = rangeState[filter.key];
86
+ if (range) {
87
+ activeFilters.push({ filter, range });
88
+ }
89
+ } else {
90
+ const selections = state[filter.key];
91
+ if (selections && selections.size > 0) {
92
+ activeFilters.push({ filter, selections });
93
+ }
94
+ }
95
+ }
96
+
97
+ // Early exit if no active filters
98
+ if (activeFilters.length === 0) {
99
+ return data;
100
+ }
101
+
102
+ return data.filter((item) => {
103
+ for (const { filter, selections, range } of activeFilters) {
104
+ if (range) {
105
+ const value = filter.getValue(item);
106
+ const numValue = typeof value === 'number' ? value : Number(value);
107
+ if (!Number.isNaN(numValue) && (numValue < range[0] || numValue > range[1])) {
108
+ return false;
109
+ }
110
+ } else if (selections) {
111
+ const valueKey = toKey(filter.getValue(item));
112
+ if (!selections.has(valueKey)) {
113
+ return false;
114
+ }
115
+ }
116
+ }
117
+ return true;
118
+ });
119
+ };
120
+
121
+ export const computeFilterOptions = <TItem extends object>(
122
+ data: TItem[],
123
+ filter: PivotFilter<TItem>,
124
+ ): PivotFilterOption[] => {
125
+ if (filter.options?.length) {
126
+ return filter.options;
127
+ }
128
+
129
+ const counts = new Map<string, { option: PivotFilterOption; count: number }>();
130
+
131
+ data.forEach((item) => {
132
+ const value = filter.getValue(item);
133
+ const key = toKey(value);
134
+ const existing = counts.get(key);
135
+ if (existing) {
136
+ existing.count += 1;
137
+ } else {
138
+ counts.set(key, {
139
+ option: {
140
+ key,
141
+ label: defaultFormat(value),
142
+ value,
143
+ count: 1,
144
+ },
145
+ count: 1,
146
+ });
147
+ }
148
+ });
149
+
150
+ const options = Array.from(counts.values()).map(({ option, count }) => ({
151
+ ...option,
152
+ count,
153
+ }));
154
+
155
+ return filter.sort ? options.sort(filter.sort) : options.sort((a, b) => b.count - a.count);
156
+ };
157
+
158
+ export const renderOptionCount = (count: number | undefined): string | number =>
159
+ typeof count === 'number' ? count : '';
160
+
161
+ export const computeNumericRange = <TItem extends object>(
162
+ data: TItem[],
163
+ filter: PivotFilter<TItem>,
164
+ ): { min: number; max: number; values: PivotPrimitive[] } => {
165
+ const values: PivotPrimitive[] = [];
166
+ let min = Infinity;
167
+ let max = -Infinity;
168
+
169
+ data.forEach((item) => {
170
+ const value = filter.getValue(item);
171
+ values.push(value);
172
+ const numValue = typeof value === 'number' ? value : Number(value);
173
+ if (!Number.isNaN(numValue)) {
174
+ min = Math.min(min, numValue);
175
+ max = Math.max(max, numValue);
176
+ }
177
+ });
178
+
179
+ return {
180
+ min: min === Infinity ? 0 : min,
181
+ max: max === -Infinity ? 100 : max,
182
+ values,
183
+ };
184
+ };
185
+
186
+ export const groupData = <TItem extends object>(
187
+ data: TItem[],
188
+ dimension: PivotDimension<TItem>,
189
+ ): PivotGroup<TItem>[] => {
190
+ const groups = new Map<string, PivotGroup<TItem>>();
191
+
192
+ // Cache the formatValue function if it exists
193
+ const formatValue = dimension.formatValue;
194
+
195
+ data.forEach((item) => {
196
+ const rawValue = dimension.getValue(item);
197
+ const key = toKey(rawValue) || 'default';
198
+ const group = groups.get(key);
199
+
200
+ if (group) {
201
+ group.items.push(item);
202
+ } else {
203
+ const label = formatValue ? formatValue(rawValue) : defaultFormat(rawValue);
204
+ groups.set(key, {
205
+ key,
206
+ label,
207
+ value: rawValue,
208
+ items: [item],
209
+ });
210
+ }
211
+ });
212
+
213
+ const result = Array.from(groups.values());
214
+ return dimension.sort ? result.sort(dimension.sort) : result.sort((a, b) => a.label.localeCompare(b.label));
215
+ };
216
+
217
+ /**
218
+ * Reorder items for a CSS Grid that displays bottom-up, left-to-right.
219
+ * CSS Grid fills top-to-bottom, left-to-right by default.
220
+ *
221
+ * Visual goal (items fill bottom row first, then row above, etc.):
222
+ * Grid Row 0 (top): [4] [5] [6] [ ] [ ] <- partial top row, empties on RIGHT
223
+ * Grid Row 1 (bottom): [0] [1] [2] [3] [4] <- full bottom row
224
+ *
225
+ * Returns array with nulls for empty cells that need placeholder rendering.
226
+ */
227
+ export const reorderForBottomUpGrid = <TItem,>(items: TItem[], columns: number): (TItem | null)[] => {
228
+ if (items.length === 0) return [];
229
+
230
+ const totalRows = Math.ceil(items.length / columns);
231
+ const itemsInTopRow = items.length % columns || columns;
232
+
233
+ const result: (TItem | null)[] = [];
234
+
235
+ // Top row: items from the "overflow" portion, plus empty cells on the right
236
+ const topRowStartIndex = items.length - itemsInTopRow;
237
+ for (let col = 0; col < columns; col++) {
238
+ if (col < itemsInTopRow) {
239
+ result.push(items[topRowStartIndex + col]);
240
+ } else {
241
+ result.push(null); // Empty cell on right side of top row
242
+ }
243
+ }
244
+
245
+ // Remaining rows (from second-to-top down to bottom)
246
+ // These are full rows, containing items 0 to (items.length - itemsInTopRow - 1)
247
+ for (let row = 1; row < totalRows; row++) {
248
+ // This grid row corresponds to visual row (totalRows - 1 - row) from bottom
249
+ // Visual row 0 = bottom, visual row (totalRows-1) = top
250
+ const visualRowFromBottom = totalRows - 1 - row;
251
+ const rowStartIndex = visualRowFromBottom * columns;
252
+
253
+ for (let col = 0; col < columns; col++) {
254
+ result.push(items[rowStartIndex + col]);
255
+ }
256
+ }
257
+
258
+ return result;
259
+ };
package/README.md ADDED
@@ -0,0 +1 @@
1
+ # Cratis Components
@@ -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 React from 'react';
5
+ import * as Comp from './EventsView';
6
+ const Component: React.ComponentType<any> | undefined = (Comp as any).default || (Object.values(Comp)[0] as any);
7
+
8
+ export default { title: 'TimeMachine/EventsView', component: Component };
9
+
10
+ export const Default = () => (Component ? <Component /> : <div>Unable to render component</div>);
@@ -0,0 +1,119 @@
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 React, { useEffect, useRef, useState } from 'react';
5
+ import { Timeline } from 'primereact/timeline';
6
+ import type { Event } from './types';
7
+ import { Properties } from './Properties';
8
+ import './EventsView.css';
9
+
10
+ interface EventsViewProps {
11
+ events: Event[];
12
+ }
13
+
14
+ export const EventsView: React.FC<EventsViewProps> = ({ events }) => {
15
+ // Use test data if no events provided
16
+ const displayEvents = events.length > 0 ? events : [];
17
+ const containerRef = useRef<HTMLDivElement>(null);
18
+ const [canScrollUp, setCanScrollUp] = useState(false);
19
+ const [canScrollDown, setCanScrollDown] = useState(false);
20
+
21
+ const updateScrollState = () => {
22
+ const container = containerRef.current;
23
+ if (!container) {
24
+ setCanScrollUp(false);
25
+ setCanScrollDown(false);
26
+ return;
27
+ }
28
+
29
+ const { scrollTop, scrollHeight, clientHeight } = container;
30
+ const epsilon = 1;
31
+ setCanScrollUp(scrollTop > epsilon);
32
+ setCanScrollDown(scrollTop + clientHeight < scrollHeight - epsilon);
33
+ };
34
+
35
+ useEffect(() => {
36
+ updateScrollState();
37
+ const container = containerRef.current;
38
+ if (!container) return;
39
+
40
+ const handleScroll = () => updateScrollState();
41
+ container.addEventListener('scroll', handleScroll);
42
+ return () => container.removeEventListener('scroll', handleScroll);
43
+ }, [displayEvents.length]);
44
+
45
+ const renderEventCard = (event: Event, position: 'left' | 'right') => {
46
+ const isLeft = position === 'left';
47
+
48
+ return (
49
+ <div className={`events-view-event-card events-view-event-card--${position}`}>
50
+ <div className={`events-view-event-header ${isLeft ? 'events-view-event-header--right' : ''}`}>
51
+ <h3 className={`events-view-event-name ${isLeft ? 'events-view-event-name--right' : ''}`}>{event.type}</h3>
52
+ <div className={`events-view-event-timestamp ${isLeft ? 'events-view-event-timestamp--right' : ''}`}>
53
+ {event.occurred.toLocaleString()}
54
+ </div>
55
+ </div>
56
+ <div className="events-view-event-properties">
57
+ <Properties data={event.content || {}} align="left" />
58
+ </div>
59
+ </div>
60
+ );
61
+ };
62
+
63
+ const customContent = (event: Event, index: number) => {
64
+ // PrimeReact places even indices (0,2,4,...) on the right, odd on the left
65
+ const position = index % 2 === 0 ? 'right' : 'left';
66
+ return renderEventCard(event, position);
67
+ };
68
+
69
+ const customMarker = () => {
70
+ return (
71
+ <div className="events-view-marker">
72
+ <div className="events-view-marker-dot"></div>
73
+ </div>
74
+ );
75
+ };
76
+
77
+ const scrollToTop = () => containerRef.current?.scrollTo({ top: 0, behavior: 'smooth' });
78
+ const scrollToBottom = () => {
79
+ const container = containerRef.current;
80
+ if (!container) return;
81
+ container.scrollTo({ top: container.scrollHeight, behavior: 'smooth' });
82
+ };
83
+
84
+ return (
85
+ <div className="events-view-container" ref={containerRef}>
86
+ {canScrollUp && (
87
+ <div className="events-view-scroll-button-wrapper events-view-scroll-button-wrapper--top">
88
+ <button
89
+ type="button"
90
+ className="events-view-scroll-button events-view-scroll-button--top"
91
+ onClick={scrollToTop}
92
+ aria-label="Scroll to top"
93
+ >
94
+ <i className="pi pi-arrow-up" />
95
+ </button>
96
+ </div>
97
+ )}
98
+ <Timeline
99
+ value={displayEvents}
100
+ align="alternate"
101
+ content={customContent}
102
+ marker={customMarker}
103
+ className="events-view-timeline"
104
+ />
105
+ {canScrollDown && (
106
+ <div className="events-view-scroll-button-wrapper events-view-scroll-button-wrapper--bottom">
107
+ <button
108
+ type="button"
109
+ className="events-view-scroll-button events-view-scroll-button--bottom"
110
+ onClick={scrollToBottom}
111
+ aria-label="Scroll to bottom"
112
+ >
113
+ <i className="pi pi-arrow-down" />
114
+ </button>
115
+ </div>
116
+ )}
117
+ </div>
118
+ );
119
+ };
@@ -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 React from 'react';
5
+ import * as Comp from './Properties';
6
+ const Component: React.ComponentType<any> | undefined = (Comp as any).default || (Object.values(Comp)[0] as any);
7
+
8
+ export default { title: 'TimeMachine/Properties', component: Component };
9
+
10
+ export const Default = () => (Component ? <Component /> : <div>Unable to render component</div>);