@ynput/ayon-frontend-shared 0.2.38 → 0.2.40
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/DetailsPanel.cjs.js +1 -1
- package/dist/DetailsPanel.es.js +72 -66
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/ProjectTreeTable.cjs.js +1 -1
- package/dist/ProjectTreeTable.es.js +169 -167
- package/dist/ProjectTreeTable.es.js.map +1 -1
- package/dist/Views.cjs.js.map +1 -1
- package/dist/Views.es.js.map +1 -1
- package/dist/_virtual/index.cjs10.js +1 -1
- package/dist/_virtual/index.cjs11.js +1 -1
- package/dist/_virtual/index.cjs12.js +1 -1
- package/dist/_virtual/index.cjs2.js +1 -1
- package/dist/_virtual/index.cjs3.js +1 -1
- package/dist/_virtual/index.cjs4.js +1 -1
- package/dist/_virtual/index.es10.js +3 -3
- package/dist/_virtual/index.es11.js +5 -5
- package/dist/_virtual/index.es12.js +5 -5
- package/dist/_virtual/index.es2.js +5 -2
- package/dist/_virtual/index.es2.js.map +1 -1
- package/dist/_virtual/index.es3.js +2 -5
- package/dist/_virtual/index.es3.js.map +1 -1
- package/dist/_virtual/index.es4.js +2 -2
- package/dist/api.cjs.js +1 -1
- package/dist/api.es.js +22 -20
- package/dist/api.es.js.map +1 -1
- package/dist/components.cjs.js +1 -1
- package/dist/components.es.js +139 -133
- package/dist/components.es.js.map +1 -1
- package/dist/context.cjs.js +1 -1
- package/dist/context.es.js +45 -38
- package/dist/context.es.js.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +61 -55
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/react-use-websocket/dist/index.cjs.js +1 -1
- package/dist/node_modules/react-use-websocket/dist/index.es.js +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
- package/dist/node_modules/rehype/node_modules/vfile/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype/node_modules/vfile/lib/index.es.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
- package/dist/shared/node_modules/prop-types/index.cjs.js +1 -1
- package/dist/shared/node_modules/prop-types/index.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.es.js +1 -1
- package/dist/shared/src/api/generated/graphql.cjs.js +4 -0
- package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.es.js +4 -0
- package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
- package/dist/shared/src/api/generated/graphqlLinks.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphqlLinks.es.js.map +1 -1
- package/dist/shared/src/api/generated/views.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/views.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +8 -3
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.es.js +4 -3
- package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.es.js +70 -66
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/uris/getUris.cjs.js +2 -0
- package/dist/shared/src/api/queries/uris/getUris.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/uris/getUris.es.js +47 -0
- package/dist/shared/src/api/queries/uris/getUris.es.js.map +1 -0
- package/dist/shared/src/api/queries/users/getUsers.cjs.js +1 -1
- package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.es.js +19 -18
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/components/AddonLoadingScreen/AddonLoadingScreen.cjs.js +28 -0
- package/dist/shared/src/components/AddonLoadingScreen/AddonLoadingScreen.cjs.js.map +1 -0
- package/dist/shared/src/components/AddonLoadingScreen/AddonLoadingScreen.es.js +54 -0
- package/dist/shared/src/components/AddonLoadingScreen/AddonLoadingScreen.es.js.map +1 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +3 -2
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +5 -2
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js +5 -2
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js +5 -2
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js +5 -2
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js.map +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +75 -69
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
- package/dist/shared/src/components/EntityPath/EntityPath.cjs.js +1 -1
- package/dist/shared/src/components/EntityPath/EntityPath.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPath/EntityPath.es.js +51 -53
- package/dist/shared/src/components/EntityPath/EntityPath.es.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js +4 -2
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js.map +1 -1
- package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js +1 -1
- package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js.map +1 -1
- package/dist/shared/src/components/Feedback/FeedbackContext.es.js +7 -4
- package/dist/shared/src/components/Feedback/FeedbackContext.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js +1 -1
- package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/AddNewLinks.es.js +60 -54
- package/dist/shared/src/components/LinksManager/AddNewLinks.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js +1 -1
- package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js +3 -2
- package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js +1 -1
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js +66 -60
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js.map +1 -1
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js +1 -1
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js.map +1 -1
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js +5 -2
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js.map +1 -1
- package/dist/shared/src/components/Menu/Menu.cjs.js +2 -0
- package/dist/shared/src/components/Menu/Menu.cjs.js.map +1 -0
- package/dist/shared/src/components/Menu/Menu.es.js +92 -0
- package/dist/shared/src/components/Menu/Menu.es.js.map +1 -0
- package/dist/shared/src/components/Menu/Menu.styled.cjs.js.map +1 -0
- package/dist/shared/src/components/Menu/Menu.styled.es.js.map +1 -0
- package/dist/shared/src/components/Menu/MenuContainer.cjs.js +2 -0
- package/dist/shared/src/components/Menu/MenuContainer.cjs.js.map +1 -0
- package/dist/shared/src/components/Menu/MenuContainer.es.js +88 -0
- package/dist/shared/src/components/Menu/MenuContainer.es.js.map +1 -0
- package/dist/shared/src/components/Menu/MenuItem.cjs.js +2 -0
- package/dist/shared/src/components/Menu/MenuItem.cjs.js.map +1 -0
- package/dist/{src/components/Menu/MenuComponents → shared/src/components/Menu}/MenuItem.es.js +26 -24
- package/dist/shared/src/components/Menu/MenuItem.es.js.map +1 -0
- package/dist/shared/src/components/Menu/MenuList.cjs.js +2 -0
- package/dist/shared/src/components/Menu/MenuList.cjs.js.map +1 -0
- package/dist/shared/src/components/Menu/MenuList.es.js +131 -0
- package/dist/shared/src/components/Menu/MenuList.es.js.map +1 -0
- package/dist/shared/src/components/Menu/useMenuPosition.cjs.js +2 -0
- package/dist/shared/src/components/Menu/useMenuPosition.cjs.js.map +1 -0
- package/dist/shared/src/components/Menu/useMenuPosition.es.js +50 -0
- package/dist/shared/src/components/Menu/useMenuPosition.es.js.map +1 -0
- package/dist/shared/src/components/Powerpack/PowerpackButton.cjs.js +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackButton.cjs.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackButton.es.js +7 -5
- package/dist/shared/src/components/Powerpack/PowerpackButton.es.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +49 -43
- package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +46 -40
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +48 -42
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/components/RenameForm/RenameForm.cjs.js +1 -1
- package/dist/shared/src/components/RenameForm/RenameForm.cjs.js.map +1 -1
- package/dist/shared/src/components/RenameForm/RenameForm.es.js +66 -60
- package/dist/shared/src/components/RenameForm/RenameForm.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +3 -2
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +64 -58
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +54 -48
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +53 -47
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js +3 -2
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +1 -1
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +219 -190
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js +2 -2
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js +20 -18
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +52 -46
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js +2 -2
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js +13 -11
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +2 -2
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +56 -50
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js +1 -1
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js +5 -4
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.cjs.js +1 -1
- package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.es.js +3 -2
- package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +53 -47
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.es.js +5 -2
- package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +54 -48
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +293 -229
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.styled.cjs.js +10 -4
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.styled.es.js +13 -7
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.styled.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +49 -43
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +68 -62
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +92 -86
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +9 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.es.js +194 -5
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js +4 -2
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useDetailsPanelURLSync.cjs.js +2 -0
- package/dist/shared/src/containers/DetailsPanel/hooks/useDetailsPanelURLSync.cjs.js.map +1 -0
- package/dist/shared/src/containers/DetailsPanel/hooks/useDetailsPanelURLSync.es.js +21 -0
- package/dist/shared/src/containers/DetailsPanel/hooks/useDetailsPanelURLSync.es.js.map +1 -0
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +20 -17
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js +49 -43
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js +53 -47
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js +53 -47
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js +53 -47
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js +5 -2
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.es.js +109 -99
- package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js +446 -212
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.cjs.js +20 -16
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js +21 -17
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.cjs.js +2 -0
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.cjs.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.es.js +288 -0
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.es.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityItem.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityItem.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityItem.es.js +23 -11
- package/dist/shared/src/containers/Feed/components/ActivityItem.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js +4 -2
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js +2 -2
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js +372 -183
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js +4 -2
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js +12 -10
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.es.js +28 -26
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js +194 -5
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js +8 -5
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +3 -2
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useScrollToHighlighted.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/hooks/useScrollToHighlighted.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useScrollToHighlighted.es.js +24 -26
- package/dist/shared/src/containers/Feed/hooks/useScrollToHighlighted.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +434 -435
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +126 -120
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js +2 -2
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js +52 -46
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +57 -51
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js +79 -72
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +7 -4
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +72 -65
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +47 -41
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +12 -10
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +8 -5
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +5 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +55 -49
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +81 -66
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js +51 -45
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +106 -111
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +51 -45
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.es.js +51 -45
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +54 -48
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js +122 -119
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js +61 -55
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +45 -39
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js +98 -94
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +62 -56
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/queryFilterToClientFilter.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/queryFilterToClientFilter.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/queryFilterToClientFilter.es.js +22 -20
- package/dist/shared/src/containers/ProjectTreeTable/utils/queryFilterToClientFilter.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +2 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +19 -17
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js +68 -62
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js +51 -45
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.es.js +45 -44
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.es.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +120 -114
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
- package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js +1 -1
- package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js +53 -47
- package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js +1 -1
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js +5 -2
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.es.js +14 -12
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.es.js.map +1 -1
- package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js +1 -1
- package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/context/ViewsContext.es.js +90 -91
- package/dist/shared/src/containers/Views/context/ViewsContext.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js +5 -2
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js +5 -2
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js +3 -2
- package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js +3 -2
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js.map +1 -1
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js +1 -1
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js +3 -2
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js.map +1 -1
- package/dist/shared/src/context/AddonProjectContext.cjs.js +1 -1
- package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
- package/dist/shared/src/context/AddonProjectContext.es.js +5 -4
- package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js +1 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js +117 -75
- package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
- package/dist/shared/src/context/GlobalContext.cjs.js +1 -1
- package/dist/shared/src/context/GlobalContext.cjs.js.map +1 -1
- package/dist/shared/src/context/GlobalContext.es.js +5 -4
- package/dist/shared/src/context/GlobalContext.es.js.map +1 -1
- package/dist/shared/src/context/PowerpackContext.cjs.js +1 -1
- package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
- package/dist/shared/src/context/PowerpackContext.es.js +18 -15
- package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
- package/dist/shared/src/context/ProjectContext.cjs.js +1 -1
- package/dist/shared/src/context/ProjectContext.cjs.js.map +1 -1
- package/dist/shared/src/context/ProjectContext.es.js +44 -40
- package/dist/shared/src/context/ProjectContext.es.js.map +1 -1
- package/dist/shared/src/context/ProjectFoldersContext.cjs.js +2 -0
- package/dist/shared/src/context/ProjectFoldersContext.cjs.js.map +1 -0
- package/dist/shared/src/context/ProjectFoldersContext.es.js +177 -0
- package/dist/shared/src/context/ProjectFoldersContext.es.js.map +1 -0
- package/dist/shared/src/context/RemoteModulesContext.cjs.js +1 -1
- package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.es.js +5 -4
- package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
- package/dist/shared/src/context/UriContext.cjs.js +2 -0
- package/dist/shared/src/context/UriContext.cjs.js.map +1 -0
- package/dist/shared/src/context/UriContext.es.js +131 -0
- package/dist/shared/src/context/UriContext.es.js.map +1 -0
- package/dist/shared/src/context/WebsocketContext.cjs.js +1 -1
- package/dist/shared/src/context/WebsocketContext.cjs.js.map +1 -1
- package/dist/shared/src/context/WebsocketContext.es.js +51 -45
- package/dist/shared/src/context/WebsocketContext.es.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.cjs.js +1 -1
- package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.es.js +3 -2
- package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.es.js +5 -2
- package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
- package/dist/shared/src/hooks/useGetEntityGroups.cjs.js +1 -1
- package/dist/shared/src/hooks/useGetEntityGroups.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useGetEntityGroups.es.js +3 -2
- package/dist/shared/src/hooks/useGetEntityGroups.es.js.map +1 -1
- package/dist/shared/src/hooks/useGroupByRemoteModules.cjs.js +1 -1
- package/dist/shared/src/hooks/useGroupByRemoteModules.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useGroupByRemoteModules.es.js +5 -2
- package/dist/shared/src/hooks/useGroupByRemoteModules.es.js.map +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.cjs.js +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.es.js +43 -119
- package/dist/shared/src/hooks/useHierarchyTable.es.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.es.js +5 -4
- package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.es.js +5 -2
- package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
- package/dist/shared/src/util/extractEntityHierarchyFromParents.cjs.js +2 -0
- package/dist/shared/src/util/extractEntityHierarchyFromParents.cjs.js.map +1 -0
- package/dist/shared/src/util/extractEntityHierarchyFromParents.es.js +25 -0
- package/dist/shared/src/util/extractEntityHierarchyFromParents.es.js.map +1 -0
- package/dist/shared/src/util/uriUtils.cjs.js +2 -0
- package/dist/shared/src/util/uriUtils.cjs.js.map +1 -0
- package/dist/shared/src/util/uriUtils.es.js +49 -0
- package/dist/shared/src/util/uriUtils.es.js.map +1 -0
- package/dist/types/api/generated/graphql.d.ts +55 -4
- package/dist/types/api/generated/graphqlLinks.d.ts +47 -0
- package/dist/types/api/generated/views.d.ts +15 -13
- package/dist/types/api/queries/entities/transformDetailsPanelData.d.ts +1 -0
- package/dist/types/api/queries/entityLists/getLists.d.ts +180 -180
- package/dist/types/api/queries/index.d.ts +1 -0
- package/dist/types/api/queries/uris/getUris.d.ts +161 -0
- package/dist/types/api/queries/uris/index.d.ts +1 -0
- package/dist/types/components/AddonLoadingScreen/AddonLoadingScreen.d.ts +25 -0
- package/dist/types/components/AddonLoadingScreen/index.d.ts +1 -0
- package/dist/types/components/Menu/Menu.d.ts +30 -0
- package/dist/types/components/Menu/Menu.styled.d.ts +8 -0
- package/dist/types/components/Menu/MenuContainer.d.ts +14 -0
- package/dist/types/components/Menu/MenuItem.d.ts +21 -0
- package/dist/types/components/Menu/MenuList.d.ts +21 -0
- package/dist/types/components/Menu/index.d.ts +4 -0
- package/dist/types/components/Menu/useMenuPosition.d.ts +12 -0
- package/dist/types/components/SearchFilter/useBuildFilterOptions.d.ts +3 -1
- package/dist/types/components/index.d.ts +32 -31
- package/dist/types/containers/DetailsPanel/DetailsPanel.d.ts +6 -2
- package/dist/types/containers/DetailsPanel/FeedWrapper.d.ts +1 -0
- package/dist/types/containers/DetailsPanel/hooks/useDetailsPanelURLSync.d.ts +12 -0
- package/dist/types/containers/Feed/Feed.d.ts +2 -1
- package/dist/types/containers/Feed/components/ActivityComment/ActivityComment.d.ts +2 -1
- package/dist/types/containers/Feed/components/ActivityComment/ActivityCommentMenu.d.ts +9 -0
- package/dist/types/containers/Feed/components/ActivityItem.d.ts +1 -0
- package/dist/types/containers/Feed/hooks/useScrollToHighlighted.d.ts +2 -1
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +2 -0
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +4 -1
- package/dist/types/containers/ProjectTreeTable/hooks/useUpdateTableData.d.ts +1 -0
- package/dist/types/containers/Views/index.d.ts +1 -1
- package/dist/types/context/AddonProjectContext.d.ts +12 -7
- package/dist/types/context/DetailsPanelContext.d.ts +1 -0
- package/dist/types/context/ProjectFoldersContext.d.ts +19 -0
- package/dist/types/context/UriContext.d.ts +40 -0
- package/dist/types/context/index.d.ts +2 -0
- package/dist/types/hooks/useGroupByRemoteModules.d.ts +1 -2
- package/dist/types/util/extractEntityHierarchyFromParents.d.ts +6 -0
- package/dist/types/util/index.d.ts +2 -0
- package/dist/types/util/uriUtils.d.ts +15 -0
- package/dist/util.cjs.js +1 -1
- package/dist/util.es.js +44 -37
- package/dist/util.es.js.map +1 -1
- package/package.json +1 -1
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.cjs.js +0 -2
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.cjs.js.map +0 -1
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.es.js +0 -263
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.es.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/Menu.cjs.js +0 -2
- package/dist/src/components/Menu/MenuComponents/Menu.cjs.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/Menu.es.js +0 -82
- package/dist/src/components/Menu/MenuComponents/Menu.es.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/Menu.styled.cjs.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/Menu.styled.es.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/MenuContainer2.cjs.js +0 -2
- package/dist/src/components/Menu/MenuComponents/MenuContainer2.cjs.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/MenuContainer2.es.js +0 -80
- package/dist/src/components/Menu/MenuComponents/MenuContainer2.es.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/MenuItem.cjs.js +0 -2
- package/dist/src/components/Menu/MenuComponents/MenuItem.cjs.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/MenuItem.es.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/MenuList.cjs.js +0 -2
- package/dist/src/components/Menu/MenuComponents/MenuList.cjs.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/MenuList.es.js +0 -135
- package/dist/src/components/Menu/MenuComponents/MenuList.es.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/useMenuPosition.cjs.js +0 -2
- package/dist/src/components/Menu/MenuComponents/useMenuPosition.cjs.js.map +0 -1
- package/dist/src/components/Menu/MenuComponents/useMenuPosition.es.js +0 -35
- package/dist/src/components/Menu/MenuComponents/useMenuPosition.es.js.map +0 -1
- package/dist/types/components/RemotePage/RemotePageWrapper.d.ts +0 -29
- package/dist/types/components/RemotePage/index.d.ts +0 -1
- /package/dist/{src/components/Menu/MenuComponents → shared/src/components/Menu}/Menu.styled.cjs.js +0 -0
- /package/dist/{src/components/Menu/MenuComponents → shared/src/components/Menu}/Menu.styled.es.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useBuildFilterOptions.cjs.js","sources":["../../../../../src/components/SearchFilter/useBuildFilterOptions.tsx"],"sourcesContent":["import { getAttributeIcon, getEntityTypeIcon } from '@shared/util'\nimport {\n useGetEntityGroupsQuery,\n useGetKanbanProjectUsersQuery,\n useGetProjectsInfoQuery,\n} from '@shared/api'\nimport type {\n GetProjectsInfoResponse,\n FolderType,\n Status,\n Tag,\n TaskType,\n AttributeModel,\n AttributeEnumItem,\n AttributeData,\n EntityGroup,\n} from '@shared/api'\nimport { ColumnOrderState } from '@tanstack/react-table'\nimport { Icon, Option, Filter } from '@ynput/ayon-react-components'\nimport { dateOptions } from './filterDates'\nimport { isEmpty } from 'lodash'\nimport { SliceFilter } from '@shared/containers'\nimport { FEATURED_VERSION_TYPES } from '../FeaturedVersionOrder'\nimport { useGlobalContext } from '@shared/context'\n\ntype ScopeType = 'folder' | 'product' | 'task' | 'user' | 'version'\ntype Scope = ScopeType | ScopeType[]\n\nexport type ScopeWithFilterTypes = {\n scope: ScopeType\n filterTypes: FilterFieldType[]\n}\n\nexport type FilterFieldType =\n | 'folderType'\n | 'taskType'\n | 'productType'\n | ('users' | 'assignees' | 'author')\n | 'attributes'\n | 'status'\n | 'tags'\n | 'version'\n | 'hasReviewables'\ntype AttributeType =\n | string\n | number\n | boolean\n | Date\n | string[]\n | number[]\n | any[]\n | { [key: string]: any }\n\ntype AttributeDataValue = AttributeType | null | undefined\n\ntype FilterConfig = {\n enableExcludes?: boolean\n enableOperatorChange?: boolean\n enableRelativeValues?: boolean\n prefixes?: Partial<Record<FilterFieldType, string>> // strings that will be prepended to the id of the option\n keys?: Partial<Record<FilterFieldType, string>> // replaces the default keys for the filter\n}\n\nexport type BuildFilterOptions = {\n filterTypes?: FilterFieldType[]\n projectNames: string[]\n scope?: Scope\n scopes?: ScopeWithFilterTypes[]\n data: {\n tags?: string[]\n attributes?: Record<string, AttributeDataValue[]>\n assignees?: string[]\n productTypes?: ProductType[]\n }\n columnOrder?: ColumnOrderState\n config?: FilterConfig\n power?: boolean\n}\n\nexport const useBuildFilterOptions = ({\n filterTypes: globalFilterTypes = [],\n projectNames,\n scope,\n scopes: customScopes,\n data,\n config,\n columnOrder = [],\n power,\n}: BuildFilterOptions): Option[] => {\n let options: Option[] = []\n\n // Determine which scopes to use\n // If customScopes is provided, use it; otherwise, fall back to the old method\n const scopesWithTypes: Array<{ scope: ScopeType; filterTypes: FilterFieldType[] }> = customScopes\n ? customScopes\n : (() => {\n // Fallback to old method: normalize scope to array and use globalFilterTypes for all\n const normalizedScopes = scope ? (Array.isArray(scope) ? scope : [scope]) : []\n return normalizedScopes.map((s) => ({\n scope: s,\n filterTypes: globalFilterTypes,\n }))\n })()\n\n const isMultiScope = scopesWithTypes.length > 1\n\n // QUERIES\n //\n //\n // Check if any scope needs these filter types\n const anyNeedsEntitySubType = scopesWithTypes.some((s) =>\n ['entitySubType', 'status'].some((type) => s.filterTypes.includes(type as FilterFieldType)),\n )\n const anyNeedsUsers = scopesWithTypes.some((s) =>\n ['assignees', 'users', 'author'].some((type) =>\n s.filterTypes.includes(type as FilterFieldType),\n ),\n )\n // find if any search field is in any of the scopesWithTypes\n const fieldInScopes = (field: FilterFieldType): boolean => {\n return scopesWithTypes.some((s) => s.filterTypes.includes(field))\n }\n\n // get grouping options for productTypes\n // NOTE: We should revisit this to be used for all attribs and fields\n const { data: { groups: productTypes = [] } = {} } = useGetEntityGroupsQuery(\n {\n entityType: 'product',\n groupingKey: 'productType',\n projectName: projectNames[0],\n empty: true,\n },\n { skip: !projectNames?.length || !fieldInScopes('productType') },\n )\n\n const { data: projectsInfo = {} } = useGetProjectsInfoQuery(\n {\n projects: projectNames,\n },\n {\n skip: !projectNames?.length || !anyNeedsEntitySubType,\n },\n )\n\n const { data: projectUsers = [] } = useGetKanbanProjectUsersQuery(\n { projects: projectNames },\n {\n skip: !projectNames?.length || !anyNeedsUsers,\n },\n )\n\n const { attributes } = useGlobalContext()\n //\n //\n // QUERIES\n\n // ADD OPTIONS\n\n // Helper to get scope label (capitalize first letter)\n const getScopeLabel = (scope: ScopeType) => scope.charAt(0).toUpperCase() + scope.slice(1)\n\n // Loop through each scope to build options\n scopesWithTypes.forEach(({ scope: currentScope, filterTypes: scopeFilterTypes }) => {\n const scopePrefix = isMultiScope ? currentScope : undefined\n const scopeLabel = isMultiScope ? getScopeLabel(currentScope) : undefined\n\n // TASK TYPE\n // add taskType option\n if (scopeFilterTypes.includes('taskType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'taskType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'task')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // FOLDER TYPE\n // add folderType option\n if (scopeFilterTypes.includes('folderType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'folderType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'folder')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // PRODUCT TYPE\n // add productType option\n if (scopeFilterTypes.includes('productType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'productType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'product')\n entitySubTypeOption.values?.push(...subTypes)\n options.push(entitySubTypeOption)\n }\n }\n\n // STATUS\n // add status option\n if (scopeFilterTypes.includes('status')) {\n const statusOption = getOptionRoot(\n 'status',\n { ...config, enableOperatorChange: false },\n scopePrefix,\n scopeLabel,\n )\n\n if (statusOption) {\n Object.values(projectsInfo).forEach((project) => {\n const statuses = project?.statuses || []\n statuses\n .filter((status) => status.scope?.includes(currentScope))\n .forEach((status: Status) => {\n if (!statusOption.values?.some((value) => value.id === status.name)) {\n statusOption.values?.push({\n id: status.name,\n label: status.name,\n icon: status.icon,\n color: status.color,\n })\n }\n })\n })\n\n options.push(statusOption)\n }\n }\n\n // ASSIGNEES\n // add users/assignees option\n if (scopeFilterTypes.includes('assignees')) {\n const assigneesOption = getOptionRoot('assignees', config, scopePrefix, scopeLabel)\n\n if (assigneesOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!assigneesOption.values?.some((value) => value.id === user.name)) {\n assigneesOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n\n // sort the assignees based on the number of times they appear in data.assignees\n assigneesOption.values?.sort((a, b) => {\n const aCount = data.assignees?.filter((assignee) => assignee === a.id).length || 0\n const bCount = data.assignees?.filter((assignee) => assignee === b.id).length || 0\n return bCount - aCount\n })\n\n options.push(assigneesOption)\n }\n }\n\n if (scopeFilterTypes.includes('author')) {\n const authorOption = getOptionRoot('author', config, scopePrefix, scopeLabel)\n if (authorOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!authorOption.values?.some((value) => value.id === user.name)) {\n authorOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n options.push(authorOption)\n }\n }\n\n // TAGS\n // add tags options\n if (scopeFilterTypes.includes('tags')) {\n const tagsOption = getOptionRoot('tags', config, scopePrefix, scopeLabel)\n\n if (tagsOption) {\n // reduce projectsInfo to get all tags\n const tagsAnatomy = new Map<string, Tag>()\n Object.values(projectsInfo).forEach((project) => {\n if (project?.tags) {\n project.tags.forEach((tag) => {\n if (!tagsAnatomy.has(tag.name)) {\n tagsAnatomy.set(tag.name, tag)\n }\n })\n }\n })\n\n // create options for each tag, finding color if in tagsAnatomy\n const tagOptionValuesMap = new Map<string, Option & { count: number }>()\n data.tags?.forEach((tag) => {\n const existingTag = tagOptionValuesMap.get(tag)\n if (existingTag) {\n // increment count\n existingTag.count++\n return\n } else {\n // create new tag\n const tagData = tagsAnatomy.get(tag)\n\n tagOptionValuesMap.set(tag, {\n id: tag,\n type: 'string',\n label: tag,\n values: [],\n color: tagData?.color || null,\n count: 1,\n })\n }\n })\n\n // convert values map to array and sort based on count\n const tagOptionValues = Array.from(tagOptionValuesMap.values()).sort(\n (a, b) => b.count - a.count,\n )\n\n // add tag options to the tagsOption\n tagsOption.values?.push(...tagOptionValues)\n\n options.push(tagsOption)\n }\n }\n\n // VERSION\n // add version options\n if (scopeFilterTypes.includes('version')) {\n const versionOption = getOptionRoot('version', config, scopePrefix, scopeLabel)\n\n if (versionOption) {\n // add featured version types as options\n FEATURED_VERSION_TYPES.forEach((versionType) => {\n versionOption.values?.push({\n id: versionType.value,\n label: versionType.label,\n icon: versionType.icon,\n })\n })\n\n options.push(versionOption)\n }\n }\n\n // HAS REVIEWABLES\n // add hasReviewables option\n if (scopeFilterTypes.includes('hasReviewables')) {\n const hasReviewablesOption = getOptionRoot('hasReviewables', config, scopePrefix, scopeLabel)\n\n if (hasReviewablesOption) {\n const options_list = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n hasReviewablesOption.values?.push(...options_list)\n options.push(hasReviewablesOption)\n }\n }\n\n // ATTRIBUTES\n // dynamically add attributes options\n if (scopeFilterTypes.includes('attributes')) {\n const attributesByScope = attributes.filter((attribute) =>\n attribute.scope?.includes(currentScope),\n )\n // if attributesData is provided, filter out attributes that are not in the attributesData\n const attributesByValues = !isEmpty(data.attributes)\n ? attributesByScope.filter(\n (attribute) => data.attributes && data.attributes[attribute.name],\n )\n : attributesByScope\n\n const attributesWithoutDates = config?.enableRelativeValues\n ? attributesByValues\n : attributesByValues.filter((attribute) => attribute.data.type !== 'datetime')\n\n attributesWithoutDates.forEach((attribute) => {\n const realData = data.attributes && data.attributes[attribute.name]\n const enums = attribute.data.enum\n const type = attribute.data.type\n\n const isListOf = [\n 'list_of_strings',\n 'list_of_integers',\n 'list_of_any',\n 'list_of_submodels',\n ].includes(type || '')\n const isDate = type === 'datetime'\n const enableOperatorChange = isListOf ? config?.enableOperatorChange : false\n const enableRelativeValues = isListOf || isDate ? config?.enableRelativeValues : false\n // for the attribute, get the option root\n const option = getAttributeFieldOptionRoot(\n attribute,\n {\n ...config,\n allowsCustomValues: true,\n enableOperatorChange: enableOperatorChange,\n enableRelativeValues: enableRelativeValues,\n },\n scopePrefix,\n scopeLabel,\n )\n\n const suggestValuesForTypes: AttributeData['type'][] = [\n 'string',\n 'integer',\n 'float',\n 'list_of_strings',\n 'list_of_integers',\n ]\n\n const optionValues: Option[] = []\n\n // if the attribute type is in the suggestValuesForTypes, get the options based on real values\n if (suggestValuesForTypes.includes(type)) {\n const options = getAttributeOptions(realData, enums, type)\n optionValues.push(...options)\n }\n\n // if the attribute type is boolean, add yes/no options\n if (type === 'boolean') {\n const options = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n optionValues.push(...options)\n }\n\n // if the attribute type is datetime, add datetime options\n\n if (isDate) {\n optionValues.push(\n ...dateOptions.map((o) => ({\n ...o,\n contentAfter: power ? undefined : <Icon icon=\"bolt\" />,\n })),\n )\n }\n\n // add option to the list of options\n option.values?.push(...optionValues)\n\n // add option to the list of options\n options.push(option)\n })\n }\n }) // End of scopes.forEach loop\n\n // order options by columnOrder\n if (columnOrder) {\n return sortOptionsBasedOnColumns(options, columnOrder)\n } else return options\n}\n\n// HELPER FUNCTIONS\n//\n//\n//\n//\nconst getSubTypes = (\n {\n projectsInfo,\n productTypes,\n }: { projectsInfo: GetProjectsInfoResponse; productTypes: EntityGroup[] },\n type: ScopeType,\n): Option[] => {\n const options: Option[] = []\n if (type === 'product') {\n productTypes.forEach(({ icon, label, value }) => {\n options.push({\n id: value,\n type: 'string',\n label: label || value,\n icon: icon || getEntityTypeIcon('product'),\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n })\n } else if (type === 'task') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all task types and add them to the options (if they don't already exist)\n const taskTypes = project?.taskTypes || []\n taskTypes.forEach((taskType: TaskType) => {\n if (!options.some((option) => option.id === taskType.name)) {\n options.push({\n id: taskType.name,\n type: 'string',\n label: taskType.name,\n icon: taskType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n } else if (type === 'folder') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all folder types and add them to the options (if they don't already exist)\n const folderTypes = project?.folderTypes || []\n folderTypes.forEach((folderType: FolderType) => {\n if (!options.some((option) => option.id === folderType.name)) {\n options.push({\n id: folderType.name,\n type: 'string',\n label: folderType.name,\n icon: folderType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n }\n\n return options\n}\n\nconst getFormattedId = (\n base: string,\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n) => {\n const { prefixes, keys } = config || {}\n let result = base\n\n if (keys && fieldType in keys) {\n result = `${keys[fieldType]}`\n } else if (prefixes && fieldType in prefixes) {\n result = `${prefixes[fieldType]}${base}`\n }\n\n // Add scope prefix if provided\n if (scopePrefix) {\n result = `${scopePrefix}_${result}`\n }\n\n return result\n}\n\nconst formatLabel = (baseLabel: string, scopeLabel?: string) =>\n scopeLabel ? `${baseLabel} - ${scopeLabel}` : baseLabel\n\nconst getOptionRoot = (\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n scopeLabel?: string,\n) => {\n const getRootIdWithPrefix = (base: string) => getFormattedId(base, fieldType, config, scopePrefix)\n const formatLabelWithScope = (baseLabel: string) => formatLabel(baseLabel, scopeLabel)\n\n let rootOption: Option | null = null\n switch (fieldType) {\n case 'taskType':\n rootOption = {\n id: getRootIdWithPrefix(`taskType`),\n type: 'string',\n label: formatLabelWithScope(`Task Type`),\n icon: getAttributeIcon('task'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'folderType':\n rootOption = {\n id: getRootIdWithPrefix(`folderType`),\n type: 'string',\n label: formatLabelWithScope(`Folder Type`),\n icon: getAttributeIcon('folder'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productType':\n rootOption = {\n id: getRootIdWithPrefix(`productType`),\n type: 'string',\n label: formatLabelWithScope(`Product Type`),\n icon: getAttributeIcon('product'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'status':\n rootOption = {\n id: getRootIdWithPrefix('status'),\n type: 'string',\n label: formatLabelWithScope('Status'),\n icon: getAttributeIcon('status'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'assignees':\n rootOption = {\n id: getRootIdWithPrefix('assignees'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Assignee'),\n icon: getAttributeIcon('assignees'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'author':\n rootOption = {\n id: getRootIdWithPrefix('author'),\n type: 'string',\n label: formatLabelWithScope('Author'),\n icon: getAttributeIcon('author'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'tags':\n rootOption = {\n id: getRootIdWithPrefix('tags'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Tags'),\n icon: getAttributeIcon('tags'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'version':\n rootOption = {\n id: getRootIdWithPrefix('version'),\n type: 'string',\n label: formatLabelWithScope('Version'),\n icon: getAttributeIcon('version'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: false,\n }\n break\n case 'hasReviewables':\n rootOption = {\n id: getRootIdWithPrefix('hasReviewables'),\n type: 'boolean',\n label: formatLabelWithScope('Has Reviewables'),\n icon: 'play_circle',\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n singleSelect: true,\n }\n break\n default:\n break\n\n // Note: attributes are handled separately\n }\n\n return rootOption\n}\n\nconst getAttributeFieldOptionRoot = (\n attribute: AttributeModel,\n config: FilterConfig & { allowsCustomValues: boolean },\n scopePrefix?: string,\n scopeLabel?: string,\n): Option => ({\n id: getFormattedId(attribute.name, 'attributes', config, scopePrefix),\n type: attribute.data.type,\n label: scopeLabel\n ? formatLabel(attribute.data.title || attribute.name, scopeLabel)\n : attribute.data.title || attribute.name,\n operator: 'OR',\n inverted: false,\n values: [],\n allowsCustomValues: config?.allowsCustomValues,\n allowHasValue: config.enableRelativeValues,\n allowNoValue: config.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n icon: getAttributeIcon(attribute.name, attribute.data.type, !!attribute.data.enum?.length),\n singleSelect: ['boolean', 'datetime'].includes(attribute.data.type || ''),\n})\n\nconst getAttributeOptions = (\n values?: AttributeDataValue[],\n enums?: AttributeEnumItem[],\n type?: AttributeData['type'],\n): Option[] => {\n const enumOptions: Option[] = []\n const options: (Option & { count: number })[] = []\n\n // add the enum values first\n if (enums) {\n enums.forEach((enumItem) => {\n enumOptions.push({\n id: enumItem.value.toString(),\n type: type,\n label: enumItem.label,\n values: [],\n icon: enumItem.icon,\n color: enumItem.color,\n })\n })\n }\n\n values?.forEach((value) => {\n // no value? do nothing\n if (!value) return\n\n let text = ''\n\n // convert value to text\n switch (typeof value) {\n case 'string':\n case 'number':\n case 'boolean':\n text = value.toString()\n break\n case 'object':\n if (Array.isArray(value)) {\n text = value.join(', ')\n } else {\n text = JSON.stringify(value)\n }\n break\n default:\n break\n }\n\n // create id for text value\n const id = text\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9\\s]/g, '')\n .replace(/\\s+/g, '-')\n\n // check if the option already exists in enums\n const existingOption = enumOptions?.find((enumItem) => enumItem.id === id)\n if (existingOption) return\n\n // check if options already has the value, if so, increment the count\n const existingValue = options.find((option) => option.id === id)\n if (existingValue) {\n existingValue.count++\n return\n } else {\n // add option\n options.push({\n id,\n type: type,\n label: text,\n values: [],\n count: 1,\n })\n }\n })\n\n // sort options based on count\n options.sort((a, b) => b.count - a.count)\n\n // enum options first, then the rest\n return [...enumOptions, ...options]\n}\n\nconst sortOptionsBasedOnColumns = (options: Option[], columnOrder: ColumnOrderState) => {\n const columnOrderWithSubTypes = columnOrder.flatMap((col) => {\n if (col === 'subType') {\n return ['taskType', 'folderType']\n }\n return col\n })\n return [...options].sort((a, b) => {\n const aIndex = columnOrderWithSubTypes.indexOf(a.id.replace('.', '_'))\n const bIndex = columnOrderWithSubTypes.indexOf(b.id.replace('.', '_'))\n\n // If both options are in columnOrder, sort them based on their index in columnOrder\n if (aIndex !== -1 && bIndex !== -1) {\n return aIndex - bIndex\n }\n\n // If only one of the options is in columnOrder, sort the one in columnOrder first\n if (aIndex !== -1) {\n return -1\n }\n if (bIndex !== -1) {\n return 1\n }\n\n // If neither option is in columnOrder, keep their original order\n return 0\n })\n}\n\n/**\n * Splits combined filters by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope filters back into individual scope filters.\n *\n * @param combinedFilter - The filter with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param config - Filter config containing prefixes for field types\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed filters (including 'unscoped' for filters that don't match any scope), with prefixes removed from IDs\n *\n * @example\n * // Input: combinedFilter with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: { conditions: [...] }, folder: { conditions: [...] }, task: { conditions: [...] }, unscoped: { conditions: [] } }\n */\nexport const splitFiltersByScope = (\n combinedFilter: Record<string, any> | null,\n scopes: ScopeType[],\n config?: FilterConfig,\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Record<string, any>> => {\n // Initialize with all scopes having empty conditions, plus unscoped\n const result: Record<ScopeType | 'unscoped', Record<string, any>> = {\n folder: { conditions: [] },\n product: { conditions: [] },\n task: { conditions: [] },\n user: { conditions: [] },\n version: { conditions: [] },\n unscoped: { conditions: [] },\n }\n\n if (!combinedFilter?.conditions || combinedFilter?.conditions.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from an ID\n const extractScopeAndRemovePrefix = (\n id: string,\n currentConfig?: FilterConfig,\n ): { scope: ScopeType | null; cleanId: string } => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n\n if (scopeMatch) {\n // Remove scope prefix\n const cleanId = id.substring(`${scopeMatch}_`.length)\n return { scope: scopeMatch, cleanId }\n }\n\n // If no scope prefix, return null scope (shouldn't happen in multi-scope scenario)\n return { scope: null, cleanId: id }\n }\n\n // Helper to process a filter recursively\n const processConditions = (\n conditions: any[] | undefined,\n targetFilters: Record<ScopeType | 'unscoped', Record<string, any>>,\n ) => {\n if (!conditions || conditions.length === 0) return\n\n conditions.forEach((condition) => {\n // If this is a nested filter\n if ('conditions' in condition && !('key' in condition)) {\n processConditions(condition.conditions, targetFilters)\n } else if ('key' in condition) {\n // This is a QueryCondition\n const { scope, cleanId } = extractScopeAndRemovePrefix(condition.key, config)\n\n if (scope && targetFilters[scope]) {\n // Add the condition with cleaned ID to the appropriate scope\n targetFilters[scope].conditions?.push({\n ...condition,\n key: cleanId,\n })\n } else if (!scope) {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[condition.key]\n\n if (mappedScope && targetFilters[mappedScope]) {\n // Found in the map, add to mapped scope\n targetFilters[mappedScope].conditions?.push(condition)\n } else {\n // Not in map, add to unscoped\n targetFilters['unscoped']?.conditions?.push(condition)\n }\n }\n }\n })\n }\n\n // Process the combined filter\n processConditions(combinedFilter.conditions, result)\n\n return result\n}\n\n/**\n * Splits combined Filter objects by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope Filter arrays back into individual scope Filter arrays.\n * This function works with Filter objects from @ynput/ayon-react-components, not QueryFilter objects.\n *\n * @param filters - Array of Filter objects with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed Filter arrays (including 'unscoped' for filters that don't match any scope)\n *\n * @example\n * // Input: filters with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: [...], folder: [...], task: [...], product: [...], user: [...], unscoped: [...] }\n */\nexport const splitClientFiltersByScope = (\n filters: (Filter | SliceFilter)[] | null | undefined,\n scopes: ScopeType[],\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Filter[]> => {\n // Initialize with all scopes having empty arrays, plus unscoped\n const result: Record<ScopeType | 'unscoped', Filter[]> = {\n folder: [],\n product: [],\n task: [],\n user: [],\n version: [],\n unscoped: [],\n }\n\n if (!filters || filters.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from a filter ID\n const extractScopeFromId = (id: string): ScopeType | null => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n return scopeMatch || null\n }\n\n // Helper to remove scope prefix from ID\n const removeScopePrefix = (id: string, scope: ScopeType): string => {\n const prefix = `${scope}_`\n return id.startsWith(prefix) ? id.substring(prefix.length) : id\n }\n\n // Process each filter\n filters.forEach((filter) => {\n if (!filter.id) return\n\n const scope = extractScopeFromId(filter.id)\n\n // If a scope was found, create a new filter without the scope prefix\n if (scope) {\n const cleanedFilter: Filter = {\n ...filter,\n id: removeScopePrefix(filter.id, scope),\n }\n result[scope].push(cleanedFilter)\n } else {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[filter.id]\n\n if (mappedScope) {\n // Found in the map, add to mapped scope\n result[mappedScope].push(filter)\n } else {\n // Not in map, add to unscoped\n result['unscoped'].push(filter)\n }\n }\n })\n\n return result\n}\n"],"names":["useBuildFilterOptions","globalFilterTypes","projectNames","scope","customScopes","data","config","columnOrder","power","options","scopesWithTypes","s","isMultiScope","anyNeedsEntitySubType","type","anyNeedsUsers","fieldInScopes","field","productTypes","useGetEntityGroupsQuery","projectsInfo","useGetProjectsInfoQuery","projectUsers","useGetKanbanProjectUsersQuery","attributes","useGlobalContext","getScopeLabel","currentScope","scopeFilterTypes","scopePrefix","scopeLabel","entitySubTypeOption","getOptionRoot","subTypes","getSubTypes","_a","_b","_c","statusOption","project","status","value","assigneesOption","user","_d","a","b","aCount","assignee","authorOption","tagsOption","tagsAnatomy","tag","tagOptionValuesMap","_e","existingTag","tagData","tagOptionValues","_f","versionOption","FEATURED_VERSION_TYPES","versionType","hasReviewablesOption","options_list","_g","attributesByScope","attribute","attributesByValues","isEmpty","realData","enums","isListOf","isDate","enableOperatorChange","enableRelativeValues","option","getAttributeFieldOptionRoot","suggestValuesForTypes","optionValues","getAttributeOptions","dateOptions","o","jsx","Icon","sortOptionsBasedOnColumns","icon","label","getEntityTypeIcon","taskType","folderType","getFormattedId","base","fieldType","prefixes","keys","result","formatLabel","baseLabel","getRootIdWithPrefix","formatLabelWithScope","rootOption","getAttributeIcon","values","enumOptions","enumItem","text","id","existingValue","columnOrderWithSubTypes","col","aIndex","bIndex","splitFiltersByScope","combinedFilter","scopes","filterIdToScopeMap","extractScopeAndRemovePrefix","currentConfig","scopeMatch","cleanId","processConditions","conditions","targetFilters","condition","mappedScope","splitClientFiltersByScope","filters","extractScopeFromId","removeScopePrefix","prefix","filter","cleanedFilter"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useBuildFilterOptions.cjs.js","sources":["../../../../../src/components/SearchFilter/useBuildFilterOptions.tsx"],"sourcesContent":["import { getAttributeIcon, getEntityTypeIcon } from '@shared/util'\nimport {\n ProductType,\n useGetEntityGroupsQuery,\n useGetKanbanProjectUsersQuery,\n useGetProjectsInfoQuery,\n} from '@shared/api'\nimport type {\n GetProjectsInfoResponse,\n FolderType,\n Status,\n Tag,\n TaskType,\n AttributeModel,\n AttributeEnumItem,\n AttributeData,\n EntityGroup,\n} from '@shared/api'\nimport { ColumnOrderState } from '@tanstack/react-table'\nimport { Icon, Option, Filter } from '@ynput/ayon-react-components'\nimport { dateOptions } from './filterDates'\nimport { isEmpty } from 'lodash'\nimport { SliceFilter } from '@shared/containers'\nimport { FEATURED_VERSION_TYPES } from '../FeaturedVersionOrder'\nimport { useGlobalContext } from '@shared/context'\n\ntype ScopeType = 'folder' | 'product' | 'task' | 'user' | 'version'\ntype Scope = ScopeType | ScopeType[]\n\nexport type ScopeWithFilterTypes = {\n scope: ScopeType\n filterTypes: FilterFieldType[]\n}\n\nexport type FilterFieldType =\n | 'folderType'\n | 'taskType'\n | 'productType'\n | ('users' | 'assignees' | 'author')\n | 'attributes'\n | 'status'\n | 'tags'\n | 'version'\n | 'hasReviewables'\n | 'productName'\ntype AttributeType =\n | string\n | number\n | boolean\n | Date\n | string[]\n | number[]\n | any[]\n | { [key: string]: any }\n\ntype AttributeDataValue = AttributeType | null | undefined\n\ntype FilterConfig = {\n enableExcludes?: boolean\n enableOperatorChange?: boolean\n enableRelativeValues?: boolean\n prefixes?: Partial<Record<FilterFieldType, string>> // strings that will be prepended to the id of the option\n keys?: Partial<Record<FilterFieldType, string>> // replaces the default keys for the filter\n}\n\nexport type BuildFilterOptions = {\n filterTypes?: FilterFieldType[]\n projectNames: string[]\n scope?: Scope\n scopes?: ScopeWithFilterTypes[]\n data: {\n tags?: string[]\n attributes?: Record<string, AttributeDataValue[]>\n assignees?: string[]\n productTypes?: ProductType[]\n productNames?: string[]\n }\n columnOrder?: ColumnOrderState\n config?: FilterConfig\n power?: boolean\n}\n\nexport const useBuildFilterOptions = ({\n filterTypes: globalFilterTypes = [],\n projectNames,\n scope,\n scopes: customScopes,\n data,\n config,\n columnOrder = [],\n power,\n}: BuildFilterOptions): Option[] => {\n let options: Option[] = []\n\n // Determine which scopes to use\n // If customScopes is provided, use it; otherwise, fall back to the old method\n const scopesWithTypes: Array<{ scope: ScopeType; filterTypes: FilterFieldType[] }> = customScopes\n ? customScopes\n : (() => {\n // Fallback to old method: normalize scope to array and use globalFilterTypes for all\n const normalizedScopes = scope ? (Array.isArray(scope) ? scope : [scope]) : []\n return normalizedScopes.map((s) => ({\n scope: s,\n filterTypes: globalFilterTypes,\n }))\n })()\n\n const isMultiScope = scopesWithTypes.length > 1\n\n // QUERIES\n //\n //\n // Check if any scope needs these filter types\n const anyNeedsEntitySubType = scopesWithTypes.some((s) =>\n ['entitySubType', 'status'].some((type) => s.filterTypes.includes(type as FilterFieldType)),\n )\n const anyNeedsUsers = scopesWithTypes.some((s) =>\n ['assignees', 'users', 'author'].some((type) =>\n s.filterTypes.includes(type as FilterFieldType),\n ),\n )\n // find if any search field is in any of the scopesWithTypes\n const fieldInScopes = (field: FilterFieldType): boolean => {\n return scopesWithTypes.some((s) => s.filterTypes.includes(field))\n }\n\n // get grouping options for productTypes\n // NOTE: We should revisit this to be used for all attribs and fields\n const { data: { groups: productTypes = [] } = {} } = useGetEntityGroupsQuery(\n {\n entityType: 'product',\n groupingKey: 'productType',\n projectName: projectNames[0],\n empty: true,\n },\n { skip: !projectNames?.length || !fieldInScopes('productType') },\n )\n\n const { data: projectsInfo = {} } = useGetProjectsInfoQuery(\n {\n projects: projectNames,\n },\n {\n skip: !projectNames?.length || !anyNeedsEntitySubType,\n },\n )\n\n const { data: projectUsers = [] } = useGetKanbanProjectUsersQuery(\n { projects: projectNames },\n {\n skip: !projectNames?.length || !anyNeedsUsers,\n },\n )\n\n const { attributes } = useGlobalContext()\n //\n //\n // QUERIES\n\n // ADD OPTIONS\n\n // Helper to get scope label (capitalize first letter)\n const getScopeLabel = (scope: ScopeType) => scope.charAt(0).toUpperCase() + scope.slice(1)\n\n // Loop through each scope to build options\n scopesWithTypes.forEach(({ scope: currentScope, filterTypes: scopeFilterTypes }) => {\n const scopePrefix = isMultiScope ? currentScope : undefined\n const scopeLabel = isMultiScope ? getScopeLabel(currentScope) : undefined\n\n // TASK TYPE\n // add taskType option\n if (scopeFilterTypes.includes('taskType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'taskType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'task')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // FOLDER TYPE\n // add folderType option\n if (scopeFilterTypes.includes('folderType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'folderType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'folder')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // PRODUCT TYPE\n // add productType option\n if (scopeFilterTypes.includes('productType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'productType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'product')\n entitySubTypeOption.values?.push(...subTypes)\n options.push(entitySubTypeOption)\n }\n }\n // PRODUCT NAME\n // add product name option\n if (scopeFilterTypes.includes('productName') && currentScope === 'product') {\n const productNameOption = getOptionRoot('productName', config, scopePrefix, scopeLabel)\n\n if (productNameOption) {\n // Populate with product names from data as suggestions (optional since allowsCustomValues: true)\n data.productNames?.forEach((name) => {\n if (!productNameOption.values?.some((value) => value.id === name)) {\n productNameOption.values?.push({\n id: name,\n label: name,\n })\n }\n })\n\n options.push(productNameOption)\n }\n }\n\n // STATUS\n // add status option\n if (scopeFilterTypes.includes('status')) {\n const statusOption = getOptionRoot(\n 'status',\n { ...config, enableOperatorChange: false },\n scopePrefix,\n scopeLabel,\n )\n\n if (statusOption) {\n Object.values(projectsInfo).forEach((project) => {\n const statuses = project?.statuses || []\n statuses\n .filter((status) => status.scope?.includes(currentScope))\n .forEach((status: Status) => {\n if (!statusOption.values?.some((value) => value.id === status.name)) {\n statusOption.values?.push({\n id: status.name,\n label: status.name,\n icon: status.icon,\n color: status.color,\n })\n }\n })\n })\n\n options.push(statusOption)\n }\n }\n\n // ASSIGNEES\n // add users/assignees option\n if (scopeFilterTypes.includes('assignees')) {\n const assigneesOption = getOptionRoot('assignees', config, scopePrefix, scopeLabel)\n\n if (assigneesOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!assigneesOption.values?.some((value) => value.id === user.name)) {\n assigneesOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n\n // sort the assignees based on the number of times they appear in data.assignees\n assigneesOption.values?.sort((a, b) => {\n const aCount = data.assignees?.filter((assignee) => assignee === a.id).length || 0\n const bCount = data.assignees?.filter((assignee) => assignee === b.id).length || 0\n return bCount - aCount\n })\n\n options.push(assigneesOption)\n }\n }\n\n if (scopeFilterTypes.includes('author')) {\n const authorOption = getOptionRoot('author', config, scopePrefix, scopeLabel)\n if (authorOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!authorOption.values?.some((value) => value.id === user.name)) {\n authorOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n options.push(authorOption)\n }\n }\n\n // TAGS\n // add tags options\n if (scopeFilterTypes.includes('tags')) {\n const tagsOption = getOptionRoot('tags', config, scopePrefix, scopeLabel)\n\n if (tagsOption) {\n // reduce projectsInfo to get all tags\n const tagsAnatomy = new Map<string, Tag>()\n Object.values(projectsInfo).forEach((project) => {\n if (project?.tags) {\n project.tags.forEach((tag) => {\n if (!tagsAnatomy.has(tag.name)) {\n tagsAnatomy.set(tag.name, tag)\n }\n })\n }\n })\n\n // create options for each tag, finding color if in tagsAnatomy\n const tagOptionValuesMap = new Map<string, Option & { count: number }>()\n data.tags?.forEach((tag) => {\n const existingTag = tagOptionValuesMap.get(tag)\n if (existingTag) {\n // increment count\n existingTag.count++\n return\n } else {\n // create new tag\n const tagData = tagsAnatomy.get(tag)\n\n tagOptionValuesMap.set(tag, {\n id: tag,\n type: 'string',\n label: tag,\n values: [],\n color: tagData?.color || null,\n count: 1,\n })\n }\n })\n\n // convert values map to array and sort based on count\n const tagOptionValues = Array.from(tagOptionValuesMap.values()).sort(\n (a, b) => b.count - a.count,\n )\n\n // add tag options to the tagsOption\n tagsOption.values?.push(...tagOptionValues)\n\n options.push(tagsOption)\n }\n }\n\n // VERSION\n // add version options\n if (scopeFilterTypes.includes('version')) {\n const versionOption = getOptionRoot('version', config, scopePrefix, scopeLabel)\n\n if (versionOption) {\n // add featured version types as options\n FEATURED_VERSION_TYPES.forEach((versionType) => {\n versionOption.values?.push({\n id: versionType.value,\n label: versionType.label,\n icon: versionType.icon,\n })\n })\n\n options.push(versionOption)\n }\n }\n\n // HAS REVIEWABLES\n // add hasReviewables option\n if (scopeFilterTypes.includes('hasReviewables')) {\n const hasReviewablesOption = getOptionRoot('hasReviewables', config, scopePrefix, scopeLabel)\n\n if (hasReviewablesOption) {\n const options_list = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n hasReviewablesOption.values?.push(...options_list)\n options.push(hasReviewablesOption)\n }\n }\n\n // ATTRIBUTES\n // dynamically add attributes options\n if (scopeFilterTypes.includes('attributes')) {\n const attributesByScope = attributes.filter((attribute) =>\n attribute.scope?.includes(currentScope),\n )\n // if attributesData is provided, filter out attributes that are not in the attributesData\n const attributesByValues = !isEmpty(data.attributes)\n ? attributesByScope.filter(\n (attribute) => data.attributes && data.attributes[attribute.name],\n )\n : attributesByScope\n\n const attributesWithoutDates = config?.enableRelativeValues\n ? attributesByValues\n : attributesByValues.filter((attribute) => attribute.data.type !== 'datetime')\n\n attributesWithoutDates.forEach((attribute) => {\n const realData = data.attributes && data.attributes[attribute.name]\n const enums = attribute.data.enum\n const type = attribute.data.type\n\n const isListOf = [\n 'list_of_strings',\n 'list_of_integers',\n 'list_of_any',\n 'list_of_submodels',\n ].includes(type || '')\n const isDate = type === 'datetime'\n const enableOperatorChange = isListOf ? config?.enableOperatorChange : false\n const enableRelativeValues = isListOf || isDate ? config?.enableRelativeValues : false\n // for the attribute, get the option root\n const option = getAttributeFieldOptionRoot(\n attribute,\n {\n ...config,\n allowsCustomValues: true,\n enableOperatorChange: enableOperatorChange,\n enableRelativeValues: enableRelativeValues,\n },\n scopePrefix,\n scopeLabel,\n )\n\n const suggestValuesForTypes: AttributeData['type'][] = [\n 'string',\n 'integer',\n 'float',\n 'list_of_strings',\n 'list_of_integers',\n ]\n\n const optionValues: Option[] = []\n\n // if the attribute type is in the suggestValuesForTypes, get the options based on real values\n if (suggestValuesForTypes.includes(type)) {\n const options = getAttributeOptions(realData, enums, type)\n optionValues.push(...options)\n }\n\n // if the attribute type is boolean, add yes/no options\n if (type === 'boolean') {\n const options = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n optionValues.push(...options)\n }\n\n // if the attribute type is datetime, add datetime options\n\n if (isDate) {\n optionValues.push(\n ...dateOptions.map((o) => ({\n ...o,\n contentAfter: power ? undefined : <Icon icon=\"bolt\" />,\n })),\n )\n }\n\n // add option to the list of options\n option.values?.push(...optionValues)\n\n // add option to the list of options\n options.push(option)\n })\n }\n }) // End of scopes.forEach loop\n\n // order options by columnOrder\n if (columnOrder) {\n return sortOptionsBasedOnColumns(options, columnOrder)\n } else return options\n}\n\n// HELPER FUNCTIONS\n//\n//\n//\n//\nconst getSubTypes = (\n {\n projectsInfo,\n productTypes,\n }: { projectsInfo: GetProjectsInfoResponse; productTypes: EntityGroup[] },\n type: ScopeType,\n): Option[] => {\n const options: Option[] = []\n if (type === 'product') {\n productTypes.forEach(({ icon, label, value }) => {\n options.push({\n id: value,\n type: 'string',\n label: label || value,\n icon: icon || getEntityTypeIcon('product'),\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n })\n } else if (type === 'task') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all task types and add them to the options (if they don't already exist)\n const taskTypes = project?.taskTypes || []\n taskTypes.forEach((taskType: TaskType) => {\n if (!options.some((option) => option.id === taskType.name)) {\n options.push({\n id: taskType.name,\n type: 'string',\n label: taskType.name,\n icon: taskType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n } else if (type === 'folder') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all folder types and add them to the options (if they don't already exist)\n const folderTypes = project?.folderTypes || []\n folderTypes.forEach((folderType: FolderType) => {\n if (!options.some((option) => option.id === folderType.name)) {\n options.push({\n id: folderType.name,\n type: 'string',\n label: folderType.name,\n icon: folderType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n }\n\n return options\n}\n\nconst getFormattedId = (\n base: string,\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n) => {\n const { prefixes, keys } = config || {}\n let result = base\n\n if (keys && fieldType in keys) {\n result = `${keys[fieldType]}`\n } else if (prefixes && fieldType in prefixes) {\n result = `${prefixes[fieldType]}${base}`\n }\n\n // Add scope prefix if provided\n if (scopePrefix) {\n result = `${scopePrefix}_${result}`\n }\n\n return result\n}\n\nconst formatLabel = (baseLabel: string, scopeLabel?: string) =>\n scopeLabel ? `${baseLabel} - ${scopeLabel}` : baseLabel\n\nconst getOptionRoot = (\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n scopeLabel?: string,\n) => {\n const getRootIdWithPrefix = (base: string) => getFormattedId(base, fieldType, config, scopePrefix)\n const formatLabelWithScope = (baseLabel: string) => formatLabel(baseLabel, scopeLabel)\n\n let rootOption: Option | null = null\n switch (fieldType) {\n case 'taskType':\n rootOption = {\n id: getRootIdWithPrefix(`taskType`),\n type: 'string',\n label: formatLabelWithScope(`Task Type`),\n icon: getAttributeIcon('task'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'folderType':\n rootOption = {\n id: getRootIdWithPrefix(`folderType`),\n type: 'string',\n label: formatLabelWithScope(`Folder Type`),\n icon: getAttributeIcon('folder'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productType':\n rootOption = {\n id: getRootIdWithPrefix(`productType`),\n type: 'string',\n label: formatLabelWithScope(`Product Type`),\n icon: getAttributeIcon('product'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productName':\n rootOption = {\n id: getRootIdWithPrefix(`productNames`),\n type: 'string',\n label: formatLabelWithScope(`Product Name`),\n icon: getAttributeIcon('productName', 'string'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: true,\n }\n break\n case 'status':\n rootOption = {\n id: getRootIdWithPrefix('status'),\n type: 'string',\n label: formatLabelWithScope('Status'),\n icon: getAttributeIcon('status'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'assignees':\n rootOption = {\n id: getRootIdWithPrefix('assignees'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Assignee'),\n icon: getAttributeIcon('assignees'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'author':\n rootOption = {\n id: getRootIdWithPrefix('author'),\n type: 'string',\n label: formatLabelWithScope('Author'),\n icon: getAttributeIcon('author'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'tags':\n rootOption = {\n id: getRootIdWithPrefix('tags'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Tags'),\n icon: getAttributeIcon('tags'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'version':\n rootOption = {\n id: getRootIdWithPrefix('version'),\n type: 'string',\n label: formatLabelWithScope('Version'),\n icon: getAttributeIcon('version'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: false,\n }\n break\n case 'hasReviewables':\n rootOption = {\n id: getRootIdWithPrefix('hasReviewables'),\n type: 'boolean',\n label: formatLabelWithScope('Has Reviewables'),\n icon: 'play_circle',\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n singleSelect: true,\n }\n break\n default:\n break\n\n // Note: attributes are handled separately\n }\n\n return rootOption\n}\n\nconst getAttributeFieldOptionRoot = (\n attribute: AttributeModel,\n config: FilterConfig & { allowsCustomValues: boolean },\n scopePrefix?: string,\n scopeLabel?: string,\n): Option => ({\n id: getFormattedId(attribute.name, 'attributes', config, scopePrefix),\n type: attribute.data.type,\n label: scopeLabel\n ? formatLabel(attribute.data.title || attribute.name, scopeLabel)\n : attribute.data.title || attribute.name,\n operator: 'OR',\n inverted: false,\n values: [],\n allowsCustomValues: config?.allowsCustomValues,\n allowHasValue: config.enableRelativeValues,\n allowNoValue: config.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n icon: getAttributeIcon(attribute.name, attribute.data.type, !!attribute.data.enum?.length),\n singleSelect: ['boolean', 'datetime'].includes(attribute.data.type || ''),\n})\n\nconst getAttributeOptions = (\n values?: AttributeDataValue[],\n enums?: AttributeEnumItem[],\n type?: AttributeData['type'],\n): Option[] => {\n const enumOptions: Option[] = []\n const options: (Option & { count: number })[] = []\n\n // add the enum values first\n if (enums) {\n enums.forEach((enumItem) => {\n enumOptions.push({\n id: enumItem.value.toString(),\n type: type,\n label: enumItem.label,\n values: [],\n icon: enumItem.icon,\n color: enumItem.color,\n })\n })\n }\n\n values?.forEach((value) => {\n // no value? do nothing\n if (!value) return\n\n let text = ''\n\n // convert value to text\n switch (typeof value) {\n case 'string':\n case 'number':\n case 'boolean':\n text = value.toString()\n break\n case 'object':\n if (Array.isArray(value)) {\n text = value.join(', ')\n } else {\n text = JSON.stringify(value)\n }\n break\n default:\n break\n }\n\n // create id for text value\n const id = text\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9\\s]/g, '')\n .replace(/\\s+/g, '-')\n\n // check if the option already exists in enums\n const existingOption = enumOptions?.find((enumItem) => enumItem.id === id)\n if (existingOption) return\n\n // check if options already has the value, if so, increment the count\n const existingValue = options.find((option) => option.id === id)\n if (existingValue) {\n existingValue.count++\n return\n } else {\n // add option\n options.push({\n id,\n type: type,\n label: text,\n values: [],\n count: 1,\n })\n }\n })\n\n // sort options based on count\n options.sort((a, b) => b.count - a.count)\n\n // enum options first, then the rest\n return [...enumOptions, ...options]\n}\n\nconst sortOptionsBasedOnColumns = (options: Option[], columnOrder: ColumnOrderState) => {\n const columnOrderWithSubTypes = columnOrder.flatMap((col) => {\n if (col === 'subType') {\n return ['taskType', 'folderType']\n }\n return col\n })\n return [...options].sort((a, b) => {\n const aIndex = columnOrderWithSubTypes.indexOf(a.id.replace('.', '_'))\n const bIndex = columnOrderWithSubTypes.indexOf(b.id.replace('.', '_'))\n\n // If both options are in columnOrder, sort them based on their index in columnOrder\n if (aIndex !== -1 && bIndex !== -1) {\n return aIndex - bIndex\n }\n\n // If only one of the options is in columnOrder, sort the one in columnOrder first\n if (aIndex !== -1) {\n return -1\n }\n if (bIndex !== -1) {\n return 1\n }\n\n // If neither option is in columnOrder, keep their original order\n return 0\n })\n}\n\n/**\n * Splits combined filters by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope filters back into individual scope filters.\n *\n * @param combinedFilter - The filter with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param config - Filter config containing prefixes for field types\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed filters (including 'unscoped' for filters that don't match any scope), with prefixes removed from IDs\n *\n * @example\n * // Input: combinedFilter with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: { conditions: [...] }, folder: { conditions: [...] }, task: { conditions: [...] }, unscoped: { conditions: [] } }\n */\nexport const splitFiltersByScope = (\n combinedFilter: Record<string, any> | null,\n scopes: ScopeType[],\n config?: FilterConfig,\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Record<string, any>> => {\n // Initialize with all scopes having empty conditions, plus unscoped\n const result: Record<ScopeType | 'unscoped', Record<string, any>> = {\n folder: { conditions: [] },\n product: { conditions: [] },\n task: { conditions: [] },\n user: { conditions: [] },\n version: { conditions: [] },\n unscoped: { conditions: [] },\n }\n\n if (!combinedFilter?.conditions || combinedFilter?.conditions.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from an ID\n const extractScopeAndRemovePrefix = (\n id: string,\n currentConfig?: FilterConfig,\n ): { scope: ScopeType | null; cleanId: string } => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n\n if (scopeMatch) {\n // Remove scope prefix\n const cleanId = id.substring(`${scopeMatch}_`.length)\n return { scope: scopeMatch, cleanId }\n }\n\n // If no scope prefix, return null scope (shouldn't happen in multi-scope scenario)\n return { scope: null, cleanId: id }\n }\n\n // Helper to process a filter recursively\n const processConditions = (\n conditions: any[] | undefined,\n targetFilters: Record<ScopeType | 'unscoped', Record<string, any>>,\n ) => {\n if (!conditions || conditions.length === 0) return\n\n conditions.forEach((condition) => {\n // If this is a nested filter\n if ('conditions' in condition && !('key' in condition)) {\n processConditions(condition.conditions, targetFilters)\n } else if ('key' in condition) {\n // This is a QueryCondition\n const { scope, cleanId } = extractScopeAndRemovePrefix(condition.key, config)\n\n if (scope && targetFilters[scope]) {\n // Add the condition with cleaned ID to the appropriate scope\n targetFilters[scope].conditions?.push({\n ...condition,\n key: cleanId,\n })\n } else if (!scope) {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[condition.key]\n\n if (mappedScope && targetFilters[mappedScope]) {\n // Found in the map, add to mapped scope\n targetFilters[mappedScope].conditions?.push(condition)\n } else {\n // Not in map, add to unscoped\n targetFilters['unscoped']?.conditions?.push(condition)\n }\n }\n }\n })\n }\n\n // Process the combined filter\n processConditions(combinedFilter.conditions, result)\n\n return result\n}\n\n/**\n * Splits combined Filter objects by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope Filter arrays back into individual scope Filter arrays.\n * This function works with Filter objects from @ynput/ayon-react-components, not QueryFilter objects.\n *\n * @param filters - Array of Filter objects with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed Filter arrays (including 'unscoped' for filters that don't match any scope)\n *\n * @example\n * // Input: filters with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: [...], folder: [...], task: [...], product: [...], user: [...], unscoped: [...] }\n */\nexport const splitClientFiltersByScope = (\n filters: (Filter | SliceFilter)[] | null | undefined,\n scopes: ScopeType[],\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Filter[]> => {\n // Initialize with all scopes having empty arrays, plus unscoped\n const result: Record<ScopeType | 'unscoped', Filter[]> = {\n folder: [],\n product: [],\n task: [],\n user: [],\n version: [],\n unscoped: [],\n }\n\n if (!filters || filters.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from a filter ID\n const extractScopeFromId = (id: string): ScopeType | null => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n return scopeMatch || null\n }\n\n // Helper to remove scope prefix from ID\n const removeScopePrefix = (id: string, scope: ScopeType): string => {\n const prefix = `${scope}_`\n return id.startsWith(prefix) ? id.substring(prefix.length) : id\n }\n\n // Process each filter\n filters.forEach((filter) => {\n if (!filter.id) return\n\n const scope = extractScopeFromId(filter.id)\n\n // If a scope was found, create a new filter without the scope prefix\n if (scope) {\n const cleanedFilter: Filter = {\n ...filter,\n id: removeScopePrefix(filter.id, scope),\n }\n result[scope].push(cleanedFilter)\n } else {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[filter.id]\n\n if (mappedScope) {\n // Found in the map, add to mapped scope\n result[mappedScope].push(filter)\n } else {\n // Not in map, add to unscoped\n result['unscoped'].push(filter)\n }\n }\n })\n\n return result\n}\n"],"names":["useBuildFilterOptions","globalFilterTypes","projectNames","scope","customScopes","data","config","columnOrder","power","options","scopesWithTypes","s","isMultiScope","anyNeedsEntitySubType","type","anyNeedsUsers","fieldInScopes","field","productTypes","useGetEntityGroupsQuery","projectsInfo","useGetProjectsInfoQuery","projectUsers","useGetKanbanProjectUsersQuery","attributes","useGlobalContext","getScopeLabel","currentScope","scopeFilterTypes","scopePrefix","scopeLabel","entitySubTypeOption","getOptionRoot","subTypes","getSubTypes","_a","_b","_c","productNameOption","_d","name","value","statusOption","project","status","assigneesOption","user","_e","a","b","aCount","assignee","authorOption","tagsOption","tagsAnatomy","tag","tagOptionValuesMap","_f","existingTag","tagData","tagOptionValues","_g","versionOption","FEATURED_VERSION_TYPES","versionType","hasReviewablesOption","options_list","_h","attributesByScope","attribute","attributesByValues","isEmpty","realData","enums","isListOf","isDate","enableOperatorChange","enableRelativeValues","option","getAttributeFieldOptionRoot","suggestValuesForTypes","optionValues","getAttributeOptions","dateOptions","o","jsx","Icon","sortOptionsBasedOnColumns","icon","label","getEntityTypeIcon","taskType","folderType","getFormattedId","base","fieldType","prefixes","keys","result","formatLabel","baseLabel","getRootIdWithPrefix","formatLabelWithScope","rootOption","getAttributeIcon","values","enumOptions","enumItem","text","id","existingValue","columnOrderWithSubTypes","col","aIndex","bIndex","splitFiltersByScope","combinedFilter","scopes","filterIdToScopeMap","extractScopeAndRemovePrefix","currentConfig","scopeMatch","cleanId","processConditions","conditions","targetFilters","condition","mappedScope","splitClientFiltersByScope","filters","extractScopeFromId","removeScopePrefix","prefix","filter","cleanedFilter"],"mappings":"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"}
|