@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.
- package/.storybook/main.ts +24 -0
- package/CommandDialog/CommandDialog.stories.tsx +25 -0
- package/CommandDialog/CommandDialog.tsx +161 -0
- package/CommandDialog/index.ts +4 -0
- package/CommandForm/CommandForm.stories.tsx +24 -0
- package/CommandForm/CommandForm.tsx +266 -0
- package/CommandForm/CommandFormField.tsx +27 -0
- package/CommandForm/CommandFormFields.tsx +142 -0
- package/CommandForm/DatePickerField.tsx +57 -0
- package/CommandForm/DropdownField.tsx +65 -0
- package/CommandForm/InputTextField.tsx +62 -0
- package/CommandForm/SliderField.tsx +68 -0
- package/CommandForm/index.ts +10 -0
- package/Common/ErrorBoundary.stories.tsx +10 -0
- package/Common/ErrorBoundary.tsx +41 -0
- package/Common/FormElement.stories.tsx +10 -0
- package/Common/FormElement.tsx +20 -0
- package/Common/Page.stories.tsx +10 -0
- package/Common/Page.tsx +21 -0
- package/Common/index.ts +6 -0
- package/DataPage/DataPage.stories.tsx +10 -0
- package/DataPage/DataPage.tsx +191 -0
- package/DataPage/index.ts +4 -0
- package/DataTables/DataTableForObservableQuery.stories.tsx +10 -0
- package/DataTables/DataTableForObservableQuery.tsx +97 -0
- package/DataTables/DataTableForQuery.stories.tsx +10 -0
- package/DataTables/DataTableForQuery.tsx +97 -0
- package/DataTables/index.ts +5 -0
- package/Dialogs/BusyIndicatorDialog.stories.tsx +26 -0
- package/Dialogs/BusyIndicatorDialog.tsx +26 -0
- package/Dialogs/ConfirmationDialog.stories.tsx +36 -0
- package/Dialogs/ConfirmationDialog.tsx +75 -0
- package/Dialogs/index.ts +5 -0
- package/Dropdown/Dropdown.tsx +23 -0
- package/Dropdown/index.ts +4 -0
- package/PivotViewer/PivotViewer.stories.tsx +24 -0
- package/PivotViewer/PivotViewer.tsx +791 -0
- package/PivotViewer/components/AxisLabels.tsx +69 -0
- package/PivotViewer/components/DetailPanel.tsx +108 -0
- package/PivotViewer/components/FilterPanel.tsx +189 -0
- package/PivotViewer/components/FilterPanelContainer.tsx +10 -0
- package/PivotViewer/components/PivotCanvas.tsx +660 -0
- package/PivotViewer/components/PivotViewerMain.tsx +229 -0
- package/PivotViewer/components/RangeHistogramFilter.tsx +220 -0
- package/PivotViewer/components/Spinner.tsx +21 -0
- package/PivotViewer/components/Toolbar.tsx +130 -0
- package/PivotViewer/components/ToolbarContainer.tsx +10 -0
- package/PivotViewer/components/index.ts +12 -0
- package/PivotViewer/components/pivot/animation.ts +108 -0
- package/PivotViewer/components/pivot/buckets.ts +152 -0
- package/PivotViewer/components/pivot/colorResolver.ts +67 -0
- package/PivotViewer/components/pivot/constants.ts +46 -0
- package/PivotViewer/components/pivot/sprites.ts +265 -0
- package/PivotViewer/components/pivot/visibility.ts +319 -0
- package/PivotViewer/constants.ts +9 -0
- package/PivotViewer/engine/layout.ts +149 -0
- package/PivotViewer/engine/pivot.worker.ts +86 -0
- package/PivotViewer/engine/store.ts +437 -0
- package/PivotViewer/engine/types.ts +255 -0
- package/PivotViewer/hooks/index.ts +13 -0
- package/PivotViewer/hooks/useContainerDimensions.ts +45 -0
- package/PivotViewer/hooks/useDimensionState.ts +53 -0
- package/PivotViewer/hooks/useFilterOptions.ts +36 -0
- package/PivotViewer/hooks/useFilterPanelDrag.ts +49 -0
- package/PivotViewer/hooks/useFilterState.ts +106 -0
- package/PivotViewer/hooks/useFilteredData.ts +119 -0
- package/PivotViewer/hooks/usePanning.ts +163 -0
- package/PivotViewer/hooks/usePivotEngine.ts +252 -0
- package/PivotViewer/hooks/useSelectedItem.ts +402 -0
- package/PivotViewer/hooks/useWheelZoom.ts +114 -0
- package/PivotViewer/hooks/useZoomState.ts +34 -0
- package/PivotViewer/index.ts +7 -0
- package/PivotViewer/types.ts +59 -0
- package/PivotViewer/utils/animations.ts +249 -0
- package/PivotViewer/utils/constants.ts +20 -0
- package/PivotViewer/utils/index.ts +6 -0
- package/PivotViewer/utils/selection.ts +292 -0
- package/PivotViewer/utils/utils.ts +259 -0
- package/README.md +1 -0
- package/TimeMachine/EventsView.stories.tsx +10 -0
- package/TimeMachine/EventsView.tsx +119 -0
- package/TimeMachine/Properties.stories.tsx +10 -0
- package/TimeMachine/Properties.tsx +98 -0
- package/TimeMachine/ReadModelView.stories.tsx +10 -0
- package/TimeMachine/ReadModelView.tsx +143 -0
- package/TimeMachine/TimeMachine.stories.tsx +10 -0
- package/TimeMachine/TimeMachine.tsx +244 -0
- package/TimeMachine/index.ts +8 -0
- package/TimeMachine/types.ts +23 -0
- package/dist/cjs/CommandDialog/CommandDialog.js +71 -0
- package/dist/cjs/CommandDialog/CommandDialog.js.map +1 -0
- package/dist/cjs/CommandDialog/index.js +9 -0
- package/dist/cjs/CommandDialog/index.js.map +1 -0
- package/dist/cjs/CommandForm/CommandForm.js +179 -0
- package/dist/cjs/CommandForm/CommandForm.js.map +1 -0
- package/dist/cjs/CommandForm/CommandFormField.js +11 -0
- package/dist/cjs/CommandForm/CommandFormField.js.map +1 -0
- package/dist/cjs/CommandForm/CommandFormFields.js +67 -0
- package/dist/cjs/CommandForm/CommandFormFields.js.map +1 -0
- package/dist/cjs/CommandForm/DatePickerField.js +31 -0
- package/dist/cjs/CommandForm/DatePickerField.js.map +1 -0
- package/dist/cjs/CommandForm/DropdownField.js +31 -0
- package/dist/cjs/CommandForm/DropdownField.js.map +1 -0
- package/dist/cjs/CommandForm/InputTextField.js +32 -0
- package/dist/cjs/CommandForm/InputTextField.js.map +1 -0
- package/dist/cjs/CommandForm/SliderField.js +34 -0
- package/dist/cjs/CommandForm/SliderField.js.map +1 -0
- package/dist/cjs/CommandForm/index.js +23 -0
- package/dist/cjs/CommandForm/index.js.map +1 -0
- package/dist/cjs/Common/Page.js +10 -0
- package/dist/cjs/Common/Page.js.map +1 -0
- package/dist/cjs/DataPage/DataPage.js +64 -0
- package/dist/cjs/DataPage/DataPage.js.map +1 -0
- package/dist/cjs/DataPage/index.js +11 -0
- package/dist/cjs/DataPage/index.js.map +1 -0
- package/dist/cjs/DataTables/DataTableForObservableQuery.js +17 -0
- package/dist/cjs/DataTables/DataTableForObservableQuery.js.map +1 -0
- package/dist/cjs/DataTables/DataTableForQuery.js +17 -0
- package/dist/cjs/DataTables/DataTableForQuery.js.map +1 -0
- package/dist/cjs/DataTables/index.js +10 -0
- package/dist/cjs/DataTables/index.js.map +1 -0
- package/dist/cjs/Dialogs/BusyIndicatorDialog.js +13 -0
- package/dist/cjs/Dialogs/BusyIndicatorDialog.js.map +1 -0
- package/dist/cjs/Dialogs/ConfirmationDialog.js +33 -0
- package/dist/cjs/Dialogs/ConfirmationDialog.js.map +1 -0
- package/dist/cjs/Dialogs/index.js +10 -0
- package/dist/cjs/Dialogs/index.js.map +1 -0
- package/dist/cjs/Dropdown/Dropdown.js +15 -0
- package/dist/cjs/Dropdown/Dropdown.js.map +1 -0
- package/dist/cjs/Dropdown/index.js +8 -0
- package/dist/cjs/Dropdown/index.js.map +1 -0
- package/dist/cjs/PivotViewer/PivotViewer.js +525 -0
- package/dist/cjs/PivotViewer/PivotViewer.js.map +1 -0
- package/dist/cjs/PivotViewer/components/AxisLabels.js +27 -0
- package/dist/cjs/PivotViewer/components/AxisLabels.js.map +1 -0
- package/dist/cjs/PivotViewer/components/DetailPanel.js +35 -0
- package/dist/cjs/PivotViewer/components/DetailPanel.js.map +1 -0
- package/dist/cjs/PivotViewer/components/FilterPanel.js +59 -0
- package/dist/cjs/PivotViewer/components/FilterPanel.js.map +1 -0
- package/dist/cjs/PivotViewer/components/FilterPanelContainer.js +11 -0
- package/dist/cjs/PivotViewer/components/FilterPanelContainer.js.map +1 -0
- package/dist/cjs/PivotViewer/components/PivotCanvas.js +394 -0
- package/dist/cjs/PivotViewer/components/PivotCanvas.js.map +1 -0
- package/dist/cjs/PivotViewer/components/PivotViewerMain.js +81 -0
- package/dist/cjs/PivotViewer/components/PivotViewerMain.js.map +1 -0
- package/dist/cjs/PivotViewer/components/RangeHistogramFilter.js +124 -0
- package/dist/cjs/PivotViewer/components/RangeHistogramFilter.js.map +1 -0
- package/dist/cjs/PivotViewer/components/Spinner.js +11 -0
- package/dist/cjs/PivotViewer/components/Spinner.js.map +1 -0
- package/dist/cjs/PivotViewer/components/Toolbar.js +12 -0
- package/dist/cjs/PivotViewer/components/Toolbar.js.map +1 -0
- package/dist/cjs/PivotViewer/components/ToolbarContainer.js +11 -0
- package/dist/cjs/PivotViewer/components/ToolbarContainer.js.map +1 -0
- package/dist/cjs/PivotViewer/components/pivot/animation.js +82 -0
- package/dist/cjs/PivotViewer/components/pivot/animation.js.map +1 -0
- package/dist/cjs/PivotViewer/components/pivot/buckets.js +124 -0
- package/dist/cjs/PivotViewer/components/pivot/buckets.js.map +1 -0
- package/dist/cjs/PivotViewer/components/pivot/colorResolver.js +64 -0
- package/dist/cjs/PivotViewer/components/pivot/colorResolver.js.map +1 -0
- package/dist/cjs/PivotViewer/components/pivot/constants.js +19 -0
- package/dist/cjs/PivotViewer/components/pivot/constants.js.map +1 -0
- package/dist/cjs/PivotViewer/components/pivot/sprites.js +227 -0
- package/dist/cjs/PivotViewer/components/pivot/sprites.js.map +1 -0
- package/dist/cjs/PivotViewer/components/pivot/visibility.js +223 -0
- package/dist/cjs/PivotViewer/components/pivot/visibility.js.map +1 -0
- package/dist/cjs/PivotViewer/constants.js +16 -0
- package/dist/cjs/PivotViewer/constants.js.map +1 -0
- package/dist/cjs/PivotViewer/engine/layout.js +95 -0
- package/dist/cjs/PivotViewer/engine/layout.js.map +1 -0
- package/dist/cjs/PivotViewer/engine/store.js +336 -0
- package/dist/cjs/PivotViewer/engine/store.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/useContainerDimensions.js +30 -0
- package/dist/cjs/PivotViewer/hooks/useContainerDimensions.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/useDimensionState.js +43 -0
- package/dist/cjs/PivotViewer/hooks/useDimensionState.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/useFilterOptions.js +24 -0
- package/dist/cjs/PivotViewer/hooks/useFilterOptions.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/useFilterState.js +96 -0
- package/dist/cjs/PivotViewer/hooks/useFilterState.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/usePanning.js +120 -0
- package/dist/cjs/PivotViewer/hooks/usePanning.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/usePivotEngine.js +183 -0
- package/dist/cjs/PivotViewer/hooks/usePivotEngine.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/useWheelZoom.js +93 -0
- package/dist/cjs/PivotViewer/hooks/useWheelZoom.js.map +1 -0
- package/dist/cjs/PivotViewer/hooks/useZoomState.js +31 -0
- package/dist/cjs/PivotViewer/hooks/useZoomState.js.map +1 -0
- package/dist/cjs/PivotViewer/index.js +9 -0
- package/dist/cjs/PivotViewer/index.js.map +1 -0
- package/dist/cjs/PivotViewer/utils/animations.js +144 -0
- package/dist/cjs/PivotViewer/utils/animations.js.map +1 -0
- package/dist/cjs/PivotViewer/utils/constants.js +12 -0
- package/dist/cjs/PivotViewer/utils/constants.js.map +1 -0
- package/dist/cjs/PivotViewer/utils/selection.js +136 -0
- package/dist/cjs/PivotViewer/utils/selection.js.map +1 -0
- package/dist/cjs/PivotViewer/utils/utils.js +150 -0
- package/dist/cjs/PivotViewer/utils/utils.js.map +1 -0
- package/dist/cjs/TimeMachine/EventsView.js +57 -0
- package/dist/cjs/TimeMachine/EventsView.js.map +1 -0
- package/dist/cjs/TimeMachine/Properties.js +58 -0
- package/dist/cjs/TimeMachine/Properties.js.map +1 -0
- package/dist/cjs/TimeMachine/ReadModelView.js +40 -0
- package/dist/cjs/TimeMachine/ReadModelView.js.map +1 -0
- package/dist/cjs/TimeMachine/TimeMachine.js +98 -0
- package/dist/cjs/TimeMachine/TimeMachine.js.map +1 -0
- package/dist/cjs/TimeMachine/index.js +14 -0
- package/dist/cjs/TimeMachine/index.js.map +1 -0
- package/dist/cjs/index.js +22 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/useOverlayZIndex.js +24 -0
- package/dist/cjs/useOverlayZIndex.js.map +1 -0
- package/dist/esm/CommandDialog/CommandDialog.d.ts +45 -0
- package/dist/esm/CommandDialog/CommandDialog.d.ts.map +1 -0
- package/dist/esm/CommandDialog/CommandDialog.js +68 -0
- package/dist/esm/CommandDialog/CommandDialog.js.map +1 -0
- package/dist/esm/CommandDialog/CommandDialog.stories.d.ts +7 -0
- package/dist/esm/CommandDialog/CommandDialog.stories.d.ts.map +1 -0
- package/dist/esm/CommandDialog/CommandDialog.stories.js +12 -0
- package/dist/esm/CommandDialog/CommandDialog.stories.js.map +1 -0
- package/dist/esm/CommandDialog/index.d.ts +2 -0
- package/dist/esm/CommandDialog/index.d.ts.map +1 -0
- package/dist/esm/CommandDialog/index.js +2 -0
- package/dist/esm/CommandDialog/index.js.map +1 -0
- package/dist/esm/CommandForm/CommandForm.d.ts +49 -0
- package/dist/esm/CommandForm/CommandForm.d.ts.map +1 -0
- package/dist/esm/CommandForm/CommandForm.js +174 -0
- package/dist/esm/CommandForm/CommandForm.js.map +1 -0
- package/dist/esm/CommandForm/CommandForm.stories.d.ts +7 -0
- package/dist/esm/CommandForm/CommandForm.stories.d.ts.map +1 -0
- package/dist/esm/CommandForm/CommandForm.stories.js +12 -0
- package/dist/esm/CommandForm/CommandForm.stories.js.map +1 -0
- package/dist/esm/CommandForm/CommandFormField.d.ts +18 -0
- package/dist/esm/CommandForm/CommandFormField.d.ts.map +1 -0
- package/dist/esm/CommandForm/CommandFormField.js +9 -0
- package/dist/esm/CommandForm/CommandFormField.js.map +1 -0
- package/dist/esm/CommandForm/CommandFormFields.d.ts +11 -0
- package/dist/esm/CommandForm/CommandFormFields.d.ts.map +1 -0
- package/dist/esm/CommandForm/CommandFormFields.js +65 -0
- package/dist/esm/CommandForm/CommandFormFields.js.map +1 -0
- package/dist/esm/CommandForm/DatePickerField.d.ts +20 -0
- package/dist/esm/CommandForm/DatePickerField.d.ts.map +1 -0
- package/dist/esm/CommandForm/DatePickerField.js +29 -0
- package/dist/esm/CommandForm/DatePickerField.js.map +1 -0
- package/dist/esm/CommandForm/DropdownField.d.ts +24 -0
- package/dist/esm/CommandForm/DropdownField.d.ts.map +1 -0
- package/dist/esm/CommandForm/DropdownField.js +29 -0
- package/dist/esm/CommandForm/DropdownField.js.map +1 -0
- package/dist/esm/CommandForm/InputTextField.d.ts +20 -0
- package/dist/esm/CommandForm/InputTextField.d.ts.map +1 -0
- package/dist/esm/CommandForm/InputTextField.js +30 -0
- package/dist/esm/CommandForm/InputTextField.js.map +1 -0
- package/dist/esm/CommandForm/SliderField.d.ts +23 -0
- package/dist/esm/CommandForm/SliderField.d.ts.map +1 -0
- package/dist/esm/CommandForm/SliderField.js +32 -0
- package/dist/esm/CommandForm/SliderField.js.map +1 -0
- package/dist/esm/CommandForm/index.d.ts +8 -0
- package/dist/esm/CommandForm/index.d.ts.map +1 -0
- package/dist/esm/CommandForm/index.js +8 -0
- package/dist/esm/CommandForm/index.js.map +1 -0
- package/dist/esm/Common/ErrorBoundary.d.ts +16 -0
- package/dist/esm/Common/ErrorBoundary.d.ts.map +1 -0
- package/dist/esm/Common/ErrorBoundary.js +21 -0
- package/dist/esm/Common/ErrorBoundary.js.map +1 -0
- package/dist/esm/Common/ErrorBoundary.stories.d.ts +8 -0
- package/dist/esm/Common/ErrorBoundary.stories.d.ts.map +1 -0
- package/dist/esm/Common/ErrorBoundary.stories.js +6 -0
- package/dist/esm/Common/ErrorBoundary.stories.js.map +1 -0
- package/dist/esm/Common/FormElement.d.ts +6 -0
- package/dist/esm/Common/FormElement.d.ts.map +1 -0
- package/dist/esm/Common/FormElement.js +5 -0
- package/dist/esm/Common/FormElement.js.map +1 -0
- package/dist/esm/Common/FormElement.stories.d.ts +8 -0
- package/dist/esm/Common/FormElement.stories.d.ts.map +1 -0
- package/dist/esm/Common/FormElement.stories.js +6 -0
- package/dist/esm/Common/FormElement.stories.js.map +1 -0
- package/dist/esm/Common/Page.d.ts +8 -0
- package/dist/esm/Common/Page.d.ts.map +1 -0
- package/dist/esm/Common/Page.js +8 -0
- package/dist/esm/Common/Page.js.map +1 -0
- package/dist/esm/Common/Page.stories.d.ts +8 -0
- package/dist/esm/Common/Page.stories.d.ts.map +1 -0
- package/dist/esm/Common/Page.stories.js +6 -0
- package/dist/esm/Common/Page.stories.js.map +1 -0
- package/dist/esm/Common/index.d.ts +4 -0
- package/dist/esm/Common/index.d.ts.map +1 -0
- package/dist/esm/Common/index.js +4 -0
- package/dist/esm/Common/index.js.map +1 -0
- package/dist/esm/DataPage/DataPage.d.ts +41 -0
- package/dist/esm/DataPage/DataPage.d.ts.map +1 -0
- package/dist/esm/DataPage/DataPage.js +59 -0
- package/dist/esm/DataPage/DataPage.js.map +1 -0
- package/dist/esm/DataPage/DataPage.stories.d.ts +8 -0
- package/dist/esm/DataPage/DataPage.stories.d.ts.map +1 -0
- package/dist/esm/DataPage/DataPage.stories.js +6 -0
- package/dist/esm/DataPage/DataPage.stories.js.map +1 -0
- package/dist/esm/DataPage/index.d.ts +2 -0
- package/dist/esm/DataPage/index.d.ts.map +1 -0
- package/dist/esm/DataPage/index.js +2 -0
- package/dist/esm/DataPage/index.js.map +1 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.d.ts +17 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.d.ts.map +1 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.js +15 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.js.map +1 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.d.ts +8 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.d.ts.map +1 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.js +6 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.js.map +1 -0
- package/dist/esm/DataTables/DataTableForQuery.d.ts +17 -0
- package/dist/esm/DataTables/DataTableForQuery.d.ts.map +1 -0
- package/dist/esm/DataTables/DataTableForQuery.js +15 -0
- package/dist/esm/DataTables/DataTableForQuery.js.map +1 -0
- package/dist/esm/DataTables/DataTableForQuery.stories.d.ts +8 -0
- package/dist/esm/DataTables/DataTableForQuery.stories.d.ts.map +1 -0
- package/dist/esm/DataTables/DataTableForQuery.stories.js +6 -0
- package/dist/esm/DataTables/DataTableForQuery.stories.js.map +1 -0
- package/dist/esm/DataTables/index.d.ts +3 -0
- package/dist/esm/DataTables/index.d.ts.map +1 -0
- package/dist/esm/DataTables/index.js +3 -0
- package/dist/esm/DataTables/index.js.map +1 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.d.ts +3 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.d.ts.map +1 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.js +11 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.js.map +1 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.stories.d.ts +7 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.stories.d.ts.map +1 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.stories.js +15 -0
- package/dist/esm/Dialogs/BusyIndicatorDialog.stories.js.map +1 -0
- package/dist/esm/Dialogs/ConfirmationDialog.d.ts +2 -0
- package/dist/esm/Dialogs/ConfirmationDialog.d.ts.map +1 -0
- package/dist/esm/Dialogs/ConfirmationDialog.js +31 -0
- package/dist/esm/Dialogs/ConfirmationDialog.js.map +1 -0
- package/dist/esm/Dialogs/ConfirmationDialog.stories.d.ts +7 -0
- package/dist/esm/Dialogs/ConfirmationDialog.stories.d.ts.map +1 -0
- package/dist/esm/Dialogs/ConfirmationDialog.stories.js +20 -0
- package/dist/esm/Dialogs/ConfirmationDialog.stories.js.map +1 -0
- package/dist/esm/Dialogs/index.d.ts +3 -0
- package/dist/esm/Dialogs/index.d.ts.map +1 -0
- package/dist/esm/Dialogs/index.js +3 -0
- package/dist/esm/Dialogs/index.js.map +1 -0
- package/dist/esm/Dropdown/Dropdown.d.ts +5 -0
- package/dist/esm/Dropdown/Dropdown.d.ts.map +1 -0
- package/dist/esm/Dropdown/Dropdown.js +13 -0
- package/dist/esm/Dropdown/Dropdown.js.map +1 -0
- package/dist/esm/Dropdown/index.d.ts +2 -0
- package/dist/esm/Dropdown/index.d.ts.map +1 -0
- package/dist/esm/Dropdown/index.js +2 -0
- package/dist/esm/Dropdown/index.js.map +1 -0
- package/dist/esm/PivotViewer/PivotViewer.d.ts +4 -0
- package/dist/esm/PivotViewer/PivotViewer.d.ts.map +1 -0
- package/dist/esm/PivotViewer/PivotViewer.js +523 -0
- package/dist/esm/PivotViewer/PivotViewer.js.map +1 -0
- package/dist/esm/PivotViewer/PivotViewer.stories.d.ts +7 -0
- package/dist/esm/PivotViewer/PivotViewer.stories.d.ts.map +1 -0
- package/dist/esm/PivotViewer/PivotViewer.stories.js +12 -0
- package/dist/esm/PivotViewer/PivotViewer.stories.js.map +1 -0
- package/dist/esm/PivotViewer/components/AxisLabels.d.ts +13 -0
- package/dist/esm/PivotViewer/components/AxisLabels.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/AxisLabels.js +25 -0
- package/dist/esm/PivotViewer/components/AxisLabels.js.map +1 -0
- package/dist/esm/PivotViewer/components/DetailPanel.d.ts +6 -0
- package/dist/esm/PivotViewer/components/DetailPanel.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/DetailPanel.js +33 -0
- package/dist/esm/PivotViewer/components/DetailPanel.js.map +1 -0
- package/dist/esm/PivotViewer/components/FilterPanel.d.ts +27 -0
- package/dist/esm/PivotViewer/components/FilterPanel.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/FilterPanel.js +57 -0
- package/dist/esm/PivotViewer/components/FilterPanel.js.map +1 -0
- package/dist/esm/PivotViewer/components/FilterPanelContainer.d.ts +4 -0
- package/dist/esm/PivotViewer/components/FilterPanelContainer.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/FilterPanelContainer.js +9 -0
- package/dist/esm/PivotViewer/components/FilterPanelContainer.js.map +1 -0
- package/dist/esm/PivotViewer/components/PivotCanvas.d.ts +29 -0
- package/dist/esm/PivotViewer/components/PivotCanvas.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/PivotCanvas.js +373 -0
- package/dist/esm/PivotViewer/components/PivotCanvas.js.map +1 -0
- package/dist/esm/PivotViewer/components/PivotViewerMain.d.ts +43 -0
- package/dist/esm/PivotViewer/components/PivotViewerMain.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/PivotViewerMain.js +79 -0
- package/dist/esm/PivotViewer/components/PivotViewerMain.js.map +1 -0
- package/dist/esm/PivotViewer/components/RangeHistogramFilter.d.ts +11 -0
- package/dist/esm/PivotViewer/components/RangeHistogramFilter.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/RangeHistogramFilter.js +122 -0
- package/dist/esm/PivotViewer/components/RangeHistogramFilter.js.map +1 -0
- package/dist/esm/PivotViewer/components/Spinner.d.ts +3 -0
- package/dist/esm/PivotViewer/components/Spinner.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/Spinner.js +9 -0
- package/dist/esm/PivotViewer/components/Spinner.js.map +1 -0
- package/dist/esm/PivotViewer/components/Toolbar.d.ts +21 -0
- package/dist/esm/PivotViewer/components/Toolbar.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/Toolbar.js +10 -0
- package/dist/esm/PivotViewer/components/Toolbar.js.map +1 -0
- package/dist/esm/PivotViewer/components/ToolbarContainer.d.ts +4 -0
- package/dist/esm/PivotViewer/components/ToolbarContainer.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/ToolbarContainer.js +9 -0
- package/dist/esm/PivotViewer/components/ToolbarContainer.js.map +1 -0
- package/dist/esm/PivotViewer/components/index.d.ts +9 -0
- package/dist/esm/PivotViewer/components/index.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/index.js +8 -0
- package/dist/esm/PivotViewer/components/index.js.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/animation.d.ts +29 -0
- package/dist/esm/PivotViewer/components/pivot/animation.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/animation.js +79 -0
- package/dist/esm/PivotViewer/components/pivot/animation.js.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/buckets.d.ts +6 -0
- package/dist/esm/PivotViewer/components/pivot/buckets.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/buckets.js +102 -0
- package/dist/esm/PivotViewer/components/pivot/buckets.js.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/colorResolver.d.ts +4 -0
- package/dist/esm/PivotViewer/components/pivot/colorResolver.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/colorResolver.js +61 -0
- package/dist/esm/PivotViewer/components/pivot/colorResolver.js.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/constants.d.ts +38 -0
- package/dist/esm/PivotViewer/components/pivot/constants.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/constants.js +14 -0
- package/dist/esm/PivotViewer/components/pivot/constants.js.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/sprites.d.ts +6 -0
- package/dist/esm/PivotViewer/components/pivot/sprites.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/sprites.js +203 -0
- package/dist/esm/PivotViewer/components/pivot/sprites.js.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/visibility.d.ts +26 -0
- package/dist/esm/PivotViewer/components/pivot/visibility.d.ts.map +1 -0
- package/dist/esm/PivotViewer/components/pivot/visibility.js +221 -0
- package/dist/esm/PivotViewer/components/pivot/visibility.js.map +1 -0
- package/dist/esm/PivotViewer/constants.d.ts +7 -0
- package/dist/esm/PivotViewer/constants.d.ts.map +1 -0
- package/dist/esm/PivotViewer/constants.js +9 -0
- package/dist/esm/PivotViewer/constants.js.map +1 -0
- package/dist/esm/PivotViewer/engine/layout.d.ts +3 -0
- package/dist/esm/PivotViewer/engine/layout.d.ts.map +1 -0
- package/dist/esm/PivotViewer/engine/layout.js +93 -0
- package/dist/esm/PivotViewer/engine/layout.js.map +1 -0
- package/dist/esm/PivotViewer/engine/pivot.worker.d.ts +2 -0
- package/dist/esm/PivotViewer/engine/pivot.worker.d.ts.map +1 -0
- package/dist/esm/PivotViewer/engine/pivot.worker.js +58 -0
- package/dist/esm/PivotViewer/engine/pivot.worker.js.map +1 -0
- package/dist/esm/PivotViewer/engine/store.d.ts +9 -0
- package/dist/esm/PivotViewer/engine/store.d.ts.map +1 -0
- package/dist/esm/PivotViewer/engine/store.js +328 -0
- package/dist/esm/PivotViewer/engine/store.js.map +1 -0
- package/dist/esm/PivotViewer/engine/types.d.ts +125 -0
- package/dist/esm/PivotViewer/engine/types.d.ts.map +1 -0
- package/dist/esm/PivotViewer/engine/types.js +2 -0
- package/dist/esm/PivotViewer/engine/types.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/index.d.ts +11 -0
- package/dist/esm/PivotViewer/hooks/index.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/index.js +11 -0
- package/dist/esm/PivotViewer/hooks/index.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useContainerDimensions.d.ts +5 -0
- package/dist/esm/PivotViewer/hooks/useContainerDimensions.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useContainerDimensions.js +28 -0
- package/dist/esm/PivotViewer/hooks/useContainerDimensions.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useDimensionState.d.ts +11 -0
- package/dist/esm/PivotViewer/hooks/useDimensionState.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useDimensionState.js +41 -0
- package/dist/esm/PivotViewer/hooks/useDimensionState.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilterOptions.d.ts +12 -0
- package/dist/esm/PivotViewer/hooks/useFilterOptions.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilterOptions.js +22 -0
- package/dist/esm/PivotViewer/hooks/useFilterOptions.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.d.ts +9 -0
- package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.js +42 -0
- package/dist/esm/PivotViewer/hooks/useFilterPanelDrag.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilterState.d.ts +11 -0
- package/dist/esm/PivotViewer/hooks/useFilterState.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilterState.js +94 -0
- package/dist/esm/PivotViewer/hooks/useFilterState.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilteredData.d.ts +9 -0
- package/dist/esm/PivotViewer/hooks/useFilteredData.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useFilteredData.js +85 -0
- package/dist/esm/PivotViewer/hooks/useFilteredData.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/usePanning.d.ts +10 -0
- package/dist/esm/PivotViewer/hooks/usePanning.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/usePanning.js +118 -0
- package/dist/esm/PivotViewer/hooks/usePanning.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/usePivotEngine.d.ts +14 -0
- package/dist/esm/PivotViewer/hooks/usePivotEngine.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/usePivotEngine.js +180 -0
- package/dist/esm/PivotViewer/hooks/usePivotEngine.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useSelectedItem.d.ts +8 -0
- package/dist/esm/PivotViewer/hooks/useSelectedItem.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useSelectedItem.js +322 -0
- package/dist/esm/PivotViewer/hooks/useSelectedItem.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useWheelZoom.d.ts +2 -0
- package/dist/esm/PivotViewer/hooks/useWheelZoom.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useWheelZoom.js +91 -0
- package/dist/esm/PivotViewer/hooks/useWheelZoom.js.map +1 -0
- package/dist/esm/PivotViewer/hooks/useZoomState.d.ts +9 -0
- package/dist/esm/PivotViewer/hooks/useZoomState.d.ts.map +1 -0
- package/dist/esm/PivotViewer/hooks/useZoomState.js +29 -0
- package/dist/esm/PivotViewer/hooks/useZoomState.js.map +1 -0
- package/dist/esm/PivotViewer/index.d.ts +4 -0
- package/dist/esm/PivotViewer/index.d.ts.map +1 -0
- package/dist/esm/PivotViewer/index.js +2 -0
- package/dist/esm/PivotViewer/index.js.map +1 -0
- package/dist/esm/PivotViewer/types.d.ts +47 -0
- package/dist/esm/PivotViewer/types.d.ts.map +1 -0
- package/dist/esm/PivotViewer/types.js +2 -0
- package/dist/esm/PivotViewer/types.js.map +1 -0
- package/dist/esm/PivotViewer/utils/animations.d.ts +54 -0
- package/dist/esm/PivotViewer/utils/animations.d.ts.map +1 -0
- package/dist/esm/PivotViewer/utils/animations.js +139 -0
- package/dist/esm/PivotViewer/utils/animations.js.map +1 -0
- package/dist/esm/PivotViewer/utils/constants.d.ts +13 -0
- package/dist/esm/PivotViewer/utils/constants.d.ts.map +1 -0
- package/dist/esm/PivotViewer/utils/constants.js +7 -0
- package/dist/esm/PivotViewer/utils/constants.js.map +1 -0
- package/dist/esm/PivotViewer/utils/index.d.ts +4 -0
- package/dist/esm/PivotViewer/utils/index.d.ts.map +1 -0
- package/dist/esm/PivotViewer/utils/index.js +4 -0
- package/dist/esm/PivotViewer/utils/index.js.map +1 -0
- package/dist/esm/PivotViewer/utils/selection.d.ts +50 -0
- package/dist/esm/PivotViewer/utils/selection.d.ts.map +1 -0
- package/dist/esm/PivotViewer/utils/selection.js +134 -0
- package/dist/esm/PivotViewer/utils/selection.js.map +1 -0
- package/dist/esm/PivotViewer/utils/utils.d.ts +24 -0
- package/dist/esm/PivotViewer/utils/utils.d.ts.map +1 -0
- package/dist/esm/PivotViewer/utils/utils.js +138 -0
- package/dist/esm/PivotViewer/utils/utils.js.map +1 -0
- package/dist/esm/TimeMachine/EventsView.d.ts +9 -0
- package/dist/esm/TimeMachine/EventsView.d.ts.map +1 -0
- package/dist/esm/TimeMachine/EventsView.js +55 -0
- package/dist/esm/TimeMachine/EventsView.js.map +1 -0
- package/dist/esm/TimeMachine/EventsView.stories.d.ts +8 -0
- package/dist/esm/TimeMachine/EventsView.stories.d.ts.map +1 -0
- package/dist/esm/TimeMachine/EventsView.stories.js +6 -0
- package/dist/esm/TimeMachine/EventsView.stories.js.map +1 -0
- package/dist/esm/TimeMachine/Properties.d.ts +9 -0
- package/dist/esm/TimeMachine/Properties.d.ts.map +1 -0
- package/dist/esm/TimeMachine/Properties.js +56 -0
- package/dist/esm/TimeMachine/Properties.js.map +1 -0
- package/dist/esm/TimeMachine/Properties.stories.d.ts +8 -0
- package/dist/esm/TimeMachine/Properties.stories.d.ts.map +1 -0
- package/dist/esm/TimeMachine/Properties.stories.js +6 -0
- package/dist/esm/TimeMachine/Properties.stories.js.map +1 -0
- package/dist/esm/TimeMachine/ReadModelView.d.ts +12 -0
- package/dist/esm/TimeMachine/ReadModelView.d.ts.map +1 -0
- package/dist/esm/TimeMachine/ReadModelView.js +38 -0
- package/dist/esm/TimeMachine/ReadModelView.js.map +1 -0
- package/dist/esm/TimeMachine/ReadModelView.stories.d.ts +8 -0
- package/dist/esm/TimeMachine/ReadModelView.stories.d.ts.map +1 -0
- package/dist/esm/TimeMachine/ReadModelView.stories.js +6 -0
- package/dist/esm/TimeMachine/ReadModelView.stories.js.map +1 -0
- package/dist/esm/TimeMachine/TimeMachine.d.ts +12 -0
- package/dist/esm/TimeMachine/TimeMachine.d.ts.map +1 -0
- package/dist/esm/TimeMachine/TimeMachine.js +93 -0
- package/dist/esm/TimeMachine/TimeMachine.js.map +1 -0
- package/dist/esm/TimeMachine/TimeMachine.stories.d.ts +8 -0
- package/dist/esm/TimeMachine/TimeMachine.stories.d.ts.map +1 -0
- package/dist/esm/TimeMachine/TimeMachine.stories.js +6 -0
- package/dist/esm/TimeMachine/TimeMachine.stories.js.map +1 -0
- package/dist/esm/TimeMachine/index.d.ts +6 -0
- package/dist/esm/TimeMachine/index.d.ts.map +1 -0
- package/dist/esm/TimeMachine/index.js +5 -0
- package/dist/esm/TimeMachine/index.js.map +1 -0
- package/dist/esm/TimeMachine/types.d.ts +19 -0
- package/dist/esm/TimeMachine/types.d.ts.map +1 -0
- package/dist/esm/TimeMachine/types.js +2 -0
- package/dist/esm/TimeMachine/types.js.map +1 -0
- package/dist/esm/index.d.ts +10 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +17 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/tsconfig.tsbuildinfo +1 -0
- package/dist/esm/useOverlayZIndex.d.ts +2 -0
- package/dist/esm/useOverlayZIndex.d.ts.map +1 -0
- package/dist/esm/useOverlayZIndex.js +22 -0
- package/dist/esm/useOverlayZIndex.js.map +1 -0
- package/dist/esm/vite.config.d.ts +3 -0
- package/dist/esm/vite.config.d.ts.map +1 -0
- package/dist/esm/vite.config.js +76 -0
- package/dist/esm/vite.config.js.map +1 -0
- package/global.d.ts +11 -0
- package/index.ts +22 -0
- package/package.json +160 -0
- package/useOverlayZIndex.ts +32 -0
- package/vite.config.ts +80 -0
|
@@ -0,0 +1,114 @@
|
|
|
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 } from 'react';
|
|
5
|
+
import { ZOOM_MIN, ZOOM_MAX } from '../utils/utils';
|
|
6
|
+
|
|
7
|
+
export function useWheelZoom(
|
|
8
|
+
containerRef: React.RefObject<HTMLDivElement | null>,
|
|
9
|
+
zoomLevel: number,
|
|
10
|
+
setZoomLevel: (zoom: number) => void
|
|
11
|
+
) {
|
|
12
|
+
const handleWheel = useCallback((e: WheelEvent) => {
|
|
13
|
+
if (e.ctrlKey || e.metaKey) {
|
|
14
|
+
e.preventDefault();
|
|
15
|
+
|
|
16
|
+
const container = containerRef.current;
|
|
17
|
+
if (!container) return;
|
|
18
|
+
|
|
19
|
+
container.style.scrollBehavior = 'auto';
|
|
20
|
+
|
|
21
|
+
const rect = container.getBoundingClientRect();
|
|
22
|
+
const cursorX = e.clientX - rect.left;
|
|
23
|
+
const cursorY = e.clientY - rect.top;
|
|
24
|
+
const scrollX = container.scrollLeft;
|
|
25
|
+
const scrollY = container.scrollTop;
|
|
26
|
+
|
|
27
|
+
const delta = -e.deltaY * 0.01;
|
|
28
|
+
const newZoom = Math.max(ZOOM_MIN, Math.min(ZOOM_MAX, zoomLevel + delta));
|
|
29
|
+
const zoomRatio = newZoom / zoomLevel;
|
|
30
|
+
|
|
31
|
+
const newScrollLeft = (scrollX + cursorX) * zoomRatio - cursorX;
|
|
32
|
+
const newScrollTop = (scrollY + cursorY) * zoomRatio - cursorY;
|
|
33
|
+
|
|
34
|
+
setZoomLevel(newZoom);
|
|
35
|
+
|
|
36
|
+
setTimeout(() => {
|
|
37
|
+
container.scrollLeft = Math.max(0, newScrollLeft);
|
|
38
|
+
container.scrollTop = Math.max(0, newScrollTop);
|
|
39
|
+
setTimeout(() => {
|
|
40
|
+
container.style.scrollBehavior = '';
|
|
41
|
+
}, 50);
|
|
42
|
+
}, 0);
|
|
43
|
+
}
|
|
44
|
+
}, [zoomLevel, setZoomLevel, containerRef]);
|
|
45
|
+
|
|
46
|
+
useEffect(() => {
|
|
47
|
+
const container = containerRef.current;
|
|
48
|
+
if (!container) return;
|
|
49
|
+
|
|
50
|
+
container.addEventListener('wheel', handleWheel, { passive: false });
|
|
51
|
+
|
|
52
|
+
let lastTouchDistance = 0;
|
|
53
|
+
let currentZoom = zoomLevel;
|
|
54
|
+
|
|
55
|
+
const handleTouchStart = (e: TouchEvent) => {
|
|
56
|
+
if (e.touches.length === 2) {
|
|
57
|
+
const dx = e.touches[0].clientX - e.touches[1].clientX;
|
|
58
|
+
const dy = e.touches[0].clientY - e.touches[1].clientY;
|
|
59
|
+
lastTouchDistance = Math.sqrt(dx * dx + dy * dy);
|
|
60
|
+
currentZoom = zoomLevel;
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
const handleTouchMove = (e: TouchEvent) => {
|
|
65
|
+
if (e.touches.length === 2) {
|
|
66
|
+
e.preventDefault();
|
|
67
|
+
const dx = e.touches[0].clientX - e.touches[1].clientX;
|
|
68
|
+
const dy = e.touches[0].clientY - e.touches[1].clientY;
|
|
69
|
+
const distance = Math.sqrt(dx * dx + dy * dy);
|
|
70
|
+
|
|
71
|
+
const centerX = (e.touches[0].clientX + e.touches[1].clientX) / 2;
|
|
72
|
+
const centerY = (e.touches[0].clientY + e.touches[1].clientY) / 2;
|
|
73
|
+
const rect = container.getBoundingClientRect();
|
|
74
|
+
const cursorX = centerX - rect.left;
|
|
75
|
+
const cursorY = centerY - rect.top;
|
|
76
|
+
|
|
77
|
+
if (lastTouchDistance > 0) {
|
|
78
|
+
const scale = distance / lastTouchDistance;
|
|
79
|
+
const newZoom = Math.max(ZOOM_MIN, Math.min(ZOOM_MAX, currentZoom * scale));
|
|
80
|
+
const zoomRatio = newZoom / zoomLevel;
|
|
81
|
+
|
|
82
|
+
const contentX = container.scrollLeft + cursorX;
|
|
83
|
+
const contentY = container.scrollTop + cursorY;
|
|
84
|
+
|
|
85
|
+
const newScrollLeft = contentX * zoomRatio - cursorX;
|
|
86
|
+
const newScrollTop = contentY * zoomRatio - cursorY;
|
|
87
|
+
|
|
88
|
+
setZoomLevel(newZoom);
|
|
89
|
+
|
|
90
|
+
requestAnimationFrame(() => {
|
|
91
|
+
container.scrollLeft = Math.max(0, newScrollLeft);
|
|
92
|
+
container.scrollTop = Math.max(0, newScrollTop);
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
lastTouchDistance = distance;
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
const handleTouchEnd = () => {
|
|
100
|
+
lastTouchDistance = 0;
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
container.addEventListener('touchstart', handleTouchStart, { passive: true });
|
|
104
|
+
container.addEventListener('touchmove', handleTouchMove, { passive: false });
|
|
105
|
+
container.addEventListener('touchend', handleTouchEnd, { passive: true });
|
|
106
|
+
|
|
107
|
+
return () => {
|
|
108
|
+
container.removeEventListener('wheel', handleWheel);
|
|
109
|
+
container.removeEventListener('touchstart', handleTouchStart);
|
|
110
|
+
container.removeEventListener('touchmove', handleTouchMove);
|
|
111
|
+
container.removeEventListener('touchend', handleTouchEnd);
|
|
112
|
+
};
|
|
113
|
+
}, [handleWheel, zoomLevel, setZoomLevel, containerRef]);
|
|
114
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
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 { useState, useCallback } from 'react';
|
|
5
|
+
import { ZOOM_MIN, ZOOM_MAX } from '../utils/utils';
|
|
6
|
+
|
|
7
|
+
export function useZoomState(initialZoom = 1) {
|
|
8
|
+
const [zoomLevel, setZoomLevel] = useState(initialZoom);
|
|
9
|
+
|
|
10
|
+
const handleZoomChange = useCallback((newZoom: number) => {
|
|
11
|
+
setZoomLevel(Math.max(ZOOM_MIN, Math.min(ZOOM_MAX, newZoom)));
|
|
12
|
+
}, []);
|
|
13
|
+
|
|
14
|
+
const handleZoomIn = useCallback(() => {
|
|
15
|
+
handleZoomChange(zoomLevel + 0.2);
|
|
16
|
+
}, [zoomLevel, handleZoomChange]);
|
|
17
|
+
|
|
18
|
+
const handleZoomOut = useCallback(() => {
|
|
19
|
+
handleZoomChange(zoomLevel - 0.2);
|
|
20
|
+
}, [zoomLevel, handleZoomChange]);
|
|
21
|
+
|
|
22
|
+
const handleZoomSlider = useCallback((e: React.ChangeEvent<HTMLInputElement>) => {
|
|
23
|
+
handleZoomChange(parseFloat(e.target.value));
|
|
24
|
+
}, [handleZoomChange]);
|
|
25
|
+
|
|
26
|
+
return {
|
|
27
|
+
zoomLevel,
|
|
28
|
+
setZoomLevel,
|
|
29
|
+
handleZoomChange,
|
|
30
|
+
handleZoomIn,
|
|
31
|
+
handleZoomOut,
|
|
32
|
+
handleZoomSlider,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
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 { PivotViewer } from './PivotViewer';
|
|
5
|
+
|
|
6
|
+
export { PivotViewer, PivotViewer as PivotViewerOptimized };
|
|
7
|
+
export type { PivotViewerProps, PivotDimension, PivotFilter, PivotFilterOption, PivotGroup, PivotPrimitive } from './types';
|
|
@@ -0,0 +1,59 @@
|
|
|
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
|
+
|
|
6
|
+
export type PivotPrimitive = string | number | boolean | Date | null | undefined;
|
|
7
|
+
|
|
8
|
+
export interface PivotGroup<TItem extends object> {
|
|
9
|
+
key: string;
|
|
10
|
+
label: string;
|
|
11
|
+
value: PivotPrimitive;
|
|
12
|
+
items: TItem[];
|
|
13
|
+
count?: number;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export interface PivotDimension<TItem extends object> {
|
|
17
|
+
key: string;
|
|
18
|
+
label: string;
|
|
19
|
+
getValue: (item: TItem) => PivotPrimitive;
|
|
20
|
+
formatValue?: (value: PivotPrimitive) => string;
|
|
21
|
+
sort?: (a: PivotGroup<TItem>, b: PivotGroup<TItem>) => number;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export interface PivotFilterOption {
|
|
25
|
+
key: string;
|
|
26
|
+
label: string;
|
|
27
|
+
value: PivotPrimitive;
|
|
28
|
+
count: number;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export interface PivotFilter<TItem extends object> {
|
|
32
|
+
key: string;
|
|
33
|
+
label: string;
|
|
34
|
+
getValue: (item: TItem) => PivotPrimitive;
|
|
35
|
+
multi?: boolean;
|
|
36
|
+
options?: PivotFilterOption[];
|
|
37
|
+
sort?: (a: PivotFilterOption, b: PivotFilterOption) => number;
|
|
38
|
+
/** For numeric filters, enables range picker with histogram */
|
|
39
|
+
type?: 'string' | 'number' | 'date';
|
|
40
|
+
/** Number of buckets for the histogram in range filters */
|
|
41
|
+
buckets?: number;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export interface PivotViewerProps<TItem extends object> {
|
|
45
|
+
data: TItem[];
|
|
46
|
+
dimensions: PivotDimension<TItem>[];
|
|
47
|
+
filters?: PivotFilter<TItem>[];
|
|
48
|
+
defaultDimensionKey?: string;
|
|
49
|
+
cardRenderer?: (item: TItem) => ReactNode;
|
|
50
|
+
getItemId?: (item: TItem, index: number) => string | number;
|
|
51
|
+
searchFields?: (keyof TItem)[];
|
|
52
|
+
className?: string;
|
|
53
|
+
emptyContent?: ReactNode;
|
|
54
|
+
isLoading?: boolean;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export type FilterState = Record<string, Set<string>>;
|
|
58
|
+
|
|
59
|
+
export type RangeFilterState = Record<string, [number, number] | null>;
|
|
@@ -0,0 +1,249 @@
|
|
|
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 type EasingFunction = (t: number) => number;
|
|
5
|
+
|
|
6
|
+
export const easeOutCubic: EasingFunction = (t: number) => 1 - Math.pow(1 - t, 3);
|
|
7
|
+
|
|
8
|
+
export interface ZoomAnimationParams {
|
|
9
|
+
startZoom: number;
|
|
10
|
+
targetZoom: number;
|
|
11
|
+
duration?: number;
|
|
12
|
+
easing?: EasingFunction;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export interface ScrollAnimationParams {
|
|
16
|
+
targetScrollLeft: number;
|
|
17
|
+
targetScrollTop: number;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface ZoomScrollAnimationParams extends ZoomAnimationParams, ScrollAnimationParams {
|
|
21
|
+
container: HTMLElement;
|
|
22
|
+
cardPosition?: { x: number; y: number; width: number; height: number } | null;
|
|
23
|
+
targetCardPosition?: { x: number; y: number; width: number; height: number } | null;
|
|
24
|
+
getCardPositionAtZoom?: (zoom: number) => { x: number; y: number; width: number; height: number } | null;
|
|
25
|
+
getLayoutSizeAtZoom?: (zoom: number) => { width: number; height: number };
|
|
26
|
+
spacer?: HTMLElement | null;
|
|
27
|
+
onUpdate: (zoom: number) => void;
|
|
28
|
+
onComplete?: () => void;
|
|
29
|
+
startScrollLeft?: number; // Optional explicit start scroll
|
|
30
|
+
startScrollTop?: number; // Optional explicit start scroll
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Animate zoom and scroll together, keeping a specific element centered
|
|
35
|
+
*/
|
|
36
|
+
export function animateZoomAndScroll({
|
|
37
|
+
container,
|
|
38
|
+
cardPosition,
|
|
39
|
+
targetCardPosition,
|
|
40
|
+
getCardPositionAtZoom,
|
|
41
|
+
getLayoutSizeAtZoom,
|
|
42
|
+
spacer,
|
|
43
|
+
startZoom,
|
|
44
|
+
targetZoom,
|
|
45
|
+
targetScrollLeft,
|
|
46
|
+
targetScrollTop,
|
|
47
|
+
duration = 300,
|
|
48
|
+
easing = easeOutCubic,
|
|
49
|
+
onUpdate,
|
|
50
|
+
onComplete,
|
|
51
|
+
startScrollLeft,
|
|
52
|
+
startScrollTop,
|
|
53
|
+
}: ZoomScrollAnimationParams): () => void {
|
|
54
|
+
container.style.scrollBehavior = 'auto';
|
|
55
|
+
|
|
56
|
+
let startTime: number | null = null;
|
|
57
|
+
let rafId: number | null = null;
|
|
58
|
+
|
|
59
|
+
// Capture start scroll if not provided
|
|
60
|
+
const initialScrollLeft = startScrollLeft ?? container.scrollLeft;
|
|
61
|
+
const initialScrollTop = startScrollTop ?? container.scrollTop;
|
|
62
|
+
|
|
63
|
+
// Calculate initial center point relative to viewport
|
|
64
|
+
const startCardCenterX = cardPosition ? (cardPosition.x * startZoom + (cardPosition.width * startZoom) / 2) : 0;
|
|
65
|
+
const startCardCenterY = cardPosition ? (cardPosition.y * startZoom + (cardPosition.height * startZoom) / 2) : 0;
|
|
66
|
+
|
|
67
|
+
const startCardScreenX = startCardCenterX - initialScrollLeft;
|
|
68
|
+
const startCardScreenY = startCardCenterY - initialScrollTop;
|
|
69
|
+
|
|
70
|
+
const animate = (timestamp: number) => {
|
|
71
|
+
if (startTime === null) {
|
|
72
|
+
startTime = timestamp;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const elapsed = timestamp - startTime;
|
|
76
|
+
const progress = Math.min(1, elapsed / duration);
|
|
77
|
+
const easedProgress = easing(progress);
|
|
78
|
+
|
|
79
|
+
const currentZoom = startZoom + (targetZoom - startZoom) * easedProgress;
|
|
80
|
+
|
|
81
|
+
// Update spacer size synchronously if possible
|
|
82
|
+
if (spacer && getLayoutSizeAtZoom) {
|
|
83
|
+
const size = getLayoutSizeAtZoom(currentZoom);
|
|
84
|
+
if (size) {
|
|
85
|
+
spacer.style.width = `${size.width * currentZoom}px`;
|
|
86
|
+
spacer.style.height = `${size.height * currentZoom}px`;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
onUpdate(currentZoom);
|
|
91
|
+
|
|
92
|
+
if (cardPosition) {
|
|
93
|
+
let currentCardX: number;
|
|
94
|
+
let currentCardY: number;
|
|
95
|
+
|
|
96
|
+
if (getCardPositionAtZoom) {
|
|
97
|
+
const pos = getCardPositionAtZoom(currentZoom);
|
|
98
|
+
if (pos) {
|
|
99
|
+
currentCardX = pos.x;
|
|
100
|
+
currentCardY = pos.y;
|
|
101
|
+
} else {
|
|
102
|
+
currentCardX = cardPosition.x;
|
|
103
|
+
currentCardY = cardPosition.y;
|
|
104
|
+
}
|
|
105
|
+
} else {
|
|
106
|
+
// Interpolate card position if target is provided (for layouts that change with zoom)
|
|
107
|
+
currentCardX = targetCardPosition
|
|
108
|
+
? cardPosition.x + (targetCardPosition.x - cardPosition.x) * easedProgress
|
|
109
|
+
: cardPosition.x;
|
|
110
|
+
currentCardY = targetCardPosition
|
|
111
|
+
? cardPosition.y + (targetCardPosition.y - cardPosition.y) * easedProgress
|
|
112
|
+
: cardPosition.y;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
// Calculate where the card center is at current zoom
|
|
116
|
+
const currentCardCenterX = currentCardX * currentZoom + (cardPosition.width * currentZoom) / 2;
|
|
117
|
+
const currentCardCenterY = currentCardY * currentZoom + (cardPosition.height * currentZoom) / 2;
|
|
118
|
+
|
|
119
|
+
// Calculate where the card center will be at the end of animation (relative to viewport)
|
|
120
|
+
// Target scroll position is where we want to end up
|
|
121
|
+
const endCardX = targetCardPosition ? targetCardPosition.x : cardPosition.x;
|
|
122
|
+
const endCardY = targetCardPosition ? targetCardPosition.y : cardPosition.y;
|
|
123
|
+
|
|
124
|
+
const endCardCenterX = endCardX * targetZoom + (cardPosition.width * targetZoom) / 2;
|
|
125
|
+
const endCardCenterY = endCardY * targetZoom + (cardPosition.height * targetZoom) / 2;
|
|
126
|
+
|
|
127
|
+
const endCardScreenX = endCardCenterX - targetScrollLeft;
|
|
128
|
+
const endCardScreenY = endCardCenterY - targetScrollTop;
|
|
129
|
+
|
|
130
|
+
// Interpolate the desired screen position
|
|
131
|
+
const desiredScreenX = startCardScreenX + (endCardScreenX - startCardScreenX) * easedProgress;
|
|
132
|
+
const desiredScreenY = startCardScreenY + (endCardScreenY - startCardScreenY) * easedProgress;
|
|
133
|
+
|
|
134
|
+
// Calculate needed scroll position to put card at desired screen position
|
|
135
|
+
const neededScrollLeft = currentCardCenterX - desiredScreenX;
|
|
136
|
+
const neededScrollTop = currentCardCenterY - desiredScreenY;
|
|
137
|
+
|
|
138
|
+
let maxScrollLeft = container.scrollWidth - container.clientWidth;
|
|
139
|
+
let maxScrollTop = container.scrollHeight - container.clientHeight;
|
|
140
|
+
|
|
141
|
+
// If we have explicit layout size, use it for clamping to avoid DOM sync issues
|
|
142
|
+
if (getLayoutSizeAtZoom) {
|
|
143
|
+
const size = getLayoutSizeAtZoom(currentZoom);
|
|
144
|
+
if (size) {
|
|
145
|
+
maxScrollLeft = Math.max(0, size.width * currentZoom - container.clientWidth);
|
|
146
|
+
maxScrollTop = Math.max(0, size.height * currentZoom - container.clientHeight);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
// We can't clamp strictly during animation because the scrollWidth/Height might not have updated yet
|
|
151
|
+
// if the spacer hasn't resized. But usually spacer resizes immediately on zoom update.
|
|
152
|
+
// For safety, we just set it.
|
|
153
|
+
container.scrollLeft = Math.min(Math.max(0, neededScrollLeft), maxScrollLeft);
|
|
154
|
+
container.scrollTop = Math.min(Math.max(0, neededScrollTop), maxScrollTop);
|
|
155
|
+
} else {
|
|
156
|
+
// If no card position, just interpolate scroll position
|
|
157
|
+
// Use captured initial scroll positions for linear interpolation
|
|
158
|
+
const currentScrollLeft = initialScrollLeft + (targetScrollLeft - initialScrollLeft) * easedProgress;
|
|
159
|
+
const currentScrollTop = initialScrollTop + (targetScrollTop - initialScrollTop) * easedProgress;
|
|
160
|
+
|
|
161
|
+
container.scrollLeft = currentScrollLeft;
|
|
162
|
+
container.scrollTop = currentScrollTop;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
if (progress < 1) {
|
|
166
|
+
rafId = requestAnimationFrame(animate);
|
|
167
|
+
} else {
|
|
168
|
+
container.style.scrollBehavior = '';
|
|
169
|
+
container.scrollLeft = targetScrollLeft;
|
|
170
|
+
container.scrollTop = targetScrollTop;
|
|
171
|
+
onComplete?.();
|
|
172
|
+
}
|
|
173
|
+
};
|
|
174
|
+
|
|
175
|
+
rafId = requestAnimationFrame(animate);
|
|
176
|
+
|
|
177
|
+
return () => {
|
|
178
|
+
if (rafId !== null) {
|
|
179
|
+
cancelAnimationFrame(rafId);
|
|
180
|
+
container.style.scrollBehavior = '';
|
|
181
|
+
}
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
/**
|
|
186
|
+
* Calculate scroll position to center a card in viewport, accounting for detail panel
|
|
187
|
+
*/
|
|
188
|
+
export function calculateCenterScrollPosition(
|
|
189
|
+
container: HTMLElement,
|
|
190
|
+
cardPosition: { x: number; y: number; width: number; height: number },
|
|
191
|
+
zoomLevel: number,
|
|
192
|
+
detailPanelWidth: number = 0,
|
|
193
|
+
totalHeight?: number
|
|
194
|
+
): { scrollLeft: number; scrollTop: number } {
|
|
195
|
+
const cardCenterX = cardPosition.x * zoomLevel + (cardPosition.width * zoomLevel) / 2;
|
|
196
|
+
const cardCenterY = cardPosition.y * zoomLevel + (cardPosition.height * zoomLevel) / 2;
|
|
197
|
+
|
|
198
|
+
const availableWidth = container.clientWidth - detailPanelWidth;
|
|
199
|
+
const targetX = availableWidth / 2;
|
|
200
|
+
const targetY = container.clientHeight / 2;
|
|
201
|
+
|
|
202
|
+
const scrollLeft = Math.max(0, cardCenterX - targetX);
|
|
203
|
+
let scrollTop = Math.max(0, cardCenterY - targetY);
|
|
204
|
+
|
|
205
|
+
console.log('[Animation] calculateCenterScrollPosition', {
|
|
206
|
+
cardY: cardPosition.y,
|
|
207
|
+
zoomLevel,
|
|
208
|
+
cardCenterY,
|
|
209
|
+
targetY,
|
|
210
|
+
initialScrollTop: scrollTop,
|
|
211
|
+
totalHeight,
|
|
212
|
+
containerHeight: container.clientHeight
|
|
213
|
+
});
|
|
214
|
+
|
|
215
|
+
// If totalHeight is provided, clamp to valid scroll range
|
|
216
|
+
if (totalHeight) {
|
|
217
|
+
const contentHeight = totalHeight * zoomLevel;
|
|
218
|
+
const viewportHeight = container.clientHeight;
|
|
219
|
+
const maxScrollTop = Math.max(0, contentHeight - viewportHeight);
|
|
220
|
+
|
|
221
|
+
console.log('[Animation] Clamping', {
|
|
222
|
+
contentHeight,
|
|
223
|
+
viewportHeight,
|
|
224
|
+
maxScrollTop,
|
|
225
|
+
currentScrollTop: scrollTop,
|
|
226
|
+
clamped: Math.min(scrollTop, maxScrollTop)
|
|
227
|
+
});
|
|
228
|
+
|
|
229
|
+
scrollTop = Math.min(scrollTop, maxScrollTop);
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
return { scrollLeft, scrollTop };
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* Smooth scroll to position
|
|
237
|
+
*/
|
|
238
|
+
export function smoothScrollTo(
|
|
239
|
+
container: HTMLElement,
|
|
240
|
+
scrollLeft: number,
|
|
241
|
+
scrollTop: number,
|
|
242
|
+
smooth: boolean = true
|
|
243
|
+
): void {
|
|
244
|
+
container.scrollTo({
|
|
245
|
+
left: scrollLeft,
|
|
246
|
+
top: scrollTop,
|
|
247
|
+
behavior: smooth ? 'smooth' : 'auto',
|
|
248
|
+
});
|
|
249
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
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
|
+
// Zoom constants
|
|
5
|
+
export const ZOOM_MIN = 0.1;
|
|
6
|
+
export const ZOOM_MAX = 3;
|
|
7
|
+
export const ZOOM_STEP = 0.05;
|
|
8
|
+
|
|
9
|
+
// Layout constants
|
|
10
|
+
export const GROUP_SPACING = 40;
|
|
11
|
+
export const CARD_GAP = 8;
|
|
12
|
+
export const CARDS_PER_COLUMN = 5;
|
|
13
|
+
export const BASE_CARD_WIDTH = 180;
|
|
14
|
+
export const BASE_CARD_HEIGHT = 140;
|
|
15
|
+
export const DETAIL_PANEL_WIDTH = 380;
|
|
16
|
+
|
|
17
|
+
// Animation constants
|
|
18
|
+
export const ZOOM_ANIMATION_DURATION = 300;
|
|
19
|
+
export const ZOOM_MULTIPLIER = 1.15;
|
|
20
|
+
export const MIN_ZOOM_ON_SELECT = 1.2;
|