@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.
Files changed (210) hide show
  1. package/dist/DetailsPanel.cjs.js +9 -10
  2. package/dist/DetailsPanel.cjs.js.map +1 -1
  3. package/dist/DetailsPanel.es.js +9 -10
  4. package/dist/DetailsPanel.es.js.map +1 -1
  5. package/dist/ProjectTreeTable.cjs.js +38 -34
  6. package/dist/ProjectTreeTable.cjs.js.map +1 -1
  7. package/dist/ProjectTreeTable.es.js +20 -16
  8. package/dist/ProjectTreeTable.es.js.map +1 -1
  9. package/dist/_virtual/index.cjs10.js +4 -4
  10. package/dist/_virtual/index.cjs5.js +5 -3
  11. package/dist/_virtual/index.cjs5.js.map +1 -1
  12. package/dist/_virtual/index.cjs6.js +3 -5
  13. package/dist/_virtual/index.cjs6.js.map +1 -1
  14. package/dist/_virtual/index.cjs8.js +4 -4
  15. package/dist/_virtual/index.cjs9.js +4 -4
  16. package/dist/_virtual/index.es10.js +4 -4
  17. package/dist/_virtual/index.es5.js +5 -2
  18. package/dist/_virtual/index.es5.js.map +1 -1
  19. package/dist/_virtual/index.es6.js +2 -5
  20. package/dist/_virtual/index.es6.js.map +1 -1
  21. package/dist/_virtual/index.es8.js +4 -4
  22. package/dist/_virtual/index.es9.js +4 -4
  23. package/dist/index.cjs.js +6 -7
  24. package/dist/index.cjs.js.map +1 -1
  25. package/dist/index.es.js +6 -7
  26. package/dist/index.es.js.map +1 -1
  27. package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.cjs.js +1 -2
  28. package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.cjs.js.map +1 -1
  29. package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.es.js +1 -2
  30. package/dist/node_modules/graphql-request/build/legacy/helpers/analyzeDocument.es.js.map +1 -1
  31. package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +2 -2
  32. package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
  33. package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
  34. package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
  35. package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
  36. package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
  37. package/dist/node_modules/remove-accents/index.cjs.js +1 -1
  38. package/dist/node_modules/remove-accents/index.es.js +1 -1
  39. package/dist/node_modules/vfile/lib/index.cjs.js +1 -1
  40. package/dist/node_modules/vfile/lib/index.es.js +1 -1
  41. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js +6 -7
  42. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js.map +1 -1
  43. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js +6 -7
  44. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js.map +1 -1
  45. package/dist/shared/src/components/ProjectTableSettings/ColumnItem.cjs.js +2 -0
  46. package/dist/shared/src/components/ProjectTableSettings/ColumnItem.cjs.js.map +1 -1
  47. package/dist/shared/src/components/ProjectTableSettings/ColumnItem.es.js +2 -0
  48. package/dist/shared/src/components/ProjectTableSettings/ColumnItem.es.js.map +1 -1
  49. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js +5 -1
  50. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js.map +1 -1
  51. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js +5 -1
  52. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js.map +1 -1
  53. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +21 -86
  54. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
  55. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +21 -86
  56. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
  57. package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.cjs.js +2 -0
  58. package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.cjs.js.map +1 -1
  59. package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.es.js +2 -0
  60. package/dist/shared/src/components/ProjectTableSettings/SortableColumnItem.es.js.map +1 -1
  61. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +6 -7
  62. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
  63. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +6 -7
  64. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
  65. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +6 -7
  66. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
  67. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +6 -7
  68. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
  69. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +6 -7
  70. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
  71. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +6 -7
  72. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
  73. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js +27 -6
  74. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js.map +1 -1
  75. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js +27 -6
  76. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js.map +1 -1
  77. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +6 -7
  78. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
  79. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +6 -7
  80. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
  81. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +6 -7
  82. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
  83. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +6 -7
  84. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
  85. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +6 -7
  86. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
  87. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +6 -7
  88. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
  89. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +9 -10
  90. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
  91. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +9 -10
  92. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
  93. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +6 -7
  94. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
  95. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +6 -7
  96. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
  97. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +6 -7
  98. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
  99. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +6 -7
  100. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
  101. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +5 -6
  102. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
  103. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +5 -6
  104. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
  105. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +16 -9
  106. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
  107. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +16 -9
  108. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
  109. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +1 -1
  110. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
  111. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +1 -1
  112. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
  113. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +5 -7
  114. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
  115. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +5 -7
  116. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
  117. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js +1 -174
  118. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js.map +1 -1
  119. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js +2 -175
  120. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js.map +1 -1
  121. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js +212 -0
  122. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js.map +1 -0
  123. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js +212 -0
  124. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js.map +1 -0
  125. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js +1 -185
  126. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
  127. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js +2 -186
  128. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
  129. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +191 -0
  130. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -0
  131. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +191 -0
  132. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -0
  133. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.cjs.js +1 -79
  134. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.cjs.js.map +1 -1
  135. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.es.js +2 -80
  136. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsContext.es.js.map +1 -1
  137. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.cjs.js +84 -0
  138. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.cjs.js.map +1 -0
  139. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.es.js +84 -0
  140. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.es.js.map +1 -0
  141. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js +1 -277
  142. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js.map +1 -1
  143. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js +2 -278
  144. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js.map +1 -1
  145. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +282 -0
  146. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -0
  147. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +282 -0
  148. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -0
  149. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +3 -2
  150. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -1
  151. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +3 -2
  152. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -1
  153. package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.cjs.js.map +1 -1
  154. package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.es.js.map +1 -1
  155. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
  156. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
  157. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +8 -175
  158. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
  159. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +8 -175
  160. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
  161. package/dist/shared/src/containers/ProjectTreeTable/{context/ProjectTableModulesContext.cjs.js → hooks/useProjectTableModules.cjs.js} +26 -48
  162. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -0
  163. package/dist/shared/src/containers/ProjectTreeTable/{context/ProjectTableModulesContext.es.js → hooks/useProjectTableModules.es.js} +26 -48
  164. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js.map +1 -0
  165. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +4 -3
  166. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
  167. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +4 -3
  168. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
  169. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +8 -5
  170. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
  171. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +7 -4
  172. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
  173. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +7 -8
  174. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
  175. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +7 -8
  176. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
  177. package/dist/shared/src/context/RemoteModulesContext.es.js +1 -1
  178. package/dist/shared/src/hooks/useLoadModule.cjs.js +3 -3
  179. package/dist/shared/src/hooks/useLoadModule.cjs.js.map +1 -1
  180. package/dist/shared/src/hooks/useLoadModule.es.js +3 -3
  181. package/dist/shared/src/hooks/useLoadModule.es.js.map +1 -1
  182. package/dist/types/components/ProjectTableSettings/ColumnItem.d.ts +1 -0
  183. package/dist/types/components/ProjectTableSettings/SortableColumnItem.d.ts +1 -0
  184. package/dist/types/components/SettingsPanel/SettingsPanelItemTemplate.d.ts +1 -0
  185. package/dist/types/containers/ProjectTreeTable/components/GroupSettingsFallback.d.ts +9 -2
  186. package/dist/types/containers/ProjectTreeTable/context/ColumnSettingsContext.d.ts +16 -16
  187. package/dist/types/containers/ProjectTreeTable/context/ColumnSettingsProvider.d.ts +9 -0
  188. package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +5 -61
  189. package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +59 -0
  190. package/dist/types/containers/ProjectTreeTable/context/SelectedRowsContext.d.ts +3 -8
  191. package/dist/types/containers/ProjectTreeTable/context/SelectedRowsProvider.d.ts +6 -0
  192. package/dist/types/containers/ProjectTreeTable/context/SelectionCellsContext.d.ts +2 -4
  193. package/dist/types/containers/ProjectTreeTable/context/SelectionCellsProvider.d.ts +4 -0
  194. package/dist/types/containers/ProjectTreeTable/context/index.d.ts +4 -2
  195. package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +1 -0
  196. package/dist/types/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.d.ts +1 -2
  197. package/dist/types/containers/ProjectTreeTable/hooks/useEntitiesMap.d.ts +1 -1
  198. package/dist/types/containers/ProjectTreeTable/hooks/useFetchOverviewData.d.ts +4 -3
  199. package/dist/types/containers/ProjectTreeTable/hooks/useGetGroupedFields.d.ts +1 -1
  200. package/dist/types/containers/ProjectTreeTable/{context/ProjectTableModulesContext.d.ts → hooks/useProjectTableModules.d.ts} +5 -12
  201. package/dist/types/containers/ProjectTreeTable/index.d.ts +1 -10
  202. package/dist/types/containers/ProjectTreeTable/types/overviewContext.d.ts +3 -3
  203. package/package.json +1 -1
  204. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.cjs.js.map +0 -1
  205. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.es.js.map +0 -1
  206. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.cjs.js +0 -33
  207. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.cjs.js.map +0 -1
  208. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.es.js +0 -33
  209. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableSelectionContext.es.js.map +0 -1
  210. 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.ProjectTableProvider = ProjectTableProvider;
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 { j as jsxRuntimeExports } from "../../../../../_virtual/jsx-runtime.es.js";
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
- ProjectTableProvider,
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