@wix/patterns 1.137.0 → 1.139.0
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/dist/cjs/components/ActionModal/CustomActionModal.js +3 -3
- package/dist/cjs/components/ActionModal/CustomActionModal.js.map +1 -1
- package/dist/cjs/components/Collapse/Collapse.st.css.js +3 -3
- package/dist/cjs/components/Collapse/Collapse.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionToolbar/CollectionToolbar.st.css.js +5 -5
- package/dist/cjs/components/CollectionToolbar/CollectionToolbar.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionToolbar/CollectionToolbar.uni.driver.js +7 -2
- package/dist/cjs/components/CollectionToolbar/CollectionToolbar.uni.driver.js.map +1 -1
- package/dist/cjs/components/CollectionToolbar/SearchOrCustomFilter.st.css.js +3 -3
- package/dist/cjs/components/CollectionToolbar/SearchOrCustomFilter.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionToolbars/CollectionToolbars.js +1 -1
- package/dist/cjs/components/CollectionToolbars/CollectionToolbars.js.map +1 -1
- package/dist/cjs/components/CollectionToolbars/ToolbarAndTitlebarContainer.js +4 -6
- package/dist/cjs/components/CollectionToolbars/ToolbarAndTitlebarContainer.js.map +1 -1
- package/dist/cjs/components/CollectionToolbars/ToolbarState.js +11 -2
- package/dist/cjs/components/CollectionToolbars/ToolbarState.js.map +1 -1
- package/dist/cjs/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js +2 -2
- package/dist/cjs/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionViewsDropdown/ViewsDropdown.st.css.js +2 -2
- package/dist/cjs/components/CollectionViewsDropdown/ViewsDropdown.st.css.js.map +1 -1
- package/dist/cjs/components/CustomColumnsPanel/CustomColumnsCTAButton.js +20 -21
- package/dist/cjs/components/CustomColumnsPanel/CustomColumnsCTAButton.js.map +1 -1
- package/dist/cjs/components/CustomFieldModal/CustomFieldFormPiiFields.js +9 -8
- package/dist/cjs/components/CustomFieldModal/CustomFieldFormPiiFields.js.map +1 -1
- package/dist/cjs/components/CustomFieldModal/CustomFieldModal.uni.driver.js +5 -1
- package/dist/cjs/components/CustomFieldModal/CustomFieldModal.uni.driver.js.map +1 -1
- package/dist/cjs/components/CustomFieldsForm/CustomFieldsForm.js +22 -29
- package/dist/cjs/components/CustomFieldsForm/CustomFieldsForm.js.map +1 -1
- package/dist/cjs/components/CustomFieldsWidget/CustomFieldsWidget.js +11 -6
- package/dist/cjs/components/CustomFieldsWidget/CustomFieldsWidget.js.map +1 -1
- package/dist/cjs/components/DragHandle/DragHandle.st.css.js +2 -2
- package/dist/cjs/components/DragHandle/DragHandle.st.css.js.map +1 -1
- package/dist/cjs/components/ExportButton/ExportButton.js +23 -26
- package/dist/cjs/components/ExportButton/ExportButton.js.map +1 -1
- package/dist/cjs/components/Fade/Fade.st.css.js +2 -2
- package/dist/cjs/components/Fade/Fade.st.css.js.map +1 -1
- package/dist/cjs/components/FormFieldInput/FormFieldInput.js +7 -4
- package/dist/cjs/components/FormFieldInput/FormFieldInput.js.map +1 -1
- package/dist/cjs/components/Heading/Heading.st.css.js +2 -2
- package/dist/cjs/components/Heading/Heading.st.css.js.map +1 -1
- package/dist/cjs/components/InputOverflow/InputOverflow.st.css.js +2 -2
- package/dist/cjs/components/InputOverflow/InputOverflow.st.css.js.map +1 -1
- package/dist/cjs/components/LoadingRow/LoadingRow.st.css.js +3 -3
- package/dist/cjs/components/LoadingRow/LoadingRow.st.css.js.map +1 -1
- package/dist/cjs/components/MaxHeightText/MaxHeightText.st.css.js +2 -2
- package/dist/cjs/components/MaxHeightText/MaxHeightText.st.css.js.map +1 -1
- package/dist/cjs/components/MaxLines/MaxLines.st.css.js +2 -2
- package/dist/cjs/components/MaxLines/MaxLines.st.css.js.map +1 -1
- package/dist/cjs/components/MoreFiltersCTA/MoreFiltersCTA.js +12 -9
- package/dist/cjs/components/MoreFiltersCTA/MoreFiltersCTA.js.map +1 -1
- package/dist/cjs/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js +2 -2
- package/dist/cjs/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js.map +1 -1
- package/dist/cjs/components/MultiLevelSorting/MultiLevelSortingCTAButton.js +17 -22
- package/dist/cjs/components/MultiLevelSorting/MultiLevelSortingCTAButton.js.map +1 -1
- package/dist/cjs/components/MultiLevelSorting/MultiLevelSortingCTAButton.uni.driver.js +11 -0
- package/dist/cjs/components/MultiLevelSorting/MultiLevelSortingCTAButton.uni.driver.js.map +1 -0
- package/dist/cjs/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.js +2 -2
- package/dist/cjs/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.js.map +1 -1
- package/dist/cjs/components/NestedTable/NestedTableRow.st.css.js +5 -5
- package/dist/cjs/components/NestedTable/NestedTableRow.st.css.js.map +1 -1
- package/dist/cjs/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js +2 -2
- package/dist/cjs/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js.map +1 -1
- package/dist/cjs/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.js +2 -2
- package/dist/cjs/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.js.map +1 -1
- package/dist/cjs/components/PickerContent/PickerContent.st.css.js +2 -2
- package/dist/cjs/components/PickerContent/PickerContent.st.css.js.map +1 -1
- package/dist/cjs/components/PickerContent/PickerContentAdditionalStep.st.css.js +4 -4
- package/dist/cjs/components/PickerContent/PickerContentAdditionalStep.st.css.js.map +1 -1
- package/dist/cjs/components/PickerTableListItem/PickerTableListItem.st.css.js +2 -2
- package/dist/cjs/components/PickerTableListItem/PickerTableListItem.st.css.js.map +1 -1
- package/dist/cjs/components/ResponsiveButton/ResponsiveButton.js +76 -0
- package/dist/cjs/components/ResponsiveButton/ResponsiveButton.js.map +1 -0
- package/dist/cjs/components/ResponsiveButton/ResponsiveButton.uni.driver.js +15 -0
- package/dist/cjs/components/ResponsiveButton/ResponsiveButton.uni.driver.js.map +1 -0
- package/dist/cjs/components/ScrollableContent/ScrollableContent.st.css.js +2 -2
- package/dist/cjs/components/ScrollableContent/ScrollableContent.st.css.js.map +1 -1
- package/dist/cjs/components/SkeletonCard/SkeletonCard.st.css.js +3 -3
- package/dist/cjs/components/SkeletonCard/SkeletonCard.st.css.js.map +1 -1
- package/dist/cjs/components/SlidingModal/SlidingModal.st.css.js +2 -2
- package/dist/cjs/components/SlidingModal/SlidingModal.st.css.js.map +1 -1
- package/dist/cjs/components/TabsFilter/TabsFilter.st.css.js +3 -3
- package/dist/cjs/components/TabsFilter/TabsFilter.st.css.js.map +1 -1
- package/dist/cjs/components/Tags/BulkAssignTagsPopover/AsyncJobProgressModal.js +7 -4
- package/dist/cjs/components/Tags/BulkAssignTagsPopover/AsyncJobProgressModal.js.map +1 -1
- package/dist/cjs/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js +2 -2
- package/dist/cjs/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js.map +1 -1
- package/dist/cjs/components/Tags/TagsBulkAssignUtils.js +40 -0
- package/dist/cjs/components/Tags/TagsBulkAssignUtils.js.map +1 -0
- package/dist/cjs/components/Tags/useTagsBulkAssignFoldersUtils.js +7 -7
- package/dist/cjs/components/Tags/useTagsBulkAssignFoldersUtils.js.map +1 -1
- package/dist/cjs/components/Tags/useTagsBulkAssignUtils.js +7 -7
- package/dist/cjs/components/Tags/useTagsBulkAssignUtils.js.map +1 -1
- package/dist/cjs/components/ToolbarItemBox/ToolbarItemBox.st.css.js +2 -2
- package/dist/cjs/components/ToolbarItemBox/ToolbarItemBox.st.css.js.map +1 -1
- package/dist/cjs/components/common.st.css.js +4 -4
- package/dist/cjs/components/common.st.css.js.map +1 -1
- package/dist/cjs/state/CustomFields/CustomFieldsFormState.js +1 -31
- package/dist/cjs/state/CustomFields/CustomFieldsFormState.js.map +1 -1
- package/dist/cjs/state/EntityPage/EntityPageState.js.map +1 -1
- package/dist/cjs/state/FoldersAndItemsCollectionsState.js +2 -2
- package/dist/cjs/state/FoldersAndItemsCollectionsState.js.map +1 -1
- package/dist/cjs/state/Responsive/HorizontalOverflowState.js +61 -0
- package/dist/cjs/state/Responsive/HorizontalOverflowState.js.map +1 -0
- package/dist/cjs/state/Responsive/HorizontalSpaceAvailableState.js +64 -0
- package/dist/cjs/state/Responsive/HorizontalSpaceAvailableState.js.map +1 -0
- package/dist/cjs/state/SettingsPage/SettingsPageState.js.map +1 -1
- package/dist/cjs/state/TagsBulkAssignAsyncState.js +98 -35
- package/dist/cjs/state/TagsBulkAssignAsyncState.js.map +1 -1
- package/dist/cjs/state/TagsBulkAssignPopoverState.js +3 -11
- package/dist/cjs/state/TagsBulkAssignPopoverState.js.map +1 -1
- package/dist/cjs/state/TagsBulkAssignSyncState.js +9 -1
- package/dist/cjs/state/TagsBulkAssignSyncState.js.map +1 -1
- package/dist/cjs/state/Toolbar/ToolbarResponsivePriorityState.js +66 -0
- package/dist/cjs/state/Toolbar/ToolbarResponsivePriorityState.js.map +1 -0
- package/dist/cjs/state/Toolbar/ToolbarResponsiveState.js +89 -0
- package/dist/cjs/state/Toolbar/ToolbarResponsiveState.js.map +1 -0
- package/dist/cjs/state/ToolbarCollectionState.js +3 -0
- package/dist/cjs/state/ToolbarCollectionState.js.map +1 -1
- package/dist/cjs/styles.global.css +1 -1
- package/dist/cjs/test-utils/AsyncJobMocks.js +16 -1
- package/dist/cjs/test-utils/AsyncJobMocks.js.map +1 -1
- package/dist/cjs/test-utils/WixPatternsEssentialsTestProvider.js +12 -7
- package/dist/cjs/test-utils/WixPatternsEssentialsTestProvider.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/esm/components/ActionModal/CustomActionModal.js +6 -4
- package/dist/esm/components/ActionModal/CustomActionModal.js.map +1 -1
- package/dist/esm/components/Collapse/Collapse.st.css.js +2 -2
- package/dist/esm/components/CollectionToolbar/CollectionToolbar.st.css.js +2 -2
- package/dist/esm/components/CollectionToolbar/CollectionToolbar.uni.driver.js +7 -2
- package/dist/esm/components/CollectionToolbar/CollectionToolbar.uni.driver.js.map +1 -1
- package/dist/esm/components/CollectionToolbar/SearchOrCustomFilter.st.css.js +2 -2
- package/dist/esm/components/CollectionToolbar/SearchOrCustomFilter.st.css.js.map +1 -1
- package/dist/esm/components/CollectionToolbars/CollectionToolbars.js +1 -1
- package/dist/esm/components/CollectionToolbars/CollectionToolbars.js.map +1 -1
- package/dist/esm/components/CollectionToolbars/ToolbarAndTitlebarContainer.js +4 -6
- package/dist/esm/components/CollectionToolbars/ToolbarAndTitlebarContainer.js.map +1 -1
- package/dist/esm/components/CollectionToolbars/ToolbarState.js +7 -1
- package/dist/esm/components/CollectionToolbars/ToolbarState.js.map +1 -1
- package/dist/esm/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js +2 -2
- package/dist/esm/components/CollectionViewsDropdown/ViewsDropdown.st.css.js +2 -2
- package/dist/esm/components/CustomColumnsPanel/CustomColumnsCTAButton.js +4 -5
- package/dist/esm/components/CustomColumnsPanel/CustomColumnsCTAButton.js.map +1 -1
- package/dist/esm/components/CustomFieldModal/CustomFieldFormPiiFields.js +1 -1
- package/dist/esm/components/CustomFieldModal/CustomFieldFormPiiFields.js.map +1 -1
- package/dist/esm/components/CustomFieldModal/CustomFieldModal.uni.driver.js +5 -1
- package/dist/esm/components/CustomFieldModal/CustomFieldModal.uni.driver.js.map +1 -1
- package/dist/esm/components/CustomFieldsForm/CustomFieldsForm.js +11 -11
- package/dist/esm/components/CustomFieldsForm/CustomFieldsForm.js.map +1 -1
- package/dist/esm/components/CustomFieldsWidget/CustomFieldsWidget.js +6 -1
- package/dist/esm/components/CustomFieldsWidget/CustomFieldsWidget.js.map +1 -1
- package/dist/esm/components/DragHandle/DragHandle.st.css.js +2 -2
- package/dist/esm/components/DragHandle/DragHandle.st.css.js.map +1 -1
- package/dist/esm/components/ExportButton/ExportButton.js +4 -4
- package/dist/esm/components/ExportButton/ExportButton.js.map +1 -1
- package/dist/esm/components/Fade/Fade.st.css.js +2 -2
- package/dist/esm/components/Fade/Fade.st.css.js.map +1 -1
- package/dist/esm/components/FormFieldInput/FormFieldInput.js +4 -1
- package/dist/esm/components/FormFieldInput/FormFieldInput.js.map +1 -1
- package/dist/esm/components/Heading/Heading.st.css.js +2 -2
- package/dist/esm/components/InputOverflow/InputOverflow.st.css.js +2 -2
- package/dist/esm/components/InputOverflow/InputOverflow.st.css.js.map +1 -1
- package/dist/esm/components/LoadingRow/LoadingRow.st.css.js +3 -3
- package/dist/esm/components/LoadingRow/LoadingRow.st.css.js.map +1 -1
- package/dist/esm/components/MaxHeightText/MaxHeightText.st.css.js +2 -2
- package/dist/esm/components/MaxHeightText/MaxHeightText.st.css.js.map +1 -1
- package/dist/esm/components/MaxLines/MaxLines.st.css.js +2 -2
- package/dist/esm/components/MoreFiltersCTA/MoreFiltersCTA.js +3 -3
- package/dist/esm/components/MoreFiltersCTA/MoreFiltersCTA.js.map +1 -1
- package/dist/esm/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js +2 -2
- package/dist/esm/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js.map +1 -1
- package/dist/esm/components/MultiLevelSorting/MultiLevelSortingCTAButton.js +13 -15
- package/dist/esm/components/MultiLevelSorting/MultiLevelSortingCTAButton.js.map +1 -1
- package/dist/esm/components/MultiLevelSorting/MultiLevelSortingCTAButton.uni.driver.js +7 -0
- package/dist/esm/components/MultiLevelSorting/MultiLevelSortingCTAButton.uni.driver.js.map +1 -0
- package/dist/esm/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.js +2 -2
- package/dist/esm/components/NestedTable/NestedTableRow.st.css.js +2 -2
- package/dist/esm/components/NestedTable/NestedTableRow.st.css.js.map +1 -1
- package/dist/esm/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js +2 -2
- package/dist/esm/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.js +2 -2
- package/dist/esm/components/PickerContent/PickerContent.st.css.js +2 -2
- package/dist/esm/components/PickerContent/PickerContentAdditionalStep.st.css.js +2 -2
- package/dist/esm/components/PickerTableListItem/PickerTableListItem.st.css.js +2 -2
- package/dist/esm/components/ResponsiveButton/ResponsiveButton.js +17 -0
- package/dist/esm/components/ResponsiveButton/ResponsiveButton.js.map +1 -0
- package/dist/esm/components/ResponsiveButton/ResponsiveButton.uni.driver.js +9 -0
- package/dist/esm/components/ResponsiveButton/ResponsiveButton.uni.driver.js.map +1 -0
- package/dist/esm/components/ScrollableContent/ScrollableContent.st.css.js +2 -2
- package/dist/esm/components/ScrollableContent/ScrollableContent.st.css.js.map +1 -1
- package/dist/esm/components/SkeletonCard/SkeletonCard.st.css.js +2 -2
- package/dist/esm/components/SkeletonCard/SkeletonCard.st.css.js.map +1 -1
- package/dist/esm/components/SlidingModal/SlidingModal.st.css.js +2 -2
- package/dist/esm/components/TabsFilter/TabsFilter.st.css.js +2 -2
- package/dist/esm/components/Tags/BulkAssignTagsPopover/AsyncJobProgressModal.js +2 -2
- package/dist/esm/components/Tags/BulkAssignTagsPopover/AsyncJobProgressModal.js.map +1 -1
- package/dist/esm/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js +2 -2
- package/dist/esm/components/Tags/TagsBulkAssignUtils.js +24 -0
- package/dist/esm/components/Tags/TagsBulkAssignUtils.js.map +1 -0
- package/dist/esm/components/Tags/useTagsBulkAssignFoldersUtils.js +8 -5
- package/dist/esm/components/Tags/useTagsBulkAssignFoldersUtils.js.map +1 -1
- package/dist/esm/components/Tags/useTagsBulkAssignUtils.js +5 -4
- package/dist/esm/components/Tags/useTagsBulkAssignUtils.js.map +1 -1
- package/dist/esm/components/ToolbarItemBox/ToolbarItemBox.st.css.js +2 -2
- package/dist/esm/components/common.st.css.js +2 -2
- package/dist/esm/state/CustomFields/CustomFieldsFormState.js +1 -31
- package/dist/esm/state/CustomFields/CustomFieldsFormState.js.map +1 -1
- package/dist/esm/state/EntityPage/EntityPageState.js.map +1 -1
- package/dist/esm/state/FoldersAndItemsCollectionsState.js +2 -2
- package/dist/esm/state/FoldersAndItemsCollectionsState.js.map +1 -1
- package/dist/esm/state/Responsive/HorizontalOverflowState.js +45 -0
- package/dist/esm/state/Responsive/HorizontalOverflowState.js.map +1 -0
- package/dist/esm/state/Responsive/HorizontalSpaceAvailableState.js +45 -0
- package/dist/esm/state/Responsive/HorizontalSpaceAvailableState.js.map +1 -0
- package/dist/esm/state/SettingsPage/SettingsPageState.js.map +1 -1
- package/dist/esm/state/TagsBulkAssignAsyncState.js +74 -18
- package/dist/esm/state/TagsBulkAssignAsyncState.js.map +1 -1
- package/dist/esm/state/TagsBulkAssignPopoverState.js +2 -8
- package/dist/esm/state/TagsBulkAssignPopoverState.js.map +1 -1
- package/dist/esm/state/TagsBulkAssignSyncState.js +6 -0
- package/dist/esm/state/TagsBulkAssignSyncState.js.map +1 -1
- package/dist/esm/state/Toolbar/ToolbarResponsivePriorityState.js +44 -0
- package/dist/esm/state/Toolbar/ToolbarResponsivePriorityState.js.map +1 -0
- package/dist/esm/state/Toolbar/ToolbarResponsiveState.js +70 -0
- package/dist/esm/state/Toolbar/ToolbarResponsiveState.js.map +1 -0
- package/dist/esm/state/ToolbarCollectionState.js +2 -0
- package/dist/esm/state/ToolbarCollectionState.js.map +1 -1
- package/dist/esm/styles.global.css +1 -1
- package/dist/esm/test-utils/AsyncJobMocks.js +11 -0
- package/dist/esm/test-utils/AsyncJobMocks.js.map +1 -1
- package/dist/esm/test-utils/WixPatternsEssentialsTestProvider.js +14 -7
- package/dist/esm/test-utils/WixPatternsEssentialsTestProvider.js.map +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/types/components/ActionModal/CustomActionModal.d.ts.map +1 -1
- package/dist/types/components/CollectionTable/CollectionTable.uni.driver.d.ts +52 -2
- package/dist/types/components/CollectionTable/CollectionTable.uni.driver.d.ts.map +1 -1
- package/dist/types/components/CollectionToolbar/CollectionToolbar.uni.driver.d.ts +37 -11
- package/dist/types/components/CollectionToolbar/CollectionToolbar.uni.driver.d.ts.map +1 -1
- package/dist/types/components/CollectionToolbar/SearchOrCustomFilter.st.css.d.ts.map +1 -1
- package/dist/types/components/CollectionToolbars/ToolbarAndTitlebarContainer.d.ts +2 -2
- package/dist/types/components/CollectionToolbars/ToolbarAndTitlebarContainer.d.ts.map +1 -1
- package/dist/types/components/CollectionToolbars/ToolbarState.d.ts +2 -0
- package/dist/types/components/CollectionToolbars/ToolbarState.d.ts.map +1 -1
- package/dist/types/components/CustomColumnsPanel/CustomColumnsCTAButton.d.ts.map +1 -1
- package/dist/types/components/CustomFieldModal/CustomFieldFormPiiFields.d.ts.map +1 -1
- package/dist/types/components/CustomFieldModal/CustomFieldModal.uni.driver.d.ts +1 -0
- package/dist/types/components/CustomFieldModal/CustomFieldModal.uni.driver.d.ts.map +1 -1
- package/dist/types/components/CustomFieldsForm/CustomFieldsForm.d.ts.map +1 -1
- package/dist/types/components/CustomFieldsWidget/CustomFieldsWidget.d.ts.map +1 -1
- package/dist/types/components/CustomFieldsWidget/CustomFieldsWidget.uni.driver.d.ts +2 -0
- package/dist/types/components/CustomFieldsWidget/CustomFieldsWidget.uni.driver.d.ts.map +1 -1
- package/dist/types/components/DragHandle/DragHandle.st.css.d.ts.map +1 -1
- package/dist/types/components/ExportButton/ExportButton.d.ts.map +1 -1
- package/dist/types/components/Fade/Fade.st.css.d.ts.map +1 -1
- package/dist/types/components/FormFieldInput/FormFieldInput.d.ts +13 -0
- package/dist/types/components/FormFieldInput/FormFieldInput.d.ts.map +1 -1
- package/dist/types/components/Grid/Grid.uni.driver.d.ts +26 -1
- package/dist/types/components/Grid/Grid.uni.driver.d.ts.map +1 -1
- package/dist/types/components/Grid/GridFolders.uni.driver.d.ts +75 -0
- package/dist/types/components/Grid/GridFolders.uni.driver.d.ts.map +1 -1
- package/dist/types/components/Grid/GridFoldersSection.uni.driver.d.ts +25 -0
- package/dist/types/components/Grid/GridFoldersSection.uni.driver.d.ts.map +1 -1
- package/dist/types/components/InputOverflow/InputOverflow.st.css.d.ts.map +1 -1
- package/dist/types/components/LoadingRow/LoadingRow.st.css.d.ts.map +1 -1
- package/dist/types/components/MaxHeightText/MaxHeightText.st.css.d.ts.map +1 -1
- package/dist/types/components/MoreFiltersCTA/MoreFiltersCTA.d.ts.map +1 -1
- package/dist/types/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.d.ts.map +1 -1
- package/dist/types/components/MultiLevelSorting/MultiLevelSortingCTAButton.d.ts.map +1 -1
- package/dist/types/components/MultiLevelSorting/MultiLevelSortingCTAButton.uni.driver.d.ts +29 -0
- package/dist/types/components/MultiLevelSorting/MultiLevelSortingCTAButton.uni.driver.d.ts.map +1 -0
- package/dist/types/components/NestedTable/NestedTable.uni.driver.d.ts +76 -36
- package/dist/types/components/NestedTable/NestedTable.uni.driver.d.ts.map +1 -1
- package/dist/types/components/NestedTable/NestedTableRow.st.css.d.ts.map +1 -1
- package/dist/types/components/ResponsiveButton/ResponsiveButton.d.ts +15 -0
- package/dist/types/components/ResponsiveButton/ResponsiveButton.d.ts.map +1 -0
- package/dist/types/components/ResponsiveButton/ResponsiveButton.uni.driver.d.ts +29 -0
- package/dist/types/components/ResponsiveButton/ResponsiveButton.uni.driver.d.ts.map +1 -0
- package/dist/types/components/ScrollableContent/ScrollableContent.st.css.d.ts.map +1 -1
- package/dist/types/components/SkeletonCard/SkeletonCard.st.css.d.ts.map +1 -1
- package/dist/types/components/Table/Table.uni.driver.d.ts +51 -0
- package/dist/types/components/Table/Table.uni.driver.d.ts.map +1 -1
- package/dist/types/components/TableFolders/TableFolders.uni.driver.d.ts +76 -0
- package/dist/types/components/TableFolders/TableFolders.uni.driver.d.ts.map +1 -1
- package/dist/types/components/TableGridSwitch/TableGridSwitch.uni.driver.d.ts +76 -0
- package/dist/types/components/TableGridSwitch/TableGridSwitch.uni.driver.d.ts.map +1 -1
- package/dist/types/components/TableGridSwitchFolders/TableGridSwitchFolders.uni.driver.d.ts +151 -0
- package/dist/types/components/TableGridSwitchFolders/TableGridSwitchFolders.uni.driver.d.ts.map +1 -1
- package/dist/types/components/Tags/BulkAssignTagsPopover/AsyncJobProgressModal.d.ts.map +1 -1
- package/dist/types/components/Tags/TagsBulkAssignUtils.d.ts +13 -0
- package/dist/types/components/Tags/TagsBulkAssignUtils.d.ts.map +1 -0
- package/dist/types/components/Tags/useTagsBulkAssignFoldersUtils.d.ts.map +1 -1
- package/dist/types/components/Tags/useTagsBulkAssignUtils.d.ts.map +1 -1
- package/dist/types/state/CustomFields/CustomFieldsFormState.d.ts +0 -8
- package/dist/types/state/CustomFields/CustomFieldsFormState.d.ts.map +1 -1
- package/dist/types/state/FoldersAndItemsCollectionsState.d.ts +1 -1
- package/dist/types/state/FoldersAndItemsCollectionsState.d.ts.map +1 -1
- package/dist/types/state/Responsive/HorizontalOverflowState.d.ts +19 -0
- package/dist/types/state/Responsive/HorizontalOverflowState.d.ts.map +1 -0
- package/dist/types/state/Responsive/HorizontalSpaceAvailableState.d.ts +20 -0
- package/dist/types/state/Responsive/HorizontalSpaceAvailableState.d.ts.map +1 -0
- package/dist/types/state/TagsBulkAssignAsyncState.d.ts +5 -0
- package/dist/types/state/TagsBulkAssignAsyncState.d.ts.map +1 -1
- package/dist/types/state/TagsBulkAssignPopoverState.d.ts +0 -2
- package/dist/types/state/TagsBulkAssignPopoverState.d.ts.map +1 -1
- package/dist/types/state/TagsBulkAssignSyncState.d.ts +2 -0
- package/dist/types/state/TagsBulkAssignSyncState.d.ts.map +1 -1
- package/dist/types/state/Toolbar/ToolbarResponsivePriorityState.d.ts +22 -0
- package/dist/types/state/Toolbar/ToolbarResponsivePriorityState.d.ts.map +1 -0
- package/dist/types/state/Toolbar/ToolbarResponsiveState.d.ts +22 -0
- package/dist/types/state/Toolbar/ToolbarResponsiveState.d.ts.map +1 -0
- package/dist/types/state/ToolbarCollectionState.d.ts +2 -0
- package/dist/types/state/ToolbarCollectionState.d.ts.map +1 -1
- package/dist/types/test-utils/AsyncJobMocks.d.ts +4 -0
- package/dist/types/test-utils/AsyncJobMocks.d.ts.map +1 -1
- package/dist/types/test-utils/WixPatternsEssentialsTestProvider.d.ts.map +1 -1
- package/dist/types/testkit/enzyme.d.ts +531 -0
- package/dist/types/testkit/enzyme.d.ts.map +1 -1
- package/dist/types/testkit/jsdom.d.ts +532 -0
- package/dist/types/testkit/jsdom.d.ts.map +1 -1
- package/dist/types/testkit/puppeteer.d.ts +531 -0
- package/dist/types/testkit/puppeteer.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/package.json +3 -3
- package/dist/cjs/components/Tags/useTagsBulkAssignBaseUtils.js +0 -28
- package/dist/cjs/components/Tags/useTagsBulkAssignBaseUtils.js.map +0 -1
- package/dist/esm/components/Tags/useTagsBulkAssignBaseUtils.js +0 -16
- package/dist/esm/components/Tags/useTagsBulkAssignBaseUtils.js.map +0 -1
- package/dist/types/components/Tags/useTagsBulkAssignBaseUtils.d.ts +0 -15
- package/dist/types/components/Tags/useTagsBulkAssignBaseUtils.d.ts.map +0 -1
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
exports.__esModule = true;
|
|
5
|
+
exports.HorizontalOverflowState = void 0;
|
|
6
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
7
|
+
var _mobx = require("mobx");
|
|
8
|
+
var _bexCore = require("@wix/bex-core");
|
|
9
|
+
class HorizontalOverflowState {
|
|
10
|
+
constructor(params) {
|
|
11
|
+
(0, _defineProperty2.default)(this, "_syncThrottled", void 0);
|
|
12
|
+
(0, _defineProperty2.default)(this, "container", void 0);
|
|
13
|
+
(0, _defineProperty2.default)(this, "_responsiveDisabled", void 0);
|
|
14
|
+
(0, _defineProperty2.default)(this, "_element", void 0);
|
|
15
|
+
(0, _defineProperty2.default)(this, "_scrollWidth", 0);
|
|
16
|
+
(0, _defineProperty2.default)(this, "_clientWidth", 0);
|
|
17
|
+
this.container = params.container;
|
|
18
|
+
this._responsiveDisabled = params.responsiveDisabled;
|
|
19
|
+
(0, _mobx.makeObservable)(this, {
|
|
20
|
+
_sync: _mobx.action.bound,
|
|
21
|
+
_scrollWidth: _mobx.observable.ref,
|
|
22
|
+
_clientWidth: _mobx.observable.ref,
|
|
23
|
+
_isOverflowing: _mobx.computed
|
|
24
|
+
});
|
|
25
|
+
this._syncThrottled = this.container.lodash.throttle(() => {
|
|
26
|
+
requestAnimationFrame(this._sync);
|
|
27
|
+
}, 200);
|
|
28
|
+
}
|
|
29
|
+
get _isOverflowing() {
|
|
30
|
+
return this._scrollWidth > this._clientWidth;
|
|
31
|
+
}
|
|
32
|
+
_sync() {
|
|
33
|
+
const {
|
|
34
|
+
_element
|
|
35
|
+
} = this;
|
|
36
|
+
if (!_element) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
this._clientWidth = _element.clientWidth;
|
|
40
|
+
this._scrollWidth = _element.scrollWidth;
|
|
41
|
+
}
|
|
42
|
+
init() {
|
|
43
|
+
const {
|
|
44
|
+
_element,
|
|
45
|
+
_responsiveDisabled
|
|
46
|
+
} = this;
|
|
47
|
+
if (_responsiveDisabled) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
if (!_element) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
this._syncThrottled();
|
|
54
|
+
const disposers = [(0, _bexCore.addResizeObserver)(_element, this._syncThrottled)];
|
|
55
|
+
return () => {
|
|
56
|
+
disposers.forEach(d => d == null ? void 0 : d());
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
exports.HorizontalOverflowState = HorizontalOverflowState;
|
|
61
|
+
//# sourceMappingURL=HorizontalOverflowState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_mobx","require","_bexCore","HorizontalOverflowState","constructor","params","_defineProperty2","default","container","_responsiveDisabled","responsiveDisabled","makeObservable","_sync","action","bound","_scrollWidth","observable","ref","_clientWidth","_isOverflowing","computed","_syncThrottled","lodash","throttle","requestAnimationFrame","_element","clientWidth","scrollWidth","init","disposers","addResizeObserver","forEach","d","exports"],"sources":["../../../../src/state/Responsive/HorizontalOverflowState.ts"],"sourcesContent":["import { action, computed, makeObservable, observable } from 'mobx';\nimport { addResizeObserver, WixPatternsContainer } from '@wix/bex-core';\n\nexport interface HorizontalOverflowStateParams {\n container: WixPatternsContainer;\n responsiveDisabled: boolean | undefined;\n}\n\nexport class HorizontalOverflowState {\n readonly _syncThrottled;\n\n readonly container;\n readonly _responsiveDisabled;\n\n _element?: Element | null | undefined;\n\n _scrollWidth = 0;\n _clientWidth = 0;\n\n constructor(params: HorizontalOverflowStateParams) {\n this.container = params.container;\n this._responsiveDisabled = params.responsiveDisabled;\n\n makeObservable(this, {\n _sync: action.bound,\n _scrollWidth: observable.ref,\n _clientWidth: observable.ref,\n _isOverflowing: computed,\n });\n\n this._syncThrottled = this.container.lodash.throttle(() => {\n requestAnimationFrame(this._sync);\n }, 200);\n }\n\n get _isOverflowing() {\n return this._scrollWidth > this._clientWidth;\n }\n\n _sync() {\n const { _element } = this;\n\n if (!_element) {\n return;\n }\n\n this._clientWidth = _element.clientWidth;\n this._scrollWidth = _element.scrollWidth;\n }\n\n init() {\n const { _element, _responsiveDisabled } = this;\n\n if (_responsiveDisabled) {\n return;\n }\n\n if (!_element) {\n return;\n }\n\n this._syncThrottled();\n\n const disposers = [addResizeObserver(_element, this._syncThrottled)];\n\n return () => {\n disposers.forEach((d) => d?.());\n };\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,KAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AAOO,MAAME,uBAAuB,CAAC;EAWnCC,WAAWA,CAACC,MAAqC,EAAE;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,wBAHpC,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,wBACD,CAAC;IAGd,IAAI,CAACC,SAAS,GAAGH,MAAM,CAACG,SAAS;IACjC,IAAI,CAACC,mBAAmB,GAAGJ,MAAM,CAACK,kBAAkB;IAEpD,IAAAC,oBAAc,EAAC,IAAI,EAAE;MACnBC,KAAK,EAAEC,YAAM,CAACC,KAAK;MACnBC,YAAY,EAAEC,gBAAU,CAACC,GAAG;MAC5BC,YAAY,EAAEF,gBAAU,CAACC,GAAG;MAC5BE,cAAc,EAAEC;IAClB,CAAC,CAAC;IAEF,IAAI,CAACC,cAAc,GAAG,IAAI,CAACb,SAAS,CAACc,MAAM,CAACC,QAAQ,CAAC,MAAM;MACzDC,qBAAqB,CAAC,IAAI,CAACZ,KAAK,CAAC;IACnC,CAAC,EAAE,GAAG,CAAC;EACT;EAEA,IAAIO,cAAcA,CAAA,EAAG;IACnB,OAAO,IAAI,CAACJ,YAAY,GAAG,IAAI,CAACG,YAAY;EAC9C;EAEAN,KAAKA,CAAA,EAAG;IACN,MAAM;MAAEa;IAAS,CAAC,GAAG,IAAI;IAEzB,IAAI,CAACA,QAAQ,EAAE;MACb;IACF;IAEA,IAAI,CAACP,YAAY,GAAGO,QAAQ,CAACC,WAAW;IACxC,IAAI,CAACX,YAAY,GAAGU,QAAQ,CAACE,WAAW;EAC1C;EAEAC,IAAIA,CAAA,EAAG;IACL,MAAM;MAAEH,QAAQ;MAAEhB;IAAoB,CAAC,GAAG,IAAI;IAE9C,IAAIA,mBAAmB,EAAE;MACvB;IACF;IAEA,IAAI,CAACgB,QAAQ,EAAE;MACb;IACF;IAEA,IAAI,CAACJ,cAAc,CAAC,CAAC;IAErB,MAAMQ,SAAS,GAAG,CAAC,IAAAC,0BAAiB,EAACL,QAAQ,EAAE,IAAI,CAACJ,cAAc,CAAC,CAAC;IAEpE,OAAO,MAAM;MACXQ,SAAS,CAACE,OAAO,CAAEC,CAAC,IAAKA,CAAC,oBAADA,CAAC,CAAG,CAAC,CAAC;IACjC,CAAC;EACH;AACF;AAACC,OAAA,CAAA9B,uBAAA,GAAAA,uBAAA","ignoreList":[]}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
exports.__esModule = true;
|
|
5
|
+
exports.HorizontalSpaceAvailableState = void 0;
|
|
6
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
7
|
+
var _mobx = require("mobx");
|
|
8
|
+
var _bexCore = require("@wix/bex-core");
|
|
9
|
+
class HorizontalSpaceAvailableState {
|
|
10
|
+
constructor(params) {
|
|
11
|
+
(0, _defineProperty2.default)(this, "_syncThrottled", void 0);
|
|
12
|
+
(0, _defineProperty2.default)(this, "container", void 0);
|
|
13
|
+
(0, _defineProperty2.default)(this, "_responsiveDisabled", void 0);
|
|
14
|
+
(0, _defineProperty2.default)(this, "_element", void 0);
|
|
15
|
+
(0, _defineProperty2.default)(this, "_child", void 0);
|
|
16
|
+
(0, _defineProperty2.default)(this, "_directChildClientWidth", 0);
|
|
17
|
+
(0, _defineProperty2.default)(this, "_clientWidth", 0);
|
|
18
|
+
this.container = params.container;
|
|
19
|
+
this._responsiveDisabled = params.responsiveDisabled;
|
|
20
|
+
(0, _mobx.makeObservable)(this, {
|
|
21
|
+
_sync: _mobx.action.bound,
|
|
22
|
+
_directChildClientWidth: _mobx.observable.ref,
|
|
23
|
+
_clientWidth: _mobx.observable.ref,
|
|
24
|
+
available: _mobx.computed
|
|
25
|
+
});
|
|
26
|
+
this._syncThrottled = this.container.lodash.throttle(() => {
|
|
27
|
+
requestAnimationFrame(this._sync);
|
|
28
|
+
}, 200);
|
|
29
|
+
}
|
|
30
|
+
_sync() {
|
|
31
|
+
const {
|
|
32
|
+
_element,
|
|
33
|
+
_child
|
|
34
|
+
} = this;
|
|
35
|
+
if (!_element || !_child) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
this._clientWidth = _element.clientWidth;
|
|
39
|
+
this._directChildClientWidth = _child.scrollWidth;
|
|
40
|
+
}
|
|
41
|
+
get available() {
|
|
42
|
+
return this._clientWidth - this._directChildClientWidth;
|
|
43
|
+
}
|
|
44
|
+
init() {
|
|
45
|
+
const {
|
|
46
|
+
_element,
|
|
47
|
+
_child,
|
|
48
|
+
_responsiveDisabled
|
|
49
|
+
} = this;
|
|
50
|
+
if (_responsiveDisabled) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
if (!_element || !_child) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
this._syncThrottled();
|
|
57
|
+
const disposers = [(0, _bexCore.addResizeObserver)(_child, this._syncThrottled)];
|
|
58
|
+
return () => {
|
|
59
|
+
disposers.forEach(d => d == null ? void 0 : d());
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
exports.HorizontalSpaceAvailableState = HorizontalSpaceAvailableState;
|
|
64
|
+
//# sourceMappingURL=HorizontalSpaceAvailableState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_mobx","require","_bexCore","HorizontalSpaceAvailableState","constructor","params","_defineProperty2","default","container","_responsiveDisabled","responsiveDisabled","makeObservable","_sync","action","bound","_directChildClientWidth","observable","ref","_clientWidth","available","computed","_syncThrottled","lodash","throttle","requestAnimationFrame","_element","_child","clientWidth","scrollWidth","init","disposers","addResizeObserver","forEach","d","exports"],"sources":["../../../../src/state/Responsive/HorizontalSpaceAvailableState.ts"],"sourcesContent":["import { action, computed, makeObservable, observable } from 'mobx';\nimport { addResizeObserver, WixPatternsContainer } from '@wix/bex-core';\n\nexport interface HorizontalSpaceAvailableStateParams {\n container: WixPatternsContainer;\n responsiveDisabled: boolean | undefined;\n}\n\nexport class HorizontalSpaceAvailableState {\n readonly _syncThrottled;\n\n readonly container;\n readonly _responsiveDisabled;\n\n _element?: Element | null | undefined;\n _child?: Element | null | undefined;\n\n _directChildClientWidth = 0;\n _clientWidth = 0;\n\n constructor(params: HorizontalSpaceAvailableStateParams) {\n this.container = params.container;\n this._responsiveDisabled = params.responsiveDisabled;\n\n makeObservable(this, {\n _sync: action.bound,\n _directChildClientWidth: observable.ref,\n _clientWidth: observable.ref,\n available: computed,\n });\n\n this._syncThrottled = this.container.lodash.throttle(() => {\n requestAnimationFrame(this._sync);\n }, 200);\n }\n\n _sync() {\n const { _element, _child } = this;\n\n if (!_element || !_child) {\n return;\n }\n\n this._clientWidth = _element.clientWidth;\n this._directChildClientWidth = _child.scrollWidth;\n }\n\n get available() {\n return this._clientWidth - this._directChildClientWidth;\n }\n\n init() {\n const { _element, _child, _responsiveDisabled } = this;\n\n if (_responsiveDisabled) {\n return;\n }\n\n if (!_element || !_child) {\n return;\n }\n\n this._syncThrottled();\n\n const disposers = [addResizeObserver(_child, this._syncThrottled)];\n\n return () => {\n disposers.forEach((d) => d?.());\n };\n }\n}\n"],"mappings":";;;;;;AAAA,IAAAA,KAAA,GAAAC,OAAA;AACA,IAAAC,QAAA,GAAAD,OAAA;AAOO,MAAME,6BAA6B,CAAC;EAYzCC,WAAWA,CAACC,MAA2C,EAAE;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,mCAH/B,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,wBACZ,CAAC;IAGd,IAAI,CAACC,SAAS,GAAGH,MAAM,CAACG,SAAS;IACjC,IAAI,CAACC,mBAAmB,GAAGJ,MAAM,CAACK,kBAAkB;IAEpD,IAAAC,oBAAc,EAAC,IAAI,EAAE;MACnBC,KAAK,EAAEC,YAAM,CAACC,KAAK;MACnBC,uBAAuB,EAAEC,gBAAU,CAACC,GAAG;MACvCC,YAAY,EAAEF,gBAAU,CAACC,GAAG;MAC5BE,SAAS,EAAEC;IACb,CAAC,CAAC;IAEF,IAAI,CAACC,cAAc,GAAG,IAAI,CAACb,SAAS,CAACc,MAAM,CAACC,QAAQ,CAAC,MAAM;MACzDC,qBAAqB,CAAC,IAAI,CAACZ,KAAK,CAAC;IACnC,CAAC,EAAE,GAAG,CAAC;EACT;EAEAA,KAAKA,CAAA,EAAG;IACN,MAAM;MAAEa,QAAQ;MAAEC;IAAO,CAAC,GAAG,IAAI;IAEjC,IAAI,CAACD,QAAQ,IAAI,CAACC,MAAM,EAAE;MACxB;IACF;IAEA,IAAI,CAACR,YAAY,GAAGO,QAAQ,CAACE,WAAW;IACxC,IAAI,CAACZ,uBAAuB,GAAGW,MAAM,CAACE,WAAW;EACnD;EAEA,IAAIT,SAASA,CAAA,EAAG;IACd,OAAO,IAAI,CAACD,YAAY,GAAG,IAAI,CAACH,uBAAuB;EACzD;EAEAc,IAAIA,CAAA,EAAG;IACL,MAAM;MAAEJ,QAAQ;MAAEC,MAAM;MAAEjB;IAAoB,CAAC,GAAG,IAAI;IAEtD,IAAIA,mBAAmB,EAAE;MACvB;IACF;IAEA,IAAI,CAACgB,QAAQ,IAAI,CAACC,MAAM,EAAE;MACxB;IACF;IAEA,IAAI,CAACL,cAAc,CAAC,CAAC;IAErB,MAAMS,SAAS,GAAG,CAAC,IAAAC,0BAAiB,EAACL,MAAM,EAAE,IAAI,CAACL,cAAc,CAAC,CAAC;IAElE,OAAO,MAAM;MACXS,SAAS,CAACE,OAAO,CAAEC,CAAC,IAAKA,CAAC,oBAADA,CAAC,CAAG,CAAC,CAAC;IACjC,CAAC;EACH;AACF;AAACC,OAAA,CAAA/B,6BAAA,GAAAA,6BAAA","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_bexCore","require","_mobx","_SettingsPageStateBIReporter","_events","SettingsPageState","constructor","params","_defineProperty2","default","EventEmitter","fetch","_onSave","onSave","_onCancel","onCancel","saveSuccessToast","saveErrorToast","formPage","FormPageState","form","container","reportBI","createBILogger","componentType","pageType","route","window","location","pathname","bi","SettingsPageStateBIReporter","settingsPageState","init","makeObservable","handleSubmit","action","_settings","observable","ref","setSettings","isDirty","computed","initTask","onBeforeUnload","onBeforeUnloadSubscription","event","preventDefault","reportOnBeforeUnload","runOnce","_this$bi$appLoaded","_this$bi","data","Promise","all","status","promise","settings","appLoaded","call","remove","retryFetch","newSettings","isFetching","reportButtonClick","ctaName","_showErrorToast","err","e","_this$saveErrorToast","_this$container$showT","_this$container","errorToast","retry","message","showTryAgain","tryAgain","undefined","showToast","type","biName","translate","code","uiType","text","onClick","reportSaveTryAgain","removeToastOnClick","_showSuccessToast","_this$saveSuccessToas","_this$container$showT2","_this$container2","submitTask","isLoading","events","emit","run","isValid","reset","getValues","errorMonitor","captureException","setError","exports"],"sources":["../../../../src/state/SettingsPage/SettingsPageState.ts"],"sourcesContent":["import { FormPageState, ReportBI, WixPatternsContainer } from '@wix/bex-core';\nimport { action, computed, makeObservable, observable } from 'mobx';\nimport { FieldValues } from 'react-hook-form';\nimport { SettingsPageStateBIReporter } from './SettingsPageStateBIReporter';\nimport { EventEmitter, TypedEmitter } from '@wix/bex-core/events';\n\nexport interface SettingsPageStateParams<\n T,\n V extends FieldValues = FieldValues,\n> {\n /**\n * A function that fetches the settings data.\n * @returns a promise that resolves to an object containing the settings.\n */\n fetch: () => Promise<{ settings: T | undefined }>;\n\n /**\n * A function to handle the save action.\n */\n onSave: () => Promise<void>;\n\n /**\n * A function to handle the cancel action.\n */\n onCancel: () => Promise<void>;\n\n /**\n * An optional object with an optional message, or it can directly get a string message.\n */\n saveSuccessToast?: { message?: string } | string;\n\n /**\n * An optional function to display an error toast message when a save operation fails.\n * @returns An object with a `message` and an `action` object. Alternatively, it can return an object with an optional `message` and a `tryAgain` flag, or a string message.\n * The previous return types are still supported but are now deprecated.\n */\n saveErrorToast?: (\n err: unknown,\n params: { retry: () => void },\n ) =>\n | {\n message?: string;\n /**\n * @deprecated use `action` instead\n */\n tryAgain?: boolean;\n action?: { text: string; onClick: () => void };\n }\n | string;\n\n form: FormPageState<V>['form'];\n\n /**\n * An object representing the container, possibly for dependency injection or component management.\n */\n container: WixPatternsContainer;\n}\n\nexport interface SettingsPageStateInterface {}\n\nexport class SettingsPageState<T, V extends FieldValues = FieldValues>\n implements SettingsPageStateInterface\n{\n readonly fetch: SettingsPageStateParams<T>['fetch'];\n readonly _onSave: SettingsPageStateParams<T, V>['onSave'];\n readonly _onCancel: SettingsPageStateParams<T, V>['onCancel'];\n readonly saveSuccessToast?: SettingsPageStateParams<T>['saveSuccessToast'];\n readonly saveErrorToast?: SettingsPageStateParams<T>['saveErrorToast'];\n\n _settings: T | null = null;\n\n readonly container: WixPatternsContainer;\n readonly reportBI: ReportBI;\n readonly bi: SettingsPageStateBIReporter<T, V>;\n\n readonly formPage: FormPageState<V>;\n\n readonly events = new EventEmitter() as TypedEmitter<{\n save: () => void;\n saveError: (err: unknown) => void;\n }>;\n\n constructor(params: SettingsPageStateParams<T, V>) {\n this.fetch = params.fetch;\n this._onSave = params.onSave;\n this._onCancel = params.onCancel;\n this.saveSuccessToast = params.saveSuccessToast;\n this.saveErrorToast = params.saveErrorToast;\n this.formPage = new FormPageState<V>({ form: params.form });\n\n this.container = params.container;\n\n this.reportBI = this.container.createBILogger({\n componentType: 'Settings page',\n pageType: 'Settings',\n route: window.location.pathname,\n });\n\n this.bi = new SettingsPageStateBIReporter({\n reportBI: this.reportBI,\n settingsPageState: this,\n });\n\n this.bi.init();\n\n makeObservable(this, {\n handleSubmit: action,\n _settings: observable.ref,\n setSettings: action,\n isDirty: computed,\n });\n }\n\n init() {\n const {\n formPage: { initTask },\n container,\n } = this;\n const { onBeforeUnload } = container;\n\n const onBeforeUnloadSubscription = onBeforeUnload?.(\n action((event) => {\n if (!this.isDirty) {\n return;\n }\n event.preventDefault();\n this.bi.reportOnBeforeUnload();\n }),\n );\n\n initTask.runOnce(async () => {\n const [data] = await Promise.all([\n this.fetch(),\n container.initTask.status.promise,\n ]);\n\n this.setSettings(data.settings ?? null);\n this.bi.appLoaded?.();\n });\n\n return () => {\n onBeforeUnloadSubscription?.remove();\n };\n }\n\n retryFetch() {\n this.formPage.retryFetch();\n }\n\n setSettings(newSettings: T | null) {\n this._settings = newSettings;\n }\n\n get settings(): T | null {\n return this._settings;\n }\n\n get isFetching() {\n return this.formPage.isFetching;\n }\n\n get form() {\n return this.formPage.form;\n }\n\n get isDirty() {\n return this.formPage.isDirty;\n }\n\n onCancel() {\n this.bi.reportButtonClick({ ctaName: 'Cancel' });\n this._onCancel();\n }\n\n _showErrorToast(err: any, e?: React.BaseSyntheticEvent) {\n const errorToast = this.saveErrorToast?.(err, {\n retry: () => this.handleSubmit(e),\n });\n const message =\n typeof errorToast === 'string' ? errorToast : errorToast?.message;\n const showTryAgain =\n typeof errorToast === 'string' ? true : errorToast?.tryAgain !== false;\n const action =\n typeof errorToast === 'string' ? undefined : errorToast?.action;\n\n this.container.showToast?.({\n type: 'ERROR',\n biName: 'cairo-settings-page-save-error-toast',\n message:\n message ??\n this.container.translate(\n err?.code === 'ERR_NETWORK'\n ? 'cairo.entityPage.saveError-offline.toast.description'\n : 'cairo.entityPage.saveError-technical.toast.description',\n ),\n action:\n action || showTryAgain\n ? {\n uiType: 'LINK',\n text:\n action?.text ?? this.container.translate('cairo.toast.retry'),\n onClick: () => {\n if (action?.onClick) {\n action.onClick();\n } else {\n this.bi.reportSaveTryAgain();\n this.handleSubmit(e);\n }\n },\n removeToastOnClick: true,\n }\n : undefined,\n });\n }\n\n _showSuccessToast() {\n const message =\n typeof this.saveSuccessToast === 'string'\n ? this.saveSuccessToast\n : this.saveSuccessToast?.message;\n\n this.container.showToast?.({\n type: 'SUCCESS',\n biName: 'cairo-settings-page-save-success-toast',\n message:\n message ?? this.container.translate('cairo.entityPage.success.toast'),\n });\n }\n\n async handleSubmit(e?: React.BaseSyntheticEvent) {\n if (this.formPage.submitTask.status.isLoading) {\n return;\n }\n\n this.events.emit('save');\n\n const {\n form,\n formPage: { submitTask },\n bi,\n } = this;\n\n submitTask.run(async () => {\n await form.handleSubmit(\n async () => {\n bi.reportButtonClick({ ctaName: 'Save', isValid: true });\n try {\n if (!this.isFetching) {\n await this._onSave();\n form.reset(form.getValues());\n }\n this._showSuccessToast();\n } catch (err) {\n this._showErrorToast(err, e);\n this.container.errorMonitor.captureException(err);\n this.events.emit('saveError', err);\n form.setError('root.serverError', {}); // https://react-hook-form.com/docs/useform/seterror\n }\n },\n () => {\n bi.reportButtonClick({ ctaName: 'Save', isValid: false });\n }, // can be used to report validation errors\n )(e);\n });\n\n await this.formPage.submitTask.status.promise;\n }\n\n get initTask() {\n return this.formPage.initTask;\n }\n\n get submitTask() {\n return this.formPage.submitTask;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_bexCore","require","_mobx","_SettingsPageStateBIReporter","_events","SettingsPageState","constructor","params","_defineProperty2","default","EventEmitter","fetch","_onSave","onSave","_onCancel","onCancel","saveSuccessToast","saveErrorToast","formPage","FormPageState","form","container","reportBI","createBILogger","componentType","pageType","route","window","location","pathname","bi","SettingsPageStateBIReporter","settingsPageState","init","makeObservable","handleSubmit","action","_settings","observable","ref","setSettings","isDirty","computed","initTask","onBeforeUnload","onBeforeUnloadSubscription","event","preventDefault","reportOnBeforeUnload","runOnce","_this$bi$appLoaded","_this$bi","data","Promise","all","status","promise","settings","appLoaded","call","remove","retryFetch","newSettings","isFetching","reportButtonClick","ctaName","_showErrorToast","err","e","_this$saveErrorToast","_this$container$showT","_this$container","errorToast","retry","message","showTryAgain","tryAgain","undefined","showToast","type","biName","translate","code","uiType","text","onClick","reportSaveTryAgain","removeToastOnClick","_showSuccessToast","_this$saveSuccessToas","_this$container$showT2","_this$container2","submitTask","isLoading","events","emit","run","isValid","reset","getValues","errorMonitor","captureException","setError","exports"],"sources":["../../../../src/state/SettingsPage/SettingsPageState.ts"],"sourcesContent":["import { FormPageState, ReportBI, WixPatternsContainer } from '@wix/bex-core';\nimport { action, computed, makeObservable, observable } from 'mobx';\nimport { FieldValues } from 'react-hook-form';\nimport { SettingsPageStateBIReporter } from './SettingsPageStateBIReporter';\nimport { EventEmitter, TypedEmitter } from '@wix/bex-core/events';\n\nexport interface SettingsPageStateParams<\n T,\n V extends FieldValues = FieldValues,\n> {\n /**\n * A function that fetches the settings data.\n * @returns a promise that resolves to an object containing the settings.\n */\n fetch: () => Promise<{ settings: T | undefined }>;\n\n /**\n * A function to handle the save action.\n */\n onSave: () => Promise<void>;\n\n /**\n * A function to handle the cancel action.\n */\n onCancel: () => Promise<void>;\n\n /**\n * An optional object with an optional message, or it can directly get a string message.\n */\n saveSuccessToast?: { message?: string } | string;\n\n /**\n * An optional function to display an error toast message when a save operation fails.\n * @returns An object with a `message` and an `action` object. Alternatively, it can return an object with an optional `message` and a `tryAgain` flag, or a string message.\n * The previous return types are still supported but are now deprecated.\n */\n saveErrorToast?: (\n err: unknown,\n params: { retry: () => void },\n ) =>\n | {\n message?: string;\n /**\n * @deprecated use `action` instead\n */\n tryAgain?: boolean;\n action?: { text: string; onClick: () => void };\n }\n | string;\n\n form: FormPageState<V>['form'];\n\n /**\n * An object representing the container, possibly for dependency injection or component management.\n */\n container: WixPatternsContainer;\n}\n\nexport interface SettingsPageStateInterface {}\n\nexport class SettingsPageState<T, V extends FieldValues = FieldValues>\n implements SettingsPageStateInterface\n{\n readonly fetch: SettingsPageStateParams<T>['fetch'];\n readonly _onSave: SettingsPageStateParams<T, V>['onSave'];\n readonly _onCancel: SettingsPageStateParams<T, V>['onCancel'];\n readonly saveSuccessToast?: SettingsPageStateParams<T>['saveSuccessToast'];\n readonly saveErrorToast?: SettingsPageStateParams<T>['saveErrorToast'];\n\n _settings: T | null = null;\n\n readonly container: WixPatternsContainer;\n readonly reportBI: ReportBI;\n readonly bi: SettingsPageStateBIReporter<T, V>;\n\n readonly formPage: FormPageState<V>;\n\n readonly events = new EventEmitter() as TypedEmitter<{\n save: () => void;\n saveError: (err: unknown) => void;\n }>;\n\n constructor(params: SettingsPageStateParams<T, V>) {\n this.fetch = params.fetch;\n this._onSave = params.onSave;\n this._onCancel = params.onCancel;\n this.saveSuccessToast = params.saveSuccessToast;\n this.saveErrorToast = params.saveErrorToast;\n this.formPage = new FormPageState<V>({ form: params.form });\n\n this.container = params.container;\n\n this.reportBI = this.container.createBILogger({\n componentType: 'Settings page',\n pageType: 'Settings',\n route: window.location.pathname,\n });\n\n this.bi = new SettingsPageStateBIReporter({\n reportBI: this.reportBI,\n settingsPageState: this,\n });\n\n this.bi.init();\n\n makeObservable(this, {\n handleSubmit: action,\n _settings: observable.ref,\n setSettings: action,\n isDirty: computed,\n });\n }\n\n init() {\n const {\n formPage: { initTask },\n container,\n } = this;\n const { onBeforeUnload } = container;\n\n const onBeforeUnloadSubscription = onBeforeUnload?.(\n action((event: Event) => {\n if (!this.isDirty) {\n return;\n }\n event.preventDefault();\n this.bi.reportOnBeforeUnload();\n }),\n );\n\n initTask.runOnce(async () => {\n const [data] = await Promise.all([\n this.fetch(),\n container.initTask.status.promise,\n ]);\n\n this.setSettings(data.settings ?? null);\n this.bi.appLoaded?.();\n });\n\n return () => {\n onBeforeUnloadSubscription?.remove();\n };\n }\n\n retryFetch() {\n this.formPage.retryFetch();\n }\n\n setSettings(newSettings: T | null) {\n this._settings = newSettings;\n }\n\n get settings(): T | null {\n return this._settings;\n }\n\n get isFetching() {\n return this.formPage.isFetching;\n }\n\n get form() {\n return this.formPage.form;\n }\n\n get isDirty() {\n return this.formPage.isDirty;\n }\n\n onCancel() {\n this.bi.reportButtonClick({ ctaName: 'Cancel' });\n this._onCancel();\n }\n\n _showErrorToast(err: any, e?: React.BaseSyntheticEvent) {\n const errorToast = this.saveErrorToast?.(err, {\n retry: () => this.handleSubmit(e),\n });\n const message =\n typeof errorToast === 'string' ? errorToast : errorToast?.message;\n const showTryAgain =\n typeof errorToast === 'string' ? true : errorToast?.tryAgain !== false;\n const action =\n typeof errorToast === 'string' ? undefined : errorToast?.action;\n\n this.container.showToast?.({\n type: 'ERROR',\n biName: 'cairo-settings-page-save-error-toast',\n message:\n message ??\n this.container.translate(\n err?.code === 'ERR_NETWORK'\n ? 'cairo.entityPage.saveError-offline.toast.description'\n : 'cairo.entityPage.saveError-technical.toast.description',\n ),\n action:\n action || showTryAgain\n ? {\n uiType: 'LINK',\n text:\n action?.text ?? this.container.translate('cairo.toast.retry'),\n onClick: () => {\n if (action?.onClick) {\n action.onClick();\n } else {\n this.bi.reportSaveTryAgain();\n this.handleSubmit(e);\n }\n },\n removeToastOnClick: true,\n }\n : undefined,\n });\n }\n\n _showSuccessToast() {\n const message =\n typeof this.saveSuccessToast === 'string'\n ? this.saveSuccessToast\n : this.saveSuccessToast?.message;\n\n this.container.showToast?.({\n type: 'SUCCESS',\n biName: 'cairo-settings-page-save-success-toast',\n message:\n message ?? this.container.translate('cairo.entityPage.success.toast'),\n });\n }\n\n async handleSubmit(e?: React.BaseSyntheticEvent) {\n if (this.formPage.submitTask.status.isLoading) {\n return;\n }\n\n this.events.emit('save');\n\n const {\n form,\n formPage: { submitTask },\n bi,\n } = this;\n\n submitTask.run(async () => {\n await form.handleSubmit(\n async () => {\n bi.reportButtonClick({ ctaName: 'Save', isValid: true });\n try {\n if (!this.isFetching) {\n await this._onSave();\n form.reset(form.getValues());\n }\n this._showSuccessToast();\n } catch (err) {\n this._showErrorToast(err, e);\n this.container.errorMonitor.captureException(err);\n this.events.emit('saveError', err);\n form.setError('root.serverError', {}); // https://react-hook-form.com/docs/useform/seterror\n }\n },\n () => {\n bi.reportButtonClick({ ctaName: 'Save', isValid: false });\n }, // can be used to report validation errors\n )(e);\n });\n\n await this.formPage.submitTask.status.promise;\n }\n\n get initTask() {\n return this.formPage.initTask;\n }\n\n get submitTask() {\n return this.formPage.submitTask;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -127,51 +127,85 @@ class TagsBulkAssignAsyncState {
|
|
|
127
127
|
throw new Error('tried to bulk assign tags async without asyncBulkUpdateTags prop given');
|
|
128
128
|
}
|
|
129
129
|
this.currentInvocationParams = params;
|
|
130
|
-
const {
|
|
131
|
-
jobId
|
|
132
|
-
} = await this.asyncBulkUpdateTags(params);
|
|
133
|
-
this.asyncJobProgressModalState.modal.open();
|
|
134
|
-
await this.pollJobStatus(jobId);
|
|
135
|
-
}
|
|
136
|
-
async pollJobStatus(jobId) {
|
|
137
130
|
try {
|
|
131
|
+
this.asyncJobProgressModalState.modal.open();
|
|
138
132
|
const {
|
|
139
|
-
data: {
|
|
140
|
-
job
|
|
141
|
-
}
|
|
142
|
-
} = await this.container.httpClient.request((0, _http.getAsyncJob)({
|
|
143
133
|
jobId
|
|
144
|
-
})
|
|
145
|
-
|
|
146
|
-
this.job = job;
|
|
147
|
-
});
|
|
134
|
+
} = await this.asyncBulkUpdateTags(params);
|
|
135
|
+
await this.pollJobStatus(jobId);
|
|
148
136
|
} catch (error) {
|
|
149
|
-
|
|
137
|
+
this.showFailToCreateJobToast(error);
|
|
138
|
+
this.resetStateParams();
|
|
150
139
|
}
|
|
140
|
+
}
|
|
141
|
+
async pollJobStatus(jobId) {
|
|
142
|
+
const job = await this.fetchJobStatus(jobId);
|
|
151
143
|
(0, _mobx.runInAction)(() => {
|
|
144
|
+
this.job = job;
|
|
152
145
|
if (this.isJobInProgress) {
|
|
153
|
-
this.
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
return;
|
|
157
|
-
}
|
|
158
|
-
if (this.isJobEnded) {
|
|
159
|
-
this.timeout = setTimeout(() => {
|
|
160
|
-
(0, _mobx.runInAction)(() => this.handleJobEnd());
|
|
161
|
-
}, MILLIS_FOR_SHOWING_SUCCESS);
|
|
146
|
+
this.scheduleNextPoll(jobId);
|
|
147
|
+
} else if (this.isJobEnded) {
|
|
148
|
+
this.handleJobEnd();
|
|
162
149
|
}
|
|
163
150
|
});
|
|
164
151
|
}
|
|
152
|
+
async fetchJobStatus(jobId) {
|
|
153
|
+
try {
|
|
154
|
+
const job = await this.container.errorHandler.withErrorHandler(async () => {
|
|
155
|
+
const {
|
|
156
|
+
data: {
|
|
157
|
+
job
|
|
158
|
+
}
|
|
159
|
+
} = await this.container.httpClient.request((0, _http.getAsyncJob)({
|
|
160
|
+
jobId
|
|
161
|
+
}));
|
|
162
|
+
return job;
|
|
163
|
+
}, {
|
|
164
|
+
errorCodesMap: {}
|
|
165
|
+
});
|
|
166
|
+
return job;
|
|
167
|
+
} catch (error) {
|
|
168
|
+
this.asyncJobProgressModalState.modal.close();
|
|
169
|
+
this.showFailedToPollToast(error);
|
|
170
|
+
this.resetStateParams();
|
|
171
|
+
return null;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
scheduleNextPoll(jobId) {
|
|
175
|
+
this.timeout = setTimeout(() => {
|
|
176
|
+
(0, _mobx.runInAction)(() => this.pollJobStatus(jobId));
|
|
177
|
+
}, POLL_DELAY);
|
|
178
|
+
}
|
|
165
179
|
handleJobEnd() {
|
|
180
|
+
this.timeout = setTimeout(() => {
|
|
181
|
+
(0, _mobx.runInAction)(() => {
|
|
182
|
+
this.handleJobCompletion();
|
|
183
|
+
});
|
|
184
|
+
}, MILLIS_FOR_SHOWING_SUCCESS);
|
|
185
|
+
}
|
|
186
|
+
handleJobCompletion() {
|
|
166
187
|
const lastInvocationParams = this.currentInvocationParams;
|
|
188
|
+
const {
|
|
189
|
+
showToast,
|
|
190
|
+
translate: t
|
|
191
|
+
} = this.container;
|
|
167
192
|
if (this.isJobCompleted) {
|
|
168
193
|
this.handleJobSuccess(lastInvocationParams);
|
|
194
|
+
} else if (this.isJobFailed) {
|
|
195
|
+
var _this$job;
|
|
196
|
+
showToast == null || showToast({
|
|
197
|
+
type: 'ERROR',
|
|
198
|
+
message: t('cairo.tags.bulkItemUpdate.toast.error', {
|
|
199
|
+
total: (_this$job = this.job) == null || (_this$job = _this$job.counts) == null ? void 0 : _this$job.failCount
|
|
200
|
+
}),
|
|
201
|
+
biName: 'cairo-update-bulk-assign-tags-async-job-status-fail'
|
|
202
|
+
});
|
|
169
203
|
}
|
|
170
204
|
this.resetStateParams();
|
|
171
205
|
}
|
|
172
206
|
handleJobSuccess(lastInvocationParams) {
|
|
173
|
-
var _this$
|
|
174
|
-
const failCount = (_this$
|
|
207
|
+
var _this$job2;
|
|
208
|
+
const failCount = (_this$job2 = this.job) == null || (_this$job2 = _this$job2.counts) == null ? void 0 : _this$job2.failCount;
|
|
175
209
|
if (failCount) {
|
|
176
210
|
this.showPartialFailureToast({
|
|
177
211
|
failCount,
|
|
@@ -220,34 +254,63 @@ class TagsBulkAssignAsyncState {
|
|
|
220
254
|
biName: 'cairo-update-bulk-assign-tags-async-success'
|
|
221
255
|
});
|
|
222
256
|
}
|
|
257
|
+
showFailToCreateJobToast(error) {
|
|
258
|
+
const {
|
|
259
|
+
errorHandler,
|
|
260
|
+
showToast,
|
|
261
|
+
translate: t
|
|
262
|
+
} = this.container;
|
|
263
|
+
const resolvedError = errorHandler == null || errorHandler.getResolvedError == null ? void 0 : errorHandler.getResolvedError(error);
|
|
264
|
+
showToast == null || showToast({
|
|
265
|
+
type: 'ERROR',
|
|
266
|
+
message: (resolvedError == null ? void 0 : resolvedError.message) ?? t('cairo.tags.bulkItemUpdate.toast.error', {
|
|
267
|
+
total: this.collectionState.bulkSelect.selectedCountOrTotal
|
|
268
|
+
}),
|
|
269
|
+
action: resolvedError == null ? void 0 : resolvedError.action,
|
|
270
|
+
biName: 'cairo-update-bulk-assign-tags-async-create-job-fail'
|
|
271
|
+
});
|
|
272
|
+
}
|
|
273
|
+
showFailedToPollToast(error) {
|
|
274
|
+
const {
|
|
275
|
+
errorHandler,
|
|
276
|
+
showToast
|
|
277
|
+
} = this.container;
|
|
278
|
+
const resolvedError = errorHandler == null || errorHandler.getResolvedError == null ? void 0 : errorHandler.getResolvedError(error);
|
|
279
|
+
showToast == null || showToast({
|
|
280
|
+
type: 'ERROR',
|
|
281
|
+
message: resolvedError == null ? void 0 : resolvedError.message,
|
|
282
|
+
action: resolvedError == null ? void 0 : resolvedError.action,
|
|
283
|
+
biName: 'cairo-update-bulk-assign-tags-async-poll-fail'
|
|
284
|
+
});
|
|
285
|
+
}
|
|
223
286
|
refreshCollection() {
|
|
224
287
|
this.collectionState.refreshAllPages();
|
|
225
288
|
}
|
|
226
289
|
get isJobCompleted() {
|
|
227
|
-
var _this$
|
|
228
|
-
return ((_this$
|
|
290
|
+
var _this$job3;
|
|
291
|
+
return ((_this$job3 = this.job) == null ? void 0 : _this$job3.status) === 'FINISHED';
|
|
229
292
|
}
|
|
230
293
|
get isJobFailed() {
|
|
231
|
-
var _this$
|
|
232
|
-
return ((_this$
|
|
294
|
+
var _this$job4;
|
|
295
|
+
return ((_this$job4 = this.job) == null ? void 0 : _this$job4.status) === 'FAILED';
|
|
233
296
|
}
|
|
234
297
|
get isJobEnded() {
|
|
235
298
|
return this.isJobCompleted || this.isJobFailed;
|
|
236
299
|
}
|
|
237
300
|
get isJobInProgress() {
|
|
238
|
-
var _this$
|
|
239
|
-
return ((_this$
|
|
301
|
+
var _this$job5, _this$job6;
|
|
302
|
+
return ((_this$job5 = this.job) == null ? void 0 : _this$job5.status) === 'PROCESSING' || ((_this$job6 = this.job) == null ? void 0 : _this$job6.status) === 'INITIALIZED';
|
|
240
303
|
}
|
|
241
304
|
get canBulkAssignAsync() {
|
|
242
305
|
return !!this.asyncBulkUpdateTags;
|
|
243
306
|
}
|
|
244
307
|
get updatedItemsPercentage() {
|
|
245
|
-
var _this$job$counts, _this$job$counts2, _this$
|
|
308
|
+
var _this$job$counts, _this$job$counts2, _this$job7;
|
|
246
309
|
if (!this.job) {
|
|
247
310
|
return 0;
|
|
248
311
|
}
|
|
249
312
|
const alreadyUpdatedItemsCount = (((_this$job$counts = this.job.counts) == null ? void 0 : _this$job$counts.successCount) || 0) + (((_this$job$counts2 = this.job.counts) == null ? void 0 : _this$job$counts2.failCount) || 0);
|
|
250
|
-
const totalUpdatingItemsCount = ((_this$
|
|
313
|
+
const totalUpdatingItemsCount = ((_this$job7 = this.job) == null || (_this$job7 = _this$job7.counts) == null ? void 0 : _this$job7.total) || this.collectionState.bulkSelect.selectedCountOrTotal;
|
|
251
314
|
return Math.floor(100 * (alreadyUpdatedItemsCount / totalUpdatingItemsCount));
|
|
252
315
|
}
|
|
253
316
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_bexCore","require","_mobx","_http","POLL_DELAY","exports","MILLIS_FOR_SHOWING_SUCCESS","TagsBulkAssignAsyncState","constructor","params","_defineProperty2","default","ConditionalModalState","asyncJobProgressModalState","modal","open","close","isJobInProgress","_this$container$showT","_this$container","updatingTagsToast","container","showToast","call","type","message","translate","action","text","onClick","openAsyncJobProgressModal","removeToastOnClick","timeout","biName","collectionState","optimisticActions","tagsBIReporter","asyncBulkUpdateTags","makeObservable","job","observable","ref","isDuringApplyChanges","init","applyChanges","pollJobStatus","canBulkAssignAsync","computed","isJobCompleted","isJobFailed","isJobEnded","updatedItemsPercentage","onBeforeUnload","onBeforeUnloadSubscription","event","preventDefault","disposers","remove","clearTimeout","forEach","disposer","newAssignedTagIds","newUnassignedTagIds","bulkSelect","result","allSelected","selectedValues","uncheckedValues","query","originQuery","assignTags","privateTags","tagIds","unassignTags","triggerBulkAssign","Error","currentInvocationParams","jobId","data","httpClient","request","getAsyncJob","runInAction","error","console","setTimeout","handleJobEnd","lastInvocationParams","handleJobSuccess","resetStateParams","_this$job","failCount","counts","showPartialFailureToast","showJobCompletedSuccessfullyToast","refreshCollection","_this$updatingTagsToa","closeAsyncJobProgressModal","_this$container$showT2","_this$container2","total","_this$container$showT3","_this$container3","refreshAllPages","_this$job2","status","_this$job3","_this$job4","_this$job5","_this$job$counts","_this$job$counts2","_this$job6","alreadyUpdatedItemsCount","successCount","totalUpdatingItemsCount","selectedCountOrTotal","Math","floor"],"sources":["../../../src/state/TagsBulkAssignAsyncState.ts"],"sourcesContent":["import {\n ConditionalModalState,\n FiltersMap,\n ShowToast,\n Tags,\n} from '@wix/bex-core';\n\nimport {\n TagsBulkAssignPopoverState,\n TagsBulkAssignPopoverStateParams,\n} from './TagsBulkAssignPopoverState';\nimport { BulkActionModalRenderPropParams } from '../components/BulkAction';\nimport {\n computed,\n makeObservable,\n observable,\n runInAction,\n action,\n} from 'mobx';\nimport { getAsyncJob } from '@wix/bex-utils/@wix/ambassador-infra-asyncjobs-v1-async-job/http';\nimport { AsyncJob } from '@wix/bex-utils/@wix/ambassador-infra-asyncjobs-v1-async-job/types';\n\nexport const POLL_DELAY = 500;\nexport const MILLIS_FOR_SHOWING_SUCCESS = 1000;\nexport interface AsyncBulkUpdateTagsParams<T, F extends FiltersMap>\n extends Pick<\n BulkActionModalRenderPropParams<T, F>,\n 'allSelected' | 'selectedValues' | 'uncheckedValues' | 'query'\n > {\n assignTags: Tags;\n unassignTags: Tags;\n}\n\nexport interface TagsBulkAssignAsyncStateParams<T, F extends FiltersMap>\n extends Pick<\n TagsBulkAssignPopoverStateParams<T, F>,\n 'asyncBulkUpdateTags' | 'collectionState'\n > {\n container: TagsBulkAssignPopoverState<T, F>['container'];\n optimisticActions: TagsBulkAssignPopoverState<T, F>['optimisticActions'];\n tagsBIReporter: TagsBulkAssignPopoverState<T, F>['tagsBIReporter'];\n}\n\nexport class TagsBulkAssignAsyncState<T, F extends FiltersMap> {\n readonly collectionState;\n readonly optimisticActions;\n readonly container;\n readonly tagsBIReporter;\n readonly asyncBulkUpdateTags;\n readonly asyncJobProgressModalState = new ConditionalModalState();\n\n job: AsyncJob | null = null;\n timeout: NodeJS.Timeout | null = null;\n isDuringApplyChanges = false;\n currentInvocationParams: AsyncBulkUpdateTagsParams<T, F> | null = null;\n updatingTagsToast: ReturnType<ShowToast> | null = null;\n\n constructor(params: TagsBulkAssignAsyncStateParams<T, F>) {\n const {\n collectionState,\n optimisticActions,\n container,\n tagsBIReporter,\n asyncBulkUpdateTags,\n } = params;\n this.collectionState = collectionState;\n this.optimisticActions = optimisticActions;\n this.container = container;\n this.tagsBIReporter = tagsBIReporter;\n this.asyncBulkUpdateTags = asyncBulkUpdateTags;\n\n makeObservable(this, {\n job: observable.ref,\n isDuringApplyChanges: observable,\n init: action,\n applyChanges: action,\n pollJobStatus: action,\n canBulkAssignAsync: computed,\n isJobCompleted: computed,\n isJobFailed: computed,\n isJobEnded: computed,\n isJobInProgress: computed,\n updatedItemsPercentage: computed,\n });\n }\n\n init() {\n const { onBeforeUnload } = this.container;\n const onBeforeUnloadSubscription = onBeforeUnload?.(\n action((event) => {\n if (this.isDuringApplyChanges) {\n event.preventDefault();\n }\n }),\n );\n const disposers = [\n () => {\n onBeforeUnloadSubscription?.remove();\n },\n () => {\n if (this.timeout) {\n clearTimeout(this.timeout);\n }\n },\n ];\n\n return () => {\n disposers.forEach((disposer) => disposer());\n };\n }\n\n async applyChanges({\n newAssignedTagIds,\n newUnassignedTagIds,\n }: {\n newAssignedTagIds: string[];\n newUnassignedTagIds: string[];\n }) {\n this.isDuringApplyChanges = true;\n const { bulkSelect, result } = this.collectionState;\n const { allSelected, selectedValues, uncheckedValues } = bulkSelect;\n\n const params = {\n allSelected,\n selectedValues,\n uncheckedValues,\n query: result.originQuery,\n assignTags: { privateTags: { tagIds: newAssignedTagIds } },\n unassignTags: { privateTags: { tagIds: newUnassignedTagIds } },\n };\n\n await this.triggerBulkAssign(params);\n }\n\n async triggerBulkAssign(params: AsyncBulkUpdateTagsParams<T, F>) {\n if (!this.asyncBulkUpdateTags) {\n throw new Error(\n 'tried to bulk assign tags async without asyncBulkUpdateTags prop given',\n );\n }\n\n this.currentInvocationParams = params;\n const { jobId } = await this.asyncBulkUpdateTags(params);\n this.asyncJobProgressModalState.modal.open();\n await this.pollJobStatus(jobId);\n }\n\n async pollJobStatus(jobId: string) {\n try {\n const {\n data: { job },\n } = await this.container.httpClient.request(getAsyncJob({ jobId }));\n runInAction(() => {\n this.job = job as AsyncJob;\n });\n } catch (error) {\n console.error('failed to get job status', error);\n }\n\n runInAction(() => {\n if (this.isJobInProgress) {\n this.timeout = setTimeout(() => {\n runInAction(() => this.pollJobStatus(jobId));\n }, POLL_DELAY);\n return;\n }\n if (this.isJobEnded) {\n this.timeout = setTimeout(() => {\n runInAction(() => this.handleJobEnd());\n }, MILLIS_FOR_SHOWING_SUCCESS);\n }\n });\n }\n\n handleJobEnd() {\n const lastInvocationParams = this.currentInvocationParams;\n\n if (this.isJobCompleted) {\n this.handleJobSuccess(lastInvocationParams);\n }\n\n this.resetStateParams();\n }\n\n handleJobSuccess(\n lastInvocationParams: AsyncBulkUpdateTagsParams<T, F> | null,\n ) {\n const failCount = this.job?.counts?.failCount;\n if (failCount) {\n this.showPartialFailureToast({ failCount, lastInvocationParams });\n }\n this.showJobCompletedSuccessfullyToast();\n this.refreshCollection();\n }\n\n resetStateParams() {\n this.job = null;\n this.currentInvocationParams = null;\n this.isDuringApplyChanges = false;\n this.updatingTagsToast?.remove();\n this.updatingTagsToast = null;\n this.closeAsyncJobProgressModal();\n }\n\n showPartialFailureToast({\n failCount,\n lastInvocationParams,\n }: {\n failCount: number;\n lastInvocationParams: AsyncBulkUpdateTagsParams<T, F> | null;\n }) {\n this.container.showToast?.({\n type: 'WARNING',\n message: this.container.translate(\n 'cairo.tags.bulkItemUpdate.toast.error',\n { total: failCount },\n ),\n action: {\n text: this.container.translate(\n 'cairo.tags.bulkItemUpdate.toast.error.CTA',\n ),\n onClick: async () => {\n if (lastInvocationParams) {\n await this.triggerBulkAssign(lastInvocationParams);\n }\n },\n removeToastOnClick: true,\n },\n biName: 'cairo-update-bulk-assign-tags-async-fail',\n });\n }\n\n showJobCompletedSuccessfullyToast() {\n this.container.showToast?.({\n type: 'SUCCESS',\n message: this.container.translate(\n 'cairo.tags.bulkItemUpdate.toast.success',\n ),\n biName: 'cairo-update-bulk-assign-tags-async-success',\n });\n }\n\n refreshCollection() {\n this.collectionState.refreshAllPages();\n }\n\n openAsyncJobProgressModal = () => {\n this.asyncJobProgressModalState.modal.open();\n };\n\n closeAsyncJobProgressModal = () => {\n this.asyncJobProgressModalState.modal.close();\n if (this.isJobInProgress) {\n this.updatingTagsToast =\n this.container.showToast?.({\n type: 'STANDARD',\n message: this.container.translate(\n 'cairo.tags.bulkItemUpdate.updatingTags.toast',\n ),\n action: {\n text: this.container.translate(\n 'cairo.tags.bulkItemUpdate.updatingTags.toast.CTA',\n ),\n onClick: async () => {\n this.openAsyncJobProgressModal();\n },\n removeToastOnClick: true,\n },\n timeout: 'NONE',\n biName: 'cairo-updating-bulk-assign-tags-async',\n }) || null;\n }\n };\n\n get isJobCompleted() {\n return this.job?.status === 'FINISHED';\n }\n\n get isJobFailed() {\n return this.job?.status === 'FAILED';\n }\n\n get isJobEnded() {\n return this.isJobCompleted || this.isJobFailed;\n }\n\n get isJobInProgress() {\n return (\n this.job?.status === 'PROCESSING' || this.job?.status === 'INITIALIZED'\n );\n }\n\n get canBulkAssignAsync() {\n return !!this.asyncBulkUpdateTags;\n }\n\n get updatedItemsPercentage() {\n if (!this.job) {\n return 0;\n }\n\n const alreadyUpdatedItemsCount =\n (this.job.counts?.successCount || 0) + (this.job.counts?.failCount || 0);\n const totalUpdatingItemsCount =\n this.job?.counts?.total ||\n this.collectionState.bulkSelect.selectedCountOrTotal;\n\n return Math.floor(\n 100 * (alreadyUpdatedItemsCount / totalUpdatingItemsCount),\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_bexCore","require","_mobx","_http","POLL_DELAY","exports","MILLIS_FOR_SHOWING_SUCCESS","TagsBulkAssignAsyncState","constructor","params","_defineProperty2","default","ConditionalModalState","asyncJobProgressModalState","modal","open","close","isJobInProgress","_this$container$showT","_this$container","updatingTagsToast","container","showToast","call","type","message","translate","action","text","onClick","openAsyncJobProgressModal","removeToastOnClick","timeout","biName","collectionState","optimisticActions","tagsBIReporter","asyncBulkUpdateTags","makeObservable","job","observable","ref","isDuringApplyChanges","init","applyChanges","pollJobStatus","canBulkAssignAsync","computed","isJobCompleted","isJobFailed","isJobEnded","updatedItemsPercentage","onBeforeUnload","onBeforeUnloadSubscription","event","preventDefault","disposers","remove","clearTimeout","forEach","disposer","newAssignedTagIds","newUnassignedTagIds","bulkSelect","result","allSelected","selectedValues","uncheckedValues","query","originQuery","assignTags","privateTags","tagIds","unassignTags","triggerBulkAssign","Error","currentInvocationParams","jobId","error","showFailToCreateJobToast","resetStateParams","fetchJobStatus","runInAction","scheduleNextPoll","handleJobEnd","errorHandler","withErrorHandler","data","httpClient","request","getAsyncJob","errorCodesMap","showFailedToPollToast","setTimeout","handleJobCompletion","lastInvocationParams","t","handleJobSuccess","_this$job","total","counts","failCount","_this$job2","showPartialFailureToast","showJobCompletedSuccessfullyToast","refreshCollection","_this$updatingTagsToa","closeAsyncJobProgressModal","_this$container$showT2","_this$container2","_this$container$showT3","_this$container3","resolvedError","getResolvedError","selectedCountOrTotal","refreshAllPages","_this$job3","status","_this$job4","_this$job5","_this$job6","_this$job$counts","_this$job$counts2","_this$job7","alreadyUpdatedItemsCount","successCount","totalUpdatingItemsCount","Math","floor"],"sources":["../../../src/state/TagsBulkAssignAsyncState.ts"],"sourcesContent":["import {\n ConditionalModalState,\n FiltersMap,\n ShowToast,\n Tags,\n} from '@wix/bex-core';\n\nimport {\n TagsBulkAssignPopoverState,\n TagsBulkAssignPopoverStateParams,\n} from './TagsBulkAssignPopoverState';\nimport { BulkActionModalRenderPropParams } from '../components/BulkAction';\nimport {\n computed,\n makeObservable,\n observable,\n runInAction,\n action,\n} from 'mobx';\nimport { getAsyncJob } from '@wix/bex-utils/@wix/ambassador-infra-asyncjobs-v1-async-job/http';\nimport { AsyncJob } from '@wix/bex-utils/@wix/ambassador-infra-asyncjobs-v1-async-job/types';\n\nexport const POLL_DELAY = 500;\nexport const MILLIS_FOR_SHOWING_SUCCESS = 1000;\nexport interface AsyncBulkUpdateTagsParams<T, F extends FiltersMap>\n extends Pick<\n BulkActionModalRenderPropParams<T, F>,\n 'allSelected' | 'selectedValues' | 'uncheckedValues' | 'query'\n > {\n assignTags: Tags;\n unassignTags: Tags;\n}\n\nexport interface TagsBulkAssignAsyncStateParams<T, F extends FiltersMap>\n extends Pick<\n TagsBulkAssignPopoverStateParams<T, F>,\n 'asyncBulkUpdateTags' | 'collectionState'\n > {\n container: TagsBulkAssignPopoverState<T, F>['container'];\n optimisticActions: TagsBulkAssignPopoverState<T, F>['optimisticActions'];\n tagsBIReporter: TagsBulkAssignPopoverState<T, F>['tagsBIReporter'];\n}\n\nexport class TagsBulkAssignAsyncState<T, F extends FiltersMap> {\n readonly collectionState;\n readonly optimisticActions;\n readonly container;\n readonly tagsBIReporter;\n readonly asyncBulkUpdateTags;\n readonly asyncJobProgressModalState = new ConditionalModalState();\n\n job: AsyncJob | null = null;\n timeout: NodeJS.Timeout | null = null;\n isDuringApplyChanges = false;\n currentInvocationParams: AsyncBulkUpdateTagsParams<T, F> | null = null;\n updatingTagsToast: ReturnType<ShowToast> | null = null;\n\n constructor(params: TagsBulkAssignAsyncStateParams<T, F>) {\n const {\n collectionState,\n optimisticActions,\n container,\n tagsBIReporter,\n asyncBulkUpdateTags,\n } = params;\n this.collectionState = collectionState;\n this.optimisticActions = optimisticActions;\n this.container = container;\n this.tagsBIReporter = tagsBIReporter;\n this.asyncBulkUpdateTags = asyncBulkUpdateTags;\n\n makeObservable(this, {\n job: observable.ref,\n isDuringApplyChanges: observable,\n init: action,\n applyChanges: action,\n pollJobStatus: action,\n canBulkAssignAsync: computed,\n isJobCompleted: computed,\n isJobFailed: computed,\n isJobEnded: computed,\n isJobInProgress: computed,\n updatedItemsPercentage: computed,\n });\n }\n\n init() {\n const { onBeforeUnload } = this.container;\n const onBeforeUnloadSubscription = onBeforeUnload?.(\n action((event: Event) => {\n if (this.isDuringApplyChanges) {\n event.preventDefault();\n }\n }),\n );\n const disposers = [\n () => {\n onBeforeUnloadSubscription?.remove();\n },\n () => {\n if (this.timeout) {\n clearTimeout(this.timeout);\n }\n },\n ];\n\n return () => {\n disposers.forEach((disposer) => disposer());\n };\n }\n\n async applyChanges({\n newAssignedTagIds,\n newUnassignedTagIds,\n }: {\n newAssignedTagIds: string[];\n newUnassignedTagIds: string[];\n }) {\n this.isDuringApplyChanges = true;\n const { bulkSelect, result } = this.collectionState;\n const { allSelected, selectedValues, uncheckedValues } = bulkSelect;\n\n const params = {\n allSelected,\n selectedValues,\n uncheckedValues,\n query: result.originQuery,\n assignTags: { privateTags: { tagIds: newAssignedTagIds } },\n unassignTags: { privateTags: { tagIds: newUnassignedTagIds } },\n };\n\n await this.triggerBulkAssign(params);\n }\n\n async triggerBulkAssign(params: AsyncBulkUpdateTagsParams<T, F>) {\n if (!this.asyncBulkUpdateTags) {\n throw new Error(\n 'tried to bulk assign tags async without asyncBulkUpdateTags prop given',\n );\n }\n\n this.currentInvocationParams = params;\n\n try {\n this.asyncJobProgressModalState.modal.open();\n const { jobId } = await this.asyncBulkUpdateTags(params);\n await this.pollJobStatus(jobId);\n } catch (error) {\n this.showFailToCreateJobToast(error);\n this.resetStateParams();\n }\n }\n\n async pollJobStatus(jobId: string) {\n const job = await this.fetchJobStatus(jobId);\n\n runInAction(() => {\n this.job = job;\n if (this.isJobInProgress) {\n this.scheduleNextPoll(jobId);\n } else if (this.isJobEnded) {\n this.handleJobEnd();\n }\n });\n }\n\n async fetchJobStatus(jobId: string): Promise<AsyncJob | null> {\n try {\n const job = await this.container.errorHandler.withErrorHandler(\n async () => {\n const {\n data: { job },\n } = await this.container.httpClient.request(getAsyncJob({ jobId }));\n\n return job as AsyncJob;\n },\n {\n errorCodesMap: {},\n },\n );\n\n return job;\n } catch (error) {\n this.asyncJobProgressModalState.modal.close();\n\n this.showFailedToPollToast(error);\n this.resetStateParams();\n\n return null;\n }\n }\n\n scheduleNextPoll(jobId: string): void {\n this.timeout = setTimeout(() => {\n runInAction(() => this.pollJobStatus(jobId));\n }, POLL_DELAY);\n }\n\n handleJobEnd(): void {\n this.timeout = setTimeout(() => {\n runInAction(() => {\n this.handleJobCompletion();\n });\n }, MILLIS_FOR_SHOWING_SUCCESS);\n }\n\n handleJobCompletion() {\n const lastInvocationParams = this.currentInvocationParams;\n const { showToast, translate: t } = this.container;\n\n if (this.isJobCompleted) {\n this.handleJobSuccess(lastInvocationParams);\n } else if (this.isJobFailed) {\n showToast?.({\n type: 'ERROR',\n message: t('cairo.tags.bulkItemUpdate.toast.error', {\n total: this.job?.counts?.failCount!,\n }),\n biName: 'cairo-update-bulk-assign-tags-async-job-status-fail',\n });\n }\n\n this.resetStateParams();\n }\n\n handleJobSuccess(\n lastInvocationParams: AsyncBulkUpdateTagsParams<T, F> | null,\n ) {\n const failCount = this.job?.counts?.failCount;\n if (failCount) {\n this.showPartialFailureToast({ failCount, lastInvocationParams });\n }\n this.showJobCompletedSuccessfullyToast();\n this.refreshCollection();\n }\n\n resetStateParams() {\n this.job = null;\n this.currentInvocationParams = null;\n this.isDuringApplyChanges = false;\n this.updatingTagsToast?.remove();\n this.updatingTagsToast = null;\n this.closeAsyncJobProgressModal();\n }\n\n showPartialFailureToast({\n failCount,\n lastInvocationParams,\n }: {\n failCount: number;\n lastInvocationParams: AsyncBulkUpdateTagsParams<T, F> | null;\n }) {\n this.container.showToast?.({\n type: 'WARNING',\n message: this.container.translate(\n 'cairo.tags.bulkItemUpdate.toast.error',\n { total: failCount },\n ),\n action: {\n text: this.container.translate(\n 'cairo.tags.bulkItemUpdate.toast.error.CTA',\n ),\n onClick: async () => {\n if (lastInvocationParams) {\n await this.triggerBulkAssign(lastInvocationParams);\n }\n },\n removeToastOnClick: true,\n },\n biName: 'cairo-update-bulk-assign-tags-async-fail',\n });\n }\n\n showJobCompletedSuccessfullyToast() {\n this.container.showToast?.({\n type: 'SUCCESS',\n message: this.container.translate(\n 'cairo.tags.bulkItemUpdate.toast.success',\n ),\n biName: 'cairo-update-bulk-assign-tags-async-success',\n });\n }\n\n showFailToCreateJobToast(error: unknown) {\n const { errorHandler, showToast, translate: t } = this.container;\n const resolvedError = errorHandler?.getResolvedError?.(error);\n\n showToast?.({\n type: 'ERROR',\n message:\n resolvedError?.message ??\n t('cairo.tags.bulkItemUpdate.toast.error', {\n total: this.collectionState.bulkSelect.selectedCountOrTotal,\n }),\n action: resolvedError?.action,\n biName: 'cairo-update-bulk-assign-tags-async-create-job-fail',\n });\n }\n\n showFailedToPollToast(error: unknown) {\n const { errorHandler, showToast } = this.container;\n\n const resolvedError = errorHandler?.getResolvedError?.(error);\n\n showToast?.({\n type: 'ERROR',\n message: resolvedError?.message!,\n action: resolvedError?.action,\n biName: 'cairo-update-bulk-assign-tags-async-poll-fail',\n });\n }\n\n refreshCollection() {\n this.collectionState.refreshAllPages();\n }\n\n openAsyncJobProgressModal = () => {\n this.asyncJobProgressModalState.modal.open();\n };\n\n closeAsyncJobProgressModal = () => {\n this.asyncJobProgressModalState.modal.close();\n if (this.isJobInProgress) {\n this.updatingTagsToast =\n this.container.showToast?.({\n type: 'STANDARD',\n message: this.container.translate(\n 'cairo.tags.bulkItemUpdate.updatingTags.toast',\n ),\n action: {\n text: this.container.translate(\n 'cairo.tags.bulkItemUpdate.updatingTags.toast.CTA',\n ),\n onClick: async () => {\n this.openAsyncJobProgressModal();\n },\n removeToastOnClick: true,\n },\n timeout: 'NONE',\n biName: 'cairo-updating-bulk-assign-tags-async',\n }) || null;\n }\n };\n\n get isJobCompleted() {\n return this.job?.status === 'FINISHED';\n }\n\n get isJobFailed() {\n return this.job?.status === 'FAILED';\n }\n\n get isJobEnded() {\n return this.isJobCompleted || this.isJobFailed;\n }\n\n get isJobInProgress() {\n return (\n this.job?.status === 'PROCESSING' || this.job?.status === 'INITIALIZED'\n );\n }\n\n get canBulkAssignAsync() {\n return !!this.asyncBulkUpdateTags;\n }\n\n get updatedItemsPercentage() {\n if (!this.job) {\n return 0;\n }\n\n const alreadyUpdatedItemsCount =\n (this.job.counts?.successCount || 0) + (this.job.counts?.failCount || 0);\n const totalUpdatingItemsCount =\n this.job?.counts?.total ||\n this.collectionState.bulkSelect.selectedCountOrTotal;\n\n return Math.floor(\n 100 * (alreadyUpdatedItemsCount / totalUpdatingItemsCount),\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
4
|
exports.__esModule = true;
|
|
5
|
-
exports.TagsBulkAssignPopoverState =
|
|
5
|
+
exports.TagsBulkAssignPopoverState = void 0;
|
|
6
6
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
7
7
|
var _mobx = require("mobx");
|
|
8
8
|
var _bexCore = require("@wix/bex-core");
|
|
@@ -12,7 +12,6 @@ var _TagsBulkAssignButtonState = require("./TagsBulkAssignButtonState");
|
|
|
12
12
|
var _TagsBulkAssignAsyncState = require("./TagsBulkAssignAsyncState");
|
|
13
13
|
var _TagsBulkAssignSyncState = require("./TagsBulkAssignSyncState");
|
|
14
14
|
const origin = 'bulk_assign_popover';
|
|
15
|
-
const MAX_SELECTED_ENTITIES_FOR_BULK_ASSIGN_SYNC = exports.MAX_SELECTED_ENTITIES_FOR_BULK_ASSIGN_SYNC = 100;
|
|
16
15
|
class TagsBulkAssignPopoverState {
|
|
17
16
|
constructor({
|
|
18
17
|
tagsManagementState,
|
|
@@ -220,7 +219,7 @@ class TagsBulkAssignPopoverState {
|
|
|
220
219
|
newAssignedTagIds,
|
|
221
220
|
newUnassignedTagIds
|
|
222
221
|
};
|
|
223
|
-
if (this.
|
|
222
|
+
if (this.bulkAssignSyncState.canUseBulkSync) {
|
|
224
223
|
this.bulkAssignSyncState.applyChanges(params);
|
|
225
224
|
} else {
|
|
226
225
|
await this.bulkAssignAsyncState.applyChanges(params);
|
|
@@ -295,13 +294,6 @@ class TagsBulkAssignPopoverState {
|
|
|
295
294
|
get newUnassignedTagIds() {
|
|
296
295
|
return [...this.initialSelectedIds.filter(tagId => !this.assignedTagIds.includes(tagId)), ...this.initialIndeterminateTagIds.filter(tagId => ![...this.assignedTagIds, ...this.indeterminateTagIds].includes(tagId))];
|
|
297
296
|
}
|
|
298
|
-
get shouldlUseBulkSync() {
|
|
299
|
-
const {
|
|
300
|
-
allSelectedItemsFetched,
|
|
301
|
-
selectedCountOrTotal
|
|
302
|
-
} = this.collectionState.bulkSelect;
|
|
303
|
-
return allSelectedItemsFetched && selectedCountOrTotal < MAX_SELECTED_ENTITIES_FOR_BULK_ASSIGN_SYNC;
|
|
304
|
-
}
|
|
305
297
|
get canUseBulkUpdate() {
|
|
306
298
|
// Cannot invoke bulk assign while applying async changes
|
|
307
299
|
if (this.bulkAssignAsyncState.isDuringApplyChanges) {
|
|
@@ -309,7 +301,7 @@ class TagsBulkAssignPopoverState {
|
|
|
309
301
|
}
|
|
310
302
|
|
|
311
303
|
// can use sync
|
|
312
|
-
if (this.
|
|
304
|
+
if (this.bulkAssignSyncState.canUseBulkSync) {
|
|
313
305
|
return true;
|
|
314
306
|
}
|
|
315
307
|
|