@ynput/ayon-frontend-shared 0.3.11 → 0.3.13
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 +24 -22
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/ProjectTreeTable.cjs.js +1 -1
- package/dist/ProjectTreeTable.es.js +95 -96
- package/dist/Slicer.cjs.js +1 -1
- package/dist/Slicer.es.js +12 -11
- package/dist/Slicer.es.js.map +1 -1
- package/dist/_virtual/index.cjs3.js +1 -1
- package/dist/_virtual/index.cjs4.js +1 -1
- package/dist/_virtual/index.cjs5.js +1 -1
- package/dist/_virtual/index.es3.js +4 -4
- package/dist/_virtual/index.es4.js +5 -2
- package/dist/_virtual/index.es4.js.map +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 +2 -2
- package/dist/api.cjs.js +1 -1
- package/dist/api.es.js +138 -136
- package/dist/api.es.js.map +1 -1
- package/dist/components.cjs.js +1 -1
- package/dist/components.es.js +21 -17
- package/dist/components.es.js.map +1 -1
- package/dist/hooks.cjs.js +1 -1
- package/dist/hooks.es.js +20 -18
- package/dist/hooks.es.js.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +11 -9
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.cjs.js +1 -1
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.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/node_modules/primereact/skeleton/skeleton.esm.cjs.js +2 -0
- package/dist/shared/node_modules/primereact/skeleton/skeleton.esm.cjs.js.map +1 -0
- package/dist/shared/node_modules/primereact/skeleton/skeleton.esm.es.js +51 -0
- package/dist/shared/node_modules/primereact/skeleton/skeleton.esm.es.js.map +1 -0
- package/dist/shared/node_modules/prop-types/index.cjs.js +1 -1
- package/dist/shared/node_modules/prop-types/index.es.js +1 -1
- package/dist/shared/node_modules/react-is/index.cjs.js +1 -1
- package/dist/shared/node_modules/react-is/index.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.es.js +1 -1
- package/dist/shared/src/api/generated/addons.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/addons.es.js.map +1 -1
- package/dist/shared/src/api/generated/projects.cjs.js +1 -1
- package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/projects.es.js +36 -1
- package/dist/shared/src/api/generated/projects.es.js.map +1 -1
- package/dist/shared/src/api/generated/views.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/views.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/patchDetailsPanel.cjs.js +1 -1
- package/dist/shared/src/api/queries/entities/patchDetailsPanel.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/patchDetailsPanel.es.js +3 -2
- package/dist/shared/src/api/queries/entities/patchDetailsPanel.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/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 +7 -6
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/project/getProject.cjs.js +1 -1
- package/dist/shared/src/api/queries/project/getProject.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/project/getProject.es.js +4 -6
- package/dist/shared/src/api/queries/project/getProject.es.js.map +1 -1
- package/dist/shared/src/api/queries/tasks/getTasks.cjs.js +2 -0
- package/dist/shared/src/api/queries/tasks/getTasks.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/tasks/getTasks.es.js +14 -0
- package/dist/shared/src/api/queries/tasks/getTasks.es.js.map +1 -0
- package/dist/shared/src/api/queries/users/getUsers.cjs.js +3 -3
- package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.es.js +19 -18
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/api/queries/versions/updateVersions.cjs.js +1 -1
- package/dist/shared/src/api/queries/versions/updateVersions.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/versions/updateVersions.es.js +9 -7
- package/dist/shared/src/api/queries/versions/updateVersions.es.js.map +1 -1
- 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 +3 -3
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +76 -71
- 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 +25 -24
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.cjs.js +12 -5
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.es.js +9 -2
- 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/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/EntityIcon/EntityIcon.cjs.js +2 -0
- package/dist/shared/src/components/EntityIcon/EntityIcon.cjs.js.map +1 -0
- package/dist/shared/src/components/EntityIcon/EntityIcon.es.js +37 -0
- package/dist/shared/src/components/EntityIcon/EntityIcon.es.js.map +1 -0
- 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 +30 -27
- 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/FileThumbnail/FileThumbnail.cjs.js +13 -3
- package/dist/shared/src/components/FileThumbnail/FileThumbnail.cjs.js.map +1 -1
- package/dist/shared/src/components/FileThumbnail/FileThumbnail.es.js +29 -19
- package/dist/shared/src/components/FileThumbnail/FileThumbnail.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 +48 -195
- 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 +28 -31
- package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/LinksManager.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/LinksManager.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 +4 -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 +4 -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 +6 -4
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +4 -2
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/components/RemotePage/ProjectPageRemote.cjs.js +1 -1
- package/dist/shared/src/components/RemotePage/ProjectPageRemote.cjs.js.map +1 -1
- package/dist/shared/src/components/RemotePage/ProjectPageRemote.es.js +4 -2
- package/dist/shared/src/components/RemotePage/ProjectPageRemote.es.js.map +1 -1
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.cjs.js +1 -1
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.cjs.js.map +1 -1
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.es.js +4 -2
- package/dist/shared/src/components/RemotePage/RemotePageWrapper.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 +4 -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 +11 -10
- 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 +4 -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 +5 -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 +4 -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/ReviewablesSelector/ReviewablesSelector.cjs.js +2 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.cjs.js.map +1 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.es.js +349 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.es.js.map +1 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.styled.cjs.js +74 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.styled.cjs.js.map +1 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.styled.es.js +84 -0
- package/dist/shared/src/components/ReviewablesSelector/ReviewablesSelector.styled.es.js.map +1 -0
- 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 +121 -105
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +4 -2
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
- package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.cjs.js +1 -1
- package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.cjs.js.map +1 -1
- package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.es.js +3 -2
- package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.es.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js +2 -2
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js +5 -4
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/Thumbnail.cjs.js +1 -1
- package/dist/shared/src/components/Thumbnail/Thumbnail.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/Thumbnail.es.js +27 -26
- package/dist/shared/src/components/Thumbnail/Thumbnail.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionDialog.cjs.js +2 -2
- package/dist/shared/src/components/VersionUploader/components/UploadVersionDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionDialog.es.js +13 -13
- package/dist/shared/src/components/VersionUploader/components/UploadVersionDialog.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +30 -6
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +190 -95
- 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 +138 -128
- 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 +4 -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 +39 -39
- package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.styled.cjs.js +12 -16
- package/dist/shared/src/containers/Actions/Actions.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.styled.es.js +15 -19
- package/dist/shared/src/containers/Actions/Actions.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js +8 -5
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js +12 -9
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.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 +4 -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 +4 -2
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.es.js +4 -2
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.es.js +5 -3
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.es.js +122 -125
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.styled.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +3 -2
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelTabs/DetailsPanelTabs.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelTabs/DetailsPanelTabs.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelTabs/DetailsPanelTabs.es.js +29 -25
- package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelTabs/DetailsPanelTabs.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.cjs.js +4 -5
- package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.es.js +18 -17
- package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.es.js +4 -2
- package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.es.js +4 -2
- package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.es.js +3 -2
- package/dist/shared/src/containers/DetailsPanel/containers/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 +4 -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 +4 -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 +4 -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 +4 -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 +5 -3
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/util/buildEntityPickerTableData.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/util/buildEntityPickerTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/util/buildEntityPickerTableData.es.js +32 -24
- package/dist/shared/src/containers/EntityPickerDialog/util/buildEntityPickerTableData.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 +132 -128
- package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.es.js +4 -2
- package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js +89 -86
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.es.js +4 -2
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.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 +28 -27
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.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 +4 -2
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/InputMarkdownConvert.cjs.js +6 -2
- package/dist/shared/src/containers/Feed/components/CommentInput/InputMarkdownConvert.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/InputMarkdownConvert.es.js +64 -54
- package/dist/shared/src/containers/Feed/components/CommentInput/InputMarkdownConvert.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/quillToMarkdown.cjs.js +5 -5
- package/dist/shared/src/containers/Feed/components/CommentInput/quillToMarkdown.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/quillToMarkdown.es.js +37 -35
- package/dist/shared/src/containers/Feed/components/CommentInput/quillToMarkdown.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.es.js +21 -21
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.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 +6 -5
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +3 -2
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/mentionHelpers/getMentionTasks.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/mentionHelpers/getMentionTasks.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/mentionHelpers/getMentionTasks.es.js +7 -6
- package/dist/shared/src/containers/Feed/mentionHelpers/getMentionTasks.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 +505 -489
- 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 +246 -229
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.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 +4 -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 +4 -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 +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +5 -4
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js +147 -146
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.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 +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.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 +51 -49
- 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 +58 -64
- 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 +4 -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 +4 -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 +4 -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 +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +4 -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 +4 -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 +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.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 +15 -13
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.es.js +2 -2
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/linksToTableData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/linksToTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/linksToTableData.es.js +24 -38
- package/dist/shared/src/containers/ProjectTreeTable/utils/linksToTableData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +2 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +25 -22
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js +6 -6
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js +17 -16
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js +8 -8
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js +50 -49
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.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 +6 -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 +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.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 +4 -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 +4 -2
- package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js.map +1 -1
- package/dist/shared/src/containers/Slicer/components/SlicerSearch.cjs.js +1 -1
- package/dist/shared/src/containers/Slicer/components/SlicerSearch.cjs.js.map +1 -1
- package/dist/shared/src/containers/Slicer/components/SlicerSearch.es.js +4 -2
- package/dist/shared/src/containers/Slicer/components/SlicerSearch.es.js.map +1 -1
- package/dist/shared/src/containers/Slicer/context/SlicerContext.cjs.js +1 -1
- package/dist/shared/src/containers/Slicer/context/SlicerContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Slicer/context/SlicerContext.es.js +5 -4
- package/dist/shared/src/containers/Slicer/context/SlicerContext.es.js.map +1 -1
- package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.cjs.js +1 -1
- package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.cjs.js.map +1 -1
- package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.es.js +10 -8
- package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.es.js.map +1 -1
- package/dist/shared/src/containers/Slicer/hooks/useUsersTable.cjs.js +1 -1
- package/dist/shared/src/containers/Slicer/hooks/useUsersTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/Slicer/hooks/useUsersTable.es.js +3 -2
- package/dist/shared/src/containers/Slicer/hooks/useUsersTable.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/ViewsMenuContainer/BaseViewsTags.cjs.js +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.es.js +4 -2
- package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.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/useBaseViewMutations.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.es.js +3 -2
- package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.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 +4 -3
- 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 +89 -82
- package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
- package/dist/shared/src/context/GlobalContext.cjs.js +1 -1
- package/dist/shared/src/context/GlobalContext.cjs.js.map +1 -1
- package/dist/shared/src/context/GlobalContext.es.js +5 -4
- package/dist/shared/src/context/GlobalContext.es.js.map +1 -1
- package/dist/shared/src/context/PowerpackContext.cjs.js +1 -1
- package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
- package/dist/shared/src/context/PowerpackContext.es.js +7 -6
- package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
- package/dist/shared/src/context/ProjectContext.cjs.js +1 -1
- package/dist/shared/src/context/ProjectContext.cjs.js.map +1 -1
- package/dist/shared/src/context/ProjectContext.es.js +64 -61
- package/dist/shared/src/context/ProjectContext.es.js.map +1 -1
- package/dist/shared/src/context/ProjectFoldersContext.cjs.js +1 -1
- package/dist/shared/src/context/ProjectFoldersContext.cjs.js.map +1 -1
- package/dist/shared/src/context/ProjectFoldersContext.es.js +5 -4
- package/dist/shared/src/context/ProjectFoldersContext.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/context/SubtasksModulesContext.cjs.js +1 -1
- package/dist/shared/src/context/SubtasksModulesContext.cjs.js.map +1 -1
- package/dist/shared/src/context/SubtasksModulesContext.es.js +5 -4
- package/dist/shared/src/context/SubtasksModulesContext.es.js.map +1 -1
- package/dist/shared/src/context/UriContext.cjs.js +1 -1
- package/dist/shared/src/context/UriContext.cjs.js.map +1 -1
- package/dist/shared/src/context/UriContext.es.js +6 -5
- package/dist/shared/src/context/UriContext.es.js.map +1 -1
- package/dist/shared/src/context/WebsocketContext.cjs.js +1 -1
- package/dist/shared/src/context/WebsocketContext.cjs.js.map +1 -1
- package/dist/shared/src/context/WebsocketContext.es.js +6 -4
- package/dist/shared/src/context/WebsocketContext.es.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.cjs.js +1 -1
- package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.es.js +3 -2
- package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.es.js +3 -2
- package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
- package/dist/shared/src/hooks/useGetEntityGroups.cjs.js +1 -1
- package/dist/shared/src/hooks/useGetEntityGroups.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useGetEntityGroups.es.js +3 -2
- package/dist/shared/src/hooks/useGetEntityGroups.es.js.map +1 -1
- package/dist/shared/src/hooks/useGroupByRemoteModules.cjs.js +1 -1
- package/dist/shared/src/hooks/useGroupByRemoteModules.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useGroupByRemoteModules.es.js +3 -2
- package/dist/shared/src/hooks/useGroupByRemoteModules.es.js.map +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.cjs.js +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.es.js +25 -24
- package/dist/shared/src/hooks/useHierarchyTable.es.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.es.js +5 -4
- package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
- package/dist/shared/src/hooks/useScopedTypes.cjs.js +2 -0
- package/dist/shared/src/hooks/useScopedTypes.cjs.js.map +1 -0
- package/dist/shared/src/hooks/useScopedTypes.es.js +109 -0
- package/dist/shared/src/hooks/useScopedTypes.es.js.map +1 -0
- 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/columnConfigConverter.cjs.js +1 -1
- package/dist/shared/src/util/columnConfigConverter.cjs.js.map +1 -1
- package/dist/shared/src/util/columnConfigConverter.es.js +61 -60
- package/dist/shared/src/util/columnConfigConverter.es.js.map +1 -1
- package/dist/shared/src/util/iconUtils.cjs.js +2 -0
- package/dist/shared/src/util/iconUtils.cjs.js.map +1 -0
- package/dist/shared/src/util/iconUtils.es.js +18 -0
- package/dist/shared/src/util/iconUtils.es.js.map +1 -0
- package/dist/shared/src/util/isHTMLElement.cjs.js +2 -0
- package/dist/shared/src/util/isHTMLElement.cjs.js.map +1 -0
- package/dist/shared/src/util/isHTMLElement.es.js +5 -0
- package/dist/shared/src/util/isHTMLElement.es.js.map +1 -0
- package/dist/shared/src/util/versionUploadHelpers.cjs.js.map +1 -1
- package/dist/shared/src/util/versionUploadHelpers.es.js.map +1 -1
- package/dist/types/api/generated/addons.d.ts +4 -0
- package/dist/types/api/generated/enums.d.ts +2 -0
- package/dist/types/api/generated/projects.d.ts +71 -3
- package/dist/types/api/generated/views.d.ts +2 -0
- package/dist/types/api/queries/project/getProject.d.ts +4 -185
- package/dist/types/api/queries/project/updateProject.d.ts +11 -11
- package/dist/types/api/queries/tasks/getTasks.d.ts +185 -0
- package/dist/types/api/queries/tasks/index.d.ts +1 -0
- package/dist/types/api/queries/versions/updateVersions.d.ts +185 -1
- package/dist/types/components/EntityIcon/EntityIcon.d.ts +10 -0
- package/dist/types/components/EntityIcon/index.d.ts +1 -0
- package/dist/types/components/LinksManager/LinksManager.d.ts +1 -0
- package/dist/types/components/ReviewablesSelector/ReviewablesSelector.d.ts +12 -0
- package/dist/types/components/ReviewablesSelector/ReviewablesSelector.styled.d.ts +8 -0
- package/dist/types/components/ReviewablesSelector/index.d.ts +2 -0
- package/dist/types/components/Thumbnail/StackedThumbnails.d.ts +1 -0
- package/dist/types/components/Thumbnail/Thumbnail.d.ts +3 -2
- package/dist/types/components/VersionUploader/context/VersionUploadContext.d.ts +14 -2
- package/dist/types/components/index.d.ts +2 -0
- package/dist/types/containers/EntityPickerDialog/util/buildEntityPickerTableData.d.ts +1 -0
- package/dist/types/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.d.ts +2 -1
- package/dist/types/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.d.ts +1 -0
- package/dist/types/containers/Feed/mentionHelpers/getMentionTasks.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/types/project.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/utils/linksToTableData.d.ts +2 -12
- package/dist/types/containers/ProjectTreeTable/widgets/EntityNameWidget.d.ts +3 -3
- package/dist/types/containers/ProjectTreeTable/widgets/EnumCellValue.d.ts +2 -1
- package/dist/types/containers/Slicer/hooks/useProjectAnatomySlices.d.ts +0 -1
- package/dist/types/context/ProjectContext.d.ts +1 -2
- package/dist/types/hooks/index.d.ts +1 -0
- package/dist/types/hooks/useHierarchyTable.d.ts +2 -1
- package/dist/types/hooks/useScopedTypes.d.ts +4 -0
- package/dist/types/util/iconUtils.d.ts +4 -0
- package/dist/types/util/index.d.ts +2 -0
- package/dist/types/util/isHTMLElement.d.ts +2 -0
- package/dist/types/util/versionUploadHelpers.d.ts +1 -0
- package/dist/util.cjs.js +1 -1
- package/dist/util.es.js +20 -18
- package/dist/util.es.js.map +1 -1
- package/package.json +2 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VersionUploadContext.cjs.js","sources":["../../../../../../src/components/VersionUploader/context/VersionUploadContext.tsx"],"sourcesContent":["import {\n GetLatestVersionResult,\n useCreateVersionMutation,\n useGetLatestProductVersionQuery,\n} from '@shared/api'\nimport React, {\n createContext,\n useContext,\n useState,\n ReactNode,\n useMemo,\n useCallback,\n useEffect,\n} from 'react'\nimport { useCreateProductMutation } from '@shared/api'\nimport { extractVersionFromFilename } from '@shared/util'\nimport { toast } from 'react-toastify'\nimport {\n validateFormData as validateFormDataHelper,\n createProductAndVersion,\n createVersionHelper,\n handleUploadError,\n getNextVersionNumber,\n type ProductCreationData,\n type VersionCreationData,\n} from '@shared/util/versionUploadHelpers'\n\nexport interface FormData {\n version: number\n name: string\n productType: string\n}\ninterface VersionUploadContextType {\n productId: string\n folderId: string\n taskId: string\n setProductId: (productId: string) => void\n setFolderId: (folderId: string) => void\n isOpen: boolean\n projectName: string\n version: GetLatestVersionResult | undefined\n pendingFiles: Array<{ file: File; preview?: string }>\n setPendingFiles: React.Dispatch<React.SetStateAction<Array<{ file: File; preview?: string }>>>\n extractAndSetVersionFromFiles: (files: File[]) => void\n form: FormData\n setForm: React.Dispatch<React.SetStateAction<FormData>>\n isSubmitting: boolean\n error: string\n createdProductId: string | null\n createdVersionId: string | null\n onOpenVersionUpload: (params: { productId?: string; folderId?: string; taskId?: string }) => void\n onCloseVersionUpload: () => void\n onUploadVersion: (data: FormData) => Promise<{ productId: string; versionId: string }>\n handleFormChange: (key: keyof FormData, value: string | number) => void\n handleFormSubmit: (formData: FormData) => Promise<void>\n // pass through\n dispatch: any\n}\n\nconst VersionUploadContext = createContext<VersionUploadContextType | undefined>(undefined)\n\ninterface VersionUploadProviderProps {\n children: ReactNode\n projectName: string\n onVersionCreated: (productId: string, versionId: string) => void\n dispatch: any\n}\n\nconst defaultFormData: FormData = {\n version: 1,\n name: 'review',\n productType: 'review',\n}\n\nexport const VersionUploadProvider: React.FC<VersionUploadProviderProps> = ({\n children,\n projectName,\n onVersionCreated,\n dispatch,\n}) => {\n const [folderId, setFolderId] = useState<string>('')\n const [productId, setProductId] = useState<string>('')\n // optional taskId to link the version to\n const [taskId, setTaskId] = useState<string>('')\n const [isOpen, setIsOpen] = useState<boolean>(false)\n const [pendingFiles, setPendingFiles] = useState<Array<{ file: File; preview?: string }>>([])\n const [form, setForm] = useState<FormData>(defaultFormData)\n const [isSubmitting, setIsSubmitting] = useState(false)\n const [error, setError] = useState<string>('')\n const [createdProductId, setCreatedProductId] = useState<string | null>(null)\n const [createdVersionId, setCreatedVersionId] = useState<string | null>(null)\n\n const { currentData: version } = useGetLatestProductVersionQuery(\n {\n projectName,\n productId,\n },\n { skip: !productId || !isOpen },\n )\n\n const onOpenVersionUpload = useCallback<VersionUploadContextType['onOpenVersionUpload']>(\n ({ productId, folderId, taskId }) => {\n setProductId(productId || '')\n setFolderId(folderId || '')\n setTaskId(taskId || '')\n setIsOpen(true)\n },\n [],\n )\n\n const onCloseVersionUpload = useCallback<VersionUploadContextType['onCloseVersionUpload']>(() => {\n // Clean up pending files\n pendingFiles.forEach((item) => {\n if (item.preview) {\n URL.revokeObjectURL(item.preview)\n }\n })\n setPendingFiles([])\n setForm(defaultFormData)\n setCreatedProductId(null)\n setCreatedVersionId(null)\n setError('')\n setIsSubmitting(false)\n setIsOpen(false)\n setProductId('')\n setFolderId('')\n setTaskId('')\n }, [pendingFiles])\n\n const [createProduct] = useCreateProductMutation()\n const [createVersion] = useCreateVersionMutation()\n\n const onUploadVersion = useCallback<VersionUploadContextType['onUploadVersion']>(\n async (data: FormData) => {\n console.log('Uploading version with data:', data)\n try {\n if (version && productId) {\n // product already exists, create new version for it\n const versionRes = await createVersionHelper(createVersion, projectName, {\n productId,\n version: data.version,\n })\n\n // select the new version\n onVersionCreated(productId, versionRes.id)\n\n return {\n productId,\n versionId: versionRes.id,\n }\n } else {\n // product does not exist, create new product with version\n const { product: productRes, version: versionRes } = await createProductAndVersion(\n createProduct,\n createVersion,\n projectName,\n {\n folderId,\n name: data.name,\n productType: data.productType || 'review',\n },\n {\n version: data.version,\n taskId: taskId || undefined,\n },\n )\n\n // select the new product and version\n onVersionCreated(productRes.id, versionRes.id)\n\n toast.success('Created new version')\n\n return {\n productId: productRes.id,\n versionId: versionRes.id,\n }\n }\n } catch (error: any) {\n console.error('Error uploading version:', error)\n throw error.message || error\n }\n },\n [onCloseVersionUpload, productId, folderId, taskId, version, projectName],\n )\n\n const extractAndSetVersionFromFiles = useCallback(\n (files: File[]) => {\n // Only extract version if we don't already have a product (new product workflow)\n if (productId) return\n\n // Try to extract version from the first file\n const firstFile = files[0]\n if (firstFile) {\n const extractedVersion = extractVersionFromFilename(firstFile.name)\n if (extractedVersion && extractedVersion !== form.version) {\n setForm((prev) => ({\n ...prev,\n version: extractedVersion,\n }))\n }\n }\n },\n [productId, form.version],\n )\n\n // Handle form changes\n const handleFormChange = useCallback((key: keyof FormData, value: string | number) => {\n setForm((prev) => ({\n ...prev,\n [key]: value,\n }))\n }, [])\n\n const validateFormData = () => {\n const validation = validateFormDataHelper(form, version?.version, !version)\n if (!validation.isValid) {\n throw validation.error\n }\n }\n\n // Handle form submission\n const handleFormSubmit = useCallback(\n async (formData: FormData) => {\n try {\n setIsSubmitting(true)\n setError('')\n\n // validate the form data\n validateFormData()\n\n const response = await onUploadVersion(formData)\n\n // Extract productId and versionId from response\n if (response?.productId) {\n setCreatedProductId(response.productId)\n }\n if (response?.versionId) {\n setCreatedVersionId(response.versionId)\n }\n\n if (pendingFiles.length < 1) {\n setIsSubmitting(false)\n onCloseVersionUpload()\n }\n } catch (error: any) {\n setError(error)\n setIsSubmitting(false)\n }\n },\n [onUploadVersion, pendingFiles.length, onCloseVersionUpload],\n )\n\n // Update form when version data changes\n useEffect(() => {\n if (!isOpen) return\n\n if (version) {\n setForm({\n ...defaultFormData,\n version: getNextVersionNumber(version),\n })\n } else {\n setForm(defaultFormData)\n }\n\n return () => {\n setForm(defaultFormData)\n }\n }, [isOpen, version])\n\n const value = useMemo(\n () => ({\n productId,\n setProductId,\n folderId,\n taskId,\n setFolderId,\n isOpen,\n projectName,\n version: productId ? version : undefined,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n setForm,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n }),\n [\n folderId,\n setFolderId,\n productId,\n taskId,\n setProductId,\n isOpen,\n projectName,\n version,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n ],\n )\n\n return <VersionUploadContext.Provider value={value}>{children}</VersionUploadContext.Provider>\n}\n\nexport const useVersionUploadContext = (): VersionUploadContextType => {\n const context = useContext(VersionUploadContext)\n if (context === undefined) {\n throw new Error('useVersionUploadContext must be used within a VersionUploadProvider')\n }\n return context\n}\n"],"names":["VersionUploadContext","createContext","defaultFormData","VersionUploadProvider","children","projectName","onVersionCreated","dispatch","folderId","setFolderId","useState","productId","setProductId","taskId","setTaskId","isOpen","setIsOpen","pendingFiles","setPendingFiles","form","setForm","isSubmitting","setIsSubmitting","error","setError","createdProductId","setCreatedProductId","createdVersionId","setCreatedVersionId","version","useGetLatestProductVersionQuery","onOpenVersionUpload","useCallback","onCloseVersionUpload","item","createProduct","useCreateProductMutation","createVersion","useCreateVersionMutation","onUploadVersion","data","versionRes","createVersionHelper","productRes","createProductAndVersion","toast","extractAndSetVersionFromFiles","files","firstFile","extractedVersion","extractVersionFromFilename","prev","handleFormChange","key","value","validateFormData","validation","validateFormDataHelper","handleFormSubmit","formData","response","useEffect","getNextVersionNumber","useMemo","jsx","useVersionUploadContext","context","useContext"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VersionUploadContext.cjs.js","sources":["../../../../../../src/components/VersionUploader/context/VersionUploadContext.tsx"],"sourcesContent":["import {\n useCreateVersionMutation,\n useCreateProductMutation,\n useGetLatestProductVersionQuery,\n useGetVersionQuery,\n} from '@shared/api'\nimport React, {\n createContext,\n useContext,\n useState,\n ReactNode,\n useMemo,\n useCallback,\n useEffect,\n} from 'react'\nimport { extractVersionFromFilename } from '@shared/util'\nimport { toast } from 'react-toastify'\nimport {\n validateFormData as validateFormDataHelper,\n createProductAndVersion,\n createVersionHelper,\n} from '@shared/util/versionUploadHelpers'\n\nexport interface FormData {\n version: number\n name: string\n productType: string\n}\nexport interface LinkedTask {\n id: string\n name: string\n label?: string | null\n taskType: string\n}\n\ninterface VersionUploadContextType {\n productId: string\n folderId: string\n taskId: string\n linkedTask: LinkedTask | null\n isLoadingTask: boolean\n setTaskId: (taskId: string) => void\n setLinkedTask: (task: LinkedTask | null) => void\n setProductId: (productId: string) => void\n setFolderId: (folderId: string) => void\n isOpen: boolean\n projectName: string\n latestVersion: number | undefined\n pendingFiles: Array<{ file: File; preview?: string }>\n setPendingFiles: React.Dispatch<React.SetStateAction<Array<{ file: File; preview?: string }>>>\n extractAndSetVersionFromFiles: (files: File[]) => void\n form: FormData\n setForm: React.Dispatch<React.SetStateAction<FormData>>\n isSubmitting: boolean\n error: string\n createdProductId: string | null\n createdVersionId: string | null\n onOpenVersionUpload: (params: {\n productId?: string\n folderId?: string\n taskId?: string\n linkedTask?: LinkedTask\n latestVersionNumber?: number\n latestVersionId?: string\n }) => void\n onCloseVersionUpload: () => void\n onUploadVersion: (data: FormData) => Promise<{ productId: string; versionId: string }>\n handleFormChange: (key: keyof FormData, value: string | number) => void\n handleFormSubmit: (formData: FormData) => Promise<void>\n // pass through\n dispatch: any\n}\n\nconst VersionUploadContext = createContext<VersionUploadContextType | undefined>(undefined)\n\ninterface VersionUploadProviderProps {\n children: ReactNode\n projectName: string\n onVersionCreated: (productId: string, versionId: string) => void\n dispatch: any\n}\n\nconst defaultFormData: FormData = {\n version: 1,\n name: 'review',\n productType: 'review',\n}\n\nexport const VersionUploadProvider: React.FC<VersionUploadProviderProps> = ({\n children,\n projectName,\n onVersionCreated,\n dispatch,\n}) => {\n const [folderId, setFolderId] = useState<string>('')\n const [productId, setProductId] = useState<string>('')\n // optional task to link the version to\n // null = not set by user (auto-resolve from version), '' = explicitly cleared, 'id' = explicitly set\n const [userTaskId, setUserTaskId] = useState<string | null>(null)\n const [linkedTask, setLinkedTask] = useState<LinkedTask | null>(null)\n const [isOpen, setIsOpen] = useState<boolean>(false)\n const [pendingFiles, setPendingFiles] = useState<Array<{ file: File; preview?: string }>>([])\n const [form, setForm] = useState<FormData>(defaultFormData)\n const [isSubmitting, setIsSubmitting] = useState(false)\n const [error, setError] = useState<string>('')\n const [createdProductId, setCreatedProductId] = useState<string | null>(null)\n const [createdVersionId, setCreatedVersionId] = useState<string | null>(null)\n // Stores the latest version number passed from the caller (e.g. VP page)\n // so we can skip the GetLatestProductVersion query when we already know it\n const [latestVersionNumber, setLatestVersionNumber] = useState<number | undefined>(undefined)\n // Stores the latest version ID so we can fetch its task when not already known\n const [latestVersionId, setLatestVersionId] = useState<string | undefined>(undefined)\n\n const { currentData: version } = useGetLatestProductVersionQuery(\n {\n projectName,\n productId,\n },\n { skip: !productId || !isOpen || latestVersionNumber != null },\n )\n\n // Fetch the latest version to discover its taskId (e.g. when versions are collapsed)\n const { data: latestVersionData } = useGetVersionQuery(\n { projectName, versionId: latestVersionId! },\n { skip: !latestVersionId || !isOpen || userTaskId !== null },\n )\n\n // Derive effective taskId: user's explicit choice takes priority, then auto-resolved from version\n const taskId = userTaskId ?? latestVersionData?.taskId ?? ''\n const isLoadingTask = !!(latestVersionId && userTaskId === null && !latestVersionData)\n\n const onOpenVersionUpload = useCallback<VersionUploadContextType['onOpenVersionUpload']>(\n ({ productId, folderId, taskId, linkedTask, latestVersionNumber, latestVersionId }) => {\n setProductId(productId || '')\n setFolderId(folderId || '')\n setUserTaskId(taskId || null)\n setLinkedTask(linkedTask || null)\n setLatestVersionNumber(latestVersionNumber)\n setLatestVersionId(latestVersionId)\n\n // If we already know the latest version number, set the form immediately\n if (latestVersionNumber != null) {\n setForm((prev) => ({ ...prev, version: latestVersionNumber + 1 }))\n }\n setIsOpen(true)\n },\n [],\n )\n\n const onCloseVersionUpload = useCallback<VersionUploadContextType['onCloseVersionUpload']>(() => {\n // Clean up pending files\n pendingFiles.forEach((item) => {\n if (item.preview) {\n URL.revokeObjectURL(item.preview)\n }\n })\n setPendingFiles([])\n setForm(defaultFormData)\n setCreatedProductId(null)\n setCreatedVersionId(null)\n setError('')\n setIsSubmitting(false)\n setIsOpen(false)\n setProductId('')\n setFolderId('')\n setUserTaskId(null)\n setLinkedTask(null)\n setLatestVersionNumber(undefined)\n setLatestVersionId(undefined)\n }, [pendingFiles])\n\n const [createProduct] = useCreateProductMutation()\n const [createVersion] = useCreateVersionMutation()\n\n const onUploadVersion = useCallback<VersionUploadContextType['onUploadVersion']>(\n async (data: FormData) => {\n try {\n if (productId) {\n // product already exists, create new version for it\n const versionRes = await createVersionHelper(createVersion, projectName, {\n productId,\n version: data.version,\n taskId: taskId || undefined,\n })\n\n // select the new version\n onVersionCreated(productId, versionRes.id)\n\n return {\n productId,\n versionId: versionRes.id,\n }\n } else {\n // product does not exist, create new product with version\n const { product: productRes, version: versionRes } = await createProductAndVersion(\n createProduct,\n createVersion,\n projectName,\n {\n folderId,\n name: data.name,\n productType: data.productType || 'review',\n productBaseType: data.productType || 'review',\n },\n {\n version: data.version,\n taskId: taskId || undefined,\n },\n )\n\n // select the new product and version\n onVersionCreated(productRes.id, versionRes.id)\n\n toast.success('Created new version')\n\n return {\n productId: productRes.id,\n versionId: versionRes.id,\n }\n }\n } catch (error: any) {\n console.error('Error uploading version:', error)\n throw error.message || error\n }\n },\n [onCloseVersionUpload, productId, folderId, taskId, projectName],\n )\n\n const extractAndSetVersionFromFiles = useCallback(\n (files: File[]) => {\n // Only extract version if we don't already have a product (new product workflow)\n if (productId) return\n\n // Try to extract version from the first file\n const firstFile = files[0]\n if (firstFile) {\n const extractedVersion = extractVersionFromFilename(firstFile.name)\n if (extractedVersion && extractedVersion !== form.version) {\n setForm((prev) => ({\n ...prev,\n version: extractedVersion,\n }))\n }\n }\n },\n [productId, form.version],\n )\n\n const latestVersion = version?.version ?? latestVersionNumber\n\n // Handle form changes\n const handleFormChange = useCallback((key: keyof FormData, value: string | number) => {\n setForm((prev) => ({\n ...prev,\n [key]: value,\n }))\n }, [])\n\n const validateFormData = () => {\n const validation = validateFormDataHelper(form, latestVersion, !productId)\n if (!validation.isValid) {\n throw validation.error\n }\n }\n\n // Handle form submission\n const handleFormSubmit = useCallback(\n async (formData: FormData) => {\n try {\n setIsSubmitting(true)\n setError('')\n\n // validate the form data\n validateFormData()\n\n const response = await onUploadVersion(formData)\n\n // Extract productId and versionId from response\n if (response?.productId) {\n setCreatedProductId(response.productId)\n }\n if (response?.versionId) {\n setCreatedVersionId(response.versionId)\n }\n\n if (pendingFiles.length < 1) {\n setIsSubmitting(false)\n onCloseVersionUpload()\n }\n } catch (error: any) {\n setError(error)\n setIsSubmitting(false)\n }\n },\n [onUploadVersion, pendingFiles.length, onCloseVersionUpload],\n )\n\n // Update form when version data changes (only when query is used as fallback)\n useEffect(() => {\n if (!isOpen || latestVersionNumber != null) return\n\n if (version) {\n setForm((prev) => ({ ...prev, version: version.version + 1 }))\n } else {\n setForm(defaultFormData)\n }\n\n return () => {\n setForm(defaultFormData)\n }\n }, [isOpen, version, latestVersionNumber])\n\n // Wrap setUserTaskId so consumers use a simple string setter\n const setTaskId = useCallback((id: string) => setUserTaskId(id), [])\n\n const value = useMemo(\n () => ({\n productId,\n setProductId,\n folderId,\n taskId,\n linkedTask,\n isLoadingTask,\n setTaskId,\n setLinkedTask,\n setFolderId,\n isOpen,\n projectName,\n latestVersion,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n setForm,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n }),\n [\n folderId,\n setFolderId,\n productId,\n taskId,\n linkedTask,\n isLoadingTask,\n setTaskId,\n setLinkedTask,\n setProductId,\n isOpen,\n projectName,\n latestVersion,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n ],\n )\n\n return <VersionUploadContext.Provider value={value}>{children}</VersionUploadContext.Provider>\n}\n\nexport const useVersionUploadContext = (): VersionUploadContextType => {\n const context = useContext(VersionUploadContext)\n if (context === undefined) {\n throw new Error('useVersionUploadContext must be used within a VersionUploadProvider')\n }\n return context\n}\n"],"names":["VersionUploadContext","createContext","defaultFormData","VersionUploadProvider","children","projectName","onVersionCreated","dispatch","folderId","setFolderId","useState","productId","setProductId","userTaskId","setUserTaskId","linkedTask","setLinkedTask","isOpen","setIsOpen","pendingFiles","setPendingFiles","form","setForm","isSubmitting","setIsSubmitting","error","setError","createdProductId","setCreatedProductId","createdVersionId","setCreatedVersionId","latestVersionNumber","setLatestVersionNumber","latestVersionId","setLatestVersionId","version","useGetLatestProductVersionQuery","latestVersionData","useGetVersionQuery","taskId","isLoadingTask","onOpenVersionUpload","useCallback","prev","onCloseVersionUpload","item","createProduct","useCreateProductMutation","createVersion","useCreateVersionMutation","onUploadVersion","data","versionRes","createVersionHelper","productRes","createProductAndVersion","toast","extractAndSetVersionFromFiles","files","firstFile","extractedVersion","extractVersionFromFilename","latestVersion","handleFormChange","key","value","validateFormData","validation","validateFormDataHelper","handleFormSubmit","formData","response","useEffect","setTaskId","id","useMemo","jsx","useVersionUploadContext","context","useContext"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { j as
|
|
1
|
+
import { j as io } from "../../../../../_virtual/jsx-runtime.es.js";
|
|
2
2
|
import "../../../api/base/client.es.js";
|
|
3
3
|
import "../../../api/generated/graphql.es.js";
|
|
4
4
|
import "../../../api/generated/graphqlLinks.es.js";
|
|
@@ -69,7 +69,7 @@ import "../../../api/queries/overview/getOverview.es.js";
|
|
|
69
69
|
import "../../../api/queries/overview/updateOverview.es.js";
|
|
70
70
|
import "../../../api/queries/versions/getVersionsProducts.es.js";
|
|
71
71
|
import "../../../api/queries/permissions/getPermissions.es.js";
|
|
72
|
-
import { useCreateProductMutation as
|
|
72
|
+
import { useCreateProductMutation as eo } from "../../../api/queries/products/createProduct.es.js";
|
|
73
73
|
import "../../../api/queries/project/getProject.es.js";
|
|
74
74
|
import "../../../api/queries/project/updateProject.es.js";
|
|
75
75
|
import "../../../api/queries/projectFolders/projectFolders.es.js";
|
|
@@ -77,189 +77,199 @@ import "../../../api/queries/review/getReview.es.js";
|
|
|
77
77
|
import "../../../api/queries/review/updateReview.es.js";
|
|
78
78
|
import "../../../api/queries/share/share.es.js";
|
|
79
79
|
import "../../../api/queries/system/getSystem.es.js";
|
|
80
|
+
import "../../../api/queries/tasks/getTasks.es.js";
|
|
80
81
|
import "../../../api/queries/tasks/updateTasks.es.js";
|
|
81
82
|
import "../../../api/queries/userDashboard/getUserDashboard.es.js";
|
|
82
83
|
import "../../../api/queries/users/getUsers.es.js";
|
|
83
84
|
import "../../../api/queries/users/updateUsers.es.js";
|
|
84
85
|
import "../../../api/queries/users/guests.es.js";
|
|
85
|
-
import { useGetLatestProductVersionQuery as
|
|
86
|
+
import { useGetLatestProductVersionQuery as so, useGetVersionQuery as no, useCreateVersionMutation as po } from "../../../api/queries/versions/updateVersions.es.js";
|
|
86
87
|
import "../../../api/queries/views/getViews.es.js";
|
|
87
88
|
import "../../../api/queries/views/updateViews.es.js";
|
|
88
89
|
import "../../../api/queries/watchers/getWatchers.es.js";
|
|
89
90
|
import "../../../api/queries/uris/getUris.es.js";
|
|
90
|
-
import { createContext as
|
|
91
|
+
import { createContext as mo, useState as r, useCallback as p, useEffect as ao, useMemo as co, useContext as lo } from "react";
|
|
91
92
|
import "lodash";
|
|
92
|
-
import { toast as
|
|
93
|
+
import { toast as uo } from "react-toastify";
|
|
93
94
|
import "uuid";
|
|
94
|
-
import { extractVersionFromFilename as
|
|
95
|
-
import { createVersionHelper as
|
|
95
|
+
import { extractVersionFromFilename as vo } from "../../../util/extractVersionFromFilename.es.js";
|
|
96
|
+
import { createVersionHelper as fo, createProductAndVersion as Io, validateFormData as Vo } from "../../../util/versionUploadHelpers.es.js";
|
|
96
97
|
import "../../../util/pubsub.es.js";
|
|
97
|
-
const
|
|
98
|
+
const _ = mo(void 0), C = {
|
|
98
99
|
version: 1,
|
|
99
100
|
name: "review",
|
|
100
101
|
productType: "review"
|
|
101
|
-
},
|
|
102
|
-
children:
|
|
103
|
-
projectName:
|
|
104
|
-
onVersionCreated:
|
|
105
|
-
dispatch:
|
|
102
|
+
}, pr = ({
|
|
103
|
+
children: u,
|
|
104
|
+
projectName: n,
|
|
105
|
+
onVersionCreated: E,
|
|
106
|
+
dispatch: R
|
|
106
107
|
}) => {
|
|
107
|
-
const [
|
|
108
|
+
const [v, f] = r(""), [i, I] = r(""), [T, h] = r(null), [D, V] = r(null), [m, S] = r(!1), [d, y] = r([]), [a, s] = r(C), [O, k] = r(!1), [M, P] = r(""), [A, G] = r(null), [Q, B] = r(null), [w, H] = r(void 0), [U, $] = r(void 0), { currentData: F } = so(
|
|
108
109
|
{
|
|
109
|
-
projectName:
|
|
110
|
-
productId:
|
|
110
|
+
projectName: n,
|
|
111
|
+
productId: i
|
|
111
112
|
},
|
|
112
|
-
{ skip: !
|
|
113
|
-
),
|
|
114
|
-
|
|
115
|
-
|
|
113
|
+
{ skip: !i || !m || w != null }
|
|
114
|
+
), { data: q } = no(
|
|
115
|
+
{ projectName: n, versionId: U },
|
|
116
|
+
{ skip: !U || !m || T !== null }
|
|
117
|
+
), c = T ?? q?.taskId ?? "", z = !!(U && T === null && !q), J = p(
|
|
118
|
+
({ productId: o, folderId: t, taskId: e, linkedTask: b, latestVersionNumber: L, latestVersionId: to }) => {
|
|
119
|
+
I(o || ""), f(t || ""), h(e || null), V(b || null), H(L), $(to), L != null && s((ro) => ({ ...ro, version: L + 1 })), S(!0);
|
|
116
120
|
},
|
|
117
121
|
[]
|
|
118
|
-
),
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
}),
|
|
122
|
-
}, [
|
|
123
|
-
async (
|
|
124
|
-
console.log("Uploading version with data:", r);
|
|
122
|
+
), l = p(() => {
|
|
123
|
+
d.forEach((o) => {
|
|
124
|
+
o.preview && URL.revokeObjectURL(o.preview);
|
|
125
|
+
}), y([]), s(C), G(null), B(null), P(""), k(!1), S(!1), I(""), f(""), h(null), V(null), H(void 0), $(void 0);
|
|
126
|
+
}, [d]), [j] = eo(), [K] = po(), x = p(
|
|
127
|
+
async (o) => {
|
|
125
128
|
try {
|
|
126
|
-
if (
|
|
127
|
-
const
|
|
128
|
-
productId:
|
|
129
|
-
version:
|
|
129
|
+
if (i) {
|
|
130
|
+
const t = await fo(K, n, {
|
|
131
|
+
productId: i,
|
|
132
|
+
version: o.version,
|
|
133
|
+
taskId: c || void 0
|
|
130
134
|
});
|
|
131
|
-
return
|
|
132
|
-
productId:
|
|
133
|
-
versionId:
|
|
135
|
+
return E(i, t.id), {
|
|
136
|
+
productId: i,
|
|
137
|
+
versionId: t.id
|
|
134
138
|
};
|
|
135
139
|
} else {
|
|
136
|
-
const { product:
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
+
const { product: t, version: e } = await Io(
|
|
141
|
+
j,
|
|
142
|
+
K,
|
|
143
|
+
n,
|
|
140
144
|
{
|
|
141
|
-
folderId:
|
|
142
|
-
name:
|
|
143
|
-
productType:
|
|
145
|
+
folderId: v,
|
|
146
|
+
name: o.name,
|
|
147
|
+
productType: o.productType || "review",
|
|
148
|
+
productBaseType: o.productType || "review"
|
|
144
149
|
},
|
|
145
150
|
{
|
|
146
|
-
version:
|
|
147
|
-
taskId:
|
|
151
|
+
version: o.version,
|
|
152
|
+
taskId: c || void 0
|
|
148
153
|
}
|
|
149
154
|
);
|
|
150
|
-
return
|
|
151
|
-
productId:
|
|
152
|
-
versionId:
|
|
155
|
+
return E(t.id, e.id), uo.success("Created new version"), {
|
|
156
|
+
productId: t.id,
|
|
157
|
+
versionId: e.id
|
|
153
158
|
};
|
|
154
159
|
}
|
|
155
|
-
} catch (
|
|
156
|
-
throw console.error("Error uploading version:",
|
|
160
|
+
} catch (t) {
|
|
161
|
+
throw console.error("Error uploading version:", t), t.message || t;
|
|
157
162
|
}
|
|
158
163
|
},
|
|
159
|
-
[
|
|
160
|
-
),
|
|
161
|
-
(
|
|
162
|
-
if (
|
|
163
|
-
const
|
|
164
|
-
if (
|
|
165
|
-
const
|
|
166
|
-
|
|
167
|
-
...
|
|
168
|
-
version:
|
|
164
|
+
[l, i, v, c, n]
|
|
165
|
+
), W = p(
|
|
166
|
+
(o) => {
|
|
167
|
+
if (i) return;
|
|
168
|
+
const t = o[0];
|
|
169
|
+
if (t) {
|
|
170
|
+
const e = vo(t.name);
|
|
171
|
+
e && e !== a.version && s((b) => ({
|
|
172
|
+
...b,
|
|
173
|
+
version: e
|
|
169
174
|
}));
|
|
170
175
|
}
|
|
171
176
|
},
|
|
172
|
-
[
|
|
173
|
-
),
|
|
174
|
-
|
|
175
|
-
...
|
|
176
|
-
[
|
|
177
|
+
[i, a.version]
|
|
178
|
+
), g = F?.version ?? w, X = p((o, t) => {
|
|
179
|
+
s((e) => ({
|
|
180
|
+
...e,
|
|
181
|
+
[o]: t
|
|
177
182
|
}));
|
|
178
|
-
}, []),
|
|
179
|
-
const
|
|
180
|
-
if (!
|
|
181
|
-
throw
|
|
182
|
-
},
|
|
183
|
-
async (
|
|
183
|
+
}, []), N = () => {
|
|
184
|
+
const o = Vo(a, g, !i);
|
|
185
|
+
if (!o.isValid)
|
|
186
|
+
throw o.error;
|
|
187
|
+
}, Y = p(
|
|
188
|
+
async (o) => {
|
|
184
189
|
try {
|
|
185
|
-
|
|
186
|
-
const
|
|
187
|
-
|
|
188
|
-
} catch (
|
|
189
|
-
|
|
190
|
+
k(!0), P(""), N();
|
|
191
|
+
const t = await x(o);
|
|
192
|
+
t?.productId && G(t.productId), t?.versionId && B(t.versionId), d.length < 1 && (k(!1), l());
|
|
193
|
+
} catch (t) {
|
|
194
|
+
P(t), k(!1);
|
|
190
195
|
}
|
|
191
196
|
},
|
|
192
|
-
[
|
|
197
|
+
[x, d.length, l]
|
|
193
198
|
);
|
|
194
|
-
|
|
195
|
-
if (
|
|
196
|
-
return
|
|
197
|
-
|
|
198
|
-
version: ro(s)
|
|
199
|
-
} : l), () => {
|
|
200
|
-
n(l);
|
|
199
|
+
ao(() => {
|
|
200
|
+
if (!(!m || w != null))
|
|
201
|
+
return s(F ? (o) => ({ ...o, version: F.version + 1 }) : C), () => {
|
|
202
|
+
s(C);
|
|
201
203
|
};
|
|
202
|
-
}, [
|
|
203
|
-
const
|
|
204
|
+
}, [m, F, w]);
|
|
205
|
+
const Z = p((o) => h(o), []), oo = co(
|
|
204
206
|
() => ({
|
|
205
|
-
productId:
|
|
206
|
-
setProductId:
|
|
207
|
-
folderId:
|
|
208
|
-
taskId:
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
207
|
+
productId: i,
|
|
208
|
+
setProductId: I,
|
|
209
|
+
folderId: v,
|
|
210
|
+
taskId: c,
|
|
211
|
+
linkedTask: D,
|
|
212
|
+
isLoadingTask: z,
|
|
213
|
+
setTaskId: Z,
|
|
214
|
+
setLinkedTask: V,
|
|
215
|
+
setFolderId: f,
|
|
216
|
+
isOpen: m,
|
|
217
|
+
projectName: n,
|
|
218
|
+
latestVersion: g,
|
|
219
|
+
pendingFiles: d,
|
|
220
|
+
setPendingFiles: y,
|
|
221
|
+
onOpenVersionUpload: J,
|
|
222
|
+
onCloseVersionUpload: l,
|
|
223
|
+
onUploadVersion: x,
|
|
224
|
+
extractAndSetVersionFromFiles: W,
|
|
219
225
|
form: a,
|
|
220
|
-
setForm:
|
|
221
|
-
isSubmitting:
|
|
222
|
-
error:
|
|
223
|
-
createdProductId:
|
|
224
|
-
createdVersionId:
|
|
225
|
-
handleFormChange:
|
|
226
|
-
handleFormSubmit:
|
|
227
|
-
dispatch:
|
|
226
|
+
setForm: s,
|
|
227
|
+
isSubmitting: O,
|
|
228
|
+
error: M,
|
|
229
|
+
createdProductId: A,
|
|
230
|
+
createdVersionId: Q,
|
|
231
|
+
handleFormChange: X,
|
|
232
|
+
handleFormSubmit: Y,
|
|
233
|
+
dispatch: R
|
|
228
234
|
}),
|
|
229
235
|
[
|
|
236
|
+
v,
|
|
230
237
|
f,
|
|
231
|
-
|
|
232
|
-
t,
|
|
233
|
-
w,
|
|
234
|
-
V,
|
|
238
|
+
i,
|
|
235
239
|
c,
|
|
236
|
-
|
|
237
|
-
|
|
240
|
+
D,
|
|
241
|
+
z,
|
|
242
|
+
Z,
|
|
243
|
+
V,
|
|
244
|
+
I,
|
|
238
245
|
m,
|
|
246
|
+
n,
|
|
239
247
|
g,
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
248
|
+
d,
|
|
249
|
+
y,
|
|
250
|
+
J,
|
|
251
|
+
l,
|
|
252
|
+
x,
|
|
253
|
+
W,
|
|
244
254
|
a,
|
|
245
|
-
|
|
246
|
-
k,
|
|
247
|
-
E,
|
|
248
|
-
S,
|
|
255
|
+
O,
|
|
249
256
|
M,
|
|
250
257
|
A,
|
|
251
|
-
|
|
258
|
+
Q,
|
|
259
|
+
X,
|
|
260
|
+
Y,
|
|
261
|
+
R
|
|
252
262
|
]
|
|
253
263
|
);
|
|
254
|
-
return /* @__PURE__ */
|
|
255
|
-
},
|
|
256
|
-
const
|
|
257
|
-
if (
|
|
264
|
+
return /* @__PURE__ */ io.jsx(_.Provider, { value: oo, children: u });
|
|
265
|
+
}, mr = () => {
|
|
266
|
+
const u = lo(_);
|
|
267
|
+
if (u === void 0)
|
|
258
268
|
throw new Error("useVersionUploadContext must be used within a VersionUploadProvider");
|
|
259
|
-
return
|
|
269
|
+
return u;
|
|
260
270
|
};
|
|
261
271
|
export {
|
|
262
|
-
|
|
263
|
-
|
|
272
|
+
pr as VersionUploadProvider,
|
|
273
|
+
mr as useVersionUploadContext
|
|
264
274
|
};
|
|
265
275
|
//# sourceMappingURL=VersionUploadContext.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VersionUploadContext.es.js","sources":["../../../../../../src/components/VersionUploader/context/VersionUploadContext.tsx"],"sourcesContent":["import {\n GetLatestVersionResult,\n useCreateVersionMutation,\n useGetLatestProductVersionQuery,\n} from '@shared/api'\nimport React, {\n createContext,\n useContext,\n useState,\n ReactNode,\n useMemo,\n useCallback,\n useEffect,\n} from 'react'\nimport { useCreateProductMutation } from '@shared/api'\nimport { extractVersionFromFilename } from '@shared/util'\nimport { toast } from 'react-toastify'\nimport {\n validateFormData as validateFormDataHelper,\n createProductAndVersion,\n createVersionHelper,\n handleUploadError,\n getNextVersionNumber,\n type ProductCreationData,\n type VersionCreationData,\n} from '@shared/util/versionUploadHelpers'\n\nexport interface FormData {\n version: number\n name: string\n productType: string\n}\ninterface VersionUploadContextType {\n productId: string\n folderId: string\n taskId: string\n setProductId: (productId: string) => void\n setFolderId: (folderId: string) => void\n isOpen: boolean\n projectName: string\n version: GetLatestVersionResult | undefined\n pendingFiles: Array<{ file: File; preview?: string }>\n setPendingFiles: React.Dispatch<React.SetStateAction<Array<{ file: File; preview?: string }>>>\n extractAndSetVersionFromFiles: (files: File[]) => void\n form: FormData\n setForm: React.Dispatch<React.SetStateAction<FormData>>\n isSubmitting: boolean\n error: string\n createdProductId: string | null\n createdVersionId: string | null\n onOpenVersionUpload: (params: { productId?: string; folderId?: string; taskId?: string }) => void\n onCloseVersionUpload: () => void\n onUploadVersion: (data: FormData) => Promise<{ productId: string; versionId: string }>\n handleFormChange: (key: keyof FormData, value: string | number) => void\n handleFormSubmit: (formData: FormData) => Promise<void>\n // pass through\n dispatch: any\n}\n\nconst VersionUploadContext = createContext<VersionUploadContextType | undefined>(undefined)\n\ninterface VersionUploadProviderProps {\n children: ReactNode\n projectName: string\n onVersionCreated: (productId: string, versionId: string) => void\n dispatch: any\n}\n\nconst defaultFormData: FormData = {\n version: 1,\n name: 'review',\n productType: 'review',\n}\n\nexport const VersionUploadProvider: React.FC<VersionUploadProviderProps> = ({\n children,\n projectName,\n onVersionCreated,\n dispatch,\n}) => {\n const [folderId, setFolderId] = useState<string>('')\n const [productId, setProductId] = useState<string>('')\n // optional taskId to link the version to\n const [taskId, setTaskId] = useState<string>('')\n const [isOpen, setIsOpen] = useState<boolean>(false)\n const [pendingFiles, setPendingFiles] = useState<Array<{ file: File; preview?: string }>>([])\n const [form, setForm] = useState<FormData>(defaultFormData)\n const [isSubmitting, setIsSubmitting] = useState(false)\n const [error, setError] = useState<string>('')\n const [createdProductId, setCreatedProductId] = useState<string | null>(null)\n const [createdVersionId, setCreatedVersionId] = useState<string | null>(null)\n\n const { currentData: version } = useGetLatestProductVersionQuery(\n {\n projectName,\n productId,\n },\n { skip: !productId || !isOpen },\n )\n\n const onOpenVersionUpload = useCallback<VersionUploadContextType['onOpenVersionUpload']>(\n ({ productId, folderId, taskId }) => {\n setProductId(productId || '')\n setFolderId(folderId || '')\n setTaskId(taskId || '')\n setIsOpen(true)\n },\n [],\n )\n\n const onCloseVersionUpload = useCallback<VersionUploadContextType['onCloseVersionUpload']>(() => {\n // Clean up pending files\n pendingFiles.forEach((item) => {\n if (item.preview) {\n URL.revokeObjectURL(item.preview)\n }\n })\n setPendingFiles([])\n setForm(defaultFormData)\n setCreatedProductId(null)\n setCreatedVersionId(null)\n setError('')\n setIsSubmitting(false)\n setIsOpen(false)\n setProductId('')\n setFolderId('')\n setTaskId('')\n }, [pendingFiles])\n\n const [createProduct] = useCreateProductMutation()\n const [createVersion] = useCreateVersionMutation()\n\n const onUploadVersion = useCallback<VersionUploadContextType['onUploadVersion']>(\n async (data: FormData) => {\n console.log('Uploading version with data:', data)\n try {\n if (version && productId) {\n // product already exists, create new version for it\n const versionRes = await createVersionHelper(createVersion, projectName, {\n productId,\n version: data.version,\n })\n\n // select the new version\n onVersionCreated(productId, versionRes.id)\n\n return {\n productId,\n versionId: versionRes.id,\n }\n } else {\n // product does not exist, create new product with version\n const { product: productRes, version: versionRes } = await createProductAndVersion(\n createProduct,\n createVersion,\n projectName,\n {\n folderId,\n name: data.name,\n productType: data.productType || 'review',\n },\n {\n version: data.version,\n taskId: taskId || undefined,\n },\n )\n\n // select the new product and version\n onVersionCreated(productRes.id, versionRes.id)\n\n toast.success('Created new version')\n\n return {\n productId: productRes.id,\n versionId: versionRes.id,\n }\n }\n } catch (error: any) {\n console.error('Error uploading version:', error)\n throw error.message || error\n }\n },\n [onCloseVersionUpload, productId, folderId, taskId, version, projectName],\n )\n\n const extractAndSetVersionFromFiles = useCallback(\n (files: File[]) => {\n // Only extract version if we don't already have a product (new product workflow)\n if (productId) return\n\n // Try to extract version from the first file\n const firstFile = files[0]\n if (firstFile) {\n const extractedVersion = extractVersionFromFilename(firstFile.name)\n if (extractedVersion && extractedVersion !== form.version) {\n setForm((prev) => ({\n ...prev,\n version: extractedVersion,\n }))\n }\n }\n },\n [productId, form.version],\n )\n\n // Handle form changes\n const handleFormChange = useCallback((key: keyof FormData, value: string | number) => {\n setForm((prev) => ({\n ...prev,\n [key]: value,\n }))\n }, [])\n\n const validateFormData = () => {\n const validation = validateFormDataHelper(form, version?.version, !version)\n if (!validation.isValid) {\n throw validation.error\n }\n }\n\n // Handle form submission\n const handleFormSubmit = useCallback(\n async (formData: FormData) => {\n try {\n setIsSubmitting(true)\n setError('')\n\n // validate the form data\n validateFormData()\n\n const response = await onUploadVersion(formData)\n\n // Extract productId and versionId from response\n if (response?.productId) {\n setCreatedProductId(response.productId)\n }\n if (response?.versionId) {\n setCreatedVersionId(response.versionId)\n }\n\n if (pendingFiles.length < 1) {\n setIsSubmitting(false)\n onCloseVersionUpload()\n }\n } catch (error: any) {\n setError(error)\n setIsSubmitting(false)\n }\n },\n [onUploadVersion, pendingFiles.length, onCloseVersionUpload],\n )\n\n // Update form when version data changes\n useEffect(() => {\n if (!isOpen) return\n\n if (version) {\n setForm({\n ...defaultFormData,\n version: getNextVersionNumber(version),\n })\n } else {\n setForm(defaultFormData)\n }\n\n return () => {\n setForm(defaultFormData)\n }\n }, [isOpen, version])\n\n const value = useMemo(\n () => ({\n productId,\n setProductId,\n folderId,\n taskId,\n setFolderId,\n isOpen,\n projectName,\n version: productId ? version : undefined,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n setForm,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n }),\n [\n folderId,\n setFolderId,\n productId,\n taskId,\n setProductId,\n isOpen,\n projectName,\n version,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n ],\n )\n\n return <VersionUploadContext.Provider value={value}>{children}</VersionUploadContext.Provider>\n}\n\nexport const useVersionUploadContext = (): VersionUploadContextType => {\n const context = useContext(VersionUploadContext)\n if (context === undefined) {\n throw new Error('useVersionUploadContext must be used within a VersionUploadProvider')\n }\n return context\n}\n"],"names":["VersionUploadContext","createContext","defaultFormData","VersionUploadProvider","children","projectName","onVersionCreated","dispatch","folderId","setFolderId","useState","productId","setProductId","taskId","setTaskId","isOpen","setIsOpen","pendingFiles","setPendingFiles","form","setForm","isSubmitting","setIsSubmitting","error","setError","createdProductId","setCreatedProductId","createdVersionId","setCreatedVersionId","version","useGetLatestProductVersionQuery","onOpenVersionUpload","useCallback","onCloseVersionUpload","item","createProduct","useCreateProductMutation","createVersion","useCreateVersionMutation","onUploadVersion","data","versionRes","createVersionHelper","productRes","createProductAndVersion","toast","extractAndSetVersionFromFiles","files","firstFile","extractedVersion","extractVersionFromFilename","prev","handleFormChange","key","value","validateFormData","validation","validateFormDataHelper","handleFormSubmit","formData","response","useEffect","getNextVersionNumber","useMemo","jsx","useVersionUploadContext","context","useContext"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VersionUploadContext.es.js","sources":["../../../../../../src/components/VersionUploader/context/VersionUploadContext.tsx"],"sourcesContent":["import {\n useCreateVersionMutation,\n useCreateProductMutation,\n useGetLatestProductVersionQuery,\n useGetVersionQuery,\n} from '@shared/api'\nimport React, {\n createContext,\n useContext,\n useState,\n ReactNode,\n useMemo,\n useCallback,\n useEffect,\n} from 'react'\nimport { extractVersionFromFilename } from '@shared/util'\nimport { toast } from 'react-toastify'\nimport {\n validateFormData as validateFormDataHelper,\n createProductAndVersion,\n createVersionHelper,\n} from '@shared/util/versionUploadHelpers'\n\nexport interface FormData {\n version: number\n name: string\n productType: string\n}\nexport interface LinkedTask {\n id: string\n name: string\n label?: string | null\n taskType: string\n}\n\ninterface VersionUploadContextType {\n productId: string\n folderId: string\n taskId: string\n linkedTask: LinkedTask | null\n isLoadingTask: boolean\n setTaskId: (taskId: string) => void\n setLinkedTask: (task: LinkedTask | null) => void\n setProductId: (productId: string) => void\n setFolderId: (folderId: string) => void\n isOpen: boolean\n projectName: string\n latestVersion: number | undefined\n pendingFiles: Array<{ file: File; preview?: string }>\n setPendingFiles: React.Dispatch<React.SetStateAction<Array<{ file: File; preview?: string }>>>\n extractAndSetVersionFromFiles: (files: File[]) => void\n form: FormData\n setForm: React.Dispatch<React.SetStateAction<FormData>>\n isSubmitting: boolean\n error: string\n createdProductId: string | null\n createdVersionId: string | null\n onOpenVersionUpload: (params: {\n productId?: string\n folderId?: string\n taskId?: string\n linkedTask?: LinkedTask\n latestVersionNumber?: number\n latestVersionId?: string\n }) => void\n onCloseVersionUpload: () => void\n onUploadVersion: (data: FormData) => Promise<{ productId: string; versionId: string }>\n handleFormChange: (key: keyof FormData, value: string | number) => void\n handleFormSubmit: (formData: FormData) => Promise<void>\n // pass through\n dispatch: any\n}\n\nconst VersionUploadContext = createContext<VersionUploadContextType | undefined>(undefined)\n\ninterface VersionUploadProviderProps {\n children: ReactNode\n projectName: string\n onVersionCreated: (productId: string, versionId: string) => void\n dispatch: any\n}\n\nconst defaultFormData: FormData = {\n version: 1,\n name: 'review',\n productType: 'review',\n}\n\nexport const VersionUploadProvider: React.FC<VersionUploadProviderProps> = ({\n children,\n projectName,\n onVersionCreated,\n dispatch,\n}) => {\n const [folderId, setFolderId] = useState<string>('')\n const [productId, setProductId] = useState<string>('')\n // optional task to link the version to\n // null = not set by user (auto-resolve from version), '' = explicitly cleared, 'id' = explicitly set\n const [userTaskId, setUserTaskId] = useState<string | null>(null)\n const [linkedTask, setLinkedTask] = useState<LinkedTask | null>(null)\n const [isOpen, setIsOpen] = useState<boolean>(false)\n const [pendingFiles, setPendingFiles] = useState<Array<{ file: File; preview?: string }>>([])\n const [form, setForm] = useState<FormData>(defaultFormData)\n const [isSubmitting, setIsSubmitting] = useState(false)\n const [error, setError] = useState<string>('')\n const [createdProductId, setCreatedProductId] = useState<string | null>(null)\n const [createdVersionId, setCreatedVersionId] = useState<string | null>(null)\n // Stores the latest version number passed from the caller (e.g. VP page)\n // so we can skip the GetLatestProductVersion query when we already know it\n const [latestVersionNumber, setLatestVersionNumber] = useState<number | undefined>(undefined)\n // Stores the latest version ID so we can fetch its task when not already known\n const [latestVersionId, setLatestVersionId] = useState<string | undefined>(undefined)\n\n const { currentData: version } = useGetLatestProductVersionQuery(\n {\n projectName,\n productId,\n },\n { skip: !productId || !isOpen || latestVersionNumber != null },\n )\n\n // Fetch the latest version to discover its taskId (e.g. when versions are collapsed)\n const { data: latestVersionData } = useGetVersionQuery(\n { projectName, versionId: latestVersionId! },\n { skip: !latestVersionId || !isOpen || userTaskId !== null },\n )\n\n // Derive effective taskId: user's explicit choice takes priority, then auto-resolved from version\n const taskId = userTaskId ?? latestVersionData?.taskId ?? ''\n const isLoadingTask = !!(latestVersionId && userTaskId === null && !latestVersionData)\n\n const onOpenVersionUpload = useCallback<VersionUploadContextType['onOpenVersionUpload']>(\n ({ productId, folderId, taskId, linkedTask, latestVersionNumber, latestVersionId }) => {\n setProductId(productId || '')\n setFolderId(folderId || '')\n setUserTaskId(taskId || null)\n setLinkedTask(linkedTask || null)\n setLatestVersionNumber(latestVersionNumber)\n setLatestVersionId(latestVersionId)\n\n // If we already know the latest version number, set the form immediately\n if (latestVersionNumber != null) {\n setForm((prev) => ({ ...prev, version: latestVersionNumber + 1 }))\n }\n setIsOpen(true)\n },\n [],\n )\n\n const onCloseVersionUpload = useCallback<VersionUploadContextType['onCloseVersionUpload']>(() => {\n // Clean up pending files\n pendingFiles.forEach((item) => {\n if (item.preview) {\n URL.revokeObjectURL(item.preview)\n }\n })\n setPendingFiles([])\n setForm(defaultFormData)\n setCreatedProductId(null)\n setCreatedVersionId(null)\n setError('')\n setIsSubmitting(false)\n setIsOpen(false)\n setProductId('')\n setFolderId('')\n setUserTaskId(null)\n setLinkedTask(null)\n setLatestVersionNumber(undefined)\n setLatestVersionId(undefined)\n }, [pendingFiles])\n\n const [createProduct] = useCreateProductMutation()\n const [createVersion] = useCreateVersionMutation()\n\n const onUploadVersion = useCallback<VersionUploadContextType['onUploadVersion']>(\n async (data: FormData) => {\n try {\n if (productId) {\n // product already exists, create new version for it\n const versionRes = await createVersionHelper(createVersion, projectName, {\n productId,\n version: data.version,\n taskId: taskId || undefined,\n })\n\n // select the new version\n onVersionCreated(productId, versionRes.id)\n\n return {\n productId,\n versionId: versionRes.id,\n }\n } else {\n // product does not exist, create new product with version\n const { product: productRes, version: versionRes } = await createProductAndVersion(\n createProduct,\n createVersion,\n projectName,\n {\n folderId,\n name: data.name,\n productType: data.productType || 'review',\n productBaseType: data.productType || 'review',\n },\n {\n version: data.version,\n taskId: taskId || undefined,\n },\n )\n\n // select the new product and version\n onVersionCreated(productRes.id, versionRes.id)\n\n toast.success('Created new version')\n\n return {\n productId: productRes.id,\n versionId: versionRes.id,\n }\n }\n } catch (error: any) {\n console.error('Error uploading version:', error)\n throw error.message || error\n }\n },\n [onCloseVersionUpload, productId, folderId, taskId, projectName],\n )\n\n const extractAndSetVersionFromFiles = useCallback(\n (files: File[]) => {\n // Only extract version if we don't already have a product (new product workflow)\n if (productId) return\n\n // Try to extract version from the first file\n const firstFile = files[0]\n if (firstFile) {\n const extractedVersion = extractVersionFromFilename(firstFile.name)\n if (extractedVersion && extractedVersion !== form.version) {\n setForm((prev) => ({\n ...prev,\n version: extractedVersion,\n }))\n }\n }\n },\n [productId, form.version],\n )\n\n const latestVersion = version?.version ?? latestVersionNumber\n\n // Handle form changes\n const handleFormChange = useCallback((key: keyof FormData, value: string | number) => {\n setForm((prev) => ({\n ...prev,\n [key]: value,\n }))\n }, [])\n\n const validateFormData = () => {\n const validation = validateFormDataHelper(form, latestVersion, !productId)\n if (!validation.isValid) {\n throw validation.error\n }\n }\n\n // Handle form submission\n const handleFormSubmit = useCallback(\n async (formData: FormData) => {\n try {\n setIsSubmitting(true)\n setError('')\n\n // validate the form data\n validateFormData()\n\n const response = await onUploadVersion(formData)\n\n // Extract productId and versionId from response\n if (response?.productId) {\n setCreatedProductId(response.productId)\n }\n if (response?.versionId) {\n setCreatedVersionId(response.versionId)\n }\n\n if (pendingFiles.length < 1) {\n setIsSubmitting(false)\n onCloseVersionUpload()\n }\n } catch (error: any) {\n setError(error)\n setIsSubmitting(false)\n }\n },\n [onUploadVersion, pendingFiles.length, onCloseVersionUpload],\n )\n\n // Update form when version data changes (only when query is used as fallback)\n useEffect(() => {\n if (!isOpen || latestVersionNumber != null) return\n\n if (version) {\n setForm((prev) => ({ ...prev, version: version.version + 1 }))\n } else {\n setForm(defaultFormData)\n }\n\n return () => {\n setForm(defaultFormData)\n }\n }, [isOpen, version, latestVersionNumber])\n\n // Wrap setUserTaskId so consumers use a simple string setter\n const setTaskId = useCallback((id: string) => setUserTaskId(id), [])\n\n const value = useMemo(\n () => ({\n productId,\n setProductId,\n folderId,\n taskId,\n linkedTask,\n isLoadingTask,\n setTaskId,\n setLinkedTask,\n setFolderId,\n isOpen,\n projectName,\n latestVersion,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n setForm,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n }),\n [\n folderId,\n setFolderId,\n productId,\n taskId,\n linkedTask,\n isLoadingTask,\n setTaskId,\n setLinkedTask,\n setProductId,\n isOpen,\n projectName,\n latestVersion,\n pendingFiles,\n setPendingFiles,\n onOpenVersionUpload,\n onCloseVersionUpload,\n onUploadVersion,\n extractAndSetVersionFromFiles,\n form,\n isSubmitting,\n error,\n createdProductId,\n createdVersionId,\n handleFormChange,\n handleFormSubmit,\n dispatch,\n ],\n )\n\n return <VersionUploadContext.Provider value={value}>{children}</VersionUploadContext.Provider>\n}\n\nexport const useVersionUploadContext = (): VersionUploadContextType => {\n const context = useContext(VersionUploadContext)\n if (context === undefined) {\n throw new Error('useVersionUploadContext must be used within a VersionUploadProvider')\n }\n return context\n}\n"],"names":["VersionUploadContext","createContext","defaultFormData","VersionUploadProvider","children","projectName","onVersionCreated","dispatch","folderId","setFolderId","useState","productId","setProductId","userTaskId","setUserTaskId","linkedTask","setLinkedTask","isOpen","setIsOpen","pendingFiles","setPendingFiles","form","setForm","isSubmitting","setIsSubmitting","error","setError","createdProductId","setCreatedProductId","createdVersionId","setCreatedVersionId","latestVersionNumber","setLatestVersionNumber","latestVersionId","setLatestVersionId","version","useGetLatestProductVersionQuery","latestVersionData","useGetVersionQuery","taskId","isLoadingTask","onOpenVersionUpload","useCallback","prev","onCloseVersionUpload","item","createProduct","useCreateProductMutation","createVersion","useCreateVersionMutation","onUploadVersion","data","versionRes","createVersionHelper","productRes","createProductAndVersion","toast","extractAndSetVersionFromFiles","files","firstFile","extractedVersion","extractVersionFromFilename","latestVersion","handleFormChange","key","value","validateFormData","validation","validateFormDataHelper","handleFormSubmit","formData","response","useEffect","setTaskId","id","useMemo","jsx","useVersionUploadContext","context","useContext"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("../../../../_virtual/jsx-runtime.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/projectFolders.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/config/getConfig.cjs.js");require("../../api/queries/config/updateConfig.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/versions/getVersionsProducts.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/projectFolders/projectFolders.cjs.js");require("../../api/queries/review/getReview.cjs.js");require("../../api/queries/review/updateReview.cjs.js");require("../../api/queries/share/share.cjs.js");require("../../api/queries/system/getSystem.cjs.js");require("../../api/queries/tasks/updateTasks.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/users/guests.cjs.js");require("../../api/queries/versions/updateVersions.cjs.js");require("../../api/queries/views/getViews.cjs.js");require("../../api/queries/views/updateViews.cjs.js");const c=require("../../api/queries/watchers/getWatchers.cjs.js");require("../../api/queries/uris/getUris.cjs.js");const y=require("@ynput/ayon-react-components"),j=require("react"),E=require("react-toastify"),R=j.forwardRef(({entities:u,entityType:o,onWatchersUpdate:q,userName:h,...d},l)=>{const p=u.map(e=>({entityId:e.id,entityType:o,projectName:e.projectName})),{data:t=[]}=c.useGetEntitiesWatchersQuery({entities:p},{skip:!u.length}),i=Array.from(new Set(t.flatMap(e=>e.watchers))),[m]=c.useSetEntitiesWatchersMutation(),w=async e=>{const s=e.filter(r=>!i.includes(r)),a=i.filter(r=>!e.includes(r)),f=t.map(r=>{const n=r.watchers.filter(W=>!a.includes(W));return n.push(...s),{...r,watchers:n}});try{await m({entities:f}).unwrap(),q&&q(s,a)}catch{E.toast.error("Failed to update watchers")}};return g.jsxRuntimeExports.jsx(y.WatcherSelect,{align:"right",...d,value:i,currentUser:h,onChange:w,ref:l,buttonProps:{"data-tooltip":"Watchers"}})});exports.Watchers=R;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("../../../../_virtual/jsx-runtime.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/projectFolders.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/config/getConfig.cjs.js");require("../../api/queries/config/updateConfig.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/versions/getVersionsProducts.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/projectFolders/projectFolders.cjs.js");require("../../api/queries/review/getReview.cjs.js");require("../../api/queries/review/updateReview.cjs.js");require("../../api/queries/share/share.cjs.js");require("../../api/queries/system/getSystem.cjs.js");require("../../api/queries/tasks/getTasks.cjs.js");require("../../api/queries/tasks/updateTasks.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/users/guests.cjs.js");require("../../api/queries/versions/updateVersions.cjs.js");require("../../api/queries/views/getViews.cjs.js");require("../../api/queries/views/updateViews.cjs.js");const c=require("../../api/queries/watchers/getWatchers.cjs.js");require("../../api/queries/uris/getUris.cjs.js");const y=require("@ynput/ayon-react-components"),j=require("react"),E=require("react-toastify"),R=j.forwardRef(({entities:u,entityType:o,onWatchersUpdate:q,userName:h,...d},l)=>{const p=u.map(e=>({entityId:e.id,entityType:o,projectName:e.projectName})),{data:t=[]}=c.useGetEntitiesWatchersQuery({entities:p},{skip:!u.length}),i=Array.from(new Set(t.flatMap(e=>e.watchers))),[m]=c.useSetEntitiesWatchersMutation(),w=async e=>{const s=e.filter(r=>!i.includes(r)),a=i.filter(r=>!e.includes(r)),f=t.map(r=>{const n=r.watchers.filter(W=>!a.includes(W));return n.push(...s),{...r,watchers:n}});try{await m({entities:f}).unwrap(),q&&q(s,a)}catch{E.toast.error("Failed to update watchers")}};return g.jsxRuntimeExports.jsx(y.WatcherSelect,{align:"right",...d,value:i,currentUser:h,onChange:w,ref:l,buttonProps:{"data-tooltip":"Watchers"}})});exports.Watchers=R;
|
|
2
2
|
//# sourceMappingURL=Watchers.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Watchers.cjs.js","sources":["../../../../../src/components/Watchers/Watchers.tsx"],"sourcesContent":["import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from '@shared/api'\nimport { DropdownRef, WatcherSelect, WatcherSelectProps } from '@ynput/ayon-react-components'\nimport { forwardRef } from 'react'\nimport { toast } from 'react-toastify'\n\ninterface WatchersProps extends Omit<WatcherSelectProps, 'currentUser' | 'value'> {\n entities: { id: string; projectName: string }[]\n entityType: string\n onWatchersUpdate?: (added: any[], removed: any[]) => void\n userName: string\n}\n\nexport const Watchers = forwardRef<DropdownRef, WatchersProps>(\n ({ entities, entityType, onWatchersUpdate, userName, ...props }, ref) => {\n const entitiesQuery = entities.map((entity) => ({\n entityId: entity.id,\n entityType,\n projectName: entity.projectName,\n }))\n\n const { data: watchers = [] } = useGetEntitiesWatchersQuery(\n {\n entities: entitiesQuery,\n },\n { skip: !entities.length },\n )\n\n // merge all watchers into a single unique array\n const uniqueWatchers = Array.from(new Set(watchers.flatMap((watcher) => watcher.watchers)))\n\n const [setEntitiesWatchers] = useSetEntitiesWatchersMutation()\n\n const handleChange = async (value: string[]) => {\n // find the difference between the current watchers and the new watchers\n // which users were added and which were removed\n const added = value.filter((watcher) => !uniqueWatchers.includes(watcher))\n const removed = uniqueWatchers.filter((watcher) => !value.includes(watcher))\n\n // for each entity, add or remove the watchers\n // we do this to preserve the unique watchers for each entity (rather than setting the same watchers for all entities)\n const updatedEntities = watchers.map((entity) => {\n // first remove\n const newWatchers = entity.watchers.filter((watcher) => !removed.includes(watcher))\n // then add\n newWatchers.push(...added)\n\n return {\n ...entity,\n watchers: newWatchers,\n }\n })\n\n // update\n try {\n await setEntitiesWatchers({ entities: updatedEntities }).unwrap()\n onWatchersUpdate && onWatchersUpdate(added, removed)\n } catch (error) {\n toast.error('Failed to update watchers')\n }\n }\n\n return (\n <WatcherSelect\n align=\"right\"\n {...props}\n value={uniqueWatchers}\n currentUser={userName}\n onChange={handleChange}\n ref={ref}\n // @ts-expect-error\n buttonProps={{ 'data-tooltip': 'Watchers' }}\n />\n )\n },\n)\n"],"names":["Watchers","forwardRef","entities","entityType","onWatchersUpdate","userName","props","ref","entitiesQuery","entity","watchers","useGetEntitiesWatchersQuery","uniqueWatchers","watcher","setEntitiesWatchers","useSetEntitiesWatchersMutation","handleChange","value","added","removed","updatedEntities","newWatchers","toast","jsx","WatcherSelect"],"mappings":"
|
|
1
|
+
{"version":3,"file":"Watchers.cjs.js","sources":["../../../../../src/components/Watchers/Watchers.tsx"],"sourcesContent":["import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from '@shared/api'\nimport { DropdownRef, WatcherSelect, WatcherSelectProps } from '@ynput/ayon-react-components'\nimport { forwardRef } from 'react'\nimport { toast } from 'react-toastify'\n\ninterface WatchersProps extends Omit<WatcherSelectProps, 'currentUser' | 'value'> {\n entities: { id: string; projectName: string }[]\n entityType: string\n onWatchersUpdate?: (added: any[], removed: any[]) => void\n userName: string\n}\n\nexport const Watchers = forwardRef<DropdownRef, WatchersProps>(\n ({ entities, entityType, onWatchersUpdate, userName, ...props }, ref) => {\n const entitiesQuery = entities.map((entity) => ({\n entityId: entity.id,\n entityType,\n projectName: entity.projectName,\n }))\n\n const { data: watchers = [] } = useGetEntitiesWatchersQuery(\n {\n entities: entitiesQuery,\n },\n { skip: !entities.length },\n )\n\n // merge all watchers into a single unique array\n const uniqueWatchers = Array.from(new Set(watchers.flatMap((watcher) => watcher.watchers)))\n\n const [setEntitiesWatchers] = useSetEntitiesWatchersMutation()\n\n const handleChange = async (value: string[]) => {\n // find the difference between the current watchers and the new watchers\n // which users were added and which were removed\n const added = value.filter((watcher) => !uniqueWatchers.includes(watcher))\n const removed = uniqueWatchers.filter((watcher) => !value.includes(watcher))\n\n // for each entity, add or remove the watchers\n // we do this to preserve the unique watchers for each entity (rather than setting the same watchers for all entities)\n const updatedEntities = watchers.map((entity) => {\n // first remove\n const newWatchers = entity.watchers.filter((watcher) => !removed.includes(watcher))\n // then add\n newWatchers.push(...added)\n\n return {\n ...entity,\n watchers: newWatchers,\n }\n })\n\n // update\n try {\n await setEntitiesWatchers({ entities: updatedEntities }).unwrap()\n onWatchersUpdate && onWatchersUpdate(added, removed)\n } catch (error) {\n toast.error('Failed to update watchers')\n }\n }\n\n return (\n <WatcherSelect\n align=\"right\"\n {...props}\n value={uniqueWatchers}\n currentUser={userName}\n onChange={handleChange}\n ref={ref}\n // @ts-expect-error\n buttonProps={{ 'data-tooltip': 'Watchers' }}\n />\n )\n },\n)\n"],"names":["Watchers","forwardRef","entities","entityType","onWatchersUpdate","userName","props","ref","entitiesQuery","entity","watchers","useGetEntitiesWatchersQuery","uniqueWatchers","watcher","setEntitiesWatchers","useSetEntitiesWatchersMutation","handleChange","value","added","removed","updatedEntities","newWatchers","toast","jsx","WatcherSelect"],"mappings":"s1JAYaA,EAAWC,EAAAA,WACtB,CAAC,CAAE,SAAAC,EAAU,WAAAC,EAAY,iBAAAC,EAAkB,SAAAC,EAAU,GAAGC,CAAA,EAASC,IAAQ,CACvE,MAAMC,EAAgBN,EAAS,IAAKO,IAAY,CAC9C,SAAUA,EAAO,GACjB,WAAAN,EACA,YAAaM,EAAO,WAAA,EACpB,EAEI,CAAE,KAAMC,EAAW,CAAA,GAAOC,EAAAA,4BAC9B,CACE,SAAUH,CAAA,EAEZ,CAAE,KAAM,CAACN,EAAS,MAAA,CAAO,EAIrBU,EAAiB,MAAM,KAAK,IAAI,IAAIF,EAAS,QAASG,GAAYA,EAAQ,QAAQ,CAAC,CAAC,EAEpF,CAACC,CAAmB,EAAIC,iCAAA,EAExBC,EAAe,MAAOC,GAAoB,CAG9C,MAAMC,EAAQD,EAAM,OAAQJ,GAAY,CAACD,EAAe,SAASC,CAAO,CAAC,EACnEM,EAAUP,EAAe,OAAQC,GAAY,CAACI,EAAM,SAASJ,CAAO,CAAC,EAIrEO,EAAkBV,EAAS,IAAKD,GAAW,CAE/C,MAAMY,EAAcZ,EAAO,SAAS,OAAQI,GAAY,CAACM,EAAQ,SAASN,CAAO,CAAC,EAElF,OAAAQ,EAAY,KAAK,GAAGH,CAAK,EAElB,CACL,GAAGT,EACH,SAAUY,CAAA,CAEd,CAAC,EAGD,GAAI,CACF,MAAMP,EAAoB,CAAE,SAAUM,CAAA,CAAiB,EAAE,OAAA,EACzDhB,GAAoBA,EAAiBc,EAAOC,CAAO,CACrD,MAAgB,CACdG,EAAAA,MAAM,MAAM,2BAA2B,CACzC,CACF,EAEA,OACEC,EAAAA,kBAAAA,IAACC,EAAAA,cAAA,CACC,MAAM,QACL,GAAGlB,EACJ,MAAOM,EACP,YAAaP,EACb,SAAUW,EACV,IAAAT,EAEA,YAAa,CAAE,eAAgB,UAAA,CAAW,CAAA,CAGhD,CACF"}
|
|
@@ -77,6 +77,7 @@ import "../../api/queries/review/getReview.es.js";
|
|
|
77
77
|
import "../../api/queries/review/updateReview.es.js";
|
|
78
78
|
import "../../api/queries/share/share.es.js";
|
|
79
79
|
import "../../api/queries/system/getSystem.es.js";
|
|
80
|
+
import "../../api/queries/tasks/getTasks.es.js";
|
|
80
81
|
import "../../api/queries/tasks/updateTasks.es.js";
|
|
81
82
|
import "../../api/queries/userDashboard/getUserDashboard.es.js";
|
|
82
83
|
import "../../api/queries/users/getUsers.es.js";
|
|
@@ -90,7 +91,7 @@ import "../../api/queries/uris/getUris.es.js";
|
|
|
90
91
|
import { WatcherSelect as x } from "@ynput/ayon-react-components";
|
|
91
92
|
import { forwardRef as y } from "react";
|
|
92
93
|
import { toast as S } from "react-toastify";
|
|
93
|
-
const
|
|
94
|
+
const nr = y(
|
|
94
95
|
({ entities: i, entityType: n, onWatchersUpdate: p, userName: c, ...h }, u) => {
|
|
95
96
|
const d = i.map((t) => ({
|
|
96
97
|
entityId: t.id,
|
|
@@ -130,6 +131,6 @@ const ar = y(
|
|
|
130
131
|
}
|
|
131
132
|
);
|
|
132
133
|
export {
|
|
133
|
-
|
|
134
|
+
nr as Watchers
|
|
134
135
|
};
|
|
135
136
|
//# sourceMappingURL=Watchers.es.js.map
|