@ynput/ayon-frontend-shared 0.2.2 → 0.2.4
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/ContextMenu.cjs.js +1 -0
- package/dist/ContextMenu.cjs.js.map +1 -1
- package/dist/ContextMenu.es.js +1 -0
- package/dist/ContextMenu.es.js.map +1 -1
- package/dist/DetailsPanel.cjs.js +23 -1
- package/dist/DetailsPanel.cjs.js.map +1 -1
- package/dist/DetailsPanel.es.js +23 -1
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/ProjectTreeTable.cjs.js +12 -1
- package/dist/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/ProjectTreeTable.es.js +14 -3
- package/dist/ProjectTreeTable.es.js.map +1 -1
- package/dist/_virtual/_commonjsHelpers.cjs.js +0 -2
- package/dist/_virtual/_commonjsHelpers.cjs.js.map +1 -1
- package/dist/_virtual/_commonjsHelpers.es.js +0 -2
- package/dist/_virtual/_commonjsHelpers.es.js.map +1 -1
- package/dist/_virtual/index.cjs10.js +3 -5
- package/dist/_virtual/index.cjs10.js.map +1 -1
- package/dist/_virtual/index.cjs4.js +4 -4
- package/dist/_virtual/index.cjs5.js +2 -2
- package/dist/_virtual/index.cjs6.js +4 -4
- package/dist/_virtual/index.cjs7.js +5 -3
- package/dist/_virtual/index.cjs7.js.map +1 -1
- package/dist/_virtual/index.cjs8.js +4 -4
- package/dist/_virtual/index.cjs9.js +4 -4
- package/dist/_virtual/index.es10.js +2 -5
- package/dist/_virtual/index.es10.js.map +1 -1
- package/dist/_virtual/index.es4.js +4 -4
- package/dist/_virtual/index.es5.js +2 -2
- package/dist/_virtual/index.es6.js +4 -4
- package/dist/_virtual/index.es7.js +5 -2
- package/dist/_virtual/index.es7.js.map +1 -1
- package/dist/_virtual/index.es8.js +4 -4
- package/dist/_virtual/index.es9.js +4 -4
- package/dist/api.cjs.js +24 -1
- package/dist/api.cjs.js.map +1 -1
- package/dist/api.es.js +26 -3
- package/dist/api.es.js.map +1 -1
- package/dist/components.cjs.js +12 -0
- package/dist/components.cjs.js.map +1 -1
- package/dist/components.es.js +12 -0
- package/dist/components.es.js.map +1 -1
- package/dist/context.cjs.js +3 -0
- package/dist/context.cjs.js.map +1 -1
- package/dist/context.es.js +3 -0
- package/dist/context.es.js.map +1 -1
- package/dist/index.cjs.js +24 -2
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +24 -2
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/@reduxjs/toolkit/dist/query/react/rtk-query-react.modern.cjs.js +19 -10
- package/dist/node_modules/@reduxjs/toolkit/dist/query/react/rtk-query-react.modern.cjs.js.map +1 -1
- package/dist/node_modules/@reduxjs/toolkit/dist/query/react/rtk-query-react.modern.es.js +21 -12
- package/dist/node_modules/@reduxjs/toolkit/dist/query/react/rtk-query-react.modern.es.js.map +1 -1
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.cjs.js +174 -68
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.cjs.js.map +1 -1
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.es.js +174 -68
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.es.js.map +1 -1
- package/dist/node_modules/@standard-schema/utils/dist/index.cjs.js +23 -0
- package/dist/node_modules/@standard-schema/utils/dist/index.cjs.js.map +1 -0
- package/dist/node_modules/@standard-schema/utils/dist/index.es.js +23 -0
- package/dist/node_modules/@standard-schema/utils/dist/index.es.js.map +1 -0
- 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/parse-numeric-range/index.cjs.js +1 -1
- package/dist/node_modules/parse-numeric-range/index.es.js +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +2 -2
- package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
- package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
- package/dist/node_modules/remove-accents/index.cjs.js +1 -1
- package/dist/node_modules/remove-accents/index.es.js +1 -1
- package/dist/node_modules/vfile/lib/index.cjs.js +1 -1
- package/dist/node_modules/vfile/lib/index.es.js +1 -1
- package/dist/shared/src/api/base/client.cjs.js +3 -0
- package/dist/shared/src/api/base/client.cjs.js.map +1 -1
- package/dist/shared/src/api/base/client.es.js +3 -0
- package/dist/shared/src/api/base/client.es.js.map +1 -1
- package/dist/shared/src/api/generated/anatomy.cjs.js +13 -0
- package/dist/shared/src/api/generated/anatomy.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/anatomy.es.js +13 -0
- package/dist/shared/src/api/generated/anatomy.es.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.cjs.js +130 -0
- package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.es.js +130 -0
- package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js +1 -1
- package/dist/shared/src/api/queries/entities/getEntityPanel.es.js +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +12 -4
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +13 -5
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +4 -0
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.es.js +4 -0
- package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +267 -0
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/getLists.es.js +267 -0
- package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js +51 -0
- package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js +51 -0
- package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +169 -0
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js +169 -0
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/updateListsAttributes.cjs.js +29 -0
- package/dist/shared/src/api/queries/entityLists/updateListsAttributes.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/entityLists/updateListsAttributes.es.js +29 -0
- package/dist/shared/src/api/queries/entityLists/updateListsAttributes.es.js.map +1 -0
- package/dist/shared/src/api/queries/overview/getOverview.cjs.js +3 -4
- package/dist/shared/src/api/queries/overview/getOverview.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/overview/getOverview.es.js +3 -4
- package/dist/shared/src/api/queries/overview/getOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +40 -5
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.es.js +40 -5
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/review/getReview.cjs.js +1 -1
- package/dist/shared/src/api/queries/review/getReview.es.js +1 -1
- package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js +1 -1
- package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js +1 -1
- package/dist/shared/src/api/queries/users/getUsers.cjs.js +6 -2
- package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.es.js +7 -3
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/components/AttributeEditor/AttributeEditor.cjs.js +355 -0
- package/dist/shared/src/components/AttributeEditor/AttributeEditor.cjs.js.map +1 -0
- package/dist/shared/src/components/AttributeEditor/AttributeEditor.es.js +355 -0
- package/dist/shared/src/components/AttributeEditor/AttributeEditor.es.js.map +1 -0
- package/dist/shared/src/components/AttributeEditor/components/MinMaxField.cjs.js +93 -0
- package/dist/shared/src/components/AttributeEditor/components/MinMaxField.cjs.js.map +1 -0
- package/dist/shared/src/components/AttributeEditor/components/MinMaxField.es.js +93 -0
- package/dist/shared/src/components/AttributeEditor/components/MinMaxField.es.js.map +1 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +4 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +4 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js +6 -2
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js +6 -2
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js +1 -1
- package/dist/shared/src/components/EmptyPlaceholder/EmptyPlaceholder.cjs.js +4 -2
- package/dist/shared/src/components/EmptyPlaceholder/EmptyPlaceholder.cjs.js.map +1 -1
- package/dist/shared/src/components/EmptyPlaceholder/EmptyPlaceholder.es.js +4 -2
- package/dist/shared/src/components/EmptyPlaceholder/EmptyPlaceholder.es.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js +3 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js +3 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js.map +1 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js +23 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js +23 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js.map +1 -1
- package/dist/shared/src/components/EnumEditor/DraggableEnumEditorItem.cjs.js +194 -0
- package/dist/shared/src/components/EnumEditor/DraggableEnumEditorItem.cjs.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/DraggableEnumEditorItem.es.js +195 -0
- package/dist/shared/src/components/EnumEditor/DraggableEnumEditorItem.es.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.cjs.js +128 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.cjs.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.es.js +128 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.es.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.styled.cjs.js +185 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.styled.cjs.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.styled.es.js +185 -0
- package/dist/shared/src/components/EnumEditor/EnumEditor.styled.es.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/hooks/useDraggable.cjs.js +67 -0
- package/dist/shared/src/components/EnumEditor/hooks/useDraggable.cjs.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/hooks/useDraggable.es.js +68 -0
- package/dist/shared/src/components/EnumEditor/hooks/useDraggable.es.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/util/index.cjs.js +19 -0
- package/dist/shared/src/components/EnumEditor/util/index.cjs.js.map +1 -0
- package/dist/shared/src/components/EnumEditor/util/index.es.js +19 -0
- package/dist/shared/src/components/EnumEditor/util/index.es.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.cjs.js +78 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.cjs.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.es.js +79 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.es.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js +352 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js +353 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +113 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +113 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.cjs.js +52 -0
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.cjs.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.es.js +53 -0
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.es.js.map +1 -0
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +4 -0
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +4 -0
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +23 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +23 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +23 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +23 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +23 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +23 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js +103 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js.map +1 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js +103 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js.map +1 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js +83 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js.map +1 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js +83 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js.map +1 -0
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js +1 -0
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js +1 -0
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.cjs.js +4 -0
- package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.es.js +4 -0
- package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +23 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +23 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js +16 -7
- package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.es.js +16 -7
- package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +2 -2
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +2 -2
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +23 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +23 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
- package/dist/shared/src/containers/ContextMenu/ContextMenu.css +54 -19
- package/dist/shared/src/containers/ContextMenu/ContextMenuItem.cjs.js +11 -1
- package/dist/shared/src/containers/ContextMenu/ContextMenuItem.cjs.js.map +1 -1
- package/dist/shared/src/containers/ContextMenu/ContextMenuItem.es.js +11 -1
- package/dist/shared/src/containers/ContextMenu/ContextMenuItem.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +23 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +23 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +25 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +25 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +24 -2
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +24 -2
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +26 -4
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +26 -4
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +5 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +5 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js +1 -0
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js +1 -0
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/helpers/getThumbnails.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/helpers/getThumbnails.es.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +6 -2
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +6 -2
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js +1 -0
- package/dist/shared/src/containers/Feed/Feed.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.es.js +1 -0
- package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.cjs.js +2 -2
- 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 +2 -2
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.es.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js +1 -0
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js +5 -3
- 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 +5 -3
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js +1 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js +1 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js +1 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js +1 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +2 -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 +2 -1
- 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 +5 -0
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js +5 -0
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +7 -3
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +7 -3
- 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.es.js +1 -1
- package/dist/shared/src/containers/Feed/mentionHelpers/getMentionVersions.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/mentionHelpers/getMentionVersions.es.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +198 -222
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +201 -225
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js +1 -3
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js +1 -3
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +361 -0
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +361 -0
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js +41 -20
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js +41 -20
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +29 -36
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +31 -38
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js +33 -4
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js +34 -5
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js +17 -11
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js +17 -11
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableQueriesContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableQueriesContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardTypes.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardTypes.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardUtils.cjs.js +6 -3
- package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardUtils.es.js +6 -3
- package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +190 -146
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +190 -146
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js +10 -3
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js +10 -3
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js +15 -12
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js +15 -12
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.cjs.js +44 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.es.js +45 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js +15 -7
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js +15 -7
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.cjs.js +27 -31
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.es.js +27 -31
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/{useUpdateOverview.cjs.js → useUpdateTableData.cjs.js} +48 -20
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/{useUpdateOverview.es.js → useUpdateTableData.es.js} +48 -20
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +2 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +2 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.cjs.js +25 -20
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.es.js +25 -20
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/getReadOnlyLists.cjs.js +36 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getReadOnlyLists.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getReadOnlyLists.es.js +36 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getReadOnlyLists.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.cjs.js +39 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.es.js +39 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/loadingUtils.cjs.js +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/loadingUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/loadingUtils.es.js +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/loadingUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.cjs.js +57 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.es.js +58 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +34 -6
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +34 -6
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/DateWidget.cjs.js +7 -5
- package/dist/shared/src/containers/ProjectTreeTable/widgets/DateWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/DateWidget.es.js +7 -5
- package/dist/shared/src/containers/ProjectTreeTable/widgets/DateWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js +9 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js +9 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.cjs.js +17 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.es.js +17 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js +53 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js +53 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js.map +1 -0
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +24 -2
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +24 -2
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js +6 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js +6 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.cjs.js +4 -0
- package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.es.js +4 -0
- package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
- package/dist/shared/src/context/SettingsPanelContext.cjs.js +63 -0
- package/dist/shared/src/context/SettingsPanelContext.cjs.js.map +1 -0
- package/dist/shared/src/context/SettingsPanelContext.es.js +63 -0
- package/dist/shared/src/context/SettingsPanelContext.es.js.map +1 -0
- package/dist/shared/src/context/ThumbnailUploaderContext.cjs.js +1 -0
- package/dist/shared/src/context/ThumbnailUploaderContext.cjs.js.map +1 -1
- package/dist/shared/src/context/ThumbnailUploaderContext.es.js +1 -0
- package/dist/shared/src/context/ThumbnailUploaderContext.es.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js +5 -0
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.es.js +5 -0
- package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js +6 -2
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.es.js +6 -2
- package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
- package/dist/shared/src/util/confirmDelete.cjs.js +3 -3
- package/dist/shared/src/util/confirmDelete.cjs.js.map +1 -1
- package/dist/shared/src/util/confirmDelete.es.js +3 -3
- package/dist/shared/src/util/confirmDelete.es.js.map +1 -1
- package/dist/shared/src/util/getAttributeIcon.cjs.js +48 -0
- package/dist/shared/src/util/getAttributeIcon.cjs.js.map +1 -0
- package/dist/shared/src/util/getAttributeIcon.es.js +48 -0
- package/dist/shared/src/util/getAttributeIcon.es.js.map +1 -0
- package/dist/shared/src/util/platform.cjs.js +7 -6
- package/dist/shared/src/util/platform.cjs.js.map +1 -1
- package/dist/shared/src/util/platform.es.js +7 -6
- package/dist/shared/src/util/platform.es.js.map +1 -1
- package/dist/types/Actions.d.ts +1 -1
- package/dist/types/ContextMenu.d.ts +1 -1
- package/dist/types/DetailsPanel.d.ts +1 -1
- package/dist/types/Feed.d.ts +1 -1
- package/dist/types/ProjectTreeTable.d.ts +1 -1
- package/dist/types/RepresentationsList.d.ts +1 -1
- package/dist/types/Slicer.d.ts +1 -1
- package/dist/types/api.d.ts +3 -3
- package/dist/types/components.d.ts +1 -1
- package/dist/types/context.d.ts +1 -1
- package/dist/types/hooks.d.ts +1 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/shared/src/SimpleTable/SimpleTable.d.ts +43 -0
- package/dist/types/shared/src/SimpleTable/SimpleTable.styled.d.ts +10 -0
- package/dist/types/shared/src/SimpleTable/SimpleTableRowTemplate.d.ts +13 -0
- package/dist/types/shared/src/SimpleTable/context/SimpleTableContext.d.ts +23 -0
- package/dist/types/shared/src/SimpleTable/index.d.ts +5 -0
- package/dist/types/{api → shared/src/api}/generated/access.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/actions.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/activityFeed.d.ts +8 -8
- package/dist/types/{api → shared/src/api}/generated/addons.d.ts +28 -28
- package/dist/types/{api → shared/src/api}/generated/anatomy.d.ts +36 -6
- package/dist/types/{api → shared/src/api}/generated/attributes.d.ts +5 -5
- package/dist/types/{api → shared/src/api}/generated/authentication.d.ts +5 -5
- package/dist/types/{api → shared/src/api}/generated/bundles.d.ts +7 -7
- package/dist/types/{api → shared/src/api}/generated/configuration.d.ts +7 -7
- package/dist/types/{api → shared/src/api}/generated/desktop.d.ts +12 -12
- package/dist/types/{api → shared/src/api}/generated/entityLists.d.ts +12 -12
- package/dist/types/{api → shared/src/api}/generated/events.d.ts +8 -8
- package/dist/types/{api → shared/src/api}/generated/files.d.ts +7 -7
- package/dist/types/{api → shared/src/api}/generated/folders.d.ts +8 -8
- package/dist/types/{api → shared/src/api}/generated/graphql.d.ts +280 -64
- package/dist/types/{api → shared/src/api}/generated/inbox.d.ts +1 -1
- package/dist/types/{api → shared/src/api}/generated/links.d.ts +5 -5
- package/dist/types/{api → shared/src/api}/generated/market.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/onboarding.d.ts +3 -3
- package/dist/types/{api → shared/src/api}/generated/operations.d.ts +3 -3
- package/dist/types/{api → shared/src/api}/generated/products.d.ts +5 -5
- package/dist/types/{api → shared/src/api}/generated/projectDashboard.d.ts +4 -4
- package/dist/types/{api → shared/src/api}/generated/projects.d.ts +27 -27
- package/dist/types/{api → shared/src/api}/generated/representations.d.ts +5 -5
- package/dist/types/{api → shared/src/api}/generated/reviewables.d.ts +7 -7
- package/dist/types/{api → shared/src/api}/generated/services.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/system.d.ts +12 -12
- package/dist/types/{api → shared/src/api}/generated/tasks.d.ts +8 -8
- package/dist/types/{api → shared/src/api}/generated/teams.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/thumbnails.d.ts +11 -11
- package/dist/types/{api → shared/src/api}/generated/uRIs.d.ts +2 -2
- package/dist/types/{api → shared/src/api}/generated/users.d.ts +26 -26
- package/dist/types/{api → shared/src/api}/generated/versions.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/workfiles.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/generated/ynputCloud.d.ts +5 -5
- package/dist/types/{api → shared/src/api}/queries/actions/getActions.d.ts +29 -29
- package/dist/types/{api → shared/src/api}/queries/activities/getActivities.d.ts +88 -71
- package/dist/types/{api → shared/src/api}/queries/activities/getMentions.d.ts +18 -18
- package/dist/types/{api → shared/src/api}/queries/activities/updateActivities.d.ts +94 -62
- package/dist/types/{api → shared/src/api}/queries/activities/updateReaction.d.ts +10 -10
- package/dist/types/{api → shared/src/api}/queries/addons/getAddons.d.ts +67 -67
- package/dist/types/{api → shared/src/api}/queries/addons/updateAddons.d.ts +35 -35
- package/dist/types/{api → shared/src/api}/queries/attributes/getAttributes.d.ts +23 -23
- package/dist/types/{api → shared/src/api}/queries/attributes/updateAttributes.d.ts +12 -12
- package/dist/types/{api → shared/src/api}/queries/authentication/getAuthentication.d.ts +15 -15
- package/dist/types/{api → shared/src/api}/queries/entities/getEntity.d.ts +89 -73
- package/dist/types/{api → shared/src/api}/queries/entities/getEntityPanel.d.ts +60 -44
- package/dist/types/{api → shared/src/api}/queries/entities/transformDetailsPanelData.d.ts +1 -0
- package/dist/types/{api → shared/src/api}/queries/entities/updateEntity.d.ts +48 -32
- package/dist/types/shared/src/api/queries/entityLists/getLists.d.ts +3009 -0
- package/dist/types/shared/src/api/queries/entityLists/getListsAttributes.d.ts +148 -0
- package/dist/types/shared/src/api/queries/entityLists/index.d.ts +5 -0
- package/dist/types/shared/src/api/queries/entityLists/types.d.ts +71 -0
- package/dist/types/shared/src/api/queries/entityLists/updateLists.d.ts +1137 -0
- package/dist/types/shared/src/api/queries/entityLists/updateListsAttributes.d.ts +176 -0
- package/dist/types/{api → shared/src/api}/queries/folders/getFolders.d.ts +26 -26
- package/dist/types/{api → shared/src/api}/queries/index.d.ts +1 -0
- package/dist/types/{api → shared/src/api}/queries/overview/getOverview.d.ts +89 -73
- package/dist/types/{api → shared/src/api}/queries/overview/updateOverview.d.ts +6 -6
- package/dist/types/{api → shared/src/api}/queries/project/getProject.d.ts +103 -103
- package/dist/types/{api → shared/src/api}/queries/review/getReview.d.ts +36 -36
- package/dist/types/{api → shared/src/api}/queries/review/updateReview.d.ts +13 -13
- package/dist/types/{api → shared/src/api}/queries/system/getSystem.d.ts +39 -39
- package/dist/types/{api → shared/src/api}/queries/userDashboard/getUserDashboard.d.ts +69 -53
- package/dist/types/{api → shared/src/api}/queries/users/getUsers.d.ts +126 -110
- package/dist/types/{api → shared/src/api}/queries/watchers/getWatchers.d.ts +20 -20
- package/dist/types/shared/src/components/AttributeEditor/AttributeEditor.d.ts +18 -0
- package/dist/types/shared/src/components/AttributeEditor/components/MinMaxField.d.ts +14 -0
- package/dist/types/shared/src/components/AttributeEditor/components/index.d.ts +1 -0
- package/dist/types/shared/src/components/AttributeEditor/index.d.ts +1 -0
- package/dist/types/shared/src/components/EnumEditor/DraggableEnumEditorItem.d.ts +10 -0
- package/dist/types/shared/src/components/EnumEditor/EnumEditor.d.ts +22 -0
- package/dist/types/shared/src/components/EnumEditor/EnumEditor.styled.d.ts +23 -0
- package/dist/types/shared/src/components/EnumEditor/hooks/useDraggable.d.ts +17 -0
- package/dist/types/shared/src/components/EnumEditor/index.d.ts +1 -0
- package/dist/types/shared/src/components/EnumEditor/util/index.d.ts +1 -0
- package/dist/types/shared/src/components/ProjectTableSettings/ColumnItem.d.ts +14 -0
- package/dist/types/shared/src/components/ProjectTableSettings/ColumnsSettings.d.ts +9 -0
- package/dist/types/shared/src/components/ProjectTableSettings/ProjectTableSettings.d.ts +18 -0
- package/dist/types/shared/src/components/ProjectTableSettings/SortableColumnItem.d.ts +13 -0
- package/dist/types/shared/src/components/ProjectTableSettings/index.d.ts +1 -0
- package/dist/types/shared/src/components/SettingsPanel/SettingsPanel.d.ts +16 -0
- package/dist/types/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.d.ts +20 -0
- package/dist/types/shared/src/components/SettingsPanel/index.d.ts +2 -0
- package/dist/types/{components → shared/src/components}/index.d.ts +4 -0
- package/dist/types/{containers → shared/src/containers}/Actions/Actions.d.ts +5 -1
- package/dist/types/{containers → shared/src/containers}/ContextMenu/ContextMenuItem.d.ts +3 -1
- package/dist/types/shared/src/containers/ProjectTreeTable/ProjectTreeTable.d.ts +39 -0
- package/dist/types/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.d.ts +23 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/CellEditingContext.d.ts +3 -3
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/ColumnSettingsContext.d.ts +6 -2
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/ProjectTableContext.d.ts +41 -34
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/ProjectTableQueriesContext.d.ts +3 -2
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/clipboard/clipboardTypes.d.ts +4 -1
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/clipboard/clipboardUtils.d.ts +2 -2
- package/dist/types/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.d.ts +29 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/useFolderRelationships.d.ts +7 -7
- package/dist/types/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.d.ts +6 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/useHistory.d.ts +5 -3
- package/dist/types/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.d.ts +17 -0
- package/dist/types/{containers/ProjectTreeTable/hooks/useUpdateOverview.d.ts → shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.d.ts} +12 -3
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/index.d.ts +5 -1
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/types/index.d.ts +4 -6
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/types/table.d.ts +51 -12
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/utils/cellUtils.d.ts +2 -3
- package/dist/types/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.d.ts +16 -0
- package/dist/types/shared/src/containers/ProjectTreeTable/utils/getReadOnlyLists.d.ts +5 -0
- package/dist/types/shared/src/containers/ProjectTreeTable/utils/getTableFieldOptions.d.ts +14 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/utils/index.d.ts +2 -0
- package/dist/types/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.d.ts +4 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/BooleanWidget.d.ts +1 -2
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/CellWidget.d.ts +10 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/DateWidget.d.ts +2 -3
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/EntityNameWidget.d.ts +1 -1
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/EnumWidget.d.ts +2 -2
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/TextWidget.d.ts +3 -1
- package/dist/types/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.d.ts +9 -0
- package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/index.d.ts +1 -0
- package/dist/types/shared/src/context/SettingsPanelContext.d.ts +20 -0
- package/dist/types/{context → shared/src/context}/index.d.ts +1 -0
- package/dist/types/shared/src/index.d.ts +2 -0
- package/dist/types/shared/src/util/getAttributeIcon.d.ts +4 -0
- package/dist/types/{util → shared/src/util}/index.d.ts +1 -0
- package/dist/types/util.d.ts +1 -1
- package/dist/util.cjs.js +2 -0
- package/dist/util.cjs.js.map +1 -1
- package/dist/util.es.js +2 -0
- package/dist/util.es.js.map +1 -1
- package/package.json +2 -1
- package/dist/_virtual/lodash.cjs.js +0 -6
- package/dist/_virtual/lodash.cjs.js.map +0 -1
- package/dist/_virtual/lodash.cjs2.js +0 -5
- package/dist/_virtual/lodash.cjs2.js.map +0 -1
- package/dist/_virtual/lodash.es.js +0 -6
- package/dist/_virtual/lodash.es.js.map +0 -1
- package/dist/_virtual/lodash.es2.js +0 -5
- package/dist/_virtual/lodash.es2.js.map +0 -1
- package/dist/shared/node_modules/lodash/lodash.cjs.js +0 -5492
- package/dist/shared/node_modules/lodash/lodash.cjs.js.map +0 -1
- package/dist/shared/node_modules/lodash/lodash.es.js +0 -5492
- package/dist/shared/node_modules/lodash/lodash.es.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTableColumns.cjs.js +0 -257
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTableColumns.cjs.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTableColumns.es.js +0 -258
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTableColumns.es.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateOverview.cjs.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateOverview.es.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useValidateUpdates.cjs.js +0 -69
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useValidateUpdates.cjs.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useValidateUpdates.es.js +0 -70
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useValidateUpdates.es.js.map +0 -1
- package/dist/types/containers/ProjectTreeTable/ProjectTreeTable.d.ts +0 -26
- package/dist/types/containers/ProjectTreeTable/ProjectTreeTableColumns.d.ts +0 -16
- package/dist/types/containers/ProjectTreeTable/hooks/useCellContextMenu.d.ts +0 -10
- package/dist/types/containers/ProjectTreeTable/hooks/useOverviewTable.d.ts +0 -32
- package/dist/types/containers/ProjectTreeTable/hooks/useValidateUpdates.d.ts +0 -3
- package/dist/types/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.d.ts +0 -4
- /package/dist/types/{api → shared/src/api}/base/baseQueryTypes.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/base/client.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/base/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/generated/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/actions/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/activities/activityQueries.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/activities/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/activities/types.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/activities/util/activitiesHelpers.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/addons/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/attributes/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/authentication/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/entities/entityQueries.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/entities/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/folders/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/overview/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/project/ProjectTypes.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/project/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/review/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/review/types.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/system/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/userDashboard/convertAccessGroupsData.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/userDashboard/getUserProjectsAccess.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/userDashboard/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/users/index.d.ts +0 -0
- /package/dist/types/{api → shared/src/api}/queries/watchers/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsDialog/DetailsDialog.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsDialog/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsPanelAttributes/DetailsPanelAttributes.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsPanelAttributes/DetailsPanelAttributesEditor.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsPanelAttributes/components/RenderFieldWidget.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsPanelAttributes/formatAttributesData.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/DetailsPanelAttributes/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EmptyPlaceholder/EmptyPlaceholder.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EmptyPlaceholder/EmptyPlaceholderFlex.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EmptyPlaceholder/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityPath/EntityPath.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityPath/EntityPath.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityPath/SegmentProvider.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityPath/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityThumbnailUploader/EntityThumbnailUploader.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityThumbnailUploader/EntityThumbnailUploader.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/EntityThumbnailUploader/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/FileThumbnail/FileThumbnail.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/FileThumbnail/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewableCard/ReviewableCard.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewableCard/ReviewableCard.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewableCard/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewableProgressCard/ReviewableProgressCard.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewableProgressCard/ReviewableProgressCard.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewableProgressCard/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/EditReviewableDialog.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/ReviewablesList.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/ReviewablesList.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/ReviewablesUpload.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/ReviewablesUpload.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/SortableReviewableCard.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/getGroupedReviewables.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ReviewablesList/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/SimpleFormDialog/SimpleFormDialog.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/SimpleFormDialog/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/Thumbnail/StackedThumbnails.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/Thumbnail/Thumbnail.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/Thumbnail/Thumbnail.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/Thumbnail/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ThumbnailSimple/ThumbnailSimple.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ThumbnailSimple/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ThumbnailUploader/ThumbnailUploader.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ThumbnailUploader/ThumbnailUploader.styled.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/ThumbnailUploader/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/UserImage/UserImage.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/UserImage/index.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/Watchers/Watchers.d.ts +0 -0
- /package/dist/types/{components → shared/src/components}/Watchers/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/ActionConfigDialog.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/ActionIcon.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/Actions.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/ActionsDropdown/ActionsDropdown.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/ActionsDropdown/ActionsDropdown.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/ActionsDropdown/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/InteractiveActionDialog.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Actions/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ContextMenu/ContextMenuContext.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ContextMenu/GlobalContextMenu.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ContextMenu/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ContextMenu/useCreateContextMenu.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanel.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanel.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelFiles/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelFloating/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelHeader/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/DetailsPanelSlideOut/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/FeedFilters/FeedFilters.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/FeedFilters/FeedFilters.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/FeedWrapper.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/helpers/buildDetailsPanelTitles.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/helpers/getAllProjectsStatuses.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/helpers/getEntityPathData.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/helpers/getThumbnails.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/helpers/mergeProjectInfo.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/hooks/useGetEntityPath.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/DetailsPanel/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/Feed.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/Feed.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityAssigneeChange/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityCheckbox/ActivityCheckbox.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityCheckbox/ActivityCheckbox.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityCheckbox/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityComment/ActivityComment.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityComment/ActivityComment.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityComment/ActivityMarkdownComponents.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityComment/CommentWrapper.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityComment/mappers.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityDate.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityGroup/ActivityGroup.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityGroup/ActivityGroup.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityHeader/ActivityHeader.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityHeader/ActivityHeader.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityItem.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityReference/ActivityReference.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityReference/ActivityReference.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityReferenceTooltip/ActivityReferenceTooltip.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityReferenceTooltip/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityStatus/ActivityStatus.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityStatusChange/ActivityStatusChange.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityStatusChange/ActivityStatusChange.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityStatusChange/hooks/getContextParents.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityVersions/ActivityVersions.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ActivityVersions/ActivityVersions.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/CommentInput.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/CommentInput.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/InputMarkdownConvert.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/helpers.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/hooks/useAnnotationsSync.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/hooks/useAnnotationsUpload.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/hooks/useInitialValue.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/hooks/useMentionLink.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/hooks/useSetCursorEnd.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/modules/ImageUploader.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/modules/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentInput/quillToMarkdown.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentMentionSelect/CommentMentionSelect.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/CommentMentionSelect/CommentMentionSelect.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadCard/FileUploadCard.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadCard/FileUploadCard.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadCard/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/FileUploadPreview.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/FileUploadPreview.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/Mimes/ImageMime.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/Mimes/TextMime.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/fileUtils.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/hooks/useAttachmentNavigation.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FileUploadPreview/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FilesGrid/FilesGrid.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FilesGrid/FilesGrid.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/FilesGrid/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/ExistingReactions.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/Reaction.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/ReactionPanelOpener.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/Reactions.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/Reactions.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/helpers.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/ReactionContainer/types.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/Tooltips/EntityTooltip/EntityTooltip.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/Tooltips/EntityTooltip/EntityTooltip.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/Tooltips/UserTooltip/UserTooltip.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/components/Tooltips/UserTooltip/UserTooltip.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/context/FeedContext.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/feedHelpers.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/helpers/groupActivityVersions.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/helpers/groupMinorActivities.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/helpers/mergeSimilarActivities.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useCommentMutations.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useGetFeedActivitiesData.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useReferenceTooltip.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useSaveScrollPos.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useScrollOnInputOpen.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useScrollToHighlighted.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useTableKeyboardNavigation.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/hooks/useTransformActivities.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/mentionHelpers/getMentionOptions.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/mentionHelpers/getMentionTasks.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/mentionHelpers/getMentionUsers.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Feed/mentionHelpers/getMentionVersions.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/ProjectTreeTable.styled.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/components/HeaderActionButton.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/components/RowSelectionHeader.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/components/SelectionCell.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/ClipboardContext.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/ProjectTableSelectionContext.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/SelectedRowsContext.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/SelectionCellsContext.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/clipboard/clipboardValidation.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/clipboard/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/context/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/useColumnVirtualization.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/useCustomColumnWidthVars.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/useDeleteEntities.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/useKeyboardNavigation.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/hooks/usePrefetchFolderTasks.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/types/folders.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/types/operations.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/types/project.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/utils/loadingUtils.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/CollapsedWidget.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/DateWidgetInput.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/ProjectTreeTable/widgets/TextWidgetInput.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/RepresentationsList/RepresentationsList.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/RepresentationsList/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/RepresentationsList/versionsToRepresentations.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Slicer/createFilterFromSlicer.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Slicer/index.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/Slicer/types.d.ts +0 -0
- /package/dist/types/{containers → shared/src/containers}/index.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/DetailsPanelContext.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/RemoteModulesContext.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/ThumbnailUploaderContext.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/pip/PiPProvider.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/pip/PiPWindow.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/pip/PiPWrapper.d.ts +0 -0
- /package/dist/types/{context → shared/src/context}/pip/index.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/index.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/useActionTriggers.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/useEntityUpdate.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/useLoadModule.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/useLoadModules.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/useLocalStorage.d.ts +0 -0
- /package/dist/types/{hooks → shared/src/hooks}/useScopedStatuses.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/confirmDelete.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/copyToClipboard.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/getEntityTypeIcon.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/getMixedState.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/getPriorityOptions.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/groupResult.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/platform.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/productTypes.d.ts +0 -0
- /package/dist/types/{util → shared/src/util}/pubsub.d.ts +0 -0
|
@@ -35,7 +35,7 @@ require("../../generated/users.cjs.js");
|
|
|
35
35
|
require("../../generated/versions.cjs.js");
|
|
36
36
|
require("../../generated/workfiles.cjs.js");
|
|
37
37
|
require("../../generated/ynputCloud.cjs.js");
|
|
38
|
-
require("
|
|
38
|
+
require("lodash");
|
|
39
39
|
require("react-toastify");
|
|
40
40
|
const pubsub = require("../../../util/pubsub.cjs.js");
|
|
41
41
|
const transformDetailsPanelData = require("./transformDetailsPanelData.cjs.js");
|
|
@@ -33,7 +33,7 @@ import "../../generated/users.es.js";
|
|
|
33
33
|
import "../../generated/versions.es.js";
|
|
34
34
|
import "../../generated/workfiles.es.js";
|
|
35
35
|
import "../../generated/ynputCloud.es.js";
|
|
36
|
-
import "
|
|
36
|
+
import "lodash";
|
|
37
37
|
import "react-toastify";
|
|
38
38
|
import PubSub from "../../../util/pubsub.es.js";
|
|
39
39
|
import { transformDetailsPanelQueriesData, detailsPanelEntityTypes } from "./transformDetailsPanelData.es.js";
|
|
@@ -48,6 +48,10 @@ require("../authentication/getAuthentication.cjs.js");
|
|
|
48
48
|
require("./getEntity.cjs.js");
|
|
49
49
|
require("./getEntityPanel.cjs.js");
|
|
50
50
|
require("./updateEntity.cjs.js");
|
|
51
|
+
require("../entityLists/getLists.cjs.js");
|
|
52
|
+
require("../entityLists/updateLists.cjs.js");
|
|
53
|
+
require("../entityLists/getListsAttributes.cjs.js");
|
|
54
|
+
require("../entityLists/updateListsAttributes.cjs.js");
|
|
51
55
|
require("../folders/getFolders.cjs.js");
|
|
52
56
|
const getOverview = require("../overview/getOverview.cjs.js");
|
|
53
57
|
require("../overview/updateOverview.cjs.js");
|
|
@@ -72,6 +76,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
72
76
|
const task = entity;
|
|
73
77
|
return {
|
|
74
78
|
entityType: "task",
|
|
79
|
+
entitySubType: task.taskType,
|
|
75
80
|
projectName,
|
|
76
81
|
id: task.id,
|
|
77
82
|
name: task.name,
|
|
@@ -80,7 +85,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
80
85
|
status: task.status,
|
|
81
86
|
updatedAt: task.updatedAt,
|
|
82
87
|
createdAt: task.createdAt,
|
|
83
|
-
attrib: getOverview.
|
|
88
|
+
attrib: getOverview.parseAllAttribs(task.allAttrib),
|
|
84
89
|
hasReviewables: task.hasReviewables,
|
|
85
90
|
thumbnailId: task.thumbnailId,
|
|
86
91
|
folder: task.folder,
|
|
@@ -98,6 +103,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
98
103
|
const version = entity;
|
|
99
104
|
return {
|
|
100
105
|
entityType: "version",
|
|
106
|
+
entitySubType: void 0,
|
|
101
107
|
projectName,
|
|
102
108
|
id: version.id,
|
|
103
109
|
name: version.name,
|
|
@@ -106,7 +112,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
106
112
|
status: version.status,
|
|
107
113
|
updatedAt: version.updatedAt,
|
|
108
114
|
createdAt: version.createdAt,
|
|
109
|
-
attrib: getOverview.
|
|
115
|
+
attrib: getOverview.parseAllAttribs(version.allAttrib),
|
|
110
116
|
hasReviewables: version.hasReviewables,
|
|
111
117
|
thumbnailId: version.thumbnailId,
|
|
112
118
|
folder: (_d = version.product) == null ? void 0 : _d.folder,
|
|
@@ -121,6 +127,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
121
127
|
const folder = entity;
|
|
122
128
|
return {
|
|
123
129
|
entityType: "folder",
|
|
130
|
+
entitySubType: folder.folderType,
|
|
124
131
|
projectName,
|
|
125
132
|
id: folder.id,
|
|
126
133
|
name: folder.name,
|
|
@@ -129,7 +136,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
129
136
|
status: folder.status,
|
|
130
137
|
updatedAt: folder.updatedAt,
|
|
131
138
|
createdAt: folder.createdAt,
|
|
132
|
-
attrib: getOverview.
|
|
139
|
+
attrib: getOverview.parseAllAttribs(folder.allAttrib),
|
|
133
140
|
hasReviewables: folder.hasReviewables,
|
|
134
141
|
thumbnailId: folder.thumbnailId,
|
|
135
142
|
folder: {
|
|
@@ -146,6 +153,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
146
153
|
const representation = entity;
|
|
147
154
|
return {
|
|
148
155
|
entityType: "representation",
|
|
156
|
+
entitySubType: void 0,
|
|
149
157
|
projectName,
|
|
150
158
|
id: representation.id,
|
|
151
159
|
name: representation.name,
|
|
@@ -154,7 +162,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
154
162
|
status: representation.status,
|
|
155
163
|
updatedAt: representation.updatedAt,
|
|
156
164
|
createdAt: representation.createdAt,
|
|
157
|
-
attrib: getOverview.
|
|
165
|
+
attrib: getOverview.parseAllAttribs(representation.allAttrib),
|
|
158
166
|
hasReviewables: void 0,
|
|
159
167
|
thumbnailId: void 0,
|
|
160
168
|
version: representation.version,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transformDetailsPanelData.cjs.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport {
|
|
1
|
+
{"version":3,"file":"transformDetailsPanelData.cjs.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport { parseAllAttribs } from '@shared/api'\n\ntype DetailsPanelTask = NonNullable<GetDetailsPanelTaskQuery['project']['task']>\ntype DetailsPanelRepresentation = NonNullable<\n GetDetailsPanelRepresentationQuery['project']['representation']\n>\ntype DetailsPanelVersion = NonNullable<GetDetailsPanelVersionQuery['project']['version']>\ntype DetailsPanelFolder = NonNullable<GetDetailsPanelFolderQuery['project']['folder']>\n\nexport const detailsPanelEntityTypes = ['task', 'version', 'folder', 'representation'] as const\nexport type DetailsPanelEntityType = (typeof detailsPanelEntityTypes)[number]\n\ntype TransformEntityDataArgs = {\n entity: DetailsPanelRepresentation | DetailsPanelTask | DetailsPanelVersion | DetailsPanelFolder\n entityType: DetailsPanelEntityType\n projectName: string\n}\n\ntype NullableString = string | null | undefined\n\n// return type\nexport type DetailsPanelEntityData = {\n id: string\n name: string\n label: NullableString\n tags: string[]\n status: string\n updatedAt: string\n createdAt: string\n attrib: Record<string, string | number>\n hasReviewables?: boolean\n thumbnailId?: string | null | undefined\n // extra metadata\n entityType: string\n entitySubType?: string\n projectName: string\n // type specific\n task?: DetailsPanelTaskFragmentFragment\n folder?: DetailsPanelFolderFragmentFragment\n product?: DetailsPanelProductFragmentFragment\n version?: DetailsPanelVersionFragmentFragment\n representations?: DetailsPanelRepresentationFragmentFragment[]\n}\n\n// takes the data from different entity types and returns a single data model\nexport const transformDetailsPanelQueriesData = ({\n entity,\n entityType,\n projectName,\n}: TransformEntityDataArgs): DetailsPanelEntityData => {\n switch (entityType) {\n case 'task':\n const task = entity as DetailsPanelTask\n return {\n entityType: 'task',\n entitySubType: task.taskType,\n projectName: projectName,\n id: task.id,\n name: task.name,\n label: task.label,\n tags: task.tags,\n status: task.status,\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n attrib: parseAllAttribs(task.allAttrib),\n hasReviewables: task.hasReviewables,\n thumbnailId: task.thumbnailId,\n folder: task.folder,\n task: {\n id: task.id,\n name: task.name,\n label: task.label,\n assignees: task.assignees,\n taskType: task.taskType,\n },\n product: undefined,\n version: task.versions?.edges?.[0]?.node,\n }\n case 'version':\n const version = entity as DetailsPanelVersion\n return {\n entityType: 'version',\n entitySubType: undefined,\n projectName: projectName,\n id: version.id,\n name: version.name,\n label: undefined,\n tags: version.tags,\n status: version.status,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n attrib: parseAllAttribs(version.allAttrib),\n hasReviewables: version.hasReviewables,\n thumbnailId: version.thumbnailId,\n folder: version.product?.folder,\n product: {\n id: version.product?.id,\n name: version.product?.name,\n productType: version.product?.productType,\n },\n representations: version.representations?.edges?.map((edge) => edge.node) || [],\n }\n case 'folder':\n const folder = entity as DetailsPanelFolder\n return {\n entityType: 'folder',\n entitySubType: folder.folderType,\n projectName: projectName,\n id: folder.id,\n name: folder.name,\n label: folder.label,\n tags: folder.tags,\n status: folder.status,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n attrib: parseAllAttribs(folder.allAttrib),\n hasReviewables: folder.hasReviewables,\n thumbnailId: folder.thumbnailId,\n folder: {\n id: folder.id,\n name: folder.name,\n label: folder.label,\n folderType: folder.folderType,\n },\n product: undefined,\n version: undefined,\n representations: undefined,\n }\n case 'representation':\n const representation = entity as DetailsPanelRepresentation\n return {\n entityType: 'representation',\n entitySubType: undefined,\n projectName: projectName,\n id: representation.id,\n name: representation.name,\n label: undefined,\n tags: representation.tags,\n status: representation.status,\n updatedAt: representation.updatedAt,\n createdAt: representation.createdAt,\n attrib: parseAllAttribs(representation.allAttrib),\n hasReviewables: undefined,\n thumbnailId: undefined,\n version: representation.version,\n product: representation.version.product,\n task: representation.version.task || undefined,\n folder: representation.version.product?.folder,\n representations: undefined,\n }\n }\n}\n"],"names":["parseAllAttribs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBO,MAAM,0BAA0B,CAAC,QAAQ,WAAW,UAAU,gBAAgB;AAoC9E,MAAM,mCAAmC,CAAC;AAAA,EAC/C;AAAA,EACA;AAAA,EACA;AACF,MAAuD;;AACrD,UAAQ,YAAY;AAAA,IAClB,KAAK;AACH,YAAM,OAAO;AACN,aAAA;AAAA,QACL,YAAY;AAAA,QACZ,eAAe,KAAK;AAAA,QACpB;AAAA,QACA,IAAI,KAAK;AAAA,QACT,MAAM,KAAK;AAAA,QACX,OAAO,KAAK;AAAA,QACZ,MAAM,KAAK;AAAA,QACX,QAAQ,KAAK;AAAA,QACb,WAAW,KAAK;AAAA,QAChB,WAAW,KAAK;AAAA,QAChB,QAAQA,YAAAA,gBAAgB,KAAK,SAAS;AAAA,QACtC,gBAAgB,KAAK;AAAA,QACrB,aAAa,KAAK;AAAA,QAClB,QAAQ,KAAK;AAAA,QACb,MAAM;AAAA,UACJ,IAAI,KAAK;AAAA,UACT,MAAM,KAAK;AAAA,UACX,OAAO,KAAK;AAAA,UACZ,WAAW,KAAK;AAAA,UAChB,UAAU,KAAK;AAAA,QACjB;AAAA,QACA,SAAS;AAAA,QACT,UAAS,sBAAK,aAAL,mBAAe,UAAf,mBAAuB,OAAvB,mBAA2B;AAAA,MACtC;AAAA,IACF,KAAK;AACH,YAAM,UAAU;AACT,aAAA;AAAA,QACL,YAAY;AAAA,QACZ,eAAe;AAAA,QACf;AAAA,QACA,IAAI,QAAQ;AAAA,QACZ,MAAM,QAAQ;AAAA,QACd,OAAO;AAAA,QACP,MAAM,QAAQ;AAAA,QACd,QAAQ,QAAQ;AAAA,QAChB,WAAW,QAAQ;AAAA,QACnB,WAAW,QAAQ;AAAA,QACnB,QAAQA,YAAAA,gBAAgB,QAAQ,SAAS;AAAA,QACzC,gBAAgB,QAAQ;AAAA,QACxB,aAAa,QAAQ;AAAA,QACrB,SAAQ,aAAQ,YAAR,mBAAiB;AAAA,QACzB,SAAS;AAAA,UACP,KAAI,aAAQ,YAAR,mBAAiB;AAAA,UACrB,OAAM,aAAQ,YAAR,mBAAiB;AAAA,UACvB,cAAa,aAAQ,YAAR,mBAAiB;AAAA,QAChC;AAAA,QACA,mBAAiB,mBAAQ,oBAAR,mBAAyB,UAAzB,mBAAgC,IAAI,CAAC,SAAS,KAAK,UAAS,CAAA;AAAA,MAC/E;AAAA,IACF,KAAK;AACH,YAAM,SAAS;AACR,aAAA;AAAA,QACL,YAAY;AAAA,QACZ,eAAe,OAAO;AAAA,QACtB;AAAA,QACA,IAAI,OAAO;AAAA,QACX,MAAM,OAAO;AAAA,QACb,OAAO,OAAO;AAAA,QACd,MAAM,OAAO;AAAA,QACb,QAAQ,OAAO;AAAA,QACf,WAAW,OAAO;AAAA,QAClB,WAAW,OAAO;AAAA,QAClB,QAAQA,YAAAA,gBAAgB,OAAO,SAAS;AAAA,QACxC,gBAAgB,OAAO;AAAA,QACvB,aAAa,OAAO;AAAA,QACpB,QAAQ;AAAA,UACN,IAAI,OAAO;AAAA,UACX,MAAM,OAAO;AAAA,UACb,OAAO,OAAO;AAAA,UACd,YAAY,OAAO;AAAA,QACrB;AAAA,QACA,SAAS;AAAA,QACT,SAAS;AAAA,QACT,iBAAiB;AAAA,MACnB;AAAA,IACF,KAAK;AACH,YAAM,iBAAiB;AAChB,aAAA;AAAA,QACL,YAAY;AAAA,QACZ,eAAe;AAAA,QACf;AAAA,QACA,IAAI,eAAe;AAAA,QACnB,MAAM,eAAe;AAAA,QACrB,OAAO;AAAA,QACP,MAAM,eAAe;AAAA,QACrB,QAAQ,eAAe;AAAA,QACvB,WAAW,eAAe;AAAA,QAC1B,WAAW,eAAe;AAAA,QAC1B,QAAQA,YAAAA,gBAAgB,eAAe,SAAS;AAAA,QAChD,gBAAgB;AAAA,QAChB,aAAa;AAAA,QACb,SAAS,eAAe;AAAA,QACxB,SAAS,eAAe,QAAQ;AAAA,QAChC,MAAM,eAAe,QAAQ,QAAQ;AAAA,QACrC,SAAQ,oBAAe,QAAQ,YAAvB,mBAAgC;AAAA,QACxC,iBAAiB;AAAA,MACnB;AAAA,EAAA;AAEN;;;"}
|
|
@@ -46,8 +46,12 @@ import "../authentication/getAuthentication.es.js";
|
|
|
46
46
|
import "./getEntity.es.js";
|
|
47
47
|
import "./getEntityPanel.es.js";
|
|
48
48
|
import "./updateEntity.es.js";
|
|
49
|
+
import "../entityLists/getLists.es.js";
|
|
50
|
+
import "../entityLists/updateLists.es.js";
|
|
51
|
+
import "../entityLists/getListsAttributes.es.js";
|
|
52
|
+
import "../entityLists/updateListsAttributes.es.js";
|
|
49
53
|
import "../folders/getFolders.es.js";
|
|
50
|
-
import {
|
|
54
|
+
import { parseAllAttribs } from "../overview/getOverview.es.js";
|
|
51
55
|
import "../overview/updateOverview.es.js";
|
|
52
56
|
import "../project/getProject.es.js";
|
|
53
57
|
import "../project/updateProject.es.js";
|
|
@@ -70,6 +74,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
70
74
|
const task = entity;
|
|
71
75
|
return {
|
|
72
76
|
entityType: "task",
|
|
77
|
+
entitySubType: task.taskType,
|
|
73
78
|
projectName,
|
|
74
79
|
id: task.id,
|
|
75
80
|
name: task.name,
|
|
@@ -78,7 +83,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
78
83
|
status: task.status,
|
|
79
84
|
updatedAt: task.updatedAt,
|
|
80
85
|
createdAt: task.createdAt,
|
|
81
|
-
attrib:
|
|
86
|
+
attrib: parseAllAttribs(task.allAttrib),
|
|
82
87
|
hasReviewables: task.hasReviewables,
|
|
83
88
|
thumbnailId: task.thumbnailId,
|
|
84
89
|
folder: task.folder,
|
|
@@ -96,6 +101,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
96
101
|
const version = entity;
|
|
97
102
|
return {
|
|
98
103
|
entityType: "version",
|
|
104
|
+
entitySubType: void 0,
|
|
99
105
|
projectName,
|
|
100
106
|
id: version.id,
|
|
101
107
|
name: version.name,
|
|
@@ -104,7 +110,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
104
110
|
status: version.status,
|
|
105
111
|
updatedAt: version.updatedAt,
|
|
106
112
|
createdAt: version.createdAt,
|
|
107
|
-
attrib:
|
|
113
|
+
attrib: parseAllAttribs(version.allAttrib),
|
|
108
114
|
hasReviewables: version.hasReviewables,
|
|
109
115
|
thumbnailId: version.thumbnailId,
|
|
110
116
|
folder: (_d = version.product) == null ? void 0 : _d.folder,
|
|
@@ -119,6 +125,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
119
125
|
const folder = entity;
|
|
120
126
|
return {
|
|
121
127
|
entityType: "folder",
|
|
128
|
+
entitySubType: folder.folderType,
|
|
122
129
|
projectName,
|
|
123
130
|
id: folder.id,
|
|
124
131
|
name: folder.name,
|
|
@@ -127,7 +134,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
127
134
|
status: folder.status,
|
|
128
135
|
updatedAt: folder.updatedAt,
|
|
129
136
|
createdAt: folder.createdAt,
|
|
130
|
-
attrib:
|
|
137
|
+
attrib: parseAllAttribs(folder.allAttrib),
|
|
131
138
|
hasReviewables: folder.hasReviewables,
|
|
132
139
|
thumbnailId: folder.thumbnailId,
|
|
133
140
|
folder: {
|
|
@@ -144,6 +151,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
144
151
|
const representation = entity;
|
|
145
152
|
return {
|
|
146
153
|
entityType: "representation",
|
|
154
|
+
entitySubType: void 0,
|
|
147
155
|
projectName,
|
|
148
156
|
id: representation.id,
|
|
149
157
|
name: representation.name,
|
|
@@ -152,7 +160,7 @@ const transformDetailsPanelQueriesData = ({
|
|
|
152
160
|
status: representation.status,
|
|
153
161
|
updatedAt: representation.updatedAt,
|
|
154
162
|
createdAt: representation.createdAt,
|
|
155
|
-
attrib:
|
|
163
|
+
attrib: parseAllAttribs(representation.allAttrib),
|
|
156
164
|
hasReviewables: void 0,
|
|
157
165
|
thumbnailId: void 0,
|
|
158
166
|
version: representation.version,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transformDetailsPanelData.es.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport {
|
|
1
|
+
{"version":3,"file":"transformDetailsPanelData.es.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport { parseAllAttribs } from '@shared/api'\n\ntype DetailsPanelTask = NonNullable<GetDetailsPanelTaskQuery['project']['task']>\ntype DetailsPanelRepresentation = NonNullable<\n GetDetailsPanelRepresentationQuery['project']['representation']\n>\ntype DetailsPanelVersion = NonNullable<GetDetailsPanelVersionQuery['project']['version']>\ntype DetailsPanelFolder = NonNullable<GetDetailsPanelFolderQuery['project']['folder']>\n\nexport const detailsPanelEntityTypes = ['task', 'version', 'folder', 'representation'] as const\nexport type DetailsPanelEntityType = (typeof detailsPanelEntityTypes)[number]\n\ntype TransformEntityDataArgs = {\n entity: DetailsPanelRepresentation | DetailsPanelTask | DetailsPanelVersion | DetailsPanelFolder\n entityType: DetailsPanelEntityType\n projectName: string\n}\n\ntype NullableString = string | null | undefined\n\n// return type\nexport type DetailsPanelEntityData = {\n id: string\n name: string\n label: NullableString\n tags: string[]\n status: string\n updatedAt: string\n createdAt: string\n attrib: Record<string, string | number>\n hasReviewables?: boolean\n thumbnailId?: string | null | undefined\n // extra metadata\n entityType: string\n entitySubType?: string\n projectName: string\n // type specific\n task?: DetailsPanelTaskFragmentFragment\n folder?: DetailsPanelFolderFragmentFragment\n product?: DetailsPanelProductFragmentFragment\n version?: DetailsPanelVersionFragmentFragment\n representations?: DetailsPanelRepresentationFragmentFragment[]\n}\n\n// takes the data from different entity types and returns a single data model\nexport const transformDetailsPanelQueriesData = ({\n entity,\n entityType,\n projectName,\n}: TransformEntityDataArgs): DetailsPanelEntityData => {\n switch (entityType) {\n case 'task':\n const task = entity as DetailsPanelTask\n return {\n entityType: 'task',\n entitySubType: task.taskType,\n projectName: projectName,\n id: task.id,\n name: task.name,\n label: task.label,\n tags: task.tags,\n status: task.status,\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n attrib: parseAllAttribs(task.allAttrib),\n hasReviewables: task.hasReviewables,\n thumbnailId: task.thumbnailId,\n folder: task.folder,\n task: {\n id: task.id,\n name: task.name,\n label: task.label,\n assignees: task.assignees,\n taskType: task.taskType,\n },\n product: undefined,\n version: task.versions?.edges?.[0]?.node,\n }\n case 'version':\n const version = entity as DetailsPanelVersion\n return {\n entityType: 'version',\n entitySubType: undefined,\n projectName: projectName,\n id: version.id,\n name: version.name,\n label: undefined,\n tags: version.tags,\n status: version.status,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n attrib: parseAllAttribs(version.allAttrib),\n hasReviewables: version.hasReviewables,\n thumbnailId: version.thumbnailId,\n folder: version.product?.folder,\n product: {\n id: version.product?.id,\n name: version.product?.name,\n productType: version.product?.productType,\n },\n representations: version.representations?.edges?.map((edge) => edge.node) || [],\n }\n case 'folder':\n const folder = entity as DetailsPanelFolder\n return {\n entityType: 'folder',\n entitySubType: folder.folderType,\n projectName: projectName,\n id: folder.id,\n name: folder.name,\n label: folder.label,\n tags: folder.tags,\n status: folder.status,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n attrib: parseAllAttribs(folder.allAttrib),\n hasReviewables: folder.hasReviewables,\n thumbnailId: folder.thumbnailId,\n folder: {\n id: folder.id,\n name: folder.name,\n label: folder.label,\n folderType: folder.folderType,\n },\n product: undefined,\n version: undefined,\n representations: undefined,\n }\n case 'representation':\n const representation = entity as DetailsPanelRepresentation\n return {\n entityType: 'representation',\n entitySubType: undefined,\n projectName: projectName,\n id: representation.id,\n name: representation.name,\n label: undefined,\n tags: representation.tags,\n status: representation.status,\n updatedAt: representation.updatedAt,\n createdAt: representation.createdAt,\n attrib: parseAllAttribs(representation.allAttrib),\n hasReviewables: undefined,\n thumbnailId: undefined,\n version: representation.version,\n product: representation.version.product,\n task: representation.version.task || undefined,\n folder: representation.version.product?.folder,\n representations: undefined,\n }\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -47,6 +47,10 @@ require("../../generated/users.cjs.js");
|
|
|
47
47
|
require("../../generated/versions.cjs.js");
|
|
48
48
|
require("../../generated/workfiles.cjs.js");
|
|
49
49
|
require("../../generated/ynputCloud.cjs.js");
|
|
50
|
+
require("../entityLists/getLists.cjs.js");
|
|
51
|
+
require("../entityLists/updateLists.cjs.js");
|
|
52
|
+
require("../entityLists/getListsAttributes.cjs.js");
|
|
53
|
+
require("../entityLists/updateListsAttributes.cjs.js");
|
|
50
54
|
require("../folders/getFolders.cjs.js");
|
|
51
55
|
require("../overview/getOverview.cjs.js");
|
|
52
56
|
const updateOverview = require("../overview/updateOverview.cjs.js");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateEntity.cjs.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n // update folder\n const newFolder = { ...folder, ...patch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["dashboardQueries","api","folder","task","getKanbanTasks","detailsPanelQueries","patchDetailsPanelEntity","toast","patchOverviewTasks","patchOverviewFolders"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"updateEntity.cjs.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n // update folder\n const newFolder = { ...folder, ...patch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["dashboardQueries","api","folder","task","getKanbanTasks","detailsPanelQueries","patchDetailsPanelEntity","toast","patchOverviewTasks","patchOverviewFolders"],"mappings":"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"}
|
|
@@ -45,6 +45,10 @@ import "../../generated/users.es.js";
|
|
|
45
45
|
import "../../generated/versions.es.js";
|
|
46
46
|
import "../../generated/workfiles.es.js";
|
|
47
47
|
import "../../generated/ynputCloud.es.js";
|
|
48
|
+
import "../entityLists/getLists.es.js";
|
|
49
|
+
import "../entityLists/updateLists.es.js";
|
|
50
|
+
import "../entityLists/getListsAttributes.es.js";
|
|
51
|
+
import "../entityLists/updateListsAttributes.es.js";
|
|
48
52
|
import "../folders/getFolders.es.js";
|
|
49
53
|
import "../overview/getOverview.es.js";
|
|
50
54
|
import { patchOverviewTasks, patchOverviewFolders, patchDetailsPanelEntity } from "../overview/updateOverview.es.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateEntity.es.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n // update folder\n const newFolder = { ...folder, ...patch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["dashboardQueries","api","folder","task","detailsPanelQueries"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"updateEntity.es.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n // update folder\n const newFolder = { ...folder, ...patch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["dashboardQueries","api","folder","task","detailsPanelQueries"],"mappings":"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"}
|