@ynput/ayon-frontend-shared 0.2.18 → 0.2.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/DetailsPanel.cjs.js +6 -6
- package/dist/DetailsPanel.es.js +7 -7
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/ProjectTreeTable.cjs.js +6 -0
- package/dist/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/ProjectTreeTable.es.js +6 -0
- package/dist/ProjectTreeTable.es.js.map +1 -1
- package/dist/api.cjs.js +6 -0
- package/dist/api.cjs.js.map +1 -1
- package/dist/api.es.js +10 -4
- package/dist/index.cjs.js +6 -5
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +6 -5
- package/dist/index.es.js.map +1 -1
- package/dist/shared/src/api/generated/folders.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/folders.es.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.cjs.js +38 -0
- package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.es.js +38 -0
- package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
- package/dist/shared/src/api/queries/actions/getActions.cjs.js +9 -1
- package/dist/shared/src/api/queries/actions/getActions.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/actions/getActions.es.js +9 -1
- package/dist/shared/src/api/queries/actions/getActions.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js +2 -1
- package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/getEntityPanel.es.js +2 -1
- package/dist/shared/src/api/queries/entities/getEntityPanel.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +12 -8
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +12 -8
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +67 -0
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.es.js +68 -1
- package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +19 -3
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js +19 -3
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +13 -0
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.es.js +13 -0
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.cjs.js +2 -0
- package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.es.js +2 -0
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/api/queries/versions/updateVersions.cjs.js +3 -1
- package/dist/shared/src/api/queries/versions/updateVersions.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/versions/updateVersions.es.js +3 -1
- package/dist/shared/src/api/queries/versions/updateVersions.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js +5 -5
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js +5 -5
- 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.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +2 -2
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +2 -2
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +15 -14
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +15 -14
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
- package/dist/shared/src/components/PlayableIcon/PlayableIcon.cjs.js +43 -0
- package/dist/shared/src/components/PlayableIcon/PlayableIcon.cjs.js.map +1 -0
- package/dist/shared/src/components/PlayableIcon/PlayableIcon.es.js +43 -0
- package/dist/shared/src/components/PlayableIcon/PlayableIcon.es.js.map +1 -0
- package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +15 -15
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +15 -15
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +6 -5
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +6 -5
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +6 -5
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +6 -5
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +6 -5
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +6 -5
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js +2 -2
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js +2 -2
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +6 -5
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +6 -5
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +6 -5
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +6 -5
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +6 -5
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +6 -5
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js +8 -2
- package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.es.js +8 -2
- package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +10 -3
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +10 -3
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js +14 -0
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js +14 -0
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +6 -5
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +6 -5
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +5 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +5 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +6 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +6 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +6 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +6 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +6 -4
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +7 -5
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js +1 -31
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.es.js +1 -31
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js +2 -2
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js +2 -2
- package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +48 -4
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +50 -6
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +47 -11
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +47 -11
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +5 -4
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +5 -4
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js +5 -3
- package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js +5 -3
- package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js +106 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js +106 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +14 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +14 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +15 -3
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +15 -3
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +106 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +106 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +26 -4
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +26 -4
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +135 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +135 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js +8 -6
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js +8 -6
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js +1 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js +1 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +88 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +88 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +35 -4
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +35 -4
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +88 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +88 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +90 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +90 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.cjs.js +19 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.es.js +19 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.cjs.js +26 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.es.js +26 -0
- package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +9 -8
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +10 -9
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js +8 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js +8 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js +190 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js +190 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js +4 -147
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js +2 -145
- package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js +12 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js +12 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +6 -5
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +6 -5
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js +5 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js +5 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
- package/dist/shared/src/util/confirmDelete.cjs.js +1 -0
- package/dist/shared/src/util/confirmDelete.cjs.js.map +1 -1
- package/dist/shared/src/util/confirmDelete.es.js +2 -0
- package/dist/shared/src/util/confirmDelete.es.js.map +1 -1
- package/dist/types/SimpleTable/SimpleTable.d.ts +1 -0
- package/dist/types/SimpleTable/SimpleTableRowTemplate.d.ts +1 -1
- package/dist/types/SimpleTable/context/SimpleTableContext.d.ts +5 -1
- package/dist/types/api/generated/folders.d.ts +1 -0
- package/dist/types/api/generated/graphql.d.ts +66 -5
- package/dist/types/api/queries/actions/getActions.d.ts +132 -1
- package/dist/types/api/queries/activities/getActivities.d.ts +6 -0
- package/dist/types/api/queries/activities/updateActivities.d.ts +12 -0
- package/dist/types/api/queries/entities/getEntity.d.ts +6 -0
- package/dist/types/api/queries/entities/getEntityPanel.d.ts +6 -0
- package/dist/types/api/queries/entities/transformDetailsPanelData.d.ts +1 -0
- package/dist/types/api/queries/entities/updateEntity.d.ts +6 -0
- package/dist/types/api/queries/entityLists/getLists.d.ts +1517 -2
- package/dist/types/api/queries/entityLists/types.d.ts +30 -1
- package/dist/types/api/queries/entityLists/updateLists.d.ts +166 -3
- package/dist/types/api/queries/overview/getOverview.d.ts +6 -0
- package/dist/types/api/queries/userDashboard/getUserDashboard.d.ts +6 -0
- package/dist/types/api/queries/users/getUsers.d.ts +6 -0
- package/dist/types/components/PlayableIcon/PlayableIcon.d.ts +4 -0
- package/dist/types/containers/Actions/Actions.d.ts +7 -1
- package/dist/types/containers/Actions/ActionsDropdown/ActionsDropdown.d.ts +5 -3
- package/dist/types/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.d.ts +0 -1
- package/dist/types/containers/ProjectTreeTable/ProjectTreeTable.d.ts +6 -2
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +4 -1
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +11 -2
- package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/hooks/useCellContextMenu.d.ts +1 -1
- package/dist/types/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.d.ts +9 -0
- package/dist/types/containers/ProjectTreeTable/hooks/useFolderRelationships.d.ts +2 -2
- package/dist/types/containers/ProjectTreeTable/hooks/useKeyboardNavigation.d.ts +3 -3
- package/dist/types/containers/ProjectTreeTable/hooks/useUpdateTableData.d.ts +1 -1
- package/dist/types/containers/ProjectTreeTable/types/table.d.ts +10 -1
- package/dist/types/containers/ProjectTreeTable/utils/getEntityViewerIds.d.ts +4 -0
- package/dist/types/containers/ProjectTreeTable/utils/getTypeDefaultValue.d.ts +2 -0
- package/dist/types/containers/ProjectTreeTable/utils/index.d.ts +2 -0
- package/dist/types/containers/ProjectTreeTable/widgets/CellWidget.d.ts +2 -1
- package/dist/types/containers/ProjectTreeTable/widgets/EnumCellValue.d.ts +20 -0
- package/dist/types/containers/ProjectTreeTable/widgets/EnumWidget.d.ts +1 -11
- package/dist/types/containers/ProjectTreeTable/widgets/ThumbnailWidget.d.ts +1 -0
- package/dist/types/context/DetailsPanelContext.d.ts +1 -0
- package/dist/types/util/confirmDelete.d.ts +2 -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 +1 -1
|
@@ -15,6 +15,94 @@ const getAttributeIcon = require("../../../util/getAttributeIcon.cjs.js");
|
|
|
15
15
|
require("../../../util/pubsub.cjs.js");
|
|
16
16
|
require("../context/ProjectTableQueriesContext.cjs.js");
|
|
17
17
|
require("../context/SelectedRowsContext.cjs.js");
|
|
18
|
+
require("@ynput/ayon-react-components");
|
|
19
|
+
;/* empty css */
|
|
20
|
+
require("clsx");
|
|
21
|
+
require("../../ContextMenu/ContextMenuContext.cjs.js");
|
|
22
|
+
require("../../../api/base/client.cjs.js");
|
|
23
|
+
require("../../../api/generated/graphql.cjs.js");
|
|
24
|
+
require("../../../api/generated/access.cjs.js");
|
|
25
|
+
require("../../../api/generated/actions.cjs.js");
|
|
26
|
+
require("../../../api/generated/activityFeed.cjs.js");
|
|
27
|
+
require("../../../api/generated/addons.cjs.js");
|
|
28
|
+
require("../../../api/generated/anatomy.cjs.js");
|
|
29
|
+
require("../../../api/generated/attributes.cjs.js");
|
|
30
|
+
require("../../../api/generated/authentication.cjs.js");
|
|
31
|
+
require("../../../api/generated/bundles.cjs.js");
|
|
32
|
+
require("../../../api/generated/configuration.cjs.js");
|
|
33
|
+
require("../../../api/generated/desktop.cjs.js");
|
|
34
|
+
require("../../../api/generated/entityLists.cjs.js");
|
|
35
|
+
require("../../../api/generated/events.cjs.js");
|
|
36
|
+
require("../../../api/generated/files.cjs.js");
|
|
37
|
+
require("../../../api/generated/folders.cjs.js");
|
|
38
|
+
require("../../../api/generated/inbox.cjs.js");
|
|
39
|
+
require("../../../api/generated/links.cjs.js");
|
|
40
|
+
require("../../../api/generated/market.cjs.js");
|
|
41
|
+
require("../../../api/generated/onboarding.cjs.js");
|
|
42
|
+
require("../../../api/generated/operations.cjs.js");
|
|
43
|
+
require("../../../api/generated/products.cjs.js");
|
|
44
|
+
require("../../../api/generated/projectDashboard.cjs.js");
|
|
45
|
+
require("../../../api/generated/projects.cjs.js");
|
|
46
|
+
require("../../../api/generated/reviewables.cjs.js");
|
|
47
|
+
require("../../../api/generated/services.cjs.js");
|
|
48
|
+
require("../../../api/generated/system.cjs.js");
|
|
49
|
+
require("../../../api/generated/tasks.cjs.js");
|
|
50
|
+
require("../../../api/generated/teams.cjs.js");
|
|
51
|
+
require("../../../api/generated/thumbnails.cjs.js");
|
|
52
|
+
require("../../../api/generated/uRIs.cjs.js");
|
|
53
|
+
require("../../../api/generated/users.cjs.js");
|
|
54
|
+
require("../../../api/generated/versions.cjs.js");
|
|
55
|
+
require("../../../api/generated/workfiles.cjs.js");
|
|
56
|
+
require("../../../api/generated/ynputCloud.cjs.js");
|
|
57
|
+
require("../../../api/generated/grouping.cjs.js");
|
|
58
|
+
require("../../../api/queries/actions/getActions.cjs.js");
|
|
59
|
+
require("../../../api/queries/activities/getActivities.cjs.js");
|
|
60
|
+
require("../../../api/queries/activities/updateActivities.cjs.js");
|
|
61
|
+
require("../../../api/queries/activities/updateReaction.cjs.js");
|
|
62
|
+
require("../../../api/queries/activities/getMentions.cjs.js");
|
|
63
|
+
require("../../../api/queries/addons/getAddons.cjs.js");
|
|
64
|
+
require("../../../api/queries/addons/updateAddons.cjs.js");
|
|
65
|
+
require("../../../api/queries/attributes/getAttributes.cjs.js");
|
|
66
|
+
require("../../../api/queries/attributes/updateAttributes.cjs.js");
|
|
67
|
+
require("../../../api/queries/authentication/getAuthentication.cjs.js");
|
|
68
|
+
require("../../../api/queries/entities/getEntity.cjs.js");
|
|
69
|
+
require("../../../api/queries/entities/getEntityPanel.cjs.js");
|
|
70
|
+
require("../../../api/queries/entities/updateEntity.cjs.js");
|
|
71
|
+
require("../../../api/queries/entityLists/getLists.cjs.js");
|
|
72
|
+
require("../../../api/queries/entityLists/updateLists.cjs.js");
|
|
73
|
+
require("../../../api/queries/entityLists/getListsAttributes.cjs.js");
|
|
74
|
+
require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");
|
|
75
|
+
require("../../../api/queries/folders/getFolders.cjs.js");
|
|
76
|
+
require("../../../api/queries/overview/getOverview.cjs.js");
|
|
77
|
+
require("../../../api/queries/overview/updateOverview.cjs.js");
|
|
78
|
+
require("../../../api/queries/project/getProject.cjs.js");
|
|
79
|
+
require("../../../api/queries/project/updateProject.cjs.js");
|
|
80
|
+
require("../../../api/queries/review/getReview.cjs.js");
|
|
81
|
+
require("../../../api/queries/review/updateReview.cjs.js");
|
|
82
|
+
require("../../../api/queries/system/getSystem.cjs.js");
|
|
83
|
+
require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");
|
|
84
|
+
require("../../../api/queries/users/getUsers.cjs.js");
|
|
85
|
+
require("../../../api/queries/users/updateUsers.cjs.js");
|
|
86
|
+
require("../../../api/queries/watchers/getWatchers.cjs.js");
|
|
87
|
+
require("../../../api/queries/permissions/getPermissions.cjs.js");
|
|
88
|
+
require("../../../api/queries/grouping/getGrouping.cjs.js");
|
|
89
|
+
require("../../../api/queries/versions/updateVersions.cjs.js");
|
|
90
|
+
require("../../../api/queries/products/createProduct.cjs.js");
|
|
91
|
+
require("../../../context/RemoteModulesContext.cjs.js");
|
|
92
|
+
require("../../../../../_virtual/runtime.cjs.js");
|
|
93
|
+
require("../../../../../_virtual/semver.cjs.js");
|
|
94
|
+
require("../../../context/DetailsPanelContext.cjs.js");
|
|
95
|
+
require("../../../context/ThumbnailUploaderContext.cjs.js");
|
|
96
|
+
require("../../../context/SettingsPanelContext.cjs.js");
|
|
97
|
+
require("../../../context/pip/PiPProvider.cjs.js");
|
|
98
|
+
require("react-dom");
|
|
99
|
+
require("../../../context/pip/PiPWrapper.cjs.js");
|
|
100
|
+
require("../../../context/AddonProjectContext.cjs.js");
|
|
101
|
+
require("../../../context/AddonContext.cjs.js");
|
|
102
|
+
require("../../../context/PowerpackContext.cjs.js");
|
|
103
|
+
require("react-redux");
|
|
104
|
+
require("custom-protocol-check");
|
|
105
|
+
require("../components/GroupSettingsFallback.cjs.js");
|
|
18
106
|
require("../context/ProjectDataContext.cjs.js");
|
|
19
107
|
const allowedGroupByFields = ["string", "integer", "float"];
|
|
20
108
|
const isAttribGroupable = (attrib, entityType, allowedTypes, enumOnly) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useGetGroupedFields.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useGetGroupedFields.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport { ProjectTableAttribute } from '../types'\nimport { useColumnSettingsContext, useProjectTableContext } from '../context'\nimport { getAttributeIcon } from '@shared/util'\nimport { EntityGrouping } from '@shared/api'\n\n// @martastain says list_of_* is a pita to implement, so we are not supporting it for now\nexport const allowedGroupByFields = ['string', 'integer', 'float']\nexport const isAttribGroupable = (\n attrib: ProjectTableAttribute,\n entityType: EntityGrouping['entityType'],\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const typesToCheck = allowedTypes || allowedGroupByFields\n const hasValidType = typesToCheck.includes(attrib.data.type) && attrib.scope?.includes(entityType)\n\n if (!hasValidType) return false\n if (enumOnly) return !!attrib.data.enum && attrib.data.enum.length > 0\n\n return true\n}\n\nexport const useGetGroupedFields = (\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const { columnOrder } = useColumnSettingsContext()\n const { attribFields } = useProjectTableContext()\n\n return useMemo(\n () =>\n [\n {\n value: 'taskType',\n label: 'Task Type',\n icon: getAttributeIcon('task'),\n },\n {\n value: 'assignees',\n label: 'Assignees',\n icon: getAttributeIcon('assignees'),\n },\n {\n value: 'status',\n label: 'Status',\n icon: getAttributeIcon('status'),\n },\n {\n value: 'tags',\n label: 'Tags',\n icon: getAttributeIcon('tags'),\n },\n ...attribFields\n .filter((attrib) => isAttribGroupable(attrib, 'task', allowedTypes, enumOnly))\n .map((field) => ({\n value: 'attrib.' + field.name,\n label: field.data.title || field.name,\n icon: getAttributeIcon(field.name),\n })),\n ].sort((a, b) => {\n const indexA = columnOrder.indexOf(a.value)\n const indexB = columnOrder.indexOf(b.value)\n if (indexA === -1 && indexB === -1) return 0\n if (indexA === -1) return 1\n if (indexB === -1) return -1\n return indexA - indexB\n }),\n [attribFields, columnOrder, allowedTypes, enumOnly],\n )\n}\n"],"names":["useColumnSettingsContext","useProjectTableContext","useMemo","getAttributeIcon"],"mappings":"
|
|
1
|
+
{"version":3,"file":"useGetGroupedFields.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useGetGroupedFields.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport { ProjectTableAttribute } from '../types'\nimport { useColumnSettingsContext, useProjectTableContext } from '../context'\nimport { getAttributeIcon } from '@shared/util'\nimport { EntityGrouping } from '@shared/api'\n\n// @martastain says list_of_* is a pita to implement, so we are not supporting it for now\nexport const allowedGroupByFields = ['string', 'integer', 'float']\nexport const isAttribGroupable = (\n attrib: ProjectTableAttribute,\n entityType: EntityGrouping['entityType'],\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const typesToCheck = allowedTypes || allowedGroupByFields\n const hasValidType = typesToCheck.includes(attrib.data.type) && attrib.scope?.includes(entityType)\n\n if (!hasValidType) return false\n if (enumOnly) return !!attrib.data.enum && attrib.data.enum.length > 0\n\n return true\n}\n\nexport const useGetGroupedFields = (\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const { columnOrder } = useColumnSettingsContext()\n const { attribFields } = useProjectTableContext()\n\n return useMemo(\n () =>\n [\n {\n value: 'taskType',\n label: 'Task Type',\n icon: getAttributeIcon('task'),\n },\n {\n value: 'assignees',\n label: 'Assignees',\n icon: getAttributeIcon('assignees'),\n },\n {\n value: 'status',\n label: 'Status',\n icon: getAttributeIcon('status'),\n },\n {\n value: 'tags',\n label: 'Tags',\n icon: getAttributeIcon('tags'),\n },\n ...attribFields\n .filter((attrib) => isAttribGroupable(attrib, 'task', allowedTypes, enumOnly))\n .map((field) => ({\n value: 'attrib.' + field.name,\n label: field.data.title || field.name,\n icon: getAttributeIcon(field.name),\n })),\n ].sort((a, b) => {\n const indexA = columnOrder.indexOf(a.value)\n const indexB = columnOrder.indexOf(b.value)\n if (indexA === -1 && indexB === -1) return 0\n if (indexA === -1) return 1\n if (indexB === -1) return -1\n return indexA - indexB\n }),\n [attribFields, columnOrder, allowedTypes, enumOnly],\n )\n}\n"],"names":["useColumnSettingsContext","useProjectTableContext","useMemo","getAttributeIcon"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOO,MAAM,uBAAuB,CAAC,UAAU,WAAW,OAAO;AAC1D,MAAM,oBAAoB,CAC/B,QACA,YACA,cACA,aACG;;AACH,QAAM,eAAe,gBAAgB;AAC/B,QAAA,eAAe,aAAa,SAAS,OAAO,KAAK,IAAI,OAAK,YAAO,UAAP,mBAAc,SAAS;AAEnF,MAAA,CAAC,aAAqB,QAAA;AACtB,MAAA,SAAiB,QAAA,CAAC,CAAC,OAAO,KAAK,QAAQ,OAAO,KAAK,KAAK,SAAS;AAE9D,SAAA;AACT;AAEa,MAAA,sBAAsB,CACjC,cACA,aACG;AACG,QAAA,EAAE,YAAY,IAAIA,+CAAyB;AAC3C,QAAA,EAAE,aAAa,IAAIC,2CAAuB;AAEzC,SAAAC,MAAA;AAAA,IACL,MACE;AAAA,MACE;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAMC,kCAAiB,MAAM;AAAA,MAC/B;AAAA,MACA;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAMA,kCAAiB,WAAW;AAAA,MACpC;AAAA,MACA;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAMA,kCAAiB,QAAQ;AAAA,MACjC;AAAA,MACA;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAMA,kCAAiB,MAAM;AAAA,MAC/B;AAAA,MACA,GAAG,aACA,OAAO,CAAC,WAAW,kBAAkB,QAAQ,QAAQ,cAAc,QAAQ,CAAC,EAC5E,IAAI,CAAC,WAAW;AAAA,QACf,OAAO,YAAY,MAAM;AAAA,QACzB,OAAO,MAAM,KAAK,SAAS,MAAM;AAAA,QACjC,MAAMA,iBAAAA,iBAAiB,MAAM,IAAI;AAAA,MAAA,EACjC;AAAA,IAAA,EACJ,KAAK,CAAC,GAAG,MAAM;AACf,YAAM,SAAS,YAAY,QAAQ,EAAE,KAAK;AAC1C,YAAM,SAAS,YAAY,QAAQ,EAAE,KAAK;AAC1C,UAAI,WAAW,MAAM,WAAW,GAAW,QAAA;AACvC,UAAA,WAAW,GAAW,QAAA;AACtB,UAAA,WAAW,GAAW,QAAA;AAC1B,aAAO,SAAS;AAAA,IAAA,CACjB;AAAA,IACH,CAAC,cAAc,aAAa,cAAc,QAAQ;AAAA,EACpD;AACF;;;;"}
|
|
@@ -13,6 +13,94 @@ import { getAttributeIcon } from "../../../util/getAttributeIcon.es.js";
|
|
|
13
13
|
import "../../../util/pubsub.es.js";
|
|
14
14
|
import "../context/ProjectTableQueriesContext.es.js";
|
|
15
15
|
import "../context/SelectedRowsContext.es.js";
|
|
16
|
+
import "@ynput/ayon-react-components";
|
|
17
|
+
/* empty css */
|
|
18
|
+
import "clsx";
|
|
19
|
+
import "../../ContextMenu/ContextMenuContext.es.js";
|
|
20
|
+
import "../../../api/base/client.es.js";
|
|
21
|
+
import "../../../api/generated/graphql.es.js";
|
|
22
|
+
import "../../../api/generated/access.es.js";
|
|
23
|
+
import "../../../api/generated/actions.es.js";
|
|
24
|
+
import "../../../api/generated/activityFeed.es.js";
|
|
25
|
+
import "../../../api/generated/addons.es.js";
|
|
26
|
+
import "../../../api/generated/anatomy.es.js";
|
|
27
|
+
import "../../../api/generated/attributes.es.js";
|
|
28
|
+
import "../../../api/generated/authentication.es.js";
|
|
29
|
+
import "../../../api/generated/bundles.es.js";
|
|
30
|
+
import "../../../api/generated/configuration.es.js";
|
|
31
|
+
import "../../../api/generated/desktop.es.js";
|
|
32
|
+
import "../../../api/generated/entityLists.es.js";
|
|
33
|
+
import "../../../api/generated/events.es.js";
|
|
34
|
+
import "../../../api/generated/files.es.js";
|
|
35
|
+
import "../../../api/generated/folders.es.js";
|
|
36
|
+
import "../../../api/generated/inbox.es.js";
|
|
37
|
+
import "../../../api/generated/links.es.js";
|
|
38
|
+
import "../../../api/generated/market.es.js";
|
|
39
|
+
import "../../../api/generated/onboarding.es.js";
|
|
40
|
+
import "../../../api/generated/operations.es.js";
|
|
41
|
+
import "../../../api/generated/products.es.js";
|
|
42
|
+
import "../../../api/generated/projectDashboard.es.js";
|
|
43
|
+
import "../../../api/generated/projects.es.js";
|
|
44
|
+
import "../../../api/generated/reviewables.es.js";
|
|
45
|
+
import "../../../api/generated/services.es.js";
|
|
46
|
+
import "../../../api/generated/system.es.js";
|
|
47
|
+
import "../../../api/generated/tasks.es.js";
|
|
48
|
+
import "../../../api/generated/teams.es.js";
|
|
49
|
+
import "../../../api/generated/thumbnails.es.js";
|
|
50
|
+
import "../../../api/generated/uRIs.es.js";
|
|
51
|
+
import "../../../api/generated/users.es.js";
|
|
52
|
+
import "../../../api/generated/versions.es.js";
|
|
53
|
+
import "../../../api/generated/workfiles.es.js";
|
|
54
|
+
import "../../../api/generated/ynputCloud.es.js";
|
|
55
|
+
import "../../../api/generated/grouping.es.js";
|
|
56
|
+
import "../../../api/queries/actions/getActions.es.js";
|
|
57
|
+
import "../../../api/queries/activities/getActivities.es.js";
|
|
58
|
+
import "../../../api/queries/activities/updateActivities.es.js";
|
|
59
|
+
import "../../../api/queries/activities/updateReaction.es.js";
|
|
60
|
+
import "../../../api/queries/activities/getMentions.es.js";
|
|
61
|
+
import "../../../api/queries/addons/getAddons.es.js";
|
|
62
|
+
import "../../../api/queries/addons/updateAddons.es.js";
|
|
63
|
+
import "../../../api/queries/attributes/getAttributes.es.js";
|
|
64
|
+
import "../../../api/queries/attributes/updateAttributes.es.js";
|
|
65
|
+
import "../../../api/queries/authentication/getAuthentication.es.js";
|
|
66
|
+
import "../../../api/queries/entities/getEntity.es.js";
|
|
67
|
+
import "../../../api/queries/entities/getEntityPanel.es.js";
|
|
68
|
+
import "../../../api/queries/entities/updateEntity.es.js";
|
|
69
|
+
import "../../../api/queries/entityLists/getLists.es.js";
|
|
70
|
+
import "../../../api/queries/entityLists/updateLists.es.js";
|
|
71
|
+
import "../../../api/queries/entityLists/getListsAttributes.es.js";
|
|
72
|
+
import "../../../api/queries/entityLists/updateListsAttributes.es.js";
|
|
73
|
+
import "../../../api/queries/folders/getFolders.es.js";
|
|
74
|
+
import "../../../api/queries/overview/getOverview.es.js";
|
|
75
|
+
import "../../../api/queries/overview/updateOverview.es.js";
|
|
76
|
+
import "../../../api/queries/project/getProject.es.js";
|
|
77
|
+
import "../../../api/queries/project/updateProject.es.js";
|
|
78
|
+
import "../../../api/queries/review/getReview.es.js";
|
|
79
|
+
import "../../../api/queries/review/updateReview.es.js";
|
|
80
|
+
import "../../../api/queries/system/getSystem.es.js";
|
|
81
|
+
import "../../../api/queries/userDashboard/getUserDashboard.es.js";
|
|
82
|
+
import "../../../api/queries/users/getUsers.es.js";
|
|
83
|
+
import "../../../api/queries/users/updateUsers.es.js";
|
|
84
|
+
import "../../../api/queries/watchers/getWatchers.es.js";
|
|
85
|
+
import "../../../api/queries/permissions/getPermissions.es.js";
|
|
86
|
+
import "../../../api/queries/grouping/getGrouping.es.js";
|
|
87
|
+
import "../../../api/queries/versions/updateVersions.es.js";
|
|
88
|
+
import "../../../api/queries/products/createProduct.es.js";
|
|
89
|
+
import "../../../context/RemoteModulesContext.es.js";
|
|
90
|
+
import "../../../../../_virtual/runtime.es.js";
|
|
91
|
+
import "../../../../../_virtual/semver.es.js";
|
|
92
|
+
import "../../../context/DetailsPanelContext.es.js";
|
|
93
|
+
import "../../../context/ThumbnailUploaderContext.es.js";
|
|
94
|
+
import "../../../context/SettingsPanelContext.es.js";
|
|
95
|
+
import "../../../context/pip/PiPProvider.es.js";
|
|
96
|
+
import "react-dom";
|
|
97
|
+
import "../../../context/pip/PiPWrapper.es.js";
|
|
98
|
+
import "../../../context/AddonProjectContext.es.js";
|
|
99
|
+
import "../../../context/AddonContext.es.js";
|
|
100
|
+
import "../../../context/PowerpackContext.es.js";
|
|
101
|
+
import "react-redux";
|
|
102
|
+
import "custom-protocol-check";
|
|
103
|
+
import "../components/GroupSettingsFallback.es.js";
|
|
16
104
|
import "../context/ProjectDataContext.es.js";
|
|
17
105
|
const allowedGroupByFields = ["string", "integer", "float"];
|
|
18
106
|
const isAttribGroupable = (attrib, entityType, allowedTypes, enumOnly) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useGetGroupedFields.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useGetGroupedFields.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport { ProjectTableAttribute } from '../types'\nimport { useColumnSettingsContext, useProjectTableContext } from '../context'\nimport { getAttributeIcon } from '@shared/util'\nimport { EntityGrouping } from '@shared/api'\n\n// @martastain says list_of_* is a pita to implement, so we are not supporting it for now\nexport const allowedGroupByFields = ['string', 'integer', 'float']\nexport const isAttribGroupable = (\n attrib: ProjectTableAttribute,\n entityType: EntityGrouping['entityType'],\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const typesToCheck = allowedTypes || allowedGroupByFields\n const hasValidType = typesToCheck.includes(attrib.data.type) && attrib.scope?.includes(entityType)\n\n if (!hasValidType) return false\n if (enumOnly) return !!attrib.data.enum && attrib.data.enum.length > 0\n\n return true\n}\n\nexport const useGetGroupedFields = (\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const { columnOrder } = useColumnSettingsContext()\n const { attribFields } = useProjectTableContext()\n\n return useMemo(\n () =>\n [\n {\n value: 'taskType',\n label: 'Task Type',\n icon: getAttributeIcon('task'),\n },\n {\n value: 'assignees',\n label: 'Assignees',\n icon: getAttributeIcon('assignees'),\n },\n {\n value: 'status',\n label: 'Status',\n icon: getAttributeIcon('status'),\n },\n {\n value: 'tags',\n label: 'Tags',\n icon: getAttributeIcon('tags'),\n },\n ...attribFields\n .filter((attrib) => isAttribGroupable(attrib, 'task', allowedTypes, enumOnly))\n .map((field) => ({\n value: 'attrib.' + field.name,\n label: field.data.title || field.name,\n icon: getAttributeIcon(field.name),\n })),\n ].sort((a, b) => {\n const indexA = columnOrder.indexOf(a.value)\n const indexB = columnOrder.indexOf(b.value)\n if (indexA === -1 && indexB === -1) return 0\n if (indexA === -1) return 1\n if (indexB === -1) return -1\n return indexA - indexB\n }),\n [attribFields, columnOrder, allowedTypes, enumOnly],\n )\n}\n"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useGetGroupedFields.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useGetGroupedFields.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport { ProjectTableAttribute } from '../types'\nimport { useColumnSettingsContext, useProjectTableContext } from '../context'\nimport { getAttributeIcon } from '@shared/util'\nimport { EntityGrouping } from '@shared/api'\n\n// @martastain says list_of_* is a pita to implement, so we are not supporting it for now\nexport const allowedGroupByFields = ['string', 'integer', 'float']\nexport const isAttribGroupable = (\n attrib: ProjectTableAttribute,\n entityType: EntityGrouping['entityType'],\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const typesToCheck = allowedTypes || allowedGroupByFields\n const hasValidType = typesToCheck.includes(attrib.data.type) && attrib.scope?.includes(entityType)\n\n if (!hasValidType) return false\n if (enumOnly) return !!attrib.data.enum && attrib.data.enum.length > 0\n\n return true\n}\n\nexport const useGetGroupedFields = (\n allowedTypes?: ('string' | 'integer' | 'float')[],\n enumOnly?: boolean,\n) => {\n const { columnOrder } = useColumnSettingsContext()\n const { attribFields } = useProjectTableContext()\n\n return useMemo(\n () =>\n [\n {\n value: 'taskType',\n label: 'Task Type',\n icon: getAttributeIcon('task'),\n },\n {\n value: 'assignees',\n label: 'Assignees',\n icon: getAttributeIcon('assignees'),\n },\n {\n value: 'status',\n label: 'Status',\n icon: getAttributeIcon('status'),\n },\n {\n value: 'tags',\n label: 'Tags',\n icon: getAttributeIcon('tags'),\n },\n ...attribFields\n .filter((attrib) => isAttribGroupable(attrib, 'task', allowedTypes, enumOnly))\n .map((field) => ({\n value: 'attrib.' + field.name,\n label: field.data.title || field.name,\n icon: getAttributeIcon(field.name),\n })),\n ].sort((a, b) => {\n const indexA = columnOrder.indexOf(a.value)\n const indexB = columnOrder.indexOf(b.value)\n if (indexA === -1 && indexB === -1) return 0\n if (indexA === -1) return 1\n if (indexB === -1) return -1\n return indexA - indexB\n }),\n [attribFields, columnOrder, allowedTypes, enumOnly],\n )\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOO,MAAM,uBAAuB,CAAC,UAAU,WAAW,OAAO;AAC1D,MAAM,oBAAoB,CAC/B,QACA,YACA,cACA,aACG;;AACH,QAAM,eAAe,gBAAgB;AAC/B,QAAA,eAAe,aAAa,SAAS,OAAO,KAAK,IAAI,OAAK,YAAO,UAAP,mBAAc,SAAS;AAEnF,MAAA,CAAC,aAAqB,QAAA;AACtB,MAAA,SAAiB,QAAA,CAAC,CAAC,OAAO,KAAK,QAAQ,OAAO,KAAK,KAAK,SAAS;AAE9D,SAAA;AACT;AAEa,MAAA,sBAAsB,CACjC,cACA,aACG;AACG,QAAA,EAAE,YAAY,IAAI,yBAAyB;AAC3C,QAAA,EAAE,aAAa,IAAI,uBAAuB;AAEzC,SAAA;AAAA,IACL,MACE;AAAA,MACE;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAM,iBAAiB,MAAM;AAAA,MAC/B;AAAA,MACA;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAM,iBAAiB,WAAW;AAAA,MACpC;AAAA,MACA;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAM,iBAAiB,QAAQ;AAAA,MACjC;AAAA,MACA;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,QACP,MAAM,iBAAiB,MAAM;AAAA,MAC/B;AAAA,MACA,GAAG,aACA,OAAO,CAAC,WAAW,kBAAkB,QAAQ,QAAQ,cAAc,QAAQ,CAAC,EAC5E,IAAI,CAAC,WAAW;AAAA,QACf,OAAO,YAAY,MAAM;AAAA,QACzB,OAAO,MAAM,KAAK,SAAS,MAAM;AAAA,QACjC,MAAM,iBAAiB,MAAM,IAAI;AAAA,MAAA,EACjC;AAAA,IAAA,EACJ,KAAK,CAAC,GAAG,MAAM;AACf,YAAM,SAAS,YAAY,QAAQ,EAAE,KAAK;AAC1C,YAAM,SAAS,YAAY,QAAQ,EAAE,KAAK;AAC1C,UAAI,WAAW,MAAM,WAAW,GAAW,QAAA;AACvC,UAAA,WAAW,GAAW,QAAA;AACtB,UAAA,WAAW,GAAW,QAAA;AAC1B,aAAO,SAAS;AAAA,IAAA,CACjB;AAAA,IACH,CAAC,cAAc,aAAa,cAAc,QAAQ;AAAA,EACpD;AACF;"}
|
|
@@ -19,7 +19,7 @@ const useHistory = (maxHistorySize = 50) => {
|
|
|
19
19
|
(acc, entity) => {
|
|
20
20
|
if (typeof entity === "function") {
|
|
21
21
|
acc[2].push(entity);
|
|
22
|
-
} else if (entity.wasInherited
|
|
22
|
+
} else if (entity.wasInherited) {
|
|
23
23
|
acc[1].push({
|
|
24
24
|
entityId: entity.id,
|
|
25
25
|
entityType: entity.type,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useHistory.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useHistory.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport { EntityUpdate, InheritFromParentEntity } from './useUpdateTableData'\n\nexport interface HistoryEntityUpdate extends EntityUpdate {\n ownAttrib: string[]\n folderId?: string\n wasInherited?: boolean\n}\n\ninterface HistoryEntry {\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n timestamp: number\n}\n\ntype SplitEntitiesByInherited = [EntityUpdate[], InheritFromParentEntity[], HistoryCustomCallback[]]\n\ntype HistoryCustomCallback = () => void\n\nexport interface UseHistoryReturn {\n pushHistory: (\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ) => void\n undo: () => SplitEntitiesByInherited | null\n redo: () => SplitEntitiesByInherited | null\n canUndo: boolean\n canRedo: boolean\n clearHistory: () => void\n removeHistoryEntries: (count: number) => void\n}\n\nconst useHistory = (maxHistorySize = 50): UseHistoryReturn => {\n const [past, setPast] = useState<HistoryEntry[]>([])\n const [future, setFuture] = useState<HistoryEntry[]>([])\n\n const pushHistory: UseHistoryReturn['pushHistory'] = useCallback(\n (undo, redo) => {\n if (!undo.length) return\n setPast((prev) => {\n const updated = [...prev, { undo, redo, timestamp: Date.now() }]\n return updated.length > maxHistorySize\n ? updated.slice(updated.length - maxHistorySize)\n : updated\n })\n setFuture([])\n },\n [maxHistorySize],\n )\n\n // Process actions by type: regular updates, inheritance, and custom callbacks\n const processHistoryActions = (\n entities: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ): SplitEntitiesByInherited => {\n return entities.reduce(\n (acc, entity) => {\n if (typeof entity === 'function') {\n acc[2].push(entity)\n } else if (entity.wasInherited
|
|
1
|
+
{"version":3,"file":"useHistory.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useHistory.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport { EntityUpdate, InheritFromParentEntity } from './useUpdateTableData'\n\nexport interface HistoryEntityUpdate extends EntityUpdate {\n ownAttrib: string[]\n folderId?: string\n wasInherited?: boolean\n}\n\ninterface HistoryEntry {\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n timestamp: number\n}\n\ntype SplitEntitiesByInherited = [EntityUpdate[], InheritFromParentEntity[], HistoryCustomCallback[]]\n\ntype HistoryCustomCallback = () => void\n\nexport interface UseHistoryReturn {\n pushHistory: (\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ) => void\n undo: () => SplitEntitiesByInherited | null\n redo: () => SplitEntitiesByInherited | null\n canUndo: boolean\n canRedo: boolean\n clearHistory: () => void\n removeHistoryEntries: (count: number) => void\n}\n\nconst useHistory = (maxHistorySize = 50): UseHistoryReturn => {\n const [past, setPast] = useState<HistoryEntry[]>([])\n const [future, setFuture] = useState<HistoryEntry[]>([])\n\n const pushHistory: UseHistoryReturn['pushHistory'] = useCallback(\n (undo, redo) => {\n if (!undo.length) return\n setPast((prev) => {\n const updated = [...prev, { undo, redo, timestamp: Date.now() }]\n return updated.length > maxHistorySize\n ? updated.slice(updated.length - maxHistorySize)\n : updated\n })\n setFuture([])\n },\n [maxHistorySize],\n )\n\n // Process actions by type: regular updates, inheritance, and custom callbacks\n const processHistoryActions = (\n entities: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ): SplitEntitiesByInherited => {\n return entities.reduce(\n (acc, entity) => {\n if (typeof entity === 'function') {\n acc[2].push(entity)\n } else if (entity.wasInherited) {\n acc[1].push({\n entityId: entity.id,\n entityType: entity.type,\n folderId: entity.folderId,\n attribs: [entity.field],\n ownAttrib: entity.ownAttrib,\n rowId: entity.rowId,\n })\n } else {\n acc[0].push(entity)\n }\n return acc\n },\n [[], [], []] as SplitEntitiesByInherited,\n )\n }\n\n const undo = useCallback(() => {\n if (past.length === 0) return null\n const newPast = [...past]\n const last = newPast.pop()!\n setPast(newPast)\n setFuture((f) => [...f, last])\n\n return processHistoryActions(last.undo)\n }, [past])\n\n const redo = useCallback(() => {\n if (future.length === 0) return null\n const newFuture = [...future]\n const next = newFuture.pop()!\n setFuture(newFuture)\n setPast((p) => [...p, next])\n return processHistoryActions(next.redo)\n }, [future])\n\n // function to remove x number of entries from the history undo/redo stacks\n const removeHistoryEntries = useCallback((count: number) => {\n setPast((prev) => prev.slice(0, Math.max(0, prev.length - count)))\n setFuture((prev) => prev.slice(0, Math.max(0, prev.length - count)))\n }, [])\n\n const clearHistory = useCallback(() => {\n setPast([])\n setFuture([])\n }, [])\n\n return {\n pushHistory,\n undo,\n redo,\n canUndo: past.length > 0,\n canRedo: future.length > 0,\n clearHistory,\n removeHistoryEntries,\n }\n}\n\nexport default useHistory\n"],"names":["useState","useCallback","undo","redo"],"mappings":";;AAgCM,MAAA,aAAa,CAAC,iBAAiB,OAAyB;AAC5D,QAAM,CAAC,MAAM,OAAO,IAAIA,MAAAA,SAAyB,CAAA,CAAE;AACnD,QAAM,CAAC,QAAQ,SAAS,IAAIA,MAAAA,SAAyB,CAAA,CAAE;AAEvD,QAAM,cAA+CC,MAAA;AAAA,IACnD,CAACC,OAAMC,UAAS;AACV,UAAA,CAACD,MAAK,OAAQ;AAClB,cAAQ,CAAC,SAAS;AAChB,cAAM,UAAU,CAAC,GAAG,MAAM,EAAE,MAAAA,OAAM,MAAAC,OAAM,WAAW,KAAK,OAAO;AACxD,eAAA,QAAQ,SAAS,iBACpB,QAAQ,MAAM,QAAQ,SAAS,cAAc,IAC7C;AAAA,MAAA,CACL;AACD,gBAAU,CAAA,CAAE;AAAA,IACd;AAAA,IACA,CAAC,cAAc;AAAA,EACjB;AAGM,QAAA,wBAAwB,CAC5B,aAC6B;AAC7B,WAAO,SAAS;AAAA,MACd,CAAC,KAAK,WAAW;AACX,YAAA,OAAO,WAAW,YAAY;AAC5B,cAAA,CAAC,EAAE,KAAK,MAAM;AAAA,QAAA,WACT,OAAO,cAAc;AAC1B,cAAA,CAAC,EAAE,KAAK;AAAA,YACV,UAAU,OAAO;AAAA,YACjB,YAAY,OAAO;AAAA,YACnB,UAAU,OAAO;AAAA,YACjB,SAAS,CAAC,OAAO,KAAK;AAAA,YACtB,WAAW,OAAO;AAAA,YAClB,OAAO,OAAO;AAAA,UAAA,CACf;AAAA,QAAA,OACI;AACD,cAAA,CAAC,EAAE,KAAK,MAAM;AAAA,QAAA;AAEb,eAAA;AAAA,MACT;AAAA,MACA,CAAC,CAAA,GAAI,CAAA,GAAI,CAAE,CAAA;AAAA,IACb;AAAA,EACF;AAEM,QAAA,OAAOF,MAAAA,YAAY,MAAM;AACzB,QAAA,KAAK,WAAW,EAAU,QAAA;AACxB,UAAA,UAAU,CAAC,GAAG,IAAI;AAClB,UAAA,OAAO,QAAQ,IAAI;AACzB,YAAQ,OAAO;AACf,cAAU,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC;AAEtB,WAAA,sBAAsB,KAAK,IAAI;AAAA,EAAA,GACrC,CAAC,IAAI,CAAC;AAEH,QAAA,OAAOA,MAAAA,YAAY,MAAM;AACzB,QAAA,OAAO,WAAW,EAAU,QAAA;AAC1B,UAAA,YAAY,CAAC,GAAG,MAAM;AACtB,UAAA,OAAO,UAAU,IAAI;AAC3B,cAAU,SAAS;AACnB,YAAQ,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC;AACpB,WAAA,sBAAsB,KAAK,IAAI;AAAA,EAAA,GACrC,CAAC,MAAM,CAAC;AAGL,QAAA,uBAAuBA,kBAAY,CAAC,UAAkB;AAC1D,YAAQ,CAAC,SAAS,KAAK,MAAM,GAAG,KAAK,IAAI,GAAG,KAAK,SAAS,KAAK,CAAC,CAAC;AACjE,cAAU,CAAC,SAAS,KAAK,MAAM,GAAG,KAAK,IAAI,GAAG,KAAK,SAAS,KAAK,CAAC,CAAC;AAAA,EACrE,GAAG,EAAE;AAEC,QAAA,eAAeA,MAAAA,YAAY,MAAM;AACrC,YAAQ,CAAA,CAAE;AACV,cAAU,CAAA,CAAE;AAAA,EACd,GAAG,EAAE;AAEE,SAAA;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,SAAS,KAAK,SAAS;AAAA,IACvB,SAAS,OAAO,SAAS;AAAA,IACzB;AAAA,IACA;AAAA,EACF;AACF;;"}
|
|
@@ -18,7 +18,7 @@ const useHistory = (maxHistorySize = 50) => {
|
|
|
18
18
|
(acc, entity) => {
|
|
19
19
|
if (typeof entity === "function") {
|
|
20
20
|
acc[2].push(entity);
|
|
21
|
-
} else if (entity.wasInherited
|
|
21
|
+
} else if (entity.wasInherited) {
|
|
22
22
|
acc[1].push({
|
|
23
23
|
entityId: entity.id,
|
|
24
24
|
entityType: entity.type,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useHistory.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useHistory.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport { EntityUpdate, InheritFromParentEntity } from './useUpdateTableData'\n\nexport interface HistoryEntityUpdate extends EntityUpdate {\n ownAttrib: string[]\n folderId?: string\n wasInherited?: boolean\n}\n\ninterface HistoryEntry {\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n timestamp: number\n}\n\ntype SplitEntitiesByInherited = [EntityUpdate[], InheritFromParentEntity[], HistoryCustomCallback[]]\n\ntype HistoryCustomCallback = () => void\n\nexport interface UseHistoryReturn {\n pushHistory: (\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ) => void\n undo: () => SplitEntitiesByInherited | null\n redo: () => SplitEntitiesByInherited | null\n canUndo: boolean\n canRedo: boolean\n clearHistory: () => void\n removeHistoryEntries: (count: number) => void\n}\n\nconst useHistory = (maxHistorySize = 50): UseHistoryReturn => {\n const [past, setPast] = useState<HistoryEntry[]>([])\n const [future, setFuture] = useState<HistoryEntry[]>([])\n\n const pushHistory: UseHistoryReturn['pushHistory'] = useCallback(\n (undo, redo) => {\n if (!undo.length) return\n setPast((prev) => {\n const updated = [...prev, { undo, redo, timestamp: Date.now() }]\n return updated.length > maxHistorySize\n ? updated.slice(updated.length - maxHistorySize)\n : updated\n })\n setFuture([])\n },\n [maxHistorySize],\n )\n\n // Process actions by type: regular updates, inheritance, and custom callbacks\n const processHistoryActions = (\n entities: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ): SplitEntitiesByInherited => {\n return entities.reduce(\n (acc, entity) => {\n if (typeof entity === 'function') {\n acc[2].push(entity)\n } else if (entity.wasInherited
|
|
1
|
+
{"version":3,"file":"useHistory.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useHistory.ts"],"sourcesContent":["import { useState, useCallback } from 'react'\nimport { EntityUpdate, InheritFromParentEntity } from './useUpdateTableData'\n\nexport interface HistoryEntityUpdate extends EntityUpdate {\n ownAttrib: string[]\n folderId?: string\n wasInherited?: boolean\n}\n\ninterface HistoryEntry {\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[]\n timestamp: number\n}\n\ntype SplitEntitiesByInherited = [EntityUpdate[], InheritFromParentEntity[], HistoryCustomCallback[]]\n\ntype HistoryCustomCallback = () => void\n\nexport interface UseHistoryReturn {\n pushHistory: (\n undo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n redo: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ) => void\n undo: () => SplitEntitiesByInherited | null\n redo: () => SplitEntitiesByInherited | null\n canUndo: boolean\n canRedo: boolean\n clearHistory: () => void\n removeHistoryEntries: (count: number) => void\n}\n\nconst useHistory = (maxHistorySize = 50): UseHistoryReturn => {\n const [past, setPast] = useState<HistoryEntry[]>([])\n const [future, setFuture] = useState<HistoryEntry[]>([])\n\n const pushHistory: UseHistoryReturn['pushHistory'] = useCallback(\n (undo, redo) => {\n if (!undo.length) return\n setPast((prev) => {\n const updated = [...prev, { undo, redo, timestamp: Date.now() }]\n return updated.length > maxHistorySize\n ? updated.slice(updated.length - maxHistorySize)\n : updated\n })\n setFuture([])\n },\n [maxHistorySize],\n )\n\n // Process actions by type: regular updates, inheritance, and custom callbacks\n const processHistoryActions = (\n entities: (HistoryEntityUpdate | HistoryCustomCallback)[],\n ): SplitEntitiesByInherited => {\n return entities.reduce(\n (acc, entity) => {\n if (typeof entity === 'function') {\n acc[2].push(entity)\n } else if (entity.wasInherited) {\n acc[1].push({\n entityId: entity.id,\n entityType: entity.type,\n folderId: entity.folderId,\n attribs: [entity.field],\n ownAttrib: entity.ownAttrib,\n rowId: entity.rowId,\n })\n } else {\n acc[0].push(entity)\n }\n return acc\n },\n [[], [], []] as SplitEntitiesByInherited,\n )\n }\n\n const undo = useCallback(() => {\n if (past.length === 0) return null\n const newPast = [...past]\n const last = newPast.pop()!\n setPast(newPast)\n setFuture((f) => [...f, last])\n\n return processHistoryActions(last.undo)\n }, [past])\n\n const redo = useCallback(() => {\n if (future.length === 0) return null\n const newFuture = [...future]\n const next = newFuture.pop()!\n setFuture(newFuture)\n setPast((p) => [...p, next])\n return processHistoryActions(next.redo)\n }, [future])\n\n // function to remove x number of entries from the history undo/redo stacks\n const removeHistoryEntries = useCallback((count: number) => {\n setPast((prev) => prev.slice(0, Math.max(0, prev.length - count)))\n setFuture((prev) => prev.slice(0, Math.max(0, prev.length - count)))\n }, [])\n\n const clearHistory = useCallback(() => {\n setPast([])\n setFuture([])\n }, [])\n\n return {\n pushHistory,\n undo,\n redo,\n canUndo: past.length > 0,\n canRedo: future.length > 0,\n clearHistory,\n removeHistoryEntries,\n }\n}\n\nexport default useHistory\n"],"names":["undo","redo"],"mappings":";AAgCM,MAAA,aAAa,CAAC,iBAAiB,OAAyB;AAC5D,QAAM,CAAC,MAAM,OAAO,IAAI,SAAyB,CAAA,CAAE;AACnD,QAAM,CAAC,QAAQ,SAAS,IAAI,SAAyB,CAAA,CAAE;AAEvD,QAAM,cAA+C;AAAA,IACnD,CAACA,OAAMC,UAAS;AACV,UAAA,CAACD,MAAK,OAAQ;AAClB,cAAQ,CAAC,SAAS;AAChB,cAAM,UAAU,CAAC,GAAG,MAAM,EAAE,MAAAA,OAAM,MAAAC,OAAM,WAAW,KAAK,OAAO;AACxD,eAAA,QAAQ,SAAS,iBACpB,QAAQ,MAAM,QAAQ,SAAS,cAAc,IAC7C;AAAA,MAAA,CACL;AACD,gBAAU,CAAA,CAAE;AAAA,IACd;AAAA,IACA,CAAC,cAAc;AAAA,EACjB;AAGM,QAAA,wBAAwB,CAC5B,aAC6B;AAC7B,WAAO,SAAS;AAAA,MACd,CAAC,KAAK,WAAW;AACX,YAAA,OAAO,WAAW,YAAY;AAC5B,cAAA,CAAC,EAAE,KAAK,MAAM;AAAA,QAAA,WACT,OAAO,cAAc;AAC1B,cAAA,CAAC,EAAE,KAAK;AAAA,YACV,UAAU,OAAO;AAAA,YACjB,YAAY,OAAO;AAAA,YACnB,UAAU,OAAO;AAAA,YACjB,SAAS,CAAC,OAAO,KAAK;AAAA,YACtB,WAAW,OAAO;AAAA,YAClB,OAAO,OAAO;AAAA,UAAA,CACf;AAAA,QAAA,OACI;AACD,cAAA,CAAC,EAAE,KAAK,MAAM;AAAA,QAAA;AAEb,eAAA;AAAA,MACT;AAAA,MACA,CAAC,CAAA,GAAI,CAAA,GAAI,CAAE,CAAA;AAAA,IACb;AAAA,EACF;AAEM,QAAA,OAAO,YAAY,MAAM;AACzB,QAAA,KAAK,WAAW,EAAU,QAAA;AACxB,UAAA,UAAU,CAAC,GAAG,IAAI;AAClB,UAAA,OAAO,QAAQ,IAAI;AACzB,YAAQ,OAAO;AACf,cAAU,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC;AAEtB,WAAA,sBAAsB,KAAK,IAAI;AAAA,EAAA,GACrC,CAAC,IAAI,CAAC;AAEH,QAAA,OAAO,YAAY,MAAM;AACzB,QAAA,OAAO,WAAW,EAAU,QAAA;AAC1B,UAAA,YAAY,CAAC,GAAG,MAAM;AACtB,UAAA,OAAO,UAAU,IAAI;AAC3B,cAAU,SAAS;AACnB,YAAQ,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC;AACpB,WAAA,sBAAsB,KAAK,IAAI;AAAA,EAAA,GACrC,CAAC,MAAM,CAAC;AAGL,QAAA,uBAAuB,YAAY,CAAC,UAAkB;AAC1D,YAAQ,CAAC,SAAS,KAAK,MAAM,GAAG,KAAK,IAAI,GAAG,KAAK,SAAS,KAAK,CAAC,CAAC;AACjE,cAAU,CAAC,SAAS,KAAK,MAAM,GAAG,KAAK,IAAI,GAAG,KAAK,SAAS,KAAK,CAAC,CAAC;AAAA,EACrE,GAAG,EAAE;AAEC,QAAA,eAAe,YAAY,MAAM;AACrC,YAAQ,CAAA,CAAE;AACV,cAAU,CAAA,CAAE;AAAA,EACd,GAAG,EAAE;AAEE,SAAA;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,SAAS,KAAK,SAAS;AAAA,IACvB,SAAS,OAAO,SAAS;AAAA,IACzB;AAAA,IACA;AAAA,EACF;AACF;"}
|
|
@@ -4,18 +4,27 @@ const SelectionCellsContext = require("../context/SelectionCellsContext.cjs.js")
|
|
|
4
4
|
const CellEditingContext = require("../context/CellEditingContext.cjs.js");
|
|
5
5
|
const cellUtils = require("../utils/cellUtils.cjs.js");
|
|
6
6
|
const ProjectTableContext = require("../context/ProjectTableContext.cjs.js");
|
|
7
|
+
require("@ynput/ayon-react-components");
|
|
8
|
+
require("lodash");
|
|
9
|
+
require("react-toastify");
|
|
10
|
+
require("../../../util/pubsub.cjs.js");
|
|
11
|
+
const getEntityViewerIds = require("../utils/getEntityViewerIds.cjs.js");
|
|
7
12
|
function useKeyboardNavigation() {
|
|
8
|
-
const { attribFields } = ProjectTableContext.useProjectTableContext();
|
|
13
|
+
const { attribFields, getEntityById, onOpenPlayer, playerOpen } = ProjectTableContext.useProjectTableContext();
|
|
9
14
|
const { focusedCellId, gridMap, selectCell, focusCell, clearSelection, setFocusedCellId } = SelectionCellsContext.useSelectionCellsContext();
|
|
10
15
|
const { setEditingCellId, editingCellId } = CellEditingContext.useCellEditing();
|
|
11
16
|
const handleKeyDown = React.useCallback(
|
|
12
17
|
(e) => {
|
|
13
18
|
var _a;
|
|
14
19
|
const target = e.target;
|
|
15
|
-
if (!(target == null ? void 0 : target.closest("table")))
|
|
20
|
+
if (!(target == null ? void 0 : target.closest("table"))) {
|
|
21
|
+
console.log("Cell key event: target is not inside a table");
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
16
24
|
if (target.tagName === "INPUT" || target.tagName === "TEXTAREA" || target.isContentEditable || target.getAttribute("role") === "textbox" || target.tagName === "LI") {
|
|
17
25
|
return;
|
|
18
26
|
}
|
|
27
|
+
if (playerOpen && e.key !== "ArrowDown" && e.key !== "ArrowUp") return;
|
|
19
28
|
if (editingCellId) return;
|
|
20
29
|
if (!focusedCellId) return;
|
|
21
30
|
const position = cellUtils.parseCellId(focusedCellId);
|
|
@@ -25,6 +34,15 @@ function useKeyboardNavigation() {
|
|
|
25
34
|
const colIndex = gridMap.colIdToIndex.get(colId);
|
|
26
35
|
if (rowIndex === void 0 || colIndex === void 0) return;
|
|
27
36
|
const isReadOnly = colId.startsWith("attrib_") && ((_a = attribFields.find((a) => a.name === colId.replace("attrib_", ""))) == null ? void 0 : _a.readOnly);
|
|
37
|
+
const openPlayer = (entityId) => {
|
|
38
|
+
if (onOpenPlayer) {
|
|
39
|
+
const entity = getEntityById(entityId);
|
|
40
|
+
if (entity) {
|
|
41
|
+
const targetIds = getEntityViewerIds.getEntityViewierIds(entity);
|
|
42
|
+
onOpenPlayer(targetIds, { quickView: true });
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
};
|
|
28
46
|
switch (e.key) {
|
|
29
47
|
case "ArrowUp": {
|
|
30
48
|
e.preventDefault();
|
|
@@ -34,6 +52,9 @@ function useKeyboardNavigation() {
|
|
|
34
52
|
const newCellId = cellUtils.getCellId(newRowId, colId);
|
|
35
53
|
selectCell(newCellId, e.shiftKey, e.shiftKey);
|
|
36
54
|
focusCell(newCellId);
|
|
55
|
+
if (playerOpen) {
|
|
56
|
+
openPlayer(newRowId);
|
|
57
|
+
}
|
|
37
58
|
}
|
|
38
59
|
}
|
|
39
60
|
break;
|
|
@@ -45,6 +66,9 @@ function useKeyboardNavigation() {
|
|
|
45
66
|
const newCellId = cellUtils.getCellId(newRowId, colId);
|
|
46
67
|
selectCell(newCellId, e.shiftKey, e.shiftKey);
|
|
47
68
|
focusCell(newCellId);
|
|
69
|
+
if (playerOpen) {
|
|
70
|
+
openPlayer(newRowId);
|
|
71
|
+
}
|
|
48
72
|
}
|
|
49
73
|
break;
|
|
50
74
|
}
|
|
@@ -110,6 +134,10 @@ function useKeyboardNavigation() {
|
|
|
110
134
|
}
|
|
111
135
|
break;
|
|
112
136
|
}
|
|
137
|
+
case " ": {
|
|
138
|
+
e.preventDefault();
|
|
139
|
+
openPlayer(rowId);
|
|
140
|
+
}
|
|
113
141
|
}
|
|
114
142
|
},
|
|
115
143
|
[
|
|
@@ -119,7 +147,9 @@ function useKeyboardNavigation() {
|
|
|
119
147
|
focusCell,
|
|
120
148
|
clearSelection,
|
|
121
149
|
setEditingCellId,
|
|
122
|
-
editingCellId
|
|
150
|
+
editingCellId,
|
|
151
|
+
getEntityById,
|
|
152
|
+
playerOpen
|
|
123
153
|
]
|
|
124
154
|
);
|
|
125
155
|
React.useEffect(() => {
|
|
@@ -135,7 +165,8 @@ function useKeyboardNavigation() {
|
|
|
135
165
|
focusCell,
|
|
136
166
|
clearSelection,
|
|
137
167
|
setEditingCellId,
|
|
138
|
-
editingCellId
|
|
168
|
+
editingCellId,
|
|
169
|
+
playerOpen
|
|
139
170
|
]);
|
|
140
171
|
return {
|
|
141
172
|
handleKeyDown,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useKeyboardNavigation.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.ts"],"sourcesContent":["import { useCallback, useEffect } from 'react'\nimport { useSelectionCellsContext } from '../context/SelectionCellsContext'\nimport { useCellEditing } from '../context/CellEditingContext' // keep for editingCellId/setEditingCellId\nimport { parseCellId, getCellId } from '../utils/cellUtils'\nimport { useProjectTableContext } from '../context/ProjectTableContext'\n\nexport default function useKeyboardNavigation() {\n const { attribFields } = useProjectTableContext()\n\n const { focusedCellId, gridMap, selectCell, focusCell, clearSelection, setFocusedCellId } =\n useSelectionCellsContext()\n\n const { setEditingCellId, editingCellId } = useCellEditing()\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n if (!target?.closest('table')) return\n\n // Skip if event target is an input element or contentEditable\n if (\n target.tagName === 'INPUT' ||\n target.tagName === 'TEXTAREA' ||\n target.isContentEditable ||\n target.getAttribute('role') === 'textbox' ||\n target.tagName === 'LI'\n ) {\n return\n }\n\n if (editingCellId) return\n\n // Don't handle keyboard events if we don't have a focused cell\n if (!focusedCellId) return\n\n const position = parseCellId(focusedCellId)\n if (!position) return\n\n const { rowId, colId } = position\n const rowIndex = gridMap.rowIdToIndex.get(rowId)\n const colIndex = gridMap.colIdToIndex.get(colId)\n\n if (rowIndex === undefined || colIndex === undefined) return\n\n const isReadOnly =\n colId.startsWith('attrib_') &&\n attribFields.find((a) => a.name === colId.replace('attrib_', ''))?.readOnly\n\n // Handle different keys\n switch (e.key) {\n case 'ArrowUp': {\n e.preventDefault()\n if (rowIndex > 0) {\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n }\n break\n }\n case 'ArrowDown': {\n e.preventDefault()\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n break\n }\n case 'ArrowLeft': {\n e.preventDefault()\n if (colIndex > 0) {\n const newColId = gridMap.indexToColId.get(colIndex - 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n }\n break\n }\n case 'ArrowRight': {\n e.preventDefault()\n const newColId = gridMap.indexToColId.get(colIndex + 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n break\n }\n case 'Enter': {\n e.preventDefault()\n if (isReadOnly) return\n // Start editing the currently focused cell\n setEditingCellId(focusedCellId)\n break\n }\n case 'Escape': {\n e.preventDefault()\n // Clear selection and stop editing\n clearSelection()\n setEditingCellId(null)\n setFocusedCellId(null)\n break\n }\n case 'Tab': {\n e.preventDefault()\n // Move to next cell (right if no shift, left if shift)\n const nextColIndex = e.shiftKey ? colIndex - 1 : colIndex + 1\n const nextColId = gridMap.indexToColId.get(nextColIndex)\n\n if (nextColId) {\n // Move to next/prev column in same row\n const newCellId = getCellId(rowId, nextColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n } else if (!e.shiftKey && rowIndex < gridMap.rowIdToIndex.size - 1) {\n // Move to first column of next row\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n const firstColId = gridMap.indexToColId.get(0)\n if (newRowId && firstColId) {\n const newCellId = getCellId(newRowId, firstColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n } else if (e.shiftKey && rowIndex > 0) {\n // Move to last column of previous row\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n const lastColId = gridMap.indexToColId.get(gridMap.colIdToIndex.size - 1)\n if (newRowId && lastColId) {\n const newCellId = getCellId(newRowId, lastColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n }\n break\n }\n }\n },\n [\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n ],\n )\n\n // Attach the keydown event handler to the document\n useEffect(() => {\n document.addEventListener('keydown', handleKeyDown)\n\n // Cleanup the event listener on component unmount\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n ])\n return {\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n }\n}\n"],"names":["useProjectTableContext","useSelectionCellsContext","useCellEditing","useCallback","parseCellId","getCellId","useEffect"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useKeyboardNavigation.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.ts"],"sourcesContent":["import { useCallback, useEffect } from 'react'\nimport { useSelectionCellsContext } from '../context/SelectionCellsContext'\nimport { useCellEditing } from '../context/CellEditingContext' // keep for editingCellId/setEditingCellId\nimport { parseCellId, getCellId } from '../utils/cellUtils'\nimport { useProjectTableContext } from '../context/ProjectTableContext'\nimport { getEntityViewierIds } from '../utils'\n\nexport default function useKeyboardNavigation() {\n const { attribFields, getEntityById, onOpenPlayer, playerOpen } = useProjectTableContext()\n\n const { focusedCellId, gridMap, selectCell, focusCell, clearSelection, setFocusedCellId } =\n useSelectionCellsContext()\n\n const { setEditingCellId, editingCellId } = useCellEditing()\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n if (!target?.closest('table')) {\n console.log('Cell key event: target is not inside a table')\n return\n }\n\n // Skip if event target is an input element or contentEditable\n if (\n target.tagName === 'INPUT' ||\n target.tagName === 'TEXTAREA' ||\n target.isContentEditable ||\n target.getAttribute('role') === 'textbox' ||\n target.tagName === 'LI'\n ) {\n return\n }\n\n // allow keyboard and up and down only if the player is open\n if (playerOpen && e.key !== 'ArrowDown' && e.key !== 'ArrowUp') return\n\n if (editingCellId) return\n\n // Don't handle keyboard events if we don't have a focused cell\n if (!focusedCellId) return\n\n const position = parseCellId(focusedCellId)\n if (!position) return\n\n const { rowId, colId } = position\n const rowIndex = gridMap.rowIdToIndex.get(rowId)\n const colIndex = gridMap.colIdToIndex.get(colId)\n\n if (rowIndex === undefined || colIndex === undefined) return\n\n const isReadOnly =\n colId.startsWith('attrib_') &&\n attribFields.find((a) => a.name === colId.replace('attrib_', ''))?.readOnly\n\n const openPlayer = (entityId: string) => {\n // try to open the player if onOpenPlayer is defined\n if (onOpenPlayer) {\n const entity = getEntityById(entityId)\n if (entity) {\n const targetIds = getEntityViewierIds(entity)\n onOpenPlayer(targetIds, { quickView: true })\n }\n }\n }\n\n // Handle different keys\n switch (e.key) {\n case 'ArrowUp': {\n e.preventDefault()\n if (rowIndex > 0) {\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n\n // if the player is open, update with new selected cell\n if (playerOpen) {\n openPlayer(newRowId)\n }\n }\n }\n break\n }\n case 'ArrowDown': {\n e.preventDefault()\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n\n // if the player is open, update with new selected cell\n if (playerOpen) {\n openPlayer(newRowId)\n }\n }\n break\n }\n case 'ArrowLeft': {\n e.preventDefault()\n if (colIndex > 0) {\n const newColId = gridMap.indexToColId.get(colIndex - 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n }\n break\n }\n case 'ArrowRight': {\n e.preventDefault()\n const newColId = gridMap.indexToColId.get(colIndex + 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n break\n }\n case 'Enter': {\n e.preventDefault()\n if (isReadOnly) return\n // Start editing the currently focused cell\n setEditingCellId(focusedCellId)\n break\n }\n case 'Escape': {\n e.preventDefault()\n // Clear selection and stop editing\n clearSelection()\n setEditingCellId(null)\n setFocusedCellId(null)\n break\n }\n case 'Tab': {\n e.preventDefault()\n // Move to next cell (right if no shift, left if shift)\n const nextColIndex = e.shiftKey ? colIndex - 1 : colIndex + 1\n const nextColId = gridMap.indexToColId.get(nextColIndex)\n\n if (nextColId) {\n // Move to next/prev column in same row\n const newCellId = getCellId(rowId, nextColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n } else if (!e.shiftKey && rowIndex < gridMap.rowIdToIndex.size - 1) {\n // Move to first column of next row\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n const firstColId = gridMap.indexToColId.get(0)\n if (newRowId && firstColId) {\n const newCellId = getCellId(newRowId, firstColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n } else if (e.shiftKey && rowIndex > 0) {\n // Move to last column of previous row\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n const lastColId = gridMap.indexToColId.get(gridMap.colIdToIndex.size - 1)\n if (newRowId && lastColId) {\n const newCellId = getCellId(newRowId, lastColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n }\n break\n }\n case ' ': {\n e.preventDefault()\n // attempt to open the player\n openPlayer(rowId)\n }\n }\n },\n [\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n getEntityById,\n playerOpen,\n ],\n )\n\n // Attach the keydown event handler to the document\n useEffect(() => {\n document.addEventListener('keydown', handleKeyDown)\n\n // Cleanup the event listener on component unmount\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n playerOpen,\n ])\n return {\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n }\n}\n"],"names":["useProjectTableContext","useSelectionCellsContext","useCellEditing","useCallback","parseCellId","getEntityViewierIds","getCellId","useEffect"],"mappings":"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"}
|
|
@@ -3,18 +3,27 @@ import { useSelectionCellsContext } from "../context/SelectionCellsContext.es.js
|
|
|
3
3
|
import { useCellEditing } from "../context/CellEditingContext.es.js";
|
|
4
4
|
import { parseCellId, getCellId } from "../utils/cellUtils.es.js";
|
|
5
5
|
import { useProjectTableContext } from "../context/ProjectTableContext.es.js";
|
|
6
|
+
import "@ynput/ayon-react-components";
|
|
7
|
+
import "lodash";
|
|
8
|
+
import "react-toastify";
|
|
9
|
+
import "../../../util/pubsub.es.js";
|
|
10
|
+
import { getEntityViewierIds } from "../utils/getEntityViewerIds.es.js";
|
|
6
11
|
function useKeyboardNavigation() {
|
|
7
|
-
const { attribFields } = useProjectTableContext();
|
|
12
|
+
const { attribFields, getEntityById, onOpenPlayer, playerOpen } = useProjectTableContext();
|
|
8
13
|
const { focusedCellId, gridMap, selectCell, focusCell, clearSelection, setFocusedCellId } = useSelectionCellsContext();
|
|
9
14
|
const { setEditingCellId, editingCellId } = useCellEditing();
|
|
10
15
|
const handleKeyDown = useCallback(
|
|
11
16
|
(e) => {
|
|
12
17
|
var _a;
|
|
13
18
|
const target = e.target;
|
|
14
|
-
if (!(target == null ? void 0 : target.closest("table")))
|
|
19
|
+
if (!(target == null ? void 0 : target.closest("table"))) {
|
|
20
|
+
console.log("Cell key event: target is not inside a table");
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
15
23
|
if (target.tagName === "INPUT" || target.tagName === "TEXTAREA" || target.isContentEditable || target.getAttribute("role") === "textbox" || target.tagName === "LI") {
|
|
16
24
|
return;
|
|
17
25
|
}
|
|
26
|
+
if (playerOpen && e.key !== "ArrowDown" && e.key !== "ArrowUp") return;
|
|
18
27
|
if (editingCellId) return;
|
|
19
28
|
if (!focusedCellId) return;
|
|
20
29
|
const position = parseCellId(focusedCellId);
|
|
@@ -24,6 +33,15 @@ function useKeyboardNavigation() {
|
|
|
24
33
|
const colIndex = gridMap.colIdToIndex.get(colId);
|
|
25
34
|
if (rowIndex === void 0 || colIndex === void 0) return;
|
|
26
35
|
const isReadOnly = colId.startsWith("attrib_") && ((_a = attribFields.find((a) => a.name === colId.replace("attrib_", ""))) == null ? void 0 : _a.readOnly);
|
|
36
|
+
const openPlayer = (entityId) => {
|
|
37
|
+
if (onOpenPlayer) {
|
|
38
|
+
const entity = getEntityById(entityId);
|
|
39
|
+
if (entity) {
|
|
40
|
+
const targetIds = getEntityViewierIds(entity);
|
|
41
|
+
onOpenPlayer(targetIds, { quickView: true });
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
};
|
|
27
45
|
switch (e.key) {
|
|
28
46
|
case "ArrowUp": {
|
|
29
47
|
e.preventDefault();
|
|
@@ -33,6 +51,9 @@ function useKeyboardNavigation() {
|
|
|
33
51
|
const newCellId = getCellId(newRowId, colId);
|
|
34
52
|
selectCell(newCellId, e.shiftKey, e.shiftKey);
|
|
35
53
|
focusCell(newCellId);
|
|
54
|
+
if (playerOpen) {
|
|
55
|
+
openPlayer(newRowId);
|
|
56
|
+
}
|
|
36
57
|
}
|
|
37
58
|
}
|
|
38
59
|
break;
|
|
@@ -44,6 +65,9 @@ function useKeyboardNavigation() {
|
|
|
44
65
|
const newCellId = getCellId(newRowId, colId);
|
|
45
66
|
selectCell(newCellId, e.shiftKey, e.shiftKey);
|
|
46
67
|
focusCell(newCellId);
|
|
68
|
+
if (playerOpen) {
|
|
69
|
+
openPlayer(newRowId);
|
|
70
|
+
}
|
|
47
71
|
}
|
|
48
72
|
break;
|
|
49
73
|
}
|
|
@@ -109,6 +133,10 @@ function useKeyboardNavigation() {
|
|
|
109
133
|
}
|
|
110
134
|
break;
|
|
111
135
|
}
|
|
136
|
+
case " ": {
|
|
137
|
+
e.preventDefault();
|
|
138
|
+
openPlayer(rowId);
|
|
139
|
+
}
|
|
112
140
|
}
|
|
113
141
|
},
|
|
114
142
|
[
|
|
@@ -118,7 +146,9 @@ function useKeyboardNavigation() {
|
|
|
118
146
|
focusCell,
|
|
119
147
|
clearSelection,
|
|
120
148
|
setEditingCellId,
|
|
121
|
-
editingCellId
|
|
149
|
+
editingCellId,
|
|
150
|
+
getEntityById,
|
|
151
|
+
playerOpen
|
|
122
152
|
]
|
|
123
153
|
);
|
|
124
154
|
useEffect(() => {
|
|
@@ -134,7 +164,8 @@ function useKeyboardNavigation() {
|
|
|
134
164
|
focusCell,
|
|
135
165
|
clearSelection,
|
|
136
166
|
setEditingCellId,
|
|
137
|
-
editingCellId
|
|
167
|
+
editingCellId,
|
|
168
|
+
playerOpen
|
|
138
169
|
]);
|
|
139
170
|
return {
|
|
140
171
|
handleKeyDown,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useKeyboardNavigation.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.ts"],"sourcesContent":["import { useCallback, useEffect } from 'react'\nimport { useSelectionCellsContext } from '../context/SelectionCellsContext'\nimport { useCellEditing } from '../context/CellEditingContext' // keep for editingCellId/setEditingCellId\nimport { parseCellId, getCellId } from '../utils/cellUtils'\nimport { useProjectTableContext } from '../context/ProjectTableContext'\n\nexport default function useKeyboardNavigation() {\n const { attribFields } = useProjectTableContext()\n\n const { focusedCellId, gridMap, selectCell, focusCell, clearSelection, setFocusedCellId } =\n useSelectionCellsContext()\n\n const { setEditingCellId, editingCellId } = useCellEditing()\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n if (!target?.closest('table')) return\n\n // Skip if event target is an input element or contentEditable\n if (\n target.tagName === 'INPUT' ||\n target.tagName === 'TEXTAREA' ||\n target.isContentEditable ||\n target.getAttribute('role') === 'textbox' ||\n target.tagName === 'LI'\n ) {\n return\n }\n\n if (editingCellId) return\n\n // Don't handle keyboard events if we don't have a focused cell\n if (!focusedCellId) return\n\n const position = parseCellId(focusedCellId)\n if (!position) return\n\n const { rowId, colId } = position\n const rowIndex = gridMap.rowIdToIndex.get(rowId)\n const colIndex = gridMap.colIdToIndex.get(colId)\n\n if (rowIndex === undefined || colIndex === undefined) return\n\n const isReadOnly =\n colId.startsWith('attrib_') &&\n attribFields.find((a) => a.name === colId.replace('attrib_', ''))?.readOnly\n\n // Handle different keys\n switch (e.key) {\n case 'ArrowUp': {\n e.preventDefault()\n if (rowIndex > 0) {\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n }\n break\n }\n case 'ArrowDown': {\n e.preventDefault()\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n break\n }\n case 'ArrowLeft': {\n e.preventDefault()\n if (colIndex > 0) {\n const newColId = gridMap.indexToColId.get(colIndex - 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n }\n break\n }\n case 'ArrowRight': {\n e.preventDefault()\n const newColId = gridMap.indexToColId.get(colIndex + 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n break\n }\n case 'Enter': {\n e.preventDefault()\n if (isReadOnly) return\n // Start editing the currently focused cell\n setEditingCellId(focusedCellId)\n break\n }\n case 'Escape': {\n e.preventDefault()\n // Clear selection and stop editing\n clearSelection()\n setEditingCellId(null)\n setFocusedCellId(null)\n break\n }\n case 'Tab': {\n e.preventDefault()\n // Move to next cell (right if no shift, left if shift)\n const nextColIndex = e.shiftKey ? colIndex - 1 : colIndex + 1\n const nextColId = gridMap.indexToColId.get(nextColIndex)\n\n if (nextColId) {\n // Move to next/prev column in same row\n const newCellId = getCellId(rowId, nextColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n } else if (!e.shiftKey && rowIndex < gridMap.rowIdToIndex.size - 1) {\n // Move to first column of next row\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n const firstColId = gridMap.indexToColId.get(0)\n if (newRowId && firstColId) {\n const newCellId = getCellId(newRowId, firstColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n } else if (e.shiftKey && rowIndex > 0) {\n // Move to last column of previous row\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n const lastColId = gridMap.indexToColId.get(gridMap.colIdToIndex.size - 1)\n if (newRowId && lastColId) {\n const newCellId = getCellId(newRowId, lastColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n }\n break\n }\n }\n },\n [\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n ],\n )\n\n // Attach the keydown event handler to the document\n useEffect(() => {\n document.addEventListener('keydown', handleKeyDown)\n\n // Cleanup the event listener on component unmount\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n ])\n return {\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n }\n}\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"useKeyboardNavigation.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.ts"],"sourcesContent":["import { useCallback, useEffect } from 'react'\nimport { useSelectionCellsContext } from '../context/SelectionCellsContext'\nimport { useCellEditing } from '../context/CellEditingContext' // keep for editingCellId/setEditingCellId\nimport { parseCellId, getCellId } from '../utils/cellUtils'\nimport { useProjectTableContext } from '../context/ProjectTableContext'\nimport { getEntityViewierIds } from '../utils'\n\nexport default function useKeyboardNavigation() {\n const { attribFields, getEntityById, onOpenPlayer, playerOpen } = useProjectTableContext()\n\n const { focusedCellId, gridMap, selectCell, focusCell, clearSelection, setFocusedCellId } =\n useSelectionCellsContext()\n\n const { setEditingCellId, editingCellId } = useCellEditing()\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n if (!target?.closest('table')) {\n console.log('Cell key event: target is not inside a table')\n return\n }\n\n // Skip if event target is an input element or contentEditable\n if (\n target.tagName === 'INPUT' ||\n target.tagName === 'TEXTAREA' ||\n target.isContentEditable ||\n target.getAttribute('role') === 'textbox' ||\n target.tagName === 'LI'\n ) {\n return\n }\n\n // allow keyboard and up and down only if the player is open\n if (playerOpen && e.key !== 'ArrowDown' && e.key !== 'ArrowUp') return\n\n if (editingCellId) return\n\n // Don't handle keyboard events if we don't have a focused cell\n if (!focusedCellId) return\n\n const position = parseCellId(focusedCellId)\n if (!position) return\n\n const { rowId, colId } = position\n const rowIndex = gridMap.rowIdToIndex.get(rowId)\n const colIndex = gridMap.colIdToIndex.get(colId)\n\n if (rowIndex === undefined || colIndex === undefined) return\n\n const isReadOnly =\n colId.startsWith('attrib_') &&\n attribFields.find((a) => a.name === colId.replace('attrib_', ''))?.readOnly\n\n const openPlayer = (entityId: string) => {\n // try to open the player if onOpenPlayer is defined\n if (onOpenPlayer) {\n const entity = getEntityById(entityId)\n if (entity) {\n const targetIds = getEntityViewierIds(entity)\n onOpenPlayer(targetIds, { quickView: true })\n }\n }\n }\n\n // Handle different keys\n switch (e.key) {\n case 'ArrowUp': {\n e.preventDefault()\n if (rowIndex > 0) {\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n\n // if the player is open, update with new selected cell\n if (playerOpen) {\n openPlayer(newRowId)\n }\n }\n }\n break\n }\n case 'ArrowDown': {\n e.preventDefault()\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, colId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n\n // if the player is open, update with new selected cell\n if (playerOpen) {\n openPlayer(newRowId)\n }\n }\n break\n }\n case 'ArrowLeft': {\n e.preventDefault()\n if (colIndex > 0) {\n const newColId = gridMap.indexToColId.get(colIndex - 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n }\n break\n }\n case 'ArrowRight': {\n e.preventDefault()\n const newColId = gridMap.indexToColId.get(colIndex + 1)\n if (newColId) {\n const newCellId = getCellId(rowId, newColId)\n selectCell(newCellId, e.shiftKey, e.shiftKey)\n focusCell(newCellId)\n }\n break\n }\n case 'Enter': {\n e.preventDefault()\n if (isReadOnly) return\n // Start editing the currently focused cell\n setEditingCellId(focusedCellId)\n break\n }\n case 'Escape': {\n e.preventDefault()\n // Clear selection and stop editing\n clearSelection()\n setEditingCellId(null)\n setFocusedCellId(null)\n break\n }\n case 'Tab': {\n e.preventDefault()\n // Move to next cell (right if no shift, left if shift)\n const nextColIndex = e.shiftKey ? colIndex - 1 : colIndex + 1\n const nextColId = gridMap.indexToColId.get(nextColIndex)\n\n if (nextColId) {\n // Move to next/prev column in same row\n const newCellId = getCellId(rowId, nextColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n } else if (!e.shiftKey && rowIndex < gridMap.rowIdToIndex.size - 1) {\n // Move to first column of next row\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n const firstColId = gridMap.indexToColId.get(0)\n if (newRowId && firstColId) {\n const newCellId = getCellId(newRowId, firstColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n } else if (e.shiftKey && rowIndex > 0) {\n // Move to last column of previous row\n const newRowId = gridMap.indexToRowId.get(rowIndex - 1)\n const lastColId = gridMap.indexToColId.get(gridMap.colIdToIndex.size - 1)\n if (newRowId && lastColId) {\n const newCellId = getCellId(newRowId, lastColId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n }\n }\n break\n }\n case ' ': {\n e.preventDefault()\n // attempt to open the player\n openPlayer(rowId)\n }\n }\n },\n [\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n getEntityById,\n playerOpen,\n ],\n )\n\n // Attach the keydown event handler to the document\n useEffect(() => {\n document.addEventListener('keydown', handleKeyDown)\n\n // Cleanup the event listener on component unmount\n return () => {\n document.removeEventListener('keydown', handleKeyDown)\n }\n }, [\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n playerOpen,\n ])\n return {\n handleKeyDown,\n focusedCellId,\n gridMap,\n selectCell,\n focusCell,\n clearSelection,\n setEditingCellId,\n editingCellId,\n }\n}\n"],"names":[],"mappings":"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"}
|