@ynput/ayon-frontend-shared 0.2.32 → 0.2.33
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 +29 -22
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/Feed.cjs.js +1 -1
- package/dist/Feed.es.js +11 -9
- package/dist/Feed.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.cjs5.js +1 -1
- package/dist/_virtual/index.cjs6.js +1 -1
- package/dist/_virtual/index.es5.js +2 -5
- package/dist/_virtual/index.es5.js.map +1 -1
- package/dist/_virtual/index.es6.js +5 -2
- package/dist/_virtual/index.es6.js.map +1 -1
- package/dist/api.cjs.js +1 -1
- package/dist/api.es.js +219 -217
- package/dist/api.es.js.map +1 -1
- package/dist/components.cjs.js +1 -1
- package/dist/components.es.js +84 -71
- package/dist/components.es.js.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +16 -9
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
- package/dist/node_modules/remove-accents/index.cjs.js +1 -1
- package/dist/node_modules/remove-accents/index.es.js +1 -1
- package/dist/shared/src/api/generated/activityFeed.cjs.js +1 -1
- package/dist/shared/src/api/generated/activityFeed.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/activityFeed.es.js +3 -0
- package/dist/shared/src/api/generated/activityFeed.es.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -1
- package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getActivities.es.js +4 -8
- package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getCategories.cjs.js +2 -0
- package/dist/shared/src/api/queries/activities/getCategories.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/activities/getCategories.es.js +53 -0
- package/dist/shared/src/api/queries/activities/getCategories.es.js.map +1 -0
- package/dist/shared/src/api/queries/activities/updateActivities.cjs.js +1 -1
- package/dist/shared/src/api/queries/activities/updateActivities.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/activities/updateActivities.es.js +53 -51
- package/dist/shared/src/api/queries/activities/updateActivities.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 +4 -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 +61 -60
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/share/share.cjs.js +1 -1
- package/dist/shared/src/api/queries/share/share.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/share/share.es.js +38 -12
- package/dist/shared/src/api/queries/share/share.es.js.map +1 -1
- 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 +18 -17
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/api/queries/views/updateViews.cjs.js +1 -1
- package/dist/shared/src/api/queries/views/updateViews.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/views/updateViews.es.js +14 -15
- package/dist/shared/src/api/queries/views/updateViews.es.js.map +1 -1
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.cjs.js +2 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.cjs.js.map +1 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.es.js +135 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.es.js.map +1 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.cjs.js +39 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.cjs.js.map +1 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.es.js +44 -0
- package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.es.js.map +1 -0
- package/dist/shared/src/components/AccessUser/AccessUser.cjs.js +2 -0
- package/dist/shared/src/components/AccessUser/AccessUser.cjs.js.map +1 -0
- package/dist/shared/src/components/AccessUser/AccessUser.es.js +43 -0
- package/dist/shared/src/components/AccessUser/AccessUser.es.js.map +1 -0
- package/dist/shared/src/components/AccessUser/AccessUser.styled.cjs.js +46 -0
- package/dist/shared/src/components/AccessUser/AccessUser.styled.cjs.js.map +1 -0
- package/dist/shared/src/components/AccessUser/AccessUser.styled.es.js +50 -0
- package/dist/shared/src/components/AccessUser/AccessUser.styled.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 +3 -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 +3 -2
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.cjs.js +47 -43
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.es.js +47 -43
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.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 +3 -2
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.es.js +3 -2
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.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 +3 -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 +9 -2
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.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 +5 -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 +9 -2
- 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 +9 -2
- 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 +3 -2
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.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 +9 -2
- 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 +11 -4
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.es.js +9 -2
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.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 +9 -2
- 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 +9 -2
- 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 +9 -2
- 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 +10 -3
- 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 +9 -2
- 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 +3 -2
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
- package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.cjs.js +12 -0
- package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.cjs.js.map +1 -0
- package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.es.js +46 -0
- package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.es.js.map +1 -0
- 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 +9 -2
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +9 -2
- 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 +9 -2
- 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 +3 -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 +9 -2
- 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 +61 -52
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.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 +9 -2
- 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 +44 -36
- 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 +9 -2
- 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 +3 -2
- 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 +4 -2
- 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 +19 -17
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
- 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 +3 -2
- 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 +9 -2
- 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 +9 -2
- 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 +9 -2
- 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 +9 -2
- 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 +3 -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 +73 -72
- package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.cjs.js +13 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.cjs.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js +89 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.cjs.js +20 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.cjs.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.es.js +42 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.es.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.cjs.js +51 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.cjs.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.es.js +76 -0
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.es.js.map +1 -0
- 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 +161 -133
- 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 +30 -14
- 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 +41 -24
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.cjs.js +3 -3
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.es.js +58 -48
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.es.js.map +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.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.es.js +24 -20
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js +12 -12
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js +13 -13
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.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 +336 -260
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.cjs.js +69 -41
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.es.js +77 -48
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.cjs.js +2 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.cjs.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.es.js +19 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.es.js.map +1 -0
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.es.js +15 -6
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.es.js +24 -14
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.es.js +60 -38
- package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.es.js +42 -9
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.cjs.js +65 -20
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.es.js +71 -26
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.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 +4 -2
- 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 +30 -26
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useCommentMutations.es.js +57 -53
- package/dist/shared/src/containers/Feed/hooks/useCommentMutations.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/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 +9 -2
- 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 +9 -2
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js +9 -2
- 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 +9 -2
- 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 +9 -2
- 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 +5 -4
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.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 +42 -35
- 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 +3 -2
- 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 +6 -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 +23 -21
- 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 +9 -2
- 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 +9 -2
- 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 +9 -2
- 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 +3 -2
- 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 +9 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.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 +9 -2
- 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 +9 -2
- 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 +9 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.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 +9 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.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 +20 -13
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +4 -3
- 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 +11 -4
- 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 +9 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.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 +9 -2
- 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 +9 -2
- 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 +3 -2
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.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 +5 -4
- 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 +3 -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 +3 -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 +70 -66
- package/dist/shared/src/context/DetailsPanelContext.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 +30 -23
- package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
- 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/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 +3 -2
- package/dist/shared/src/hooks/useEntityUpdate.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 +3 -2
- package/dist/shared/src/hooks/useHierarchyTable.es.js.map +1 -1
- package/dist/shared/src/hooks/useLoadModule.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useLoadModule.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 +3 -2
- package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
- package/dist/shared/src/util/colorUtils.cjs.js +2 -0
- package/dist/shared/src/util/colorUtils.cjs.js.map +1 -0
- package/dist/shared/src/util/colorUtils.es.js +40 -0
- package/dist/shared/src/util/colorUtils.es.js.map +1 -0
- package/dist/types/api/generated/activityFeed.d.ts +9 -0
- package/dist/types/api/generated/graphql.d.ts +6 -1
- package/dist/types/api/index.d.ts +1 -0
- package/dist/types/api/queries/activities/getCategories.d.ts +142 -0
- package/dist/types/api/queries/activities/getMentions.d.ts +1 -0
- package/dist/types/api/queries/activities/index.d.ts +1 -0
- package/dist/types/api/queries/activities/updateReaction.d.ts +1 -0
- package/dist/types/api/queries/watchers/getWatchers.d.ts +1 -0
- package/dist/types/components/AccessSearchInput/AccessSearchInput.d.ts +16 -0
- package/dist/types/components/AccessSearchInput/AccessSearchInput.styled.d.ts +2 -0
- package/dist/types/components/AccessSearchInput/index.d.ts +2 -0
- package/dist/types/components/AccessUser/AccessUser.d.ts +24 -0
- package/dist/types/components/AccessUser/AccessUser.styled.d.ts +1 -0
- package/dist/types/components/AccessUser/index.d.ts +1 -0
- package/dist/types/components/ShareOptionIcon/ShareOptionIcon.d.ts +16 -0
- package/dist/types/components/ShareOptionIcon/index.d.ts +1 -0
- package/dist/types/components/index.d.ts +3 -0
- package/dist/types/containers/DetailsPanel/DetailsPanel.d.ts +2 -1
- package/dist/types/containers/DetailsPanel/FeedWrapper.d.ts +1 -0
- package/dist/types/containers/Feed/Feed.d.ts +2 -1
- package/dist/types/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.d.ts +14 -0
- package/dist/types/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.d.ts +8 -0
- package/dist/types/containers/Feed/components/ActivityCategorySelect/CategoryTag.d.ts +10 -0
- package/dist/types/containers/Feed/components/ActivityCategorySelect/index.d.ts +1 -0
- package/dist/types/containers/Feed/components/ActivityComment/ActivityComment.d.ts +1 -1
- package/dist/types/containers/Feed/components/ActivityComment/ActivityComment.styled.d.ts +2 -1
- package/dist/types/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.d.ts +3 -1
- package/dist/types/containers/Feed/components/ActivityItem.d.ts +1 -1
- package/dist/types/containers/Feed/components/ActivityReference/ActivityReference.d.ts +2 -0
- package/dist/types/containers/Feed/components/ActivityReference/ActivityReference.styled.d.ts +2 -0
- package/dist/types/containers/Feed/components/CommentInput/CommentInput.d.ts +1 -0
- package/dist/types/containers/Feed/components/CommentInput/CommentInput.styled.d.ts +7 -1
- package/dist/types/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.d.ts +11 -0
- package/dist/types/containers/Feed/components/ReactionContainer/ExistingReactions.d.ts +4 -1
- package/dist/types/containers/Feed/components/ReactionContainer/Reaction.d.ts +4 -1
- package/dist/types/containers/Feed/components/ReactionContainer/ReactionPanelOpener.d.ts +4 -1
- package/dist/types/containers/Feed/components/ReactionContainer/Reactions.d.ts +4 -1
- package/dist/types/containers/Feed/components/ReactionContainer/Reactions.styled.d.ts +9 -4
- package/dist/types/containers/Feed/context/FeedContext.d.ts +2 -1
- package/dist/types/containers/Feed/hooks/useCommentMutations.d.ts +3 -2
- package/dist/types/containers/Feed/index.d.ts +1 -0
- package/dist/types/containers/Views/index.d.ts +2 -2
- package/dist/types/context/DetailsPanelContext.d.ts +3 -0
- package/dist/types/context/PowerpackContext.d.ts +1 -1
- package/dist/types/util/colorUtils.d.ts +42 -0
- package/dist/types/util/index.d.ts +1 -0
- package/dist/util.cjs.js +1 -1
- package/dist/util.es.js +30 -24
- package/dist/util.es.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortableReviewableCard.cjs.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["SortableReviewableCard","props","attributes","listeners","setNodeRef","transform","transition","isDragging","useSortable","style","CSS","jsx","ReviewableCard"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SortableReviewableCard.cjs.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["SortableReviewableCard","props","attributes","listeners","setNodeRef","transform","transition","isDragging","useSortable","style","CSS","jsx","ReviewableCard"],"mappings":"4qZAOA,MAAMA,EAA0D,CAAC,CAAE,GAAGC,KAAY,CAC1E,KAAA,CAAE,WAAAC,EAAY,UAAAC,EAAW,WAAAC,EAAY,UAAAC,EAAW,WAAAC,EAAY,WAAAC,GAAeC,cAAY,CAC3F,GAAIP,EAAM,OACV,qBAAsB,IAAM,EAAA,CAC7B,EAEKQ,EAAQ,CACZ,UAAWC,EAAA,IAAI,UAAU,SAASL,CAAS,EAC3C,WAAAC,CACF,EAEA,OACGK,EAAAA,kBAAAA,IAAA,MAAA,CAAI,IAAKP,EAAY,MAAAK,EACpB,SAAAE,EAAA,kBAAA,IAACC,EAAA,eAAA,CACC,kBAAmBL,EACnB,UAAW,CAAE,GAAGL,EAAY,GAAGC,CAAU,EACzC,SAAUF,EAAM,gBACf,GAAGA,CAAA,CAAA,EAER,CAEJ"}
|
|
@@ -50,6 +50,7 @@ import "../../api/queries/activities/getActivities.es.js";
|
|
|
50
50
|
import "../../api/queries/activities/updateActivities.es.js";
|
|
51
51
|
import "../../api/queries/activities/updateReaction.es.js";
|
|
52
52
|
import "../../api/queries/activities/getMentions.es.js";
|
|
53
|
+
import "../../api/queries/activities/getCategories.es.js";
|
|
53
54
|
import "../../api/queries/addons/getAddons.es.js";
|
|
54
55
|
import "../../api/queries/addons/updateAddons.es.js";
|
|
55
56
|
import "../../api/queries/attributes/getAttributes.es.js";
|
|
@@ -135,12 +136,14 @@ import "react-router-dom";
|
|
|
135
136
|
import "../../containers/Feed/components/ActivityStatus/ActivityStatus.es.js";
|
|
136
137
|
import "../../containers/Feed/components/ActivityHeader/ActivityHeader.styled.es.js";
|
|
137
138
|
import "../../containers/Feed/components/ActivityDate.es.js";
|
|
139
|
+
import "../../containers/Feed/components/ActivityCategorySelect/CategoryTag.es.js";
|
|
138
140
|
import "../../containers/Feed/components/ActivityStatusChange/ActivityStatusChange.styled.es.js";
|
|
139
141
|
import "../../containers/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.styled.es.js";
|
|
140
142
|
import "../../containers/Feed/components/ActivityVersions/ActivityVersions.styled.es.js";
|
|
141
143
|
import "../../containers/Feed/components/ActivityGroup/ActivityGroup.styled.es.js";
|
|
142
144
|
import "../../containers/Feed/Feed.styled.es.js";
|
|
143
145
|
import "date-fns";
|
|
146
|
+
import "../../containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js";
|
|
144
147
|
import "../../containers/ProjectTreeTable/ProjectTreeTable.es.js";
|
|
145
148
|
import "../../containers/ProjectTreeTable/context/CellEditingContext.es.js";
|
|
146
149
|
import "@tanstack/react-table";
|
|
@@ -215,7 +218,11 @@ import "../Feedback/SupportBubble.es.js";
|
|
|
215
218
|
import "../Chips/Chips.es.js";
|
|
216
219
|
import "../../containers/EntityPickerDialog/EntityPickerDialog.es.js";
|
|
217
220
|
import "../StyledLink/StyledLink.es.js";
|
|
218
|
-
|
|
221
|
+
import "../ShareOptionIcon/ShareOptionIcon.es.js";
|
|
222
|
+
import "../AccessUser/AccessUser.es.js";
|
|
223
|
+
import "../../../../node_modules/match-sorter/dist/match-sorter.esm.es.js";
|
|
224
|
+
import "../AccessSearchInput/AccessSearchInput.styled.es.js";
|
|
225
|
+
const Ri = ({ ...r }) => {
|
|
219
226
|
const { attributes: o, listeners: i, setNodeRef: m, transform: p, transition: e, isDragging: s } = n({
|
|
220
227
|
id: r.fileId,
|
|
221
228
|
animateLayoutChanges: () => !1
|
|
@@ -234,6 +241,6 @@ const gi = ({ ...r }) => {
|
|
|
234
241
|
) });
|
|
235
242
|
};
|
|
236
243
|
export {
|
|
237
|
-
|
|
244
|
+
Ri as default
|
|
238
245
|
};
|
|
239
246
|
//# sourceMappingURL=SortableReviewableCard.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortableReviewableCard.es.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["SortableReviewableCard","props","attributes","listeners","setNodeRef","transform","transition","isDragging","useSortable","style","CSS","jsx","ReviewableCard"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SortableReviewableCard.es.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["SortableReviewableCard","props","attributes","listeners","setNodeRef","transform","transition","isDragging","useSortable","style","CSS","jsx","ReviewableCard"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,MAAMA,KAA0D,CAAC,EAAE,GAAGC,QAAY;AAC1E,QAAA,EAAE,YAAAC,GAAY,WAAAC,GAAW,YAAAC,GAAY,WAAAC,GAAW,YAAAC,GAAY,YAAAC,MAAeC,EAAY;AAAA,IAC3F,IAAIP,EAAM;AAAA,IACV,sBAAsB,MAAM;AAAA,EAAA,CAC7B,GAEKQ,IAAQ;AAAA,IACZ,WAAWC,EAAI,UAAU,SAASL,CAAS;AAAA,IAC3C,YAAAC;AAAA,EACF;AAEA,SACGK,gBAAAA,EAAAA,IAAA,OAAA,EAAI,KAAKP,GAAY,OAAAK,GACpB,UAAAE,gBAAAA,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,mBAAmBL;AAAA,MACnB,WAAW,EAAE,GAAGL,GAAY,GAAGC,EAAU;AAAA,MACzC,UAAUF,EAAM;AAAA,MACf,GAAGA;AAAA,IAAA;AAAA,EAAA,GAER;AAEJ;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const $=require("react"),z=require("axios"),h=require("react-toastify"),w=require("../../api/base/client.cjs.js");require("../../api/generated/graphql.cjs.js");require("../../api/generated/graphqlLinks.cjs.js");require("../../api/generated/access.cjs.js");require("../../api/generated/actions.cjs.js");require("../../api/generated/activityFeed.cjs.js");require("../../api/generated/addons.cjs.js");require("../../api/generated/anatomy.cjs.js");require("../../api/generated/attributes.cjs.js");require("../../api/generated/authentication.cjs.js");require("../../api/generated/bundles.cjs.js");require("../../api/generated/configuration.cjs.js");require("../../api/generated/desktop.cjs.js");require("../../api/generated/entityLists.cjs.js");require("../../api/generated/events.cjs.js");require("../../api/generated/files.cjs.js");require("../../api/generated/folders.cjs.js");require("../../api/generated/inbox.cjs.js");require("../../api/generated/links.cjs.js");require("../../api/generated/market.cjs.js");require("../../api/generated/onboarding.cjs.js");require("../../api/generated/operations.cjs.js");require("../../api/generated/products.cjs.js");require("../../api/generated/projectDashboard.cjs.js");require("../../api/generated/projects.cjs.js");require("../../api/generated/reviewables.cjs.js");require("../../api/generated/services.cjs.js");require("../../api/generated/system.cjs.js");require("../../api/generated/tasks.cjs.js");require("../../api/generated/teams.cjs.js");require("../../api/generated/thumbnails.cjs.js");require("../../api/generated/uRIs.cjs.js");require("../../api/generated/users.cjs.js");require("../../api/generated/versions.cjs.js");require("../../api/generated/workfiles.cjs.js");require("../../api/generated/ynputCloud.cjs.js");require("../../api/generated/grouping.cjs.js");require("../../api/generated/views.cjs.js");require("../../api/queries/actions/getActions.cjs.js");require("../../api/queries/activities/getActivities.cjs.js");require("../../api/queries/activities/updateActivities.cjs.js");require("../../api/queries/activities/updateReaction.cjs.js");require("../../api/queries/activities/getMentions.cjs.js");require("../../api/queries/addons/getAddons.cjs.js");require("../../api/queries/addons/updateAddons.cjs.js");require("../../api/queries/attributes/getAttributes.cjs.js");require("../../api/queries/attributes/updateAttributes.cjs.js");require("../../api/queries/authentication/getAuthentication.cjs.js");require("../../api/queries/cloud/cloud.cjs.js");require("../../api/queries/entities/getEntity.cjs.js");require("../../api/queries/entities/getEntityPanel.cjs.js");require("../../api/queries/entities/updateEntity.cjs.js");require("../../api/queries/entityLists/getLists.cjs.js");require("../../api/queries/entityLists/updateLists.cjs.js");require("../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../api/queries/entityLists/listFolders.cjs.js");require("../../api/queries/folders/getFolders.cjs.js");require("../../api/queries/grouping/getGrouping.cjs.js");require("../../api/queries/links/updateLinks.cjs.js");require("../../api/queries/links/getLinks.cjs.js");require("../../api/queries/links/getEntityLinks.cjs.js");require("../../api/queries/overview/getOverview.cjs.js");require("../../api/queries/overview/updateOverview.cjs.js");require("../../api/queries/permissions/getPermissions.cjs.js");require("../../api/queries/products/createProduct.cjs.js");require("../../api/queries/project/getProject.cjs.js");require("../../api/queries/project/updateProject.cjs.js");require("../../api/queries/review/getReview.cjs.js");const A=require("../../api/queries/review/updateReview.cjs.js");require("../../api/queries/share/share.cjs.js");require("../../api/queries/system/getSystem.cjs.js");require("../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../api/queries/users/getUsers.cjs.js");require("../../api/queries/users/updateUsers.cjs.js");require("../../api/queries/versions/updateVersions.cjs.js");require("../../api/queries/views/getViews.cjs.js");require("../../api/queries/views/updateViews.cjs.js");require("../../api/queries/watchers/getWatchers.cjs.js");const C=({projectName:s,versionId:q,taskId:b,folderId:y,productId:U,dispatch:n,onUpload:g,onProgress:c})=>{const[p,d]=$.useState({}),f=$.useCallback(F=>{q&&d(m=>{var r;return{...m,[q]:((r=m[q])==null?void 0:r.filter(v=>v.name!==F))||[]}})},[q]);return{handleFileUpload:$.useCallback(async(F,m)=>{const r=m||q;if(!r||!s)return;const v=Array.from(F),R=v.map(i=>({name:i.name,size:i.size,progress:0})),T=[...p[r]||[],...R];d({...p,[r]:T});const H=i=>e=>{if(!r)return;console.log(`Upload successful for ${i.name}`);const u=e.data;s&&(n(A.reviewablesQueries.util.updateQueryData("getReviewablesForVersion",{projectName:s,versionId:r},a=>{a.reviewables||(a.reviewables=[]),a.reviewables.push(u)})),U&&n(w.api.util.invalidateTags([{type:"viewer",id:U}])),n(w.api.util.invalidateTags([{type:"viewer",id:r}])),y&&n(w.api.util.invalidateTags([{type:"viewer",id:y}])),b&&n(w.api.util.invalidateTags([{type:"viewer",id:b}])),f(i.name))},M=i=>e=>{r&&(console.error(`Upload failed for ${i.name}: ${e}`),h.toast.error(`Failed to upload file: ${i.name}`),d(u=>{const t=(u[r]||[]).map(o=>o.name!==i.name?o:{...o,error:e.response.data.detail||e.message});return{...u,[r]:t}}))},S=i=>r?e=>d(u=>{const t=(u[r]||[]).map(l=>l.name!==i.name?l:{...l,progress:e.total?Math.round(e.loaded/e.total*100):0}),o=t.reduce((l,x)=>l+(x.progress||0),0),V=Math.round(o/t.length);return c==null||c(V),{...u,[r]:t}}):()=>{};try{const i=v.map(e=>{const u=e.name.split(".").slice(0,-1).join("."),a=`/api/projects/${s}/versions/${r}/reviewables?label=${u}`,t={"content-type":e.type,"x-file-name":e.name};return z.post(a,e,{headers:t,onUploadProgress:S(e)}).then(H(e)).catch(M(e))});await Promise.all(i),g&&g()}catch(i){console.error(i),h.toast.error("Failed to upload file/s")}},[q,s,p,n,U,y,b,f,g,c]),handleRemoveUpload:f,uploading:p}};exports.useReviewablesUpload=C;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const $=require("react"),z=require("axios"),h=require("react-toastify"),w=require("../../api/base/client.cjs.js");require("../../api/generated/graphql.cjs.js");require("../../api/generated/graphqlLinks.cjs.js");require("../../api/generated/access.cjs.js");require("../../api/generated/actions.cjs.js");require("../../api/generated/activityFeed.cjs.js");require("../../api/generated/addons.cjs.js");require("../../api/generated/anatomy.cjs.js");require("../../api/generated/attributes.cjs.js");require("../../api/generated/authentication.cjs.js");require("../../api/generated/bundles.cjs.js");require("../../api/generated/configuration.cjs.js");require("../../api/generated/desktop.cjs.js");require("../../api/generated/entityLists.cjs.js");require("../../api/generated/events.cjs.js");require("../../api/generated/files.cjs.js");require("../../api/generated/folders.cjs.js");require("../../api/generated/inbox.cjs.js");require("../../api/generated/links.cjs.js");require("../../api/generated/market.cjs.js");require("../../api/generated/onboarding.cjs.js");require("../../api/generated/operations.cjs.js");require("../../api/generated/products.cjs.js");require("../../api/generated/projectDashboard.cjs.js");require("../../api/generated/projects.cjs.js");require("../../api/generated/reviewables.cjs.js");require("../../api/generated/services.cjs.js");require("../../api/generated/system.cjs.js");require("../../api/generated/tasks.cjs.js");require("../../api/generated/teams.cjs.js");require("../../api/generated/thumbnails.cjs.js");require("../../api/generated/uRIs.cjs.js");require("../../api/generated/users.cjs.js");require("../../api/generated/versions.cjs.js");require("../../api/generated/workfiles.cjs.js");require("../../api/generated/ynputCloud.cjs.js");require("../../api/generated/grouping.cjs.js");require("../../api/generated/views.cjs.js");require("../../api/queries/actions/getActions.cjs.js");require("../../api/queries/activities/getActivities.cjs.js");require("../../api/queries/activities/updateActivities.cjs.js");require("../../api/queries/activities/updateReaction.cjs.js");require("../../api/queries/activities/getMentions.cjs.js");require("../../api/queries/activities/getCategories.cjs.js");require("../../api/queries/addons/getAddons.cjs.js");require("../../api/queries/addons/updateAddons.cjs.js");require("../../api/queries/attributes/getAttributes.cjs.js");require("../../api/queries/attributes/updateAttributes.cjs.js");require("../../api/queries/authentication/getAuthentication.cjs.js");require("../../api/queries/cloud/cloud.cjs.js");require("../../api/queries/entities/getEntity.cjs.js");require("../../api/queries/entities/getEntityPanel.cjs.js");require("../../api/queries/entities/updateEntity.cjs.js");require("../../api/queries/entityLists/getLists.cjs.js");require("../../api/queries/entityLists/updateLists.cjs.js");require("../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../api/queries/entityLists/listFolders.cjs.js");require("../../api/queries/folders/getFolders.cjs.js");require("../../api/queries/grouping/getGrouping.cjs.js");require("../../api/queries/links/updateLinks.cjs.js");require("../../api/queries/links/getLinks.cjs.js");require("../../api/queries/links/getEntityLinks.cjs.js");require("../../api/queries/overview/getOverview.cjs.js");require("../../api/queries/overview/updateOverview.cjs.js");require("../../api/queries/permissions/getPermissions.cjs.js");require("../../api/queries/products/createProduct.cjs.js");require("../../api/queries/project/getProject.cjs.js");require("../../api/queries/project/updateProject.cjs.js");require("../../api/queries/review/getReview.cjs.js");const A=require("../../api/queries/review/updateReview.cjs.js");require("../../api/queries/share/share.cjs.js");require("../../api/queries/system/getSystem.cjs.js");require("../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../api/queries/users/getUsers.cjs.js");require("../../api/queries/users/updateUsers.cjs.js");require("../../api/queries/versions/updateVersions.cjs.js");require("../../api/queries/views/getViews.cjs.js");require("../../api/queries/views/updateViews.cjs.js");require("../../api/queries/watchers/getWatchers.cjs.js");const C=({projectName:s,versionId:q,taskId:b,folderId:y,productId:U,dispatch:n,onUpload:g,onProgress:c})=>{const[p,d]=$.useState({}),f=$.useCallback(F=>{q&&d(m=>{var r;return{...m,[q]:((r=m[q])==null?void 0:r.filter(v=>v.name!==F))||[]}})},[q]);return{handleFileUpload:$.useCallback(async(F,m)=>{const r=m||q;if(!r||!s)return;const v=Array.from(F),R=v.map(i=>({name:i.name,size:i.size,progress:0})),T=[...p[r]||[],...R];d({...p,[r]:T});const H=i=>e=>{if(!r)return;console.log(`Upload successful for ${i.name}`);const u=e.data;s&&(n(A.reviewablesQueries.util.updateQueryData("getReviewablesForVersion",{projectName:s,versionId:r},a=>{a.reviewables||(a.reviewables=[]),a.reviewables.push(u)})),U&&n(w.api.util.invalidateTags([{type:"viewer",id:U}])),n(w.api.util.invalidateTags([{type:"viewer",id:r}])),y&&n(w.api.util.invalidateTags([{type:"viewer",id:y}])),b&&n(w.api.util.invalidateTags([{type:"viewer",id:b}])),f(i.name))},M=i=>e=>{r&&(console.error(`Upload failed for ${i.name}: ${e}`),h.toast.error(`Failed to upload file: ${i.name}`),d(u=>{const t=(u[r]||[]).map(o=>o.name!==i.name?o:{...o,error:e.response.data.detail||e.message});return{...u,[r]:t}}))},S=i=>r?e=>d(u=>{const t=(u[r]||[]).map(l=>l.name!==i.name?l:{...l,progress:e.total?Math.round(e.loaded/e.total*100):0}),o=t.reduce((l,x)=>l+(x.progress||0),0),V=Math.round(o/t.length);return c==null||c(V),{...u,[r]:t}}):()=>{};try{const i=v.map(e=>{const u=e.name.split(".").slice(0,-1).join("."),a=`/api/projects/${s}/versions/${r}/reviewables?label=${u}`,t={"content-type":e.type,"x-file-name":e.name};return z.post(a,e,{headers:t,onUploadProgress:S(e)}).then(H(e)).catch(M(e))});await Promise.all(i),g&&g()}catch(i){console.error(i),h.toast.error("Failed to upload file/s")}},[q,s,p,n,U,y,b,f,g,c]),handleRemoveUpload:f,uploading:p}};exports.useReviewablesUpload=C;
|
|
2
2
|
//# sourceMappingURL=useReviewablesUpload.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useReviewablesUpload.cjs.js","sources":["../../../../../src/components/ReviewablesList/useReviewablesUpload.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\nimport type { ReviewableProgress } from '@shared/components'\n\nexport interface UseReviewablesUploadProps {\n projectName: string | null\n versionId?: string | null\n taskId?: string | null\n folderId?: string | null\n productId?: string | null\n dispatch: any\n onUpload?: () => void\n onProgress?: (progress: number) => void\n}\n\nexport interface UploadHandlers {\n handleFileUpload: (files: FileList | File[], versionId?: string) => Promise<void>\n handleRemoveUpload: (name: string) => void\n uploading: { [key: string]: ReviewableProgress[] }\n}\n\nexport const useReviewablesUpload = ({\n projectName,\n versionId,\n taskId,\n folderId,\n productId,\n dispatch,\n onUpload,\n onProgress,\n}: UseReviewablesUploadProps): UploadHandlers => {\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = useCallback(\n (name: string) => {\n if (!versionId) return\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n },\n [versionId],\n )\n\n const handleFileUpload = useCallback(\n async (files: FileList | File[], fileVersionId?: string) => {\n // use the passed versionId or the one from props\n const reviewableVersionId = fileVersionId || versionId\n if (!reviewableVersionId || !projectName) return\n\n const fileArray = Array.from(files)\n\n const uploadingFiles = fileArray.map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[reviewableVersionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [reviewableVersionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n if (!reviewableVersionId) return\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId: reviewableVersionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: reviewableVersionId }]))\n folderId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n taskId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n if (!reviewableVersionId) return\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n if (!reviewableVersionId) return () => {}\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // Calculate overall progress across all files\n const totalProgress = updatedUploads.reduce(\n (sum, upload) => sum + (upload.progress || 0),\n 0,\n )\n const overallProgress = Math.round(totalProgress / updatedUploads.length)\n\n // Call the onProgress callback with overall progress\n onProgress?.(overallProgress)\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n const uploadPromises = fileArray.map((file) => {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${reviewableVersionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n return axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n })\n\n // Wait for all uploads to complete\n await Promise.all(uploadPromises)\n\n // Callback after all uploads are finished\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n },\n [\n versionId,\n projectName,\n uploading,\n dispatch,\n productId,\n folderId,\n taskId,\n handleRemoveUpload,\n onUpload,\n onProgress,\n ],\n )\n\n return {\n handleFileUpload,\n handleRemoveUpload,\n uploading,\n }\n}\n"],"names":["useReviewablesUpload","projectName","versionId","taskId","folderId","productId","dispatch","onUpload","onProgress","uploading","setUploads","useState","handleRemoveUpload","useCallback","name","uploads","_a","upload","files","fileVersionId","reviewableVersionId","fileArray","uploadingFiles","file","newUploadsForVersion","successHandler","response","data","reviewablesQueries","draft","api","errorHandler","error","toast","updatedUploads","progressHandler","progressEvent","totalProgress","sum","overallProgress","uploadPromises","autoLabel","url","headers","axios"],"mappings":"ytIAyBO,MAAMA,EAAuB,CAAC,CACnC,YAAAC,EACA,UAAAC,EACA,OAAAC,EACA,SAAAC,EACA,UAAAC,EACA,SAAAC,EACA,SAAAC,EACA,WAAAC,CACF,IAAiD,CAC/C,KAAM,CAACC,EAAWC,CAAU,EAAIC,EAAAA,SAAkD,CAAA,CAAE,EAE9EC,EAAqBC,EAAA,YACxBC,GAAiB,CACXZ,GACLQ,EAAYK,GAAa,OAAA,OACvB,GAAGA,EACH,CAACb,CAAS,IAAGc,EAAAD,EAAQb,CAAS,IAAjB,YAAAc,EAAoB,OAAQC,GAAWA,EAAO,OAASH,KAAS,CAAA,CAAC,EAC9E,CACJ,EACA,CAACZ,CAAS,CACZ,EAqJO,MAAA,CACL,iBApJuBW,EAAA,YACvB,MAAOK,EAA0BC,IAA2B,CAE1D,MAAMC,EAAsBD,GAAiBjB,EACzC,GAAA,CAACkB,GAAuB,CAACnB,EAAa,OAEpC,MAAAoB,EAAY,MAAM,KAAKH,CAAK,EAE5BI,EAAiBD,EAAU,IAAKE,IAAU,CAC9C,KAAMA,EAAK,KACX,KAAMA,EAAK,KACX,SAAU,CAAA,EACV,EAEIC,EAAuB,CAAC,GAAIf,EAAUW,CAAmB,GAAK,CAAA,EAAK,GAAGE,CAAc,EAE1FZ,EAAW,CAAE,GAAGD,EAAW,CAACW,CAAmB,EAAGI,EAAsB,EAExE,MAAMC,EAAkBF,GAAgBG,GAA4B,CAClE,GAAI,CAACN,EAAqB,OAE1B,QAAQ,IAAI,yBAAyBG,EAAK,IAAI,EAAE,EAEhD,MAAMI,EAAOD,EAAS,KAEjBzB,IAELK,EAEEsB,qBAAmB,KAAK,gBACtB,2BACA,CAAE,YAAA3B,EAAa,UAAWmB,CAAoB,EAC7CS,GAAU,CACJA,EAAM,cACTA,EAAM,YAAc,CAAC,GAGjBA,EAAA,YAAY,KAAKF,CAAI,CAAA,CAC7B,CAEJ,EAGAtB,GAAaC,EAASwB,MAAI,KAAK,eAAe,CAAC,CAAE,KAAM,SAAU,GAAIzB,CAAA,CAAW,CAAC,CAAC,EACzEC,EAAAwB,EAAA,IAAI,KAAK,eAAe,CAAC,CAAE,KAAM,SAAU,GAAIV,CAAqB,CAAA,CAAC,CAAC,EAC/EhB,GAAYE,EAASwB,MAAI,KAAK,eAAe,CAAC,CAAE,KAAM,SAAU,GAAI1B,CAAA,CAAU,CAAC,CAAC,EAChFD,GAAUG,EAASwB,MAAI,KAAK,eAAe,CAAC,CAAE,KAAM,SAAU,GAAI3B,CAAA,CAAQ,CAAC,CAAC,EAE5ES,EAAmBW,EAAK,IAAI,EAC9B,EAEMQ,EAAgBR,GAAgBS,GAAe,CAC9CZ,IACL,QAAQ,MAAM,qBAAqBG,EAAK,IAAI,KAAKS,CAAK,EAAE,EACxDC,EAAA,MAAM,MAAM,0BAA0BV,EAAK,IAAI,EAAE,EAEjDb,EAAYK,GAAY,CAGtB,MAAMmB,GADiBnB,EAAQK,CAAmB,GAAK,CAAC,GAClB,IAAKH,GACrCA,EAAO,OAASM,EAAK,KAAaN,EAC/B,CACL,GAAGA,EACH,MAAOe,EAAM,SAAS,KAAK,QAAUA,EAAM,OAC7C,CACD,EAGM,MAAA,CACL,GAAGjB,EACH,CAACK,CAAmB,EAAGc,CACzB,CAAA,CACD,EACH,EAEMC,EAAmBZ,GAClBH,EACGgB,GACN1B,EAAYK,GAAY,CAGtB,MAAMmB,GADiBnB,EAAQK,CAAmB,GAAK,CAAC,GAClB,IAAKH,GACrCA,EAAO,OAASM,EAAK,KAAaN,EAC/B,CACL,GAAGA,EACH,SAAUmB,EAAc,MACpB,KAAK,MAAOA,EAAc,OAASA,EAAc,MAAS,GAAG,EAC7D,CACN,CACD,EAGKC,EAAgBH,EAAe,OACnC,CAACI,EAAKrB,IAAWqB,GAAOrB,EAAO,UAAY,GAC3C,CACF,EACMsB,EAAkB,KAAK,MAAMF,EAAgBH,EAAe,MAAM,EAGxE,OAAA1B,GAAA,MAAAA,EAAa+B,GAGN,CACL,GAAGxB,EACH,CAACK,CAAmB,EAAGc,CACzB,CAAA,CACD,EA9B8B,IAAM,CAAC,EAiCtC,GAAA,CAEF,MAAMM,EAAiBnB,EAAU,IAAKE,GAAS,CACvC,MAAAkB,EAAYlB,EAAK,KAAK,MAAM,GAAG,EAAE,MAAM,EAAG,EAAE,EAAE,KAAK,GAAG,EAEtDmB,EAAM,iBAAiBzC,CAAW,aAAamB,CAAmB,sBAAsBqB,CAAS,GACjGE,EAAU,CAAE,eAAgBpB,EAAK,KAAM,cAAeA,EAAK,IAAK,EAC/D,OAAAqB,EACJ,KAAKF,EAAKnB,EAAM,CAAE,QAAAoB,EAAS,iBAAkBR,EAAgBZ,CAAI,CAAA,CAAG,EACpE,KAAKE,EAAeF,CAAI,CAAC,EACzB,MAAMQ,EAAaR,CAAI,CAAC,CAAA,CAC5B,EAGK,MAAA,QAAQ,IAAIiB,CAAc,EAGhCjC,GAAYA,EAAS,QACdyB,EAAO,CAEd,QAAQ,MAAMA,CAAK,EACnBC,EAAA,MAAM,MAAM,yBAAyB,CAAA,CAEzC,EACA,CACE/B,EACAD,EACAQ,EACAH,EACAD,EACAD,EACAD,EACAS,EACAL,EACAC,CAAA,CAEJ,EAIE,mBAAAI,EACA,UAAAH,CACF,CACF"}
|
|
1
|
+
{"version":3,"file":"useReviewablesUpload.cjs.js","sources":["../../../../../src/components/ReviewablesList/useReviewablesUpload.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\nimport type { ReviewableProgress } from '@shared/components'\n\nexport interface UseReviewablesUploadProps {\n projectName: string | null\n versionId?: string | null\n taskId?: string | null\n folderId?: string | null\n productId?: string | null\n dispatch: any\n onUpload?: () => void\n onProgress?: (progress: number) => void\n}\n\nexport interface UploadHandlers {\n handleFileUpload: (files: FileList | File[], versionId?: string) => Promise<void>\n handleRemoveUpload: (name: string) => void\n uploading: { [key: string]: ReviewableProgress[] }\n}\n\nexport const useReviewablesUpload = ({\n projectName,\n versionId,\n taskId,\n folderId,\n productId,\n dispatch,\n onUpload,\n onProgress,\n}: UseReviewablesUploadProps): UploadHandlers => {\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = useCallback(\n (name: string) => {\n if (!versionId) return\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n },\n [versionId],\n )\n\n const handleFileUpload = useCallback(\n async (files: FileList | File[], fileVersionId?: string) => {\n // use the passed versionId or the one from props\n const reviewableVersionId = fileVersionId || versionId\n if (!reviewableVersionId || !projectName) return\n\n const fileArray = Array.from(files)\n\n const uploadingFiles = fileArray.map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[reviewableVersionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [reviewableVersionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n if (!reviewableVersionId) return\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId: reviewableVersionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: reviewableVersionId }]))\n folderId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n taskId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n if (!reviewableVersionId) return\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n if (!reviewableVersionId) return () => {}\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // Calculate overall progress across all files\n const totalProgress = updatedUploads.reduce(\n (sum, upload) => sum + (upload.progress || 0),\n 0,\n )\n const overallProgress = Math.round(totalProgress / updatedUploads.length)\n\n // Call the onProgress callback with overall progress\n onProgress?.(overallProgress)\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n const uploadPromises = fileArray.map((file) => {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${reviewableVersionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n return axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n })\n\n // Wait for all uploads to complete\n await Promise.all(uploadPromises)\n\n // Callback after all uploads are finished\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n },\n [\n versionId,\n projectName,\n uploading,\n dispatch,\n productId,\n folderId,\n taskId,\n handleRemoveUpload,\n onUpload,\n onProgress,\n ],\n )\n\n return {\n handleFileUpload,\n handleRemoveUpload,\n uploading,\n }\n}\n"],"names":["useReviewablesUpload","projectName","versionId","taskId","folderId","productId","dispatch","onUpload","onProgress","uploading","setUploads","useState","handleRemoveUpload","useCallback","name","uploads","_a","upload","files","fileVersionId","reviewableVersionId","fileArray","uploadingFiles","file","newUploadsForVersion","successHandler","response","data","reviewablesQueries","draft","api","errorHandler","error","toast","updatedUploads","progressHandler","progressEvent","totalProgress","sum","overallProgress","uploadPromises","autoLabel","url","headers","axios"],"mappings":"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"}
|
|
@@ -44,6 +44,7 @@ import "../../api/queries/activities/getActivities.es.js";
|
|
|
44
44
|
import "../../api/queries/activities/updateActivities.es.js";
|
|
45
45
|
import "../../api/queries/activities/updateReaction.es.js";
|
|
46
46
|
import "../../api/queries/activities/getMentions.es.js";
|
|
47
|
+
import "../../api/queries/activities/getCategories.es.js";
|
|
47
48
|
import "../../api/queries/addons/getAddons.es.js";
|
|
48
49
|
import "../../api/queries/addons/updateAddons.es.js";
|
|
49
50
|
import "../../api/queries/attributes/getAttributes.es.js";
|
|
@@ -80,7 +81,7 @@ import "../../api/queries/versions/updateVersions.es.js";
|
|
|
80
81
|
import "../../api/queries/views/getViews.es.js";
|
|
81
82
|
import "../../api/queries/views/updateViews.es.js";
|
|
82
83
|
import "../../api/queries/watchers/getWatchers.es.js";
|
|
83
|
-
const
|
|
84
|
+
const ut = ({
|
|
84
85
|
projectName: n,
|
|
85
86
|
versionId: p,
|
|
86
87
|
taskId: b,
|
|
@@ -180,6 +181,6 @@ const lt = ({
|
|
|
180
181
|
};
|
|
181
182
|
};
|
|
182
183
|
export {
|
|
183
|
-
|
|
184
|
+
ut as useReviewablesUpload
|
|
184
185
|
};
|
|
185
186
|
//# sourceMappingURL=useReviewablesUpload.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useReviewablesUpload.es.js","sources":["../../../../../src/components/ReviewablesList/useReviewablesUpload.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\nimport type { ReviewableProgress } from '@shared/components'\n\nexport interface UseReviewablesUploadProps {\n projectName: string | null\n versionId?: string | null\n taskId?: string | null\n folderId?: string | null\n productId?: string | null\n dispatch: any\n onUpload?: () => void\n onProgress?: (progress: number) => void\n}\n\nexport interface UploadHandlers {\n handleFileUpload: (files: FileList | File[], versionId?: string) => Promise<void>\n handleRemoveUpload: (name: string) => void\n uploading: { [key: string]: ReviewableProgress[] }\n}\n\nexport const useReviewablesUpload = ({\n projectName,\n versionId,\n taskId,\n folderId,\n productId,\n dispatch,\n onUpload,\n onProgress,\n}: UseReviewablesUploadProps): UploadHandlers => {\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = useCallback(\n (name: string) => {\n if (!versionId) return\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n },\n [versionId],\n )\n\n const handleFileUpload = useCallback(\n async (files: FileList | File[], fileVersionId?: string) => {\n // use the passed versionId or the one from props\n const reviewableVersionId = fileVersionId || versionId\n if (!reviewableVersionId || !projectName) return\n\n const fileArray = Array.from(files)\n\n const uploadingFiles = fileArray.map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[reviewableVersionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [reviewableVersionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n if (!reviewableVersionId) return\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId: reviewableVersionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: reviewableVersionId }]))\n folderId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n taskId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n if (!reviewableVersionId) return\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n if (!reviewableVersionId) return () => {}\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // Calculate overall progress across all files\n const totalProgress = updatedUploads.reduce(\n (sum, upload) => sum + (upload.progress || 0),\n 0,\n )\n const overallProgress = Math.round(totalProgress / updatedUploads.length)\n\n // Call the onProgress callback with overall progress\n onProgress?.(overallProgress)\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n const uploadPromises = fileArray.map((file) => {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${reviewableVersionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n return axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n })\n\n // Wait for all uploads to complete\n await Promise.all(uploadPromises)\n\n // Callback after all uploads are finished\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n },\n [\n versionId,\n projectName,\n uploading,\n dispatch,\n productId,\n folderId,\n taskId,\n handleRemoveUpload,\n onUpload,\n onProgress,\n ],\n )\n\n return {\n handleFileUpload,\n handleRemoveUpload,\n uploading,\n }\n}\n"],"names":["useReviewablesUpload","projectName","versionId","taskId","folderId","productId","dispatch","onUpload","onProgress","uploading","setUploads","useState","handleRemoveUpload","useCallback","name","uploads","_a","upload","files","fileVersionId","reviewableVersionId","fileArray","uploadingFiles","file","newUploadsForVersion","successHandler","response","data","reviewablesQueries","draft","api","errorHandler","error","toast","updatedUploads","progressHandler","progressEvent","totalProgress","sum","overallProgress","uploadPromises","autoLabel","url","headers","axios"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useReviewablesUpload.es.js","sources":["../../../../../src/components/ReviewablesList/useReviewablesUpload.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\nimport type { ReviewableProgress } from '@shared/components'\n\nexport interface UseReviewablesUploadProps {\n projectName: string | null\n versionId?: string | null\n taskId?: string | null\n folderId?: string | null\n productId?: string | null\n dispatch: any\n onUpload?: () => void\n onProgress?: (progress: number) => void\n}\n\nexport interface UploadHandlers {\n handleFileUpload: (files: FileList | File[], versionId?: string) => Promise<void>\n handleRemoveUpload: (name: string) => void\n uploading: { [key: string]: ReviewableProgress[] }\n}\n\nexport const useReviewablesUpload = ({\n projectName,\n versionId,\n taskId,\n folderId,\n productId,\n dispatch,\n onUpload,\n onProgress,\n}: UseReviewablesUploadProps): UploadHandlers => {\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = useCallback(\n (name: string) => {\n if (!versionId) return\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n },\n [versionId],\n )\n\n const handleFileUpload = useCallback(\n async (files: FileList | File[], fileVersionId?: string) => {\n // use the passed versionId or the one from props\n const reviewableVersionId = fileVersionId || versionId\n if (!reviewableVersionId || !projectName) return\n\n const fileArray = Array.from(files)\n\n const uploadingFiles = fileArray.map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[reviewableVersionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [reviewableVersionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n if (!reviewableVersionId) return\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId: reviewableVersionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: reviewableVersionId }]))\n folderId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n taskId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n if (!reviewableVersionId) return\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n if (!reviewableVersionId) return () => {}\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for reviewableVersionId\n const currentUploads = uploads[reviewableVersionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // Calculate overall progress across all files\n const totalProgress = updatedUploads.reduce(\n (sum, upload) => sum + (upload.progress || 0),\n 0,\n )\n const overallProgress = Math.round(totalProgress / updatedUploads.length)\n\n // Call the onProgress callback with overall progress\n onProgress?.(overallProgress)\n\n // update state\n return {\n ...uploads,\n [reviewableVersionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n const uploadPromises = fileArray.map((file) => {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${reviewableVersionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n return axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n })\n\n // Wait for all uploads to complete\n await Promise.all(uploadPromises)\n\n // Callback after all uploads are finished\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n },\n [\n versionId,\n projectName,\n uploading,\n dispatch,\n productId,\n folderId,\n taskId,\n handleRemoveUpload,\n onUpload,\n onProgress,\n ],\n )\n\n return {\n handleFileUpload,\n handleRemoveUpload,\n uploading,\n }\n}\n"],"names":["useReviewablesUpload","projectName","versionId","taskId","folderId","productId","dispatch","onUpload","onProgress","uploading","setUploads","useState","handleRemoveUpload","useCallback","name","uploads","_a","upload","files","fileVersionId","reviewableVersionId","fileArray","uploadingFiles","file","newUploadsForVersion","successHandler","response","data","reviewablesQueries","draft","api","errorHandler","error","toast","updatedUploads","progressHandler","progressEvent","totalProgress","sum","overallProgress","uploadPromises","autoLabel","url","headers","axios"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const W=require("../../../../_virtual/jsx-runtime.cjs.js"),$=require("../../util/productTypes.cjs.js"),G=require("lodash");require("react-toastify");const c=require("../../util/getAttributeIcon.cjs.js");require("uuid");require("../../util/pubsub.cjs.js");require("../../api/base/client.cjs.js");require("../../api/generated/graphql.cjs.js");require("../../api/generated/graphqlLinks.cjs.js");require("../../api/generated/access.cjs.js");require("../../api/generated/actions.cjs.js");require("../../api/generated/activityFeed.cjs.js");require("../../api/generated/addons.cjs.js");require("../../api/generated/anatomy.cjs.js");require("../../api/generated/attributes.cjs.js");require("../../api/generated/authentication.cjs.js");require("../../api/generated/bundles.cjs.js");require("../../api/generated/configuration.cjs.js");require("../../api/generated/desktop.cjs.js");require("../../api/generated/entityLists.cjs.js");require("../../api/generated/events.cjs.js");require("../../api/generated/files.cjs.js");require("../../api/generated/folders.cjs.js");require("../../api/generated/inbox.cjs.js");require("../../api/generated/links.cjs.js");require("../../api/generated/market.cjs.js");require("../../api/generated/onboarding.cjs.js");require("../../api/generated/operations.cjs.js");require("../../api/generated/products.cjs.js");require("../../api/generated/projectDashboard.cjs.js");require("../../api/generated/projects.cjs.js");require("../../api/generated/reviewables.cjs.js");require("../../api/generated/services.cjs.js");require("../../api/generated/system.cjs.js");require("../../api/generated/tasks.cjs.js");require("../../api/generated/teams.cjs.js");require("../../api/generated/thumbnails.cjs.js");require("../../api/generated/uRIs.cjs.js");require("../../api/generated/users.cjs.js");require("../../api/generated/versions.cjs.js");require("../../api/generated/workfiles.cjs.js");require("../../api/generated/ynputCloud.cjs.js");require("../../api/generated/grouping.cjs.js");require("../../api/generated/views.cjs.js");require("../../api/queries/actions/getActions.cjs.js");require("../../api/queries/activities/getActivities.cjs.js");require("../../api/queries/activities/updateActivities.cjs.js");require("../../api/queries/activities/updateReaction.cjs.js");require("../../api/queries/activities/getMentions.cjs.js");require("../../api/queries/addons/getAddons.cjs.js");require("../../api/queries/addons/updateAddons.cjs.js");require("../../api/queries/attributes/getAttributes.cjs.js");require("../../api/queries/attributes/updateAttributes.cjs.js");require("../../api/queries/authentication/getAuthentication.cjs.js");require("../../api/queries/cloud/cloud.cjs.js");require("../../api/queries/entities/getEntity.cjs.js");require("../../api/queries/entities/getEntityPanel.cjs.js");require("../../api/queries/entities/updateEntity.cjs.js");require("../../api/queries/entityLists/getLists.cjs.js");require("../../api/queries/entityLists/updateLists.cjs.js");require("../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../api/queries/entityLists/listFolders.cjs.js");require("../../api/queries/folders/getFolders.cjs.js");require("../../api/queries/grouping/getGrouping.cjs.js");require("../../api/queries/links/updateLinks.cjs.js");require("../../api/queries/links/getLinks.cjs.js");require("../../api/queries/links/getEntityLinks.cjs.js");require("../../api/queries/overview/getOverview.cjs.js");require("../../api/queries/overview/updateOverview.cjs.js");require("../../api/queries/permissions/getPermissions.cjs.js");require("../../api/queries/products/createProduct.cjs.js");require("../../api/queries/project/getProject.cjs.js");require("../../api/queries/project/updateProject.cjs.js");require("../../api/queries/review/getReview.cjs.js");require("../../api/queries/review/updateReview.cjs.js");require("../../api/queries/share/share.cjs.js");const Q=require("../../api/queries/system/getSystem.cjs.js"),H=require("../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../api/queries/users/getUsers.cjs.js");require("../../api/queries/users/updateUsers.cjs.js");require("../../api/queries/versions/updateVersions.cjs.js");require("../../api/queries/views/getViews.cjs.js");require("../../api/queries/views/updateViews.cjs.js");require("../../api/queries/watchers/getWatchers.cjs.js");const U=require("@ynput/ayon-react-components"),L=require("./filterDates.cjs.js"),z=({filterTypes:t,projectNames:e,scope:u,data:s,config:a,columnOrder:l=[],power:d})=>{var x,k,R,_,T,f;let q=[];const{data:y={}}=H.useGetProjectsInfoQuery({projects:e},{skip:!(e!=null&&e.length)||!["entitySubType","status"].some(r=>t.includes(r))}),{data:w=[]}=H.useGetKanbanProjectUsersQuery({projects:e},{skip:!(e!=null&&e.length)||!t.includes("users")&&!t.includes("assignees")}),{data:V}=Q.useGetSiteInfoQuery({full:!0},{skip:!t.includes("attributes")}),{attributes:B=[]}=V||{};if(t.includes("taskType")&&u!=="user"){const r=O("taskType",{...a,enableOperatorChange:!1});if(r){let i=E(y,"task");(x=r.values)==null||x.push(...i),q.push(r)}}if(t.includes("folderType")&&u!=="user"){const r=O("folderType",{...a,enableOperatorChange:!1});if(r){let i=E(y,"folder");(k=r.values)==null||k.push(...i),q.push(r)}}if(t.includes("productType")&&u!=="user"){const r=O("productType",{...a,enableOperatorChange:!1});if(r){let i=E(y,"product");(R=r.values)==null||R.push(...i),q.push(r)}}if(t.includes("status")){const r=O("status",{...a,enableOperatorChange:!1});r&&(Object.values(y).forEach(i=>{((i==null?void 0:i.statuses)||[]).forEach(n=>{var o,b;(o=r.values)!=null&&o.some(p=>p.id===n.name)||(b=r.values)==null||b.push({id:n.name,label:n.name,icon:n.icon,color:n.color})})}),q.push(r))}if(t.includes("assignees")){const r=O("assignees",a);r&&(w.forEach(i=>{var h,n;(h=r.values)!=null&&h.some(o=>o.id===i.name)||(n=r.values)==null||n.push({id:i.name,label:i.attrib.fullName||i.name,img:`/api/users/${i.name}/avatar`,icon:null})}),(_=r.values)==null||_.sort((i,h)=>{var b,p;const n=((b=s.assignees)==null?void 0:b.filter(v=>v===i.id).length)||0;return(((p=s.assignees)==null?void 0:p.filter(v=>v===h.id).length)||0)-n}),q.push(r))}if(t.includes("tags")){const r=O("tags",a);if(r){const i=new Map;Object.values(y).forEach(o=>{o!=null&&o.tags&&o.tags.forEach(b=>{i.has(b.name)||i.set(b.name,b)})});const h=new Map;(T=s.tags)==null||T.forEach(o=>{const b=h.get(o);if(b){b.count++;return}else{const p=i.get(o);h.set(o,{id:o,type:"string",label:o,values:[],color:(p==null?void 0:p.color)||null,count:1})}});const n=Array.from(h.values()).sort((o,b)=>b.count-o.count);(f=r.values)==null||f.push(...n),q.push(r)}}if(t.includes("attributes")){const r=B.filter(n=>{var o;return(o=n.scope)==null?void 0:o.includes(u)}),i=G.isEmpty(s.attributes)?r:r.filter(n=>s.attributes&&s.attributes[n.name]);(a!=null&&a.enableRelativeValues?i:i.filter(n=>n.data.type!=="datetime")).forEach(n=>{var I;const o=s.attributes&&s.attributes[n.name],b=n.data.enum,p=n.data.type,v=["list_of_strings","list_of_integers","list_of_any","list_of_submodels"].includes(p),A=p==="datetime",D=v?a==null?void 0:a.enableOperatorChange:!1,M=v||A?a==null?void 0:a.enableRelativeValues:!1,S=J(n,{...a,allowsCustomValues:!0,enableOperatorChange:D,enableRelativeValues:M}),P=["string","integer","float","list_of_strings","list_of_integers"],C=[];if(P.includes(p)){const m=K(o,b,p);C.push(...m)}if(p==="boolean"){const m=[{id:"true",label:"Yes",values:[],icon:"radio_button_checked"},{id:"false",label:"No",values:[],icon:"radio_button_unchecked"}];C.push(...m)}A&&C.push(...L.dateOptions.map(m=>({...m,contentAfter:d?void 0:W.jsxRuntimeExports.jsx(U.Icon,{icon:"bolt"})}))),(I=S.values)==null||I.push(...C),q.push(S)})}return l?Y(q,l):q},E=(t,e)=>{const u=[];return e==="product"?Object.values($).forEach(({icon:s,name:a})=>{u.push({id:a,type:"string",label:a,icon:s,inverted:!1,values:[],allowsCustomValues:!1})}):e==="task"?Object.values(t).forEach(s=>{((s==null?void 0:s.taskTypes)||[]).forEach(l=>{u.some(d=>d.id===l.name)||u.push({id:l.name,type:"string",label:l.name,icon:l.icon,inverted:!1,values:[],allowsCustomValues:!1})})}):e==="folder"&&Object.values(t).forEach(s=>{((s==null?void 0:s.folderTypes)||[]).forEach(l=>{u.some(d=>d.id===l.name)||u.push({id:l.name,type:"string",label:l.name,icon:l.icon,inverted:!1,values:[],allowsCustomValues:!1})})}),u},F=(t,e,u)=>{const{prefixes:s,keys:a}=u||{};return a&&e in a?`${a[e]}`:s&&e in s?`${s[e]}${t}`:t},O=(t,e)=>{const u=a=>F(a,t,e);let s=null;switch(t){case"taskType":s={id:u("taskType"),type:"string",label:"Task Type",icon:c.getAttributeIcon("task"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"folderType":s={id:u("folderType"),type:"string",label:"Folder Type",icon:c.getAttributeIcon("folder"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"productType":s={id:u("productType"),type:"string",label:"Product Type",icon:c.getAttributeIcon("product"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"status":s={id:u("status"),type:"string",label:"Status",icon:c.getAttributeIcon("status"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"assignees":s={id:u("assignees"),type:"list_of_strings",label:"Assignee",icon:c.getAttributeIcon("assignees"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:e==null?void 0:e.enableRelativeValues,allowNoValue:e==null?void 0:e.enableRelativeValues,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:e==null?void 0:e.enableOperatorChange};break;case"tags":s={id:u("tags"),type:"list_of_strings",label:"Tags",icon:c.getAttributeIcon("tags"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!0,allowHasValue:e==null?void 0:e.enableRelativeValues,allowNoValue:e==null?void 0:e.enableRelativeValues,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:e==null?void 0:e.enableOperatorChange};break}return s},J=(t,e)=>{var u;return{id:F(t.name,"attributes",e),type:t.data.type,label:t.data.title||t.name,operator:"OR",inverted:!1,values:[],allowsCustomValues:e==null?void 0:e.allowsCustomValues,allowHasValue:e.enableRelativeValues,allowNoValue:e.enableRelativeValues,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:e==null?void 0:e.enableOperatorChange,icon:c.getAttributeIcon(t.name,t.data.type,!!((u=t.data.enum)!=null&&u.length)),singleSelect:["boolean","datetime"].includes(t.data.type)}},K=(t,e,u)=>{const s=[],a=[];return e&&e.forEach(l=>{s.push({id:l.value.toString(),type:u,label:l.label,values:[],icon:l.icon,color:l.color})}),t==null||t.forEach(l=>{if(!l)return;let d="";switch(typeof l){case"string":case"number":case"boolean":d=l.toString();break;case"object":Array.isArray(l)?d=l.join(", "):d=JSON.stringify(l);break}const q=d.trim().toLowerCase().replace(/[^a-z0-9\s]/g,"").replace(/\s+/g,"-");if(s==null?void 0:s.find(V=>V.id===q))return;const w=a.find(V=>V.id===q);if(w){w.count++;return}else a.push({id:q,type:u,label:d,values:[],count:1})}),a.sort((l,d)=>d.count-l.count),[...s,...a]},Y=(t,e)=>{const u=e.flatMap(s=>s==="subType"?["taskType","folderType"]:s);return[...t].sort((s,a)=>{const l=u.indexOf(s.id.replace(".","_")),d=u.indexOf(a.id.replace(".","_"));return l!==-1&&d!==-1?l-d:l!==-1?-1:d!==-1?1:0})};exports.useBuildFilterOptions=z;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const W=require("../../../../_virtual/jsx-runtime.cjs.js"),$=require("../../util/productTypes.cjs.js"),G=require("lodash");require("react-toastify");const c=require("../../util/getAttributeIcon.cjs.js");require("uuid");require("../../util/pubsub.cjs.js");require("../../api/base/client.cjs.js");require("../../api/generated/graphql.cjs.js");require("../../api/generated/graphqlLinks.cjs.js");require("../../api/generated/access.cjs.js");require("../../api/generated/actions.cjs.js");require("../../api/generated/activityFeed.cjs.js");require("../../api/generated/addons.cjs.js");require("../../api/generated/anatomy.cjs.js");require("../../api/generated/attributes.cjs.js");require("../../api/generated/authentication.cjs.js");require("../../api/generated/bundles.cjs.js");require("../../api/generated/configuration.cjs.js");require("../../api/generated/desktop.cjs.js");require("../../api/generated/entityLists.cjs.js");require("../../api/generated/events.cjs.js");require("../../api/generated/files.cjs.js");require("../../api/generated/folders.cjs.js");require("../../api/generated/inbox.cjs.js");require("../../api/generated/links.cjs.js");require("../../api/generated/market.cjs.js");require("../../api/generated/onboarding.cjs.js");require("../../api/generated/operations.cjs.js");require("../../api/generated/products.cjs.js");require("../../api/generated/projectDashboard.cjs.js");require("../../api/generated/projects.cjs.js");require("../../api/generated/reviewables.cjs.js");require("../../api/generated/services.cjs.js");require("../../api/generated/system.cjs.js");require("../../api/generated/tasks.cjs.js");require("../../api/generated/teams.cjs.js");require("../../api/generated/thumbnails.cjs.js");require("../../api/generated/uRIs.cjs.js");require("../../api/generated/users.cjs.js");require("../../api/generated/versions.cjs.js");require("../../api/generated/workfiles.cjs.js");require("../../api/generated/ynputCloud.cjs.js");require("../../api/generated/grouping.cjs.js");require("../../api/generated/views.cjs.js");require("../../api/queries/actions/getActions.cjs.js");require("../../api/queries/activities/getActivities.cjs.js");require("../../api/queries/activities/updateActivities.cjs.js");require("../../api/queries/activities/updateReaction.cjs.js");require("../../api/queries/activities/getMentions.cjs.js");require("../../api/queries/activities/getCategories.cjs.js");require("../../api/queries/addons/getAddons.cjs.js");require("../../api/queries/addons/updateAddons.cjs.js");require("../../api/queries/attributes/getAttributes.cjs.js");require("../../api/queries/attributes/updateAttributes.cjs.js");require("../../api/queries/authentication/getAuthentication.cjs.js");require("../../api/queries/cloud/cloud.cjs.js");require("../../api/queries/entities/getEntity.cjs.js");require("../../api/queries/entities/getEntityPanel.cjs.js");require("../../api/queries/entities/updateEntity.cjs.js");require("../../api/queries/entityLists/getLists.cjs.js");require("../../api/queries/entityLists/updateLists.cjs.js");require("../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../api/queries/entityLists/listFolders.cjs.js");require("../../api/queries/folders/getFolders.cjs.js");require("../../api/queries/grouping/getGrouping.cjs.js");require("../../api/queries/links/updateLinks.cjs.js");require("../../api/queries/links/getLinks.cjs.js");require("../../api/queries/links/getEntityLinks.cjs.js");require("../../api/queries/overview/getOverview.cjs.js");require("../../api/queries/overview/updateOverview.cjs.js");require("../../api/queries/permissions/getPermissions.cjs.js");require("../../api/queries/products/createProduct.cjs.js");require("../../api/queries/project/getProject.cjs.js");require("../../api/queries/project/updateProject.cjs.js");require("../../api/queries/review/getReview.cjs.js");require("../../api/queries/review/updateReview.cjs.js");require("../../api/queries/share/share.cjs.js");const Q=require("../../api/queries/system/getSystem.cjs.js"),H=require("../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../api/queries/users/getUsers.cjs.js");require("../../api/queries/users/updateUsers.cjs.js");require("../../api/queries/versions/updateVersions.cjs.js");require("../../api/queries/views/getViews.cjs.js");require("../../api/queries/views/updateViews.cjs.js");require("../../api/queries/watchers/getWatchers.cjs.js");const U=require("@ynput/ayon-react-components"),L=require("./filterDates.cjs.js"),z=({filterTypes:t,projectNames:e,scope:u,data:s,config:r,columnOrder:l=[],power:d})=>{var x,k,R,_,T,f;let q=[];const{data:y={}}=H.useGetProjectsInfoQuery({projects:e},{skip:!(e!=null&&e.length)||!["entitySubType","status"].some(a=>t.includes(a))}),{data:w=[]}=H.useGetKanbanProjectUsersQuery({projects:e},{skip:!(e!=null&&e.length)||!t.includes("users")&&!t.includes("assignees")}),{data:V}=Q.useGetSiteInfoQuery({full:!0},{skip:!t.includes("attributes")}),{attributes:B=[]}=V||{};if(t.includes("taskType")&&u!=="user"){const a=O("taskType",{...r,enableOperatorChange:!1});if(a){let i=E(y,"task");(x=a.values)==null||x.push(...i),q.push(a)}}if(t.includes("folderType")&&u!=="user"){const a=O("folderType",{...r,enableOperatorChange:!1});if(a){let i=E(y,"folder");(k=a.values)==null||k.push(...i),q.push(a)}}if(t.includes("productType")&&u!=="user"){const a=O("productType",{...r,enableOperatorChange:!1});if(a){let i=E(y,"product");(R=a.values)==null||R.push(...i),q.push(a)}}if(t.includes("status")){const a=O("status",{...r,enableOperatorChange:!1});a&&(Object.values(y).forEach(i=>{((i==null?void 0:i.statuses)||[]).forEach(n=>{var o,b;(o=a.values)!=null&&o.some(p=>p.id===n.name)||(b=a.values)==null||b.push({id:n.name,label:n.name,icon:n.icon,color:n.color})})}),q.push(a))}if(t.includes("assignees")){const a=O("assignees",r);a&&(w.forEach(i=>{var h,n;(h=a.values)!=null&&h.some(o=>o.id===i.name)||(n=a.values)==null||n.push({id:i.name,label:i.attrib.fullName||i.name,img:`/api/users/${i.name}/avatar`,icon:null})}),(_=a.values)==null||_.sort((i,h)=>{var b,p;const n=((b=s.assignees)==null?void 0:b.filter(v=>v===i.id).length)||0;return(((p=s.assignees)==null?void 0:p.filter(v=>v===h.id).length)||0)-n}),q.push(a))}if(t.includes("tags")){const a=O("tags",r);if(a){const i=new Map;Object.values(y).forEach(o=>{o!=null&&o.tags&&o.tags.forEach(b=>{i.has(b.name)||i.set(b.name,b)})});const h=new Map;(T=s.tags)==null||T.forEach(o=>{const b=h.get(o);if(b){b.count++;return}else{const p=i.get(o);h.set(o,{id:o,type:"string",label:o,values:[],color:(p==null?void 0:p.color)||null,count:1})}});const n=Array.from(h.values()).sort((o,b)=>b.count-o.count);(f=a.values)==null||f.push(...n),q.push(a)}}if(t.includes("attributes")){const a=B.filter(n=>{var o;return(o=n.scope)==null?void 0:o.includes(u)}),i=G.isEmpty(s.attributes)?a:a.filter(n=>s.attributes&&s.attributes[n.name]);(r!=null&&r.enableRelativeValues?i:i.filter(n=>n.data.type!=="datetime")).forEach(n=>{var I;const o=s.attributes&&s.attributes[n.name],b=n.data.enum,p=n.data.type,v=["list_of_strings","list_of_integers","list_of_any","list_of_submodels"].includes(p),A=p==="datetime",D=v?r==null?void 0:r.enableOperatorChange:!1,M=v||A?r==null?void 0:r.enableRelativeValues:!1,S=J(n,{...r,allowsCustomValues:!0,enableOperatorChange:D,enableRelativeValues:M}),P=["string","integer","float","list_of_strings","list_of_integers"],C=[];if(P.includes(p)){const m=K(o,b,p);C.push(...m)}if(p==="boolean"){const m=[{id:"true",label:"Yes",values:[],icon:"radio_button_checked"},{id:"false",label:"No",values:[],icon:"radio_button_unchecked"}];C.push(...m)}A&&C.push(...L.dateOptions.map(m=>({...m,contentAfter:d?void 0:W.jsxRuntimeExports.jsx(U.Icon,{icon:"bolt"})}))),(I=S.values)==null||I.push(...C),q.push(S)})}return l?Y(q,l):q},E=(t,e)=>{const u=[];return e==="product"?Object.values($).forEach(({icon:s,name:r})=>{u.push({id:r,type:"string",label:r,icon:s,inverted:!1,values:[],allowsCustomValues:!1})}):e==="task"?Object.values(t).forEach(s=>{((s==null?void 0:s.taskTypes)||[]).forEach(l=>{u.some(d=>d.id===l.name)||u.push({id:l.name,type:"string",label:l.name,icon:l.icon,inverted:!1,values:[],allowsCustomValues:!1})})}):e==="folder"&&Object.values(t).forEach(s=>{((s==null?void 0:s.folderTypes)||[]).forEach(l=>{u.some(d=>d.id===l.name)||u.push({id:l.name,type:"string",label:l.name,icon:l.icon,inverted:!1,values:[],allowsCustomValues:!1})})}),u},F=(t,e,u)=>{const{prefixes:s,keys:r}=u||{};return r&&e in r?`${r[e]}`:s&&e in s?`${s[e]}${t}`:t},O=(t,e)=>{const u=r=>F(r,t,e);let s=null;switch(t){case"taskType":s={id:u("taskType"),type:"string",label:"Task Type",icon:c.getAttributeIcon("task"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"folderType":s={id:u("folderType"),type:"string",label:"Folder Type",icon:c.getAttributeIcon("folder"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"productType":s={id:u("productType"),type:"string",label:"Product Type",icon:c.getAttributeIcon("product"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"status":s={id:u("status"),type:"string",label:"Status",icon:c.getAttributeIcon("status"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:!1,allowNoValue:!1,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:!1};break;case"assignees":s={id:u("assignees"),type:"list_of_strings",label:"Assignee",icon:c.getAttributeIcon("assignees"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!1,allowHasValue:e==null?void 0:e.enableRelativeValues,allowNoValue:e==null?void 0:e.enableRelativeValues,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:e==null?void 0:e.enableOperatorChange};break;case"tags":s={id:u("tags"),type:"list_of_strings",label:"Tags",icon:c.getAttributeIcon("tags"),inverted:!1,operator:"OR",values:[],allowsCustomValues:!0,allowHasValue:e==null?void 0:e.enableRelativeValues,allowNoValue:e==null?void 0:e.enableRelativeValues,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:e==null?void 0:e.enableOperatorChange};break}return s},J=(t,e)=>{var u;return{id:F(t.name,"attributes",e),type:t.data.type,label:t.data.title||t.name,operator:"OR",inverted:!1,values:[],allowsCustomValues:e==null?void 0:e.allowsCustomValues,allowHasValue:e.enableRelativeValues,allowNoValue:e.enableRelativeValues,allowExcludes:e==null?void 0:e.enableExcludes,operatorChangeable:e==null?void 0:e.enableOperatorChange,icon:c.getAttributeIcon(t.name,t.data.type,!!((u=t.data.enum)!=null&&u.length)),singleSelect:["boolean","datetime"].includes(t.data.type)}},K=(t,e,u)=>{const s=[],r=[];return e&&e.forEach(l=>{s.push({id:l.value.toString(),type:u,label:l.label,values:[],icon:l.icon,color:l.color})}),t==null||t.forEach(l=>{if(!l)return;let d="";switch(typeof l){case"string":case"number":case"boolean":d=l.toString();break;case"object":Array.isArray(l)?d=l.join(", "):d=JSON.stringify(l);break}const q=d.trim().toLowerCase().replace(/[^a-z0-9\s]/g,"").replace(/\s+/g,"-");if(s==null?void 0:s.find(V=>V.id===q))return;const w=r.find(V=>V.id===q);if(w){w.count++;return}else r.push({id:q,type:u,label:d,values:[],count:1})}),r.sort((l,d)=>d.count-l.count),[...s,...r]},Y=(t,e)=>{const u=e.flatMap(s=>s==="subType"?["taskType","folderType"]:s);return[...t].sort((s,r)=>{const l=u.indexOf(s.id.replace(".","_")),d=u.indexOf(r.id.replace(".","_"));return l!==-1&&d!==-1?l-d:l!==-1?-1:d!==-1?1:0})};exports.useBuildFilterOptions=z;
|
|
2
2
|
//# sourceMappingURL=useBuildFilterOptions.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useBuildFilterOptions.cjs.js","sources":["../../../../../src/components/SearchFilter/useBuildFilterOptions.tsx"],"sourcesContent":["import { getAttributeIcon, getEntityTypeIcon } from '@shared/util'\nimport {\n useGetSiteInfoQuery,\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} from '@shared/api'\nimport { productTypes } from '@shared/util'\nimport { ColumnOrderState } from '@tanstack/react-table'\nimport { Icon, Option } from '@ynput/ayon-react-components'\nimport { dateOptions } from './filterDates'\nimport { isEmpty } from 'lodash'\n\ntype Scope = 'folder' | 'product' | 'task' | 'user' | 'version'\nexport type FilterFieldType =\n | 'folderType'\n | 'taskType'\n | 'productType'\n | ('users' | 'assignees')\n | 'attributes'\n | 'status'\n | 'tags'\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 data: {\n tags?: string[]\n attributes?: Record<string, AttributeDataValue[]>\n assignees?: string[]\n }\n columnOrder?: ColumnOrderState\n config?: FilterConfig\n power?: boolean\n}\n\nexport const useBuildFilterOptions = ({\n filterTypes,\n projectNames,\n scope,\n data,\n config,\n columnOrder = [],\n power,\n}: BuildFilterOptions): Option[] => {\n let options: Option[] = []\n\n // QUERIES\n //\n //\n const { data: projectsInfo = {} } = useGetProjectsInfoQuery(\n {\n projects: projectNames,\n },\n {\n skip:\n !projectNames?.length ||\n !['entitySubType', 'status'].some((type) => filterTypes.includes(type as FilterFieldType)),\n },\n )\n\n const { data: projectUsers = [] } = useGetKanbanProjectUsersQuery(\n { projects: projectNames },\n {\n skip:\n !projectNames?.length ||\n (!filterTypes.includes('users') && !filterTypes.includes('assignees')),\n },\n )\n\n const { data: info } = useGetSiteInfoQuery(\n { full: true },\n { skip: !filterTypes.includes('attributes') },\n )\n const { attributes = [] } = info || {}\n //\n //\n // QUERIES\n\n // ADD OPTIONS\n\n // TASK TYPE\n // add taskType option\n if (filterTypes.includes('taskType') && scope !== 'user') {\n const entitySubTypeOption = getOptionRoot('taskType', {\n ...config,\n enableOperatorChange: false,\n })\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes(projectsInfo, 'task')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // FOLDER TYPE\n // add folderType option\n if (filterTypes.includes('folderType') && scope !== 'user') {\n const entitySubTypeOption = getOptionRoot('folderType', {\n ...config,\n enableOperatorChange: false,\n })\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes(projectsInfo, 'folder')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // PRODUCT TYPE\n // add productType option\n if (filterTypes.includes('productType') && scope !== 'user') {\n const entitySubTypeOption = getOptionRoot('productType', {\n ...config,\n enableOperatorChange: false,\n })\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes(projectsInfo, 'product')\n entitySubTypeOption.values?.push(...subTypes)\n options.push(entitySubTypeOption)\n }\n }\n\n // STATUS\n // add status option\n if (filterTypes.includes('status')) {\n const statusOption = getOptionRoot('status', { ...config, enableOperatorChange: false })\n\n if (statusOption) {\n Object.values(projectsInfo).forEach((project) => {\n const statuses = project?.statuses || []\n statuses.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 (filterTypes.includes('assignees')) {\n const assigneesOption = getOptionRoot('assignees', config)\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 // TAGS\n // add tags options\n if (filterTypes.includes('tags')) {\n const tagsOption = getOptionRoot('tags', config)\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 // ATTRIBUTES\n // dynamically add attributes options\n if (filterTypes.includes('attributes')) {\n const attributesByScope = attributes.filter((attribute) => attribute.scope?.includes(scope))\n // if attributesData is provided, filter out attributes that are not in the attributesData\n const attributesByValues = !isEmpty(data.attributes)\n ? attributesByScope.filter((attribute) => data.attributes && data.attributes[attribute.name])\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(attribute, {\n ...config,\n allowsCustomValues: true,\n enableOperatorChange: enableOperatorChange,\n enableRelativeValues: enableRelativeValues,\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\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 = (projectsInfo: GetProjectsInfoResponse, type: Scope): Option[] => {\n const options: Option[] = []\n if (type === 'product') {\n Object.values(productTypes).forEach(({ icon, name }) => {\n options.push({\n id: name,\n type: 'string',\n label: name,\n icon: icon,\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 = (base: string, fieldType: FilterFieldType, config?: FilterConfig) => {\n const { prefixes, keys } = config || {}\n if (keys && fieldType in keys) {\n return `${keys[fieldType]}`\n } else if (prefixes && fieldType in prefixes) {\n return `${prefixes[fieldType]}${base}`\n } else return base\n}\n\nconst getOptionRoot = (fieldType: FilterFieldType, config?: FilterConfig) => {\n const getRootIdWithPrefix = (base: string) => getFormattedId(base, fieldType, config)\n\n let rootOption: Option | null = null\n switch (fieldType) {\n case 'taskType':\n rootOption = {\n id: getRootIdWithPrefix(`taskType`),\n type: 'string',\n label: `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: `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: `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: '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: '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 'tags':\n rootOption = {\n id: getRootIdWithPrefix('tags'),\n type: 'list_of_strings',\n label: '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 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): Option => ({\n id: getFormattedId(attribute.name, 'attributes', config),\n type: attribute.data.type,\n label: 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"],"names":["useBuildFilterOptions","filterTypes","projectNames","scope","data","config","columnOrder","power","options","projectsInfo","useGetProjectsInfoQuery","type","projectUsers","useGetKanbanProjectUsersQuery","info","useGetSiteInfoQuery","attributes","entitySubTypeOption","getOptionRoot","subTypes","getSubTypes","_a","_b","_c","statusOption","project","status","value","assigneesOption","user","_d","a","b","aCount","assignee","tagsOption","tagsAnatomy","tag","tagOptionValuesMap","_e","existingTag","tagData","tagOptionValues","_f","attributesByScope","attribute","attributesByValues","isEmpty","realData","enums","isListOf","isDate","enableOperatorChange","enableRelativeValues","option","getAttributeFieldOptionRoot","suggestValuesForTypes","optionValues","getAttributeOptions","dateOptions","o","jsx","Icon","sortOptionsBasedOnColumns","productTypes","icon","name","taskType","folderType","getFormattedId","base","fieldType","prefixes","keys","getRootIdWithPrefix","rootOption","getAttributeIcon","values","enumOptions","enumItem","text","id","existingValue","columnOrderWithSubTypes","col","aIndex","bIndex"],"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 useGetSiteInfoQuery,\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} from '@shared/api'\nimport { productTypes } from '@shared/util'\nimport { ColumnOrderState } from '@tanstack/react-table'\nimport { Icon, Option } from '@ynput/ayon-react-components'\nimport { dateOptions } from './filterDates'\nimport { isEmpty } from 'lodash'\n\ntype Scope = 'folder' | 'product' | 'task' | 'user' | 'version'\nexport type FilterFieldType =\n | 'folderType'\n | 'taskType'\n | 'productType'\n | ('users' | 'assignees')\n | 'attributes'\n | 'status'\n | 'tags'\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 data: {\n tags?: string[]\n attributes?: Record<string, AttributeDataValue[]>\n assignees?: string[]\n }\n columnOrder?: ColumnOrderState\n config?: FilterConfig\n power?: boolean\n}\n\nexport const useBuildFilterOptions = ({\n filterTypes,\n projectNames,\n scope,\n data,\n config,\n columnOrder = [],\n power,\n}: BuildFilterOptions): Option[] => {\n let options: Option[] = []\n\n // QUERIES\n //\n //\n const { data: projectsInfo = {} } = useGetProjectsInfoQuery(\n {\n projects: projectNames,\n },\n {\n skip:\n !projectNames?.length ||\n !['entitySubType', 'status'].some((type) => filterTypes.includes(type as FilterFieldType)),\n },\n )\n\n const { data: projectUsers = [] } = useGetKanbanProjectUsersQuery(\n { projects: projectNames },\n {\n skip:\n !projectNames?.length ||\n (!filterTypes.includes('users') && !filterTypes.includes('assignees')),\n },\n )\n\n const { data: info } = useGetSiteInfoQuery(\n { full: true },\n { skip: !filterTypes.includes('attributes') },\n )\n const { attributes = [] } = info || {}\n //\n //\n // QUERIES\n\n // ADD OPTIONS\n\n // TASK TYPE\n // add taskType option\n if (filterTypes.includes('taskType') && scope !== 'user') {\n const entitySubTypeOption = getOptionRoot('taskType', {\n ...config,\n enableOperatorChange: false,\n })\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes(projectsInfo, 'task')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // FOLDER TYPE\n // add folderType option\n if (filterTypes.includes('folderType') && scope !== 'user') {\n const entitySubTypeOption = getOptionRoot('folderType', {\n ...config,\n enableOperatorChange: false,\n })\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes(projectsInfo, 'folder')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // PRODUCT TYPE\n // add productType option\n if (filterTypes.includes('productType') && scope !== 'user') {\n const entitySubTypeOption = getOptionRoot('productType', {\n ...config,\n enableOperatorChange: false,\n })\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes(projectsInfo, 'product')\n entitySubTypeOption.values?.push(...subTypes)\n options.push(entitySubTypeOption)\n }\n }\n\n // STATUS\n // add status option\n if (filterTypes.includes('status')) {\n const statusOption = getOptionRoot('status', { ...config, enableOperatorChange: false })\n\n if (statusOption) {\n Object.values(projectsInfo).forEach((project) => {\n const statuses = project?.statuses || []\n statuses.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 (filterTypes.includes('assignees')) {\n const assigneesOption = getOptionRoot('assignees', config)\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 // TAGS\n // add tags options\n if (filterTypes.includes('tags')) {\n const tagsOption = getOptionRoot('tags', config)\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 // ATTRIBUTES\n // dynamically add attributes options\n if (filterTypes.includes('attributes')) {\n const attributesByScope = attributes.filter((attribute) => attribute.scope?.includes(scope))\n // if attributesData is provided, filter out attributes that are not in the attributesData\n const attributesByValues = !isEmpty(data.attributes)\n ? attributesByScope.filter((attribute) => data.attributes && data.attributes[attribute.name])\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(attribute, {\n ...config,\n allowsCustomValues: true,\n enableOperatorChange: enableOperatorChange,\n enableRelativeValues: enableRelativeValues,\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\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 = (projectsInfo: GetProjectsInfoResponse, type: Scope): Option[] => {\n const options: Option[] = []\n if (type === 'product') {\n Object.values(productTypes).forEach(({ icon, name }) => {\n options.push({\n id: name,\n type: 'string',\n label: name,\n icon: icon,\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 = (base: string, fieldType: FilterFieldType, config?: FilterConfig) => {\n const { prefixes, keys } = config || {}\n if (keys && fieldType in keys) {\n return `${keys[fieldType]}`\n } else if (prefixes && fieldType in prefixes) {\n return `${prefixes[fieldType]}${base}`\n } else return base\n}\n\nconst getOptionRoot = (fieldType: FilterFieldType, config?: FilterConfig) => {\n const getRootIdWithPrefix = (base: string) => getFormattedId(base, fieldType, config)\n\n let rootOption: Option | null = null\n switch (fieldType) {\n case 'taskType':\n rootOption = {\n id: getRootIdWithPrefix(`taskType`),\n type: 'string',\n label: `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: `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: `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: '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: '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 'tags':\n rootOption = {\n id: getRootIdWithPrefix('tags'),\n type: 'list_of_strings',\n label: '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 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): Option => ({\n id: getFormattedId(attribute.name, 'attributes', config),\n type: attribute.data.type,\n label: 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"],"names":["useBuildFilterOptions","filterTypes","projectNames","scope","data","config","columnOrder","power","options","projectsInfo","useGetProjectsInfoQuery","type","projectUsers","useGetKanbanProjectUsersQuery","info","useGetSiteInfoQuery","attributes","entitySubTypeOption","getOptionRoot","subTypes","getSubTypes","_a","_b","_c","statusOption","project","status","value","assigneesOption","user","_d","a","b","aCount","assignee","tagsOption","tagsAnatomy","tag","tagOptionValuesMap","_e","existingTag","tagData","tagOptionValues","_f","attributesByScope","attribute","attributesByValues","isEmpty","realData","enums","isListOf","isDate","enableOperatorChange","enableRelativeValues","option","getAttributeFieldOptionRoot","suggestValuesForTypes","optionValues","getAttributeOptions","dateOptions","o","jsx","Icon","sortOptionsBasedOnColumns","productTypes","icon","name","taskType","folderType","getFormattedId","base","fieldType","prefixes","keys","getRootIdWithPrefix","rootOption","getAttributeIcon","values","enumOptions","enumItem","text","id","existingValue","columnOrderWithSubTypes","col","aIndex","bIndex"],"mappings":"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"}
|
|
@@ -48,6 +48,7 @@ import "../../api/queries/activities/getActivities.es.js";
|
|
|
48
48
|
import "../../api/queries/activities/updateActivities.es.js";
|
|
49
49
|
import "../../api/queries/activities/updateReaction.es.js";
|
|
50
50
|
import "../../api/queries/activities/getMentions.es.js";
|
|
51
|
+
import "../../api/queries/activities/getCategories.es.js";
|
|
51
52
|
import "../../api/queries/addons/getAddons.es.js";
|
|
52
53
|
import "../../api/queries/addons/updateAddons.es.js";
|
|
53
54
|
import "../../api/queries/attributes/getAttributes.es.js";
|
|
@@ -86,7 +87,7 @@ import "../../api/queries/views/updateViews.es.js";
|
|
|
86
87
|
import "../../api/queries/watchers/getWatchers.es.js";
|
|
87
88
|
import { Icon as z } from "@ynput/ayon-react-components";
|
|
88
89
|
import { dateOptions as J } from "./filterDates.es.js";
|
|
89
|
-
const
|
|
90
|
+
const At = ({
|
|
90
91
|
filterTypes: s,
|
|
91
92
|
projectNames: e,
|
|
92
93
|
scope: r,
|
|
@@ -466,6 +467,6 @@ const St = ({
|
|
|
466
467
|
});
|
|
467
468
|
};
|
|
468
469
|
export {
|
|
469
|
-
|
|
470
|
+
At as useBuildFilterOptions
|
|
470
471
|
};
|
|
471
472
|
//# sourceMappingURL=useBuildFilterOptions.es.js.map
|