@ynput/ayon-frontend-shared 0.2.16 → 0.2.17
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 +9 -10
- package/dist/DetailsPanel.cjs.js.map +1 -1
- package/dist/DetailsPanel.es.js +9 -10
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/ProjectTreeTable.cjs.js +38 -34
- package/dist/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/ProjectTreeTable.es.js +20 -16
- package/dist/ProjectTreeTable.es.js.map +1 -1
- package/dist/_virtual/index.cjs10.js +4 -4
- package/dist/_virtual/index.cjs5.js +5 -3
- package/dist/_virtual/index.cjs5.js.map +1 -1
- package/dist/_virtual/index.cjs6.js +3 -5
- package/dist/_virtual/index.cjs6.js.map +1 -1
- package/dist/_virtual/index.cjs8.js +4 -4
- package/dist/_virtual/index.cjs9.js +4 -4
- package/dist/_virtual/index.es10.js +4 -4
- package/dist/_virtual/index.es5.js +5 -2
- package/dist/_virtual/index.es5.js.map +1 -1
- package/dist/_virtual/index.es6.js +2 -5
- package/dist/_virtual/index.es6.js.map +1 -1
- package/dist/_virtual/index.es8.js +4 -4
- package/dist/_virtual/index.es9.js +4 -4
- package/dist/index.cjs.js +6 -7
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +6 -7
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.cjs.js +1 -2
- package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.cjs.js.map +1 -1
- package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.es.js +1 -2
- package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.es.js.map +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +2 -2
- package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
- package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
- package/dist/node_modules/remove-accents/index.cjs.js +1 -1
- package/dist/node_modules/remove-accents/index.es.js +1 -1
- package/dist/node_modules/vfile/lib/index.cjs.js +1 -1
- package/dist/node_modules/vfile/lib/index.es.js +1 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js +6 -7
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js +6 -7
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.cjs.js +2 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.es.js +2 -0
- package/dist/shared/src/components/ProjectTableSettings/ColumnItem.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js +5 -1
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js +5 -1
- package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +21 -86
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +21 -86
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.cjs.js +2 -0
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.es.js +2 -0
- package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +6 -7
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +6 -7
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +6 -7
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +6 -7
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +6 -7
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +6 -7
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js +27 -6
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js +27 -6
- package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +6 -7
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +6 -7
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +6 -7
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +6 -7
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +6 -7
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +6 -7
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +9 -10
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +9 -10
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +6 -7
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +6 -7
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +6 -7
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +6 -7
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +5 -6
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +5 -6
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +16 -9
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +16 -9
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +5 -7
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +5 -7
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js +1 -174
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js +2 -175
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js +212 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js +212 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js +1 -185
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js +2 -186
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +191 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +191 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.cjs.js +1 -79
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.es.js +2 -80
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.cjs.js +84 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.es.js +84 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js +1 -277
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js +2 -278
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +282 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +282 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +8 -175
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +8 -175
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/{context/ProjectTableModulesContext.cjs.js → hooks/useProjectTableModules.cjs.js} +26 -48
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/{context/ProjectTableModulesContext.es.js → hooks/useProjectTableModules.es.js} +26 -48
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +4 -3
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +4 -3
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +8 -5
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +7 -4
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +7 -8
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +7 -8
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.es.js +1 -1
- package/dist/shared/src/hooks/useLoadModule.cjs.js +3 -3
- package/dist/shared/src/hooks/useLoadModule.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useLoadModule.es.js +3 -3
- package/dist/shared/src/hooks/useLoadModule.es.js.map +1 -1
- package/dist/types/components/ProjectTableSettings/ColumnItem.d.ts +1 -0
- package/dist/types/components/ProjectTableSettings/SortableColumnItem.d.ts +1 -0
- package/dist/types/components/SettingsPanel/SettingsPanelItemTemplate.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/components/GroupSettingsFallback.d.ts +9 -2
- package/dist/types/containers/ProjectTreeTable/context/ColumnSettingsContext.d.ts +16 -16
- package/dist/types/containers/ProjectTreeTable/context/ColumnSettingsProvider.d.ts +9 -0
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +5 -61
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +59 -0
- package/dist/types/containers/ProjectTreeTable/context/SelectedRowsContext.d.ts +3 -8
- package/dist/types/containers/ProjectTreeTable/context/SelectedRowsProvider.d.ts +6 -0
- package/dist/types/containers/ProjectTreeTable/context/SelectionCellsContext.d.ts +2 -4
- package/dist/types/containers/ProjectTreeTable/context/SelectionCellsProvider.d.ts +4 -0
- package/dist/types/containers/ProjectTreeTable/context/index.d.ts +4 -2
- package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.d.ts +1 -2
- package/dist/types/containers/ProjectTreeTable/hooks/useEntitiesMap.d.ts +1 -1
- package/dist/types/containers/ProjectTreeTable/hooks/useFetchOverviewData.d.ts +4 -3
- package/dist/types/containers/ProjectTreeTable/hooks/useGetGroupedFields.d.ts +1 -1
- package/dist/types/containers/ProjectTreeTable/{context/ProjectTableModulesContext.d.ts → hooks/useProjectTableModules.d.ts} +5 -12
- package/dist/types/containers/ProjectTreeTable/index.d.ts +1 -10
- package/dist/types/containers/ProjectTreeTable/types/overviewContext.d.ts +3 -3
- package/package.json +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.cjs.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.es.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.cjs.js +0 -33
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.cjs.js.map +0 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.es.js +0 -33
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.es.js.map +0 -1
- package/dist/types/containers/ProjectTreeTable/context/ProjectTableSelectionContext.d.ts +0 -11
|
@@ -1,190 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const jsxRuntime = require("../../../../../_virtual/jsx-runtime.cjs.js");
|
|
4
3
|
const React = require("react");
|
|
5
|
-
const useBuildProjectDataTable = require("../hooks/useBuildProjectDataTable.cjs.js");
|
|
6
|
-
const useFolderRelationships = require("../hooks/useFolderRelationships.cjs.js");
|
|
7
|
-
const useBuildGroupByTableData = require("../hooks/useBuildGroupByTableData.cjs.js");
|
|
8
|
-
const ColumnSettingsContext = require("./ColumnSettingsContext.cjs.js");
|
|
9
|
-
const parseRowId = (rowId) => rowId.split(useBuildGroupByTableData.ROW_ID_SEPARATOR)[0] || rowId;
|
|
10
4
|
const ProjectTableContext = React.createContext(void 0);
|
|
11
|
-
const ProjectTableProvider = ({
|
|
12
|
-
children,
|
|
13
|
-
foldersMap,
|
|
14
|
-
tableRows,
|
|
15
|
-
tasksMap,
|
|
16
|
-
entitiesMap,
|
|
17
|
-
tasksByFolderMap,
|
|
18
|
-
expanded,
|
|
19
|
-
projectInfo,
|
|
20
|
-
showHierarchy,
|
|
21
|
-
loadingTasks,
|
|
22
|
-
isLoadingMore,
|
|
23
|
-
isLoading,
|
|
24
|
-
error,
|
|
25
|
-
isInitialized,
|
|
26
|
-
projectName,
|
|
27
|
-
users,
|
|
28
|
-
attribFields,
|
|
29
|
-
taskGroups,
|
|
30
|
-
filters,
|
|
31
|
-
setFilters,
|
|
32
|
-
queryFilters,
|
|
33
|
-
updateShowHierarchy,
|
|
34
|
-
toggleExpanded,
|
|
35
|
-
updateExpanded,
|
|
36
|
-
sorting,
|
|
37
|
-
updateSorting,
|
|
38
|
-
fetchNextPage,
|
|
39
|
-
reloadTableData,
|
|
40
|
-
setExpanded,
|
|
41
|
-
contextMenuItems,
|
|
42
|
-
powerpack,
|
|
43
|
-
modules,
|
|
44
|
-
groupByConfig
|
|
45
|
-
}) => {
|
|
46
|
-
const defaultTableData = useBuildProjectDataTable({
|
|
47
|
-
foldersMap,
|
|
48
|
-
tasksMap,
|
|
49
|
-
rows: tableRows,
|
|
50
|
-
tasksByFolderMap,
|
|
51
|
-
expanded,
|
|
52
|
-
projectInfo,
|
|
53
|
-
showHierarchy,
|
|
54
|
-
loadingTasks,
|
|
55
|
-
isLoadingMore
|
|
56
|
-
});
|
|
57
|
-
const { groupBy } = ColumnSettingsContext.useColumnSettingsContext();
|
|
58
|
-
const buildGroupByTableData = useBuildGroupByTableData.default({
|
|
59
|
-
entities: entitiesMap,
|
|
60
|
-
entityType: groupByConfig == null ? void 0 : groupByConfig.entityType,
|
|
61
|
-
groups: taskGroups,
|
|
62
|
-
project: projectInfo,
|
|
63
|
-
attribFields
|
|
64
|
-
});
|
|
65
|
-
const groupedTableData = React.useMemo(
|
|
66
|
-
() => !!groupBy && buildGroupByTableData(groupBy),
|
|
67
|
-
[groupBy, entitiesMap, taskGroups]
|
|
68
|
-
);
|
|
69
|
-
const tableData = groupBy && groupedTableData ? groupedTableData : defaultTableData;
|
|
70
|
-
const getEntityById = React.useCallback(
|
|
71
|
-
(id) => {
|
|
72
|
-
const parsedId = parseRowId(id);
|
|
73
|
-
if (foldersMap.has(parsedId)) {
|
|
74
|
-
return foldersMap.get(parsedId);
|
|
75
|
-
} else if (tasksMap.has(parsedId)) {
|
|
76
|
-
return tasksMap.get(parsedId);
|
|
77
|
-
} else if (entitiesMap.has(parsedId)) {
|
|
78
|
-
return entitiesMap.get(parsedId);
|
|
79
|
-
}
|
|
80
|
-
return void 0;
|
|
81
|
-
},
|
|
82
|
-
[foldersMap, tasksMap, entitiesMap]
|
|
83
|
-
);
|
|
84
|
-
const {
|
|
85
|
-
getInheritedDependents,
|
|
86
|
-
getChildrenEntities,
|
|
87
|
-
findInheritedValueFromAncestors,
|
|
88
|
-
findNonInheritedValues,
|
|
89
|
-
getAncestorsOf
|
|
90
|
-
} = useFolderRelationships({
|
|
91
|
-
entitiesMap,
|
|
92
|
-
tasksMap,
|
|
93
|
-
tasksByFolderMap,
|
|
94
|
-
getEntityById,
|
|
95
|
-
projectAttrib: projectInfo == null ? void 0 : projectInfo.attrib,
|
|
96
|
-
attribFields
|
|
97
|
-
});
|
|
98
|
-
const toggleExpandAll = React.useCallback(
|
|
99
|
-
(rowIds, expandAll) => {
|
|
100
|
-
const expandedState = typeof expanded === "object" ? expanded : {};
|
|
101
|
-
const newExpandedState = { ...expandedState };
|
|
102
|
-
rowIds.forEach((rowId) => {
|
|
103
|
-
const childIds = getChildrenEntities(rowId).map((child) => child.id);
|
|
104
|
-
const isExpanded = expandedState[rowId] || false;
|
|
105
|
-
if (expandAll !== void 0 ? !expandAll : isExpanded) {
|
|
106
|
-
newExpandedState[rowId] = false;
|
|
107
|
-
childIds.forEach((id) => {
|
|
108
|
-
newExpandedState[id] = false;
|
|
109
|
-
});
|
|
110
|
-
} else {
|
|
111
|
-
newExpandedState[rowId] = true;
|
|
112
|
-
childIds.forEach((id) => {
|
|
113
|
-
newExpandedState[id] = true;
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
setExpanded(newExpandedState);
|
|
118
|
-
},
|
|
119
|
-
[expanded, getChildrenEntities, setExpanded]
|
|
120
|
-
);
|
|
121
|
-
const toggleExpands = React.useCallback(
|
|
122
|
-
(rowIds, expand) => {
|
|
123
|
-
const expandedState = typeof expanded === "object" ? expanded : {};
|
|
124
|
-
const newExpandedState = { ...expandedState };
|
|
125
|
-
rowIds.forEach((rowId) => {
|
|
126
|
-
if (expand !== void 0) {
|
|
127
|
-
newExpandedState[rowId] = expand;
|
|
128
|
-
} else {
|
|
129
|
-
newExpandedState[rowId] = !expandedState[rowId];
|
|
130
|
-
}
|
|
131
|
-
});
|
|
132
|
-
setExpanded(newExpandedState);
|
|
133
|
-
},
|
|
134
|
-
[expanded, setExpanded]
|
|
135
|
-
);
|
|
136
|
-
return /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
|
|
137
|
-
ProjectTableContext.Provider,
|
|
138
|
-
{
|
|
139
|
-
value: {
|
|
140
|
-
// from this context
|
|
141
|
-
tableData,
|
|
142
|
-
// forwarded on
|
|
143
|
-
isInitialized,
|
|
144
|
-
isLoading,
|
|
145
|
-
error,
|
|
146
|
-
projectInfo,
|
|
147
|
-
attribFields,
|
|
148
|
-
users,
|
|
149
|
-
projectName,
|
|
150
|
-
tasksMap,
|
|
151
|
-
foldersMap,
|
|
152
|
-
entitiesMap,
|
|
153
|
-
fetchNextPage,
|
|
154
|
-
reloadTableData,
|
|
155
|
-
taskGroups,
|
|
156
|
-
// filters
|
|
157
|
-
filters,
|
|
158
|
-
setFilters,
|
|
159
|
-
queryFilters,
|
|
160
|
-
// hierarchy
|
|
161
|
-
showHierarchy,
|
|
162
|
-
updateShowHierarchy,
|
|
163
|
-
// expanded state
|
|
164
|
-
expanded,
|
|
165
|
-
toggleExpanded,
|
|
166
|
-
updateExpanded,
|
|
167
|
-
toggleExpandAll,
|
|
168
|
-
toggleExpands,
|
|
169
|
-
// sorting
|
|
170
|
-
sorting,
|
|
171
|
-
updateSorting,
|
|
172
|
-
getEntityById,
|
|
173
|
-
// folder relationships
|
|
174
|
-
getInheritedDependents,
|
|
175
|
-
findInheritedValueFromAncestors,
|
|
176
|
-
findNonInheritedValues,
|
|
177
|
-
getAncestorsOf,
|
|
178
|
-
// context menu
|
|
179
|
-
contextMenuItems,
|
|
180
|
-
// powerpack context
|
|
181
|
-
powerpack,
|
|
182
|
-
modules
|
|
183
|
-
},
|
|
184
|
-
children
|
|
185
|
-
}
|
|
186
|
-
);
|
|
187
|
-
};
|
|
188
5
|
const useProjectTableContext = () => {
|
|
189
6
|
const context = React.useContext(ProjectTableContext);
|
|
190
7
|
if (!context) {
|
|
@@ -192,7 +9,6 @@ const useProjectTableContext = () => {
|
|
|
192
9
|
}
|
|
193
10
|
return context;
|
|
194
11
|
};
|
|
195
|
-
exports.
|
|
196
|
-
exports.parseRowId = parseRowId;
|
|
12
|
+
exports.ProjectTableContext = ProjectTableContext;
|
|
197
13
|
exports.useProjectTableContext = useProjectTableContext;
|
|
198
14
|
//# sourceMappingURL=ProjectTableContext.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProjectTableContext.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/context/ProjectTableContext.tsx"],"sourcesContent":["/**\n * Project Table Context\n *\n * This context serves as the central data management layer for the project table component.\n * It performs three main functions:\n *\n * 1. **Props Forwarding**: Acts as a bridge to forward essential props (project info, users,\n * attributes, filters, etc.) down to child components throughout the table hierarchy.\n *\n * 2. **Table Data Structure Building**: Transforms raw project data into structured table rows\n * that can be consumed by the table component. This includes processing folders, tasks,\n * and entities into a unified table format.\n *\n * 3. **Multi-Modal Data Presentation**: Supports three different data presentation modes:\n * - **Hierarchy Mode**: Builds nested folder/task relationships with expandable rows\n * - **Tasks List Mode**: Flattened view of tasks without hierarchical structure\n * - **Groups Mode**: Groups entities by specified criteria (entity type, custom groups)\n *\n * The context also provides utility functions for entity relationships, expansion state\n * management, filtering, sorting, and folder inheritance operations.\n */\nimport { createContext, ReactNode, useCallback, useContext, useMemo } from 'react'\nimport { ExpandedState, OnChangeFn, SortingState } from '@tanstack/react-table'\nimport useBuildProjectDataTable from '../hooks/useBuildProjectDataTable'\nimport { Filter } from '@ynput/ayon-react-components'\nimport {\n EntitiesMap,\n EntityMap,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport useFolderRelationships, {\n FindInheritedValueFromAncestors,\n GetAncestorsOf,\n GetInheritedDependents,\n FindNonInheritedValues,\n} from '../hooks/useFolderRelationships'\nimport { RowId } from '../utils/cellUtils'\nimport { ProjectModel } from '../types/project'\nimport { ProjectTableAttribute, LoadingTasks } from '../types'\nimport { QueryFilter } from '../types/folders'\nimport { ContextMenuItemConstructors } from '../hooks/useCellContextMenu'\nimport { EntityGroup } from '@shared/api'\nimport useBuildGroupByTableData, {\n GroupByEntityType,\n ROW_ID_SEPARATOR,\n} from '../hooks/useBuildGroupByTableData'\nimport { PowerpackContextType } from '@shared/context'\nimport { ProjectTableModuleContextType } from './ProjectTableModulesContext'\nimport { useColumnSettingsContext } from './ColumnSettingsContext'\n\nexport const parseRowId = (rowId: string) => rowId.split(ROW_ID_SEPARATOR)[0] || rowId\n\nexport type TableUser = {\n name: string\n fullName?: string\n}\n\nexport type ToggleExpandAll = (rowIds: RowId[], expand?: boolean) => void\nexport type ToggleExpands = (rowIds: RowId[], expand?: boolean) => void\n\nexport interface ProjectTableProviderProps {\n children: ReactNode\n isInitialized: boolean\n\n // loading\n isLoading: boolean\n isLoadingMore: boolean\n loadingTasks?: LoadingTasks\n error?: string\n // Project Info\n projectInfo?: ProjectModel\n projectName: string\n users: TableUser[]\n // Attributes\n attribFields: ProjectTableAttribute[]\n\n // data\n tasksMap: TaskNodeMap\n foldersMap: FolderNodeMap\n entitiesMap: EntitiesMap\n tasksByFolderMap: TasksByFolderMap\n tableRows?: TableRow[] // any extra rows that we want to add to the table\n\n // grouping\n taskGroups: EntityGroup[]\n\n // data functions\n fetchNextPage: (value?: string) => void\n reloadTableData: () => void\n\n // Filters\n filters: Filter[]\n setFilters: (filters: Filter[]) => void\n queryFilters: {\n filter: QueryFilter | undefined\n filterString?: string\n search: string | undefined\n }\n\n // Hierarchy\n showHierarchy: boolean\n updateShowHierarchy: (showHierarchy: boolean) => void\n\n // Expanded state\n expanded: ExpandedState\n toggleExpanded: (id: string) => void\n updateExpanded: OnChangeFn<ExpandedState>\n setExpanded: (expanded: ExpandedState) => void\n\n // Sorting\n sorting: SortingState\n updateSorting: OnChangeFn<SortingState>\n\n // context menu\n contextMenuItems: ContextMenuItemConstructors\n\n // powerpack context\n powerpack?: PowerpackContextType\n\n // remote modules\n modules: ProjectTableModuleContextType\n\n groupByConfig?: {\n entityType?: GroupByEntityType\n }\n}\n\nexport interface ProjectTableContextProps {\n isInitialized: ProjectTableProviderProps['isInitialized']\n isLoading: ProjectTableProviderProps['isLoading']\n // Project Info\n projectInfo: ProjectTableProviderProps['projectInfo']\n projectName: ProjectTableProviderProps['projectName']\n users: ProjectTableProviderProps['users']\n // Attributes\n attribFields: ProjectTableProviderProps['attribFields']\n error?: string\n\n // Data\n tableData: TableRow[]\n tasksMap: ProjectTableProviderProps['tasksMap']\n foldersMap: ProjectTableProviderProps['foldersMap']\n entitiesMap: ProjectTableProviderProps['entitiesMap']\n fetchNextPage: ProjectTableProviderProps['fetchNextPage']\n reloadTableData: ProjectTableProviderProps['reloadTableData']\n getEntityById: (id: string) => EntityMap | undefined\n\n // grouping\n taskGroups: ProjectTableProviderProps['taskGroups']\n\n // Filters\n filters: ProjectTableProviderProps['filters']\n setFilters: ProjectTableProviderProps['setFilters']\n queryFilters: ProjectTableProviderProps['queryFilters']\n\n // Hierarchy\n showHierarchy: ProjectTableProviderProps['showHierarchy']\n updateShowHierarchy: ProjectTableProviderProps['updateShowHierarchy']\n\n // Expanded state\n expanded: ProjectTableProviderProps['expanded']\n toggleExpanded: ProjectTableProviderProps['toggleExpanded']\n updateExpanded: ProjectTableProviderProps['updateExpanded']\n toggleExpandAll: ToggleExpandAll\n toggleExpands: ToggleExpands // expand/collapse multiple rows at once\n\n // Sorting\n sorting: ProjectTableProviderProps['sorting']\n updateSorting: ProjectTableProviderProps['updateSorting']\n\n // Folder Relationships\n getInheritedDependents: GetInheritedDependents\n findInheritedValueFromAncestors: FindInheritedValueFromAncestors\n findNonInheritedValues: FindNonInheritedValues\n getAncestorsOf: GetAncestorsOf\n\n // Context menu\n contextMenuItems: ProjectTableProviderProps['contextMenuItems']\n\n // Powerpack context\n powerpack?: ProjectTableProviderProps['powerpack']\n\n // remote modules\n modules: ProjectTableProviderProps['modules']\n}\n\nconst ProjectTableContext = createContext<ProjectTableContextProps | undefined>(undefined)\n\nexport const ProjectTableProvider = ({\n children,\n foldersMap,\n tableRows,\n tasksMap,\n entitiesMap,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n isLoading,\n error,\n isInitialized,\n projectName,\n users,\n attribFields,\n taskGroups,\n filters,\n setFilters,\n queryFilters,\n updateShowHierarchy,\n toggleExpanded,\n updateExpanded,\n sorting,\n updateSorting,\n fetchNextPage,\n reloadTableData,\n setExpanded,\n contextMenuItems,\n powerpack,\n modules,\n groupByConfig,\n}: ProjectTableProviderProps) => {\n // DATA TO TABLE\n const defaultTableData = useBuildProjectDataTable({\n foldersMap,\n tasksMap,\n rows: tableRows,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n })\n const { groupBy } = useColumnSettingsContext()\n\n const buildGroupByTableData = useBuildGroupByTableData({\n entities: entitiesMap,\n entityType: groupByConfig?.entityType,\n groups: taskGroups,\n project: projectInfo,\n attribFields,\n })\n\n // if we are grouping by something, we ignore current tableData and format the data based on the groupBy\n const groupedTableData = useMemo(\n () => !!groupBy && buildGroupByTableData(groupBy),\n [groupBy, entitiesMap, taskGroups],\n )\n\n const tableData = groupBy && groupedTableData ? groupedTableData : defaultTableData\n\n const getEntityById = useCallback(\n (id: string): EntityMap | undefined => {\n // always parse the id to remove any suffixes\n // this can happen if the id is a group by id (we need to make the row id unique)\n const parsedId = parseRowId(id)\n if (foldersMap.has(parsedId)) {\n return foldersMap.get(parsedId)\n } else if (tasksMap.has(parsedId)) {\n return tasksMap.get(parsedId)\n } else if (entitiesMap.has(parsedId)) {\n return entitiesMap.get(parsedId)\n }\n\n // Return undefined if not found\n return undefined\n },\n [foldersMap, tasksMap, entitiesMap],\n )\n\n // get folder relationship functions\n const {\n getInheritedDependents,\n getChildrenEntities,\n findInheritedValueFromAncestors,\n findNonInheritedValues,\n getAncestorsOf,\n } = useFolderRelationships({\n entitiesMap,\n tasksMap,\n tasksByFolderMap,\n getEntityById,\n projectAttrib: projectInfo?.attrib,\n attribFields: attribFields,\n })\n\n const toggleExpandAll: ProjectTableContextProps['toggleExpandAll'] = useCallback(\n (rowIds, expandAll) => {\n const expandedState = typeof expanded === 'object' ? expanded : {}\n\n const newExpandedState = { ...expandedState }\n\n rowIds.forEach((rowId) => {\n // get all children of the rowId using tableData\n const childIds = getChildrenEntities(rowId).map((child) => child.id)\n // check if the rowId is expanded\n const isExpanded = expandedState[rowId] || false\n\n if (expandAll !== undefined ? !expandAll : isExpanded) {\n // collapse all children\n newExpandedState[rowId] = false\n childIds.forEach((id) => {\n newExpandedState[id] = false\n })\n } else {\n // expand all children\n newExpandedState[rowId] = true\n childIds.forEach((id) => {\n newExpandedState[id] = true\n })\n }\n })\n\n setExpanded(newExpandedState)\n },\n [expanded, getChildrenEntities, setExpanded],\n )\n\n const toggleExpands: ProjectTableContextProps['toggleExpands'] = useCallback(\n (rowIds, expand) => {\n const expandedState = typeof expanded === 'object' ? expanded : {}\n const newExpandedState = { ...expandedState }\n\n rowIds.forEach((rowId) => {\n if (expand !== undefined) {\n // Use the provided expand parameter\n newExpandedState[rowId] = expand\n } else {\n // Toggle based on current state\n newExpandedState[rowId] = !expandedState[rowId]\n }\n })\n\n setExpanded(newExpandedState)\n },\n [expanded, setExpanded],\n )\n\n return (\n <ProjectTableContext.Provider\n value={{\n // from this context\n tableData,\n // forwarded on\n isInitialized,\n isLoading,\n error,\n projectInfo,\n attribFields,\n users,\n projectName,\n tasksMap,\n foldersMap,\n entitiesMap,\n fetchNextPage,\n reloadTableData,\n taskGroups,\n // filters\n filters,\n setFilters,\n queryFilters,\n // hierarchy\n showHierarchy,\n updateShowHierarchy,\n // expanded state\n expanded,\n toggleExpanded,\n updateExpanded,\n toggleExpandAll,\n toggleExpands,\n // sorting\n sorting,\n updateSorting,\n getEntityById,\n // folder relationships\n getInheritedDependents,\n findInheritedValueFromAncestors,\n findNonInheritedValues,\n getAncestorsOf,\n // context menu\n contextMenuItems,\n // powerpack context\n powerpack,\n modules,\n }}\n >\n {children}\n </ProjectTableContext.Provider>\n )\n}\n\nexport const useProjectTableContext = () => {\n const context = useContext(ProjectTableContext)\n if (!context) {\n throw new Error('useProjectTableContext must be used within a ProjectTableProvider')\n }\n return context\n}\n"],"names":["ROW_ID_SEPARATOR","createContext","useColumnSettingsContext","useBuildGroupByTableData","useMemo","useCallback","jsx","useContext"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ProjectTableContext.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/context/ProjectTableContext.ts"],"sourcesContent":["import { createContext, useContext } from 'react'\nimport { EntityMap, TableRow } from '../types/table'\nimport {\n FindInheritedValueFromAncestors,\n GetAncestorsOf,\n GetInheritedDependents,\n FindNonInheritedValues,\n} from '../hooks/useFolderRelationships'\nimport { RowId } from '../utils/cellUtils'\n\nimport { ProjectTableProviderProps } from './ProjectTableProvider'\n\nexport type ToggleExpandAll = (rowIds: RowId[], expand?: boolean) => void\nexport type ToggleExpands = (rowIds: RowId[], expand?: boolean) => void\n\nexport interface ProjectTableContextType {\n isInitialized: ProjectTableProviderProps['isInitialized']\n isLoading: ProjectTableProviderProps['isLoading']\n // Project Info\n projectInfo: ProjectTableProviderProps['projectInfo']\n projectName: ProjectTableProviderProps['projectName']\n users: ProjectTableProviderProps['users']\n // Attributes\n attribFields: ProjectTableProviderProps['attribFields']\n error?: string\n\n // Data\n tableData: TableRow[]\n tasksMap: ProjectTableProviderProps['tasksMap']\n foldersMap: ProjectTableProviderProps['foldersMap']\n entitiesMap: ProjectTableProviderProps['entitiesMap']\n fetchNextPage: ProjectTableProviderProps['fetchNextPage']\n reloadTableData: ProjectTableProviderProps['reloadTableData']\n getEntityById: (id: string) => EntityMap | undefined\n\n // grouping\n taskGroups: ProjectTableProviderProps['taskGroups']\n\n // Filters\n filters: ProjectTableProviderProps['filters']\n setFilters: ProjectTableProviderProps['setFilters']\n queryFilters: ProjectTableProviderProps['queryFilters']\n\n // Hierarchy\n showHierarchy: ProjectTableProviderProps['showHierarchy']\n updateShowHierarchy: ProjectTableProviderProps['updateShowHierarchy']\n\n // Expanded state\n expanded: ProjectTableProviderProps['expanded']\n toggleExpanded: ProjectTableProviderProps['toggleExpanded']\n updateExpanded: ProjectTableProviderProps['updateExpanded']\n toggleExpandAll: ToggleExpandAll\n toggleExpands: ToggleExpands // expand/collapse multiple rows at once\n\n // Sorting\n sorting: ProjectTableProviderProps['sorting']\n updateSorting: ProjectTableProviderProps['updateSorting']\n\n // Folder Relationships\n getInheritedDependents: GetInheritedDependents\n findInheritedValueFromAncestors: FindInheritedValueFromAncestors\n findNonInheritedValues: FindNonInheritedValues\n getAncestorsOf: GetAncestorsOf\n\n // Context menu\n contextMenuItems: ProjectTableProviderProps['contextMenuItems']\n\n // Powerpack context\n powerpack?: ProjectTableProviderProps['powerpack']\n\n // remote modules\n modules: ProjectTableProviderProps['modules']\n}\n\nexport const ProjectTableContext = createContext<ProjectTableContextType | undefined>(undefined)\n\nexport const useProjectTableContext = () => {\n const context = useContext(ProjectTableContext)\n if (!context) {\n throw new Error('useProjectTableContext must be used within a ProjectTableProvider')\n }\n return context\n}\n"],"names":["createContext","useContext"],"mappings":";;;AA0Ea,MAAA,sBAAsBA,oBAAmD,MAAS;AAExF,MAAM,yBAAyB,MAAM;AACpC,QAAA,UAAUC,iBAAW,mBAAmB;AAC9C,MAAI,CAAC,SAAS;AACN,UAAA,IAAI,MAAM,mEAAmE;AAAA,EAAA;AAE9E,SAAA;AACT;;;"}
|
|
@@ -1,188 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { createContext, useMemo, useCallback, useContext } from "react";
|
|
3
|
-
import useBuildProjectDataTable from "../hooks/useBuildProjectDataTable.es.js";
|
|
4
|
-
import useFolderRelationships from "../hooks/useFolderRelationships.es.js";
|
|
5
|
-
import useBuildGroupByTableData, { ROW_ID_SEPARATOR } from "../hooks/useBuildGroupByTableData.es.js";
|
|
6
|
-
import { useColumnSettingsContext } from "./ColumnSettingsContext.es.js";
|
|
7
|
-
const parseRowId = (rowId) => rowId.split(ROW_ID_SEPARATOR)[0] || rowId;
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
8
2
|
const ProjectTableContext = createContext(void 0);
|
|
9
|
-
const ProjectTableProvider = ({
|
|
10
|
-
children,
|
|
11
|
-
foldersMap,
|
|
12
|
-
tableRows,
|
|
13
|
-
tasksMap,
|
|
14
|
-
entitiesMap,
|
|
15
|
-
tasksByFolderMap,
|
|
16
|
-
expanded,
|
|
17
|
-
projectInfo,
|
|
18
|
-
showHierarchy,
|
|
19
|
-
loadingTasks,
|
|
20
|
-
isLoadingMore,
|
|
21
|
-
isLoading,
|
|
22
|
-
error,
|
|
23
|
-
isInitialized,
|
|
24
|
-
projectName,
|
|
25
|
-
users,
|
|
26
|
-
attribFields,
|
|
27
|
-
taskGroups,
|
|
28
|
-
filters,
|
|
29
|
-
setFilters,
|
|
30
|
-
queryFilters,
|
|
31
|
-
updateShowHierarchy,
|
|
32
|
-
toggleExpanded,
|
|
33
|
-
updateExpanded,
|
|
34
|
-
sorting,
|
|
35
|
-
updateSorting,
|
|
36
|
-
fetchNextPage,
|
|
37
|
-
reloadTableData,
|
|
38
|
-
setExpanded,
|
|
39
|
-
contextMenuItems,
|
|
40
|
-
powerpack,
|
|
41
|
-
modules,
|
|
42
|
-
groupByConfig
|
|
43
|
-
}) => {
|
|
44
|
-
const defaultTableData = useBuildProjectDataTable({
|
|
45
|
-
foldersMap,
|
|
46
|
-
tasksMap,
|
|
47
|
-
rows: tableRows,
|
|
48
|
-
tasksByFolderMap,
|
|
49
|
-
expanded,
|
|
50
|
-
projectInfo,
|
|
51
|
-
showHierarchy,
|
|
52
|
-
loadingTasks,
|
|
53
|
-
isLoadingMore
|
|
54
|
-
});
|
|
55
|
-
const { groupBy } = useColumnSettingsContext();
|
|
56
|
-
const buildGroupByTableData = useBuildGroupByTableData({
|
|
57
|
-
entities: entitiesMap,
|
|
58
|
-
entityType: groupByConfig == null ? void 0 : groupByConfig.entityType,
|
|
59
|
-
groups: taskGroups,
|
|
60
|
-
project: projectInfo,
|
|
61
|
-
attribFields
|
|
62
|
-
});
|
|
63
|
-
const groupedTableData = useMemo(
|
|
64
|
-
() => !!groupBy && buildGroupByTableData(groupBy),
|
|
65
|
-
[groupBy, entitiesMap, taskGroups]
|
|
66
|
-
);
|
|
67
|
-
const tableData = groupBy && groupedTableData ? groupedTableData : defaultTableData;
|
|
68
|
-
const getEntityById = useCallback(
|
|
69
|
-
(id) => {
|
|
70
|
-
const parsedId = parseRowId(id);
|
|
71
|
-
if (foldersMap.has(parsedId)) {
|
|
72
|
-
return foldersMap.get(parsedId);
|
|
73
|
-
} else if (tasksMap.has(parsedId)) {
|
|
74
|
-
return tasksMap.get(parsedId);
|
|
75
|
-
} else if (entitiesMap.has(parsedId)) {
|
|
76
|
-
return entitiesMap.get(parsedId);
|
|
77
|
-
}
|
|
78
|
-
return void 0;
|
|
79
|
-
},
|
|
80
|
-
[foldersMap, tasksMap, entitiesMap]
|
|
81
|
-
);
|
|
82
|
-
const {
|
|
83
|
-
getInheritedDependents,
|
|
84
|
-
getChildrenEntities,
|
|
85
|
-
findInheritedValueFromAncestors,
|
|
86
|
-
findNonInheritedValues,
|
|
87
|
-
getAncestorsOf
|
|
88
|
-
} = useFolderRelationships({
|
|
89
|
-
entitiesMap,
|
|
90
|
-
tasksMap,
|
|
91
|
-
tasksByFolderMap,
|
|
92
|
-
getEntityById,
|
|
93
|
-
projectAttrib: projectInfo == null ? void 0 : projectInfo.attrib,
|
|
94
|
-
attribFields
|
|
95
|
-
});
|
|
96
|
-
const toggleExpandAll = useCallback(
|
|
97
|
-
(rowIds, expandAll) => {
|
|
98
|
-
const expandedState = typeof expanded === "object" ? expanded : {};
|
|
99
|
-
const newExpandedState = { ...expandedState };
|
|
100
|
-
rowIds.forEach((rowId) => {
|
|
101
|
-
const childIds = getChildrenEntities(rowId).map((child) => child.id);
|
|
102
|
-
const isExpanded = expandedState[rowId] || false;
|
|
103
|
-
if (expandAll !== void 0 ? !expandAll : isExpanded) {
|
|
104
|
-
newExpandedState[rowId] = false;
|
|
105
|
-
childIds.forEach((id) => {
|
|
106
|
-
newExpandedState[id] = false;
|
|
107
|
-
});
|
|
108
|
-
} else {
|
|
109
|
-
newExpandedState[rowId] = true;
|
|
110
|
-
childIds.forEach((id) => {
|
|
111
|
-
newExpandedState[id] = true;
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
setExpanded(newExpandedState);
|
|
116
|
-
},
|
|
117
|
-
[expanded, getChildrenEntities, setExpanded]
|
|
118
|
-
);
|
|
119
|
-
const toggleExpands = useCallback(
|
|
120
|
-
(rowIds, expand) => {
|
|
121
|
-
const expandedState = typeof expanded === "object" ? expanded : {};
|
|
122
|
-
const newExpandedState = { ...expandedState };
|
|
123
|
-
rowIds.forEach((rowId) => {
|
|
124
|
-
if (expand !== void 0) {
|
|
125
|
-
newExpandedState[rowId] = expand;
|
|
126
|
-
} else {
|
|
127
|
-
newExpandedState[rowId] = !expandedState[rowId];
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
setExpanded(newExpandedState);
|
|
131
|
-
},
|
|
132
|
-
[expanded, setExpanded]
|
|
133
|
-
);
|
|
134
|
-
return /* @__PURE__ */ jsxRuntimeExports.jsx(
|
|
135
|
-
ProjectTableContext.Provider,
|
|
136
|
-
{
|
|
137
|
-
value: {
|
|
138
|
-
// from this context
|
|
139
|
-
tableData,
|
|
140
|
-
// forwarded on
|
|
141
|
-
isInitialized,
|
|
142
|
-
isLoading,
|
|
143
|
-
error,
|
|
144
|
-
projectInfo,
|
|
145
|
-
attribFields,
|
|
146
|
-
users,
|
|
147
|
-
projectName,
|
|
148
|
-
tasksMap,
|
|
149
|
-
foldersMap,
|
|
150
|
-
entitiesMap,
|
|
151
|
-
fetchNextPage,
|
|
152
|
-
reloadTableData,
|
|
153
|
-
taskGroups,
|
|
154
|
-
// filters
|
|
155
|
-
filters,
|
|
156
|
-
setFilters,
|
|
157
|
-
queryFilters,
|
|
158
|
-
// hierarchy
|
|
159
|
-
showHierarchy,
|
|
160
|
-
updateShowHierarchy,
|
|
161
|
-
// expanded state
|
|
162
|
-
expanded,
|
|
163
|
-
toggleExpanded,
|
|
164
|
-
updateExpanded,
|
|
165
|
-
toggleExpandAll,
|
|
166
|
-
toggleExpands,
|
|
167
|
-
// sorting
|
|
168
|
-
sorting,
|
|
169
|
-
updateSorting,
|
|
170
|
-
getEntityById,
|
|
171
|
-
// folder relationships
|
|
172
|
-
getInheritedDependents,
|
|
173
|
-
findInheritedValueFromAncestors,
|
|
174
|
-
findNonInheritedValues,
|
|
175
|
-
getAncestorsOf,
|
|
176
|
-
// context menu
|
|
177
|
-
contextMenuItems,
|
|
178
|
-
// powerpack context
|
|
179
|
-
powerpack,
|
|
180
|
-
modules
|
|
181
|
-
},
|
|
182
|
-
children
|
|
183
|
-
}
|
|
184
|
-
);
|
|
185
|
-
};
|
|
186
3
|
const useProjectTableContext = () => {
|
|
187
4
|
const context = useContext(ProjectTableContext);
|
|
188
5
|
if (!context) {
|
|
@@ -191,8 +8,7 @@ const useProjectTableContext = () => {
|
|
|
191
8
|
return context;
|
|
192
9
|
};
|
|
193
10
|
export {
|
|
194
|
-
|
|
195
|
-
parseRowId,
|
|
11
|
+
ProjectTableContext,
|
|
196
12
|
useProjectTableContext
|
|
197
13
|
};
|
|
198
14
|
//# sourceMappingURL=ProjectTableContext.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProjectTableContext.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/context/ProjectTableContext.tsx"],"sourcesContent":["/**\n * Project Table Context\n *\n * This context serves as the central data management layer for the project table component.\n * It performs three main functions:\n *\n * 1. **Props Forwarding**: Acts as a bridge to forward essential props (project info, users,\n * attributes, filters, etc.) down to child components throughout the table hierarchy.\n *\n * 2. **Table Data Structure Building**: Transforms raw project data into structured table rows\n * that can be consumed by the table component. This includes processing folders, tasks,\n * and entities into a unified table format.\n *\n * 3. **Multi-Modal Data Presentation**: Supports three different data presentation modes:\n * - **Hierarchy Mode**: Builds nested folder/task relationships with expandable rows\n * - **Tasks List Mode**: Flattened view of tasks without hierarchical structure\n * - **Groups Mode**: Groups entities by specified criteria (entity type, custom groups)\n *\n * The context also provides utility functions for entity relationships, expansion state\n * management, filtering, sorting, and folder inheritance operations.\n */\nimport { createContext, ReactNode, useCallback, useContext, useMemo } from 'react'\nimport { ExpandedState, OnChangeFn, SortingState } from '@tanstack/react-table'\nimport useBuildProjectDataTable from '../hooks/useBuildProjectDataTable'\nimport { Filter } from '@ynput/ayon-react-components'\nimport {\n EntitiesMap,\n EntityMap,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport useFolderRelationships, {\n FindInheritedValueFromAncestors,\n GetAncestorsOf,\n GetInheritedDependents,\n FindNonInheritedValues,\n} from '../hooks/useFolderRelationships'\nimport { RowId } from '../utils/cellUtils'\nimport { ProjectModel } from '../types/project'\nimport { ProjectTableAttribute, LoadingTasks } from '../types'\nimport { QueryFilter } from '../types/folders'\nimport { ContextMenuItemConstructors } from '../hooks/useCellContextMenu'\nimport { EntityGroup } from '@shared/api'\nimport useBuildGroupByTableData, {\n GroupByEntityType,\n ROW_ID_SEPARATOR,\n} from '../hooks/useBuildGroupByTableData'\nimport { PowerpackContextType } from '@shared/context'\nimport { ProjectTableModuleContextType } from './ProjectTableModulesContext'\nimport { useColumnSettingsContext } from './ColumnSettingsContext'\n\nexport const parseRowId = (rowId: string) => rowId.split(ROW_ID_SEPARATOR)[0] || rowId\n\nexport type TableUser = {\n name: string\n fullName?: string\n}\n\nexport type ToggleExpandAll = (rowIds: RowId[], expand?: boolean) => void\nexport type ToggleExpands = (rowIds: RowId[], expand?: boolean) => void\n\nexport interface ProjectTableProviderProps {\n children: ReactNode\n isInitialized: boolean\n\n // loading\n isLoading: boolean\n isLoadingMore: boolean\n loadingTasks?: LoadingTasks\n error?: string\n // Project Info\n projectInfo?: ProjectModel\n projectName: string\n users: TableUser[]\n // Attributes\n attribFields: ProjectTableAttribute[]\n\n // data\n tasksMap: TaskNodeMap\n foldersMap: FolderNodeMap\n entitiesMap: EntitiesMap\n tasksByFolderMap: TasksByFolderMap\n tableRows?: TableRow[] // any extra rows that we want to add to the table\n\n // grouping\n taskGroups: EntityGroup[]\n\n // data functions\n fetchNextPage: (value?: string) => void\n reloadTableData: () => void\n\n // Filters\n filters: Filter[]\n setFilters: (filters: Filter[]) => void\n queryFilters: {\n filter: QueryFilter | undefined\n filterString?: string\n search: string | undefined\n }\n\n // Hierarchy\n showHierarchy: boolean\n updateShowHierarchy: (showHierarchy: boolean) => void\n\n // Expanded state\n expanded: ExpandedState\n toggleExpanded: (id: string) => void\n updateExpanded: OnChangeFn<ExpandedState>\n setExpanded: (expanded: ExpandedState) => void\n\n // Sorting\n sorting: SortingState\n updateSorting: OnChangeFn<SortingState>\n\n // context menu\n contextMenuItems: ContextMenuItemConstructors\n\n // powerpack context\n powerpack?: PowerpackContextType\n\n // remote modules\n modules: ProjectTableModuleContextType\n\n groupByConfig?: {\n entityType?: GroupByEntityType\n }\n}\n\nexport interface ProjectTableContextProps {\n isInitialized: ProjectTableProviderProps['isInitialized']\n isLoading: ProjectTableProviderProps['isLoading']\n // Project Info\n projectInfo: ProjectTableProviderProps['projectInfo']\n projectName: ProjectTableProviderProps['projectName']\n users: ProjectTableProviderProps['users']\n // Attributes\n attribFields: ProjectTableProviderProps['attribFields']\n error?: string\n\n // Data\n tableData: TableRow[]\n tasksMap: ProjectTableProviderProps['tasksMap']\n foldersMap: ProjectTableProviderProps['foldersMap']\n entitiesMap: ProjectTableProviderProps['entitiesMap']\n fetchNextPage: ProjectTableProviderProps['fetchNextPage']\n reloadTableData: ProjectTableProviderProps['reloadTableData']\n getEntityById: (id: string) => EntityMap | undefined\n\n // grouping\n taskGroups: ProjectTableProviderProps['taskGroups']\n\n // Filters\n filters: ProjectTableProviderProps['filters']\n setFilters: ProjectTableProviderProps['setFilters']\n queryFilters: ProjectTableProviderProps['queryFilters']\n\n // Hierarchy\n showHierarchy: ProjectTableProviderProps['showHierarchy']\n updateShowHierarchy: ProjectTableProviderProps['updateShowHierarchy']\n\n // Expanded state\n expanded: ProjectTableProviderProps['expanded']\n toggleExpanded: ProjectTableProviderProps['toggleExpanded']\n updateExpanded: ProjectTableProviderProps['updateExpanded']\n toggleExpandAll: ToggleExpandAll\n toggleExpands: ToggleExpands // expand/collapse multiple rows at once\n\n // Sorting\n sorting: ProjectTableProviderProps['sorting']\n updateSorting: ProjectTableProviderProps['updateSorting']\n\n // Folder Relationships\n getInheritedDependents: GetInheritedDependents\n findInheritedValueFromAncestors: FindInheritedValueFromAncestors\n findNonInheritedValues: FindNonInheritedValues\n getAncestorsOf: GetAncestorsOf\n\n // Context menu\n contextMenuItems: ProjectTableProviderProps['contextMenuItems']\n\n // Powerpack context\n powerpack?: ProjectTableProviderProps['powerpack']\n\n // remote modules\n modules: ProjectTableProviderProps['modules']\n}\n\nconst ProjectTableContext = createContext<ProjectTableContextProps | undefined>(undefined)\n\nexport const ProjectTableProvider = ({\n children,\n foldersMap,\n tableRows,\n tasksMap,\n entitiesMap,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n isLoading,\n error,\n isInitialized,\n projectName,\n users,\n attribFields,\n taskGroups,\n filters,\n setFilters,\n queryFilters,\n updateShowHierarchy,\n toggleExpanded,\n updateExpanded,\n sorting,\n updateSorting,\n fetchNextPage,\n reloadTableData,\n setExpanded,\n contextMenuItems,\n powerpack,\n modules,\n groupByConfig,\n}: ProjectTableProviderProps) => {\n // DATA TO TABLE\n const defaultTableData = useBuildProjectDataTable({\n foldersMap,\n tasksMap,\n rows: tableRows,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n })\n const { groupBy } = useColumnSettingsContext()\n\n const buildGroupByTableData = useBuildGroupByTableData({\n entities: entitiesMap,\n entityType: groupByConfig?.entityType,\n groups: taskGroups,\n project: projectInfo,\n attribFields,\n })\n\n // if we are grouping by something, we ignore current tableData and format the data based on the groupBy\n const groupedTableData = useMemo(\n () => !!groupBy && buildGroupByTableData(groupBy),\n [groupBy, entitiesMap, taskGroups],\n )\n\n const tableData = groupBy && groupedTableData ? groupedTableData : defaultTableData\n\n const getEntityById = useCallback(\n (id: string): EntityMap | undefined => {\n // always parse the id to remove any suffixes\n // this can happen if the id is a group by id (we need to make the row id unique)\n const parsedId = parseRowId(id)\n if (foldersMap.has(parsedId)) {\n return foldersMap.get(parsedId)\n } else if (tasksMap.has(parsedId)) {\n return tasksMap.get(parsedId)\n } else if (entitiesMap.has(parsedId)) {\n return entitiesMap.get(parsedId)\n }\n\n // Return undefined if not found\n return undefined\n },\n [foldersMap, tasksMap, entitiesMap],\n )\n\n // get folder relationship functions\n const {\n getInheritedDependents,\n getChildrenEntities,\n findInheritedValueFromAncestors,\n findNonInheritedValues,\n getAncestorsOf,\n } = useFolderRelationships({\n entitiesMap,\n tasksMap,\n tasksByFolderMap,\n getEntityById,\n projectAttrib: projectInfo?.attrib,\n attribFields: attribFields,\n })\n\n const toggleExpandAll: ProjectTableContextProps['toggleExpandAll'] = useCallback(\n (rowIds, expandAll) => {\n const expandedState = typeof expanded === 'object' ? expanded : {}\n\n const newExpandedState = { ...expandedState }\n\n rowIds.forEach((rowId) => {\n // get all children of the rowId using tableData\n const childIds = getChildrenEntities(rowId).map((child) => child.id)\n // check if the rowId is expanded\n const isExpanded = expandedState[rowId] || false\n\n if (expandAll !== undefined ? !expandAll : isExpanded) {\n // collapse all children\n newExpandedState[rowId] = false\n childIds.forEach((id) => {\n newExpandedState[id] = false\n })\n } else {\n // expand all children\n newExpandedState[rowId] = true\n childIds.forEach((id) => {\n newExpandedState[id] = true\n })\n }\n })\n\n setExpanded(newExpandedState)\n },\n [expanded, getChildrenEntities, setExpanded],\n )\n\n const toggleExpands: ProjectTableContextProps['toggleExpands'] = useCallback(\n (rowIds, expand) => {\n const expandedState = typeof expanded === 'object' ? expanded : {}\n const newExpandedState = { ...expandedState }\n\n rowIds.forEach((rowId) => {\n if (expand !== undefined) {\n // Use the provided expand parameter\n newExpandedState[rowId] = expand\n } else {\n // Toggle based on current state\n newExpandedState[rowId] = !expandedState[rowId]\n }\n })\n\n setExpanded(newExpandedState)\n },\n [expanded, setExpanded],\n )\n\n return (\n <ProjectTableContext.Provider\n value={{\n // from this context\n tableData,\n // forwarded on\n isInitialized,\n isLoading,\n error,\n projectInfo,\n attribFields,\n users,\n projectName,\n tasksMap,\n foldersMap,\n entitiesMap,\n fetchNextPage,\n reloadTableData,\n taskGroups,\n // filters\n filters,\n setFilters,\n queryFilters,\n // hierarchy\n showHierarchy,\n updateShowHierarchy,\n // expanded state\n expanded,\n toggleExpanded,\n updateExpanded,\n toggleExpandAll,\n toggleExpands,\n // sorting\n sorting,\n updateSorting,\n getEntityById,\n // folder relationships\n getInheritedDependents,\n findInheritedValueFromAncestors,\n findNonInheritedValues,\n getAncestorsOf,\n // context menu\n contextMenuItems,\n // powerpack context\n powerpack,\n modules,\n }}\n >\n {children}\n </ProjectTableContext.Provider>\n )\n}\n\nexport const useProjectTableContext = () => {\n const context = useContext(ProjectTableContext)\n if (!context) {\n throw new Error('useProjectTableContext must be used within a ProjectTableProvider')\n }\n return context\n}\n"],"names":["jsx"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ProjectTableContext.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/context/ProjectTableContext.ts"],"sourcesContent":["import { createContext, useContext } from 'react'\nimport { EntityMap, TableRow } from '../types/table'\nimport {\n FindInheritedValueFromAncestors,\n GetAncestorsOf,\n GetInheritedDependents,\n FindNonInheritedValues,\n} from '../hooks/useFolderRelationships'\nimport { RowId } from '../utils/cellUtils'\n\nimport { ProjectTableProviderProps } from './ProjectTableProvider'\n\nexport type ToggleExpandAll = (rowIds: RowId[], expand?: boolean) => void\nexport type ToggleExpands = (rowIds: RowId[], expand?: boolean) => void\n\nexport interface ProjectTableContextType {\n isInitialized: ProjectTableProviderProps['isInitialized']\n isLoading: ProjectTableProviderProps['isLoading']\n // Project Info\n projectInfo: ProjectTableProviderProps['projectInfo']\n projectName: ProjectTableProviderProps['projectName']\n users: ProjectTableProviderProps['users']\n // Attributes\n attribFields: ProjectTableProviderProps['attribFields']\n error?: string\n\n // Data\n tableData: TableRow[]\n tasksMap: ProjectTableProviderProps['tasksMap']\n foldersMap: ProjectTableProviderProps['foldersMap']\n entitiesMap: ProjectTableProviderProps['entitiesMap']\n fetchNextPage: ProjectTableProviderProps['fetchNextPage']\n reloadTableData: ProjectTableProviderProps['reloadTableData']\n getEntityById: (id: string) => EntityMap | undefined\n\n // grouping\n taskGroups: ProjectTableProviderProps['taskGroups']\n\n // Filters\n filters: ProjectTableProviderProps['filters']\n setFilters: ProjectTableProviderProps['setFilters']\n queryFilters: ProjectTableProviderProps['queryFilters']\n\n // Hierarchy\n showHierarchy: ProjectTableProviderProps['showHierarchy']\n updateShowHierarchy: ProjectTableProviderProps['updateShowHierarchy']\n\n // Expanded state\n expanded: ProjectTableProviderProps['expanded']\n toggleExpanded: ProjectTableProviderProps['toggleExpanded']\n updateExpanded: ProjectTableProviderProps['updateExpanded']\n toggleExpandAll: ToggleExpandAll\n toggleExpands: ToggleExpands // expand/collapse multiple rows at once\n\n // Sorting\n sorting: ProjectTableProviderProps['sorting']\n updateSorting: ProjectTableProviderProps['updateSorting']\n\n // Folder Relationships\n getInheritedDependents: GetInheritedDependents\n findInheritedValueFromAncestors: FindInheritedValueFromAncestors\n findNonInheritedValues: FindNonInheritedValues\n getAncestorsOf: GetAncestorsOf\n\n // Context menu\n contextMenuItems: ProjectTableProviderProps['contextMenuItems']\n\n // Powerpack context\n powerpack?: ProjectTableProviderProps['powerpack']\n\n // remote modules\n modules: ProjectTableProviderProps['modules']\n}\n\nexport const ProjectTableContext = createContext<ProjectTableContextType | undefined>(undefined)\n\nexport const useProjectTableContext = () => {\n const context = useContext(ProjectTableContext)\n if (!context) {\n throw new Error('useProjectTableContext must be used within a ProjectTableProvider')\n }\n return context\n}\n"],"names":[],"mappings":";AA0Ea,MAAA,sBAAsB,cAAmD,MAAS;AAExF,MAAM,yBAAyB,MAAM;AACpC,QAAA,UAAU,WAAW,mBAAmB;AAC9C,MAAI,CAAC,SAAS;AACN,UAAA,IAAI,MAAM,mEAAmE;AAAA,EAAA;AAE9E,SAAA;AACT;"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const jsxRuntime = require("../../../../../_virtual/jsx-runtime.cjs.js");
|
|
4
|
+
const React = require("react");
|
|
5
|
+
const useBuildProjectDataTable = require("../hooks/useBuildProjectDataTable.cjs.js");
|
|
6
|
+
const useFolderRelationships = require("../hooks/useFolderRelationships.cjs.js");
|
|
7
|
+
const useBuildGroupByTableData = require("../hooks/useBuildGroupByTableData.cjs.js");
|
|
8
|
+
const ColumnSettingsContext = require("./ColumnSettingsContext.cjs.js");
|
|
9
|
+
const ProjectTableContext = require("./ProjectTableContext.cjs.js");
|
|
10
|
+
const parseRowId = (rowId) => rowId.split(useBuildGroupByTableData.ROW_ID_SEPARATOR)[0] || rowId;
|
|
11
|
+
const ProjectTableProvider = ({
|
|
12
|
+
children,
|
|
13
|
+
foldersMap,
|
|
14
|
+
tableRows,
|
|
15
|
+
tasksMap,
|
|
16
|
+
entitiesMap,
|
|
17
|
+
tasksByFolderMap,
|
|
18
|
+
expanded,
|
|
19
|
+
projectInfo,
|
|
20
|
+
showHierarchy,
|
|
21
|
+
loadingTasks,
|
|
22
|
+
isLoadingMore,
|
|
23
|
+
isLoading,
|
|
24
|
+
error,
|
|
25
|
+
isInitialized,
|
|
26
|
+
projectName,
|
|
27
|
+
users,
|
|
28
|
+
attribFields,
|
|
29
|
+
taskGroups,
|
|
30
|
+
filters,
|
|
31
|
+
setFilters,
|
|
32
|
+
queryFilters,
|
|
33
|
+
updateShowHierarchy,
|
|
34
|
+
toggleExpanded,
|
|
35
|
+
updateExpanded,
|
|
36
|
+
sorting,
|
|
37
|
+
updateSorting,
|
|
38
|
+
fetchNextPage,
|
|
39
|
+
reloadTableData,
|
|
40
|
+
setExpanded,
|
|
41
|
+
contextMenuItems,
|
|
42
|
+
powerpack,
|
|
43
|
+
modules,
|
|
44
|
+
groupByConfig
|
|
45
|
+
}) => {
|
|
46
|
+
const defaultTableData = useBuildProjectDataTable({
|
|
47
|
+
foldersMap,
|
|
48
|
+
tasksMap,
|
|
49
|
+
rows: tableRows,
|
|
50
|
+
tasksByFolderMap,
|
|
51
|
+
expanded,
|
|
52
|
+
projectInfo,
|
|
53
|
+
showHierarchy,
|
|
54
|
+
loadingTasks,
|
|
55
|
+
isLoadingMore
|
|
56
|
+
});
|
|
57
|
+
const { groupBy, groupByConfig: { showEmpty: showEmptyGroups = false } = {} } = ColumnSettingsContext.useColumnSettingsContext();
|
|
58
|
+
const buildGroupByTableData = useBuildGroupByTableData.default({
|
|
59
|
+
entities: entitiesMap,
|
|
60
|
+
entityType: groupByConfig == null ? void 0 : groupByConfig.entityType,
|
|
61
|
+
groups: taskGroups,
|
|
62
|
+
project: projectInfo,
|
|
63
|
+
attribFields,
|
|
64
|
+
showEmpty: showEmptyGroups
|
|
65
|
+
});
|
|
66
|
+
const groupedTableData = React.useMemo(
|
|
67
|
+
() => !!groupBy && buildGroupByTableData(groupBy),
|
|
68
|
+
[groupBy, entitiesMap, taskGroups]
|
|
69
|
+
);
|
|
70
|
+
const tableData = groupBy && groupedTableData ? groupedTableData : defaultTableData;
|
|
71
|
+
const getEntityById = React.useCallback(
|
|
72
|
+
(id) => {
|
|
73
|
+
const parsedId = parseRowId(id);
|
|
74
|
+
if (foldersMap.has(parsedId)) {
|
|
75
|
+
return foldersMap.get(parsedId);
|
|
76
|
+
} else if (tasksMap.has(parsedId)) {
|
|
77
|
+
return tasksMap.get(parsedId);
|
|
78
|
+
} else if (entitiesMap.has(parsedId)) {
|
|
79
|
+
return entitiesMap.get(parsedId);
|
|
80
|
+
}
|
|
81
|
+
return void 0;
|
|
82
|
+
},
|
|
83
|
+
[foldersMap, tasksMap, entitiesMap]
|
|
84
|
+
);
|
|
85
|
+
const {
|
|
86
|
+
getInheritedDependents,
|
|
87
|
+
getChildrenEntities,
|
|
88
|
+
findInheritedValueFromAncestors,
|
|
89
|
+
findNonInheritedValues,
|
|
90
|
+
getAncestorsOf
|
|
91
|
+
} = useFolderRelationships({
|
|
92
|
+
entitiesMap,
|
|
93
|
+
tasksMap,
|
|
94
|
+
tasksByFolderMap,
|
|
95
|
+
getEntityById,
|
|
96
|
+
projectAttrib: projectInfo == null ? void 0 : projectInfo.attrib,
|
|
97
|
+
attribFields
|
|
98
|
+
});
|
|
99
|
+
const toggleExpandAll = React.useCallback(
|
|
100
|
+
(rowIds, expandAll) => {
|
|
101
|
+
const expandedState = typeof expanded === "object" ? expanded : {};
|
|
102
|
+
const newExpandedState = { ...expandedState };
|
|
103
|
+
rowIds.forEach((rowId) => {
|
|
104
|
+
const childIds = getChildrenEntities(rowId).map((child) => child.id);
|
|
105
|
+
const isExpanded = expandedState[rowId] || false;
|
|
106
|
+
if (expandAll !== void 0 ? !expandAll : isExpanded) {
|
|
107
|
+
newExpandedState[rowId] = false;
|
|
108
|
+
childIds.forEach((id) => {
|
|
109
|
+
newExpandedState[id] = false;
|
|
110
|
+
});
|
|
111
|
+
} else {
|
|
112
|
+
newExpandedState[rowId] = true;
|
|
113
|
+
childIds.forEach((id) => {
|
|
114
|
+
newExpandedState[id] = true;
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
setExpanded(newExpandedState);
|
|
119
|
+
},
|
|
120
|
+
[expanded, getChildrenEntities, setExpanded]
|
|
121
|
+
);
|
|
122
|
+
const toggleExpands = React.useCallback(
|
|
123
|
+
(rowIds, expand) => {
|
|
124
|
+
const expandedState = typeof expanded === "object" ? expanded : {};
|
|
125
|
+
const newExpandedState = { ...expandedState };
|
|
126
|
+
rowIds.forEach((rowId) => {
|
|
127
|
+
if (expand !== void 0) {
|
|
128
|
+
newExpandedState[rowId] = expand;
|
|
129
|
+
} else {
|
|
130
|
+
newExpandedState[rowId] = !expandedState[rowId];
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
setExpanded(newExpandedState);
|
|
134
|
+
},
|
|
135
|
+
[expanded, setExpanded]
|
|
136
|
+
);
|
|
137
|
+
return /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
|
|
138
|
+
ProjectTableContext.ProjectTableContext.Provider,
|
|
139
|
+
{
|
|
140
|
+
value: {
|
|
141
|
+
// from this context
|
|
142
|
+
tableData,
|
|
143
|
+
// forwarded on
|
|
144
|
+
isInitialized,
|
|
145
|
+
isLoading,
|
|
146
|
+
error,
|
|
147
|
+
projectInfo,
|
|
148
|
+
attribFields,
|
|
149
|
+
users,
|
|
150
|
+
projectName,
|
|
151
|
+
tasksMap,
|
|
152
|
+
foldersMap,
|
|
153
|
+
entitiesMap,
|
|
154
|
+
fetchNextPage,
|
|
155
|
+
reloadTableData,
|
|
156
|
+
taskGroups,
|
|
157
|
+
// filters
|
|
158
|
+
filters,
|
|
159
|
+
setFilters,
|
|
160
|
+
queryFilters,
|
|
161
|
+
// hierarchy
|
|
162
|
+
showHierarchy,
|
|
163
|
+
updateShowHierarchy,
|
|
164
|
+
// expanded state
|
|
165
|
+
expanded,
|
|
166
|
+
toggleExpanded,
|
|
167
|
+
updateExpanded,
|
|
168
|
+
toggleExpandAll,
|
|
169
|
+
toggleExpands,
|
|
170
|
+
// sorting
|
|
171
|
+
sorting,
|
|
172
|
+
updateSorting,
|
|
173
|
+
getEntityById,
|
|
174
|
+
// folder relationships
|
|
175
|
+
getInheritedDependents,
|
|
176
|
+
findInheritedValueFromAncestors,
|
|
177
|
+
findNonInheritedValues,
|
|
178
|
+
getAncestorsOf,
|
|
179
|
+
// context menu
|
|
180
|
+
contextMenuItems,
|
|
181
|
+
// powerpack context
|
|
182
|
+
powerpack,
|
|
183
|
+
modules
|
|
184
|
+
},
|
|
185
|
+
children
|
|
186
|
+
}
|
|
187
|
+
);
|
|
188
|
+
};
|
|
189
|
+
exports.ProjectTableProvider = ProjectTableProvider;
|
|
190
|
+
exports.parseRowId = parseRowId;
|
|
191
|
+
//# sourceMappingURL=ProjectTableProvider.cjs.js.map
|