pne-ui 4.0.6 → 4.0.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/cjs/common/paynet/type.d.ts +2 -9
- package/cjs/common/paynet/type.js +3 -3
- package/cjs/common/paynet/type.js.map +1 -1
- package/cjs/common/pne/type.d.ts +8 -2
- package/cjs/common/pne/type.js +2 -2
- package/cjs/common/pne/type.js.map +1 -1
- package/cjs/component/CustomIconWrapper.d.ts +2 -1
- package/cjs/component/CustomIconWrapper.js.map +1 -1
- package/cjs/component/PneButton.d.ts +1 -1
- package/cjs/component/cloudscape/CloudscapeBoardStyles.js +1 -2
- package/cjs/component/cloudscape/CloudscapeBoardStyles.js.map +1 -1
- package/cjs/component/cloudscape/CloudscapeThemeProvider.js +1 -2
- package/cjs/component/cloudscape/CloudscapeThemeProvider.js.map +1 -1
- package/cjs/component/cloudscape/boardI18n.js +2 -2
- package/cjs/component/cloudscape/boardI18n.js.map +1 -1
- package/cjs/component/fab/PneFloatingActionButtons.js +1 -2
- package/cjs/component/fab/PneFloatingActionButtons.js.map +1 -1
- package/cjs/component/non-abstract-entity-selector/styled.d.ts +8 -13
- package/cjs/component/overlay/OverlayHost.js +1 -2
- package/cjs/component/overlay/OverlayHost.js.map +1 -1
- package/cjs/component/overlay/PermanentOverlay.js +1 -2
- package/cjs/component/overlay/PermanentOverlay.js.map +1 -1
- package/cjs/component/overlay/PermanentOverlayContext.d.ts +0 -1
- package/cjs/component/overlay/overlayStore.d.ts +4 -4
- package/cjs/component/responsive/useBreakpoint.js +1 -2
- package/cjs/component/responsive/useBreakpoint.js.map +1 -1
- package/cjs/component/search-ui/filters/component/criterion/DateRangeCriterion.js +2 -2
- package/cjs/component/search-ui/filters/component/criterion/DateRangeCriterion.js.map +1 -1
- package/cjs/component/search-ui/filters/state/store.d.ts +568 -88
- package/cjs/component/search-ui/filters/styled.d.ts +0 -1
- package/cjs/component/search-ui/multiget_select/state/store.d.ts +50 -11
- package/cjs/component/search-ui/state/store.d.ts +44 -4
- package/cjs/component/table/AbstractTable.js.map +1 -1
- package/cjs/component/table/PneTablePagination.d.ts +1 -2
- package/cjs/component/table/PneTablePaginationActions.d.ts +1 -1
- package/cjs/component/table/PneTableRow.d.ts +2 -5
- package/cjs/component/table/state/store.d.ts +5 -1
- package/cjs/component/widget-board/types.d.ts +0 -1
- package/cjs/component/widget-board/useWidgetBoardAutosize.d.ts +2 -2
- package/cjs/component/widget-board/useWidgetBoardLayoutSource.d.ts +4 -5
- package/cjs/component/widget-board/widgetBoardLayoutUtils.d.ts +1 -1
- package/cjs/createTheme.d.ts +1 -1
- package/cjs/exports/buttons.js +2 -4
- package/cjs/exports/buttons.js.map +1 -1
- package/cjs/exports/inputs.js +6 -8
- package/cjs/exports/inputs.js.map +1 -1
- package/cjs/exports/modals.js +3 -5
- package/cjs/exports/modals.js.map +1 -1
- package/cjs/exports/table.js +11 -13
- package/cjs/exports/table.js.map +1 -1
- package/cjs/exports/utils.js +2 -4
- package/cjs/exports/utils.js.map +1 -1
- package/esm/common/paynet/type.d.ts +2 -9
- package/esm/common/pne/type.d.ts +8 -2
- package/esm/component/CustomIconWrapper.d.ts +2 -1
- package/esm/component/CustomIconWrapper.js.map +1 -1
- package/esm/component/PneButton.d.ts +1 -1
- package/esm/component/non-abstract-entity-selector/styled.d.ts +8 -13
- package/esm/component/overlay/PermanentOverlayContext.d.ts +0 -1
- package/esm/component/overlay/overlayStore.d.ts +4 -4
- package/esm/component/search-ui/filters/component/criterion/DateRangeCriterion.js +2 -2
- package/esm/component/search-ui/filters/component/criterion/DateRangeCriterion.js.map +1 -1
- package/esm/component/search-ui/filters/state/store.d.ts +568 -88
- package/esm/component/search-ui/filters/styled.d.ts +0 -1
- package/esm/component/search-ui/multiget_select/state/store.d.ts +50 -11
- package/esm/component/search-ui/state/store.d.ts +44 -4
- package/esm/component/table/AbstractTable.js.map +1 -1
- package/esm/component/table/PneTablePagination.d.ts +1 -2
- package/esm/component/table/PneTablePaginationActions.d.ts +1 -1
- package/esm/component/table/PneTableRow.d.ts +2 -5
- package/esm/component/table/state/store.d.ts +5 -1
- package/esm/component/widget-board/types.d.ts +0 -1
- package/esm/component/widget-board/useWidgetBoardAutosize.d.ts +2 -2
- package/esm/component/widget-board/useWidgetBoardLayoutSource.d.ts +4 -5
- package/esm/component/widget-board/widgetBoardLayoutUtils.d.ts +1 -1
- package/esm/createTheme.d.ts +1 -1
- package/esm/src/common/index.d.ts +2 -0
- package/esm/src/common/index.js +3 -0
- package/esm/src/common/index.js.map +1 -0
- package/esm/src/common/paynet/dropdown.d.ts +7 -0
- package/esm/src/common/paynet/dropdown.js +56 -0
- package/esm/src/common/paynet/dropdown.js.map +1 -0
- package/esm/src/common/paynet/index.d.ts +3 -0
- package/esm/src/common/paynet/index.js +4 -0
- package/esm/src/common/paynet/index.js.map +1 -0
- package/esm/src/common/paynet/schema.d.ts +58 -0
- package/esm/src/common/paynet/schema.js +21 -0
- package/esm/src/common/paynet/schema.js.map +1 -0
- package/esm/src/common/paynet/skin.d.ts +36 -0
- package/esm/src/common/paynet/skin.js +2 -0
- package/esm/src/common/paynet/skin.js.map +1 -0
- package/esm/src/common/paynet/type.d.ts +36 -0
- package/esm/src/common/paynet/type.js +45 -0
- package/esm/src/common/paynet/type.js.map +1 -0
- package/esm/src/common/pne/index.d.ts +1 -0
- package/esm/src/common/pne/index.js +2 -0
- package/esm/src/common/pne/index.js.map +1 -0
- package/esm/src/common/pne/type.d.ts +19 -0
- package/esm/src/common/pne/type.js +18 -0
- package/esm/src/common/pne/type.js.map +1 -0
- package/esm/src/common/responsive/breakpoints.d.ts +3 -0
- package/esm/src/common/responsive/breakpoints.js +17 -0
- package/esm/src/common/responsive/breakpoints.js.map +1 -0
- package/esm/src/component/AutoTestAttribute.d.ts +8 -0
- package/esm/src/component/AutoTestAttribute.js +32 -0
- package/esm/src/component/AutoTestAttribute.js.map +1 -0
- package/esm/src/component/CustomIconWrapper.d.ts +9 -0
- package/esm/src/component/CustomIconWrapper.js +12 -0
- package/esm/src/component/CustomIconWrapper.js.map +1 -0
- package/esm/src/component/PneButton.d.ts +9 -0
- package/esm/src/component/PneButton.js +47 -0
- package/esm/src/component/PneButton.js.map +1 -0
- package/esm/src/component/PneButtonGroup.d.ts +3 -0
- package/esm/src/component/PneButtonGroup.js +15 -0
- package/esm/src/component/PneButtonGroup.js.map +1 -0
- package/esm/src/component/PneCheckbox.d.ts +3 -0
- package/esm/src/component/PneCheckbox.js +10 -0
- package/esm/src/component/PneCheckbox.js.map +1 -0
- package/esm/src/component/PneHighContrastLabeledCheckbox.d.ts +3 -0
- package/esm/src/component/PneHighContrastLabeledCheckbox.js +199 -0
- package/esm/src/component/PneHighContrastLabeledCheckbox.js.map +1 -0
- package/esm/src/component/PneLabeledCheckbox.d.ts +14 -0
- package/esm/src/component/PneLabeledCheckbox.js +12 -0
- package/esm/src/component/PneLabeledCheckbox.js.map +1 -0
- package/esm/src/component/PneModal.d.ts +12 -0
- package/esm/src/component/PneModal.js +63 -0
- package/esm/src/component/PneModal.js.map +1 -0
- package/esm/src/component/PneSwitch.d.ts +4 -0
- package/esm/src/component/PneSwitch.js +11 -0
- package/esm/src/component/PneSwitch.js.map +1 -0
- package/esm/src/component/PneTextField.d.ts +3 -0
- package/esm/src/component/PneTextField.js +11 -0
- package/esm/src/component/PneTextField.js.map +1 -0
- package/esm/src/component/cloudscape/CloudscapeBoardStyles.d.ts +10 -0
- package/esm/src/component/cloudscape/CloudscapeBoardStyles.js +88 -0
- package/esm/src/component/cloudscape/CloudscapeBoardStyles.js.map +1 -0
- package/esm/src/component/cloudscape/CloudscapeThemeProvider.d.ts +8 -0
- package/esm/src/component/cloudscape/CloudscapeThemeProvider.js +15 -0
- package/esm/src/component/cloudscape/CloudscapeThemeProvider.js.map +1 -0
- package/esm/src/component/cloudscape/boardI18n.d.ts +10 -0
- package/esm/src/component/cloudscape/boardI18n.js +47 -0
- package/esm/src/component/cloudscape/boardI18n.js.map +1 -0
- package/esm/src/component/cloudscape/cloudscapeTheme.d.ts +6 -0
- package/esm/src/component/cloudscape/cloudscapeTheme.js +11 -0
- package/esm/src/component/cloudscape/cloudscapeTheme.js.map +1 -0
- package/esm/src/component/confirm/PneConfirmProvider.d.ts +17 -0
- package/esm/src/component/confirm/PneConfirmProvider.js +75 -0
- package/esm/src/component/confirm/PneConfirmProvider.js.map +1 -0
- package/esm/src/component/confirm/index.d.ts +1 -0
- package/esm/src/component/confirm/index.js +2 -0
- package/esm/src/component/confirm/index.js.map +1 -0
- package/esm/src/component/dropdown/PneAsyncAutocomplete.d.ts +15 -0
- package/esm/src/component/dropdown/PneAsyncAutocomplete.js +65 -0
- package/esm/src/component/dropdown/PneAsyncAutocomplete.js.map +1 -0
- package/esm/src/component/dropdown/PneAutocomplete.d.ts +13 -0
- package/esm/src/component/dropdown/PneAutocomplete.js +16 -0
- package/esm/src/component/dropdown/PneAutocomplete.js.map +1 -0
- package/esm/src/component/dropdown/PneSelect.d.ts +13 -0
- package/esm/src/component/dropdown/PneSelect.js +44 -0
- package/esm/src/component/dropdown/PneSelect.js.map +1 -0
- package/esm/src/component/fab/PneFloatingActionButtons.d.ts +42 -0
- package/esm/src/component/fab/PneFloatingActionButtons.js +119 -0
- package/esm/src/component/fab/PneFloatingActionButtons.js.map +1 -0
- package/esm/src/component/non-abstract-entity-selector/AbstractEntitySelectModal.d.ts +19 -0
- package/esm/src/component/non-abstract-entity-selector/AbstractEntitySelectModal.js +64 -0
- package/esm/src/component/non-abstract-entity-selector/AbstractEntitySelectModal.js.map +1 -0
- package/esm/src/component/non-abstract-entity-selector/AbstractEntitySelector.d.ts +27 -0
- package/esm/src/component/non-abstract-entity-selector/AbstractEntitySelector.js +382 -0
- package/esm/src/component/non-abstract-entity-selector/AbstractEntitySelector.js.map +1 -0
- package/esm/src/component/non-abstract-entity-selector/ItemEntitySelector.d.ts +11 -0
- package/esm/src/component/non-abstract-entity-selector/ItemEntitySelector.js +8 -0
- package/esm/src/component/non-abstract-entity-selector/ItemEntitySelector.js.map +1 -0
- package/esm/src/component/non-abstract-entity-selector/styled.d.ts +30 -0
- package/esm/src/component/non-abstract-entity-selector/styled.js +145 -0
- package/esm/src/component/non-abstract-entity-selector/styled.js.map +1 -0
- package/esm/src/component/overlay/OverlayHost.d.ts +14 -0
- package/esm/src/component/overlay/OverlayHost.js +212 -0
- package/esm/src/component/overlay/OverlayHost.js.map +1 -0
- package/esm/src/component/overlay/PermanentOverlay.d.ts +14 -0
- package/esm/src/component/overlay/PermanentOverlay.js +29 -0
- package/esm/src/component/overlay/PermanentOverlay.js.map +1 -0
- package/esm/src/component/overlay/PermanentOverlayContext.d.ts +6 -0
- package/esm/src/component/overlay/PermanentOverlayContext.js +3 -0
- package/esm/src/component/overlay/PermanentOverlayContext.js.map +1 -0
- package/esm/src/component/overlay/overlayRuntime.d.ts +3 -0
- package/esm/src/component/overlay/overlayRuntime.js +39 -0
- package/esm/src/component/overlay/overlayRuntime.js.map +1 -0
- package/esm/src/component/overlay/overlayStore.d.ts +16 -0
- package/esm/src/component/overlay/overlayStore.js +70 -0
- package/esm/src/component/overlay/overlayStore.js.map +1 -0
- package/esm/src/component/overlay/types.d.ts +40 -0
- package/esm/src/component/overlay/types.js +2 -0
- package/esm/src/component/overlay/types.js.map +1 -0
- package/esm/src/component/responsive/useBreakpoint.d.ts +8 -0
- package/esm/src/component/responsive/useBreakpoint.js +17 -0
- package/esm/src/component/responsive/useBreakpoint.js.map +1 -0
- package/esm/src/component/search-ui/SearchUI.d.ts +89 -0
- package/esm/src/component/search-ui/SearchUI.js +103 -0
- package/esm/src/component/search-ui/SearchUI.js.map +1 -0
- package/esm/src/component/search-ui/SearchUIProvider.d.ts +114 -0
- package/esm/src/component/search-ui/SearchUIProvider.js +85 -0
- package/esm/src/component/search-ui/SearchUIProvider.js.map +1 -0
- package/esm/src/component/search-ui/filters/CriterionContainer.d.ts +7 -0
- package/esm/src/component/search-ui/filters/CriterionContainer.js +148 -0
- package/esm/src/component/search-ui/filters/CriterionContainer.js.map +1 -0
- package/esm/src/component/search-ui/filters/SearchUIFilters.d.ts +102 -0
- package/esm/src/component/search-ui/filters/SearchUIFilters.js +226 -0
- package/esm/src/component/search-ui/filters/SearchUIFilters.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/button/SearchUIFiltersCriterionHeaderClearButton.d.ts +6 -0
- package/esm/src/component/search-ui/filters/component/button/SearchUIFiltersCriterionHeaderClearButton.js +15 -0
- package/esm/src/component/search-ui/filters/component/button/SearchUIFiltersCriterionHeaderClearButton.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/button/SearchUIFiltersCriterionHeaderRemoveButton.d.ts +6 -0
- package/esm/src/component/search-ui/filters/component/button/SearchUIFiltersCriterionHeaderRemoveButton.js +11 -0
- package/esm/src/component/search-ui/filters/component/button/SearchUIFiltersCriterionHeaderRemoveButton.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/CardTypesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/CardTypesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/CardTypesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/CountriesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/CountriesCriterion.js +19 -0
- package/esm/src/component/search-ui/filters/component/criterion/CountriesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/CriterionLeft.d.ts +7 -0
- package/esm/src/component/search-ui/filters/component/criterion/CriterionLeft.js +17 -0
- package/esm/src/component/search-ui/filters/component/criterion/CriterionLeft.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/CriterionRight.d.ts +7 -0
- package/esm/src/component/search-ui/filters/component/criterion/CriterionRight.js +29 -0
- package/esm/src/component/search-ui/filters/component/criterion/CriterionRight.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/CurrenciesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/CurrenciesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/CurrenciesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/DateRangeCriterion.d.ts +6 -0
- package/esm/src/component/search-ui/filters/component/criterion/DateRangeCriterion.js +157 -0
- package/esm/src/component/search-ui/filters/component/criterion/DateRangeCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/ErrorCodeCriterion.d.ts +3 -0
- package/esm/src/component/search-ui/filters/component/criterion/ErrorCodeCriterion.js +40 -0
- package/esm/src/component/search-ui/filters/component/criterion/ErrorCodeCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/ExactSearchCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/ExactSearchCriterion.js +37 -0
- package/esm/src/component/search-ui/filters/component/criterion/ExactSearchCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/GroupingCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/GroupingCriterion.js +45 -0
- package/esm/src/component/search-ui/filters/component/criterion/GroupingCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/MarkerStatusCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/MarkerStatusCriterion.js +19 -0
- package/esm/src/component/search-ui/filters/component/criterion/MarkerStatusCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/MarkerTypesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/MarkerTypesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/MarkerTypesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/MfoFonfigurationTypesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/MfoFonfigurationTypesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/MfoFonfigurationTypesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/MultigetCriterionPanel.d.ts +8 -0
- package/esm/src/component/search-ui/filters/component/criterion/MultigetCriterionPanel.js +95 -0
- package/esm/src/component/search-ui/filters/component/criterion/MultigetCriterionPanel.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/ProcessorLogEntryTypesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/ProcessorLogEntryTypesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/ProcessorLogEntryTypesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/ProjectCurrencyCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/ProjectCurrencyCriterion.js +62 -0
- package/esm/src/component/search-ui/filters/component/criterion/ProjectCurrencyCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/RecurrenceStatusesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/RecurrenceStatusesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/RecurrenceStatusesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/RecurrenceTypesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/RecurrenceTypesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/RecurrenceTypesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/StatusCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/StatusCriterion.js +19 -0
- package/esm/src/component/search-ui/filters/component/criterion/StatusCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/ThreeDCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/ThreeDCriterion.js +24 -0
- package/esm/src/component/search-ui/filters/component/criterion/ThreeDCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionSessionStatusCriterion.d.ts +3 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionSessionStatusCriterion.js +82 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionSessionStatusCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionStatusesCriterion.d.ts +3 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionStatusesCriterion.js +21 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionStatusesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionTypesCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionTypesCriterion.js +20 -0
- package/esm/src/component/search-ui/filters/component/criterion/TransactionTypesCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/AmountMaskInput.d.ts +13 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/AmountMaskInput.js +16 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/AmountMaskInput.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/Card6And4MaskInput.d.ts +13 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/Card6And4MaskInput.js +9 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/Card6And4MaskInput.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchCountrySelect.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchCountrySelect.js +33 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchCountrySelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchCriterion.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchCriterion.js +19 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchCriterion.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchInput.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchInput.js +84 -0
- package/esm/src/component/search-ui/filters/component/criterion/orders-search/OrdersSearchInput.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/criterion/style.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/criterion/style.js +12 -0
- package/esm/src/component/search-ui/filters/component/criterion/style.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIAbstractEntitySelect.d.ts +9 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIAbstractEntitySelect.js +82 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIAbstractEntitySelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIAddFilter.d.ts +8 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIAddFilter.js +47 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIAddFilter.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUICollapsableGroupSelect.d.ts +8 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUICollapsableGroupSelect.js +169 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUICollapsableGroupSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUICountriesSelect.d.ts +10 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUICountriesSelect.js +71 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUICountriesSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIDateRangeSpecTypeSelect.d.ts +3 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIDateRangeSpecTypeSelect.js +53 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIDateRangeSpecTypeSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIExactSearchLabelSelect.d.ts +9 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIExactSearchLabelSelect.js +16 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIExactSearchLabelSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIGroupingDateTypeSelect.d.ts +3 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIGroupingDateTypeSelect.js +19 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIGroupingDateTypeSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIOrderDateTypeSelect.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIOrderDateTypeSelect.js +28 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIOrderDateTypeSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIOrdersSearchLabelSelect.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIOrdersSearchLabelSelect.js +15 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIOrdersSearchLabelSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIProcessorLogEntryTypeSelect.d.ts +9 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIProcessorLogEntryTypeSelect.js +20 -0
- package/esm/src/component/search-ui/filters/component/select/SearchUIProcessorLogEntryTypeSelect.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/select/style.d.ts +2 -0
- package/esm/src/component/search-ui/filters/component/select/style.js +23 -0
- package/esm/src/component/search-ui/filters/component/select/style.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/template/SearchUITemplatePanel.d.ts +6 -0
- package/esm/src/component/search-ui/filters/component/template/SearchUITemplatePanel.js +77 -0
- package/esm/src/component/search-ui/filters/component/template/SearchUITemplatePanel.js.map +1 -0
- package/esm/src/component/search-ui/filters/component/template/SearchUITemplatesMenu.d.ts +3 -0
- package/esm/src/component/search-ui/filters/component/template/SearchUITemplatesMenu.js +100 -0
- package/esm/src/component/search-ui/filters/component/template/SearchUITemplatesMenu.js.map +1 -0
- package/esm/src/component/search-ui/filters/criterionAvailability.d.ts +7 -0
- package/esm/src/component/search-ui/filters/criterionAvailability.js +8 -0
- package/esm/src/component/search-ui/filters/criterionAvailability.js.map +1 -0
- package/esm/src/component/search-ui/filters/state/actions.d.ts +10 -0
- package/esm/src/component/search-ui/filters/state/actions.js +1047 -0
- package/esm/src/component/search-ui/filters/state/actions.js.map +1 -0
- package/esm/src/component/search-ui/filters/state/initial.d.ts +13 -0
- package/esm/src/component/search-ui/filters/state/initial.js +114 -0
- package/esm/src/component/search-ui/filters/state/initial.js.map +1 -0
- package/esm/src/component/search-ui/filters/state/store.d.ts +1067 -0
- package/esm/src/component/search-ui/filters/state/store.js +11 -0
- package/esm/src/component/search-ui/filters/state/store.js.map +1 -0
- package/esm/src/component/search-ui/filters/state/type.d.ts +84 -0
- package/esm/src/component/search-ui/filters/state/type.js +2 -0
- package/esm/src/component/search-ui/filters/state/type.js.map +1 -0
- package/esm/src/component/search-ui/filters/state/undo.d.ts +2 -0
- package/esm/src/component/search-ui/filters/state/undo.js +32 -0
- package/esm/src/component/search-ui/filters/state/undo.js.map +1 -0
- package/esm/src/component/search-ui/filters/styled.d.ts +6 -0
- package/esm/src/component/search-ui/filters/styled.js +77 -0
- package/esm/src/component/search-ui/filters/styled.js.map +1 -0
- package/esm/src/component/search-ui/filters/types.d.ts +231 -0
- package/esm/src/component/search-ui/filters/types.js +202 -0
- package/esm/src/component/search-ui/filters/types.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/MultigetSelect.d.ts +11 -0
- package/esm/src/component/search-ui/multiget_select/MultigetSelect.js +212 -0
- package/esm/src/component/search-ui/multiget_select/MultigetSelect.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/MultigetSelectTable.d.ts +2 -0
- package/esm/src/component/search-ui/multiget_select/MultigetSelectTable.js +70 -0
- package/esm/src/component/search-ui/multiget_select/MultigetSelectTable.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/state/IsolatedStoreProvider.d.ts +6 -0
- package/esm/src/component/search-ui/multiget_select/state/IsolatedStoreProvider.js +7 -0
- package/esm/src/component/search-ui/multiget_select/state/IsolatedStoreProvider.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/state/actions.d.ts +3 -0
- package/esm/src/component/search-ui/multiget_select/state/actions.js +49 -0
- package/esm/src/component/search-ui/multiget_select/state/actions.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/state/initial.d.ts +2 -0
- package/esm/src/component/search-ui/multiget_select/state/initial.js +13 -0
- package/esm/src/component/search-ui/multiget_select/state/initial.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/state/store.d.ts +112 -0
- package/esm/src/component/search-ui/multiget_select/state/store.js +20 -0
- package/esm/src/component/search-ui/multiget_select/state/store.js.map +1 -0
- package/esm/src/component/search-ui/multiget_select/state/type.d.ts +26 -0
- package/esm/src/component/search-ui/multiget_select/state/type.js +2 -0
- package/esm/src/component/search-ui/multiget_select/state/type.js.map +1 -0
- package/esm/src/component/search-ui/state/actions.d.ts +3 -0
- package/esm/src/component/search-ui/state/actions.js +8 -0
- package/esm/src/component/search-ui/state/actions.js.map +1 -0
- package/esm/src/component/search-ui/state/initial.d.ts +2 -0
- package/esm/src/component/search-ui/state/initial.js +32 -0
- package/esm/src/component/search-ui/state/initial.js.map +1 -0
- package/esm/src/component/search-ui/state/store.d.ts +83 -0
- package/esm/src/component/search-ui/state/store.js +9 -0
- package/esm/src/component/search-ui/state/store.js.map +1 -0
- package/esm/src/component/search-ui/state/type.d.ts +8 -0
- package/esm/src/component/search-ui/state/type.js +2 -0
- package/esm/src/component/search-ui/state/type.js.map +1 -0
- package/esm/src/component/table/AbstractHeaderTableCell.d.ts +4 -0
- package/esm/src/component/table/AbstractHeaderTableCell.js +20 -0
- package/esm/src/component/table/AbstractHeaderTableCell.js.map +1 -0
- package/esm/src/component/table/AbstractTable.d.ts +45 -0
- package/esm/src/component/table/AbstractTable.js +112 -0
- package/esm/src/component/table/AbstractTable.js.map +1 -0
- package/esm/src/component/table/AbstractTableCell.d.ts +4 -0
- package/esm/src/component/table/AbstractTableCell.js +7 -0
- package/esm/src/component/table/AbstractTableCell.js.map +1 -0
- package/esm/src/component/table/PneFirstPageIcon.d.ts +6 -0
- package/esm/src/component/table/PneFirstPageIcon.js +10 -0
- package/esm/src/component/table/PneFirstPageIcon.js.map +1 -0
- package/esm/src/component/table/PneHeaderTableCell.d.ts +4 -0
- package/esm/src/component/table/PneHeaderTableCell.js +17 -0
- package/esm/src/component/table/PneHeaderTableCell.js.map +1 -0
- package/esm/src/component/table/PneLastPageIcon.d.ts +6 -0
- package/esm/src/component/table/PneLastPageIcon.js +10 -0
- package/esm/src/component/table/PneLastPageIcon.js.map +1 -0
- package/esm/src/component/table/PneNextPageIcon.d.ts +6 -0
- package/esm/src/component/table/PneNextPageIcon.js +10 -0
- package/esm/src/component/table/PneNextPageIcon.js.map +1 -0
- package/esm/src/component/table/PnePreviousPageIcon.d.ts +6 -0
- package/esm/src/component/table/PnePreviousPageIcon.js +10 -0
- package/esm/src/component/table/PnePreviousPageIcon.js.map +1 -0
- package/esm/src/component/table/PneTable.d.ts +4 -0
- package/esm/src/component/table/PneTable.js +19 -0
- package/esm/src/component/table/PneTable.js.map +1 -0
- package/esm/src/component/table/PneTableCell.d.ts +6 -0
- package/esm/src/component/table/PneTableCell.js +20 -0
- package/esm/src/component/table/PneTableCell.js.map +1 -0
- package/esm/src/component/table/PneTableControlCell.d.ts +6 -0
- package/esm/src/component/table/PneTableControlCell.js +15 -0
- package/esm/src/component/table/PneTableControlCell.js.map +1 -0
- package/esm/src/component/table/PneTablePagination.d.ts +2 -0
- package/esm/src/component/table/PneTablePagination.js +28 -0
- package/esm/src/component/table/PneTablePagination.js.map +1 -0
- package/esm/src/component/table/PneTablePaginationActions.d.ts +12 -0
- package/esm/src/component/table/PneTablePaginationActions.js +119 -0
- package/esm/src/component/table/PneTablePaginationActions.js.map +1 -0
- package/esm/src/component/table/PneTableRow.d.ts +4 -0
- package/esm/src/component/table/PneTableRow.js +28 -0
- package/esm/src/component/table/PneTableRow.js.map +1 -0
- package/esm/src/component/table/PneTableSortLabel.d.ts +10 -0
- package/esm/src/component/table/PneTableSortLabel.js +35 -0
- package/esm/src/component/table/PneTableSortLabel.js.map +1 -0
- package/esm/src/component/table/state/actions.d.ts +3 -0
- package/esm/src/component/table/state/actions.js +8 -0
- package/esm/src/component/table/state/actions.js.map +1 -0
- package/esm/src/component/table/state/initial.d.ts +2 -0
- package/esm/src/component/table/state/initial.js +4 -0
- package/esm/src/component/table/state/initial.js.map +1 -0
- package/esm/src/component/table/state/store.d.ts +11 -0
- package/esm/src/component/table/state/store.js +9 -0
- package/esm/src/component/table/state/store.js.map +1 -0
- package/esm/src/component/table/state/type.d.ts +7 -0
- package/esm/src/component/table/state/type.js +2 -0
- package/esm/src/component/table/state/type.js.map +1 -0
- package/esm/src/component/table/type.d.ts +5 -0
- package/esm/src/component/table/type.js +2 -0
- package/esm/src/component/table/type.js.map +1 -0
- package/esm/src/component/table/useDelayedLoading.d.ts +9 -0
- package/esm/src/component/table/useDelayedLoading.js +48 -0
- package/esm/src/component/table/useDelayedLoading.js.map +1 -0
- package/esm/src/component/table/useTable.d.ts +41 -0
- package/esm/src/component/table/useTable.js +242 -0
- package/esm/src/component/table/useTable.js.map +1 -0
- package/esm/src/component/useModal.d.ts +8 -0
- package/esm/src/component/useModal.js +14 -0
- package/esm/src/component/useModal.js.map +1 -0
- package/esm/src/component/widget-board/WidgetBoard.d.ts +13 -0
- package/esm/src/component/widget-board/WidgetBoard.js +326 -0
- package/esm/src/component/widget-board/WidgetBoard.js.map +1 -0
- package/esm/src/component/widget-board/WidgetBoardFab.d.ts +6 -0
- package/esm/src/component/widget-board/WidgetBoardFab.js +23 -0
- package/esm/src/component/widget-board/WidgetBoardFab.js.map +1 -0
- package/esm/src/component/widget-board/WidgetBoardItem.d.ts +16 -0
- package/esm/src/component/widget-board/WidgetBoardItem.js +50 -0
- package/esm/src/component/widget-board/WidgetBoardItem.js.map +1 -0
- package/esm/src/component/widget-board/WidgetBoardScope.d.ts +7 -0
- package/esm/src/component/widget-board/WidgetBoardScope.js +17 -0
- package/esm/src/component/widget-board/WidgetBoardScope.js.map +1 -0
- package/esm/src/component/widget-board/WidgetBoardSkeleton.d.ts +2 -0
- package/esm/src/component/widget-board/WidgetBoardSkeleton.js +60 -0
- package/esm/src/component/widget-board/WidgetBoardSkeleton.js.map +1 -0
- package/esm/src/component/widget-board/WidgetBoardVisibilityModal.d.ts +10 -0
- package/esm/src/component/widget-board/WidgetBoardVisibilityModal.js +42 -0
- package/esm/src/component/widget-board/WidgetBoardVisibilityModal.js.map +1 -0
- package/esm/src/component/widget-board/WidgetLayoutsPanel.d.ts +21 -0
- package/esm/src/component/widget-board/WidgetLayoutsPanel.js +124 -0
- package/esm/src/component/widget-board/WidgetLayoutsPanel.js.map +1 -0
- package/esm/src/component/widget-board/index.d.ts +8 -0
- package/esm/src/component/widget-board/index.js +9 -0
- package/esm/src/component/widget-board/index.js.map +1 -0
- package/esm/src/component/widget-board/layoutPersistence.d.ts +2 -0
- package/esm/src/component/widget-board/layoutPersistence.js +60 -0
- package/esm/src/component/widget-board/layoutPersistence.js.map +1 -0
- package/esm/src/component/widget-board/types.d.ts +75 -0
- package/esm/src/component/widget-board/types.js +2 -0
- package/esm/src/component/widget-board/types.js.map +1 -0
- package/esm/src/component/widget-board/useWidgetBoardAutosize.d.ts +19 -0
- package/esm/src/component/widget-board/useWidgetBoardAutosize.js +180 -0
- package/esm/src/component/widget-board/useWidgetBoardAutosize.js.map +1 -0
- package/esm/src/component/widget-board/useWidgetBoardFabActions.d.ts +11 -0
- package/esm/src/component/widget-board/useWidgetBoardFabActions.js +99 -0
- package/esm/src/component/widget-board/useWidgetBoardFabActions.js.map +1 -0
- package/esm/src/component/widget-board/useWidgetBoardInteractionLock.d.ts +1 -0
- package/esm/src/component/widget-board/useWidgetBoardInteractionLock.js +25 -0
- package/esm/src/component/widget-board/useWidgetBoardInteractionLock.js.map +1 -0
- package/esm/src/component/widget-board/useWidgetBoardLayoutActions.d.ts +28 -0
- package/esm/src/component/widget-board/useWidgetBoardLayoutActions.js +140 -0
- package/esm/src/component/widget-board/useWidgetBoardLayoutActions.js.map +1 -0
- package/esm/src/component/widget-board/useWidgetBoardLayoutSource.d.ts +29 -0
- package/esm/src/component/widget-board/useWidgetBoardLayoutSource.js +68 -0
- package/esm/src/component/widget-board/useWidgetBoardLayoutSource.js.map +1 -0
- package/esm/src/component/widget-board/useWidgetBoardStateActions.d.ts +24 -0
- package/esm/src/component/widget-board/useWidgetBoardStateActions.js +245 -0
- package/esm/src/component/widget-board/useWidgetBoardStateActions.js.map +1 -0
- package/esm/src/component/widget-board/widgetBoardFabStore.d.ts +27 -0
- package/esm/src/component/widget-board/widgetBoardFabStore.js +12 -0
- package/esm/src/component/widget-board/widgetBoardFabStore.js.map +1 -0
- package/esm/src/component/widget-board/widgetBoardLayoutUtils.d.ts +21 -0
- package/esm/src/component/widget-board/widgetBoardLayoutUtils.js +113 -0
- package/esm/src/component/widget-board/widgetBoardLayoutUtils.js.map +1 -0
- package/esm/src/createTheme.d.ts +3 -0
- package/esm/src/createTheme.js +142 -0
- package/esm/src/createTheme.js.map +1 -0
- package/esm/src/exports/buttons.d.ts +2 -0
- package/esm/src/exports/buttons.js +3 -0
- package/esm/src/exports/buttons.js.map +1 -0
- package/esm/src/exports/cloudscape.d.ts +5 -0
- package/esm/src/exports/cloudscape.js +6 -0
- package/esm/src/exports/cloudscape.js.map +1 -0
- package/esm/src/exports/confirm.d.ts +1 -0
- package/esm/src/exports/confirm.js +2 -0
- package/esm/src/exports/confirm.js.map +1 -0
- package/esm/src/exports/entities.d.ts +2 -0
- package/esm/src/exports/entities.js +3 -0
- package/esm/src/exports/entities.js.map +1 -0
- package/esm/src/exports/fab.d.ts +1 -0
- package/esm/src/exports/fab.js +2 -0
- package/esm/src/exports/fab.js.map +1 -0
- package/esm/src/exports/inputs.d.ts +10 -0
- package/esm/src/exports/inputs.js +9 -0
- package/esm/src/exports/inputs.js.map +1 -0
- package/esm/src/exports/modals.d.ts +2 -0
- package/esm/src/exports/modals.js +3 -0
- package/esm/src/exports/modals.js.map +1 -0
- package/esm/src/exports/overlay.d.ts +4 -0
- package/esm/src/exports/overlay.js +5 -0
- package/esm/src/exports/overlay.js.map +1 -0
- package/esm/src/exports/search.d.ts +7 -0
- package/esm/src/exports/search.js +7 -0
- package/esm/src/exports/search.js.map +1 -0
- package/esm/src/exports/table.d.ts +13 -0
- package/esm/src/exports/table.js +11 -0
- package/esm/src/exports/table.js.map +1 -0
- package/esm/src/exports/theme.d.ts +2 -0
- package/esm/src/exports/theme.js +2 -0
- package/esm/src/exports/theme.js.map +1 -0
- package/esm/src/exports/utils.d.ts +4 -0
- package/esm/src/exports/utils.js +5 -0
- package/esm/src/exports/utils.js.map +1 -0
- package/esm/src/index.d.ts +62 -0
- package/esm/src/index.js +14 -0
- package/esm/src/index.js.map +1 -0
- package/esm/src/usePneTheme.d.ts +2 -0
- package/esm/src/usePneTheme.js +5 -0
- package/esm/src/usePneTheme.js.map +1 -0
- package/package.json +22 -19
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import type { BoardProps } from '@cloudscape-design/board-components/board';
|
|
2
|
+
import type { WidgetLayoutOption } from './WidgetLayoutsPanel';
|
|
3
|
+
export type WidgetId = string;
|
|
4
|
+
export type WidgetLayoutSnapshot = {
|
|
5
|
+
columnSpan?: number;
|
|
6
|
+
rowSpan?: number;
|
|
7
|
+
columnOffset?: BoardProps.Item['columnOffset'];
|
|
8
|
+
order: number;
|
|
9
|
+
};
|
|
10
|
+
export type WidgetLayoutMemory = Record<string, Record<WidgetId, WidgetLayoutSnapshot>>;
|
|
11
|
+
export type WidgetLayoutSize = {
|
|
12
|
+
columnSpan: number;
|
|
13
|
+
rowSpan: number;
|
|
14
|
+
columnOffset?: BoardProps.Item['columnOffset'];
|
|
15
|
+
};
|
|
16
|
+
export type WidgetLayoutLimits = {
|
|
17
|
+
minColumnSpan?: number;
|
|
18
|
+
minRowSpan?: number;
|
|
19
|
+
};
|
|
20
|
+
export type WidgetHeightMode = 'auto' | 'fixed';
|
|
21
|
+
export type WidgetHeightModeMemory = Record<string, Partial<Record<WidgetId, WidgetHeightMode>>>;
|
|
22
|
+
export type WidgetLayoutInitialState = {
|
|
23
|
+
isHidden?: boolean;
|
|
24
|
+
isCollapsed?: boolean;
|
|
25
|
+
};
|
|
26
|
+
export type WidgetLayoutConfig = {
|
|
27
|
+
defaultSize: WidgetLayoutSize;
|
|
28
|
+
limits?: WidgetLayoutLimits;
|
|
29
|
+
initialState?: WidgetLayoutInitialState;
|
|
30
|
+
heightMode?: WidgetHeightMode;
|
|
31
|
+
};
|
|
32
|
+
export type BreakpointLayoutConfig = {
|
|
33
|
+
widgets: Record<WidgetId, WidgetLayoutConfig>;
|
|
34
|
+
};
|
|
35
|
+
export type WidgetDefinition = {
|
|
36
|
+
id: WidgetId;
|
|
37
|
+
title: string;
|
|
38
|
+
render: () => React.ReactNode;
|
|
39
|
+
settingsActions?: React.ReactNode;
|
|
40
|
+
contentFullHeight?: boolean;
|
|
41
|
+
};
|
|
42
|
+
export type WidgetBoardItemData = {
|
|
43
|
+
id: WidgetId;
|
|
44
|
+
title: string;
|
|
45
|
+
};
|
|
46
|
+
export type WidgetBoardState = {
|
|
47
|
+
items: Array<BoardProps.Item<WidgetBoardItemData>>;
|
|
48
|
+
hidden: WidgetId[];
|
|
49
|
+
collapsed: WidgetId[];
|
|
50
|
+
sizeMemory: Partial<Record<WidgetId, number>>;
|
|
51
|
+
layoutMemory: WidgetLayoutMemory;
|
|
52
|
+
heightModeMemory: WidgetHeightModeMemory;
|
|
53
|
+
};
|
|
54
|
+
export type WidgetBoardLayoutOption = WidgetLayoutOption & {
|
|
55
|
+
layoutByBreakpoint: Record<number | string, BreakpointLayoutConfig>;
|
|
56
|
+
};
|
|
57
|
+
export type WidgetBoardLoadLayoutsResult = {
|
|
58
|
+
options: WidgetBoardLayoutOption[];
|
|
59
|
+
selectedId?: string;
|
|
60
|
+
};
|
|
61
|
+
export type WidgetBoardActionsState = {
|
|
62
|
+
hasHiddenWidgets: boolean;
|
|
63
|
+
canResetLayout: boolean;
|
|
64
|
+
isDefaultLayoutSelected: boolean;
|
|
65
|
+
selectedLayoutId?: string;
|
|
66
|
+
defaultLayoutId: string;
|
|
67
|
+
};
|
|
68
|
+
export type WidgetBoardProps = {
|
|
69
|
+
widgets: WidgetDefinition[];
|
|
70
|
+
layoutByBreakpoint: Record<number | string, BreakpointLayoutConfig>;
|
|
71
|
+
loadLayouts: () => Promise<WidgetBoardLoadLayoutsResult | null>;
|
|
72
|
+
saveLayouts: (options: WidgetBoardLayoutOption[], selectedId?: string) => Promise<void>;
|
|
73
|
+
onActionsStateChange?: (state: WidgetBoardActionsState) => void;
|
|
74
|
+
autoHeightEnabled?: boolean;
|
|
75
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/component/widget-board/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Dispatch, SetStateAction } from 'react';
|
|
2
|
+
import type { WidgetBoardState } from './types';
|
|
3
|
+
import { type WidgetDefinitionWithLayout } from './widgetBoardLayoutUtils';
|
|
4
|
+
type UseWidgetBoardAutosizeParams = {
|
|
5
|
+
autoHeightEnabled: boolean;
|
|
6
|
+
lockedHeightModeByWidgetId: Partial<Record<string, boolean>>;
|
|
7
|
+
definitionsMap: Map<string, WidgetDefinitionWithLayout>;
|
|
8
|
+
currentBreakpointKey: string;
|
|
9
|
+
isInteractionLocked: boolean;
|
|
10
|
+
layoutPresetBreakpoint: number | string | undefined;
|
|
11
|
+
setLayoutState: Dispatch<SetStateAction<WidgetBoardState>>;
|
|
12
|
+
};
|
|
13
|
+
export declare const useWidgetBoardAutosize: ({ autoHeightEnabled, lockedHeightModeByWidgetId, definitionsMap, currentBreakpointKey, isInteractionLocked, layoutPresetBreakpoint, setLayoutState, }: UseWidgetBoardAutosizeParams) => {
|
|
14
|
+
boardRootRef: import("react").RefObject<HTMLDivElement | null>;
|
|
15
|
+
handleContentRef: (widgetId: string, node: HTMLDivElement | null) => void;
|
|
16
|
+
measuredRowsRef: import("react").RefObject<Record<string, number>>;
|
|
17
|
+
remeasureAll: () => void;
|
|
18
|
+
};
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { useCallback, useEffect, useRef } from 'react';
|
|
2
|
+
import { DEFAULT_ROW_GAP, DEFAULT_ROW_HEIGHT } from './widgetBoardLayoutUtils';
|
|
3
|
+
export const useWidgetBoardAutosize = ({ autoHeightEnabled, lockedHeightModeByWidgetId, definitionsMap, currentBreakpointKey, isInteractionLocked, layoutPresetBreakpoint, setLayoutState, }) => {
|
|
4
|
+
const boardRootRef = useRef(null);
|
|
5
|
+
const gridMetricsRef = useRef(null);
|
|
6
|
+
const contentRefs = useRef(new Map());
|
|
7
|
+
const resizeObserverRef = useRef(null);
|
|
8
|
+
const measuredRowsRef = useRef({});
|
|
9
|
+
const parseCssNumber = useCallback((value) => {
|
|
10
|
+
if (!value)
|
|
11
|
+
return Number.NaN;
|
|
12
|
+
const parsed = Number.parseFloat(value);
|
|
13
|
+
return Number.isFinite(parsed) ? parsed : Number.NaN;
|
|
14
|
+
}, []);
|
|
15
|
+
const resolveFallbackRowGap = useCallback(() => (typeof window !== 'undefined' && window.innerWidth < 640 ? 8 : DEFAULT_ROW_GAP), []);
|
|
16
|
+
const findGridElement = useCallback((root) => {
|
|
17
|
+
const boardRoot = root.querySelector('[data-awsui-board]') ?? root;
|
|
18
|
+
const boardStyle = window.getComputedStyle(boardRoot);
|
|
19
|
+
if (boardStyle.display === 'grid' && boardStyle.gridAutoRows && boardStyle.gridAutoRows !== 'auto') {
|
|
20
|
+
return boardRoot;
|
|
21
|
+
}
|
|
22
|
+
const preferred = boardRoot.querySelectorAll('[class*="awsui_grid_"]');
|
|
23
|
+
const candidates = preferred.length ? preferred : boardRoot.querySelectorAll('div');
|
|
24
|
+
for (const element of candidates) {
|
|
25
|
+
if (element !== boardRoot && element.closest('[data-awsui-board-item]'))
|
|
26
|
+
continue;
|
|
27
|
+
const className = typeof element.className === 'string' ? element.className : '';
|
|
28
|
+
if (className.includes('grid__item'))
|
|
29
|
+
continue;
|
|
30
|
+
const style = window.getComputedStyle(element);
|
|
31
|
+
if (style.display === 'grid' && style.gridAutoRows && style.gridAutoRows !== 'auto') {
|
|
32
|
+
return element;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return null;
|
|
36
|
+
}, []);
|
|
37
|
+
const updateGridMetrics = useCallback(() => {
|
|
38
|
+
if (typeof window === 'undefined')
|
|
39
|
+
return gridMetricsRef.current;
|
|
40
|
+
const root = boardRootRef.current;
|
|
41
|
+
if (!root)
|
|
42
|
+
return gridMetricsRef.current;
|
|
43
|
+
const grid = findGridElement(root);
|
|
44
|
+
if (!grid)
|
|
45
|
+
return gridMetricsRef.current;
|
|
46
|
+
const style = window.getComputedStyle(grid);
|
|
47
|
+
const rowHeight = parseCssNumber(style.gridAutoRows);
|
|
48
|
+
const rowGapValue = parseCssNumber(style.rowGap);
|
|
49
|
+
const gapValue = parseCssNumber(style.gap);
|
|
50
|
+
const fallbackRowGap = resolveFallbackRowGap();
|
|
51
|
+
const rowGap = Number.isFinite(rowGapValue) ? rowGapValue : Number.isFinite(gapValue) ? gapValue : fallbackRowGap;
|
|
52
|
+
if (!Number.isFinite(rowHeight) || rowHeight <= 0)
|
|
53
|
+
return gridMetricsRef.current;
|
|
54
|
+
const next = { rowHeight, rowGap };
|
|
55
|
+
gridMetricsRef.current = next;
|
|
56
|
+
return next;
|
|
57
|
+
}, [findGridElement, parseCssNumber, resolveFallbackRowGap]);
|
|
58
|
+
const computeRequiredRows = useCallback((contentElement) => {
|
|
59
|
+
if (!contentElement.isConnected)
|
|
60
|
+
return null;
|
|
61
|
+
const metrics = updateGridMetrics() ?? { rowHeight: DEFAULT_ROW_HEIGHT, rowGap: resolveFallbackRowGap() };
|
|
62
|
+
const containerRoot = contentElement.closest('[data-awsui-board-item]') ??
|
|
63
|
+
contentElement.closest('[class*="container-override"]');
|
|
64
|
+
if (!containerRoot)
|
|
65
|
+
return null;
|
|
66
|
+
const containerRect = containerRoot.getBoundingClientRect();
|
|
67
|
+
const contentRect = contentElement.getBoundingClientRect();
|
|
68
|
+
const offsetTop = contentRect.top - containerRect.top;
|
|
69
|
+
const contentHeight = contentElement.scrollHeight;
|
|
70
|
+
if (!Number.isFinite(offsetTop) || !Number.isFinite(contentHeight) || contentHeight <= 0)
|
|
71
|
+
return null;
|
|
72
|
+
const requiredPx = offsetTop + contentHeight;
|
|
73
|
+
return Math.ceil((requiredPx + metrics.rowGap) / (metrics.rowHeight + metrics.rowGap));
|
|
74
|
+
}, [resolveFallbackRowGap, updateGridMetrics]);
|
|
75
|
+
const applyAutoSize = useCallback((widgetId, requiredRows) => {
|
|
76
|
+
setLayoutState(prev => {
|
|
77
|
+
const definition = definitionsMap.get(widgetId);
|
|
78
|
+
if (!definition)
|
|
79
|
+
return prev;
|
|
80
|
+
if (lockedHeightModeByWidgetId[widgetId])
|
|
81
|
+
return prev;
|
|
82
|
+
if (prev.collapsed.includes(widgetId))
|
|
83
|
+
return prev;
|
|
84
|
+
const heightMode = prev.heightModeMemory[currentBreakpointKey]?.[widgetId] ?? definition.layout.heightMode ?? 'auto';
|
|
85
|
+
if (heightMode !== 'auto')
|
|
86
|
+
return prev;
|
|
87
|
+
const index = prev.items.findIndex(item => item.id === widgetId);
|
|
88
|
+
if (index < 0)
|
|
89
|
+
return prev;
|
|
90
|
+
const minRows = Math.max(definition.layout.limits?.minRowSpan ?? 2, 2);
|
|
91
|
+
const nextRows = Math.max(minRows, requiredRows);
|
|
92
|
+
const currentItem = prev.items[index];
|
|
93
|
+
if (currentItem.rowSpan === nextRows)
|
|
94
|
+
return prev;
|
|
95
|
+
const nextItems = [...prev.items];
|
|
96
|
+
nextItems[index] = { ...currentItem, rowSpan: nextRows };
|
|
97
|
+
return { ...prev, items: nextItems };
|
|
98
|
+
});
|
|
99
|
+
}, [currentBreakpointKey, definitionsMap, lockedHeightModeByWidgetId, setLayoutState]);
|
|
100
|
+
const handleContentResize = useCallback((widgetId, contentElement) => {
|
|
101
|
+
if (!autoHeightEnabled)
|
|
102
|
+
return;
|
|
103
|
+
if (isInteractionLocked)
|
|
104
|
+
return;
|
|
105
|
+
const requiredRows = computeRequiredRows(contentElement);
|
|
106
|
+
if (!requiredRows)
|
|
107
|
+
return;
|
|
108
|
+
measuredRowsRef.current[widgetId] = requiredRows;
|
|
109
|
+
applyAutoSize(widgetId, requiredRows);
|
|
110
|
+
}, [applyAutoSize, autoHeightEnabled, computeRequiredRows, isInteractionLocked]);
|
|
111
|
+
const handleContentRef = useCallback((widgetId, node) => {
|
|
112
|
+
const map = contentRefs.current;
|
|
113
|
+
const observer = resizeObserverRef.current;
|
|
114
|
+
const prev = map.get(widgetId);
|
|
115
|
+
if (prev === node)
|
|
116
|
+
return;
|
|
117
|
+
if (prev && observer) {
|
|
118
|
+
observer.unobserve(prev);
|
|
119
|
+
}
|
|
120
|
+
if (!node) {
|
|
121
|
+
map.delete(widgetId);
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
map.set(widgetId, node);
|
|
125
|
+
if (!autoHeightEnabled) {
|
|
126
|
+
delete measuredRowsRef.current[widgetId];
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
if (observer) {
|
|
130
|
+
observer.observe(node);
|
|
131
|
+
}
|
|
132
|
+
requestAnimationFrame(() => handleContentResize(widgetId, node));
|
|
133
|
+
}, [autoHeightEnabled, handleContentResize]);
|
|
134
|
+
const remeasureAll = useCallback(() => {
|
|
135
|
+
if (!autoHeightEnabled)
|
|
136
|
+
return;
|
|
137
|
+
if (isInteractionLocked)
|
|
138
|
+
return;
|
|
139
|
+
updateGridMetrics();
|
|
140
|
+
contentRefs.current.forEach((element, widgetId) => {
|
|
141
|
+
handleContentResize(widgetId, element);
|
|
142
|
+
});
|
|
143
|
+
}, [autoHeightEnabled, handleContentResize, isInteractionLocked, updateGridMetrics]);
|
|
144
|
+
useEffect(() => {
|
|
145
|
+
if (!autoHeightEnabled)
|
|
146
|
+
return;
|
|
147
|
+
if (typeof ResizeObserver === 'undefined')
|
|
148
|
+
return;
|
|
149
|
+
const observer = new ResizeObserver(entries => {
|
|
150
|
+
entries.forEach(entry => {
|
|
151
|
+
const target = entry.target;
|
|
152
|
+
const widgetId = target.dataset.widgetId;
|
|
153
|
+
if (!widgetId)
|
|
154
|
+
return;
|
|
155
|
+
handleContentResize(widgetId, target);
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
resizeObserverRef.current = observer;
|
|
159
|
+
contentRefs.current.forEach(element => observer.observe(element));
|
|
160
|
+
return () => {
|
|
161
|
+
observer.disconnect();
|
|
162
|
+
resizeObserverRef.current = null;
|
|
163
|
+
};
|
|
164
|
+
}, [autoHeightEnabled, handleContentResize]);
|
|
165
|
+
useEffect(() => {
|
|
166
|
+
if (!autoHeightEnabled) {
|
|
167
|
+
measuredRowsRef.current = {};
|
|
168
|
+
}
|
|
169
|
+
}, [autoHeightEnabled]);
|
|
170
|
+
useEffect(() => {
|
|
171
|
+
remeasureAll();
|
|
172
|
+
}, [layoutPresetBreakpoint, remeasureAll]);
|
|
173
|
+
return {
|
|
174
|
+
boardRootRef,
|
|
175
|
+
handleContentRef,
|
|
176
|
+
measuredRowsRef,
|
|
177
|
+
remeasureAll,
|
|
178
|
+
};
|
|
179
|
+
};
|
|
180
|
+
//# sourceMappingURL=useWidgetBoardAutosize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWidgetBoardAutosize.js","sourceRoot":"","sources":["../../../../src/component/widget-board/useWidgetBoardAutosize.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { PneFabItem } from '../fab/PneFloatingActionButtons';
|
|
3
|
+
import type { WidgetBoardFabStore } from './widgetBoardFabStore';
|
|
4
|
+
export type UseWidgetBoardFabActionsOptions = {
|
|
5
|
+
store: WidgetBoardFabStore;
|
|
6
|
+
resetLabel?: React.ReactNode;
|
|
7
|
+
editVisibilityLabel?: React.ReactNode;
|
|
8
|
+
restoreHiddenLabel?: React.ReactNode;
|
|
9
|
+
onEditVisibilityClick?: () => void;
|
|
10
|
+
};
|
|
11
|
+
export declare const useWidgetBoardFabActions: ({ store, resetLabel, editVisibilityLabel, restoreHiddenLabel, onEditVisibilityClick, }: UseWidgetBoardFabActionsOptions) => PneFabItem[];
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import React, { useCallback, useMemo } from 'react';
|
|
2
|
+
import RestartAltIcon from '@mui/icons-material/RestartAlt';
|
|
3
|
+
import VisibilityIcon from '@mui/icons-material/Visibility';
|
|
4
|
+
import { useTranslation } from 'react-i18next';
|
|
5
|
+
import { usePneConfirm } from '../confirm';
|
|
6
|
+
import { WidgetLayoutsPanel } from './WidgetLayoutsPanel';
|
|
7
|
+
export const useWidgetBoardFabActions = ({ store, resetLabel, editVisibilityLabel, restoreHiddenLabel, onEditVisibilityClick, }) => {
|
|
8
|
+
const { t } = useTranslation();
|
|
9
|
+
const { confirm } = usePneConfirm();
|
|
10
|
+
const layoutItems = store(state => state.items);
|
|
11
|
+
const selectedLayoutId = store(state => state.selectedId);
|
|
12
|
+
const selectLayout = store(state => state.onSelect);
|
|
13
|
+
const addLayout = store(state => state.onAdd);
|
|
14
|
+
const deleteLayout = store(state => state.onDelete);
|
|
15
|
+
const addInfo = store(state => state.addInfo);
|
|
16
|
+
const lockedIds = store(state => state.lockedIds);
|
|
17
|
+
const actionsState = store(state => state.actionsState);
|
|
18
|
+
const resetLayout = store(state => state.onResetLayout);
|
|
19
|
+
const visibilityItems = store(state => state.visibilityItems);
|
|
20
|
+
const setWidgetVisibility = store(state => state.onSetWidgetVisibility);
|
|
21
|
+
const resolvedResetLabel = resetLabel ?? t('pne.widgetBoard.actions.resetLayout', { defaultValue: 'Reset layout' });
|
|
22
|
+
const resolvedEditVisibilityLabel = editVisibilityLabel ??
|
|
23
|
+
restoreHiddenLabel ??
|
|
24
|
+
t('pne.widgetBoard.actions.editVisibility', { defaultValue: 'Edit visibility' });
|
|
25
|
+
const confirmTitle = t('react.confirm-alert.title.are-you-sure', { defaultValue: 'Are you sure?' });
|
|
26
|
+
const confirmLabel = t('react.confirm-alert.yes', { defaultValue: 'Yes' });
|
|
27
|
+
const cancelLabel = t('react.confirm-alert.no.cancel', { defaultValue: 'Cancel' });
|
|
28
|
+
const resetMessage = t('pne.widgetBoard.confirm.resetLayout', { defaultValue: 'Reset selected saved layout to default for this breakpoint?' });
|
|
29
|
+
const handleResetLayout = useCallback(() => {
|
|
30
|
+
if (!resetLayout)
|
|
31
|
+
return;
|
|
32
|
+
const shouldConfirm = !actionsState?.isDefaultLayoutSelected;
|
|
33
|
+
if (shouldConfirm) {
|
|
34
|
+
void confirm({
|
|
35
|
+
title: confirmTitle,
|
|
36
|
+
message: resetMessage,
|
|
37
|
+
confirmLabel,
|
|
38
|
+
cancelLabel,
|
|
39
|
+
}).then(accepted => {
|
|
40
|
+
if (accepted) {
|
|
41
|
+
resetLayout?.();
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
resetLayout();
|
|
47
|
+
}, [actionsState?.isDefaultLayoutSelected, cancelLabel, confirm, confirmLabel, confirmTitle, resetLayout, resetMessage]);
|
|
48
|
+
const canEditVisibility = visibilityItems.length > 0 && Boolean(setWidgetVisibility) && Boolean(onEditVisibilityClick);
|
|
49
|
+
const handleEditVisibility = useCallback(() => {
|
|
50
|
+
if (!canEditVisibility)
|
|
51
|
+
return;
|
|
52
|
+
onEditVisibilityClick?.();
|
|
53
|
+
}, [canEditVisibility, onEditVisibilityClick]);
|
|
54
|
+
const showResetLayout = Boolean(actionsState?.canResetLayout);
|
|
55
|
+
const canReset = showResetLayout && Boolean(resetLayout);
|
|
56
|
+
return useMemo(() => {
|
|
57
|
+
const items = [
|
|
58
|
+
{
|
|
59
|
+
id: 'layouts',
|
|
60
|
+
kind: 'content',
|
|
61
|
+
node: (React.createElement(WidgetLayoutsPanel, { items: layoutItems, selectedId: selectedLayoutId, onSelect: selectLayout, onAdd: addLayout, onDelete: deleteLayout, addInfo: addInfo, lockedIds: lockedIds })),
|
|
62
|
+
},
|
|
63
|
+
{ id: 'divider-layouts', kind: 'divider' },
|
|
64
|
+
];
|
|
65
|
+
items.push({
|
|
66
|
+
id: 'reset-layout',
|
|
67
|
+
label: resolvedResetLabel,
|
|
68
|
+
icon: React.createElement(RestartAltIcon, { fontSize: 'small' }),
|
|
69
|
+
onClick: handleResetLayout,
|
|
70
|
+
disabled: !canReset,
|
|
71
|
+
showInFabStack: canReset,
|
|
72
|
+
});
|
|
73
|
+
items.push({
|
|
74
|
+
id: 'edit-visibility',
|
|
75
|
+
label: resolvedEditVisibilityLabel,
|
|
76
|
+
icon: React.createElement(VisibilityIcon, { fontSize: 'small' }),
|
|
77
|
+
onClick: handleEditVisibility,
|
|
78
|
+
disabled: !canEditVisibility,
|
|
79
|
+
showInFabStack: Boolean(onEditVisibilityClick),
|
|
80
|
+
});
|
|
81
|
+
return items;
|
|
82
|
+
}, [
|
|
83
|
+
addInfo,
|
|
84
|
+
addLayout,
|
|
85
|
+
canEditVisibility,
|
|
86
|
+
canReset,
|
|
87
|
+
handleEditVisibility,
|
|
88
|
+
handleResetLayout,
|
|
89
|
+
deleteLayout,
|
|
90
|
+
layoutItems,
|
|
91
|
+
lockedIds,
|
|
92
|
+
onEditVisibilityClick,
|
|
93
|
+
resolvedEditVisibilityLabel,
|
|
94
|
+
resolvedResetLabel,
|
|
95
|
+
selectLayout,
|
|
96
|
+
selectedLayoutId,
|
|
97
|
+
]);
|
|
98
|
+
};
|
|
99
|
+
//# sourceMappingURL=useWidgetBoardFabActions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWidgetBoardFabActions.js","sourceRoot":"","sources":["../../../../src/component/widget-board/useWidgetBoardFabActions.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const useWidgetBoardInteractionLock: () => boolean;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react';
|
|
2
|
+
export const useWidgetBoardInteractionLock = () => {
|
|
3
|
+
const [isInteractionLocked, setIsInteractionLocked] = useState(false);
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
if (typeof document === 'undefined')
|
|
6
|
+
return;
|
|
7
|
+
const isDragActive = () => {
|
|
8
|
+
for (const className of document.body.classList) {
|
|
9
|
+
if (className.includes('show-grab-cursor') || className.includes('show-resize-cursor')) {
|
|
10
|
+
return true;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
return false;
|
|
14
|
+
};
|
|
15
|
+
const update = () => {
|
|
16
|
+
setIsInteractionLocked(isDragActive());
|
|
17
|
+
};
|
|
18
|
+
update();
|
|
19
|
+
const observer = new MutationObserver(update);
|
|
20
|
+
observer.observe(document.body, { attributes: true, attributeFilter: ['class'] });
|
|
21
|
+
return () => observer.disconnect();
|
|
22
|
+
}, []);
|
|
23
|
+
return isInteractionLocked;
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=useWidgetBoardInteractionLock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWidgetBoardInteractionLock.js","sourceRoot":"","sources":["../../../../src/component/widget-board/useWidgetBoardInteractionLock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE3C,MAAM,CAAC,MAAM,6BAA6B,GAAG,GAAG,EAAE;IAC9C,MAAM,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAErE,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,OAAO,QAAQ,KAAK,WAAW;YAAE,OAAM;QAC3C,MAAM,YAAY,GAAG,GAAG,EAAE;YACtB,KAAK,MAAM,SAAS,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;gBAC9C,IAAI,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,oBAAoB,CAAC,EAAE,CAAC;oBACrF,OAAO,IAAI,CAAA;gBACf,CAAC;YACL,CAAC;YACD,OAAO,KAAK,CAAA;QAChB,CAAC,CAAA;QACD,MAAM,MAAM,GAAG,GAAG,EAAE;YAChB,sBAAsB,CAAC,YAAY,EAAE,CAAC,CAAA;QAC1C,CAAC,CAAA;QACD,MAAM,EAAE,CAAA;QACR,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,MAAM,CAAC,CAAA;QAC7C,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QACjF,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAA;IACtC,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,mBAAmB,CAAA;AAC9B,CAAC,CAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { Dispatch, MutableRefObject, SetStateAction } from 'react';
|
|
2
|
+
import type { BreakpointLayoutConfig, WidgetBoardActionsState, WidgetBoardLayoutOption } from './types';
|
|
3
|
+
import type { WidgetBoardFabStore, WidgetBoardVisibilityItem } from './widgetBoardFabStore';
|
|
4
|
+
type UseWidgetBoardLayoutActionsParams = {
|
|
5
|
+
buildCurrentPreset: () => Record<number | string, BreakpointLayoutConfig>;
|
|
6
|
+
defaultLayoutId: string;
|
|
7
|
+
isLoadingLayouts: boolean;
|
|
8
|
+
layoutOptions: WidgetBoardLayoutOption[];
|
|
9
|
+
layoutOptionsMap: Map<string, WidgetBoardLayoutOption>;
|
|
10
|
+
layoutSourceOwnerIdRef: MutableRefObject<string | undefined>;
|
|
11
|
+
lockedLayoutIdRef: MutableRefObject<string | undefined>;
|
|
12
|
+
saveLayouts: (options: WidgetBoardLayoutOption[], selectedId?: string) => Promise<void>;
|
|
13
|
+
fabStore: WidgetBoardFabStore;
|
|
14
|
+
actionsState: WidgetBoardActionsState;
|
|
15
|
+
visibilityItems: WidgetBoardVisibilityItem[];
|
|
16
|
+
onSetWidgetVisibility: (id: string, visible: boolean) => void;
|
|
17
|
+
onResetLayout: () => void;
|
|
18
|
+
onRestoreHidden: () => void;
|
|
19
|
+
selectedLayoutId: string | undefined;
|
|
20
|
+
setLayoutOptions: Dispatch<SetStateAction<WidgetBoardLayoutOption[]>>;
|
|
21
|
+
setSelectedLayoutId: Dispatch<SetStateAction<string | undefined>>;
|
|
22
|
+
};
|
|
23
|
+
export declare const useWidgetBoardLayoutActions: ({ buildCurrentPreset, defaultLayoutId, isLoadingLayouts, layoutOptions, layoutOptionsMap, layoutSourceOwnerIdRef, lockedLayoutIdRef, saveLayouts, fabStore, actionsState, visibilityItems, onSetWidgetVisibility, onResetLayout, onRestoreHidden, selectedLayoutId, setLayoutOptions, setSelectedLayoutId, }: UseWidgetBoardLayoutActionsParams) => {
|
|
24
|
+
addLayout: (name: string) => void;
|
|
25
|
+
deleteLayout: (id: string) => void;
|
|
26
|
+
selectLayout: (id: string) => void;
|
|
27
|
+
};
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { useCallback, useEffect, useMemo, useRef } from 'react';
|
|
2
|
+
import { useTranslation } from 'react-i18next';
|
|
3
|
+
import { createLayoutId } from './widgetBoardLayoutUtils';
|
|
4
|
+
export const useWidgetBoardLayoutActions = ({ buildCurrentPreset, defaultLayoutId, isLoadingLayouts, layoutOptions, layoutOptionsMap, layoutSourceOwnerIdRef, lockedLayoutIdRef, saveLayouts, fabStore, actionsState, visibilityItems, onSetWidgetVisibility, onResetLayout, onRestoreHidden, selectedLayoutId, setLayoutOptions, setSelectedLayoutId, }) => {
|
|
5
|
+
const { t } = useTranslation();
|
|
6
|
+
const autosaveTimeoutRef = useRef(null);
|
|
7
|
+
useEffect(() => {
|
|
8
|
+
return () => {
|
|
9
|
+
if (autosaveTimeoutRef.current) {
|
|
10
|
+
clearTimeout(autosaveTimeoutRef.current);
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
}, []);
|
|
14
|
+
const ensureSelected = useCallback((options, candidate) => {
|
|
15
|
+
if (candidate && options.some(option => option.id === candidate))
|
|
16
|
+
return candidate;
|
|
17
|
+
return options[0]?.id;
|
|
18
|
+
}, []);
|
|
19
|
+
const persistLayouts = useCallback((options, nextSelectedId) => {
|
|
20
|
+
Promise.resolve(saveLayouts(options, nextSelectedId)).catch(error => {
|
|
21
|
+
console.warn('Failed to save widget layouts', error);
|
|
22
|
+
});
|
|
23
|
+
}, [saveLayouts]);
|
|
24
|
+
const selectLayout = useCallback((id) => {
|
|
25
|
+
if (!id || id === selectedLayoutId || !layoutOptionsMap.has(id))
|
|
26
|
+
return;
|
|
27
|
+
setSelectedLayoutId(id);
|
|
28
|
+
persistLayouts(layoutOptions, id);
|
|
29
|
+
}, [layoutOptions, layoutOptionsMap, persistLayouts, selectedLayoutId, setSelectedLayoutId]);
|
|
30
|
+
const addLayout = useCallback((name) => {
|
|
31
|
+
const layoutByBreakpoint = buildCurrentPreset();
|
|
32
|
+
const option = {
|
|
33
|
+
id: createLayoutId(),
|
|
34
|
+
name: name.trim() || t('pne.widgetBoard.layouts.customName', { defaultValue: 'Custom layout' }),
|
|
35
|
+
layoutByBreakpoint,
|
|
36
|
+
};
|
|
37
|
+
const nextOptions = [...layoutOptions, option];
|
|
38
|
+
setLayoutOptions(nextOptions);
|
|
39
|
+
setSelectedLayoutId(option.id);
|
|
40
|
+
persistLayouts(nextOptions, option.id);
|
|
41
|
+
}, [buildCurrentPreset, layoutOptions, persistLayouts, setLayoutOptions, setSelectedLayoutId, t]);
|
|
42
|
+
const deleteLayout = useCallback((id) => {
|
|
43
|
+
if (!layoutOptionsMap.has(id))
|
|
44
|
+
return;
|
|
45
|
+
if (lockedLayoutIdRef.current && id === lockedLayoutIdRef.current)
|
|
46
|
+
return;
|
|
47
|
+
const nextOptions = layoutOptions.filter(option => option.id !== id);
|
|
48
|
+
const nextSelected = id === selectedLayoutId ? ensureSelected(nextOptions) : selectedLayoutId;
|
|
49
|
+
setLayoutOptions(nextOptions);
|
|
50
|
+
setSelectedLayoutId(nextSelected);
|
|
51
|
+
persistLayouts(nextOptions, nextSelected);
|
|
52
|
+
}, [ensureSelected, layoutOptions, layoutOptionsMap, lockedLayoutIdRef, persistLayouts, selectedLayoutId, setLayoutOptions, setSelectedLayoutId]);
|
|
53
|
+
useEffect(() => {
|
|
54
|
+
if (isLoadingLayouts)
|
|
55
|
+
return;
|
|
56
|
+
const expectedOwnerId = selectedLayoutId ?? defaultLayoutId;
|
|
57
|
+
if (layoutSourceOwnerIdRef.current !== expectedOwnerId)
|
|
58
|
+
return;
|
|
59
|
+
const lockedId = lockedLayoutIdRef.current;
|
|
60
|
+
if (!selectedLayoutId || (lockedId && selectedLayoutId === lockedId))
|
|
61
|
+
return;
|
|
62
|
+
const selectedOption = layoutOptionsMap.get(selectedLayoutId);
|
|
63
|
+
if (!selectedOption)
|
|
64
|
+
return;
|
|
65
|
+
const nextPreset = buildCurrentPreset();
|
|
66
|
+
const selectedSerialized = JSON.stringify(selectedOption.layoutByBreakpoint ?? {});
|
|
67
|
+
const nextSerialized = JSON.stringify(nextPreset ?? {});
|
|
68
|
+
if (selectedSerialized === nextSerialized)
|
|
69
|
+
return;
|
|
70
|
+
const nextOptions = layoutOptions.map(option => (option.id === selectedLayoutId ? { ...option, layoutByBreakpoint: nextPreset } : option));
|
|
71
|
+
setLayoutOptions(nextOptions);
|
|
72
|
+
if (autosaveTimeoutRef.current) {
|
|
73
|
+
clearTimeout(autosaveTimeoutRef.current);
|
|
74
|
+
}
|
|
75
|
+
autosaveTimeoutRef.current = setTimeout(() => {
|
|
76
|
+
persistLayouts(nextOptions, selectedLayoutId);
|
|
77
|
+
autosaveTimeoutRef.current = null;
|
|
78
|
+
}, 350);
|
|
79
|
+
}, [
|
|
80
|
+
buildCurrentPreset,
|
|
81
|
+
defaultLayoutId,
|
|
82
|
+
isLoadingLayouts,
|
|
83
|
+
layoutOptions,
|
|
84
|
+
layoutOptionsMap,
|
|
85
|
+
layoutSourceOwnerIdRef,
|
|
86
|
+
lockedLayoutIdRef,
|
|
87
|
+
persistLayouts,
|
|
88
|
+
selectedLayoutId,
|
|
89
|
+
setLayoutOptions,
|
|
90
|
+
]);
|
|
91
|
+
const addInfo = useMemo(() => {
|
|
92
|
+
const sourceLayoutId = selectedLayoutId ?? defaultLayoutId;
|
|
93
|
+
const sourceOption = layoutOptionsMap.get(sourceLayoutId);
|
|
94
|
+
if (!sourceOption)
|
|
95
|
+
return undefined;
|
|
96
|
+
return {
|
|
97
|
+
basedOnName: sourceOption.name,
|
|
98
|
+
};
|
|
99
|
+
}, [defaultLayoutId, layoutOptionsMap, selectedLayoutId]);
|
|
100
|
+
useEffect(() => {
|
|
101
|
+
const panelProps = {
|
|
102
|
+
items: layoutOptions,
|
|
103
|
+
selectedId: selectedLayoutId,
|
|
104
|
+
onSelect: selectLayout,
|
|
105
|
+
onAdd: addLayout,
|
|
106
|
+
onDelete: deleteLayout,
|
|
107
|
+
addInfo,
|
|
108
|
+
lockedIds: lockedLayoutIdRef.current ? [lockedLayoutIdRef.current] : [],
|
|
109
|
+
actionsState,
|
|
110
|
+
visibilityItems,
|
|
111
|
+
onSetWidgetVisibility,
|
|
112
|
+
onResetLayout,
|
|
113
|
+
onRestoreHidden,
|
|
114
|
+
};
|
|
115
|
+
fabStore.getState().setPanelState(panelProps);
|
|
116
|
+
return () => {
|
|
117
|
+
fabStore.getState().resetPanelState();
|
|
118
|
+
};
|
|
119
|
+
}, [
|
|
120
|
+
actionsState,
|
|
121
|
+
addInfo,
|
|
122
|
+
addLayout,
|
|
123
|
+
deleteLayout,
|
|
124
|
+
fabStore,
|
|
125
|
+
layoutOptions,
|
|
126
|
+
lockedLayoutIdRef,
|
|
127
|
+
onSetWidgetVisibility,
|
|
128
|
+
onResetLayout,
|
|
129
|
+
onRestoreHidden,
|
|
130
|
+
selectLayout,
|
|
131
|
+
selectedLayoutId,
|
|
132
|
+
visibilityItems,
|
|
133
|
+
]);
|
|
134
|
+
return {
|
|
135
|
+
addLayout,
|
|
136
|
+
deleteLayout,
|
|
137
|
+
selectLayout,
|
|
138
|
+
};
|
|
139
|
+
};
|
|
140
|
+
//# sourceMappingURL=useWidgetBoardLayoutActions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useWidgetBoardLayoutActions.js","sourceRoot":"","sources":["../../../../src/component/widget-board/useWidgetBoardLayoutActions.ts"],"names":[],"mappings":"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"}
|