pne-ui 4.0.8 → 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.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 +111 -215
- package/cjs/component/search-ui/filters/styled.d.ts +0 -1
- package/cjs/component/search-ui/multiget_select/state/store.d.ts +10 -35
- package/cjs/component/search-ui/state/store.d.ts +7 -7
- 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 +1 -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/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 +111 -215
- package/esm/component/search-ui/filters/styled.d.ts +0 -1
- package/esm/component/search-ui/multiget_select/state/store.d.ts +10 -35
- package/esm/component/search-ui/state/store.d.ts +7 -7
- 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 +1 -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,119 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import ArrowUpwardIcon from '@mui/icons-material/ArrowUpward';
|
|
3
|
+
import EditIcon from '@mui/icons-material/Edit';
|
|
4
|
+
import { Box, Divider, Fab, ListItemIcon, ListItemText, Menu, MenuItem, Stack, Tooltip } from '@mui/material';
|
|
5
|
+
import { useTranslation } from 'react-i18next';
|
|
6
|
+
import { DEFAULT_BREAKPOINTS } from '../../common/responsive/breakpoints';
|
|
7
|
+
import { useBreakpoint } from '../responsive/useBreakpoint';
|
|
8
|
+
const isContentItem = (item) => 'kind' in item && item.kind === 'content';
|
|
9
|
+
const isDividerItem = (item) => 'kind' in item && item.kind === 'divider';
|
|
10
|
+
const isActionItem = (item) => !isContentItem(item) && !isDividerItem(item);
|
|
11
|
+
/**
|
|
12
|
+
* Floating action menu:
|
|
13
|
+
* - on mobile: actions/content rendered inside a Menu
|
|
14
|
+
* - on desktop: actions rendered as floating Fabs stacked above the trigger; Menu still opens for content/banner
|
|
15
|
+
* Actions array may include content blocks (`{ kind: 'content', node: <...> }`) to embed custom UI.
|
|
16
|
+
*/
|
|
17
|
+
export function PneFloatingActionButtons({ actions, breakpoints = DEFAULT_BREAKPOINTS, mobileBreakpoint = 800, position, fabLabel, fabIcon = React.createElement(EditIcon, null), className, bannerText, }) {
|
|
18
|
+
const { t } = useTranslation();
|
|
19
|
+
const breakpoint = useBreakpoint({ breakpoints });
|
|
20
|
+
const isMobile = breakpoint < mobileBreakpoint;
|
|
21
|
+
const resolvedFabLabel = fabLabel ?? t('pne.fab.actions', { defaultValue: 'Actions' });
|
|
22
|
+
const resolvedFabActionLabel = t('pne.fab.action', { defaultValue: 'Action' });
|
|
23
|
+
const scrollTopLabel = t('pne.fab.scrollToTop', { defaultValue: 'Scroll to top' });
|
|
24
|
+
const [anchorEl, setAnchorEl] = useState(null);
|
|
25
|
+
const [showScrollTop, setShowScrollTop] = useState(false);
|
|
26
|
+
const handleOpen = (event) => setAnchorEl(event.currentTarget);
|
|
27
|
+
const handleClose = () => setAnchorEl(null);
|
|
28
|
+
const handleAction = (action) => {
|
|
29
|
+
handleClose();
|
|
30
|
+
action.onClick();
|
|
31
|
+
};
|
|
32
|
+
const handleScrollTop = () => {
|
|
33
|
+
if (typeof window === 'undefined')
|
|
34
|
+
return;
|
|
35
|
+
window.scrollTo({ top: 0, behavior: 'smooth' });
|
|
36
|
+
};
|
|
37
|
+
const renderMenuItems = (items) => items.map(item => isContentItem(item) ? (React.createElement(Box, { key: item.id }, item.node)) : isDividerItem(item) ? (React.createElement(Divider, { key: item.id, component: 'li', role: 'presentation', sx: { my: 2 } })) : isActionItem(item) ? (React.createElement(MenuItem, { key: item.id, disabled: item.disabled, onClick: () => handleAction(item), sx: { fontSize: '0.875rem', display: 'flex', alignItems: 'center', gap: 1 } },
|
|
38
|
+
React.createElement(ListItemText, { slotProps: { primary: { sx: { fontSize: '0.875rem' } } }, sx: { flex: 1 } }, item.label),
|
|
39
|
+
item.icon ? (React.createElement(Box, { component: 'span', sx: { display: 'inline-flex', color: 'inherit', lineHeight: 0 } }, item.icon)) : null)) : null);
|
|
40
|
+
// Desktop: actions can be shown independently in menu and floating stack.
|
|
41
|
+
const menuItems = actions.filter(item => !isActionItem(item) || item.showInMenu !== false);
|
|
42
|
+
const actionItems = isMobile ? [] : actions.filter(isActionItem).filter(item => item.showInFabStack !== false);
|
|
43
|
+
const fabSx = isMobile ? { opacity: 0.85 } : { opacity: 0.3 };
|
|
44
|
+
const stackSx = isMobile ? undefined : { '&:hover .pne-fab': { opacity: 0.85 } };
|
|
45
|
+
const baseOffset = isMobile ? 16 : 24;
|
|
46
|
+
const bottomOffset = position?.bottom ?? baseOffset;
|
|
47
|
+
const rightOffset = position?.right ?? baseOffset;
|
|
48
|
+
const containerSx = {
|
|
49
|
+
bottom: `calc(${bottomOffset}px + env(safe-area-inset-bottom, 0px))`,
|
|
50
|
+
right: `calc(${rightOffset}px + env(safe-area-inset-right, 0px))`,
|
|
51
|
+
};
|
|
52
|
+
useEffect(() => {
|
|
53
|
+
if (typeof window === 'undefined')
|
|
54
|
+
return;
|
|
55
|
+
let frameId = null;
|
|
56
|
+
const update = () => {
|
|
57
|
+
frameId = null;
|
|
58
|
+
const offset = window.scrollY ?? document.documentElement.scrollTop ?? 0;
|
|
59
|
+
setShowScrollTop(offset > 16);
|
|
60
|
+
};
|
|
61
|
+
update();
|
|
62
|
+
const handleScroll = () => {
|
|
63
|
+
if (frameId !== null)
|
|
64
|
+
return;
|
|
65
|
+
frameId = window.requestAnimationFrame(update);
|
|
66
|
+
};
|
|
67
|
+
window.addEventListener('scroll', handleScroll, { passive: true });
|
|
68
|
+
return () => {
|
|
69
|
+
window.removeEventListener('scroll', handleScroll);
|
|
70
|
+
if (frameId !== null) {
|
|
71
|
+
window.cancelAnimationFrame(frameId);
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
}, []);
|
|
75
|
+
return (React.createElement(Box, { className: className, sx: {
|
|
76
|
+
position: 'fixed',
|
|
77
|
+
zIndex: 1300,
|
|
78
|
+
...containerSx,
|
|
79
|
+
} },
|
|
80
|
+
React.createElement(Stack, { spacing: 1, sx: {
|
|
81
|
+
alignItems: 'flex-end',
|
|
82
|
+
...(stackSx ?? {}),
|
|
83
|
+
} },
|
|
84
|
+
showScrollTop ? (React.createElement(Tooltip, { title: isMobile ? '' : scrollTopLabel, placement: 'left', disableInteractive: true },
|
|
85
|
+
React.createElement("span", null,
|
|
86
|
+
React.createElement(Fab, { className: 'pne-fab', color: 'primary', size: 'small', onClick: handleScrollTop, "aria-label": scrollTopLabel, sx: fabSx },
|
|
87
|
+
React.createElement(ArrowUpwardIcon, { fontSize: 'small' }))))) : null,
|
|
88
|
+
!isMobile
|
|
89
|
+
? actionItems.map(item => {
|
|
90
|
+
const title = item.tooltip ??
|
|
91
|
+
(typeof item.label === 'string' ? item.label : typeof resolvedFabLabel === 'string' ? resolvedFabLabel : resolvedFabActionLabel);
|
|
92
|
+
return (React.createElement(Tooltip, { key: item.id, title: title, placement: 'left', disableInteractive: true },
|
|
93
|
+
React.createElement("span", null,
|
|
94
|
+
React.createElement(Fab, { className: 'pne-fab', color: 'primary', size: 'small', onClick: () => handleAction(item), "aria-label": typeof title === 'string' ? title : resolvedFabActionLabel, sx: fabSx }, item.icon ?? (typeof item.label === 'string' ? item.label.charAt(0) : fabIcon)))));
|
|
95
|
+
})
|
|
96
|
+
: null,
|
|
97
|
+
React.createElement(Tooltip, { title: isMobile ? '' : resolvedFabLabel, disableInteractive: true },
|
|
98
|
+
React.createElement(Fab, { className: 'pne-fab', color: 'primary', size: 'small', onClick: handleOpen, "aria-label": typeof resolvedFabLabel === 'string' ? resolvedFabLabel : t('pne.fab.actions', { defaultValue: 'Actions' }), sx: fabSx }, fabIcon))),
|
|
99
|
+
React.createElement(Menu, { anchorEl: anchorEl, open: Boolean(anchorEl), onClose: handleClose, anchorOrigin: { vertical: 'top', horizontal: 'left' }, slotProps: { list: { sx: { py: 0 } } } },
|
|
100
|
+
renderMenuItems(menuItems),
|
|
101
|
+
bannerText ? (React.createElement(MenuItem, { disabled: true, sx: {
|
|
102
|
+
pointerEvents: 'none',
|
|
103
|
+
bgcolor: theme => theme.palette.primary.main,
|
|
104
|
+
color: theme => theme.palette.primary.contrastText,
|
|
105
|
+
'&.Mui-disabled': { opacity: 1 },
|
|
106
|
+
minHeight: 60,
|
|
107
|
+
} },
|
|
108
|
+
React.createElement(ListItemIcon, { sx: { minWidth: 36, color: 'inherit' } }, fabIcon),
|
|
109
|
+
React.createElement(ListItemText, { slotProps: {
|
|
110
|
+
primary: {
|
|
111
|
+
sx: {
|
|
112
|
+
fontWeight: 600,
|
|
113
|
+
fontSize: '20px',
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
} }, bannerText))) : null)));
|
|
117
|
+
}
|
|
118
|
+
export default PneFloatingActionButtons;
|
|
119
|
+
//# sourceMappingURL=PneFloatingActionButtons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PneFloatingActionButtons.js","sourceRoot":"","sources":["../../../../src/component/fab/PneFloatingActionButtons.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { TFunction } from 'react-i18next';
|
|
3
|
+
import { AbstractEntitySelectorProp, IMappedUnmappedList } from './AbstractEntitySelector';
|
|
4
|
+
interface IProps<T extends AbstractEntitySelectorProp> {
|
|
5
|
+
open: boolean;
|
|
6
|
+
onClose: () => void;
|
|
7
|
+
mappedList: T[];
|
|
8
|
+
unMappedList: T[];
|
|
9
|
+
handleSave: (list: IMappedUnmappedList<T>) => void;
|
|
10
|
+
title: string;
|
|
11
|
+
subTitle?: string;
|
|
12
|
+
loading?: boolean;
|
|
13
|
+
disableMoving?: 'ADDED' | 'AVAILABLE' | undefined;
|
|
14
|
+
optionRenderer?: TFunction;
|
|
15
|
+
textRepresentation?: 'ID' | 'NAME' | undefined;
|
|
16
|
+
textRepresentationValue?: string;
|
|
17
|
+
}
|
|
18
|
+
export declare const AbstractEntitySelectModal: <T extends AbstractEntitySelectorProp>(props: IProps<T>) => React.JSX.Element;
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { useTranslation } from 'react-i18next';
|
|
3
|
+
import { Stack } from '@mui/material';
|
|
4
|
+
import { AbstractEntitySelector } from './AbstractEntitySelector';
|
|
5
|
+
import PneButton from '../PneButton';
|
|
6
|
+
import PneModal from "../PneModal";
|
|
7
|
+
export const AbstractEntitySelectModal = (props) => {
|
|
8
|
+
const { open, onClose, mappedList, unMappedList, handleSave, title, subTitle, loading = false, disableMoving, optionRenderer, textRepresentation, textRepresentationValue } = props;
|
|
9
|
+
const { t } = useTranslation();
|
|
10
|
+
const autoHeight = () => {
|
|
11
|
+
if (mappedList?.length > unMappedList?.length) {
|
|
12
|
+
return mappedList.length <= 10
|
|
13
|
+
? mappedList.length == 1
|
|
14
|
+
? `calc((${mappedList?.length + 1} * 32px) + 36px)`
|
|
15
|
+
: `calc((${mappedList?.length} * 32px) + 36px)`
|
|
16
|
+
: `calc(400px + 40px + 16px)`;
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
return unMappedList?.length <= 10
|
|
20
|
+
? unMappedList?.length == 1
|
|
21
|
+
? `calc((${unMappedList?.length + 1} * 32px) + 36px)`
|
|
22
|
+
: `calc((${unMappedList?.length} * 32px) + 36px)`
|
|
23
|
+
: `calc(320px + 36px)`;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
const [localUnMappedList, setLocalUnMappedList] = useState(unMappedList);
|
|
27
|
+
const [localMappedList, setLocalMappedList] = useState(mappedList);
|
|
28
|
+
const handleChange = (mappedList, unMappedList) => {
|
|
29
|
+
setLocalMappedList(mappedList);
|
|
30
|
+
setLocalUnMappedList(unMappedList);
|
|
31
|
+
};
|
|
32
|
+
const entitySelectorOptions = {
|
|
33
|
+
list: unMappedList,
|
|
34
|
+
selected: mappedList,
|
|
35
|
+
height: autoHeight(),
|
|
36
|
+
disableMoving,
|
|
37
|
+
optionRenderer,
|
|
38
|
+
textRepresentation,
|
|
39
|
+
textRepresentationValue,
|
|
40
|
+
onChange: handleChange,
|
|
41
|
+
actionBlock: (React.createElement(Stack, { direction: 'row', sx: {
|
|
42
|
+
marginTop: '16px',
|
|
43
|
+
gap: 2,
|
|
44
|
+
} },
|
|
45
|
+
React.createElement(PneButton, { variant: 'outlined', onClick: () => onClose(), fullWidth: true }, t('cancel')),
|
|
46
|
+
React.createElement(PneButton, { variant: 'contained', onClick: () => {
|
|
47
|
+
handleSave({
|
|
48
|
+
mapped: localMappedList,
|
|
49
|
+
unmapped: localUnMappedList
|
|
50
|
+
});
|
|
51
|
+
}, fullWidth: true }, t('save')))),
|
|
52
|
+
};
|
|
53
|
+
return (React.createElement(PneModal, { open: open, onClose: onClose, title: title, subtitle: subTitle, containerSx: {
|
|
54
|
+
width: {
|
|
55
|
+
xs: 'clamp(360px, calc(100vw - 32px), 600px)',
|
|
56
|
+
sm: '600px'
|
|
57
|
+
},
|
|
58
|
+
minWidth: 0,
|
|
59
|
+
maxWidth: '600px',
|
|
60
|
+
height: 'auto'
|
|
61
|
+
} },
|
|
62
|
+
React.createElement(AbstractEntitySelector, { ...entitySelectorOptions })));
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=AbstractEntitySelectModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractEntitySelectModal.js","sourceRoot":"","sources":["../../../../src/component/non-abstract-entity-selector/AbstractEntitySelectModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { TFunction } from 'react-i18next';
|
|
3
|
+
import { AbstractEntity, Country, IMappedAbstractEntity } from '../../common';
|
|
4
|
+
export type ProcessorPaymentApparatus = {
|
|
5
|
+
id: number;
|
|
6
|
+
name: string;
|
|
7
|
+
mapped: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare const isProcessorPaymentApparatus: (value: unknown) => value is ProcessorPaymentApparatus;
|
|
10
|
+
export interface IAbstractEntityOptions<T> {
|
|
11
|
+
reset?: boolean;
|
|
12
|
+
list: T[];
|
|
13
|
+
selected: T[];
|
|
14
|
+
height?: string;
|
|
15
|
+
disableMoving?: 'ADDED' | 'AVAILABLE' | undefined;
|
|
16
|
+
optionRenderer?: TFunction;
|
|
17
|
+
textRepresentation?: 'ID' | 'NAME' | undefined;
|
|
18
|
+
textRepresentationValue?: string;
|
|
19
|
+
onChange: (mappedList: T[], unMappedList: T[]) => void;
|
|
20
|
+
actionBlock?: React.ReactNode;
|
|
21
|
+
}
|
|
22
|
+
export type AbstractEntitySelectorProp = string | IMappedAbstractEntity | AbstractEntity | Country | ProcessorPaymentApparatus;
|
|
23
|
+
export interface IMappedUnmappedList<T extends AbstractEntitySelectorProp> {
|
|
24
|
+
mapped: T[];
|
|
25
|
+
unmapped: T[];
|
|
26
|
+
}
|
|
27
|
+
export declare const AbstractEntitySelector: <T extends AbstractEntitySelectorProp>(props: React.PropsWithChildren<IAbstractEntityOptions<T>>) => React.JSX.Element;
|
|
@@ -0,0 +1,382 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react';
|
|
2
|
+
import { DragDropContext, Draggable, Droppable } from '@hello-pangea/dnd';
|
|
3
|
+
import { Box, IconButton, InputAdornment, Stack } from '@mui/material';
|
|
4
|
+
import { Virtuoso } from 'react-virtuoso';
|
|
5
|
+
import { useTranslation } from 'react-i18next';
|
|
6
|
+
import { AddedListWrapper, ColumnWrapper, Container, HeaderColumn, HeaderColumnWrapper, } from './styled';
|
|
7
|
+
import ItemEntitySelector from './ItemEntitySelector';
|
|
8
|
+
import { assertObject, exhaustiveCheck, isAbstractEntity, isMappedAbstractEntity, isObject } from '../../common';
|
|
9
|
+
import PneTextField from '../PneTextField';
|
|
10
|
+
import PneButton from '../PneButton';
|
|
11
|
+
import ClearIcon from '@mui/icons-material/Clear';
|
|
12
|
+
//TODO must be removed
|
|
13
|
+
export const isProcessorPaymentApparatus = (value) => {
|
|
14
|
+
if (!isObject(value)) {
|
|
15
|
+
return false;
|
|
16
|
+
}
|
|
17
|
+
return 'id' in value && typeof value.id === 'number' &&
|
|
18
|
+
'name' in value && typeof value.name === 'string';
|
|
19
|
+
};
|
|
20
|
+
const getListEntity = (item, index) => {
|
|
21
|
+
if (typeof item === 'string') {
|
|
22
|
+
return {
|
|
23
|
+
id: index,
|
|
24
|
+
displayName: item
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
assertObject(item);
|
|
28
|
+
if (isMappedAbstractEntity(item) || isProcessorPaymentApparatus(item)) {
|
|
29
|
+
return {
|
|
30
|
+
displayName: item.name,
|
|
31
|
+
...item
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
else if (isAbstractEntity(item)) {
|
|
35
|
+
return item;
|
|
36
|
+
}
|
|
37
|
+
exhaustiveCheck(item);
|
|
38
|
+
throw new TypeError('Incompatible types of option:\n'
|
|
39
|
+
+ JSON.stringify(item, null, 4));
|
|
40
|
+
};
|
|
41
|
+
const checkInitialType = (item) => {
|
|
42
|
+
if (typeof item === 'string') {
|
|
43
|
+
return 'string';
|
|
44
|
+
}
|
|
45
|
+
else if (isMappedAbstractEntity(item) || isProcessorPaymentApparatus(item)) {
|
|
46
|
+
return 'mappedEntity';
|
|
47
|
+
}
|
|
48
|
+
else if (isAbstractEntity(item)) {
|
|
49
|
+
return 'abstractEntity';
|
|
50
|
+
}
|
|
51
|
+
return undefined;
|
|
52
|
+
};
|
|
53
|
+
export const AbstractEntitySelector = (props) => {
|
|
54
|
+
const { reset, list, selected, height, optionRenderer, disableMoving, textRepresentation, textRepresentationValue = '', onChange, actionBlock, } = props;
|
|
55
|
+
const { t } = useTranslation();
|
|
56
|
+
const [searchValue, setSearchValue] = useState('');
|
|
57
|
+
const [availableList, setAvailableList] = useState([]);
|
|
58
|
+
const [addedList, setAddedList] = useState([]);
|
|
59
|
+
const [textValue, setTextValue] = useState(textRepresentationValue);
|
|
60
|
+
const [initialType, setInitialType] = useState(undefined);
|
|
61
|
+
useEffect(() => {
|
|
62
|
+
let availArray = [];
|
|
63
|
+
const selectedArray = selected.map((item, index) => {
|
|
64
|
+
return getListEntity(item, list.length + index + 1);
|
|
65
|
+
});
|
|
66
|
+
const type = list.length > 0 ? checkInitialType(list[0]) : checkInitialType(selected[0]);
|
|
67
|
+
setInitialType(type);
|
|
68
|
+
if (list.length > 0) {
|
|
69
|
+
if (type === 'string') {
|
|
70
|
+
const uniqArray = list.filter(item => selected.indexOf(item) == -1);
|
|
71
|
+
availArray = uniqArray.map((item, index) => getListEntity(item, index + 1));
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
availArray = list.map((item, index) => getListEntity(item, index + 1));
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
setAvailableList(availArray);
|
|
78
|
+
setAddedList(selectedArray);
|
|
79
|
+
if (textRepresentation) {
|
|
80
|
+
const array = selectedArray.map(item => {
|
|
81
|
+
return textRepresentation === 'ID' ? item.id : item.displayName;
|
|
82
|
+
}).toString();
|
|
83
|
+
setTextValue(array);
|
|
84
|
+
}
|
|
85
|
+
}, [reset]);
|
|
86
|
+
const onListChange = (item, type) => {
|
|
87
|
+
let tempAddedList;
|
|
88
|
+
switch (type) {
|
|
89
|
+
case 'ADD':
|
|
90
|
+
tempAddedList = addedList.filter(i => i.id !== item.id);
|
|
91
|
+
setAvailableList(prevState => {
|
|
92
|
+
return [...prevState, item];
|
|
93
|
+
});
|
|
94
|
+
setAddedList(prevState => {
|
|
95
|
+
return prevState.filter(i => i.id !== item.id);
|
|
96
|
+
});
|
|
97
|
+
if (textRepresentation) {
|
|
98
|
+
const tempArray = tempAddedList.map(item => {
|
|
99
|
+
if (textRepresentation === 'ID') {
|
|
100
|
+
return item.id;
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
return item.displayName;
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
setTextValue(tempArray.toString());
|
|
107
|
+
}
|
|
108
|
+
break;
|
|
109
|
+
case 'AVAILABLE':
|
|
110
|
+
tempAddedList = [...addedList, item];
|
|
111
|
+
setAvailableList(prevState => {
|
|
112
|
+
return prevState.filter(i => i.id !== item.id);
|
|
113
|
+
});
|
|
114
|
+
setAddedList(prevState => {
|
|
115
|
+
return [...prevState, item];
|
|
116
|
+
});
|
|
117
|
+
if (textRepresentation) {
|
|
118
|
+
const tempArray = tempAddedList.map(item => {
|
|
119
|
+
if (textRepresentation === 'ID') {
|
|
120
|
+
return item.id;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
return item.displayName;
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
setTextValue(tempArray.toString());
|
|
127
|
+
}
|
|
128
|
+
break;
|
|
129
|
+
default:
|
|
130
|
+
throw new Error('Cannot be');
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
const onDragEnd = (result) => {
|
|
134
|
+
const { destination, source } = result;
|
|
135
|
+
if (!destination) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
if (destination.index === source.index && destination.droppableId === source.droppableId) {
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
if (destination.droppableId === source.droppableId) {
|
|
142
|
+
let tempAdded = [];
|
|
143
|
+
switch (destination.droppableId) {
|
|
144
|
+
case 'availableList':
|
|
145
|
+
setAvailableList((prev) => {
|
|
146
|
+
const temp = [...prev];
|
|
147
|
+
const [removed] = temp.splice(source.index, 1);
|
|
148
|
+
temp.splice(destination.index, 0, removed);
|
|
149
|
+
return temp;
|
|
150
|
+
});
|
|
151
|
+
break;
|
|
152
|
+
case 'addedList':
|
|
153
|
+
setAddedList((prev) => {
|
|
154
|
+
const temp = [...prev];
|
|
155
|
+
const [removed] = temp.splice(source.index, 1);
|
|
156
|
+
temp.splice(destination.index, 0, removed);
|
|
157
|
+
tempAdded = temp;
|
|
158
|
+
return temp;
|
|
159
|
+
});
|
|
160
|
+
if (textRepresentation) {
|
|
161
|
+
const tempArray = tempAdded.map(item => {
|
|
162
|
+
if (textRepresentation === 'ID') {
|
|
163
|
+
return item.id;
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
return item.displayName;
|
|
167
|
+
}
|
|
168
|
+
});
|
|
169
|
+
setTextValue(tempArray.toString());
|
|
170
|
+
}
|
|
171
|
+
break;
|
|
172
|
+
default:
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
if (destination.droppableId !== result.source.droppableId) {
|
|
177
|
+
if (destination.droppableId === 'availableList') {
|
|
178
|
+
const sourceList = [...addedList];
|
|
179
|
+
const destList = [...availableList];
|
|
180
|
+
const [removed] = sourceList.splice(result.source.index, 1);
|
|
181
|
+
destList.splice(destination.index, 0, removed);
|
|
182
|
+
setAvailableList(destList);
|
|
183
|
+
setAddedList(sourceList);
|
|
184
|
+
if (textRepresentation) {
|
|
185
|
+
const tempArray = sourceList.map(item => {
|
|
186
|
+
if (textRepresentation === 'ID') {
|
|
187
|
+
return item.id;
|
|
188
|
+
}
|
|
189
|
+
else {
|
|
190
|
+
return item.displayName;
|
|
191
|
+
}
|
|
192
|
+
});
|
|
193
|
+
setTextValue(tempArray.toString());
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
const sourceList = [...availableList];
|
|
198
|
+
const destList = [...addedList];
|
|
199
|
+
const [removed] = sourceList.splice(result.source.index, 1);
|
|
200
|
+
destList.splice(destination.index, 0, removed);
|
|
201
|
+
setAvailableList(sourceList);
|
|
202
|
+
setAddedList(destList);
|
|
203
|
+
if (textRepresentation) {
|
|
204
|
+
const tempArray = destList.map(item => {
|
|
205
|
+
if (textRepresentation === 'ID') {
|
|
206
|
+
return item.id;
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
return item.displayName;
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
setTextValue(tempArray.toString());
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
onChangeParentDate();
|
|
217
|
+
};
|
|
218
|
+
const handleSelectAll = (type) => {
|
|
219
|
+
if (type === 'AVAILABLE') {
|
|
220
|
+
setAddedList(prevState => {
|
|
221
|
+
return [...prevState, ...availableList];
|
|
222
|
+
});
|
|
223
|
+
if (textRepresentation) {
|
|
224
|
+
const array = [...addedList, ...availableList].map(item => {
|
|
225
|
+
return textRepresentation === 'ID' ? item.id : item.displayName;
|
|
226
|
+
}).toString();
|
|
227
|
+
setTextValue(array);
|
|
228
|
+
}
|
|
229
|
+
setAvailableList([]);
|
|
230
|
+
}
|
|
231
|
+
else {
|
|
232
|
+
setAvailableList(prevState => {
|
|
233
|
+
return [...prevState, ...addedList];
|
|
234
|
+
});
|
|
235
|
+
if (textRepresentation) {
|
|
236
|
+
setTextValue('');
|
|
237
|
+
}
|
|
238
|
+
setAddedList([]);
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
const handleChangeTextareaValue = (value) => {
|
|
242
|
+
if (textRepresentation === 'ID') {
|
|
243
|
+
const regex = /[\d+,*]$/;
|
|
244
|
+
if (value !== '' && !regex.test(value)) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
setTextValue(value);
|
|
249
|
+
const dictionary = [...addedList, ...availableList];
|
|
250
|
+
if (value !== '') {
|
|
251
|
+
if (textRepresentation === 'ID') {
|
|
252
|
+
const tempArray = value.split(',');
|
|
253
|
+
const newAddedList = dictionary.filter(addedItem => {
|
|
254
|
+
return tempArray.includes(String(addedItem.id));
|
|
255
|
+
});
|
|
256
|
+
const newAvailableList = dictionary.filter(addedItem => {
|
|
257
|
+
return !tempArray.includes(String(addedItem.id));
|
|
258
|
+
});
|
|
259
|
+
setAddedList(newAddedList);
|
|
260
|
+
setAvailableList(newAvailableList);
|
|
261
|
+
}
|
|
262
|
+
else {
|
|
263
|
+
const tempArray = value.split(',');
|
|
264
|
+
const newAddedList = dictionary.filter(addedItem => {
|
|
265
|
+
return tempArray.includes(String(addedItem.displayName));
|
|
266
|
+
});
|
|
267
|
+
const newAvailableList = dictionary.filter(addedItem => {
|
|
268
|
+
return !tempArray.includes(String(addedItem.displayName));
|
|
269
|
+
});
|
|
270
|
+
setAddedList(newAddedList);
|
|
271
|
+
setAvailableList(newAvailableList);
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
else {
|
|
275
|
+
setAvailableList(dictionary);
|
|
276
|
+
setAddedList([]);
|
|
277
|
+
}
|
|
278
|
+
};
|
|
279
|
+
const renderOption = (option) => {
|
|
280
|
+
return optionRenderer ? optionRenderer(option) : option;
|
|
281
|
+
};
|
|
282
|
+
const onChangeParentDate = () => {
|
|
283
|
+
let mapped = [];
|
|
284
|
+
let unmapped = [];
|
|
285
|
+
if (initialType !== undefined) {
|
|
286
|
+
switch (initialType) {
|
|
287
|
+
case 'string':
|
|
288
|
+
mapped = addedList.map(item => item.displayName);
|
|
289
|
+
unmapped = availableList.map(item => item.displayName);
|
|
290
|
+
break;
|
|
291
|
+
case 'mappedEntity':
|
|
292
|
+
mapped = addedList.map(item => ({
|
|
293
|
+
...item,
|
|
294
|
+
name: item.displayName
|
|
295
|
+
}));
|
|
296
|
+
unmapped = availableList.map(item => ({
|
|
297
|
+
...item,
|
|
298
|
+
name: item.displayName
|
|
299
|
+
}));
|
|
300
|
+
break;
|
|
301
|
+
case 'abstractEntity':
|
|
302
|
+
mapped = addedList;
|
|
303
|
+
unmapped = availableList;
|
|
304
|
+
break;
|
|
305
|
+
default:
|
|
306
|
+
throw new Error('please check the types of lists');
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
onChange(mapped, unmapped);
|
|
310
|
+
};
|
|
311
|
+
useEffect(() => {
|
|
312
|
+
if (initialType) {
|
|
313
|
+
onChangeParentDate();
|
|
314
|
+
}
|
|
315
|
+
}, [addedList, availableList]);
|
|
316
|
+
const HeightPreservingItem = ({ children, ...props }) => {
|
|
317
|
+
return (React.createElement("div", { ...props, style: { minHeight: '32px' } }, children));
|
|
318
|
+
};
|
|
319
|
+
return (React.createElement(React.Fragment, null,
|
|
320
|
+
React.createElement(Box, { sx: { marginBottom: '20px' } },
|
|
321
|
+
React.createElement(PneTextField, { variant: 'outlined', sx: { width: '100%' }, onChange: (e) => {
|
|
322
|
+
setSearchValue(e.target.value);
|
|
323
|
+
}, value: searchValue, label: t('search'), slotProps: {
|
|
324
|
+
input: {
|
|
325
|
+
endAdornment: searchValue && (React.createElement(InputAdornment, { position: "end" },
|
|
326
|
+
React.createElement(IconButton, { onClick: e => setSearchValue(''), edge: "end" },
|
|
327
|
+
React.createElement(ClearIcon, null)))),
|
|
328
|
+
},
|
|
329
|
+
}, autoFocus: true })),
|
|
330
|
+
React.createElement(DragDropContext, { onDragEnd: onDragEnd },
|
|
331
|
+
React.createElement(Container, { height: height },
|
|
332
|
+
React.createElement(ColumnWrapper, null,
|
|
333
|
+
React.createElement(AddedListWrapper, null,
|
|
334
|
+
React.createElement(HeaderColumnWrapper, null,
|
|
335
|
+
React.createElement(HeaderColumn, null, t('abstractSelector.available')),
|
|
336
|
+
disableMoving !== 'AVAILABLE' && (React.createElement(PneButton, { variant: 'text', onClick: () => {
|
|
337
|
+
handleSelectAll('AVAILABLE');
|
|
338
|
+
}, sx: { marginLeft: 'auto' } }, t('abstractSelector.select.all')))),
|
|
339
|
+
React.createElement(Droppable, { droppableId: 'availableList', mode: "virtual", renderClone: (provided, _snapshot, rubric) => {
|
|
340
|
+
return (React.createElement(ItemEntitySelector, { handleClick: () => {
|
|
341
|
+
if (disableMoving !== 'AVAILABLE') {
|
|
342
|
+
onListChange(availableList[rubric.source.index], 'AVAILABLE');
|
|
343
|
+
}
|
|
344
|
+
}, provided: provided, item: availableList[rubric.source.index], name: renderOption(availableList[rubric.source.index].displayName) }));
|
|
345
|
+
} }, (provided) => (React.createElement(Virtuoso, { components: {
|
|
346
|
+
Item: HeightPreservingItem,
|
|
347
|
+
}, scrollerRef: (value) => provided.innerRef(value), data: availableList.filter(item => renderOption(item.displayName).toLowerCase().includes(searchValue.toLowerCase())), itemContent: (index, item) => {
|
|
348
|
+
return (React.createElement(Draggable, { key: item.id, draggableId: item.id.toString(), index: index, isDragDisabled: disableMoving === 'AVAILABLE' }, (provided) => (React.createElement(ItemEntitySelector, { handleClick: () => {
|
|
349
|
+
if (disableMoving !== 'AVAILABLE') {
|
|
350
|
+
onListChange(item, 'AVAILABLE');
|
|
351
|
+
}
|
|
352
|
+
}, provided: provided, item: item, name: renderOption(item.displayName) }))));
|
|
353
|
+
} }, provided.placeholder))))),
|
|
354
|
+
React.createElement(ColumnWrapper, null,
|
|
355
|
+
React.createElement(AddedListWrapper, null,
|
|
356
|
+
React.createElement(HeaderColumnWrapper, null,
|
|
357
|
+
React.createElement(HeaderColumn, null, t('abstractSelector.added')),
|
|
358
|
+
disableMoving !== 'ADDED' && (React.createElement(PneButton, { variant: 'text', onClick: () => {
|
|
359
|
+
handleSelectAll('ADDED');
|
|
360
|
+
}, sx: { marginLeft: 'auto' } }, t('abstractSelector.select.all')))),
|
|
361
|
+
React.createElement(Droppable, { droppableId: 'addedList', mode: "virtual", renderClone: (provided, _snapshot, rubric) => {
|
|
362
|
+
return (React.createElement(ItemEntitySelector, { handleClick: () => {
|
|
363
|
+
if (disableMoving !== 'ADDED') {
|
|
364
|
+
onListChange(addedList[rubric.source.index], 'ADD');
|
|
365
|
+
}
|
|
366
|
+
}, provided: provided, item: addedList[rubric.source.index], name: renderOption(addedList[rubric.source.index].displayName) }));
|
|
367
|
+
} }, (provided) => (React.createElement(Virtuoso, { components: {
|
|
368
|
+
Item: HeightPreservingItem,
|
|
369
|
+
}, scrollerRef: (value) => provided.innerRef(value), data: addedList, itemContent: (index, item) => {
|
|
370
|
+
return (React.createElement(Draggable, { key: item.id, draggableId: item.id.toString(), index: index, isDragDisabled: disableMoving === 'ADDED' }, (provided) => (React.createElement(ItemEntitySelector, { handleClick: () => {
|
|
371
|
+
if (disableMoving !== 'ADDED') {
|
|
372
|
+
onListChange(item, 'ADD');
|
|
373
|
+
}
|
|
374
|
+
}, provided: provided, item: item, name: renderOption(item.displayName) }))));
|
|
375
|
+
} }, provided.placeholder))))))),
|
|
376
|
+
textRepresentation && (React.createElement(Stack, { sx: { marginTop: '38px' } },
|
|
377
|
+
React.createElement(PneTextField, { value: textValue, onChange: (event) => {
|
|
378
|
+
handleChangeTextareaValue(event.target.value);
|
|
379
|
+
}, multiline: true, fullWidth: true, sx: { mt: '16px' }, minRows: 3 }))),
|
|
380
|
+
actionBlock ? actionBlock : null));
|
|
381
|
+
};
|
|
382
|
+
//# sourceMappingURL=AbstractEntitySelector.js.map
|