@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
|
@@ -1,32 +1,20 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
const React = require("react");
|
|
3
3
|
const loadingUtils = require("../utils/loadingUtils.cjs.js");
|
|
4
|
+
const useGetEntityTypeData = require("./useGetEntityTypeData.cjs.js");
|
|
4
5
|
const TASKS_INFINITE_QUERY_COUNT = 100;
|
|
5
6
|
function useOverviewTable({
|
|
6
7
|
foldersMap,
|
|
7
8
|
tasksMap,
|
|
9
|
+
rows,
|
|
8
10
|
tasksByFolderMap,
|
|
9
11
|
expanded,
|
|
10
|
-
|
|
11
|
-
taskTypes = [],
|
|
12
|
+
projectInfo,
|
|
12
13
|
showHierarchy,
|
|
13
14
|
loadingTasks = {},
|
|
14
15
|
isLoadingMore = false
|
|
15
16
|
}) {
|
|
16
|
-
const
|
|
17
|
-
const map = /* @__PURE__ */ new Map();
|
|
18
|
-
for (const folderType of folderTypes) {
|
|
19
|
-
map.set(folderType.name, folderType);
|
|
20
|
-
}
|
|
21
|
-
return map;
|
|
22
|
-
}, [folderTypes]);
|
|
23
|
-
const taskTypesByName = React.useMemo(() => {
|
|
24
|
-
const map = /* @__PURE__ */ new Map();
|
|
25
|
-
for (const taskType of taskTypes) {
|
|
26
|
-
map.set(taskType.name, taskType);
|
|
27
|
-
}
|
|
28
|
-
return map;
|
|
29
|
-
}, [taskTypes]);
|
|
17
|
+
const getEntityTypeData = useGetEntityTypeData({ projectInfo });
|
|
30
18
|
const expandedKey = React.useMemo(() => JSON.stringify(expanded), [expanded]);
|
|
31
19
|
const expandedFolderIds = React.useMemo(() => {
|
|
32
20
|
return new Set(
|
|
@@ -37,7 +25,7 @@ function useOverviewTable({
|
|
|
37
25
|
const childToParent = /* @__PURE__ */ new Map();
|
|
38
26
|
const parentToChildren = /* @__PURE__ */ new Map();
|
|
39
27
|
for (const folder of foldersMap.values()) {
|
|
40
|
-
if (!folder.id) continue;
|
|
28
|
+
if (!(folder == null ? void 0 : folder.id)) continue;
|
|
41
29
|
const parentId = folder.parentId;
|
|
42
30
|
if (parentId) {
|
|
43
31
|
childToParent.set(folder.id, parentId);
|
|
@@ -55,7 +43,7 @@ function useOverviewTable({
|
|
|
55
43
|
const visible = /* @__PURE__ */ new Set();
|
|
56
44
|
const queue = [];
|
|
57
45
|
for (const folder of foldersMap.values()) {
|
|
58
|
-
if (!folder.id) continue;
|
|
46
|
+
if (!(folder == null ? void 0 : folder.id)) continue;
|
|
59
47
|
if (!folder.parentId || !foldersMap.has(folder.parentId)) {
|
|
60
48
|
visible.add(folder.id);
|
|
61
49
|
queue.push(folder.id);
|
|
@@ -80,15 +68,15 @@ function useOverviewTable({
|
|
|
80
68
|
return React.useMemo(() => {
|
|
81
69
|
var _a, _b, _c, _d, _e, _f, _g;
|
|
82
70
|
const createTaskRow = (task, parentId) => {
|
|
83
|
-
|
|
71
|
+
const typeData = getEntityTypeData("task", task.taskType);
|
|
84
72
|
return {
|
|
85
73
|
id: task.id,
|
|
86
74
|
entityType: "task",
|
|
87
75
|
parentId: parentId || task.folderId,
|
|
88
76
|
name: task.name || "",
|
|
89
77
|
label: task.label || task.name || "",
|
|
90
|
-
icon: (
|
|
91
|
-
color: (
|
|
78
|
+
icon: (typeData == null ? void 0 : typeData.icon) || null,
|
|
79
|
+
color: (typeData == null ? void 0 : typeData.color) || null,
|
|
92
80
|
status: task.status,
|
|
93
81
|
assignees: task.assignees,
|
|
94
82
|
tags: task.tags,
|
|
@@ -97,17 +85,21 @@ function useOverviewTable({
|
|
|
97
85
|
subType: task.taskType || null,
|
|
98
86
|
attrib: task.attrib,
|
|
99
87
|
ownAttrib: task.ownAttrib,
|
|
100
|
-
path: task.folder.path
|
|
88
|
+
path: task.folder.path,
|
|
89
|
+
updatedAt: task.updatedAt
|
|
101
90
|
};
|
|
102
91
|
};
|
|
103
92
|
if (!showHierarchy) {
|
|
104
|
-
const
|
|
93
|
+
const flatRows = [];
|
|
105
94
|
for (const task of tasksMap.values()) {
|
|
106
95
|
if (!task.id) continue;
|
|
107
|
-
|
|
96
|
+
flatRows.push(createTaskRow(task));
|
|
108
97
|
}
|
|
109
|
-
|
|
110
|
-
|
|
98
|
+
for (const row of rows || []) {
|
|
99
|
+
flatRows.push(row);
|
|
100
|
+
}
|
|
101
|
+
if (flatRows.length > 1) {
|
|
102
|
+
flatRows.sort((a, b) => {
|
|
111
103
|
if (a.name < b.name) return -1;
|
|
112
104
|
if (a.name > b.name) return 1;
|
|
113
105
|
return 0;
|
|
@@ -123,10 +115,10 @@ function useOverviewTable({
|
|
|
123
115
|
const loadingTaskRows = loadingUtils.generateLoadingRows(loadingAttribs, count, {
|
|
124
116
|
type: "task"
|
|
125
117
|
});
|
|
126
|
-
|
|
118
|
+
flatRows.push(...loadingTaskRows);
|
|
127
119
|
}
|
|
128
120
|
}
|
|
129
|
-
return
|
|
121
|
+
return flatRows;
|
|
130
122
|
}
|
|
131
123
|
const rowsById = /* @__PURE__ */ new Map();
|
|
132
124
|
const rootRows = [];
|
|
@@ -139,7 +131,7 @@ function useOverviewTable({
|
|
|
139
131
|
parentId: folder.parentId || void 0,
|
|
140
132
|
name: folder.name || "",
|
|
141
133
|
label: folder.label || folder.name || "",
|
|
142
|
-
icon: ((_d =
|
|
134
|
+
icon: ((_d = getEntityTypeData("folder", folder.folderType)) == null ? void 0 : _d.icon) || null,
|
|
143
135
|
color: null,
|
|
144
136
|
img: null,
|
|
145
137
|
subRows: [],
|
|
@@ -149,7 +141,8 @@ function useOverviewTable({
|
|
|
149
141
|
ownAttrib: folder.ownAttrib || [],
|
|
150
142
|
path: folder.path,
|
|
151
143
|
attrib: folder.attrib || {},
|
|
152
|
-
childOnlyMatch: folder.childOnlyMatch || false
|
|
144
|
+
childOnlyMatch: folder.childOnlyMatch || false,
|
|
145
|
+
updatedAt: folder.updatedAt
|
|
153
146
|
};
|
|
154
147
|
rowsById.set(folderId, row);
|
|
155
148
|
if (!folder.parentId || !foldersMap.has(folder.parentId)) {
|
|
@@ -211,6 +204,9 @@ function useOverviewTable({
|
|
|
211
204
|
});
|
|
212
205
|
}
|
|
213
206
|
}
|
|
207
|
+
for (const row of rows || []) {
|
|
208
|
+
rootRows.push(row);
|
|
209
|
+
}
|
|
214
210
|
if (rootRows.length > 1) {
|
|
215
211
|
rootRows.sort((a, b) => {
|
|
216
212
|
if (a.name < b.name) return -1;
|
|
@@ -222,11 +218,11 @@ function useOverviewTable({
|
|
|
222
218
|
}, [
|
|
223
219
|
foldersMap,
|
|
224
220
|
tasksMap,
|
|
221
|
+
rows,
|
|
225
222
|
visibleFolders,
|
|
226
223
|
childToParentMap,
|
|
227
224
|
expandedFolderIds,
|
|
228
225
|
showHierarchy,
|
|
229
|
-
taskTypesByName,
|
|
230
226
|
loadingTasks,
|
|
231
227
|
isLoadingMore
|
|
232
228
|
]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useOverviewTable.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useOverviewTable.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport {\n EditorTaskNode,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport { ExpandedState } from '@tanstack/react-table'\nimport { generateLoadingRows } from '../utils/loadingUtils'\nconst TASKS_INFINITE_QUERY_COUNT = 100\nimport { LoadingTasks } from '../types'\nimport { FolderType, TaskType } from '../types/project'\n\ntype Params = {\n foldersMap: FolderNodeMap\n tasksMap: TaskNodeMap\n tasksByFolderMap: TasksByFolderMap\n expanded: ExpandedState\n folderTypes?: FolderType[]\n taskTypes?: TaskType[]\n showHierarchy: boolean\n loadingTasks: LoadingTasks\n isLoadingMore?: boolean\n}\n\n/**\n * React hook that creates a hierarchical tree structure from folders and tasks for use with TanStack Table\n * Uses memoization to avoid unnecessary recalculations on re-render\n *\n * @param foldersMap - Map of folders organized by folder ID\n * @param tasksMap - Map of tasks organized by task ID\n * @param tasksByFolderMap - Map of tasks organized by folder ID\n * @param expanded - Object with folder IDs as keys to indicate expanded folders\n * @param folderTypes - Array of folder types for to add things like folder icon\n * @param taskTypes - Array of task types for to add things like task icon\n * @param showHierarchy - Boolean to indicate if the hierarchy should be shown\n * @param loadingTasks - Object with folder IDs as keys to indicate loading tasks\n * @param isLoadingMore - Boolean to indicate if more tasks are being loaded\n * @returns An array of TableRow objects with nested subRows suitable for TanStack Table\n */\nexport default function useOverviewTable({\n foldersMap,\n tasksMap,\n tasksByFolderMap,\n expanded,\n folderTypes = [],\n taskTypes = [],\n showHierarchy,\n loadingTasks = {},\n isLoadingMore = false,\n}: Params): TableRow[] {\n // create a map of folder types by name for efficient lookups\n const folderTypesByName = useMemo(() => {\n const map: Map<string, FolderType> = new Map()\n for (const folderType of folderTypes) {\n map.set(folderType.name, folderType)\n }\n return map\n }, [folderTypes])\n\n // create a map of task types by name for efficient lookups\n const taskTypesByName = useMemo(() => {\n const map: Map<string, TaskType> = new Map()\n for (const taskType of taskTypes) {\n map.set(taskType.name, taskType)\n }\n return map\n }, [taskTypes])\n\n // Convert expanded object to a stable string for memoization comparison\n const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded])\n\n // Memoize expandedFolderIds set for efficient lookups\n const expandedFolderIds = useMemo(() => {\n return new Set(\n Object.entries(expanded)\n .filter(([_, isExpanded]) => isExpanded)\n .map(([id]) => id),\n )\n }, [expandedKey])\n\n // Memoize relationship maps to avoid rebuilding them on every render\n const { childToParentMap, parentToChildrenMap } = useMemo(() => {\n const childToParent = new Map<string, string>()\n const parentToChildren = new Map<string, Set<string>>()\n\n // Construct relationship maps in a single pass\n for (const folder of foldersMap.values()) {\n if (!folder.id) continue\n\n const parentId = folder.parentId\n if (parentId) {\n childToParent.set(folder.id, parentId)\n\n let children = parentToChildren.get(parentId)\n if (!children) {\n children = new Set<string>()\n parentToChildren.set(parentId, children)\n }\n children.add(folder.id)\n }\n }\n\n return { childToParentMap: childToParent, parentToChildrenMap: parentToChildren }\n }, [foldersMap])\n\n // Memoize visible folders calculation\n const visibleFolders = useMemo(() => {\n const visible = new Set<string>()\n\n // Start with root folders and folders with non-existent parents\n const queue: string[] = []\n for (const folder of foldersMap.values()) {\n if (!folder.id) continue\n\n // Include folders with no parent OR with a parent that doesn't exist\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n visible.add(folder.id)\n queue.push(folder.id)\n }\n }\n\n // Process queue to identify visible folders (BFS)\n while (queue.length > 0) {\n const folderId = queue.shift()!\n const isParentExpanded = expandedFolderIds.has(folderId)\n\n if (!isParentExpanded) continue\n\n // Add children of expanded folders to visible set\n const childrenIds = parentToChildrenMap.get(folderId)\n if (childrenIds) {\n for (const childId of childrenIds) {\n if (!visible.has(childId)) {\n visible.add(childId)\n queue.push(childId)\n }\n }\n }\n }\n\n return visible\n }, [foldersMap, parentToChildrenMap, expandedFolderIds])\n\n // Final memoized result - build the table tree\n return useMemo(() => {\n // Helper function to create a task row\n const createTaskRow = (task: EditorTaskNode, parentId?: string): TableRow => {\n return {\n id: task.id,\n entityType: 'task',\n parentId: parentId || task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: taskTypesByName.get(task.taskType)?.icon || null,\n color: taskTypesByName.get(task.taskType)?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n path: task.folder.path,\n }\n }\n\n // If showHierarchy is false, create a flat list of task rows\n if (!showHierarchy) {\n const flatTaskRows: TableRow[] = []\n\n // Loop through all tasks\n for (const task of tasksMap.values()) {\n if (!task.id) continue\n flatTaskRows.push(createTaskRow(task))\n }\n\n // Sort all tasks by name\n if (flatTaskRows.length > 1) {\n flatTaskRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n // if we are loading more tasks, add loading rows\n if (isLoadingMore) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n // number of tasks we loading with the infinite query\n const count = TASKS_INFINITE_QUERY_COUNT\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n })\n\n flatTaskRows.push(...loadingTaskRows)\n }\n }\n\n return flatTaskRows\n }\n\n // Use Map for O(1) lookups\n const rowsById = new Map<string, TableRow>()\n const rootRows: TableRow[] = []\n\n // Create minimal rows for only visible folders\n for (const folderId of visibleFolders) {\n const folder = foldersMap.get(folderId)\n if (!folder) continue\n\n // Create row with minimal required properties\n const row: TableRow = {\n id: folderId,\n entityType: 'folder',\n parentId: folder.parentId || undefined,\n name: folder.name || '',\n label: folder.label || folder.name || '',\n icon: folderTypesByName.get(folder.folderType)?.icon || null,\n color: null,\n img: null,\n subRows: [],\n status: folder.status,\n tags: folder.tags || [],\n subType: folder.folderType || null,\n ownAttrib: folder.ownAttrib || [],\n path: folder.path,\n attrib: folder.attrib || {},\n childOnlyMatch: folder.childOnlyMatch || false,\n }\n\n rowsById.set(folderId, row)\n\n // Add root rows directly to the rootRows array\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n rootRows.push(row)\n }\n\n // Process tasks immediately if folder is expanded\n if (expandedFolderIds.has(folderId)) {\n // because tasksByFolderMap is a map of tasks by folder ID\n // we can directly get the tasks for the current folder\n const folderTaskIds = tasksByFolderMap.get(folderId) || []\n const folderTasks = folderTaskIds.flatMap((taskId) => tasksMap.get(taskId) || [])\n\n if (folderTasks.length || loadingTasks[folderId]) {\n // Use array literal with known length for better performance\n const taskRows = new Array<TableRow>(folderTasks.length)\n\n // Direct array assignment is faster than push operations\n for (let i = 0; i < folderTasks.length; i++) {\n taskRows[i] = createTaskRow(folderTasks[i], folderId)\n }\n\n // Add loading rows if applicable\n if (loadingTasks[folderId]) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n const count = loadingTasks[folderId]\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n parentId: folderId,\n })\n\n taskRows.push(...loadingTaskRows)\n }\n }\n // Only sort if we have multiple items\n if (taskRows.length > 1) {\n // Use a more efficient string comparison for sorting\n taskRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n row.subRows = taskRows\n }\n }\n }\n\n // Build the folder hierarchy efficiently\n for (const folderId of visibleFolders) {\n const parentId = childToParentMap.get(folderId)\n if (!parentId || !expandedFolderIds.has(parentId)) continue\n\n const childRow = rowsById.get(folderId)\n const parentRow = rowsById.get(parentId)\n\n if (!childRow || !parentRow) continue\n\n // Add folder to its parent's subRows\n parentRow.subRows.push(childRow)\n }\n\n // Sort subRows for expanded folders in a single pass\n for (const folderId of expandedFolderIds) {\n const row = rowsById.get(folderId)\n if (!row || row.subRows.length <= 1) continue\n\n // Process only folders that have both task rows and folder children\n const hasTasksAndFolders =\n row.subRows.some((r) => r.entityType === 'task') &&\n row.subRows.some((r) => r.entityType === 'folder')\n\n if (hasTasksAndFolders) {\n // More efficient sort using type as primary key to reduce comparisons\n row.subRows.sort((a, b) => {\n // Type first (tasks before folders)\n const typeA = a.entityType === 'task' ? 0 : 1\n const typeB = b.entityType === 'task' ? 0 : 1\n\n if (typeA !== typeB) return typeA - typeB\n\n // Then by name using more efficient string comparison\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n }\n\n // Sort root rows\n if (rootRows.length > 1) {\n rootRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n return rootRows\n }, [\n foldersMap,\n tasksMap,\n visibleFolders,\n childToParentMap,\n expandedFolderIds,\n showHierarchy,\n taskTypesByName,\n loadingTasks,\n isLoadingMore,\n ])\n}\n"],"names":["useMemo","_a","_b","generateLoadingRows"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useOverviewTable.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useOverviewTable.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport {\n EditorTaskNode,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport { ExpandedState } from '@tanstack/react-table'\nimport { generateLoadingRows } from '../utils/loadingUtils'\nconst TASKS_INFINITE_QUERY_COUNT = 100\nimport { LoadingTasks } from '../types'\nimport { ProjectModel } from '../types/project'\nimport useGetEntityTypeData from './useGetEntityTypeData'\n\ntype Params = {\n foldersMap: FolderNodeMap\n tasksMap: TaskNodeMap\n tasksByFolderMap: TasksByFolderMap\n rows?: TableRow[]\n expanded: ExpandedState\n projectInfo?: ProjectModel\n showHierarchy: boolean\n loadingTasks?: LoadingTasks\n isLoadingMore?: boolean\n}\n\nexport default function useOverviewTable({\n foldersMap,\n tasksMap,\n rows,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks = {},\n isLoadingMore = false,\n}: Params): TableRow[] {\n const getEntityTypeData = useGetEntityTypeData({ projectInfo })\n\n // Convert expanded object to a stable string for memoization comparison\n const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded])\n\n // Memoize expandedFolderIds set for efficient lookups\n const expandedFolderIds = useMemo(() => {\n return new Set(\n Object.entries(expanded)\n .filter(([_, isExpanded]) => isExpanded)\n .map(([id]) => id),\n )\n }, [expandedKey])\n\n // Memoize relationship maps to avoid rebuilding them on every render\n const { childToParentMap, parentToChildrenMap } = useMemo(() => {\n const childToParent = new Map<string, string>()\n const parentToChildren = new Map<string, Set<string>>()\n\n // Construct relationship maps in a single pass\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n const parentId = folder.parentId\n if (parentId) {\n childToParent.set(folder.id, parentId)\n\n let children = parentToChildren.get(parentId)\n if (!children) {\n children = new Set<string>()\n parentToChildren.set(parentId, children)\n }\n children.add(folder.id)\n }\n }\n\n return { childToParentMap: childToParent, parentToChildrenMap: parentToChildren }\n }, [foldersMap])\n\n // Memoize visible folders calculation\n const visibleFolders = useMemo(() => {\n const visible = new Set<string>()\n\n // Start with root folders and folders with non-existent parents\n const queue: string[] = []\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n // Include folders with no parent OR with a parent that doesn't exist\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n visible.add(folder.id)\n queue.push(folder.id)\n }\n }\n\n // Process queue to identify visible folders (BFS)\n while (queue.length > 0) {\n const folderId = queue.shift()!\n const isParentExpanded = expandedFolderIds.has(folderId)\n\n if (!isParentExpanded) continue\n\n // Add children of expanded folders to visible set\n const childrenIds = parentToChildrenMap.get(folderId)\n if (childrenIds) {\n for (const childId of childrenIds) {\n if (!visible.has(childId)) {\n visible.add(childId)\n queue.push(childId)\n }\n }\n }\n }\n\n return visible\n }, [foldersMap, parentToChildrenMap, expandedFolderIds])\n\n // Final memoized result - build the table tree\n return useMemo(() => {\n // Helper function to create a task row\n const createTaskRow = (task: EditorTaskNode, parentId?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n return {\n id: task.id,\n entityType: 'task',\n parentId: parentId || task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n path: task.folder.path,\n updatedAt: task.updatedAt,\n }\n }\n\n // If showHierarchy is false, create a flat list of task rows\n if (!showHierarchy) {\n const flatRows: TableRow[] = []\n\n // Loop through all tasks\n for (const task of tasksMap.values()) {\n if (!task.id) continue\n flatRows.push(createTaskRow(task))\n }\n\n // Loop through all extra rows\n for (const row of rows || []) {\n flatRows.push(row)\n }\n\n // Sort all tasks by name\n if (flatRows.length > 1) {\n flatRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n // if we are loading more tasks, add loading rows\n if (isLoadingMore) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n // number of tasks we loading with the infinite query\n const count = TASKS_INFINITE_QUERY_COUNT\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n })\n\n flatRows.push(...loadingTaskRows)\n }\n }\n\n return flatRows\n }\n\n // Use Map for O(1) lookups\n const rowsById = new Map<string, TableRow>()\n const rootRows: TableRow[] = []\n\n // Create minimal rows for only visible folders\n for (const folderId of visibleFolders) {\n const folder = foldersMap.get(folderId)\n if (!folder) continue\n\n // Create row with minimal required properties\n const row: TableRow = {\n id: folderId,\n entityType: 'folder',\n parentId: folder.parentId || undefined,\n name: folder.name || '',\n label: folder.label || folder.name || '',\n icon: getEntityTypeData('folder', folder.folderType)?.icon || null,\n color: null,\n img: null,\n subRows: [],\n status: folder.status,\n tags: folder.tags || [],\n subType: folder.folderType || null,\n ownAttrib: folder.ownAttrib || [],\n path: folder.path,\n attrib: folder.attrib || {},\n childOnlyMatch: folder.childOnlyMatch || false,\n updatedAt: folder.updatedAt,\n }\n\n rowsById.set(folderId, row)\n\n // Add root rows directly to the rootRows array\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n rootRows.push(row)\n }\n\n // Process tasks immediately if folder is expanded\n if (expandedFolderIds.has(folderId)) {\n // because tasksByFolderMap is a map of tasks by folder ID\n // we can directly get the tasks for the current folder\n const folderTaskIds = tasksByFolderMap.get(folderId) || []\n const folderTasks = folderTaskIds.flatMap((taskId) => tasksMap.get(taskId) || [])\n\n if (folderTasks.length || loadingTasks[folderId]) {\n // Use array literal with known length for better performance\n const taskRows = new Array<TableRow>(folderTasks.length)\n\n // Direct array assignment is faster than push operations\n for (let i = 0; i < folderTasks.length; i++) {\n taskRows[i] = createTaskRow(folderTasks[i], folderId)\n }\n\n // Add loading rows if applicable\n if (loadingTasks[folderId]) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n const count = loadingTasks[folderId]\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n parentId: folderId,\n })\n\n taskRows.push(...loadingTaskRows)\n }\n }\n // Only sort if we have multiple items\n if (taskRows.length > 1) {\n // Use a more efficient string comparison for sorting\n taskRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n row.subRows = taskRows\n }\n }\n }\n\n // Build the folder hierarchy efficiently\n for (const folderId of visibleFolders) {\n const parentId = childToParentMap.get(folderId)\n if (!parentId || !expandedFolderIds.has(parentId)) continue\n\n const childRow = rowsById.get(folderId)\n const parentRow = rowsById.get(parentId)\n\n if (!childRow || !parentRow) continue\n\n // Add folder to its parent's subRows\n parentRow.subRows.push(childRow)\n }\n\n // Sort subRows for expanded folders in a single pass\n for (const folderId of expandedFolderIds) {\n const row = rowsById.get(folderId)\n if (!row || row.subRows.length <= 1) continue\n\n // Process only folders that have both task rows and folder children\n const hasTasksAndFolders =\n row.subRows.some((r) => r.entityType === 'task') &&\n row.subRows.some((r) => r.entityType === 'folder')\n\n if (hasTasksAndFolders) {\n // More efficient sort using type as primary key to reduce comparisons\n row.subRows.sort((a, b) => {\n // Type first (tasks before folders)\n const typeA = a.entityType === 'task' ? 0 : 1\n const typeB = b.entityType === 'task' ? 0 : 1\n\n if (typeA !== typeB) return typeA - typeB\n\n // Then by name using more efficient string comparison\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n }\n\n // Add any extra rows to the root rows\n for (const row of rows || []) {\n rootRows.push(row)\n }\n\n // Sort root rows\n if (rootRows.length > 1) {\n rootRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n return rootRows\n }, [\n foldersMap,\n tasksMap,\n rows,\n visibleFolders,\n childToParentMap,\n expandedFolderIds,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n ])\n}\n"],"names":["useMemo","generateLoadingRows"],"mappings":"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"}
|
|
@@ -1,31 +1,19 @@
|
|
|
1
1
|
import { useMemo } from "react";
|
|
2
2
|
import { generateLoadingRows } from "../utils/loadingUtils.es.js";
|
|
3
|
+
import useGetEntityTypeData from "./useGetEntityTypeData.es.js";
|
|
3
4
|
const TASKS_INFINITE_QUERY_COUNT = 100;
|
|
4
5
|
function useOverviewTable({
|
|
5
6
|
foldersMap,
|
|
6
7
|
tasksMap,
|
|
8
|
+
rows,
|
|
7
9
|
tasksByFolderMap,
|
|
8
10
|
expanded,
|
|
9
|
-
|
|
10
|
-
taskTypes = [],
|
|
11
|
+
projectInfo,
|
|
11
12
|
showHierarchy,
|
|
12
13
|
loadingTasks = {},
|
|
13
14
|
isLoadingMore = false
|
|
14
15
|
}) {
|
|
15
|
-
const
|
|
16
|
-
const map = /* @__PURE__ */ new Map();
|
|
17
|
-
for (const folderType of folderTypes) {
|
|
18
|
-
map.set(folderType.name, folderType);
|
|
19
|
-
}
|
|
20
|
-
return map;
|
|
21
|
-
}, [folderTypes]);
|
|
22
|
-
const taskTypesByName = useMemo(() => {
|
|
23
|
-
const map = /* @__PURE__ */ new Map();
|
|
24
|
-
for (const taskType of taskTypes) {
|
|
25
|
-
map.set(taskType.name, taskType);
|
|
26
|
-
}
|
|
27
|
-
return map;
|
|
28
|
-
}, [taskTypes]);
|
|
16
|
+
const getEntityTypeData = useGetEntityTypeData({ projectInfo });
|
|
29
17
|
const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded]);
|
|
30
18
|
const expandedFolderIds = useMemo(() => {
|
|
31
19
|
return new Set(
|
|
@@ -36,7 +24,7 @@ function useOverviewTable({
|
|
|
36
24
|
const childToParent = /* @__PURE__ */ new Map();
|
|
37
25
|
const parentToChildren = /* @__PURE__ */ new Map();
|
|
38
26
|
for (const folder of foldersMap.values()) {
|
|
39
|
-
if (!folder.id) continue;
|
|
27
|
+
if (!(folder == null ? void 0 : folder.id)) continue;
|
|
40
28
|
const parentId = folder.parentId;
|
|
41
29
|
if (parentId) {
|
|
42
30
|
childToParent.set(folder.id, parentId);
|
|
@@ -54,7 +42,7 @@ function useOverviewTable({
|
|
|
54
42
|
const visible = /* @__PURE__ */ new Set();
|
|
55
43
|
const queue = [];
|
|
56
44
|
for (const folder of foldersMap.values()) {
|
|
57
|
-
if (!folder.id) continue;
|
|
45
|
+
if (!(folder == null ? void 0 : folder.id)) continue;
|
|
58
46
|
if (!folder.parentId || !foldersMap.has(folder.parentId)) {
|
|
59
47
|
visible.add(folder.id);
|
|
60
48
|
queue.push(folder.id);
|
|
@@ -79,15 +67,15 @@ function useOverviewTable({
|
|
|
79
67
|
return useMemo(() => {
|
|
80
68
|
var _a, _b, _c, _d, _e, _f, _g;
|
|
81
69
|
const createTaskRow = (task, parentId) => {
|
|
82
|
-
|
|
70
|
+
const typeData = getEntityTypeData("task", task.taskType);
|
|
83
71
|
return {
|
|
84
72
|
id: task.id,
|
|
85
73
|
entityType: "task",
|
|
86
74
|
parentId: parentId || task.folderId,
|
|
87
75
|
name: task.name || "",
|
|
88
76
|
label: task.label || task.name || "",
|
|
89
|
-
icon: (
|
|
90
|
-
color: (
|
|
77
|
+
icon: (typeData == null ? void 0 : typeData.icon) || null,
|
|
78
|
+
color: (typeData == null ? void 0 : typeData.color) || null,
|
|
91
79
|
status: task.status,
|
|
92
80
|
assignees: task.assignees,
|
|
93
81
|
tags: task.tags,
|
|
@@ -96,17 +84,21 @@ function useOverviewTable({
|
|
|
96
84
|
subType: task.taskType || null,
|
|
97
85
|
attrib: task.attrib,
|
|
98
86
|
ownAttrib: task.ownAttrib,
|
|
99
|
-
path: task.folder.path
|
|
87
|
+
path: task.folder.path,
|
|
88
|
+
updatedAt: task.updatedAt
|
|
100
89
|
};
|
|
101
90
|
};
|
|
102
91
|
if (!showHierarchy) {
|
|
103
|
-
const
|
|
92
|
+
const flatRows = [];
|
|
104
93
|
for (const task of tasksMap.values()) {
|
|
105
94
|
if (!task.id) continue;
|
|
106
|
-
|
|
95
|
+
flatRows.push(createTaskRow(task));
|
|
107
96
|
}
|
|
108
|
-
|
|
109
|
-
|
|
97
|
+
for (const row of rows || []) {
|
|
98
|
+
flatRows.push(row);
|
|
99
|
+
}
|
|
100
|
+
if (flatRows.length > 1) {
|
|
101
|
+
flatRows.sort((a, b) => {
|
|
110
102
|
if (a.name < b.name) return -1;
|
|
111
103
|
if (a.name > b.name) return 1;
|
|
112
104
|
return 0;
|
|
@@ -122,10 +114,10 @@ function useOverviewTable({
|
|
|
122
114
|
const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {
|
|
123
115
|
type: "task"
|
|
124
116
|
});
|
|
125
|
-
|
|
117
|
+
flatRows.push(...loadingTaskRows);
|
|
126
118
|
}
|
|
127
119
|
}
|
|
128
|
-
return
|
|
120
|
+
return flatRows;
|
|
129
121
|
}
|
|
130
122
|
const rowsById = /* @__PURE__ */ new Map();
|
|
131
123
|
const rootRows = [];
|
|
@@ -138,7 +130,7 @@ function useOverviewTable({
|
|
|
138
130
|
parentId: folder.parentId || void 0,
|
|
139
131
|
name: folder.name || "",
|
|
140
132
|
label: folder.label || folder.name || "",
|
|
141
|
-
icon: ((_d =
|
|
133
|
+
icon: ((_d = getEntityTypeData("folder", folder.folderType)) == null ? void 0 : _d.icon) || null,
|
|
142
134
|
color: null,
|
|
143
135
|
img: null,
|
|
144
136
|
subRows: [],
|
|
@@ -148,7 +140,8 @@ function useOverviewTable({
|
|
|
148
140
|
ownAttrib: folder.ownAttrib || [],
|
|
149
141
|
path: folder.path,
|
|
150
142
|
attrib: folder.attrib || {},
|
|
151
|
-
childOnlyMatch: folder.childOnlyMatch || false
|
|
143
|
+
childOnlyMatch: folder.childOnlyMatch || false,
|
|
144
|
+
updatedAt: folder.updatedAt
|
|
152
145
|
};
|
|
153
146
|
rowsById.set(folderId, row);
|
|
154
147
|
if (!folder.parentId || !foldersMap.has(folder.parentId)) {
|
|
@@ -210,6 +203,9 @@ function useOverviewTable({
|
|
|
210
203
|
});
|
|
211
204
|
}
|
|
212
205
|
}
|
|
206
|
+
for (const row of rows || []) {
|
|
207
|
+
rootRows.push(row);
|
|
208
|
+
}
|
|
213
209
|
if (rootRows.length > 1) {
|
|
214
210
|
rootRows.sort((a, b) => {
|
|
215
211
|
if (a.name < b.name) return -1;
|
|
@@ -221,11 +217,11 @@ function useOverviewTable({
|
|
|
221
217
|
}, [
|
|
222
218
|
foldersMap,
|
|
223
219
|
tasksMap,
|
|
220
|
+
rows,
|
|
224
221
|
visibleFolders,
|
|
225
222
|
childToParentMap,
|
|
226
223
|
expandedFolderIds,
|
|
227
224
|
showHierarchy,
|
|
228
|
-
taskTypesByName,
|
|
229
225
|
loadingTasks,
|
|
230
226
|
isLoadingMore
|
|
231
227
|
]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useOverviewTable.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useOverviewTable.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport {\n EditorTaskNode,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport { ExpandedState } from '@tanstack/react-table'\nimport { generateLoadingRows } from '../utils/loadingUtils'\nconst TASKS_INFINITE_QUERY_COUNT = 100\nimport { LoadingTasks } from '../types'\nimport { FolderType, TaskType } from '../types/project'\n\ntype Params = {\n foldersMap: FolderNodeMap\n tasksMap: TaskNodeMap\n tasksByFolderMap: TasksByFolderMap\n expanded: ExpandedState\n folderTypes?: FolderType[]\n taskTypes?: TaskType[]\n showHierarchy: boolean\n loadingTasks: LoadingTasks\n isLoadingMore?: boolean\n}\n\n/**\n * React hook that creates a hierarchical tree structure from folders and tasks for use with TanStack Table\n * Uses memoization to avoid unnecessary recalculations on re-render\n *\n * @param foldersMap - Map of folders organized by folder ID\n * @param tasksMap - Map of tasks organized by task ID\n * @param tasksByFolderMap - Map of tasks organized by folder ID\n * @param expanded - Object with folder IDs as keys to indicate expanded folders\n * @param folderTypes - Array of folder types for to add things like folder icon\n * @param taskTypes - Array of task types for to add things like task icon\n * @param showHierarchy - Boolean to indicate if the hierarchy should be shown\n * @param loadingTasks - Object with folder IDs as keys to indicate loading tasks\n * @param isLoadingMore - Boolean to indicate if more tasks are being loaded\n * @returns An array of TableRow objects with nested subRows suitable for TanStack Table\n */\nexport default function useOverviewTable({\n foldersMap,\n tasksMap,\n tasksByFolderMap,\n expanded,\n folderTypes = [],\n taskTypes = [],\n showHierarchy,\n loadingTasks = {},\n isLoadingMore = false,\n}: Params): TableRow[] {\n // create a map of folder types by name for efficient lookups\n const folderTypesByName = useMemo(() => {\n const map: Map<string, FolderType> = new Map()\n for (const folderType of folderTypes) {\n map.set(folderType.name, folderType)\n }\n return map\n }, [folderTypes])\n\n // create a map of task types by name for efficient lookups\n const taskTypesByName = useMemo(() => {\n const map: Map<string, TaskType> = new Map()\n for (const taskType of taskTypes) {\n map.set(taskType.name, taskType)\n }\n return map\n }, [taskTypes])\n\n // Convert expanded object to a stable string for memoization comparison\n const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded])\n\n // Memoize expandedFolderIds set for efficient lookups\n const expandedFolderIds = useMemo(() => {\n return new Set(\n Object.entries(expanded)\n .filter(([_, isExpanded]) => isExpanded)\n .map(([id]) => id),\n )\n }, [expandedKey])\n\n // Memoize relationship maps to avoid rebuilding them on every render\n const { childToParentMap, parentToChildrenMap } = useMemo(() => {\n const childToParent = new Map<string, string>()\n const parentToChildren = new Map<string, Set<string>>()\n\n // Construct relationship maps in a single pass\n for (const folder of foldersMap.values()) {\n if (!folder.id) continue\n\n const parentId = folder.parentId\n if (parentId) {\n childToParent.set(folder.id, parentId)\n\n let children = parentToChildren.get(parentId)\n if (!children) {\n children = new Set<string>()\n parentToChildren.set(parentId, children)\n }\n children.add(folder.id)\n }\n }\n\n return { childToParentMap: childToParent, parentToChildrenMap: parentToChildren }\n }, [foldersMap])\n\n // Memoize visible folders calculation\n const visibleFolders = useMemo(() => {\n const visible = new Set<string>()\n\n // Start with root folders and folders with non-existent parents\n const queue: string[] = []\n for (const folder of foldersMap.values()) {\n if (!folder.id) continue\n\n // Include folders with no parent OR with a parent that doesn't exist\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n visible.add(folder.id)\n queue.push(folder.id)\n }\n }\n\n // Process queue to identify visible folders (BFS)\n while (queue.length > 0) {\n const folderId = queue.shift()!\n const isParentExpanded = expandedFolderIds.has(folderId)\n\n if (!isParentExpanded) continue\n\n // Add children of expanded folders to visible set\n const childrenIds = parentToChildrenMap.get(folderId)\n if (childrenIds) {\n for (const childId of childrenIds) {\n if (!visible.has(childId)) {\n visible.add(childId)\n queue.push(childId)\n }\n }\n }\n }\n\n return visible\n }, [foldersMap, parentToChildrenMap, expandedFolderIds])\n\n // Final memoized result - build the table tree\n return useMemo(() => {\n // Helper function to create a task row\n const createTaskRow = (task: EditorTaskNode, parentId?: string): TableRow => {\n return {\n id: task.id,\n entityType: 'task',\n parentId: parentId || task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: taskTypesByName.get(task.taskType)?.icon || null,\n color: taskTypesByName.get(task.taskType)?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n path: task.folder.path,\n }\n }\n\n // If showHierarchy is false, create a flat list of task rows\n if (!showHierarchy) {\n const flatTaskRows: TableRow[] = []\n\n // Loop through all tasks\n for (const task of tasksMap.values()) {\n if (!task.id) continue\n flatTaskRows.push(createTaskRow(task))\n }\n\n // Sort all tasks by name\n if (flatTaskRows.length > 1) {\n flatTaskRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n // if we are loading more tasks, add loading rows\n if (isLoadingMore) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n // number of tasks we loading with the infinite query\n const count = TASKS_INFINITE_QUERY_COUNT\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n })\n\n flatTaskRows.push(...loadingTaskRows)\n }\n }\n\n return flatTaskRows\n }\n\n // Use Map for O(1) lookups\n const rowsById = new Map<string, TableRow>()\n const rootRows: TableRow[] = []\n\n // Create minimal rows for only visible folders\n for (const folderId of visibleFolders) {\n const folder = foldersMap.get(folderId)\n if (!folder) continue\n\n // Create row with minimal required properties\n const row: TableRow = {\n id: folderId,\n entityType: 'folder',\n parentId: folder.parentId || undefined,\n name: folder.name || '',\n label: folder.label || folder.name || '',\n icon: folderTypesByName.get(folder.folderType)?.icon || null,\n color: null,\n img: null,\n subRows: [],\n status: folder.status,\n tags: folder.tags || [],\n subType: folder.folderType || null,\n ownAttrib: folder.ownAttrib || [],\n path: folder.path,\n attrib: folder.attrib || {},\n childOnlyMatch: folder.childOnlyMatch || false,\n }\n\n rowsById.set(folderId, row)\n\n // Add root rows directly to the rootRows array\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n rootRows.push(row)\n }\n\n // Process tasks immediately if folder is expanded\n if (expandedFolderIds.has(folderId)) {\n // because tasksByFolderMap is a map of tasks by folder ID\n // we can directly get the tasks for the current folder\n const folderTaskIds = tasksByFolderMap.get(folderId) || []\n const folderTasks = folderTaskIds.flatMap((taskId) => tasksMap.get(taskId) || [])\n\n if (folderTasks.length || loadingTasks[folderId]) {\n // Use array literal with known length for better performance\n const taskRows = new Array<TableRow>(folderTasks.length)\n\n // Direct array assignment is faster than push operations\n for (let i = 0; i < folderTasks.length; i++) {\n taskRows[i] = createTaskRow(folderTasks[i], folderId)\n }\n\n // Add loading rows if applicable\n if (loadingTasks[folderId]) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n const count = loadingTasks[folderId]\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n parentId: folderId,\n })\n\n taskRows.push(...loadingTaskRows)\n }\n }\n // Only sort if we have multiple items\n if (taskRows.length > 1) {\n // Use a more efficient string comparison for sorting\n taskRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n row.subRows = taskRows\n }\n }\n }\n\n // Build the folder hierarchy efficiently\n for (const folderId of visibleFolders) {\n const parentId = childToParentMap.get(folderId)\n if (!parentId || !expandedFolderIds.has(parentId)) continue\n\n const childRow = rowsById.get(folderId)\n const parentRow = rowsById.get(parentId)\n\n if (!childRow || !parentRow) continue\n\n // Add folder to its parent's subRows\n parentRow.subRows.push(childRow)\n }\n\n // Sort subRows for expanded folders in a single pass\n for (const folderId of expandedFolderIds) {\n const row = rowsById.get(folderId)\n if (!row || row.subRows.length <= 1) continue\n\n // Process only folders that have both task rows and folder children\n const hasTasksAndFolders =\n row.subRows.some((r) => r.entityType === 'task') &&\n row.subRows.some((r) => r.entityType === 'folder')\n\n if (hasTasksAndFolders) {\n // More efficient sort using type as primary key to reduce comparisons\n row.subRows.sort((a, b) => {\n // Type first (tasks before folders)\n const typeA = a.entityType === 'task' ? 0 : 1\n const typeB = b.entityType === 'task' ? 0 : 1\n\n if (typeA !== typeB) return typeA - typeB\n\n // Then by name using more efficient string comparison\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n }\n\n // Sort root rows\n if (rootRows.length > 1) {\n rootRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n return rootRows\n }, [\n foldersMap,\n tasksMap,\n visibleFolders,\n childToParentMap,\n expandedFolderIds,\n showHierarchy,\n taskTypesByName,\n loadingTasks,\n isLoadingMore,\n ])\n}\n"],"names":["_a","_b"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useOverviewTable.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useOverviewTable.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport {\n EditorTaskNode,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport { ExpandedState } from '@tanstack/react-table'\nimport { generateLoadingRows } from '../utils/loadingUtils'\nconst TASKS_INFINITE_QUERY_COUNT = 100\nimport { LoadingTasks } from '../types'\nimport { ProjectModel } from '../types/project'\nimport useGetEntityTypeData from './useGetEntityTypeData'\n\ntype Params = {\n foldersMap: FolderNodeMap\n tasksMap: TaskNodeMap\n tasksByFolderMap: TasksByFolderMap\n rows?: TableRow[]\n expanded: ExpandedState\n projectInfo?: ProjectModel\n showHierarchy: boolean\n loadingTasks?: LoadingTasks\n isLoadingMore?: boolean\n}\n\nexport default function useOverviewTable({\n foldersMap,\n tasksMap,\n rows,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks = {},\n isLoadingMore = false,\n}: Params): TableRow[] {\n const getEntityTypeData = useGetEntityTypeData({ projectInfo })\n\n // Convert expanded object to a stable string for memoization comparison\n const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded])\n\n // Memoize expandedFolderIds set for efficient lookups\n const expandedFolderIds = useMemo(() => {\n return new Set(\n Object.entries(expanded)\n .filter(([_, isExpanded]) => isExpanded)\n .map(([id]) => id),\n )\n }, [expandedKey])\n\n // Memoize relationship maps to avoid rebuilding them on every render\n const { childToParentMap, parentToChildrenMap } = useMemo(() => {\n const childToParent = new Map<string, string>()\n const parentToChildren = new Map<string, Set<string>>()\n\n // Construct relationship maps in a single pass\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n const parentId = folder.parentId\n if (parentId) {\n childToParent.set(folder.id, parentId)\n\n let children = parentToChildren.get(parentId)\n if (!children) {\n children = new Set<string>()\n parentToChildren.set(parentId, children)\n }\n children.add(folder.id)\n }\n }\n\n return { childToParentMap: childToParent, parentToChildrenMap: parentToChildren }\n }, [foldersMap])\n\n // Memoize visible folders calculation\n const visibleFolders = useMemo(() => {\n const visible = new Set<string>()\n\n // Start with root folders and folders with non-existent parents\n const queue: string[] = []\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n // Include folders with no parent OR with a parent that doesn't exist\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n visible.add(folder.id)\n queue.push(folder.id)\n }\n }\n\n // Process queue to identify visible folders (BFS)\n while (queue.length > 0) {\n const folderId = queue.shift()!\n const isParentExpanded = expandedFolderIds.has(folderId)\n\n if (!isParentExpanded) continue\n\n // Add children of expanded folders to visible set\n const childrenIds = parentToChildrenMap.get(folderId)\n if (childrenIds) {\n for (const childId of childrenIds) {\n if (!visible.has(childId)) {\n visible.add(childId)\n queue.push(childId)\n }\n }\n }\n }\n\n return visible\n }, [foldersMap, parentToChildrenMap, expandedFolderIds])\n\n // Final memoized result - build the table tree\n return useMemo(() => {\n // Helper function to create a task row\n const createTaskRow = (task: EditorTaskNode, parentId?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n return {\n id: task.id,\n entityType: 'task',\n parentId: parentId || task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n path: task.folder.path,\n updatedAt: task.updatedAt,\n }\n }\n\n // If showHierarchy is false, create a flat list of task rows\n if (!showHierarchy) {\n const flatRows: TableRow[] = []\n\n // Loop through all tasks\n for (const task of tasksMap.values()) {\n if (!task.id) continue\n flatRows.push(createTaskRow(task))\n }\n\n // Loop through all extra rows\n for (const row of rows || []) {\n flatRows.push(row)\n }\n\n // Sort all tasks by name\n if (flatRows.length > 1) {\n flatRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n // if we are loading more tasks, add loading rows\n if (isLoadingMore) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n // number of tasks we loading with the infinite query\n const count = TASKS_INFINITE_QUERY_COUNT\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n })\n\n flatRows.push(...loadingTaskRows)\n }\n }\n\n return flatRows\n }\n\n // Use Map for O(1) lookups\n const rowsById = new Map<string, TableRow>()\n const rootRows: TableRow[] = []\n\n // Create minimal rows for only visible folders\n for (const folderId of visibleFolders) {\n const folder = foldersMap.get(folderId)\n if (!folder) continue\n\n // Create row with minimal required properties\n const row: TableRow = {\n id: folderId,\n entityType: 'folder',\n parentId: folder.parentId || undefined,\n name: folder.name || '',\n label: folder.label || folder.name || '',\n icon: getEntityTypeData('folder', folder.folderType)?.icon || null,\n color: null,\n img: null,\n subRows: [],\n status: folder.status,\n tags: folder.tags || [],\n subType: folder.folderType || null,\n ownAttrib: folder.ownAttrib || [],\n path: folder.path,\n attrib: folder.attrib || {},\n childOnlyMatch: folder.childOnlyMatch || false,\n updatedAt: folder.updatedAt,\n }\n\n rowsById.set(folderId, row)\n\n // Add root rows directly to the rootRows array\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n rootRows.push(row)\n }\n\n // Process tasks immediately if folder is expanded\n if (expandedFolderIds.has(folderId)) {\n // because tasksByFolderMap is a map of tasks by folder ID\n // we can directly get the tasks for the current folder\n const folderTaskIds = tasksByFolderMap.get(folderId) || []\n const folderTasks = folderTaskIds.flatMap((taskId) => tasksMap.get(taskId) || [])\n\n if (folderTasks.length || loadingTasks[folderId]) {\n // Use array literal with known length for better performance\n const taskRows = new Array<TableRow>(folderTasks.length)\n\n // Direct array assignment is faster than push operations\n for (let i = 0; i < folderTasks.length; i++) {\n taskRows[i] = createTaskRow(folderTasks[i], folderId)\n }\n\n // Add loading rows if applicable\n if (loadingTasks[folderId]) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n const count = loadingTasks[folderId]\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n parentId: folderId,\n })\n\n taskRows.push(...loadingTaskRows)\n }\n }\n // Only sort if we have multiple items\n if (taskRows.length > 1) {\n // Use a more efficient string comparison for sorting\n taskRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n row.subRows = taskRows\n }\n }\n }\n\n // Build the folder hierarchy efficiently\n for (const folderId of visibleFolders) {\n const parentId = childToParentMap.get(folderId)\n if (!parentId || !expandedFolderIds.has(parentId)) continue\n\n const childRow = rowsById.get(folderId)\n const parentRow = rowsById.get(parentId)\n\n if (!childRow || !parentRow) continue\n\n // Add folder to its parent's subRows\n parentRow.subRows.push(childRow)\n }\n\n // Sort subRows for expanded folders in a single pass\n for (const folderId of expandedFolderIds) {\n const row = rowsById.get(folderId)\n if (!row || row.subRows.length <= 1) continue\n\n // Process only folders that have both task rows and folder children\n const hasTasksAndFolders =\n row.subRows.some((r) => r.entityType === 'task') &&\n row.subRows.some((r) => r.entityType === 'folder')\n\n if (hasTasksAndFolders) {\n // More efficient sort using type as primary key to reduce comparisons\n row.subRows.sort((a, b) => {\n // Type first (tasks before folders)\n const typeA = a.entityType === 'task' ? 0 : 1\n const typeB = b.entityType === 'task' ? 0 : 1\n\n if (typeA !== typeB) return typeA - typeB\n\n // Then by name using more efficient string comparison\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n }\n\n // Add any extra rows to the root rows\n for (const row of rows || []) {\n rootRows.push(row)\n }\n\n // Sort root rows\n if (rootRows.length > 1) {\n rootRows.sort((a, b) => {\n if (a.name < b.name) return -1\n if (a.name > b.name) return 1\n return 0\n })\n }\n\n return rootRows\n }, [\n foldersMap,\n tasksMap,\n rows,\n visibleFolders,\n childToParentMap,\n expandedFolderIds,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n ])\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ const reactToastify = require("react-toastify");
|
|
|
3
3
|
const ProjectTableQueriesContext = require("../context/ProjectTableQueriesContext.cjs.js");
|
|
4
4
|
const React = require("react");
|
|
5
5
|
const ProjectTableContext = require("../context/ProjectTableContext.cjs.js");
|
|
6
|
-
const
|
|
6
|
+
const useUpdateTableData = (props) => {
|
|
7
7
|
const { pushHistory } = props || {};
|
|
8
8
|
const {
|
|
9
9
|
getEntityById,
|
|
@@ -21,14 +21,16 @@ const useUpdateOverview = (props) => {
|
|
|
21
21
|
}
|
|
22
22
|
if (pushHistory && pushToHistory) {
|
|
23
23
|
const inverseEntities = entities.map(
|
|
24
|
-
({ id, type, field, isAttrib }) => {
|
|
24
|
+
({ rowId, id, type, field, isAttrib, meta }) => {
|
|
25
25
|
var _a2;
|
|
26
26
|
const entityData = getEntityById(id);
|
|
27
|
+
const entityId = (entityData == null ? void 0 : entityData.entityId) || id;
|
|
27
28
|
const oldValue = isAttrib ? ((_a2 = entityData.attrib) == null ? void 0 : _a2[field]) ?? null : entityData[field] ?? null;
|
|
28
29
|
const ownAttrib = (entityData == null ? void 0 : entityData.ownAttrib) || [];
|
|
29
30
|
const wasInherited = isAttrib && !ownAttrib.includes(field);
|
|
30
31
|
return {
|
|
31
|
-
|
|
32
|
+
rowId,
|
|
33
|
+
id: entityId,
|
|
32
34
|
type,
|
|
33
35
|
field,
|
|
34
36
|
value: oldValue,
|
|
@@ -36,38 +38,48 @@ const useUpdateOverview = (props) => {
|
|
|
36
38
|
wasInherited,
|
|
37
39
|
// Track inheritance status for undo
|
|
38
40
|
ownAttrib,
|
|
39
|
-
folderId: entityData == null ? void 0 : entityData.folderId
|
|
41
|
+
folderId: entityData == null ? void 0 : entityData.folderId,
|
|
42
|
+
meta
|
|
40
43
|
};
|
|
41
44
|
}
|
|
42
45
|
);
|
|
43
46
|
const historyEntities = entities.flatMap(
|
|
44
|
-
({ id, type, field, value, isAttrib }) => {
|
|
47
|
+
({ rowId, id, type, field, value, isAttrib, meta }) => {
|
|
45
48
|
const entityData = getEntityById(id);
|
|
49
|
+
const entityId = (entityData == null ? void 0 : entityData.entityId) || id;
|
|
46
50
|
if (!entityData) return [];
|
|
47
51
|
return {
|
|
48
|
-
|
|
52
|
+
rowId,
|
|
53
|
+
id: entityId,
|
|
49
54
|
type,
|
|
50
55
|
field,
|
|
51
56
|
value,
|
|
52
57
|
isAttrib,
|
|
53
58
|
ownAttrib: (entityData == null ? void 0 : entityData.ownAttrib) || [],
|
|
54
|
-
folderId: "folderId" in entityData ? entityData.folderId : entityData == null ? void 0 : entityData.parentId
|
|
59
|
+
folderId: "folderId" in entityData ? entityData.folderId : entityData == null ? void 0 : entityData.parentId,
|
|
60
|
+
meta
|
|
55
61
|
};
|
|
56
62
|
}
|
|
57
63
|
);
|
|
58
64
|
pushHistory(inverseEntities, historyEntities);
|
|
59
65
|
}
|
|
60
|
-
const supportedEntityTypes = [
|
|
66
|
+
const supportedEntityTypes = [
|
|
67
|
+
"task",
|
|
68
|
+
"folder",
|
|
69
|
+
"product",
|
|
70
|
+
"version"
|
|
71
|
+
];
|
|
61
72
|
let operations = [];
|
|
62
73
|
for (const entity of entities) {
|
|
63
|
-
let { id, type, field, value, isAttrib } = entity;
|
|
74
|
+
let { id, type, field, value, isAttrib, meta } = entity;
|
|
75
|
+
const entityData = getEntityById(id);
|
|
76
|
+
const entityId = (entityData == null ? void 0 : entityData.entityId) || id;
|
|
64
77
|
let entityType = type;
|
|
65
78
|
if (!supportedEntityTypes.includes(entityType)) {
|
|
66
79
|
continue;
|
|
67
80
|
}
|
|
68
81
|
const data = isAttrib ? { attrib: { [field]: value } } : { [field]: value };
|
|
69
82
|
if (isAttrib) {
|
|
70
|
-
const entityData = getEntityById(id);
|
|
71
83
|
const ownAttrib = [...(entityData == null ? void 0 : entityData.ownAttrib) || []];
|
|
72
84
|
if (!ownAttrib.includes(field)) {
|
|
73
85
|
ownAttrib.push(field);
|
|
@@ -75,7 +87,7 @@ const useUpdateOverview = (props) => {
|
|
|
75
87
|
data.ownAttrib = ownAttrib;
|
|
76
88
|
}
|
|
77
89
|
const existingOperationIndex = operations.findIndex(
|
|
78
|
-
(op) => op.entityId ===
|
|
90
|
+
(op) => op.entityId === entityId && op.entityType === entityType
|
|
79
91
|
);
|
|
80
92
|
if (existingOperationIndex !== -1) {
|
|
81
93
|
const existingOperation = operations[existingOperationIndex];
|
|
@@ -89,10 +101,12 @@ const useUpdateOverview = (props) => {
|
|
|
89
101
|
};
|
|
90
102
|
} else {
|
|
91
103
|
operations.push({
|
|
104
|
+
rowId: entity.rowId,
|
|
92
105
|
entityType,
|
|
93
|
-
entityId
|
|
106
|
+
entityId,
|
|
94
107
|
type: "update",
|
|
95
|
-
data
|
|
108
|
+
data,
|
|
109
|
+
meta
|
|
96
110
|
});
|
|
97
111
|
}
|
|
98
112
|
}
|
|
@@ -118,10 +132,18 @@ const useUpdateOverview = (props) => {
|
|
|
118
132
|
patchOperations: inheritedDependentsOperations
|
|
119
133
|
});
|
|
120
134
|
} catch (error) {
|
|
121
|
-
|
|
135
|
+
console.error("Error updating entities:", error);
|
|
136
|
+
reactToastify.toast.error("Failed to update entities: " + (error == null ? void 0 : error.error));
|
|
122
137
|
}
|
|
123
138
|
},
|
|
124
|
-
[
|
|
139
|
+
[
|
|
140
|
+
projectName,
|
|
141
|
+
updateEntities,
|
|
142
|
+
//
|
|
143
|
+
getEntityById,
|
|
144
|
+
getInheritedDependents,
|
|
145
|
+
pushHistory
|
|
146
|
+
]
|
|
125
147
|
);
|
|
126
148
|
const inheritFromParent = React.useCallback(
|
|
127
149
|
async (entities, pushToHistory = true) => {
|
|
@@ -136,6 +158,7 @@ const useUpdateOverview = (props) => {
|
|
|
136
158
|
for (const attrib of entity.attribs) {
|
|
137
159
|
if ((entityData == null ? void 0 : entityData.attrib) && attrib in entityData.attrib) {
|
|
138
160
|
undoEntities.push({
|
|
161
|
+
rowId: entity.rowId,
|
|
139
162
|
id: entity.entityId,
|
|
140
163
|
type: entity.entityType,
|
|
141
164
|
field: attrib,
|
|
@@ -144,13 +167,15 @@ const useUpdateOverview = (props) => {
|
|
|
144
167
|
wasInherited: false,
|
|
145
168
|
// Mark as not inherited
|
|
146
169
|
ownAttrib: (entityData == null ? void 0 : entityData.ownAttrib) || [],
|
|
147
|
-
folderId: entityData == null ? void 0 : entityData.folderId
|
|
170
|
+
folderId: entityData == null ? void 0 : entityData.folderId,
|
|
171
|
+
meta: entityData.meta
|
|
148
172
|
});
|
|
149
173
|
}
|
|
150
174
|
}
|
|
151
175
|
}
|
|
152
176
|
const redoEntities = entities.flatMap(
|
|
153
177
|
(entity) => entity.attribs.map((attrib) => ({
|
|
178
|
+
rowId: entity.rowId,
|
|
154
179
|
id: entity.entityId,
|
|
155
180
|
type: entity.entityType,
|
|
156
181
|
field: attrib,
|
|
@@ -159,7 +184,8 @@ const useUpdateOverview = (props) => {
|
|
|
159
184
|
wasInherited: true,
|
|
160
185
|
// Mark as inherited
|
|
161
186
|
ownAttrib: entity.ownAttrib,
|
|
162
|
-
folderId: entity.folderId
|
|
187
|
+
folderId: entity.folderId,
|
|
188
|
+
meta: entity.meta
|
|
163
189
|
}))
|
|
164
190
|
);
|
|
165
191
|
if (undoEntities.length > 0) {
|
|
@@ -180,12 +206,14 @@ const useUpdateOverview = (props) => {
|
|
|
180
206
|
attribData[attrib] = null;
|
|
181
207
|
});
|
|
182
208
|
operations.push({
|
|
209
|
+
rowId: entity.rowId,
|
|
183
210
|
entityType,
|
|
184
211
|
entityId: entity.entityId,
|
|
185
212
|
type: "update",
|
|
186
213
|
data: {
|
|
187
214
|
attrib: attribData
|
|
188
|
-
}
|
|
215
|
+
},
|
|
216
|
+
meta: entity.meta
|
|
189
217
|
});
|
|
190
218
|
const findTopFolder = () => {
|
|
191
219
|
const folderId = entity.folderId;
|
|
@@ -291,5 +319,5 @@ const useUpdateOverview = (props) => {
|
|
|
291
319
|
);
|
|
292
320
|
return { updateEntities: handleUpdateEntities, inheritFromParent };
|
|
293
321
|
};
|
|
294
|
-
module.exports =
|
|
295
|
-
//# sourceMappingURL=
|
|
322
|
+
module.exports = useUpdateTableData;
|
|
323
|
+
//# sourceMappingURL=useUpdateTableData.cjs.js.map
|