@wix/patterns 1.387.0 → 1.388.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/CardContainer/CardContainer.st.css.js +2 -2
- package/dist/cjs/components/CardContainer/CardContainer.st.css.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/CollectionPageNew/CollectionPage.st.css.js +2 -2
- package/dist/cjs/components/CollectionPageNew/CollectionPage.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionSectionHeader/CollectionSectionHeader.st.css.js +3 -3
- package/dist/cjs/components/CollectionSectionHeader/CollectionSectionHeader.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionTable/CollectionTable.st.css.js +2 -2
- package/dist/cjs/components/CollectionTable/CollectionTable.st.css.js.map +1 -1
- package/dist/cjs/components/CollectionTable/CollectionTableWSRTable.st.css.js +2 -2
- package/dist/cjs/components/CollectionTable/CollectionTableWSRTable.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/SearchOrCustomFilter.st.css.js +4 -4
- package/dist/cjs/components/CollectionToolbar/SearchOrCustomFilter.st.css.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/ColumnListTableListItem.js +15 -14
- package/dist/cjs/components/CustomColumnsPanel/ColumnListTableListItem.js.map +1 -1
- package/dist/cjs/components/CustomColumnsPanel/ColumnsList.js +8 -6
- package/dist/cjs/components/CustomColumnsPanel/ColumnsList.js.map +1 -1
- package/dist/cjs/components/CustomColumnsPanel/CustomColumnsPanel.js +19 -16
- package/dist/cjs/components/CustomColumnsPanel/CustomColumnsPanel.js.map +1 -1
- package/dist/cjs/components/CustomColumnsPanel/useSidePanelFieldActions.js +52 -0
- package/dist/cjs/components/CustomColumnsPanel/useSidePanelFieldActions.js.map +1 -0
- 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/EditableTable/EditableCell.js +6 -6
- package/dist/cjs/components/EditableTable/EditableCell.js.map +1 -1
- package/dist/cjs/components/EditableTable/EditableCell.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/EditableCell.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/EditableColumnHeader.uni.driver.js +8 -1
- package/dist/cjs/components/EditableTable/EditableColumnHeader.uni.driver.js.map +1 -1
- package/dist/cjs/components/EditableTable/EditableTable.js +12 -10
- package/dist/cjs/components/EditableTable/EditableTable.js.map +1 -1
- package/dist/cjs/components/EditableTable/HeaderActionsPopover.js +14 -99
- package/dist/cjs/components/EditableTable/HeaderActionsPopover.js.map +1 -1
- package/dist/cjs/components/EditableTable/HeaderActionsPopover.st.css +8 -10
- package/dist/cjs/components/EditableTable/HeaderActionsPopover.st.css.js +2 -2
- package/dist/cjs/components/EditableTable/HeaderActionsPopover.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/CellViewLayout.st.css.js +2 -2
- package/dist/cjs/components/EditableTable/cellTypes/CellViewLayout.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/boolean/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/boolean/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/boolean/View.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/boolean/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/date/Edit.js +4 -4
- package/dist/cjs/components/EditableTable/cellTypes/date/Edit.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/date/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/date/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/date/View.st.css.js +2 -2
- package/dist/cjs/components/EditableTable/cellTypes/date/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/email/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/email/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/email/View.st.css.js +2 -2
- package/dist/cjs/components/EditableTable/cellTypes/email/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/image/View.js +2 -2
- package/dist/cjs/components/EditableTable/cellTypes/image/View.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/number/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/number/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/number/View.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/number/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/object/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/object/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/object/View.st.css.js +2 -2
- package/dist/cjs/components/EditableTable/cellTypes/object/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/select/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/select/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/text/Edit.js +7 -7
- package/dist/cjs/components/EditableTable/cellTypes/text/Edit.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/text/Edit.st.css.js +4 -4
- package/dist/cjs/components/EditableTable/cellTypes/text/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/text/View.st.css.js +2 -2
- package/dist/cjs/components/EditableTable/cellTypes/text/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/url/Edit.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/url/Edit.st.css.js +3 -3
- package/dist/cjs/components/EditableTable/cellTypes/url/Edit.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/url/View.st.css.js +5 -5
- package/dist/cjs/components/EditableTable/cellTypes/url/View.st.css.js.map +1 -1
- package/dist/cjs/components/EditableTable/cellTypes/url/View.uni.driver.js.map +1 -1
- package/dist/cjs/components/EditableTable/useCellFocusAndEditing.js.map +1 -1
- package/dist/cjs/components/EditableTable/useHeaderActions.js +91 -0
- package/dist/cjs/components/EditableTable/useHeaderActions.js.map +1 -0
- package/dist/cjs/components/EntityPage/EntityPagePlain.st.css.js +2 -2
- package/dist/cjs/components/EntityPage/EntityPagePlain.st.css.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/FieldActions/FieldActions.js +225 -0
- package/dist/cjs/components/FieldActions/FieldActions.js.map +1 -0
- package/dist/cjs/components/FieldActions/HeaderActionsPopover.js +121 -0
- package/dist/cjs/components/FieldActions/HeaderActionsPopover.js.map +1 -0
- package/dist/cjs/components/FieldActions/headerActionTypes.js.map +1 -0
- package/dist/cjs/components/FieldActions/index.js +13 -0
- package/dist/cjs/components/FieldActions/index.js.map +1 -0
- 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/ImportButton/ImportStepUpload.st.css.js +3 -3
- package/dist/cjs/components/ImportButton/ImportStepUpload.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/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js +5 -5
- package/dist/cjs/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js.map +1 -1
- 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/SchemaCard/SchemaCard.js +9 -2
- package/dist/cjs/components/SchemaCard/SchemaCard.js.map +1 -1
- 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/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/ToolbarItem/ToolbarItem.st.css.js +2 -2
- package/dist/cjs/components/ToolbarItem/ToolbarItem.st.css.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/hooks/useCloseOnAncestorScroll.js.map +1 -0
- package/dist/cjs/state/CollectionPage/CollectionPageHeader.st.css.js +2 -2
- package/dist/cjs/state/CollectionPage/CollectionPageHeader.st.css.js.map +1 -1
- package/dist/cjs/state/EditableTable/EditableTableState.js +1 -1
- package/dist/cjs/state/EditableTable/EditableTableState.js.map +1 -1
- package/dist/cjs/state/EditableTable/FieldActionsState.js +113 -2
- package/dist/cjs/state/EditableTable/FieldActionsState.js.map +1 -1
- package/dist/cjs/state/EditableTable/types.js.map +1 -1
- package/dist/cjs/state/FormPage/FormPageHeader.st.css.js +2 -2
- package/dist/cjs/state/FormPage/FormPageHeader.st.css.js.map +1 -1
- package/dist/cjs/state/ViewTypeState.js.map +1 -1
- package/dist/cjs/styles.global.css +1 -1
- package/dist/cjs/types/SchemaConfig.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/docs/index.json +23 -23
- package/dist/esm/components/CardContainer/CardContainer.st.css.js +2 -2
- package/dist/esm/components/CardContainer/CardContainer.st.css.js.map +1 -1
- package/dist/esm/components/Collapse/Collapse.st.css.js +2 -2
- package/dist/esm/components/CollectionPageNew/CollectionPage.st.css.js +2 -2
- package/dist/esm/components/CollectionSectionHeader/CollectionSectionHeader.st.css.js +2 -2
- package/dist/esm/components/CollectionTable/CollectionTable.st.css.js +2 -2
- package/dist/esm/components/CollectionTable/CollectionTableWSRTable.st.css.js +2 -2
- package/dist/esm/components/CollectionToolbar/CollectionToolbar.st.css.js +2 -2
- package/dist/esm/components/CollectionToolbar/CollectionToolbar.st.css.js.map +1 -1
- package/dist/esm/components/CollectionToolbar/SearchOrCustomFilter.st.css.js +2 -2
- package/dist/esm/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js +2 -2
- package/dist/esm/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js.map +1 -1
- package/dist/esm/components/CollectionViewsDropdown/ViewsDropdown.st.css.js +2 -2
- package/dist/esm/components/CustomColumnsPanel/ColumnListTableListItem.js +4 -3
- package/dist/esm/components/CustomColumnsPanel/ColumnListTableListItem.js.map +1 -1
- package/dist/esm/components/CustomColumnsPanel/ColumnsList.js +2 -2
- package/dist/esm/components/CustomColumnsPanel/ColumnsList.js.map +1 -1
- package/dist/esm/components/CustomColumnsPanel/CustomColumnsPanel.js +4 -2
- package/dist/esm/components/CustomColumnsPanel/CustomColumnsPanel.js.map +1 -1
- package/dist/esm/components/CustomColumnsPanel/useSidePanelFieldActions.js +43 -0
- package/dist/esm/components/CustomColumnsPanel/useSidePanelFieldActions.js.map +1 -0
- package/dist/esm/components/DragHandle/DragHandle.st.css.js +2 -2
- package/dist/esm/components/EditableTable/EditableCell.js.map +1 -1
- package/dist/esm/components/EditableTable/EditableCell.st.css.js +2 -2
- package/dist/esm/components/EditableTable/EditableColumnHeader.uni.driver.js +9 -0
- package/dist/esm/components/EditableTable/EditableColumnHeader.uni.driver.js.map +1 -1
- package/dist/esm/components/EditableTable/EditableTable.js +3 -3
- package/dist/esm/components/EditableTable/EditableTable.js.map +1 -1
- package/dist/esm/components/EditableTable/HeaderActionsPopover.js +5 -31
- package/dist/esm/components/EditableTable/HeaderActionsPopover.js.map +1 -1
- package/dist/esm/components/EditableTable/HeaderActionsPopover.st.css +8 -10
- package/dist/esm/components/EditableTable/HeaderActionsPopover.st.css.js +2 -2
- package/dist/esm/components/EditableTable/HeaderActionsPopover.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/CellViewLayout.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/boolean/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/boolean/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/date/Edit.js +4 -2
- package/dist/esm/components/EditableTable/cellTypes/date/Edit.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/date/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/date/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/date/View.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/email/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/email/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/email/View.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/image/View.js +1 -1
- package/dist/esm/components/EditableTable/cellTypes/image/View.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/number/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/number/Edit.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/number/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/object/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/object/Edit.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/object/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/select/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/text/Edit.js +7 -5
- package/dist/esm/components/EditableTable/cellTypes/text/Edit.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/text/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/text/Edit.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/text/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/text/View.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/url/Edit.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/url/Edit.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/url/Edit.st.css.js.map +1 -1
- package/dist/esm/components/EditableTable/cellTypes/url/View.st.css.js +2 -2
- package/dist/esm/components/EditableTable/cellTypes/url/View.uni.driver.js +1 -3
- package/dist/esm/components/EditableTable/cellTypes/url/View.uni.driver.js.map +1 -1
- package/dist/esm/components/EditableTable/useCellFocusAndEditing.js +4 -1
- package/dist/esm/components/EditableTable/useCellFocusAndEditing.js.map +1 -1
- package/dist/esm/components/EditableTable/useHeaderActions.js +82 -0
- package/dist/esm/components/EditableTable/useHeaderActions.js.map +1 -0
- package/dist/esm/components/EntityPage/EntityPagePlain.st.css.js +2 -2
- package/dist/esm/components/EntityPage/EntityPagePlain.st.css.js.map +1 -1
- package/dist/esm/components/Fade/Fade.st.css.js +2 -2
- package/dist/esm/components/FieldActions/FieldActions.js +152 -0
- package/dist/esm/components/FieldActions/FieldActions.js.map +1 -0
- package/dist/esm/components/FieldActions/HeaderActionsPopover.js +33 -0
- package/dist/esm/components/FieldActions/HeaderActionsPopover.js.map +1 -0
- package/dist/esm/components/FieldActions/headerActionTypes.js.map +1 -0
- package/dist/esm/components/FieldActions/index.js +3 -0
- package/dist/esm/components/FieldActions/index.js.map +1 -0
- package/dist/esm/components/Heading/Heading.st.css.js +2 -2
- package/dist/esm/components/ImportButton/ImportStepUpload.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/MaxHeightText/MaxHeightText.st.css.js +2 -2
- package/dist/esm/components/MaxLines/MaxLines.st.css.js +2 -2
- package/dist/esm/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js +2 -2
- 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/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js +2 -2
- package/dist/esm/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js.map +1 -1
- 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/PickerContent.st.css.js.map +1 -1
- 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/SchemaCard/SchemaCard.js +6 -5
- package/dist/esm/components/SchemaCard/SchemaCard.js.map +1 -1
- 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/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js +2 -2
- package/dist/esm/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js.map +1 -1
- package/dist/esm/components/ToolbarItem/ToolbarItem.st.css.js +2 -2
- package/dist/esm/components/ToolbarItemBox/ToolbarItemBox.st.css.js +2 -2
- package/dist/esm/components/common.st.css.js +2 -2
- package/dist/esm/hooks/useCloseOnAncestorScroll.js.map +1 -0
- package/dist/esm/state/CollectionPage/CollectionPageHeader.st.css.js +2 -2
- package/dist/esm/state/CollectionPage/CollectionPageHeader.st.css.js.map +1 -1
- package/dist/esm/state/EditableTable/EditableTableState.js +1 -1
- package/dist/esm/state/EditableTable/EditableTableState.js.map +1 -1
- package/dist/esm/state/EditableTable/FieldActionsState.js +114 -1
- package/dist/esm/state/EditableTable/FieldActionsState.js.map +1 -1
- package/dist/esm/state/FormPage/FormPageHeader.st.css.js +2 -2
- package/dist/esm/state/ViewTypeState.js +3 -1
- package/dist/esm/state/ViewTypeState.js.map +1 -1
- package/dist/esm/styles.global.css +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/types/components/CardContainer/CardContainer.st.css.d.ts.map +1 -1
- package/dist/types/components/CollectionToolbar/CollectionToolbar.st.css.d.ts.map +1 -1
- package/dist/types/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.d.ts.map +1 -1
- package/dist/types/components/CustomColumnsPanel/ColumnListTableListItem.d.ts +1 -0
- package/dist/types/components/CustomColumnsPanel/ColumnListTableListItem.d.ts.map +1 -1
- package/dist/types/components/CustomColumnsPanel/ColumnsList.d.ts +2 -1
- package/dist/types/components/CustomColumnsPanel/ColumnsList.d.ts.map +1 -1
- package/dist/types/components/CustomColumnsPanel/CustomColumnsPanel.d.ts.map +1 -1
- package/dist/types/components/CustomColumnsPanel/useSidePanelFieldActions.d.ts +6 -0
- package/dist/types/components/CustomColumnsPanel/useSidePanelFieldActions.d.ts.map +1 -0
- package/dist/types/components/EditableTable/EditableCell.d.ts.map +1 -1
- package/dist/types/components/EditableTable/EditableColumnHeader.uni.driver.d.ts +2 -0
- package/dist/types/components/EditableTable/EditableColumnHeader.uni.driver.d.ts.map +1 -1
- package/dist/types/components/EditableTable/EditableTable.d.ts +1 -1
- package/dist/types/components/EditableTable/EditableTable.d.ts.map +1 -1
- package/dist/types/components/EditableTable/EditableTable.uni.driver.d.ts +1 -0
- package/dist/types/components/EditableTable/EditableTable.uni.driver.d.ts.map +1 -1
- package/dist/types/components/EditableTable/HeaderActionsPopover.d.ts +2 -6
- package/dist/types/components/EditableTable/HeaderActionsPopover.d.ts.map +1 -1
- package/dist/types/components/EditableTable/HeaderActionsPopover.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/date/Edit.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/date/View.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/email/View.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/image/View.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/number/Edit.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/object/Edit.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/text/Edit.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/text/Edit.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/text/View.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/url/Edit.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/url/Edit.st.css.d.ts.map +1 -1
- package/dist/types/components/EditableTable/cellTypes/url/View.uni.driver.d.ts.map +1 -1
- package/dist/types/components/EditableTable/useCellFocusAndEditing.d.ts.map +1 -1
- package/dist/types/components/EditableTable/useHeaderActions.d.ts +6 -0
- package/dist/types/components/EditableTable/useHeaderActions.d.ts.map +1 -0
- package/dist/types/components/EntityPage/EntityPagePlain.st.css.d.ts.map +1 -1
- package/dist/types/components/FieldActions/FieldActions.d.ts +40 -0
- package/dist/types/components/FieldActions/FieldActions.d.ts.map +1 -0
- package/dist/types/components/FieldActions/HeaderActionsPopover.d.ts +9 -0
- package/dist/types/components/FieldActions/HeaderActionsPopover.d.ts.map +1 -0
- package/dist/types/components/{EditableTable → FieldActions}/headerActionTypes.d.ts +2 -0
- package/dist/types/components/FieldActions/headerActionTypes.d.ts.map +1 -0
- package/dist/types/components/FieldActions/index.d.ts +6 -0
- package/dist/types/components/FieldActions/index.d.ts.map +1 -0
- package/dist/types/components/InputOverflow/InputOverflow.st.css.d.ts.map +1 -1
- package/dist/types/components/LayoutSwitch/LayoutSwitch.uni.driver.d.ts +1 -0
- package/dist/types/components/LayoutSwitch/LayoutSwitch.uni.driver.d.ts.map +1 -1
- package/dist/types/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.d.ts.map +1 -1
- package/dist/types/components/PickerContent/PickerContent.st.css.d.ts.map +1 -1
- package/dist/types/components/SchemaCard/SchemaCard.d.ts.map +1 -1
- 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/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.d.ts.map +1 -1
- package/dist/types/hooks/useCloseOnAncestorScroll.d.ts.map +1 -0
- package/dist/types/state/CollectionPage/CollectionPageHeader.st.css.d.ts.map +1 -1
- package/dist/types/state/EditableTable/EditableTableState.d.ts +2 -5
- package/dist/types/state/EditableTable/EditableTableState.d.ts.map +1 -1
- package/dist/types/state/EditableTable/FieldActionsState.d.ts +11 -2
- package/dist/types/state/EditableTable/FieldActionsState.d.ts.map +1 -1
- package/dist/types/state/EditableTable/types.d.ts +4 -0
- package/dist/types/state/EditableTable/types.d.ts.map +1 -1
- package/dist/types/state/ViewTypeState.d.ts.map +1 -1
- package/dist/types/testkit/jsdom.d.ts +2 -0
- package/dist/types/testkit/jsdom.d.ts.map +1 -1
- package/dist/types/testkit/playwright.d.ts +1 -0
- package/dist/types/testkit/playwright.d.ts.map +1 -1
- package/dist/types/testkit/puppeteer.d.ts +1 -0
- package/dist/types/testkit/puppeteer.d.ts.map +1 -1
- package/dist/types/types/SchemaConfig.d.ts +2 -0
- package/dist/types/types/SchemaConfig.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/package.json +3 -3
- package/src/components/CardContainer/CardContainer.st.css.ts +2 -2
- package/src/components/Collapse/Collapse.st.css.ts +2 -2
- package/src/components/CollectionPageNew/CollectionPage.st.css.ts +2 -2
- package/src/components/CollectionSectionHeader/CollectionSectionHeader.st.css.ts +2 -2
- package/src/components/CollectionTable/CollectionTable.st.css.ts +2 -2
- package/src/components/CollectionTable/CollectionTableWSRTable.st.css.ts +2 -2
- package/src/components/CollectionToolbar/CollectionToolbar.st.css.ts +2 -2
- package/src/components/CollectionToolbar/SearchOrCustomFilter.st.css.ts +2 -2
- package/src/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.ts +2 -2
- package/src/components/CollectionViewsDropdown/ViewsDropdown.st.css.ts +2 -2
- package/src/components/CustomColumnsPanel/ColumnListTableListItem.tsx +5 -1
- package/src/components/CustomColumnsPanel/ColumnsList.tsx +4 -2
- package/src/components/CustomColumnsPanel/CustomColumnsPanel.tsx +7 -2
- package/src/components/CustomColumnsPanel/useSidePanelFieldActions.tsx +69 -0
- package/src/components/DragHandle/DragHandle.st.css.ts +2 -2
- package/src/components/EditableTable/EditableCell.st.css.ts +2 -2
- package/src/components/EditableTable/EditableCell.tsx +5 -8
- package/src/components/EditableTable/EditableColumnHeader.uni.driver.ts +10 -0
- package/src/components/EditableTable/EditableTable.tsx +11 -3
- package/src/components/EditableTable/HeaderActionsPopover.st.css +8 -10
- package/src/components/EditableTable/HeaderActionsPopover.st.css.ts +2 -2
- package/src/components/EditableTable/HeaderActionsPopover.tsx +9 -84
- package/src/components/EditableTable/cellTypes/CellViewLayout.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/boolean/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/boolean/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/date/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/date/Edit.tsx +6 -2
- package/src/components/EditableTable/cellTypes/date/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/email/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/email/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/image/View.tsx +3 -3
- package/src/components/EditableTable/cellTypes/number/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/number/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/object/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/object/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/select/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/text/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/text/Edit.tsx +24 -13
- package/src/components/EditableTable/cellTypes/text/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/url/Edit.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/url/Edit.tsx +8 -2
- package/src/components/EditableTable/cellTypes/url/View.st.css.ts +2 -2
- package/src/components/EditableTable/cellTypes/url/View.uni.driver.ts +1 -3
- package/src/components/EditableTable/useCellFocusAndEditing.ts +4 -1
- package/src/components/EditableTable/useHeaderActions.tsx +120 -0
- package/src/components/EntityPage/EntityPagePlain.st.css.ts +2 -2
- package/src/components/Fade/Fade.st.css.ts +2 -2
- package/src/components/FieldActions/FieldActions.tsx +248 -0
- package/src/components/FieldActions/HeaderActionsPopover.tsx +99 -0
- package/src/components/{EditableTable → FieldActions}/headerActionTypes.ts +2 -0
- package/src/components/FieldActions/index.ts +17 -0
- package/src/components/Heading/Heading.st.css.ts +2 -2
- package/src/components/ImportButton/ImportStepUpload.st.css.ts +2 -2
- package/src/components/InputOverflow/InputOverflow.st.css.ts +2 -2
- package/src/components/LoadingRow/LoadingRow.st.css.ts +3 -3
- package/src/components/MaxHeightText/MaxHeightText.st.css.ts +2 -2
- package/src/components/MaxLines/MaxLines.st.css.ts +2 -2
- package/src/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.ts +2 -2
- package/src/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.ts +2 -2
- package/src/components/NestedTable/NestedTableRow.st.css.ts +2 -2
- package/src/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.ts +2 -2
- package/src/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.ts +2 -2
- package/src/components/PickerContent/PickerContent.st.css.ts +2 -2
- package/src/components/PickerContent/PickerContentAdditionalStep.st.css.ts +2 -2
- package/src/components/PickerTableListItem/PickerTableListItem.st.css.ts +2 -2
- package/src/components/SchemaCard/SchemaCard.tsx +7 -5
- package/src/components/ScrollableContent/ScrollableContent.st.css.ts +2 -2
- package/src/components/SkeletonCard/SkeletonCard.st.css.ts +2 -2
- package/src/components/SlidingModal/SlidingModal.st.css.ts +2 -2
- package/src/components/TabsFilter/TabsFilter.st.css.ts +2 -2
- package/src/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.ts +2 -2
- package/src/components/ToolbarItem/ToolbarItem.st.css.ts +2 -2
- package/src/components/ToolbarItemBox/ToolbarItemBox.st.css.ts +2 -2
- package/src/components/common.st.css.ts +2 -2
- package/src/state/CollectionPage/CollectionPageHeader.st.css.ts +2 -2
- package/src/state/EditableTable/EditableTableState.ts +3 -5
- package/src/state/EditableTable/FieldActionsState.ts +137 -1
- package/src/state/EditableTable/types.ts +6 -0
- package/src/state/FormPage/FormPageHeader.st.css.ts +2 -2
- package/src/state/ViewTypeState.ts +3 -1
- package/src/styles.global.css +1 -1
- package/src/types/SchemaConfig.ts +2 -0
- package/src/version.ts +1 -1
- package/dist/cjs/components/EditableTable/headerActionTypes.js.map +0 -1
- package/dist/cjs/components/EditableTable/useBuiltInHeaderActions.js +0 -130
- package/dist/cjs/components/EditableTable/useBuiltInHeaderActions.js.map +0 -1
- package/dist/cjs/components/EditableTable/useCloseOnAncestorScroll.js.map +0 -1
- package/dist/esm/components/EditableTable/headerActionTypes.js.map +0 -1
- package/dist/esm/components/EditableTable/useBuiltInHeaderActions.js +0 -84
- package/dist/esm/components/EditableTable/useBuiltInHeaderActions.js.map +0 -1
- package/dist/esm/components/EditableTable/useCloseOnAncestorScroll.js.map +0 -1
- package/dist/types/components/EditableTable/headerActionTypes.d.ts.map +0 -1
- package/dist/types/components/EditableTable/useBuiltInHeaderActions.d.ts +0 -6
- package/dist/types/components/EditableTable/useBuiltInHeaderActions.d.ts.map +0 -1
- package/dist/types/components/EditableTable/useCloseOnAncestorScroll.d.ts.map +0 -1
- package/src/components/EditableTable/useBuiltInHeaderActions.tsx +0 -116
- /package/dist/cjs/components/{EditableTable → FieldActions}/headerActionTypes.js +0 -0
- /package/dist/cjs/{components/EditableTable → hooks}/useCloseOnAncestorScroll.js +0 -0
- /package/dist/esm/components/{EditableTable → FieldActions}/headerActionTypes.js +0 -0
- /package/dist/esm/{components/EditableTable → hooks}/useCloseOnAncestorScroll.js +0 -0
- /package/dist/types/{components/EditableTable → hooks}/useCloseOnAncestorScroll.d.ts +0 -0
- /package/src/{components/EditableTable → hooks}/useCloseOnAncestorScroll.ts +0 -0
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "Edit3198482543";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"Edit3198482543__root","numberInput":"Edit3198482543__numberInput"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "View1943206141";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"View1943206141__root","textView":"View1943206141__textView"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "Edit1103264885";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"Edit1103264885__root","jsonInput":"Edit1103264885__jsonInput"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "View3210567209";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"View3210567209__root"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "Edit1556649707";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"Edit1556649707__root","selectInput":"Edit1556649707__selectInput"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "Edit4035541426";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"Edit4035541426__root","editWrapper":"Edit4035541426__editWrapper","inputArea":"Edit4035541426__inputArea"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -6,24 +6,25 @@ import {
|
|
|
6
6
|
} from '@wix/patterns-fields';
|
|
7
7
|
import type { CellEditProps } from '../../types';
|
|
8
8
|
import type { ValidationRule } from '../../../../state/EditableTable/types';
|
|
9
|
-
import { useCloseOnAncestorScroll } from '
|
|
9
|
+
import { useCloseOnAncestorScroll } from '../../../../hooks/useCloseOnAncestorScroll';
|
|
10
10
|
import { st, classes } from './Edit.st.css.js';
|
|
11
11
|
|
|
12
12
|
function getMaxLength(validation?: ValidationRule[]) {
|
|
13
|
-
return (
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
r.type === 'maxLength',
|
|
17
|
-
)
|
|
13
|
+
return validation?.find(
|
|
14
|
+
(r): r is { type: 'maxLength'; value: number; message: string } =>
|
|
15
|
+
r.type === 'maxLength',
|
|
18
16
|
)?.value;
|
|
19
17
|
}
|
|
20
18
|
|
|
21
19
|
function getSpecificValues(validation?: ValidationRule[]) {
|
|
22
|
-
return (
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
20
|
+
return validation?.find(
|
|
21
|
+
(
|
|
22
|
+
r,
|
|
23
|
+
): r is {
|
|
24
|
+
type: 'specificValues';
|
|
25
|
+
values: { id: string; value: string }[];
|
|
26
|
+
message: string;
|
|
27
|
+
} => r.type === 'specificValues',
|
|
27
28
|
)?.values;
|
|
28
29
|
}
|
|
29
30
|
|
|
@@ -77,7 +78,15 @@ const TextEditPlain: React.FC<CellEditProps<string>> = ({
|
|
|
77
78
|
// Specific values mode — autocomplete with a closed list of options
|
|
78
79
|
const TextEditSpecificValues: React.FC<
|
|
79
80
|
CellEditProps<string> & { options: { id: string; value: string }[] }
|
|
80
|
-
> = ({
|
|
81
|
+
> = ({
|
|
82
|
+
value,
|
|
83
|
+
onChange,
|
|
84
|
+
onCommit,
|
|
85
|
+
onCancel,
|
|
86
|
+
inputRef,
|
|
87
|
+
editTrigger,
|
|
88
|
+
options,
|
|
89
|
+
}) => {
|
|
81
90
|
const acHandle = useRef<CellAutoCompleteHandle | null>(null);
|
|
82
91
|
const wrapperRef = useRef<HTMLDivElement | null>(null);
|
|
83
92
|
|
|
@@ -134,7 +143,9 @@ const TextEditSpecificValues: React.FC<
|
|
|
134
143
|
value={value || undefined}
|
|
135
144
|
options={options}
|
|
136
145
|
initialSearchText={
|
|
137
|
-
editTrigger &&
|
|
146
|
+
editTrigger &&
|
|
147
|
+
typeof editTrigger === 'object' &&
|
|
148
|
+
editTrigger.kind === 'type'
|
|
138
149
|
? editTrigger.key
|
|
139
150
|
: undefined
|
|
140
151
|
}
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "View3195187770";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"View3195187770__root"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "Edit3804783142";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"Edit3804783142__root","urlInput":"Edit3804783142__urlInput"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -39,12 +39,18 @@ export const UrlEdit: React.FC<CellEditProps<string>> = ({
|
|
|
39
39
|
}}
|
|
40
40
|
>
|
|
41
41
|
<CellUrlInput
|
|
42
|
-
inputRef={
|
|
42
|
+
inputRef={
|
|
43
|
+
inputRef as React.MutableRefObject<
|
|
44
|
+
InputImperativeActions | null | undefined
|
|
45
|
+
>
|
|
46
|
+
}
|
|
43
47
|
value={value ?? ''}
|
|
44
48
|
onChange={onChange}
|
|
45
49
|
onKeyDown={handleKeyDown}
|
|
46
50
|
onBlur={handleBlur}
|
|
47
|
-
autoSelect={
|
|
51
|
+
autoSelect={
|
|
52
|
+
!(typeof editTrigger === 'object' && editTrigger?.kind === 'type')
|
|
53
|
+
}
|
|
48
54
|
className={classes.urlInput}
|
|
49
55
|
/>
|
|
50
56
|
</div>
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../stylable-esm-runtime.
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "View3203535727";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"View3203535727__root","textView":"View3203535727__textView","urlText":"View3203535727__urlText","suffix":"View3203535727__suffix"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -13,9 +13,7 @@ export function UrlViewUniDriver(base: UniDriver, body: UniDriver) {
|
|
|
13
13
|
getValue: () => base.text(),
|
|
14
14
|
hasOpenLinkButton: () => linkButton.exists(),
|
|
15
15
|
getLinkHref: () =>
|
|
16
|
-
base
|
|
17
|
-
.$('[data-hook="open-link-button"]')
|
|
18
|
-
.attr('href') as Promise<string>,
|
|
16
|
+
base.$('[data-hook="open-link-button"]').attr('href') as Promise<string>,
|
|
19
17
|
clickOpenLink: () => linkButton.click(),
|
|
20
18
|
};
|
|
21
19
|
}
|
|
@@ -147,7 +147,10 @@ export function useCellFocusAndEditing<T, F extends FiltersMap>({
|
|
|
147
147
|
}
|
|
148
148
|
|
|
149
149
|
e.preventDefault();
|
|
150
|
-
cellInteraction.startEdit(undefined, undefined, {
|
|
150
|
+
cellInteraction.startEdit(undefined, undefined, {
|
|
151
|
+
kind: 'type',
|
|
152
|
+
key: e.key,
|
|
153
|
+
});
|
|
151
154
|
|
|
152
155
|
if ('value' in typeResult) {
|
|
153
156
|
// Cell type provides an explicit pre-populated value (e.g. first typed
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import React, { useMemo, type ReactNode } from 'react';
|
|
2
|
+
import type { FiltersMap } from '@wix/bex-core';
|
|
3
|
+
import type { EditableTableState } from '../../state/EditableTable';
|
|
4
|
+
import type { EditableColumn } from '../../state/EditableTable/types';
|
|
5
|
+
import {
|
|
6
|
+
buildFieldActionGroups,
|
|
7
|
+
type FieldActionHandlers,
|
|
8
|
+
type FieldActionKey,
|
|
9
|
+
} from '../FieldActions';
|
|
10
|
+
import { HeaderActionsPopover } from './HeaderActionsPopover';
|
|
11
|
+
|
|
12
|
+
const FIELD_ACTION_GROUPS: FieldActionKey[][] = [
|
|
13
|
+
['editField'],
|
|
14
|
+
['makePrimary', 'hideColumn', 'duplicateField', 'duplicateFieldWithContent'],
|
|
15
|
+
['sortAscending', 'sortDescending', 'filter'],
|
|
16
|
+
['delete'],
|
|
17
|
+
];
|
|
18
|
+
|
|
19
|
+
export function useHeaderActions<T, F extends FiltersMap>(
|
|
20
|
+
state: EditableTableState<T, F>,
|
|
21
|
+
columns: EditableColumn<T>[],
|
|
22
|
+
disabled?: boolean,
|
|
23
|
+
): Record<string, ReactNode> {
|
|
24
|
+
const { toolbar } = state;
|
|
25
|
+
const { customColumnsState, panels, toolbarFiltersState } = toolbar;
|
|
26
|
+
const { handlers: fieldActionHandlers, permissions: fieldActionPermissions } =
|
|
27
|
+
state.fieldActions;
|
|
28
|
+
const isDuplicating =
|
|
29
|
+
state.fieldActions.duplicateTask.status.isLoading ||
|
|
30
|
+
state.fieldActions.duplicateWithContentTask.status.isLoading;
|
|
31
|
+
const isMakingPrimary = state.fieldActions.makePrimaryTask.status.isLoading;
|
|
32
|
+
|
|
33
|
+
return useMemo(() => {
|
|
34
|
+
if (disabled) {
|
|
35
|
+
return {};
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
const result: Record<string, ReactNode> = {};
|
|
39
|
+
|
|
40
|
+
const loading: Partial<Record<FieldActionKey, boolean>> = {
|
|
41
|
+
makePrimary: isMakingPrimary,
|
|
42
|
+
duplicateField: isDuplicating,
|
|
43
|
+
duplicateFieldWithContent: isDuplicating,
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
for (const col of columns) {
|
|
47
|
+
const handlers: FieldActionHandlers = {};
|
|
48
|
+
|
|
49
|
+
if (fieldActionHandlers?.makePrimary) {
|
|
50
|
+
handlers.makePrimary = (id) => state.fieldActions.makePrimary(id);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
if (col.hideable !== false && customColumnsState) {
|
|
54
|
+
const toolbarColumn = toolbar.columns.find((c) => c.id === col.id);
|
|
55
|
+
if (toolbarColumn) {
|
|
56
|
+
handlers.hideColumn = () =>
|
|
57
|
+
customColumnsState.onColumnCheckboxToggle(toolbarColumn);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
if (fieldActionHandlers?.duplicateField) {
|
|
62
|
+
handlers.duplicateField = (id) => state.fieldActions.duplicate(id);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (fieldActionHandlers?.duplicateFieldWithContent) {
|
|
66
|
+
handlers.duplicateFieldWithContent = (id) =>
|
|
67
|
+
state.fieldActions.duplicateWithContent(id);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
if (col.sortable) {
|
|
71
|
+
handlers.sortAscending = (id) =>
|
|
72
|
+
state.sort(id, { forceDirection: 'asc' });
|
|
73
|
+
handlers.sortDescending = (id) =>
|
|
74
|
+
state.sort(id, { forceDirection: 'desc' });
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const hasFilter =
|
|
78
|
+
toolbarFiltersState &&
|
|
79
|
+
state.collection.query.customFilters[col.id] != null;
|
|
80
|
+
if (hasFilter) {
|
|
81
|
+
handlers.filter = () => panels.openSidePanel('filters');
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
if (fieldActionHandlers?.deleteField) {
|
|
85
|
+
handlers.delete = (id) => state.fieldActions.confirmDelete(id);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
const groups = buildFieldActionGroups({
|
|
89
|
+
column: col,
|
|
90
|
+
permissions: fieldActionPermissions,
|
|
91
|
+
handlers,
|
|
92
|
+
loading,
|
|
93
|
+
groups: FIELD_ACTION_GROUPS,
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
if (groups.length > 0) {
|
|
97
|
+
result[col.id] = (
|
|
98
|
+
<HeaderActionsPopover
|
|
99
|
+
actions={groups}
|
|
100
|
+
dataHook={`header-actions-${col.id}`}
|
|
101
|
+
/>
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
return result;
|
|
107
|
+
}, [
|
|
108
|
+
state,
|
|
109
|
+
columns,
|
|
110
|
+
toolbar,
|
|
111
|
+
customColumnsState,
|
|
112
|
+
panels,
|
|
113
|
+
toolbarFiltersState,
|
|
114
|
+
disabled,
|
|
115
|
+
fieldActionHandlers,
|
|
116
|
+
fieldActionPermissions,
|
|
117
|
+
isDuplicating,
|
|
118
|
+
isMakingPrimary,
|
|
119
|
+
]);
|
|
120
|
+
}
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../stylable-esm-runtime.js";
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "EntityPagePlain2692009362";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"EntityPagePlain2692009362__root"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../stylable-esm-runtime.js";
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var _namespace_ = "
|
|
8
|
+
var _namespace_ = "Fade2962062934";
|
|
9
9
|
var _style_ = classesRuntime.bind(null, _namespace_);
|
|
10
10
|
|
|
11
11
|
export var cssStates = statesRuntime.bind(null, _namespace_);
|
|
@@ -13,7 +13,7 @@ export var style = _style_;
|
|
|
13
13
|
export var st: import("@stylable/runtime").STFunction = _style_;
|
|
14
14
|
|
|
15
15
|
export var namespace = _namespace_;
|
|
16
|
-
export var classes = {"root":"
|
|
16
|
+
export var classes = {"root":"Fade2962062934__root"};
|
|
17
17
|
export var keyframes = {};
|
|
18
18
|
export var layers = {};
|
|
19
19
|
export var containers = {};
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import React, { type ReactNode } from 'react';
|
|
2
|
+
import {
|
|
3
|
+
SortAscendingSmall,
|
|
4
|
+
SortDescendingSmall,
|
|
5
|
+
ContentFilterSmall,
|
|
6
|
+
HiddenSmall,
|
|
7
|
+
DeleteSmall,
|
|
8
|
+
EditSmall,
|
|
9
|
+
FlagSmall,
|
|
10
|
+
DuplicateSmall,
|
|
11
|
+
} from '@wix/wix-ui-icons-common';
|
|
12
|
+
import type { HeaderAction } from './headerActionTypes';
|
|
13
|
+
|
|
14
|
+
export interface FieldActionPermissions {
|
|
15
|
+
schemaEditable?: boolean;
|
|
16
|
+
addDisabled?: boolean;
|
|
17
|
+
editDisabled?: boolean;
|
|
18
|
+
deleteDisabled?: boolean;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface FieldActionColumn {
|
|
22
|
+
isPrimary?: boolean;
|
|
23
|
+
isSystem?: boolean;
|
|
24
|
+
cellType?: string;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export type FieldActionKey =
|
|
28
|
+
| 'editField'
|
|
29
|
+
| 'makePrimary'
|
|
30
|
+
| 'hideColumn'
|
|
31
|
+
| 'duplicateField'
|
|
32
|
+
| 'duplicateFieldWithContent'
|
|
33
|
+
| 'sortAscending'
|
|
34
|
+
| 'sortDescending'
|
|
35
|
+
| 'filter'
|
|
36
|
+
| 'delete';
|
|
37
|
+
|
|
38
|
+
export type FieldActionDisableReason =
|
|
39
|
+
| 'schemaNotEditable'
|
|
40
|
+
| 'addDisabled'
|
|
41
|
+
| 'editDisabled'
|
|
42
|
+
| 'deleteDisabled'
|
|
43
|
+
| 'alreadyPrimary'
|
|
44
|
+
| 'systemField'
|
|
45
|
+
| 'nonTextField';
|
|
46
|
+
|
|
47
|
+
interface FieldActionDef {
|
|
48
|
+
label: string;
|
|
49
|
+
icon: ReactNode;
|
|
50
|
+
skin?: 'destructive';
|
|
51
|
+
getDisableReason?: (
|
|
52
|
+
col: FieldActionColumn,
|
|
53
|
+
perms: FieldActionPermissions | undefined,
|
|
54
|
+
) => FieldActionDisableReason | null;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const getReadOnlySchemaReason = (
|
|
58
|
+
perms: FieldActionPermissions | undefined,
|
|
59
|
+
): FieldActionDisableReason | null =>
|
|
60
|
+
perms?.schemaEditable === false ? 'schemaNotEditable' : null;
|
|
61
|
+
|
|
62
|
+
const checkEditPerms = (
|
|
63
|
+
col: FieldActionColumn,
|
|
64
|
+
perms: FieldActionPermissions | undefined,
|
|
65
|
+
): FieldActionDisableReason | null => {
|
|
66
|
+
const blocked = getReadOnlySchemaReason(perms);
|
|
67
|
+
if (blocked) {
|
|
68
|
+
return blocked;
|
|
69
|
+
}
|
|
70
|
+
if (perms?.editDisabled) {
|
|
71
|
+
return 'editDisabled';
|
|
72
|
+
}
|
|
73
|
+
if (col.isSystem) {
|
|
74
|
+
return 'systemField';
|
|
75
|
+
}
|
|
76
|
+
return null;
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
const checkAddPerms = (
|
|
80
|
+
col: FieldActionColumn,
|
|
81
|
+
perms: FieldActionPermissions | undefined,
|
|
82
|
+
): FieldActionDisableReason | null => {
|
|
83
|
+
const blocked = getReadOnlySchemaReason(perms);
|
|
84
|
+
if (blocked) {
|
|
85
|
+
return blocked;
|
|
86
|
+
}
|
|
87
|
+
if (perms?.addDisabled) {
|
|
88
|
+
return 'addDisabled';
|
|
89
|
+
}
|
|
90
|
+
if (col.isSystem) {
|
|
91
|
+
return 'systemField';
|
|
92
|
+
}
|
|
93
|
+
return null;
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const checkDeletePerms = (
|
|
97
|
+
col: FieldActionColumn,
|
|
98
|
+
perms: FieldActionPermissions | undefined,
|
|
99
|
+
): FieldActionDisableReason | null => {
|
|
100
|
+
const blocked = getReadOnlySchemaReason(perms);
|
|
101
|
+
if (blocked) {
|
|
102
|
+
return blocked;
|
|
103
|
+
}
|
|
104
|
+
if (perms?.deleteDisabled) {
|
|
105
|
+
return 'deleteDisabled';
|
|
106
|
+
}
|
|
107
|
+
if (col.isSystem) {
|
|
108
|
+
return 'systemField';
|
|
109
|
+
}
|
|
110
|
+
if (col.isPrimary) {
|
|
111
|
+
return 'alreadyPrimary';
|
|
112
|
+
}
|
|
113
|
+
return null;
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
export const FIELD_ACTIONS: Record<FieldActionKey, FieldActionDef> = {
|
|
117
|
+
editField: {
|
|
118
|
+
label: 'Edit Field',
|
|
119
|
+
icon: <EditSmall />,
|
|
120
|
+
getDisableReason: checkEditPerms,
|
|
121
|
+
},
|
|
122
|
+
makePrimary: {
|
|
123
|
+
label: 'Use as Primary Field',
|
|
124
|
+
icon: <FlagSmall />,
|
|
125
|
+
getDisableReason: (col, perms) => {
|
|
126
|
+
const blocked = getReadOnlySchemaReason(perms);
|
|
127
|
+
if (blocked) {
|
|
128
|
+
return blocked;
|
|
129
|
+
}
|
|
130
|
+
if (perms?.editDisabled) {
|
|
131
|
+
return 'editDisabled';
|
|
132
|
+
}
|
|
133
|
+
if (col.isPrimary) {
|
|
134
|
+
return 'alreadyPrimary';
|
|
135
|
+
}
|
|
136
|
+
if (col.isSystem) {
|
|
137
|
+
return 'systemField';
|
|
138
|
+
}
|
|
139
|
+
if (col.cellType !== 'text') {
|
|
140
|
+
return 'nonTextField';
|
|
141
|
+
}
|
|
142
|
+
return null;
|
|
143
|
+
},
|
|
144
|
+
},
|
|
145
|
+
hideColumn: {
|
|
146
|
+
label: 'Hide Column',
|
|
147
|
+
icon: <HiddenSmall />,
|
|
148
|
+
},
|
|
149
|
+
duplicateField: {
|
|
150
|
+
label: 'Duplicate Field',
|
|
151
|
+
icon: <DuplicateSmall />,
|
|
152
|
+
getDisableReason: checkAddPerms,
|
|
153
|
+
},
|
|
154
|
+
duplicateFieldWithContent: {
|
|
155
|
+
label: 'Duplicate Field with Content',
|
|
156
|
+
icon: <DuplicateSmall />,
|
|
157
|
+
getDisableReason: checkAddPerms,
|
|
158
|
+
},
|
|
159
|
+
sortAscending: {
|
|
160
|
+
label: 'Sort Ascending',
|
|
161
|
+
icon: <SortAscendingSmall />,
|
|
162
|
+
},
|
|
163
|
+
sortDescending: {
|
|
164
|
+
label: 'Sort Descending',
|
|
165
|
+
icon: <SortDescendingSmall />,
|
|
166
|
+
},
|
|
167
|
+
filter: {
|
|
168
|
+
label: 'Filter',
|
|
169
|
+
icon: <ContentFilterSmall />,
|
|
170
|
+
},
|
|
171
|
+
delete: {
|
|
172
|
+
label: 'Delete',
|
|
173
|
+
icon: <DeleteSmall />,
|
|
174
|
+
skin: 'destructive',
|
|
175
|
+
getDisableReason: checkDeletePerms,
|
|
176
|
+
},
|
|
177
|
+
};
|
|
178
|
+
|
|
179
|
+
export const FIELD_ACTION_DISABLE_REASON_TOOLTIPS: Record<
|
|
180
|
+
FieldActionDisableReason,
|
|
181
|
+
string
|
|
182
|
+
> = {
|
|
183
|
+
schemaNotEditable: 'This schema is read-only.',
|
|
184
|
+
addDisabled: 'Adding fields is disabled.',
|
|
185
|
+
editDisabled: 'Editing fields is disabled.',
|
|
186
|
+
deleteDisabled: 'Deleting fields is disabled.',
|
|
187
|
+
alreadyPrimary: 'This is the primary field.',
|
|
188
|
+
systemField: "System fields can't be modified.",
|
|
189
|
+
nonTextField: 'Only text fields can be made primary.',
|
|
190
|
+
};
|
|
191
|
+
|
|
192
|
+
export function getFieldActionDisableReason(
|
|
193
|
+
action: FieldActionKey,
|
|
194
|
+
column: FieldActionColumn,
|
|
195
|
+
permissions: FieldActionPermissions | undefined,
|
|
196
|
+
): FieldActionDisableReason | null {
|
|
197
|
+
return FIELD_ACTIONS[action].getDisableReason?.(column, permissions) ?? null;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
export function getFieldActionDisableState(
|
|
201
|
+
action: FieldActionKey,
|
|
202
|
+
column: FieldActionColumn,
|
|
203
|
+
permissions: FieldActionPermissions | undefined,
|
|
204
|
+
): { disabled: boolean; disabledTooltip: string | undefined } {
|
|
205
|
+
const reason = getFieldActionDisableReason(action, column, permissions);
|
|
206
|
+
return {
|
|
207
|
+
disabled: reason !== null,
|
|
208
|
+
disabledTooltip: reason
|
|
209
|
+
? FIELD_ACTION_DISABLE_REASON_TOOLTIPS[reason]
|
|
210
|
+
: undefined,
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
export type FieldActionHandlers = Partial<
|
|
215
|
+
Record<FieldActionKey, (id: string) => void>
|
|
216
|
+
>;
|
|
217
|
+
|
|
218
|
+
export function buildFieldActionGroups(args: {
|
|
219
|
+
column: FieldActionColumn & { id: string };
|
|
220
|
+
permissions?: FieldActionPermissions;
|
|
221
|
+
handlers: FieldActionHandlers;
|
|
222
|
+
loading?: Partial<Record<FieldActionKey, boolean>>;
|
|
223
|
+
groups: FieldActionKey[][];
|
|
224
|
+
}): HeaderAction[][] {
|
|
225
|
+
const { column, permissions, handlers, loading, groups } = args;
|
|
226
|
+
return groups
|
|
227
|
+
.map((group) =>
|
|
228
|
+
group.flatMap((key): HeaderAction[] => {
|
|
229
|
+
const handler = handlers[key];
|
|
230
|
+
if (!handler) {
|
|
231
|
+
return [];
|
|
232
|
+
}
|
|
233
|
+
const def = FIELD_ACTIONS[key];
|
|
234
|
+
const disable = getFieldActionDisableState(key, column, permissions);
|
|
235
|
+
return [
|
|
236
|
+
{
|
|
237
|
+
label: def.label,
|
|
238
|
+
icon: def.icon,
|
|
239
|
+
skin: def.skin,
|
|
240
|
+
onClick: () => handler(column.id),
|
|
241
|
+
loading: loading?.[key],
|
|
242
|
+
...disable,
|
|
243
|
+
},
|
|
244
|
+
];
|
|
245
|
+
}),
|
|
246
|
+
)
|
|
247
|
+
.filter((g) => g.length > 0);
|
|
248
|
+
}
|