@ynput/ayon-frontend-shared 0.2.32 → 0.2.34

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 (636) hide show
  1. package/dist/DetailsPanel.cjs.js +1 -1
  2. package/dist/DetailsPanel.es.js +32 -22
  3. package/dist/DetailsPanel.es.js.map +1 -1
  4. package/dist/Feed.cjs.js +1 -1
  5. package/dist/Feed.es.js +19 -13
  6. package/dist/Feed.es.js.map +1 -1
  7. package/dist/Views.cjs.js.map +1 -1
  8. package/dist/Views.es.js.map +1 -1
  9. package/dist/_virtual/index.cjs5.js +1 -1
  10. package/dist/_virtual/index.cjs6.js +1 -1
  11. package/dist/_virtual/index.es5.js +2 -5
  12. package/dist/_virtual/index.es5.js.map +1 -1
  13. package/dist/_virtual/index.es6.js +5 -2
  14. package/dist/_virtual/index.es6.js.map +1 -1
  15. package/dist/api.cjs.js +1 -1
  16. package/dist/api.es.js +230 -223
  17. package/dist/api.es.js.map +1 -1
  18. package/dist/components.cjs.js +1 -1
  19. package/dist/components.es.js +84 -69
  20. package/dist/components.es.js.map +1 -1
  21. package/dist/index.cjs.js +1 -1
  22. package/dist/index.es.js +19 -9
  23. package/dist/index.es.js.map +1 -1
  24. package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
  25. package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
  26. package/dist/node_modules/remove-accents/index.cjs.js +1 -1
  27. package/dist/node_modules/remove-accents/index.es.js +1 -1
  28. package/dist/shared/src/api/base/client.cjs.js +1 -1
  29. package/dist/shared/src/api/base/client.cjs.js.map +1 -1
  30. package/dist/shared/src/api/base/client.es.js +9 -8
  31. package/dist/shared/src/api/base/client.es.js.map +1 -1
  32. package/dist/shared/src/api/generated/activityFeed.cjs.js +1 -1
  33. package/dist/shared/src/api/generated/activityFeed.cjs.js.map +1 -1
  34. package/dist/shared/src/api/generated/activityFeed.es.js +3 -0
  35. package/dist/shared/src/api/generated/activityFeed.es.js.map +1 -1
  36. package/dist/shared/src/api/generated/entityLists.cjs.js +1 -1
  37. package/dist/shared/src/api/generated/entityLists.cjs.js.map +1 -1
  38. package/dist/shared/src/api/generated/entityLists.es.js +4 -1
  39. package/dist/shared/src/api/generated/entityLists.es.js.map +1 -1
  40. package/dist/shared/src/api/generated/graphql.cjs.js +10 -7
  41. package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
  42. package/dist/shared/src/api/generated/graphql.es.js +15 -12
  43. package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
  44. package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
  45. package/dist/shared/src/api/generated/projects.es.js.map +1 -1
  46. package/dist/shared/src/api/generated/views.cjs.js.map +1 -1
  47. package/dist/shared/src/api/generated/views.es.js.map +1 -1
  48. package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -1
  49. package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
  50. package/dist/shared/src/api/queries/activities/getActivities.es.js +4 -8
  51. package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
  52. package/dist/shared/src/api/queries/activities/getCategories.cjs.js +2 -0
  53. package/dist/shared/src/api/queries/activities/getCategories.cjs.js.map +1 -0
  54. package/dist/shared/src/api/queries/activities/getCategories.es.js +53 -0
  55. package/dist/shared/src/api/queries/activities/getCategories.es.js.map +1 -0
  56. package/dist/shared/src/api/queries/activities/updateActivities.cjs.js +1 -1
  57. package/dist/shared/src/api/queries/activities/updateActivities.cjs.js.map +1 -1
  58. package/dist/shared/src/api/queries/activities/updateActivities.es.js +53 -51
  59. package/dist/shared/src/api/queries/activities/updateActivities.es.js.map +1 -1
  60. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +1 -1
  61. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
  62. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +5 -3
  63. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
  64. package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +1 -1
  65. package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
  66. package/dist/shared/src/api/queries/entities/updateEntity.es.js +32 -30
  67. package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
  68. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +1 -1
  69. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
  70. package/dist/shared/src/api/queries/entityLists/getLists.es.js +68 -68
  71. package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
  72. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +1 -1
  73. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
  74. package/dist/shared/src/api/queries/entityLists/updateLists.es.js +47 -49
  75. package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
  76. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +1 -1
  77. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
  78. package/dist/shared/src/api/queries/overview/updateOverview.es.js +62 -60
  79. package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
  80. package/dist/shared/src/api/queries/share/share.cjs.js +1 -1
  81. package/dist/shared/src/api/queries/share/share.cjs.js.map +1 -1
  82. package/dist/shared/src/api/queries/share/share.es.js +38 -12
  83. package/dist/shared/src/api/queries/share/share.es.js.map +1 -1
  84. package/dist/shared/src/api/queries/users/getUsers.cjs.js +2 -2
  85. package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
  86. package/dist/shared/src/api/queries/users/getUsers.es.js +39 -33
  87. package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
  88. package/dist/shared/src/api/queries/users/guests.cjs.js +2 -0
  89. package/dist/shared/src/api/queries/users/guests.cjs.js.map +1 -0
  90. package/dist/shared/src/api/queries/users/guests.es.js +60 -0
  91. package/dist/shared/src/api/queries/users/guests.es.js.map +1 -0
  92. package/dist/shared/src/api/queries/views/updateViews.cjs.js +1 -1
  93. package/dist/shared/src/api/queries/views/updateViews.cjs.js.map +1 -1
  94. package/dist/shared/src/api/queries/views/updateViews.es.js +14 -15
  95. package/dist/shared/src/api/queries/views/updateViews.es.js.map +1 -1
  96. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.cjs.js +2 -0
  97. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.cjs.js.map +1 -0
  98. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.es.js +135 -0
  99. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.es.js.map +1 -0
  100. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.cjs.js +39 -0
  101. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.cjs.js.map +1 -0
  102. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.es.js +44 -0
  103. package/dist/shared/src/components/AccessSearchInput/AccessSearchInput.styled.es.js.map +1 -0
  104. package/dist/shared/src/components/AccessUser/AccessUser.cjs.js +2 -0
  105. package/dist/shared/src/components/AccessUser/AccessUser.cjs.js.map +1 -0
  106. package/dist/shared/src/components/AccessUser/AccessUser.es.js +43 -0
  107. package/dist/shared/src/components/AccessUser/AccessUser.es.js.map +1 -0
  108. package/dist/shared/src/components/AccessUser/AccessUser.styled.cjs.js +46 -0
  109. package/dist/shared/src/components/AccessUser/AccessUser.styled.cjs.js.map +1 -0
  110. package/dist/shared/src/components/AccessUser/AccessUser.styled.es.js +50 -0
  111. package/dist/shared/src/components/AccessUser/AccessUser.styled.es.js.map +1 -0
  112. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +1 -1
  113. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
  114. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +4 -2
  115. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
  116. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +1 -1
  117. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
  118. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +4 -2
  119. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
  120. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js +1 -1
  121. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js.map +1 -1
  122. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js +4 -2
  123. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js.map +1 -1
  124. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.cjs.js +47 -43
  125. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.cjs.js.map +1 -1
  126. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.es.js +47 -43
  127. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.styles.es.js.map +1 -1
  128. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js +2 -2
  129. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js.map +1 -1
  130. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js +4 -2
  131. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js.map +1 -1
  132. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.cjs.js +1 -1
  133. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.cjs.js.map +1 -1
  134. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.es.js +4 -2
  135. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.es.js.map +1 -1
  136. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js +1 -1
  137. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js.map +1 -1
  138. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js +4 -2
  139. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js.map +1 -1
  140. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +1 -1
  141. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
  142. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +12 -2
  143. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
  144. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js +1 -1
  145. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js.map +1 -1
  146. package/dist/shared/src/components/Feedback/FeedbackContext.es.js +6 -4
  147. package/dist/shared/src/components/Feedback/FeedbackContext.es.js.map +1 -1
  148. package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js +1 -1
  149. package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js.map +1 -1
  150. package/dist/shared/src/components/LinksManager/AddNewLinks.es.js +12 -2
  151. package/dist/shared/src/components/LinksManager/AddNewLinks.es.js.map +1 -1
  152. package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js +1 -1
  153. package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js.map +1 -1
  154. package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js +4 -2
  155. package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js.map +1 -1
  156. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js +1 -1
  157. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js.map +1 -1
  158. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js +12 -2
  159. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js.map +1 -1
  160. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js +1 -1
  161. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js.map +1 -1
  162. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js +40 -38
  163. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js.map +1 -1
  164. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +1 -1
  165. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -1
  166. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +12 -2
  167. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -1
  168. package/dist/shared/src/components/Powerpack/RequiredPowerpackVersion.cjs.js +9 -0
  169. package/dist/shared/src/components/Powerpack/RequiredPowerpackVersion.cjs.js.map +1 -0
  170. package/dist/shared/src/components/Powerpack/RequiredPowerpackVersion.es.js +25 -0
  171. package/dist/shared/src/components/Powerpack/RequiredPowerpackVersion.es.js.map +1 -0
  172. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +1 -1
  173. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
  174. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +14 -4
  175. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
  176. package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.cjs.js +1 -1
  177. package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.cjs.js.map +1 -1
  178. package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.es.js +12 -2
  179. package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.es.js.map +1 -1
  180. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +1 -1
  181. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
  182. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +25 -21
  183. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
  184. package/dist/shared/src/components/RenameForm/RenameForm.cjs.js +1 -1
  185. package/dist/shared/src/components/RenameForm/RenameForm.cjs.js.map +1 -1
  186. package/dist/shared/src/components/RenameForm/RenameForm.es.js +12 -2
  187. package/dist/shared/src/components/RenameForm/RenameForm.es.js.map +1 -1
  188. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +1 -1
  189. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
  190. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +4 -2
  191. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
  192. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +1 -1
  193. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
  194. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +12 -2
  195. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
  196. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +1 -1
  197. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
  198. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +13 -3
  199. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
  200. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +1 -1
  201. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
  202. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +12 -2
  203. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
  204. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js +1 -1
  205. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js.map +1 -1
  206. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js +4 -2
  207. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js.map +1 -1
  208. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +1 -1
  209. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
  210. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +4 -2
  211. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
  212. package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.cjs.js +12 -0
  213. package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.cjs.js.map +1 -0
  214. package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.es.js +46 -0
  215. package/dist/shared/src/components/ShareOptionIcon/ShareOptionIcon.es.js.map +1 -0
  216. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +1 -1
  217. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
  218. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +12 -2
  219. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
  220. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +1 -1
  221. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
  222. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +12 -2
  223. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
  224. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js +1 -1
  225. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js.map +1 -1
  226. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js +6 -4
  227. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js.map +1 -1
  228. package/dist/shared/src/components/Watchers/Watchers.cjs.js +1 -1
  229. package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
  230. package/dist/shared/src/components/Watchers/Watchers.es.js +4 -2
  231. package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
  232. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +1 -1
  233. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
  234. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +12 -2
  235. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
  236. package/dist/shared/src/containers/Actions/Actions.cjs.js +1 -1
  237. package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
  238. package/dist/shared/src/containers/Actions/Actions.es.js +4 -2
  239. package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
  240. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +1 -1
  241. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
  242. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +12 -2
  243. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
  244. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +1 -1
  245. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
  246. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +136 -117
  247. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
  248. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +1 -1
  249. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
  250. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +12 -2
  251. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
  252. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +1 -1
  253. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
  254. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +28 -18
  255. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
  256. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +1 -1
  257. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
  258. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +13 -3
  259. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
  260. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +1 -1
  261. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
  262. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +4 -2
  263. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
  264. package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.cjs.js +1 -1
  265. package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.cjs.js.map +1 -1
  266. package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.es.js +5 -2
  267. package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.es.js.map +1 -1
  268. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js +1 -1
  269. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js.map +1 -1
  270. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js +21 -17
  271. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
  272. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +1 -1
  273. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
  274. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +4 -2
  275. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
  276. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js +1 -1
  277. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js.map +1 -1
  278. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js +12 -2
  279. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js.map +1 -1
  280. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js +1 -1
  281. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js.map +1 -1
  282. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js +12 -2
  283. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js.map +1 -1
  284. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js +1 -1
  285. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js.map +1 -1
  286. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js +12 -2
  287. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js.map +1 -1
  288. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js +1 -1
  289. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js.map +1 -1
  290. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js +12 -2
  291. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js.map +1 -1
  292. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js +1 -1
  293. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js.map +1 -1
  294. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js +4 -2
  295. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js.map +1 -1
  296. package/dist/shared/src/containers/Feed/Feed.cjs.js +1 -1
  297. package/dist/shared/src/containers/Feed/Feed.cjs.js.map +1 -1
  298. package/dist/shared/src/containers/Feed/Feed.es.js +92 -95
  299. package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
  300. package/dist/shared/src/containers/Feed/Feed.styled.cjs.js +4 -4
  301. package/dist/shared/src/containers/Feed/Feed.styled.cjs.js.map +1 -1
  302. package/dist/shared/src/containers/Feed/Feed.styled.es.js +8 -7
  303. package/dist/shared/src/containers/Feed/Feed.styled.es.js.map +1 -1
  304. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.cjs.js +13 -0
  305. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.cjs.js.map +1 -0
  306. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js +89 -0
  307. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js.map +1 -0
  308. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.cjs.js +21 -0
  309. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.cjs.js.map +1 -0
  310. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.es.js +62 -0
  311. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.es.js.map +1 -0
  312. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.cjs.js +51 -0
  313. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.cjs.js.map +1 -0
  314. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.es.js +76 -0
  315. package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryTag.es.js.map +1 -0
  316. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js +1 -1
  317. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js.map +1 -1
  318. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js +164 -130
  319. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js.map +1 -1
  320. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.cjs.js +34 -14
  321. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.cjs.js.map +1 -1
  322. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js +45 -24
  323. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js.map +1 -1
  324. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.cjs.js +3 -3
  325. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.cjs.js.map +1 -1
  326. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.es.js +58 -48
  327. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.es.js.map +1 -1
  328. package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.cjs.js +1 -1
  329. package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.cjs.js.map +1 -1
  330. package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.es.js +28 -28
  331. package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.es.js.map +1 -1
  332. package/dist/shared/src/containers/Feed/components/ActivityItem.cjs.js.map +1 -1
  333. package/dist/shared/src/containers/Feed/components/ActivityItem.es.js.map +1 -1
  334. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.cjs.js +1 -1
  335. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.cjs.js.map +1 -1
  336. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.es.js +24 -20
  337. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.es.js.map +1 -1
  338. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js +12 -12
  339. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js.map +1 -1
  340. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js +13 -13
  341. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js.map +1 -1
  342. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js +2 -2
  343. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js.map +1 -1
  344. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js +339 -257
  345. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
  346. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.cjs.js +69 -41
  347. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.cjs.js.map +1 -1
  348. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.es.js +77 -48
  349. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.es.js.map +1 -1
  350. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.cjs.js +2 -0
  351. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.cjs.js.map +1 -0
  352. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.es.js +19 -0
  353. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.es.js.map +1 -0
  354. package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.cjs.js +1 -1
  355. package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.cjs.js.map +1 -1
  356. package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.es.js +34 -31
  357. package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.es.js.map +1 -1
  358. package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.cjs.js +1 -1
  359. package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.cjs.js.map +1 -1
  360. package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.es.js +15 -6
  361. package/dist/shared/src/containers/Feed/components/ReactionContainer/ExistingReactions.es.js.map +1 -1
  362. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.cjs.js +1 -1
  363. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.cjs.js.map +1 -1
  364. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.es.js +24 -14
  365. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reaction.es.js.map +1 -1
  366. package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.cjs.js +1 -1
  367. package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.cjs.js.map +1 -1
  368. package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.es.js +60 -38
  369. package/dist/shared/src/containers/Feed/components/ReactionContainer/ReactionPanelOpener.es.js.map +1 -1
  370. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.cjs.js +1 -1
  371. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.cjs.js.map +1 -1
  372. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.es.js +26 -8
  373. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.es.js.map +1 -1
  374. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.cjs.js +65 -20
  375. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.cjs.js.map +1 -1
  376. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.es.js +71 -26
  377. package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.es.js.map +1 -1
  378. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +1 -1
  379. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js.map +1 -1
  380. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js +5 -2
  381. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js.map +1 -1
  382. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +1 -1
  383. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
  384. package/dist/shared/src/containers/Feed/context/FeedContext.es.js +39 -33
  385. package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
  386. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js +1 -1
  387. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js.map +1 -1
  388. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.es.js +57 -53
  389. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.es.js.map +1 -1
  390. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +1 -1
  391. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
  392. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +4 -2
  393. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
  394. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +1 -1
  395. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
  396. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +12 -2
  397. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
  398. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +1 -1
  399. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
  400. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +51 -41
  401. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
  402. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js +1 -1
  403. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js.map +1 -1
  404. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js +12 -2
  405. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js.map +1 -1
  406. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +1 -1
  407. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
  408. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +12 -2
  409. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
  410. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js +1 -1
  411. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js.map +1 -1
  412. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js +12 -2
  413. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js.map +1 -1
  414. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +1 -1
  415. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
  416. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +12 -10
  417. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
  418. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +1 -1
  419. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
  420. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +50 -40
  421. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
  422. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +1 -1
  423. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -1
  424. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +4 -2
  425. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -1
  426. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +1 -1
  427. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -1
  428. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +7 -5
  429. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -1
  430. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +1 -1
  431. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
  432. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +24 -21
  433. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
  434. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +1 -1
  435. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
  436. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +12 -2
  437. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
  438. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +1 -1
  439. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -1
  440. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +12 -2
  441. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -1
  442. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js +1 -1
  443. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js.map +1 -1
  444. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js +12 -2
  445. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js.map +1 -1
  446. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +1 -1
  447. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
  448. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +4 -2
  449. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
  450. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +1 -1
  451. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
  452. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +12 -2
  453. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
  454. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js +1 -1
  455. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js.map +1 -1
  456. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js +4 -2
  457. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js.map +1 -1
  458. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +1 -1
  459. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
  460. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +12 -2
  461. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
  462. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js +1 -1
  463. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js.map +1 -1
  464. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js +12 -2
  465. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js.map +1 -1
  466. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js +1 -1
  467. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js.map +1 -1
  468. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js +12 -2
  469. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js.map +1 -1
  470. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js +1 -1
  471. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -1
  472. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js +4 -2
  473. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js.map +1 -1
  474. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +1 -1
  475. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
  476. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +12 -2
  477. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
  478. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +1 -1
  479. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
  480. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +23 -13
  481. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
  482. package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.cjs.js +1 -1
  483. package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.cjs.js.map +1 -1
  484. package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.es.js +7 -7
  485. package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.es.js.map +1 -1
  486. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +1 -1
  487. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
  488. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +5 -3
  489. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
  490. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js +1 -1
  491. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js.map +1 -1
  492. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js +14 -4
  493. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js.map +1 -1
  494. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js +1 -1
  495. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js.map +1 -1
  496. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js +12 -2
  497. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js.map +1 -1
  498. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +1 -1
  499. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
  500. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +12 -2
  501. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
  502. package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js +1 -1
  503. package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js.map +1 -1
  504. package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js +43 -33
  505. package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js.map +1 -1
  506. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js +1 -1
  507. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js.map +1 -1
  508. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js +4 -2
  509. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js.map +1 -1
  510. package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js +1 -1
  511. package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js.map +1 -1
  512. package/dist/shared/src/containers/Views/context/ViewsContext.es.js +6 -4
  513. package/dist/shared/src/containers/Views/context/ViewsContext.es.js.map +1 -1
  514. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js +1 -1
  515. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js.map +1 -1
  516. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js +4 -2
  517. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js.map +1 -1
  518. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js +1 -1
  519. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js.map +1 -1
  520. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js +4 -2
  521. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js.map +1 -1
  522. package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js +1 -1
  523. package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js.map +1 -1
  524. package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js +4 -2
  525. package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js.map +1 -1
  526. package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js +1 -1
  527. package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js.map +1 -1
  528. package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js +4 -2
  529. package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js.map +1 -1
  530. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js +1 -1
  531. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js.map +1 -1
  532. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js +4 -2
  533. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js.map +1 -1
  534. package/dist/shared/src/context/AddonProjectContext.cjs.js +1 -1
  535. package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
  536. package/dist/shared/src/context/AddonProjectContext.es.js +6 -4
  537. package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
  538. package/dist/shared/src/context/DetailsPanelContext.cjs.js +1 -1
  539. package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
  540. package/dist/shared/src/context/DetailsPanelContext.es.js +73 -66
  541. package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
  542. package/dist/shared/src/context/PowerpackContext.cjs.js +1 -1
  543. package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
  544. package/dist/shared/src/context/PowerpackContext.es.js +42 -26
  545. package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
  546. package/dist/shared/src/context/RemoteModulesContext.cjs.js +1 -1
  547. package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
  548. package/dist/shared/src/context/RemoteModulesContext.es.js +6 -4
  549. package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
  550. package/dist/shared/src/hooks/useActionTriggers.cjs.js +1 -1
  551. package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
  552. package/dist/shared/src/hooks/useActionTriggers.es.js +4 -2
  553. package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
  554. package/dist/shared/src/hooks/useEntityUpdate.cjs.js +1 -1
  555. package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
  556. package/dist/shared/src/hooks/useEntityUpdate.es.js +4 -2
  557. package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
  558. package/dist/shared/src/hooks/useHierarchyTable.cjs.js +1 -1
  559. package/dist/shared/src/hooks/useHierarchyTable.cjs.js.map +1 -1
  560. package/dist/shared/src/hooks/useHierarchyTable.es.js +4 -2
  561. package/dist/shared/src/hooks/useHierarchyTable.es.js.map +1 -1
  562. package/dist/shared/src/hooks/useLoadModule.cjs.js.map +1 -1
  563. package/dist/shared/src/hooks/useLoadModule.es.js.map +1 -1
  564. package/dist/shared/src/hooks/useScopedStatuses.cjs.js +1 -1
  565. package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
  566. package/dist/shared/src/hooks/useScopedStatuses.es.js +6 -4
  567. package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
  568. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +1 -1
  569. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
  570. package/dist/shared/src/hooks/useUserProjectConfig.es.js +4 -2
  571. package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
  572. package/dist/shared/src/util/colorUtils.cjs.js +2 -0
  573. package/dist/shared/src/util/colorUtils.cjs.js.map +1 -0
  574. package/dist/shared/src/util/colorUtils.es.js +40 -0
  575. package/dist/shared/src/util/colorUtils.es.js.map +1 -0
  576. package/dist/types/api/generated/activityFeed.d.ts +9 -0
  577. package/dist/types/api/generated/entityLists.d.ts +2 -0
  578. package/dist/types/api/generated/graphql.d.ts +11 -3
  579. package/dist/types/api/generated/projects.d.ts +4 -4
  580. package/dist/types/api/generated/views.d.ts +9 -3
  581. package/dist/types/api/index.d.ts +1 -0
  582. package/dist/types/api/queries/activities/getCategories.d.ts +142 -0
  583. package/dist/types/api/queries/activities/getMentions.d.ts +1 -0
  584. package/dist/types/api/queries/activities/index.d.ts +1 -0
  585. package/dist/types/api/queries/activities/updateReaction.d.ts +1 -0
  586. package/dist/types/api/queries/users/getUsers.d.ts +132 -0
  587. package/dist/types/api/queries/users/guests.d.ts +453 -0
  588. package/dist/types/api/queries/users/index.d.ts +1 -0
  589. package/dist/types/api/queries/watchers/getWatchers.d.ts +1 -0
  590. package/dist/types/components/AccessSearchInput/AccessSearchInput.d.ts +16 -0
  591. package/dist/types/components/AccessSearchInput/AccessSearchInput.styled.d.ts +2 -0
  592. package/dist/types/components/AccessSearchInput/index.d.ts +2 -0
  593. package/dist/types/components/AccessUser/AccessUser.d.ts +24 -0
  594. package/dist/types/components/AccessUser/AccessUser.styled.d.ts +1 -0
  595. package/dist/types/components/AccessUser/index.d.ts +1 -0
  596. package/dist/types/components/Powerpack/RequiredPowerpackVersion.d.ts +5 -0
  597. package/dist/types/components/Powerpack/index.d.ts +1 -0
  598. package/dist/types/components/ShareOptionIcon/ShareOptionIcon.d.ts +16 -0
  599. package/dist/types/components/ShareOptionIcon/index.d.ts +1 -0
  600. package/dist/types/components/index.d.ts +4 -0
  601. package/dist/types/containers/DetailsPanel/DetailsPanel.d.ts +3 -1
  602. package/dist/types/containers/DetailsPanel/FeedContextWrapper.d.ts +1 -1
  603. package/dist/types/containers/DetailsPanel/FeedWrapper.d.ts +2 -1
  604. package/dist/types/containers/Feed/Feed.d.ts +3 -2
  605. package/dist/types/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.d.ts +14 -0
  606. package/dist/types/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.d.ts +10 -0
  607. package/dist/types/containers/Feed/components/ActivityCategorySelect/CategoryTag.d.ts +10 -0
  608. package/dist/types/containers/Feed/components/ActivityCategorySelect/index.d.ts +3 -0
  609. package/dist/types/containers/Feed/components/ActivityComment/ActivityComment.d.ts +1 -1
  610. package/dist/types/containers/Feed/components/ActivityComment/ActivityComment.styled.d.ts +2 -1
  611. package/dist/types/containers/Feed/components/ActivityComment/ActivityMarkdownComponents.d.ts +3 -1
  612. package/dist/types/containers/Feed/components/ActivityItem.d.ts +1 -1
  613. package/dist/types/containers/Feed/components/ActivityReference/ActivityReference.d.ts +2 -0
  614. package/dist/types/containers/Feed/components/ActivityReference/ActivityReference.styled.d.ts +2 -0
  615. package/dist/types/containers/Feed/components/CommentInput/CommentInput.d.ts +1 -0
  616. package/dist/types/containers/Feed/components/CommentInput/CommentInput.styled.d.ts +7 -1
  617. package/dist/types/containers/Feed/components/CommentInput/hooks/useBlendedCategoryColor.d.ts +11 -0
  618. package/dist/types/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.d.ts +2 -1
  619. package/dist/types/containers/Feed/components/ReactionContainer/ExistingReactions.d.ts +4 -1
  620. package/dist/types/containers/Feed/components/ReactionContainer/Reaction.d.ts +4 -1
  621. package/dist/types/containers/Feed/components/ReactionContainer/ReactionPanelOpener.d.ts +4 -1
  622. package/dist/types/containers/Feed/components/ReactionContainer/Reactions.d.ts +5 -1
  623. package/dist/types/containers/Feed/components/ReactionContainer/Reactions.styled.d.ts +8 -3
  624. package/dist/types/containers/Feed/context/FeedContext.d.ts +3 -1
  625. package/dist/types/containers/Feed/hooks/useCommentMutations.d.ts +3 -2
  626. package/dist/types/containers/Feed/index.d.ts +1 -0
  627. package/dist/types/containers/ProjectTreeTable/widgets/BooleanWidget.d.ts +1 -0
  628. package/dist/types/containers/Views/index.d.ts +5 -2
  629. package/dist/types/context/DetailsPanelContext.d.ts +9 -0
  630. package/dist/types/context/PowerpackContext.d.ts +1 -1
  631. package/dist/types/util/colorUtils.d.ts +42 -0
  632. package/dist/types/util/index.d.ts +1 -0
  633. package/dist/util.cjs.js +1 -1
  634. package/dist/util.es.js +30 -24
  635. package/dist/util.es.js.map +1 -1
  636. package/package.json +1 -1
@@ -1,2 +1,2 @@
1
- "use strict";require("../../../api/base/client.cjs.js");require("../../../api/generated/graphql.cjs.js");require("../../../api/generated/graphqlLinks.cjs.js");require("../../../api/generated/access.cjs.js");require("../../../api/generated/actions.cjs.js");require("../../../api/generated/activityFeed.cjs.js");require("../../../api/generated/addons.cjs.js");require("../../../api/generated/anatomy.cjs.js");require("../../../api/generated/attributes.cjs.js");require("../../../api/generated/authentication.cjs.js");require("../../../api/generated/bundles.cjs.js");require("../../../api/generated/configuration.cjs.js");require("../../../api/generated/desktop.cjs.js");require("../../../api/generated/entityLists.cjs.js");require("../../../api/generated/events.cjs.js");require("../../../api/generated/files.cjs.js");require("../../../api/generated/folders.cjs.js");require("../../../api/generated/inbox.cjs.js");require("../../../api/generated/links.cjs.js");require("../../../api/generated/market.cjs.js");require("../../../api/generated/onboarding.cjs.js");require("../../../api/generated/operations.cjs.js");require("../../../api/generated/products.cjs.js");require("../../../api/generated/projectDashboard.cjs.js");require("../../../api/generated/projects.cjs.js");require("../../../api/generated/reviewables.cjs.js");require("../../../api/generated/services.cjs.js");require("../../../api/generated/system.cjs.js");require("../../../api/generated/tasks.cjs.js");require("../../../api/generated/teams.cjs.js");require("../../../api/generated/thumbnails.cjs.js");require("../../../api/generated/uRIs.cjs.js");require("../../../api/generated/users.cjs.js");require("../../../api/generated/versions.cjs.js");require("../../../api/generated/workfiles.cjs.js");require("../../../api/generated/ynputCloud.cjs.js");require("../../../api/generated/grouping.cjs.js");require("../../../api/generated/views.cjs.js");require("../../../api/queries/actions/getActions.cjs.js");require("../../../api/queries/activities/getActivities.cjs.js");require("../../../api/queries/activities/updateActivities.cjs.js");require("../../../api/queries/activities/updateReaction.cjs.js");require("../../../api/queries/activities/getMentions.cjs.js");require("../../../api/queries/addons/getAddons.cjs.js");require("../../../api/queries/addons/updateAddons.cjs.js");require("../../../api/queries/attributes/getAttributes.cjs.js");require("../../../api/queries/attributes/updateAttributes.cjs.js");require("../../../api/queries/authentication/getAuthentication.cjs.js");require("../../../api/queries/cloud/cloud.cjs.js");require("../../../api/queries/entities/getEntity.cjs.js");require("../../../api/queries/entities/getEntityPanel.cjs.js");require("../../../api/queries/entities/updateEntity.cjs.js");require("../../../api/queries/entityLists/getLists.cjs.js");require("../../../api/queries/entityLists/updateLists.cjs.js");require("../../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../../api/queries/entityLists/listFolders.cjs.js");require("../../../api/queries/folders/getFolders.cjs.js");require("../../../api/queries/grouping/getGrouping.cjs.js");require("../../../api/queries/links/updateLinks.cjs.js");require("../../../api/queries/links/getLinks.cjs.js");require("../../../api/queries/links/getEntityLinks.cjs.js");require("../../../api/queries/overview/getOverview.cjs.js");require("../../../api/queries/overview/updateOverview.cjs.js");require("../../../api/queries/permissions/getPermissions.cjs.js");require("../../../api/queries/products/createProduct.cjs.js");require("../../../api/queries/project/getProject.cjs.js");require("../../../api/queries/project/updateProject.cjs.js");require("../../../api/queries/review/getReview.cjs.js");require("../../../api/queries/review/updateReview.cjs.js");require("../../../api/queries/share/share.cjs.js");const b=require("../../../api/queries/system/getSystem.cjs.js");require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../../api/queries/users/getUsers.cjs.js");require("../../../api/queries/users/updateUsers.cjs.js");require("../../../api/queries/versions/updateVersions.cjs.js");require("../../../api/queries/views/getViews.cjs.js");require("../../../api/queries/views/updateViews.cjs.js");require("../../../api/queries/watchers/getWatchers.cjs.js");const c=({projectPermissions:u})=>{const{data:q,isLoading:t}=b.useGetSiteInfoQuery({full:!0}),{attributes:s=[]}=q||{},{attrib_read:n,attrib_write:a}=u||{},{enabled:l,attributes:r}=n||{},{enabled:d,attributes:i,fields:o}=a||{};return{attribFields:s.filter(e=>!l||(r==null?void 0:r.includes(e.name))).map(e=>({...e,readOnly:d?!(i!=null&&i.includes(e.name)):!1})),writableFields:o,isLoading:t}};module.exports=c;
1
+ "use strict";require("../../../api/base/client.cjs.js");require("../../../api/generated/graphql.cjs.js");require("../../../api/generated/graphqlLinks.cjs.js");require("../../../api/generated/access.cjs.js");require("../../../api/generated/actions.cjs.js");require("../../../api/generated/activityFeed.cjs.js");require("../../../api/generated/addons.cjs.js");require("../../../api/generated/anatomy.cjs.js");require("../../../api/generated/attributes.cjs.js");require("../../../api/generated/authentication.cjs.js");require("../../../api/generated/bundles.cjs.js");require("../../../api/generated/configuration.cjs.js");require("../../../api/generated/desktop.cjs.js");require("../../../api/generated/entityLists.cjs.js");require("../../../api/generated/events.cjs.js");require("../../../api/generated/files.cjs.js");require("../../../api/generated/folders.cjs.js");require("../../../api/generated/inbox.cjs.js");require("../../../api/generated/links.cjs.js");require("../../../api/generated/market.cjs.js");require("../../../api/generated/onboarding.cjs.js");require("../../../api/generated/operations.cjs.js");require("../../../api/generated/products.cjs.js");require("../../../api/generated/projectDashboard.cjs.js");require("../../../api/generated/projects.cjs.js");require("../../../api/generated/reviewables.cjs.js");require("../../../api/generated/services.cjs.js");require("../../../api/generated/system.cjs.js");require("../../../api/generated/tasks.cjs.js");require("../../../api/generated/teams.cjs.js");require("../../../api/generated/thumbnails.cjs.js");require("../../../api/generated/uRIs.cjs.js");require("../../../api/generated/users.cjs.js");require("../../../api/generated/versions.cjs.js");require("../../../api/generated/workfiles.cjs.js");require("../../../api/generated/ynputCloud.cjs.js");require("../../../api/generated/grouping.cjs.js");require("../../../api/generated/views.cjs.js");require("../../../api/queries/actions/getActions.cjs.js");require("../../../api/queries/activities/getActivities.cjs.js");require("../../../api/queries/activities/updateActivities.cjs.js");require("../../../api/queries/activities/updateReaction.cjs.js");require("../../../api/queries/activities/getMentions.cjs.js");require("../../../api/queries/activities/getCategories.cjs.js");require("../../../api/queries/addons/getAddons.cjs.js");require("../../../api/queries/addons/updateAddons.cjs.js");require("../../../api/queries/attributes/getAttributes.cjs.js");require("../../../api/queries/attributes/updateAttributes.cjs.js");require("../../../api/queries/authentication/getAuthentication.cjs.js");require("../../../api/queries/cloud/cloud.cjs.js");require("../../../api/queries/entities/getEntity.cjs.js");require("../../../api/queries/entities/getEntityPanel.cjs.js");require("../../../api/queries/entities/updateEntity.cjs.js");require("../../../api/queries/entityLists/getLists.cjs.js");require("../../../api/queries/entityLists/updateLists.cjs.js");require("../../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../../api/queries/entityLists/listFolders.cjs.js");require("../../../api/queries/folders/getFolders.cjs.js");require("../../../api/queries/grouping/getGrouping.cjs.js");require("../../../api/queries/links/updateLinks.cjs.js");require("../../../api/queries/links/getLinks.cjs.js");require("../../../api/queries/links/getEntityLinks.cjs.js");require("../../../api/queries/overview/getOverview.cjs.js");require("../../../api/queries/overview/updateOverview.cjs.js");require("../../../api/queries/permissions/getPermissions.cjs.js");require("../../../api/queries/products/createProduct.cjs.js");require("../../../api/queries/project/getProject.cjs.js");require("../../../api/queries/project/updateProject.cjs.js");require("../../../api/queries/review/getReview.cjs.js");require("../../../api/queries/review/updateReview.cjs.js");require("../../../api/queries/share/share.cjs.js");const b=require("../../../api/queries/system/getSystem.cjs.js");require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../../api/queries/users/getUsers.cjs.js");require("../../../api/queries/users/updateUsers.cjs.js");require("../../../api/queries/users/guests.cjs.js");require("../../../api/queries/versions/updateVersions.cjs.js");require("../../../api/queries/views/getViews.cjs.js");require("../../../api/queries/views/updateViews.cjs.js");require("../../../api/queries/watchers/getWatchers.cjs.js");const c=({projectPermissions:u})=>{const{data:q,isLoading:t}=b.useGetSiteInfoQuery({full:!0}),{attributes:s=[]}=q||{},{attrib_read:n,attrib_write:a}=u||{},{enabled:l,attributes:r}=n||{},{enabled:d,attributes:i,fields:o}=a||{};return{attribFields:s.filter(e=>!l||(r==null?void 0:r.includes(e.name))).map(e=>({...e,readOnly:d?!(i!=null&&i.includes(e.name)):!1})),writableFields:o,isLoading:t}};module.exports=c;
2
2
  //# sourceMappingURL=useAttributesList.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useAttributesList.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useAttributesList.ts"],"sourcesContent":["import { useGetSiteInfoQuery, AttributeModel, Permissions } from '@shared/api'\n\nexport interface ProjectTableAttribute extends AttributeModel {\n readOnly?: boolean\n}\n\ninterface UseAttributeFieldsParams {\n projectPermissions?: Permissions\n}\n\nconst useAttributeFields = ({ projectPermissions }: UseAttributeFieldsParams) => {\n const { data: info, isLoading } = useGetSiteInfoQuery({ full: true })\n const { attributes = [] } = info || {}\n\n const { attrib_read, attrib_write } = projectPermissions || {}\n const { enabled: attribReadEnabled, attributes: attribReadAttributes } = attrib_read || {}\n const {\n enabled: attribWriteEnabled,\n attributes: attribWriteAttributes,\n fields: writableFields,\n } = attrib_write || {}\n\n // filter out scopes and filter out attributes that do not have read access\n const attribFields: ProjectTableAttribute[] = attributes\n .filter((a) => !attribReadEnabled || attribReadAttributes?.includes(a.name))\n .map((a) => ({\n ...a,\n readOnly: attribWriteEnabled ? !attribWriteAttributes?.includes(a.name) : false,\n }))\n\n return { attribFields, writableFields, isLoading }\n}\n\nexport default useAttributeFields\n"],"names":["useAttributeFields","projectPermissions","info","isLoading","useGetSiteInfoQuery","attributes","attrib_read","attrib_write","attribReadEnabled","attribReadAttributes","attribWriteEnabled","attribWriteAttributes","writableFields","a"],"mappings":"yzIAUA,MAAMA,EAAqB,CAAC,CAAE,mBAAAC,KAAmD,CACzE,KAAA,CAAE,KAAMC,EAAM,UAAAC,CAAA,EAAcC,EAAAA,oBAAoB,CAAE,KAAM,GAAM,EAC9D,CAAE,WAAAC,EAAa,EAAG,EAAIH,GAAQ,CAAC,EAE/B,CAAE,YAAAI,EAAa,aAAAC,CAAa,EAAIN,GAAsB,CAAC,EACvD,CAAE,QAASO,EAAmB,WAAYC,CAAqB,EAAIH,GAAe,CAAC,EACnF,CACJ,QAASI,EACT,WAAYC,EACZ,OAAQC,CACV,EAAIL,GAAgB,CAAC,EAUd,MAAA,CAAE,aAPqCF,EAC3C,OAAQQ,GAAM,CAACL,IAAqBC,GAAA,YAAAA,EAAsB,SAASI,EAAE,MAAK,EAC1E,IAAKA,IAAO,CACX,GAAGA,EACH,SAAUH,EAAqB,EAACC,GAAA,MAAAA,EAAuB,SAASE,EAAE,OAAQ,EAAA,EAC1E,EAEmB,eAAAD,EAAgB,UAAAT,CAAU,CACnD"}
1
+ {"version":3,"file":"useAttributesList.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useAttributesList.ts"],"sourcesContent":["import { useGetSiteInfoQuery, AttributeModel, Permissions } from '@shared/api'\n\nexport interface ProjectTableAttribute extends AttributeModel {\n readOnly?: boolean\n}\n\ninterface UseAttributeFieldsParams {\n projectPermissions?: Permissions\n}\n\nconst useAttributeFields = ({ projectPermissions }: UseAttributeFieldsParams) => {\n const { data: info, isLoading } = useGetSiteInfoQuery({ full: true })\n const { attributes = [] } = info || {}\n\n const { attrib_read, attrib_write } = projectPermissions || {}\n const { enabled: attribReadEnabled, attributes: attribReadAttributes } = attrib_read || {}\n const {\n enabled: attribWriteEnabled,\n attributes: attribWriteAttributes,\n fields: writableFields,\n } = attrib_write || {}\n\n // filter out scopes and filter out attributes that do not have read access\n const attribFields: ProjectTableAttribute[] = attributes\n .filter((a) => !attribReadEnabled || attribReadAttributes?.includes(a.name))\n .map((a) => ({\n ...a,\n readOnly: attribWriteEnabled ? !attribWriteAttributes?.includes(a.name) : false,\n }))\n\n return { attribFields, writableFields, isLoading }\n}\n\nexport default useAttributeFields\n"],"names":["useAttributeFields","projectPermissions","info","isLoading","useGetSiteInfoQuery","attributes","attrib_read","attrib_write","attribReadEnabled","attribReadAttributes","attribWriteEnabled","attribWriteAttributes","writableFields","a"],"mappings":"66IAUA,MAAMA,EAAqB,CAAC,CAAE,mBAAAC,KAAmD,CACzE,KAAA,CAAE,KAAMC,EAAM,UAAAC,CAAA,EAAcC,EAAAA,oBAAoB,CAAE,KAAM,GAAM,EAC9D,CAAE,WAAAC,EAAa,EAAG,EAAIH,GAAQ,CAAC,EAE/B,CAAE,YAAAI,EAAa,aAAAC,CAAa,EAAIN,GAAsB,CAAC,EACvD,CAAE,QAASO,EAAmB,WAAYC,CAAqB,EAAIH,GAAe,CAAC,EACnF,CACJ,QAASI,EACT,WAAYC,EACZ,OAAQC,CACV,EAAIL,GAAgB,CAAC,EAUd,MAAA,CAAE,aAPqCF,EAC3C,OAAQQ,GAAM,CAACL,IAAqBC,GAAA,YAAAA,EAAsB,SAASI,EAAE,MAAK,EAC1E,IAAKA,IAAO,CACX,GAAGA,EACH,SAAUH,EAAqB,EAACC,GAAA,MAAAA,EAAuB,SAASE,EAAE,OAAQ,EAAA,EAC1E,EAEmB,eAAAD,EAAgB,UAAAT,CAAU,CACnD"}
@@ -41,6 +41,7 @@ import "../../../api/queries/activities/getActivities.es.js";
41
41
  import "../../../api/queries/activities/updateActivities.es.js";
42
42
  import "../../../api/queries/activities/updateReaction.es.js";
43
43
  import "../../../api/queries/activities/getMentions.es.js";
44
+ import "../../../api/queries/activities/getCategories.es.js";
44
45
  import "../../../api/queries/addons/getAddons.es.js";
45
46
  import "../../../api/queries/addons/updateAddons.es.js";
46
47
  import "../../../api/queries/attributes/getAttributes.es.js";
@@ -73,11 +74,12 @@ import { useGetSiteInfoQuery as b } from "../../../api/queries/system/getSystem.
73
74
  import "../../../api/queries/userDashboard/getUserDashboard.es.js";
74
75
  import "../../../api/queries/users/getUsers.es.js";
75
76
  import "../../../api/queries/users/updateUsers.es.js";
77
+ import "../../../api/queries/users/guests.es.js";
76
78
  import "../../../api/queries/versions/updateVersions.es.js";
77
79
  import "../../../api/queries/views/getViews.es.js";
78
80
  import "../../../api/queries/views/updateViews.es.js";
79
81
  import "../../../api/queries/watchers/getWatchers.es.js";
80
- const Jt = ({ projectPermissions: o }) => {
82
+ const Mt = ({ projectPermissions: o }) => {
81
83
  const { data: m, isLoading: p } = b({ full: !0 }), { attributes: e = [] } = m || {}, { attrib_read: a, attrib_write: n } = o || {}, { enabled: s, attributes: i } = a || {}, {
82
84
  enabled: l,
83
85
  attributes: r,
@@ -89,6 +91,6 @@ const Jt = ({ projectPermissions: o }) => {
89
91
  })), writableFields: d, isLoading: p };
90
92
  };
91
93
  export {
92
- Jt as default
94
+ Mt as default
93
95
  };
94
96
  //# sourceMappingURL=useAttributesList.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useAttributesList.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useAttributesList.ts"],"sourcesContent":["import { useGetSiteInfoQuery, AttributeModel, Permissions } from '@shared/api'\n\nexport interface ProjectTableAttribute extends AttributeModel {\n readOnly?: boolean\n}\n\ninterface UseAttributeFieldsParams {\n projectPermissions?: Permissions\n}\n\nconst useAttributeFields = ({ projectPermissions }: UseAttributeFieldsParams) => {\n const { data: info, isLoading } = useGetSiteInfoQuery({ full: true })\n const { attributes = [] } = info || {}\n\n const { attrib_read, attrib_write } = projectPermissions || {}\n const { enabled: attribReadEnabled, attributes: attribReadAttributes } = attrib_read || {}\n const {\n enabled: attribWriteEnabled,\n attributes: attribWriteAttributes,\n fields: writableFields,\n } = attrib_write || {}\n\n // filter out scopes and filter out attributes that do not have read access\n const attribFields: ProjectTableAttribute[] = attributes\n .filter((a) => !attribReadEnabled || attribReadAttributes?.includes(a.name))\n .map((a) => ({\n ...a,\n readOnly: attribWriteEnabled ? !attribWriteAttributes?.includes(a.name) : false,\n }))\n\n return { attribFields, writableFields, isLoading }\n}\n\nexport default useAttributeFields\n"],"names":["useAttributeFields","projectPermissions","info","isLoading","useGetSiteInfoQuery","attributes","attrib_read","attrib_write","attribReadEnabled","attribReadAttributes","attribWriteEnabled","attribWriteAttributes","writableFields","a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAMA,KAAqB,CAAC,EAAE,oBAAAC,QAAmD;AACzE,QAAA,EAAE,MAAMC,GAAM,WAAAC,EAAA,IAAcC,EAAoB,EAAE,MAAM,IAAM,GAC9D,EAAE,YAAAC,IAAa,GAAG,IAAIH,KAAQ,CAAC,GAE/B,EAAE,aAAAI,GAAa,cAAAC,EAAa,IAAIN,KAAsB,CAAC,GACvD,EAAE,SAASO,GAAmB,YAAYC,EAAqB,IAAIH,KAAe,CAAC,GACnF;AAAA,IACJ,SAASI;AAAA,IACT,YAAYC;AAAA,IACZ,QAAQC;AAAA,EACV,IAAIL,KAAgB,CAAC;AAUd,SAAA,EAAE,cAPqCF,EAC3C,OAAO,CAACQ,MAAM,CAACL,MAAqBC,KAAA,gBAAAA,EAAsB,SAASI,EAAE,MAAK,EAC1E,IAAI,CAACA,OAAO;AAAA,IACX,GAAGA;AAAA,IACH,UAAUH,IAAqB,EAACC,KAAA,QAAAA,EAAuB,SAASE,EAAE,SAAQ;AAAA,EAAA,EAC1E,GAEmB,gBAAAD,GAAgB,WAAAT,EAAU;AACnD;"}
1
+ {"version":3,"file":"useAttributesList.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useAttributesList.ts"],"sourcesContent":["import { useGetSiteInfoQuery, AttributeModel, Permissions } from '@shared/api'\n\nexport interface ProjectTableAttribute extends AttributeModel {\n readOnly?: boolean\n}\n\ninterface UseAttributeFieldsParams {\n projectPermissions?: Permissions\n}\n\nconst useAttributeFields = ({ projectPermissions }: UseAttributeFieldsParams) => {\n const { data: info, isLoading } = useGetSiteInfoQuery({ full: true })\n const { attributes = [] } = info || {}\n\n const { attrib_read, attrib_write } = projectPermissions || {}\n const { enabled: attribReadEnabled, attributes: attribReadAttributes } = attrib_read || {}\n const {\n enabled: attribWriteEnabled,\n attributes: attribWriteAttributes,\n fields: writableFields,\n } = attrib_write || {}\n\n // filter out scopes and filter out attributes that do not have read access\n const attribFields: ProjectTableAttribute[] = attributes\n .filter((a) => !attribReadEnabled || attribReadAttributes?.includes(a.name))\n .map((a) => ({\n ...a,\n readOnly: attribWriteEnabled ? !attribWriteAttributes?.includes(a.name) : false,\n }))\n\n return { attribFields, writableFields, isLoading }\n}\n\nexport default useAttributeFields\n"],"names":["useAttributeFields","projectPermissions","info","isLoading","useGetSiteInfoQuery","attributes","attrib_read","attrib_write","attribReadEnabled","attribReadAttributes","attribWriteEnabled","attribWriteAttributes","writableFields","a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,MAAMA,KAAqB,CAAC,EAAE,oBAAAC,QAAmD;AACzE,QAAA,EAAE,MAAMC,GAAM,WAAAC,EAAA,IAAcC,EAAoB,EAAE,MAAM,IAAM,GAC9D,EAAE,YAAAC,IAAa,GAAG,IAAIH,KAAQ,CAAC,GAE/B,EAAE,aAAAI,GAAa,cAAAC,EAAa,IAAIN,KAAsB,CAAC,GACvD,EAAE,SAASO,GAAmB,YAAYC,EAAqB,IAAIH,KAAe,CAAC,GACnF;AAAA,IACJ,SAASI;AAAA,IACT,YAAYC;AAAA,IACZ,QAAQC;AAAA,EACV,IAAIL,KAAgB,CAAC;AAUd,SAAA,EAAE,cAPqCF,EAC3C,OAAO,CAACQ,MAAM,CAACL,MAAqBC,KAAA,gBAAAA,EAAsB,SAASI,EAAE,MAAK,EAC1E,IAAI,CAACA,OAAO;AAAA,IACX,GAAGA;AAAA,IACH,UAAUH,IAAqB,EAACC,KAAA,QAAAA,EAAuB,SAASE,EAAE,SAAQ;AAAA,EAAA,EAC1E,GAEmB,gBAAAD,GAAgB,WAAAT,EAAU;AACnD;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const M=require("./useGetEntityTypeData.cjs.js"),k=require("react");require("@ynput/ayon-react-components");const C=require("../../../util/productTypes.cjs.js");require("lodash");require("react-toastify");require("uuid");require("../../../util/pubsub.cjs.js");require("../context/CellEditingContext.cjs.js");require("../../../../../_virtual/jsx-runtime.cjs.js");require("../context/SelectionCellsContext.cjs.js");require("../context/ProjectTableQueriesContext.cjs.js");require("../context/ProjectTableContext.cjs.js");require("../context/ClipboardContext.cjs.js");require("@tanstack/react-table");require("../ProjectTreeTable.cjs.js");require("../context/ColumnSettingsContext.cjs.js");require("../context/SelectedRowsContext.cjs.js");require("../context/DetailsPanelEntityContext.cjs.js");;/* empty css */require("clsx");require("../../ContextMenu/ContextMenuContext.cjs.js");require("../context/ProjectDataContext.cjs.js");require("../../../api/base/client.cjs.js");require("../../../api/generated/graphql.cjs.js");require("../../../api/generated/graphqlLinks.cjs.js");require("../../../api/generated/access.cjs.js");require("../../../api/generated/actions.cjs.js");require("../../../api/generated/activityFeed.cjs.js");require("../../../api/generated/addons.cjs.js");require("../../../api/generated/anatomy.cjs.js");require("../../../api/generated/attributes.cjs.js");require("../../../api/generated/authentication.cjs.js");require("../../../api/generated/bundles.cjs.js");require("../../../api/generated/configuration.cjs.js");require("../../../api/generated/desktop.cjs.js");require("../../../api/generated/entityLists.cjs.js");require("../../../api/generated/events.cjs.js");require("../../../api/generated/files.cjs.js");require("../../../api/generated/folders.cjs.js");require("../../../api/generated/inbox.cjs.js");require("../../../api/generated/links.cjs.js");require("../../../api/generated/market.cjs.js");require("../../../api/generated/onboarding.cjs.js");require("../../../api/generated/operations.cjs.js");require("../../../api/generated/products.cjs.js");require("../../../api/generated/projectDashboard.cjs.js");require("../../../api/generated/projects.cjs.js");require("../../../api/generated/reviewables.cjs.js");require("../../../api/generated/services.cjs.js");require("../../../api/generated/system.cjs.js");require("../../../api/generated/tasks.cjs.js");require("../../../api/generated/teams.cjs.js");require("../../../api/generated/thumbnails.cjs.js");require("../../../api/generated/uRIs.cjs.js");require("../../../api/generated/users.cjs.js");require("../../../api/generated/versions.cjs.js");require("../../../api/generated/workfiles.cjs.js");require("../../../api/generated/ynputCloud.cjs.js");require("../../../api/generated/grouping.cjs.js");require("../../../api/generated/views.cjs.js");require("../../../api/queries/actions/getActions.cjs.js");require("../../../api/queries/activities/getActivities.cjs.js");require("../../../api/queries/activities/updateActivities.cjs.js");require("../../../api/queries/activities/updateReaction.cjs.js");require("../../../api/queries/activities/getMentions.cjs.js");require("../../../api/queries/addons/getAddons.cjs.js");require("../../../api/queries/addons/updateAddons.cjs.js");require("../../../api/queries/attributes/getAttributes.cjs.js");require("../../../api/queries/attributes/updateAttributes.cjs.js");require("../../../api/queries/authentication/getAuthentication.cjs.js");require("../../../api/queries/cloud/cloud.cjs.js");require("../../../api/queries/entities/getEntity.cjs.js");require("../../../api/queries/entities/getEntityPanel.cjs.js");require("../../../api/queries/entities/updateEntity.cjs.js");require("../../../api/queries/entityLists/getLists.cjs.js");require("../../../api/queries/entityLists/updateLists.cjs.js");require("../../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../../api/queries/entityLists/listFolders.cjs.js");require("../../../api/queries/folders/getFolders.cjs.js");require("../../../api/queries/grouping/getGrouping.cjs.js");require("../../../api/queries/links/updateLinks.cjs.js");require("../../../api/queries/links/getLinks.cjs.js");require("../../../api/queries/links/getEntityLinks.cjs.js");require("../../../api/queries/overview/getOverview.cjs.js");require("../../../api/queries/overview/updateOverview.cjs.js");require("../../../api/queries/permissions/getPermissions.cjs.js");require("../../../api/queries/products/createProduct.cjs.js");require("../../../api/queries/project/getProject.cjs.js");require("../../../api/queries/project/updateProject.cjs.js");require("../../../api/queries/review/getReview.cjs.js");require("../../../api/queries/review/updateReview.cjs.js");require("../../../api/queries/share/share.cjs.js");require("../../../api/queries/system/getSystem.cjs.js");require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../../api/queries/users/getUsers.cjs.js");require("../../../api/queries/users/updateUsers.cjs.js");require("../../../api/queries/versions/updateVersions.cjs.js");require("../../../api/queries/views/getViews.cjs.js");require("../../../api/queries/views/updateViews.cjs.js");require("../../../api/queries/watchers/getWatchers.cjs.js");require("../../../context/RemoteModulesContext.cjs.js");require("../../../../../_virtual/runtime.cjs.js");require("../../../../../_virtual/semver.cjs.js");require("../../../context/DetailsPanelContext.cjs.js");require("../../../context/ThumbnailUploaderContext.cjs.js");require("../../../context/SettingsPanelContext.cjs.js");require("../../../context/pip/PiPProvider.cjs.js");require("react-dom");require("../../../context/pip/PiPWrapper.cjs.js");require("../../../context/AddonProjectContext.cjs.js");require("../../../context/AddonContext.cjs.js");require("../../../context/PowerpackContext.cjs.js");require("../../../context/MoveEntityContext.cjs.js");require("../../../context/MenuContext.cjs.js");require("react-redux");require("custom-protocol-check");require("../components/GroupSettingsFallback.cjs.js");const B=require("../utils/linksToTableData.cjs.js"),N="next-page",m="_ungrouped",W="__",x=t=>t?Array.isArray(t)?t.map(e=>e.toString()):[t.toString()]:[],X=(t,e,d)=>{if(!d)return{value:e,label:e};const s=d.find(p=>p.value===e);return s?{value:s.value,label:s.label||s.value,color:s.color,icon:s.icon,count:s.count,img:t==="assignees"?`/api/users/${s.value}/avatar`:void 0}:{value:e,label:e}},f="_GROUP_",$=t=>`${f}${t}`,Y=t=>t.startsWith(f)?t.slice(f.length):null,F=t=>t.startsWith(f),V=(t,e,d=[])=>{var p,T,G,y,g;const s=t.id.replace("attrib.","");return s==="status"?((p=e==null?void 0:e.statuses)==null?void 0:p.map(a=>a.name))||[]:s==="taskType"?((T=e==null?void 0:e.taskTypes)==null?void 0:T.map(a=>a.name))||[]:s==="folderType"?((G=e==null?void 0:e.folderTypes)==null?void 0:G.map(a=>a.name))||[]:t.id.startsWith("attrib.")?((g=(y=d.find(a=>a.name===s))==null?void 0:y.data.enum)==null?void 0:g.map(a=>a.value.toString()))||[]:[]},z=t=>{const{project:e,entities:d,entityType:s,groups:p=[],attribFields:T,showEmpty:G}=t,y=M.useGetEntityTypeData({projectInfo:e}),g=k.useCallback((r,q)=>{const o=y("task",r.taskType);return{id:r.id+W+q,entityId:r.id,entityType:"task",parentId:r.folderId,name:r.name||"",label:r.label||r.name||"",icon:(o==null?void 0:o.icon)||null,color:(o==null?void 0:o.color)||null,status:r.status,assignees:r.assignees,tags:r.tags,img:null,subRows:[],subType:r.taskType||null,attrib:r.attrib,ownAttrib:r.ownAttrib,parents:r.parents||[],updatedAt:r.updatedAt,links:B.linksToTableData(r.links,"task",{folderTypes:(e==null?void 0:e.folderTypes)||[],productTypes:Object.values(C)||[],taskTypes:(e==null?void 0:e.taskTypes)||[]})}},[y]);return r=>{var h,w;const q=new Map;for(const n of p){const u=(h=n.value)==null?void 0:h.toString(),l=$(u),i=X(r.id,u,p);q.set(u,{id:l,name:u,entityType:"group",subRows:[],label:i.label,group:i,links:{}})}const o=f+"."+m,A=()=>{let n=q.get(o);return n||(n={id:o,name:"Ungrouped",entityType:"group",subRows:[],label:"Ungrouped",group:{value:o,label:"Ungrouped"},links:{}},q.set(o,n)),n};for(const[n,u]of d){if(u.entityType!==s)continue;let l=[];if(r.id.startsWith("attrib.")){const i=r.id.split(".")[1];l=x((w=u.attrib)==null?void 0:w[i])}else l=x(u[r.id]);l.length===0&&A().subRows.push(g(u,m));for(const i of l){const c=q.get(i);c?c.subRows.push(g(u,i)):A().subRows.push(g(u,m))}if("groups"in u&&Array.isArray(u.groups)){for(const i of u.groups)if(i.hasNextPage&&q.has(i.value)){const b=q.get(i.value);b&&b.subRows.push({id:`${i.value}-next-page`,name:"Load more tasks...",entityType:N,subRows:[],label:`Next page for ${i.value}`,group:{value:i.value,label:i.value},links:{}})}}}const v=Array.from(q.values()),R=V(r,e,T);v.sort((n,u)=>{var l,i,c,b,D,E,O,P,U,S;if(((l=n.group)==null?void 0:l.value)===o)return 1;if(((i=u.group)==null?void 0:i.value)===o)return-1;if(R.length){const I=R.indexOf(((c=n.group)==null?void 0:c.value)||""),_=R.indexOf(((b=u.group)==null?void 0:b.value)||"");return I!==-1&&_!==-1?I-_:I!==-1?-1:_!==-1?1:((O=(D=n.group)==null?void 0:D.label)==null?void 0:O.localeCompare(((E=u.group)==null?void 0:E.label)||""))||0}else return((S=(P=n.group)==null?void 0:P.label)==null?void 0:S.localeCompare(((U=u.group)==null?void 0:U.label)||""))||0});const L=v.filter(n=>n.subRows.length>0);return G?v:L}};exports.GROUP_BY_ID=f;exports.NEXT_PAGE_ID=N;exports.ROW_ID_SEPARATOR=W;exports.UNGROUPED_VALUE=m;exports.buildGroupId=$;exports.default=z;exports.isGroupId=F;exports.parseGroupId=Y;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const M=require("./useGetEntityTypeData.cjs.js"),k=require("react");require("@ynput/ayon-react-components");const C=require("../../../util/productTypes.cjs.js");require("lodash");require("react-toastify");require("uuid");require("../../../util/pubsub.cjs.js");require("../context/CellEditingContext.cjs.js");require("../../../../../_virtual/jsx-runtime.cjs.js");require("../context/SelectionCellsContext.cjs.js");require("../context/ProjectTableQueriesContext.cjs.js");require("../context/ProjectTableContext.cjs.js");require("../context/ClipboardContext.cjs.js");require("@tanstack/react-table");require("../ProjectTreeTable.cjs.js");require("../context/ColumnSettingsContext.cjs.js");require("../context/SelectedRowsContext.cjs.js");require("../context/DetailsPanelEntityContext.cjs.js");;/* empty css */require("clsx");require("../../ContextMenu/ContextMenuContext.cjs.js");require("../context/ProjectDataContext.cjs.js");require("../../../api/base/client.cjs.js");require("../../../api/generated/graphql.cjs.js");require("../../../api/generated/graphqlLinks.cjs.js");require("../../../api/generated/access.cjs.js");require("../../../api/generated/actions.cjs.js");require("../../../api/generated/activityFeed.cjs.js");require("../../../api/generated/addons.cjs.js");require("../../../api/generated/anatomy.cjs.js");require("../../../api/generated/attributes.cjs.js");require("../../../api/generated/authentication.cjs.js");require("../../../api/generated/bundles.cjs.js");require("../../../api/generated/configuration.cjs.js");require("../../../api/generated/desktop.cjs.js");require("../../../api/generated/entityLists.cjs.js");require("../../../api/generated/events.cjs.js");require("../../../api/generated/files.cjs.js");require("../../../api/generated/folders.cjs.js");require("../../../api/generated/inbox.cjs.js");require("../../../api/generated/links.cjs.js");require("../../../api/generated/market.cjs.js");require("../../../api/generated/onboarding.cjs.js");require("../../../api/generated/operations.cjs.js");require("../../../api/generated/products.cjs.js");require("../../../api/generated/projectDashboard.cjs.js");require("../../../api/generated/projects.cjs.js");require("../../../api/generated/reviewables.cjs.js");require("../../../api/generated/services.cjs.js");require("../../../api/generated/system.cjs.js");require("../../../api/generated/tasks.cjs.js");require("../../../api/generated/teams.cjs.js");require("../../../api/generated/thumbnails.cjs.js");require("../../../api/generated/uRIs.cjs.js");require("../../../api/generated/users.cjs.js");require("../../../api/generated/versions.cjs.js");require("../../../api/generated/workfiles.cjs.js");require("../../../api/generated/ynputCloud.cjs.js");require("../../../api/generated/grouping.cjs.js");require("../../../api/generated/views.cjs.js");require("../../../api/queries/actions/getActions.cjs.js");require("../../../api/queries/activities/getActivities.cjs.js");require("../../../api/queries/activities/updateActivities.cjs.js");require("../../../api/queries/activities/updateReaction.cjs.js");require("../../../api/queries/activities/getMentions.cjs.js");require("../../../api/queries/activities/getCategories.cjs.js");require("../../../api/queries/addons/getAddons.cjs.js");require("../../../api/queries/addons/updateAddons.cjs.js");require("../../../api/queries/attributes/getAttributes.cjs.js");require("../../../api/queries/attributes/updateAttributes.cjs.js");require("../../../api/queries/authentication/getAuthentication.cjs.js");require("../../../api/queries/cloud/cloud.cjs.js");require("../../../api/queries/entities/getEntity.cjs.js");require("../../../api/queries/entities/getEntityPanel.cjs.js");require("../../../api/queries/entities/updateEntity.cjs.js");require("../../../api/queries/entityLists/getLists.cjs.js");require("../../../api/queries/entityLists/updateLists.cjs.js");require("../../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../../api/queries/entityLists/listFolders.cjs.js");require("../../../api/queries/folders/getFolders.cjs.js");require("../../../api/queries/grouping/getGrouping.cjs.js");require("../../../api/queries/links/updateLinks.cjs.js");require("../../../api/queries/links/getLinks.cjs.js");require("../../../api/queries/links/getEntityLinks.cjs.js");require("../../../api/queries/overview/getOverview.cjs.js");require("../../../api/queries/overview/updateOverview.cjs.js");require("../../../api/queries/permissions/getPermissions.cjs.js");require("../../../api/queries/products/createProduct.cjs.js");require("../../../api/queries/project/getProject.cjs.js");require("../../../api/queries/project/updateProject.cjs.js");require("../../../api/queries/review/getReview.cjs.js");require("../../../api/queries/review/updateReview.cjs.js");require("../../../api/queries/share/share.cjs.js");require("../../../api/queries/system/getSystem.cjs.js");require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../../api/queries/users/getUsers.cjs.js");require("../../../api/queries/users/updateUsers.cjs.js");require("../../../api/queries/users/guests.cjs.js");require("../../../api/queries/versions/updateVersions.cjs.js");require("../../../api/queries/views/getViews.cjs.js");require("../../../api/queries/views/updateViews.cjs.js");require("../../../api/queries/watchers/getWatchers.cjs.js");require("../../../context/RemoteModulesContext.cjs.js");require("../../../../../_virtual/runtime.cjs.js");require("../../../../../_virtual/semver.cjs.js");require("../../../context/DetailsPanelContext.cjs.js");require("../../../context/ThumbnailUploaderContext.cjs.js");require("../../../context/SettingsPanelContext.cjs.js");require("../../../context/pip/PiPProvider.cjs.js");require("react-dom");require("../../../context/pip/PiPWrapper.cjs.js");require("../../../context/AddonProjectContext.cjs.js");require("../../../context/AddonContext.cjs.js");require("../../../context/PowerpackContext.cjs.js");require("../../../context/MoveEntityContext.cjs.js");require("../../../context/MenuContext.cjs.js");require("react-redux");require("custom-protocol-check");require("../components/GroupSettingsFallback.cjs.js");const B=require("../utils/linksToTableData.cjs.js"),N="next-page",m="_ungrouped",W="__",x=t=>t?Array.isArray(t)?t.map(e=>e.toString()):[t.toString()]:[],X=(t,e,d)=>{if(!d)return{value:e,label:e};const s=d.find(p=>p.value===e);return s?{value:s.value,label:s.label||s.value,color:s.color,icon:s.icon,count:s.count,img:t==="assignees"?`/api/users/${s.value}/avatar`:void 0}:{value:e,label:e}},f="_GROUP_",$=t=>`${f}${t}`,Y=t=>t.startsWith(f)?t.slice(f.length):null,F=t=>t.startsWith(f),V=(t,e,d=[])=>{var p,T,G,y,g;const s=t.id.replace("attrib.","");return s==="status"?((p=e==null?void 0:e.statuses)==null?void 0:p.map(a=>a.name))||[]:s==="taskType"?((T=e==null?void 0:e.taskTypes)==null?void 0:T.map(a=>a.name))||[]:s==="folderType"?((G=e==null?void 0:e.folderTypes)==null?void 0:G.map(a=>a.name))||[]:t.id.startsWith("attrib.")?((g=(y=d.find(a=>a.name===s))==null?void 0:y.data.enum)==null?void 0:g.map(a=>a.value.toString()))||[]:[]},z=t=>{const{project:e,entities:d,entityType:s,groups:p=[],attribFields:T,showEmpty:G}=t,y=M.useGetEntityTypeData({projectInfo:e}),g=k.useCallback((r,q)=>{const o=y("task",r.taskType);return{id:r.id+W+q,entityId:r.id,entityType:"task",parentId:r.folderId,name:r.name||"",label:r.label||r.name||"",icon:(o==null?void 0:o.icon)||null,color:(o==null?void 0:o.color)||null,status:r.status,assignees:r.assignees,tags:r.tags,img:null,subRows:[],subType:r.taskType||null,attrib:r.attrib,ownAttrib:r.ownAttrib,parents:r.parents||[],updatedAt:r.updatedAt,links:B.linksToTableData(r.links,"task",{folderTypes:(e==null?void 0:e.folderTypes)||[],productTypes:Object.values(C)||[],taskTypes:(e==null?void 0:e.taskTypes)||[]})}},[y]);return r=>{var h,w;const q=new Map;for(const n of p){const u=(h=n.value)==null?void 0:h.toString(),l=$(u),i=X(r.id,u,p);q.set(u,{id:l,name:u,entityType:"group",subRows:[],label:i.label,group:i,links:{}})}const o=f+"."+m,A=()=>{let n=q.get(o);return n||(n={id:o,name:"Ungrouped",entityType:"group",subRows:[],label:"Ungrouped",group:{value:o,label:"Ungrouped"},links:{}},q.set(o,n)),n};for(const[n,u]of d){if(u.entityType!==s)continue;let l=[];if(r.id.startsWith("attrib.")){const i=r.id.split(".")[1];l=x((w=u.attrib)==null?void 0:w[i])}else l=x(u[r.id]);l.length===0&&A().subRows.push(g(u,m));for(const i of l){const c=q.get(i);c?c.subRows.push(g(u,i)):A().subRows.push(g(u,m))}if("groups"in u&&Array.isArray(u.groups)){for(const i of u.groups)if(i.hasNextPage&&q.has(i.value)){const b=q.get(i.value);b&&b.subRows.push({id:`${i.value}-next-page`,name:"Load more tasks...",entityType:N,subRows:[],label:`Next page for ${i.value}`,group:{value:i.value,label:i.value},links:{}})}}}const v=Array.from(q.values()),R=V(r,e,T);v.sort((n,u)=>{var l,i,c,b,D,E,O,P,U,S;if(((l=n.group)==null?void 0:l.value)===o)return 1;if(((i=u.group)==null?void 0:i.value)===o)return-1;if(R.length){const I=R.indexOf(((c=n.group)==null?void 0:c.value)||""),_=R.indexOf(((b=u.group)==null?void 0:b.value)||"");return I!==-1&&_!==-1?I-_:I!==-1?-1:_!==-1?1:((O=(D=n.group)==null?void 0:D.label)==null?void 0:O.localeCompare(((E=u.group)==null?void 0:E.label)||""))||0}else return((S=(P=n.group)==null?void 0:P.label)==null?void 0:S.localeCompare(((U=u.group)==null?void 0:U.label)||""))||0});const L=v.filter(n=>n.subRows.length>0);return G?v:L}};exports.GROUP_BY_ID=f;exports.NEXT_PAGE_ID=N;exports.ROW_ID_SEPARATOR=W;exports.UNGROUPED_VALUE=m;exports.buildGroupId=$;exports.default=z;exports.isGroupId=F;exports.parseGroupId=Y;
2
2
  //# sourceMappingURL=useBuildGroupByTableData.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useBuildGroupByTableData.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.ts"],"sourcesContent":["// based on the groupBy field we take a flat list of items and group them\n// each group is a root node with subItems as the grouped items\n// any leftover items that do not match the groupBy field are added as a separate group (\"Ungrouped\")\n\nimport { ProjectModel, EntityGroup } from '@shared/api'\nimport { TableGroupBy } from '../context'\nimport { EditorTaskNode, EntitiesMap, EntityMap, ProjectTableAttribute, TableRow } from '../types'\nimport { useGetEntityTypeData } from './useGetEntityTypeData'\nimport { useCallback } from 'react'\nimport { linksToTableData } from '../utils'\nimport { productTypes } from '@shared/util'\nexport type GroupByEntityType = 'task' | 'folder' | 'version' | 'product'\n\nexport type GroupData = {\n value: string\n label: string\n color?: string\n icon?: string\n img?: string\n count?: number\n}\n\nexport const NEXT_PAGE_ID = 'next-page'\nexport const UNGROUPED_VALUE = '_ungrouped'\nexport const ROW_ID_SEPARATOR = '__'\n\nconst valueToStringArray = (value?: any): string[] =>\n value ? (Array.isArray(value) ? value.map((v) => v.toString()) : [value.toString()]) : []\n\n// get group label, color and icon\nconst getGroupData = (groupById: string, groupValue: string, groups?: EntityGroup[]): GroupData => {\n if (!groups)\n return {\n value: groupValue,\n label: groupValue,\n }\n\n const group = groups.find((g) => g.value === groupValue)\n if (!group) {\n return {\n value: groupValue,\n label: groupValue,\n }\n } else {\n return {\n value: group.value,\n label: group.label || group.value,\n color: group.color,\n icon: group.icon,\n count: group.count,\n img: groupById === 'assignees' ? `/api/users/${group.value}/avatar` : undefined,\n }\n }\n}\n\nexport const GROUP_BY_ID = '_GROUP_'\nexport const buildGroupId = (value: string) => `${GROUP_BY_ID}${value}`\nexport const parseGroupId = (groupId: string): string | null => {\n if (!groupId.startsWith(GROUP_BY_ID)) return null\n return groupId.slice(GROUP_BY_ID.length) // +1 for the underscore\n}\nexport const isGroupId = (id: string): boolean => id.startsWith(GROUP_BY_ID)\n\ntype BuildGroupByTableProps = {\n project?: ProjectModel\n entities: EntitiesMap\n entityType?: GroupByEntityType\n groups?: EntityGroup[]\n attribFields: ProjectTableAttribute[]\n showEmpty?: boolean\n}\n\n// get sorting ids based on the groupBy field\nconst getSortingIds = (\n groupBy: TableGroupBy,\n project?: ProjectModel,\n attribFields: ProjectTableAttribute[] = [],\n): string[] => {\n const attributeId = groupBy.id.replace('attrib.', '')\n\n // for status, taskType, folderType use project data order\n if (attributeId === 'status') {\n return project?.statuses?.map((s) => s.name) || []\n } else if (attributeId === 'taskType') {\n return project?.taskTypes?.map((t) => t.name) || []\n } else if (attributeId === 'folderType') {\n return project?.folderTypes?.map((f) => f.name) || []\n } else if (groupBy.id.startsWith('attrib.')) {\n // for other enum attributes, use the enum values order\n return (\n attribFields\n .find((field) => field.name === attributeId)\n ?.data.enum?.map((e) => e.value.toString()) || []\n )\n } else return []\n}\n\nconst useBuildGroupByTableData = (props: BuildGroupByTableProps) => {\n const { project, entities, entityType, groups = [], attribFields, showEmpty } = props\n const getEntityTypeData = useGetEntityTypeData({ projectInfo: project })\n\n const entityToGroupRow = useCallback(\n (task: EditorTaskNode, group?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n return {\n id: task.id + ROW_ID_SEPARATOR + group, // unique id for the task in the folder\n entityId: task.id,\n entityType: 'task',\n parentId: task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n parents: task.parents || [],\n updatedAt: task.updatedAt,\n links: linksToTableData(task.links, 'task', {\n folderTypes: project?.folderTypes || [],\n productTypes: Object.values(productTypes) || [],\n taskTypes: project?.taskTypes || [],\n }),\n }\n },\n [getEntityTypeData],\n )\n\n const buildGroupByTableData = (groupBy: TableGroupBy): TableRow[] => {\n const groupsMap = new Map<string, TableRow>()\n\n for (const group of groups) {\n const groupValue = group.value?.toString() as string\n const groupId = buildGroupId(groupValue)\n const groupData = getGroupData(groupBy.id, groupValue, groups)\n groupsMap.set(groupValue, {\n id: groupId,\n name: groupValue,\n entityType: 'group',\n subRows: [],\n label: groupData.label,\n group: groupData,\n links: {},\n })\n }\n\n const ungroupedId = GROUP_BY_ID + '.' + UNGROUPED_VALUE // unique id for ungrouped group\n // gets the \"Ungrouped\" group, creating it if it doesn't exist\n const getUnGroupedGroup = () => {\n let ungroupedGroup = groupsMap.get(ungroupedId)\n if (!ungroupedGroup) {\n ungroupedGroup = {\n id: ungroupedId,\n name: 'Ungrouped',\n entityType: 'group',\n subRows: [],\n label: 'Ungrouped',\n group: { value: ungroupedId, label: 'Ungrouped' },\n links: {},\n }\n // create ungrouped group if it doesn't exist\n groupsMap.set(ungroupedId, ungroupedGroup)\n }\n return ungroupedGroup\n }\n\n for (const [id, entity] of entities) {\n // if the entity is not of the specified type, skip it\n if (entity.entityType !== entityType) continue\n // add entities to specific group\n let groupValues: string[] = []\n if (groupBy.id.startsWith('attrib.')) {\n // for attribute based grouping, get the value of the attribute\n const attributeId = groupBy.id.split('.')[1]\n groupValues = valueToStringArray(entity.attrib?.[attributeId])\n } else {\n groupValues = valueToStringArray(entity[groupBy.id as keyof EntityMap])\n }\n\n // if there are no values, add to \"Ungrouped\" group\n if (groupValues.length === 0) {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n // for each group value, find it's group and add the entity to it\n // if we can't find the group, add it to \"Ungrouped\"\n for (const groupValue of groupValues) {\n const groupRow = groupsMap.get(groupValue)\n if (groupRow) {\n groupRow.subRows.push(entityToGroupRow(entity as EditorTaskNode, groupValue))\n } else {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n }\n\n // for groups metadata on entity, check if there is a next page\n if ('groups' in entity && Array.isArray(entity.groups)) {\n for (const group of entity.groups) {\n const hasNextPageGroup = group.hasNextPage\n if (hasNextPageGroup && groupsMap.has(group.value)) {\n // add a next page row to the group\n const groupRow = groupsMap.get(group.value)\n if (groupRow) {\n groupRow.subRows.push({\n id: `${group.value}-next-page`,\n name: `Load more tasks...`,\n entityType: NEXT_PAGE_ID,\n subRows: [],\n label: `Next page for ${group.value}`,\n group: { value: group.value, label: group.value },\n links: {},\n })\n }\n }\n }\n }\n }\n\n const groupsList = Array.from(groupsMap.values())\n\n const attribSortingIds = getSortingIds(groupBy, project, attribFields)\n\n // sort the groups by their label\n // if the group is an attribute with enum values, sort by the enum values\n groupsList.sort((a, b) => {\n if (a.group?.value === ungroupedId) return 1 // \"Ungrouped\" should be last\n if (b.group?.value === ungroupedId) return -1 // \"Ungrouped\" should be last\n if (attribSortingIds.length) {\n // sort by index of the enum value\n const indexA = attribSortingIds.indexOf(a.group?.value || '')\n const indexB = attribSortingIds.indexOf(b.group?.value || '')\n if (indexA !== -1 && indexB !== -1) {\n return indexA - indexB\n }\n if (indexA !== -1) return -1 // a is in the enum, b is not\n if (indexB !== -1) return 1 // b is in the enum, a is not\n // if both are not in the enum, sort by label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n } else {\n // for other groupings, sort by the group label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n }\n })\n\n // filter out empty groups\n const nonEmptyGroups = groupsList.filter((group) => group.subRows.length > 0)\n\n return showEmpty ? groupsList : nonEmptyGroups\n }\n\n return buildGroupByTableData\n}\n\nexport default useBuildGroupByTableData\n"],"names":["NEXT_PAGE_ID","UNGROUPED_VALUE","ROW_ID_SEPARATOR","valueToStringArray","value","v","getGroupData","groupById","groupValue","groups","group","g","GROUP_BY_ID","buildGroupId","parseGroupId","groupId","isGroupId","id","getSortingIds","groupBy","project","attribFields","attributeId","_a","s","_b","t","_c","f","_e","_d","field","e","useBuildGroupByTableData","props","entities","entityType","showEmpty","getEntityTypeData","useGetEntityTypeData","entityToGroupRow","useCallback","task","typeData","linksToTableData","productTypes","groupsMap","groupData","ungroupedId","getUnGroupedGroup","ungroupedGroup","entity","groupValues","groupRow","groupsList","attribSortingIds","a","b","indexA","indexB","_g","_f","_j","_h","_i","nonEmptyGroups"],"mappings":"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"}
1
+ {"version":3,"file":"useBuildGroupByTableData.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.ts"],"sourcesContent":["// based on the groupBy field we take a flat list of items and group them\n// each group is a root node with subItems as the grouped items\n// any leftover items that do not match the groupBy field are added as a separate group (\"Ungrouped\")\n\nimport { ProjectModel, EntityGroup } from '@shared/api'\nimport { TableGroupBy } from '../context'\nimport { EditorTaskNode, EntitiesMap, EntityMap, ProjectTableAttribute, TableRow } from '../types'\nimport { useGetEntityTypeData } from './useGetEntityTypeData'\nimport { useCallback } from 'react'\nimport { linksToTableData } from '../utils'\nimport { productTypes } from '@shared/util'\nexport type GroupByEntityType = 'task' | 'folder' | 'version' | 'product'\n\nexport type GroupData = {\n value: string\n label: string\n color?: string\n icon?: string\n img?: string\n count?: number\n}\n\nexport const NEXT_PAGE_ID = 'next-page'\nexport const UNGROUPED_VALUE = '_ungrouped'\nexport const ROW_ID_SEPARATOR = '__'\n\nconst valueToStringArray = (value?: any): string[] =>\n value ? (Array.isArray(value) ? value.map((v) => v.toString()) : [value.toString()]) : []\n\n// get group label, color and icon\nconst getGroupData = (groupById: string, groupValue: string, groups?: EntityGroup[]): GroupData => {\n if (!groups)\n return {\n value: groupValue,\n label: groupValue,\n }\n\n const group = groups.find((g) => g.value === groupValue)\n if (!group) {\n return {\n value: groupValue,\n label: groupValue,\n }\n } else {\n return {\n value: group.value,\n label: group.label || group.value,\n color: group.color,\n icon: group.icon,\n count: group.count,\n img: groupById === 'assignees' ? `/api/users/${group.value}/avatar` : undefined,\n }\n }\n}\n\nexport const GROUP_BY_ID = '_GROUP_'\nexport const buildGroupId = (value: string) => `${GROUP_BY_ID}${value}`\nexport const parseGroupId = (groupId: string): string | null => {\n if (!groupId.startsWith(GROUP_BY_ID)) return null\n return groupId.slice(GROUP_BY_ID.length) // +1 for the underscore\n}\nexport const isGroupId = (id: string): boolean => id.startsWith(GROUP_BY_ID)\n\ntype BuildGroupByTableProps = {\n project?: ProjectModel\n entities: EntitiesMap\n entityType?: GroupByEntityType\n groups?: EntityGroup[]\n attribFields: ProjectTableAttribute[]\n showEmpty?: boolean\n}\n\n// get sorting ids based on the groupBy field\nconst getSortingIds = (\n groupBy: TableGroupBy,\n project?: ProjectModel,\n attribFields: ProjectTableAttribute[] = [],\n): string[] => {\n const attributeId = groupBy.id.replace('attrib.', '')\n\n // for status, taskType, folderType use project data order\n if (attributeId === 'status') {\n return project?.statuses?.map((s) => s.name) || []\n } else if (attributeId === 'taskType') {\n return project?.taskTypes?.map((t) => t.name) || []\n } else if (attributeId === 'folderType') {\n return project?.folderTypes?.map((f) => f.name) || []\n } else if (groupBy.id.startsWith('attrib.')) {\n // for other enum attributes, use the enum values order\n return (\n attribFields\n .find((field) => field.name === attributeId)\n ?.data.enum?.map((e) => e.value.toString()) || []\n )\n } else return []\n}\n\nconst useBuildGroupByTableData = (props: BuildGroupByTableProps) => {\n const { project, entities, entityType, groups = [], attribFields, showEmpty } = props\n const getEntityTypeData = useGetEntityTypeData({ projectInfo: project })\n\n const entityToGroupRow = useCallback(\n (task: EditorTaskNode, group?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n return {\n id: task.id + ROW_ID_SEPARATOR + group, // unique id for the task in the folder\n entityId: task.id,\n entityType: 'task',\n parentId: task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n parents: task.parents || [],\n updatedAt: task.updatedAt,\n links: linksToTableData(task.links, 'task', {\n folderTypes: project?.folderTypes || [],\n productTypes: Object.values(productTypes) || [],\n taskTypes: project?.taskTypes || [],\n }),\n }\n },\n [getEntityTypeData],\n )\n\n const buildGroupByTableData = (groupBy: TableGroupBy): TableRow[] => {\n const groupsMap = new Map<string, TableRow>()\n\n for (const group of groups) {\n const groupValue = group.value?.toString() as string\n const groupId = buildGroupId(groupValue)\n const groupData = getGroupData(groupBy.id, groupValue, groups)\n groupsMap.set(groupValue, {\n id: groupId,\n name: groupValue,\n entityType: 'group',\n subRows: [],\n label: groupData.label,\n group: groupData,\n links: {},\n })\n }\n\n const ungroupedId = GROUP_BY_ID + '.' + UNGROUPED_VALUE // unique id for ungrouped group\n // gets the \"Ungrouped\" group, creating it if it doesn't exist\n const getUnGroupedGroup = () => {\n let ungroupedGroup = groupsMap.get(ungroupedId)\n if (!ungroupedGroup) {\n ungroupedGroup = {\n id: ungroupedId,\n name: 'Ungrouped',\n entityType: 'group',\n subRows: [],\n label: 'Ungrouped',\n group: { value: ungroupedId, label: 'Ungrouped' },\n links: {},\n }\n // create ungrouped group if it doesn't exist\n groupsMap.set(ungroupedId, ungroupedGroup)\n }\n return ungroupedGroup\n }\n\n for (const [id, entity] of entities) {\n // if the entity is not of the specified type, skip it\n if (entity.entityType !== entityType) continue\n // add entities to specific group\n let groupValues: string[] = []\n if (groupBy.id.startsWith('attrib.')) {\n // for attribute based grouping, get the value of the attribute\n const attributeId = groupBy.id.split('.')[1]\n groupValues = valueToStringArray(entity.attrib?.[attributeId])\n } else {\n groupValues = valueToStringArray(entity[groupBy.id as keyof EntityMap])\n }\n\n // if there are no values, add to \"Ungrouped\" group\n if (groupValues.length === 0) {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n // for each group value, find it's group and add the entity to it\n // if we can't find the group, add it to \"Ungrouped\"\n for (const groupValue of groupValues) {\n const groupRow = groupsMap.get(groupValue)\n if (groupRow) {\n groupRow.subRows.push(entityToGroupRow(entity as EditorTaskNode, groupValue))\n } else {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n }\n\n // for groups metadata on entity, check if there is a next page\n if ('groups' in entity && Array.isArray(entity.groups)) {\n for (const group of entity.groups) {\n const hasNextPageGroup = group.hasNextPage\n if (hasNextPageGroup && groupsMap.has(group.value)) {\n // add a next page row to the group\n const groupRow = groupsMap.get(group.value)\n if (groupRow) {\n groupRow.subRows.push({\n id: `${group.value}-next-page`,\n name: `Load more tasks...`,\n entityType: NEXT_PAGE_ID,\n subRows: [],\n label: `Next page for ${group.value}`,\n group: { value: group.value, label: group.value },\n links: {},\n })\n }\n }\n }\n }\n }\n\n const groupsList = Array.from(groupsMap.values())\n\n const attribSortingIds = getSortingIds(groupBy, project, attribFields)\n\n // sort the groups by their label\n // if the group is an attribute with enum values, sort by the enum values\n groupsList.sort((a, b) => {\n if (a.group?.value === ungroupedId) return 1 // \"Ungrouped\" should be last\n if (b.group?.value === ungroupedId) return -1 // \"Ungrouped\" should be last\n if (attribSortingIds.length) {\n // sort by index of the enum value\n const indexA = attribSortingIds.indexOf(a.group?.value || '')\n const indexB = attribSortingIds.indexOf(b.group?.value || '')\n if (indexA !== -1 && indexB !== -1) {\n return indexA - indexB\n }\n if (indexA !== -1) return -1 // a is in the enum, b is not\n if (indexB !== -1) return 1 // b is in the enum, a is not\n // if both are not in the enum, sort by label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n } else {\n // for other groupings, sort by the group label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n }\n })\n\n // filter out empty groups\n const nonEmptyGroups = groupsList.filter((group) => group.subRows.length > 0)\n\n return showEmpty ? groupsList : nonEmptyGroups\n }\n\n return buildGroupByTableData\n}\n\nexport default useBuildGroupByTableData\n"],"names":["NEXT_PAGE_ID","UNGROUPED_VALUE","ROW_ID_SEPARATOR","valueToStringArray","value","v","getGroupData","groupById","groupValue","groups","group","g","GROUP_BY_ID","buildGroupId","parseGroupId","groupId","isGroupId","id","getSortingIds","groupBy","project","attribFields","attributeId","_a","s","_b","t","_c","f","_e","_d","field","e","useBuildGroupByTableData","props","entities","entityType","showEmpty","getEntityTypeData","useGetEntityTypeData","entityToGroupRow","useCallback","task","typeData","linksToTableData","productTypes","groupsMap","groupData","ungroupedId","getUnGroupedGroup","ungroupedGroup","entity","groupValues","groupRow","groupsList","attribSortingIds","a","b","indexA","indexB","_g","_f","_j","_h","_i","nonEmptyGroups"],"mappings":"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"}
@@ -64,6 +64,7 @@ import "../../../api/queries/activities/getActivities.es.js";
64
64
  import "../../../api/queries/activities/updateActivities.es.js";
65
65
  import "../../../api/queries/activities/updateReaction.es.js";
66
66
  import "../../../api/queries/activities/getMentions.es.js";
67
+ import "../../../api/queries/activities/getCategories.es.js";
67
68
  import "../../../api/queries/addons/getAddons.es.js";
68
69
  import "../../../api/queries/addons/updateAddons.es.js";
69
70
  import "../../../api/queries/attributes/getAttributes.es.js";
@@ -96,6 +97,7 @@ import "../../../api/queries/system/getSystem.es.js";
96
97
  import "../../../api/queries/userDashboard/getUserDashboard.es.js";
97
98
  import "../../../api/queries/users/getUsers.es.js";
98
99
  import "../../../api/queries/users/updateUsers.es.js";
100
+ import "../../../api/queries/users/guests.es.js";
99
101
  import "../../../api/queries/versions/updateVersions.es.js";
100
102
  import "../../../api/queries/views/getViews.es.js";
101
103
  import "../../../api/queries/views/updateViews.es.js";
@@ -136,11 +138,11 @@ const M = "next-page", A = "_ungrouped", B = "__", N = (p) => p ? Array.isArray(
136
138
  value: t,
137
139
  label: t
138
140
  };
139
- }, y = "_GROUP_", X = (p) => `${y}${p}`, io = (p) => p.startsWith(y) ? p.slice(y.length) : null, po = (p) => p.startsWith(y), Y = (p, t, d = []) => {
141
+ }, y = "_GROUP_", X = (p) => `${y}${p}`, eo = (p) => p.startsWith(y) ? p.slice(y.length) : null, mo = (p) => p.startsWith(y), Y = (p, t, d = []) => {
140
142
  var l, T, v, c, g;
141
143
  const e = p.id.replace("attrib.", "");
142
144
  return e === "status" ? ((l = t == null ? void 0 : t.statuses) == null ? void 0 : l.map((s) => s.name)) || [] : e === "taskType" ? ((T = t == null ? void 0 : t.taskTypes) == null ? void 0 : T.map((s) => s.name)) || [] : e === "folderType" ? ((v = t == null ? void 0 : t.folderTypes) == null ? void 0 : v.map((s) => s.name)) || [] : p.id.startsWith("attrib.") ? ((g = (c = d.find((s) => s.name === e)) == null ? void 0 : c.data.enum) == null ? void 0 : g.map((s) => s.value.toString())) || [] : [];
143
- }, eo = (p) => {
145
+ }, no = (p) => {
144
146
  const { project: t, entities: d, entityType: e, groups: l = [], attribFields: T, showEmpty: v } = p, c = $({ projectInfo: t }), g = C(
145
147
  (r, u) => {
146
148
  const n = c("task", r.taskType);
@@ -250,8 +252,8 @@ export {
250
252
  B as ROW_ID_SEPARATOR,
251
253
  A as UNGROUPED_VALUE,
252
254
  X as buildGroupId,
253
- eo as default,
254
- po as isGroupId,
255
- io as parseGroupId
255
+ no as default,
256
+ mo as isGroupId,
257
+ eo as parseGroupId
256
258
  };
257
259
  //# sourceMappingURL=useBuildGroupByTableData.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useBuildGroupByTableData.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.ts"],"sourcesContent":["// based on the groupBy field we take a flat list of items and group them\n// each group is a root node with subItems as the grouped items\n// any leftover items that do not match the groupBy field are added as a separate group (\"Ungrouped\")\n\nimport { ProjectModel, EntityGroup } from '@shared/api'\nimport { TableGroupBy } from '../context'\nimport { EditorTaskNode, EntitiesMap, EntityMap, ProjectTableAttribute, TableRow } from '../types'\nimport { useGetEntityTypeData } from './useGetEntityTypeData'\nimport { useCallback } from 'react'\nimport { linksToTableData } from '../utils'\nimport { productTypes } from '@shared/util'\nexport type GroupByEntityType = 'task' | 'folder' | 'version' | 'product'\n\nexport type GroupData = {\n value: string\n label: string\n color?: string\n icon?: string\n img?: string\n count?: number\n}\n\nexport const NEXT_PAGE_ID = 'next-page'\nexport const UNGROUPED_VALUE = '_ungrouped'\nexport const ROW_ID_SEPARATOR = '__'\n\nconst valueToStringArray = (value?: any): string[] =>\n value ? (Array.isArray(value) ? value.map((v) => v.toString()) : [value.toString()]) : []\n\n// get group label, color and icon\nconst getGroupData = (groupById: string, groupValue: string, groups?: EntityGroup[]): GroupData => {\n if (!groups)\n return {\n value: groupValue,\n label: groupValue,\n }\n\n const group = groups.find((g) => g.value === groupValue)\n if (!group) {\n return {\n value: groupValue,\n label: groupValue,\n }\n } else {\n return {\n value: group.value,\n label: group.label || group.value,\n color: group.color,\n icon: group.icon,\n count: group.count,\n img: groupById === 'assignees' ? `/api/users/${group.value}/avatar` : undefined,\n }\n }\n}\n\nexport const GROUP_BY_ID = '_GROUP_'\nexport const buildGroupId = (value: string) => `${GROUP_BY_ID}${value}`\nexport const parseGroupId = (groupId: string): string | null => {\n if (!groupId.startsWith(GROUP_BY_ID)) return null\n return groupId.slice(GROUP_BY_ID.length) // +1 for the underscore\n}\nexport const isGroupId = (id: string): boolean => id.startsWith(GROUP_BY_ID)\n\ntype BuildGroupByTableProps = {\n project?: ProjectModel\n entities: EntitiesMap\n entityType?: GroupByEntityType\n groups?: EntityGroup[]\n attribFields: ProjectTableAttribute[]\n showEmpty?: boolean\n}\n\n// get sorting ids based on the groupBy field\nconst getSortingIds = (\n groupBy: TableGroupBy,\n project?: ProjectModel,\n attribFields: ProjectTableAttribute[] = [],\n): string[] => {\n const attributeId = groupBy.id.replace('attrib.', '')\n\n // for status, taskType, folderType use project data order\n if (attributeId === 'status') {\n return project?.statuses?.map((s) => s.name) || []\n } else if (attributeId === 'taskType') {\n return project?.taskTypes?.map((t) => t.name) || []\n } else if (attributeId === 'folderType') {\n return project?.folderTypes?.map((f) => f.name) || []\n } else if (groupBy.id.startsWith('attrib.')) {\n // for other enum attributes, use the enum values order\n return (\n attribFields\n .find((field) => field.name === attributeId)\n ?.data.enum?.map((e) => e.value.toString()) || []\n )\n } else return []\n}\n\nconst useBuildGroupByTableData = (props: BuildGroupByTableProps) => {\n const { project, entities, entityType, groups = [], attribFields, showEmpty } = props\n const getEntityTypeData = useGetEntityTypeData({ projectInfo: project })\n\n const entityToGroupRow = useCallback(\n (task: EditorTaskNode, group?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n return {\n id: task.id + ROW_ID_SEPARATOR + group, // unique id for the task in the folder\n entityId: task.id,\n entityType: 'task',\n parentId: task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n parents: task.parents || [],\n updatedAt: task.updatedAt,\n links: linksToTableData(task.links, 'task', {\n folderTypes: project?.folderTypes || [],\n productTypes: Object.values(productTypes) || [],\n taskTypes: project?.taskTypes || [],\n }),\n }\n },\n [getEntityTypeData],\n )\n\n const buildGroupByTableData = (groupBy: TableGroupBy): TableRow[] => {\n const groupsMap = new Map<string, TableRow>()\n\n for (const group of groups) {\n const groupValue = group.value?.toString() as string\n const groupId = buildGroupId(groupValue)\n const groupData = getGroupData(groupBy.id, groupValue, groups)\n groupsMap.set(groupValue, {\n id: groupId,\n name: groupValue,\n entityType: 'group',\n subRows: [],\n label: groupData.label,\n group: groupData,\n links: {},\n })\n }\n\n const ungroupedId = GROUP_BY_ID + '.' + UNGROUPED_VALUE // unique id for ungrouped group\n // gets the \"Ungrouped\" group, creating it if it doesn't exist\n const getUnGroupedGroup = () => {\n let ungroupedGroup = groupsMap.get(ungroupedId)\n if (!ungroupedGroup) {\n ungroupedGroup = {\n id: ungroupedId,\n name: 'Ungrouped',\n entityType: 'group',\n subRows: [],\n label: 'Ungrouped',\n group: { value: ungroupedId, label: 'Ungrouped' },\n links: {},\n }\n // create ungrouped group if it doesn't exist\n groupsMap.set(ungroupedId, ungroupedGroup)\n }\n return ungroupedGroup\n }\n\n for (const [id, entity] of entities) {\n // if the entity is not of the specified type, skip it\n if (entity.entityType !== entityType) continue\n // add entities to specific group\n let groupValues: string[] = []\n if (groupBy.id.startsWith('attrib.')) {\n // for attribute based grouping, get the value of the attribute\n const attributeId = groupBy.id.split('.')[1]\n groupValues = valueToStringArray(entity.attrib?.[attributeId])\n } else {\n groupValues = valueToStringArray(entity[groupBy.id as keyof EntityMap])\n }\n\n // if there are no values, add to \"Ungrouped\" group\n if (groupValues.length === 0) {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n // for each group value, find it's group and add the entity to it\n // if we can't find the group, add it to \"Ungrouped\"\n for (const groupValue of groupValues) {\n const groupRow = groupsMap.get(groupValue)\n if (groupRow) {\n groupRow.subRows.push(entityToGroupRow(entity as EditorTaskNode, groupValue))\n } else {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n }\n\n // for groups metadata on entity, check if there is a next page\n if ('groups' in entity && Array.isArray(entity.groups)) {\n for (const group of entity.groups) {\n const hasNextPageGroup = group.hasNextPage\n if (hasNextPageGroup && groupsMap.has(group.value)) {\n // add a next page row to the group\n const groupRow = groupsMap.get(group.value)\n if (groupRow) {\n groupRow.subRows.push({\n id: `${group.value}-next-page`,\n name: `Load more tasks...`,\n entityType: NEXT_PAGE_ID,\n subRows: [],\n label: `Next page for ${group.value}`,\n group: { value: group.value, label: group.value },\n links: {},\n })\n }\n }\n }\n }\n }\n\n const groupsList = Array.from(groupsMap.values())\n\n const attribSortingIds = getSortingIds(groupBy, project, attribFields)\n\n // sort the groups by their label\n // if the group is an attribute with enum values, sort by the enum values\n groupsList.sort((a, b) => {\n if (a.group?.value === ungroupedId) return 1 // \"Ungrouped\" should be last\n if (b.group?.value === ungroupedId) return -1 // \"Ungrouped\" should be last\n if (attribSortingIds.length) {\n // sort by index of the enum value\n const indexA = attribSortingIds.indexOf(a.group?.value || '')\n const indexB = attribSortingIds.indexOf(b.group?.value || '')\n if (indexA !== -1 && indexB !== -1) {\n return indexA - indexB\n }\n if (indexA !== -1) return -1 // a is in the enum, b is not\n if (indexB !== -1) return 1 // b is in the enum, a is not\n // if both are not in the enum, sort by label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n } else {\n // for other groupings, sort by the group label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n }\n })\n\n // filter out empty groups\n const nonEmptyGroups = groupsList.filter((group) => group.subRows.length > 0)\n\n return showEmpty ? groupsList : nonEmptyGroups\n }\n\n return buildGroupByTableData\n}\n\nexport default useBuildGroupByTableData\n"],"names":["NEXT_PAGE_ID","UNGROUPED_VALUE","ROW_ID_SEPARATOR","valueToStringArray","value","v","getGroupData","groupById","groupValue","groups","group","g","GROUP_BY_ID","buildGroupId","parseGroupId","groupId","isGroupId","id","getSortingIds","groupBy","project","attribFields","attributeId","_a","_b","t","_c","f","_e","_d","field","e","useBuildGroupByTableData","props","entities","entityType","showEmpty","getEntityTypeData","useGetEntityTypeData","entityToGroupRow","useCallback","task","typeData","linksToTableData","productTypes","groupsMap","groupData","ungroupedId","getUnGroupedGroup","ungroupedGroup","entity","groupValues","groupRow","groupsList","attribSortingIds","a","b","indexA","indexB","_g","_f","_j","_h","_i","nonEmptyGroups"],"mappings":"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"}
1
+ {"version":3,"file":"useBuildGroupByTableData.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.ts"],"sourcesContent":["// based on the groupBy field we take a flat list of items and group them\n// each group is a root node with subItems as the grouped items\n// any leftover items that do not match the groupBy field are added as a separate group (\"Ungrouped\")\n\nimport { ProjectModel, EntityGroup } from '@shared/api'\nimport { TableGroupBy } from '../context'\nimport { EditorTaskNode, EntitiesMap, EntityMap, ProjectTableAttribute, TableRow } from '../types'\nimport { useGetEntityTypeData } from './useGetEntityTypeData'\nimport { useCallback } from 'react'\nimport { linksToTableData } from '../utils'\nimport { productTypes } from '@shared/util'\nexport type GroupByEntityType = 'task' | 'folder' | 'version' | 'product'\n\nexport type GroupData = {\n value: string\n label: string\n color?: string\n icon?: string\n img?: string\n count?: number\n}\n\nexport const NEXT_PAGE_ID = 'next-page'\nexport const UNGROUPED_VALUE = '_ungrouped'\nexport const ROW_ID_SEPARATOR = '__'\n\nconst valueToStringArray = (value?: any): string[] =>\n value ? (Array.isArray(value) ? value.map((v) => v.toString()) : [value.toString()]) : []\n\n// get group label, color and icon\nconst getGroupData = (groupById: string, groupValue: string, groups?: EntityGroup[]): GroupData => {\n if (!groups)\n return {\n value: groupValue,\n label: groupValue,\n }\n\n const group = groups.find((g) => g.value === groupValue)\n if (!group) {\n return {\n value: groupValue,\n label: groupValue,\n }\n } else {\n return {\n value: group.value,\n label: group.label || group.value,\n color: group.color,\n icon: group.icon,\n count: group.count,\n img: groupById === 'assignees' ? `/api/users/${group.value}/avatar` : undefined,\n }\n }\n}\n\nexport const GROUP_BY_ID = '_GROUP_'\nexport const buildGroupId = (value: string) => `${GROUP_BY_ID}${value}`\nexport const parseGroupId = (groupId: string): string | null => {\n if (!groupId.startsWith(GROUP_BY_ID)) return null\n return groupId.slice(GROUP_BY_ID.length) // +1 for the underscore\n}\nexport const isGroupId = (id: string): boolean => id.startsWith(GROUP_BY_ID)\n\ntype BuildGroupByTableProps = {\n project?: ProjectModel\n entities: EntitiesMap\n entityType?: GroupByEntityType\n groups?: EntityGroup[]\n attribFields: ProjectTableAttribute[]\n showEmpty?: boolean\n}\n\n// get sorting ids based on the groupBy field\nconst getSortingIds = (\n groupBy: TableGroupBy,\n project?: ProjectModel,\n attribFields: ProjectTableAttribute[] = [],\n): string[] => {\n const attributeId = groupBy.id.replace('attrib.', '')\n\n // for status, taskType, folderType use project data order\n if (attributeId === 'status') {\n return project?.statuses?.map((s) => s.name) || []\n } else if (attributeId === 'taskType') {\n return project?.taskTypes?.map((t) => t.name) || []\n } else if (attributeId === 'folderType') {\n return project?.folderTypes?.map((f) => f.name) || []\n } else if (groupBy.id.startsWith('attrib.')) {\n // for other enum attributes, use the enum values order\n return (\n attribFields\n .find((field) => field.name === attributeId)\n ?.data.enum?.map((e) => e.value.toString()) || []\n )\n } else return []\n}\n\nconst useBuildGroupByTableData = (props: BuildGroupByTableProps) => {\n const { project, entities, entityType, groups = [], attribFields, showEmpty } = props\n const getEntityTypeData = useGetEntityTypeData({ projectInfo: project })\n\n const entityToGroupRow = useCallback(\n (task: EditorTaskNode, group?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n return {\n id: task.id + ROW_ID_SEPARATOR + group, // unique id for the task in the folder\n entityId: task.id,\n entityType: 'task',\n parentId: task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n parents: task.parents || [],\n updatedAt: task.updatedAt,\n links: linksToTableData(task.links, 'task', {\n folderTypes: project?.folderTypes || [],\n productTypes: Object.values(productTypes) || [],\n taskTypes: project?.taskTypes || [],\n }),\n }\n },\n [getEntityTypeData],\n )\n\n const buildGroupByTableData = (groupBy: TableGroupBy): TableRow[] => {\n const groupsMap = new Map<string, TableRow>()\n\n for (const group of groups) {\n const groupValue = group.value?.toString() as string\n const groupId = buildGroupId(groupValue)\n const groupData = getGroupData(groupBy.id, groupValue, groups)\n groupsMap.set(groupValue, {\n id: groupId,\n name: groupValue,\n entityType: 'group',\n subRows: [],\n label: groupData.label,\n group: groupData,\n links: {},\n })\n }\n\n const ungroupedId = GROUP_BY_ID + '.' + UNGROUPED_VALUE // unique id for ungrouped group\n // gets the \"Ungrouped\" group, creating it if it doesn't exist\n const getUnGroupedGroup = () => {\n let ungroupedGroup = groupsMap.get(ungroupedId)\n if (!ungroupedGroup) {\n ungroupedGroup = {\n id: ungroupedId,\n name: 'Ungrouped',\n entityType: 'group',\n subRows: [],\n label: 'Ungrouped',\n group: { value: ungroupedId, label: 'Ungrouped' },\n links: {},\n }\n // create ungrouped group if it doesn't exist\n groupsMap.set(ungroupedId, ungroupedGroup)\n }\n return ungroupedGroup\n }\n\n for (const [id, entity] of entities) {\n // if the entity is not of the specified type, skip it\n if (entity.entityType !== entityType) continue\n // add entities to specific group\n let groupValues: string[] = []\n if (groupBy.id.startsWith('attrib.')) {\n // for attribute based grouping, get the value of the attribute\n const attributeId = groupBy.id.split('.')[1]\n groupValues = valueToStringArray(entity.attrib?.[attributeId])\n } else {\n groupValues = valueToStringArray(entity[groupBy.id as keyof EntityMap])\n }\n\n // if there are no values, add to \"Ungrouped\" group\n if (groupValues.length === 0) {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n // for each group value, find it's group and add the entity to it\n // if we can't find the group, add it to \"Ungrouped\"\n for (const groupValue of groupValues) {\n const groupRow = groupsMap.get(groupValue)\n if (groupRow) {\n groupRow.subRows.push(entityToGroupRow(entity as EditorTaskNode, groupValue))\n } else {\n const ungroupedGroup = getUnGroupedGroup()\n ungroupedGroup.subRows.push(entityToGroupRow(entity as EditorTaskNode, UNGROUPED_VALUE))\n }\n }\n\n // for groups metadata on entity, check if there is a next page\n if ('groups' in entity && Array.isArray(entity.groups)) {\n for (const group of entity.groups) {\n const hasNextPageGroup = group.hasNextPage\n if (hasNextPageGroup && groupsMap.has(group.value)) {\n // add a next page row to the group\n const groupRow = groupsMap.get(group.value)\n if (groupRow) {\n groupRow.subRows.push({\n id: `${group.value}-next-page`,\n name: `Load more tasks...`,\n entityType: NEXT_PAGE_ID,\n subRows: [],\n label: `Next page for ${group.value}`,\n group: { value: group.value, label: group.value },\n links: {},\n })\n }\n }\n }\n }\n }\n\n const groupsList = Array.from(groupsMap.values())\n\n const attribSortingIds = getSortingIds(groupBy, project, attribFields)\n\n // sort the groups by their label\n // if the group is an attribute with enum values, sort by the enum values\n groupsList.sort((a, b) => {\n if (a.group?.value === ungroupedId) return 1 // \"Ungrouped\" should be last\n if (b.group?.value === ungroupedId) return -1 // \"Ungrouped\" should be last\n if (attribSortingIds.length) {\n // sort by index of the enum value\n const indexA = attribSortingIds.indexOf(a.group?.value || '')\n const indexB = attribSortingIds.indexOf(b.group?.value || '')\n if (indexA !== -1 && indexB !== -1) {\n return indexA - indexB\n }\n if (indexA !== -1) return -1 // a is in the enum, b is not\n if (indexB !== -1) return 1 // b is in the enum, a is not\n // if both are not in the enum, sort by label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n } else {\n // for other groupings, sort by the group label\n return a.group?.label?.localeCompare(b.group?.label || '') || 0\n }\n })\n\n // filter out empty groups\n const nonEmptyGroups = groupsList.filter((group) => group.subRows.length > 0)\n\n return showEmpty ? groupsList : nonEmptyGroups\n }\n\n return buildGroupByTableData\n}\n\nexport default useBuildGroupByTableData\n"],"names":["NEXT_PAGE_ID","UNGROUPED_VALUE","ROW_ID_SEPARATOR","valueToStringArray","value","v","getGroupData","groupById","groupValue","groups","group","g","GROUP_BY_ID","buildGroupId","parseGroupId","groupId","isGroupId","id","getSortingIds","groupBy","project","attribFields","attributeId","_a","_b","t","_c","f","_e","_d","field","e","useBuildGroupByTableData","props","entities","entityType","showEmpty","getEntityTypeData","useGetEntityTypeData","entityToGroupRow","useCallback","task","typeData","linksToTableData","productTypes","groupsMap","groupData","ungroupedId","getUnGroupedGroup","ungroupedGroup","entity","groupValues","groupRow","groupsList","attribSortingIds","a","b","indexA","indexB","_g","_f","_j","_h","_i","nonEmptyGroups"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";const f=require("react"),N=require("../utils/loadingUtils.cjs.js"),G=require("./useGetEntityTypeData.cjs.js");require("@ynput/ayon-react-components");const _=require("../../../util/productTypes.cjs.js");require("lodash");require("react-toastify");require("uuid");require("../../../util/pubsub.cjs.js");require("../context/CellEditingContext.cjs.js");require("../../../../../_virtual/jsx-runtime.cjs.js");require("../context/SelectionCellsContext.cjs.js");require("../context/ProjectTableQueriesContext.cjs.js");require("../context/ProjectTableContext.cjs.js");require("../context/ClipboardContext.cjs.js");require("@tanstack/react-table");require("../ProjectTreeTable.cjs.js");require("../context/ColumnSettingsContext.cjs.js");require("../context/SelectedRowsContext.cjs.js");require("../context/DetailsPanelEntityContext.cjs.js");;/* empty css */require("clsx");require("../../ContextMenu/ContextMenuContext.cjs.js");require("../context/ProjectDataContext.cjs.js");require("../../../api/base/client.cjs.js");require("../../../api/generated/graphql.cjs.js");require("../../../api/generated/graphqlLinks.cjs.js");require("../../../api/generated/access.cjs.js");require("../../../api/generated/actions.cjs.js");require("../../../api/generated/activityFeed.cjs.js");require("../../../api/generated/addons.cjs.js");require("../../../api/generated/anatomy.cjs.js");require("../../../api/generated/attributes.cjs.js");require("../../../api/generated/authentication.cjs.js");require("../../../api/generated/bundles.cjs.js");require("../../../api/generated/configuration.cjs.js");require("../../../api/generated/desktop.cjs.js");require("../../../api/generated/entityLists.cjs.js");require("../../../api/generated/events.cjs.js");require("../../../api/generated/files.cjs.js");require("../../../api/generated/folders.cjs.js");require("../../../api/generated/inbox.cjs.js");require("../../../api/generated/links.cjs.js");require("../../../api/generated/market.cjs.js");require("../../../api/generated/onboarding.cjs.js");require("../../../api/generated/operations.cjs.js");require("../../../api/generated/products.cjs.js");require("../../../api/generated/projectDashboard.cjs.js");require("../../../api/generated/projects.cjs.js");require("../../../api/generated/reviewables.cjs.js");require("../../../api/generated/services.cjs.js");require("../../../api/generated/system.cjs.js");require("../../../api/generated/tasks.cjs.js");require("../../../api/generated/teams.cjs.js");require("../../../api/generated/thumbnails.cjs.js");require("../../../api/generated/uRIs.cjs.js");require("../../../api/generated/users.cjs.js");require("../../../api/generated/versions.cjs.js");require("../../../api/generated/workfiles.cjs.js");require("../../../api/generated/ynputCloud.cjs.js");require("../../../api/generated/grouping.cjs.js");require("../../../api/generated/views.cjs.js");require("../../../api/queries/actions/getActions.cjs.js");require("../../../api/queries/activities/getActivities.cjs.js");require("../../../api/queries/activities/updateActivities.cjs.js");require("../../../api/queries/activities/updateReaction.cjs.js");require("../../../api/queries/activities/getMentions.cjs.js");require("../../../api/queries/addons/getAddons.cjs.js");require("../../../api/queries/addons/updateAddons.cjs.js");require("../../../api/queries/attributes/getAttributes.cjs.js");require("../../../api/queries/attributes/updateAttributes.cjs.js");require("../../../api/queries/authentication/getAuthentication.cjs.js");require("../../../api/queries/cloud/cloud.cjs.js");require("../../../api/queries/entities/getEntity.cjs.js");require("../../../api/queries/entities/getEntityPanel.cjs.js");require("../../../api/queries/entities/updateEntity.cjs.js");require("../../../api/queries/entityLists/getLists.cjs.js");require("../../../api/queries/entityLists/updateLists.cjs.js");require("../../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../../api/queries/entityLists/listFolders.cjs.js");require("../../../api/queries/folders/getFolders.cjs.js");require("../../../api/queries/grouping/getGrouping.cjs.js");require("../../../api/queries/links/updateLinks.cjs.js");require("../../../api/queries/links/getLinks.cjs.js");require("../../../api/queries/links/getEntityLinks.cjs.js");require("../../../api/queries/overview/getOverview.cjs.js");require("../../../api/queries/overview/updateOverview.cjs.js");require("../../../api/queries/permissions/getPermissions.cjs.js");require("../../../api/queries/products/createProduct.cjs.js");require("../../../api/queries/project/getProject.cjs.js");require("../../../api/queries/project/updateProject.cjs.js");require("../../../api/queries/review/getReview.cjs.js");require("../../../api/queries/review/updateReview.cjs.js");require("../../../api/queries/share/share.cjs.js");require("../../../api/queries/system/getSystem.cjs.js");require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../../api/queries/users/getUsers.cjs.js");require("../../../api/queries/users/updateUsers.cjs.js");require("../../../api/queries/versions/updateVersions.cjs.js");require("../../../api/queries/views/getViews.cjs.js");require("../../../api/queries/views/updateViews.cjs.js");require("../../../api/queries/watchers/getWatchers.cjs.js");require("../../../context/RemoteModulesContext.cjs.js");require("../../../../../_virtual/runtime.cjs.js");require("../../../../../_virtual/semver.cjs.js");require("../../../context/DetailsPanelContext.cjs.js");require("../../../context/ThumbnailUploaderContext.cjs.js");require("../../../context/SettingsPanelContext.cjs.js");require("../../../context/pip/PiPProvider.cjs.js");require("react-dom");require("../../../context/pip/PiPWrapper.cjs.js");require("../../../context/AddonProjectContext.cjs.js");require("../../../context/AddonContext.cjs.js");require("../../../context/PowerpackContext.cjs.js");require("../../../context/MoveEntityContext.cjs.js");require("../../../context/MenuContext.cjs.js");require("react-redux");require("custom-protocol-check");require("../components/GroupSettingsFallback.cjs.js");const F=require("../utils/linksToTableData.cjs.js"),K=100;function V({foldersMap:o,tasksMap:T,rows:g,tasksByFolderMap:M,expanded:m,projectInfo:t,showHierarchy:v,loadingTasks:b={},isLoadingMore:O=!1}){const E=G.useGetEntityTypeData({projectInfo:t}),U=f.useMemo(()=>JSON.stringify(m),[m]),p=f.useMemo(()=>new Set(Object.entries(m).filter(([s,u])=>u).map(([s])=>s)),[U]),{childToParentMap:I,parentToChildrenMap:k}=f.useMemo(()=>{const s=new Map,u=new Map;for(const i of o.values()){if(!(i!=null&&i.id))continue;const l=i.parentId;if(l){s.set(i.id,l);let q=u.get(l);q||(q=new Set,u.set(l,q)),q.add(i.id)}}return{childToParentMap:s,parentToChildrenMap:u}},[o]),A=f.useMemo(()=>{const s=new Set,u=[];for(const i of o.values())i!=null&&i.id&&(!i.parentId||!o.has(i.parentId))&&(s.add(i.id),u.push(i.id));for(;u.length>0;){const i=u.shift();if(!p.has(i))continue;const q=k.get(i);if(q)for(const d of q)s.has(d)||(s.add(d),u.push(d))}return s},[o,k,p]);return f.useMemo(()=>{var l,q,d,P,S,x,C;const s=(e,r)=>{const n=E("task",e.taskType),a=F.linksToTableData(e.links,"task",{folderTypes:(t==null?void 0:t.folderTypes)||[],productTypes:Object.values(_||{}),taskTypes:(t==null?void 0:t.taskTypes)||[]});return{id:e.id,entityType:"task",parentId:r||e.folderId,folderId:e.folderId,name:e.name||"",label:e.label||e.name||"",icon:(n==null?void 0:n.icon)||null,color:(n==null?void 0:n.color)||null,status:e.status,assignees:e.assignees,tags:e.tags,img:null,subRows:[],subType:e.taskType||null,attrib:e.attrib,ownAttrib:e.ownAttrib,parents:e.parents||[],path:e.parents.join("/")||null,updatedAt:e.updatedAt,createdAt:e.createdAt,links:a}};if(!v){const e=[];for(const r of T.values())r.id&&e.push(s(r));for(const r of g||[])e.push(r);if(O){const r=((d=(q=(l=T.entries().next())==null?void 0:l.value)==null?void 0:q[1])==null?void 0:d.attrib)||{},n=Object.keys(r).map(y=>({name:y})),a=K;{const y=N.generateLoadingRows(n,a,{type:"task"});e.push(...y)}}return e}const u=new Map,i=[];for(const e of A){const r=o.get(e);if(!r)continue;const n=F.linksToTableData(r.links,"folder",{folderTypes:(t==null?void 0:t.folderTypes)||[],productTypes:Object.values(_||{}),taskTypes:(t==null?void 0:t.taskTypes)||[]}),a={id:e,entityType:"folder",parentId:r.parentId||void 0,folderId:e||null,name:r.name||"",label:r.label||r.name||"",icon:((P=E("folder",r.folderType))==null?void 0:P.icon)||null,color:null,img:null,subRows:[],status:r.status,tags:r.tags||[],subType:r.folderType||null,ownAttrib:r.ownAttrib||[],path:r.path,attrib:r.attrib||{},childOnlyMatch:r.childOnlyMatch||!1,updatedAt:r.updatedAt,createdAt:r.createdAt,hasReviewables:r.hasReviewables||!1,hasVersions:r.hasVersions||!1,links:n};if(u.set(e,a),(!r.parentId||!o.has(r.parentId))&&i.push(a),p.has(e)){const w=(M.get(e)||[]).flatMap(h=>T.get(h)||[]);if(w.length||b[e]){const h=new Array(w.length);for(let c=0;c<w.length;c++)h[c]=s(w[c],e);if(b[e]){const c=((C=(x=(S=T.entries().next())==null?void 0:S.value)==null?void 0:x[1])==null?void 0:C.attrib)||{},B=Object.keys(c).map(R=>({name:R})),D=b[e];if(D>0){const R=N.generateLoadingRows(B,D,{type:"task",parentId:e});h.push(...R)}}a.subRows=h}}}for(const e of A){const r=I.get(e);if(!r||!p.has(r))continue;const n=u.get(e),a=u.get(r);!n||!a||a.subRows.push(n)}for(const e of g||[])i.push(e);return i},[o,T,g,A,I,p,v,b,O])}module.exports=V;
1
+ "use strict";const f=require("react"),N=require("../utils/loadingUtils.cjs.js"),G=require("./useGetEntityTypeData.cjs.js");require("@ynput/ayon-react-components");const _=require("../../../util/productTypes.cjs.js");require("lodash");require("react-toastify");require("uuid");require("../../../util/pubsub.cjs.js");require("../context/CellEditingContext.cjs.js");require("../../../../../_virtual/jsx-runtime.cjs.js");require("../context/SelectionCellsContext.cjs.js");require("../context/ProjectTableQueriesContext.cjs.js");require("../context/ProjectTableContext.cjs.js");require("../context/ClipboardContext.cjs.js");require("@tanstack/react-table");require("../ProjectTreeTable.cjs.js");require("../context/ColumnSettingsContext.cjs.js");require("../context/SelectedRowsContext.cjs.js");require("../context/DetailsPanelEntityContext.cjs.js");;/* empty css */require("clsx");require("../../ContextMenu/ContextMenuContext.cjs.js");require("../context/ProjectDataContext.cjs.js");require("../../../api/base/client.cjs.js");require("../../../api/generated/graphql.cjs.js");require("../../../api/generated/graphqlLinks.cjs.js");require("../../../api/generated/access.cjs.js");require("../../../api/generated/actions.cjs.js");require("../../../api/generated/activityFeed.cjs.js");require("../../../api/generated/addons.cjs.js");require("../../../api/generated/anatomy.cjs.js");require("../../../api/generated/attributes.cjs.js");require("../../../api/generated/authentication.cjs.js");require("../../../api/generated/bundles.cjs.js");require("../../../api/generated/configuration.cjs.js");require("../../../api/generated/desktop.cjs.js");require("../../../api/generated/entityLists.cjs.js");require("../../../api/generated/events.cjs.js");require("../../../api/generated/files.cjs.js");require("../../../api/generated/folders.cjs.js");require("../../../api/generated/inbox.cjs.js");require("../../../api/generated/links.cjs.js");require("../../../api/generated/market.cjs.js");require("../../../api/generated/onboarding.cjs.js");require("../../../api/generated/operations.cjs.js");require("../../../api/generated/products.cjs.js");require("../../../api/generated/projectDashboard.cjs.js");require("../../../api/generated/projects.cjs.js");require("../../../api/generated/reviewables.cjs.js");require("../../../api/generated/services.cjs.js");require("../../../api/generated/system.cjs.js");require("../../../api/generated/tasks.cjs.js");require("../../../api/generated/teams.cjs.js");require("../../../api/generated/thumbnails.cjs.js");require("../../../api/generated/uRIs.cjs.js");require("../../../api/generated/users.cjs.js");require("../../../api/generated/versions.cjs.js");require("../../../api/generated/workfiles.cjs.js");require("../../../api/generated/ynputCloud.cjs.js");require("../../../api/generated/grouping.cjs.js");require("../../../api/generated/views.cjs.js");require("../../../api/queries/actions/getActions.cjs.js");require("../../../api/queries/activities/getActivities.cjs.js");require("../../../api/queries/activities/updateActivities.cjs.js");require("../../../api/queries/activities/updateReaction.cjs.js");require("../../../api/queries/activities/getMentions.cjs.js");require("../../../api/queries/activities/getCategories.cjs.js");require("../../../api/queries/addons/getAddons.cjs.js");require("../../../api/queries/addons/updateAddons.cjs.js");require("../../../api/queries/attributes/getAttributes.cjs.js");require("../../../api/queries/attributes/updateAttributes.cjs.js");require("../../../api/queries/authentication/getAuthentication.cjs.js");require("../../../api/queries/cloud/cloud.cjs.js");require("../../../api/queries/entities/getEntity.cjs.js");require("../../../api/queries/entities/getEntityPanel.cjs.js");require("../../../api/queries/entities/updateEntity.cjs.js");require("../../../api/queries/entityLists/getLists.cjs.js");require("../../../api/queries/entityLists/updateLists.cjs.js");require("../../../api/queries/entityLists/getListsAttributes.cjs.js");require("../../../api/queries/entityLists/updateListsAttributes.cjs.js");require("../../../api/queries/entityLists/listFolders.cjs.js");require("../../../api/queries/folders/getFolders.cjs.js");require("../../../api/queries/grouping/getGrouping.cjs.js");require("../../../api/queries/links/updateLinks.cjs.js");require("../../../api/queries/links/getLinks.cjs.js");require("../../../api/queries/links/getEntityLinks.cjs.js");require("../../../api/queries/overview/getOverview.cjs.js");require("../../../api/queries/overview/updateOverview.cjs.js");require("../../../api/queries/permissions/getPermissions.cjs.js");require("../../../api/queries/products/createProduct.cjs.js");require("../../../api/queries/project/getProject.cjs.js");require("../../../api/queries/project/updateProject.cjs.js");require("../../../api/queries/review/getReview.cjs.js");require("../../../api/queries/review/updateReview.cjs.js");require("../../../api/queries/share/share.cjs.js");require("../../../api/queries/system/getSystem.cjs.js");require("../../../api/queries/userDashboard/getUserDashboard.cjs.js");require("../../../api/queries/users/getUsers.cjs.js");require("../../../api/queries/users/updateUsers.cjs.js");require("../../../api/queries/users/guests.cjs.js");require("../../../api/queries/versions/updateVersions.cjs.js");require("../../../api/queries/views/getViews.cjs.js");require("../../../api/queries/views/updateViews.cjs.js");require("../../../api/queries/watchers/getWatchers.cjs.js");require("../../../context/RemoteModulesContext.cjs.js");require("../../../../../_virtual/runtime.cjs.js");require("../../../../../_virtual/semver.cjs.js");require("../../../context/DetailsPanelContext.cjs.js");require("../../../context/ThumbnailUploaderContext.cjs.js");require("../../../context/SettingsPanelContext.cjs.js");require("../../../context/pip/PiPProvider.cjs.js");require("react-dom");require("../../../context/pip/PiPWrapper.cjs.js");require("../../../context/AddonProjectContext.cjs.js");require("../../../context/AddonContext.cjs.js");require("../../../context/PowerpackContext.cjs.js");require("../../../context/MoveEntityContext.cjs.js");require("../../../context/MenuContext.cjs.js");require("react-redux");require("custom-protocol-check");require("../components/GroupSettingsFallback.cjs.js");const F=require("../utils/linksToTableData.cjs.js"),K=100;function V({foldersMap:o,tasksMap:T,rows:g,tasksByFolderMap:M,expanded:R,projectInfo:t,showHierarchy:v,loadingTasks:b={},isLoadingMore:O=!1}){const E=G.useGetEntityTypeData({projectInfo:t}),U=f.useMemo(()=>JSON.stringify(R),[R]),h=f.useMemo(()=>new Set(Object.entries(R).filter(([s,u])=>u).map(([s])=>s)),[U]),{childToParentMap:I,parentToChildrenMap:P}=f.useMemo(()=>{const s=new Map,u=new Map;for(const i of o.values()){if(!(i!=null&&i.id))continue;const l=i.parentId;if(l){s.set(i.id,l);let q=u.get(l);q||(q=new Set,u.set(l,q)),q.add(i.id)}}return{childToParentMap:s,parentToChildrenMap:u}},[o]),m=f.useMemo(()=>{const s=new Set,u=[];for(const i of o.values())i!=null&&i.id&&(!i.parentId||!o.has(i.parentId))&&(s.add(i.id),u.push(i.id));for(;u.length>0;){const i=u.shift();if(!h.has(i))continue;const q=P.get(i);if(q)for(const d of q)s.has(d)||(s.add(d),u.push(d))}return s},[o,P,h]);return f.useMemo(()=>{var l,q,d,S,k,x,C;const s=(e,r)=>{const n=E("task",e.taskType),a=F.linksToTableData(e.links,"task",{folderTypes:(t==null?void 0:t.folderTypes)||[],productTypes:Object.values(_||{}),taskTypes:(t==null?void 0:t.taskTypes)||[]});return{id:e.id,entityType:"task",parentId:r||e.folderId,folderId:e.folderId,name:e.name||"",label:e.label||e.name||"",icon:(n==null?void 0:n.icon)||null,color:(n==null?void 0:n.color)||null,status:e.status,assignees:e.assignees,tags:e.tags,img:null,subRows:[],subType:e.taskType||null,attrib:e.attrib,ownAttrib:e.ownAttrib,parents:e.parents||[],path:e.parents.join("/")||null,updatedAt:e.updatedAt,createdAt:e.createdAt,hasReviewables:e.hasReviewables||!1,links:a}};if(!v){const e=[];for(const r of T.values())r.id&&e.push(s(r));for(const r of g||[])e.push(r);if(O){const r=((d=(q=(l=T.entries().next())==null?void 0:l.value)==null?void 0:q[1])==null?void 0:d.attrib)||{},n=Object.keys(r).map(y=>({name:y})),a=K;{const y=N.generateLoadingRows(n,a,{type:"task"});e.push(...y)}}return e}const u=new Map,i=[];for(const e of m){const r=o.get(e);if(!r)continue;const n=F.linksToTableData(r.links,"folder",{folderTypes:(t==null?void 0:t.folderTypes)||[],productTypes:Object.values(_||{}),taskTypes:(t==null?void 0:t.taskTypes)||[]}),a={id:e,entityType:"folder",parentId:r.parentId||void 0,folderId:e||null,name:r.name||"",label:r.label||r.name||"",icon:((S=E("folder",r.folderType))==null?void 0:S.icon)||null,color:null,img:null,subRows:[],status:r.status,tags:r.tags||[],subType:r.folderType||null,ownAttrib:r.ownAttrib||[],path:r.path,attrib:r.attrib||{},childOnlyMatch:r.childOnlyMatch||!1,updatedAt:r.updatedAt,createdAt:r.createdAt,hasReviewables:r.hasReviewables||!1,hasVersions:r.hasVersions||!1,links:n};if(u.set(e,a),(!r.parentId||!o.has(r.parentId))&&i.push(a),h.has(e)){const w=(M.get(e)||[]).flatMap(p=>T.get(p)||[]);if(w.length||b[e]){const p=new Array(w.length);for(let c=0;c<w.length;c++)p[c]=s(w[c],e);if(b[e]){const c=((C=(x=(k=T.entries().next())==null?void 0:k.value)==null?void 0:x[1])==null?void 0:C.attrib)||{},B=Object.keys(c).map(A=>({name:A})),D=b[e];if(D>0){const A=N.generateLoadingRows(B,D,{type:"task",parentId:e});p.push(...A)}}a.subRows=p}}}for(const e of m){const r=I.get(e);if(!r||!h.has(r))continue;const n=u.get(e),a=u.get(r);!n||!a||a.subRows.push(n)}for(const e of g||[])i.push(e);return i},[o,T,g,m,I,h,v,b,O])}module.exports=V;
2
2
  //# sourceMappingURL=useBuildProjectDataTable.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useBuildProjectDataTable.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport {\n EditorTaskNode,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport { ExpandedState } from '@tanstack/react-table'\nimport { generateLoadingRows } from '../utils/loadingUtils'\nconst TASKS_INFINITE_QUERY_COUNT = 100\nimport { LoadingTasks } from '../types'\nimport { ProjectModel } from '../types/project'\nimport { useGetEntityTypeData } from './useGetEntityTypeData'\nimport { TableGroupBy } from '../context'\nimport { linksToTableData } from '../utils'\nimport { productTypes } from '@shared/util'\n\ntype Params = {\n foldersMap: FolderNodeMap\n tasksMap: TaskNodeMap\n tasksByFolderMap: TasksByFolderMap\n rows?: TableRow[]\n expanded: ExpandedState\n projectInfo?: ProjectModel\n showHierarchy: boolean\n loadingTasks?: LoadingTasks\n isLoadingMore?: boolean\n groupBy?: TableGroupBy\n}\n\nexport default function useBuildProjectDataTable({\n foldersMap,\n tasksMap,\n rows,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks = {},\n isLoadingMore = false,\n}: Params): TableRow[] {\n const getEntityTypeData = useGetEntityTypeData({ projectInfo })\n\n // Convert expanded object to a stable string for memoization comparison\n const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded])\n\n // Memoize expandedFolderIds set for efficient lookups\n const expandedFolderIds = useMemo(() => {\n return new Set(\n Object.entries(expanded)\n .filter(([_, isExpanded]) => isExpanded)\n .map(([id]) => id),\n )\n }, [expandedKey])\n\n // Memoize relationship maps to avoid rebuilding them on every render\n const { childToParentMap, parentToChildrenMap } = useMemo(() => {\n const childToParent = new Map<string, string>()\n const parentToChildren = new Map<string, Set<string>>()\n\n // Construct relationship maps in a single pass\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n const parentId = folder.parentId\n if (parentId) {\n childToParent.set(folder.id, parentId)\n\n let children = parentToChildren.get(parentId)\n if (!children) {\n children = new Set<string>()\n parentToChildren.set(parentId, children)\n }\n children.add(folder.id)\n }\n }\n\n return { childToParentMap: childToParent, parentToChildrenMap: parentToChildren }\n }, [foldersMap])\n\n // Memoize visible folders calculation\n const visibleFolders = useMemo(() => {\n const visible = new Set<string>()\n\n // Start with root folders and folders with non-existent parents\n const queue: string[] = []\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n // Include folders with no parent OR with a parent that doesn't exist\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n visible.add(folder.id)\n queue.push(folder.id)\n }\n }\n\n // Process queue to identify visible folders (BFS)\n while (queue.length > 0) {\n const folderId = queue.shift()!\n const isParentExpanded = expandedFolderIds.has(folderId)\n\n if (!isParentExpanded) continue\n\n // Add children of expanded folders to visible set\n const childrenIds = parentToChildrenMap.get(folderId)\n if (childrenIds) {\n for (const childId of childrenIds) {\n if (!visible.has(childId)) {\n visible.add(childId)\n queue.push(childId)\n }\n }\n }\n }\n\n return visible\n }, [foldersMap, parentToChildrenMap, expandedFolderIds])\n\n // Final memoized result - build the table tree\n return useMemo(() => {\n // Helper function to create a task row\n const createTaskRow = (task: EditorTaskNode, parentId?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n\n const links = linksToTableData(task.links, 'task', {\n folderTypes: projectInfo?.folderTypes || [],\n productTypes: Object.values(productTypes || {}),\n taskTypes: projectInfo?.taskTypes || [],\n })\n\n return {\n id: task.id,\n entityType: 'task',\n parentId: parentId || task.folderId,\n folderId: task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n parents: task.parents || [],\n path: task.parents.join('/') || null, // todo: probably remove this and just use parents\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n links: links,\n }\n }\n\n // If showHierarchy is false, create a flat list of task rows\n if (!showHierarchy) {\n const flatRows: TableRow[] = []\n\n // Loop through all tasks\n for (const task of tasksMap.values()) {\n if (!task.id) continue\n flatRows.push(createTaskRow(task))\n }\n\n // Loop through all extra rows\n for (const row of rows || []) {\n flatRows.push(row)\n }\n\n // if we are loading more tasks, add loading rows\n if (isLoadingMore) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n // number of tasks we loading with the infinite query\n const count = TASKS_INFINITE_QUERY_COUNT\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n })\n\n flatRows.push(...loadingTaskRows)\n }\n }\n\n return flatRows\n }\n\n // Use Map for O(1) lookups\n const rowsById = new Map<string, TableRow>()\n const rootRows: TableRow[] = []\n\n // Create minimal rows for only visible folders\n for (const folderId of visibleFolders) {\n const folder = foldersMap.get(folderId)\n if (!folder) continue\n\n const links = linksToTableData(folder.links, 'folder', {\n folderTypes: projectInfo?.folderTypes || [],\n productTypes: Object.values(productTypes || {}),\n taskTypes: projectInfo?.taskTypes || [],\n })\n\n // Create row with minimal required properties\n const row: TableRow = {\n id: folderId,\n entityType: 'folder',\n parentId: folder.parentId || undefined,\n folderId: folderId || null, // root folders have no folderId\n name: folder.name || '',\n label: folder.label || folder.name || '',\n icon: getEntityTypeData('folder', folder.folderType)?.icon || null,\n color: null,\n img: null,\n subRows: [],\n status: folder.status,\n tags: folder.tags || [],\n subType: folder.folderType || null,\n ownAttrib: folder.ownAttrib || [],\n path: folder.path,\n attrib: folder.attrib || {},\n childOnlyMatch: folder.childOnlyMatch || false,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n hasReviewables: folder.hasReviewables || false,\n hasVersions: folder.hasVersions || false,\n links: links,\n }\n\n rowsById.set(folderId, row)\n\n // Add root rows directly to the rootRows array\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n rootRows.push(row)\n }\n\n // Process tasks immediately if folder is expanded\n if (expandedFolderIds.has(folderId)) {\n // because tasksByFolderMap is a map of tasks by folder ID\n // we can directly get the tasks for the current folder\n const folderTaskIds = tasksByFolderMap.get(folderId) || []\n const folderTasks = folderTaskIds.flatMap((taskId) => tasksMap.get(taskId) || [])\n\n if (folderTasks.length || loadingTasks[folderId]) {\n // Use array literal with known length for better performance\n const taskRows = new Array<TableRow>(folderTasks.length)\n\n // Direct array assignment is faster than push operations\n for (let i = 0; i < folderTasks.length; i++) {\n taskRows[i] = createTaskRow(folderTasks[i], folderId)\n }\n\n // Add loading rows if applicable\n if (loadingTasks[folderId]) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n const count = loadingTasks[folderId]\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n parentId: folderId,\n })\n\n taskRows.push(...loadingTaskRows)\n }\n }\n\n row.subRows = taskRows\n }\n }\n }\n\n // Build the folder hierarchy efficiently\n for (const folderId of visibleFolders) {\n const parentId = childToParentMap.get(folderId)\n if (!parentId || !expandedFolderIds.has(parentId)) continue\n\n const childRow = rowsById.get(folderId)\n const parentRow = rowsById.get(parentId)\n\n if (!childRow || !parentRow) continue\n\n // Add folder to its parent's subRows\n parentRow.subRows.push(childRow)\n }\n\n // Add any extra rows to the root rows\n for (const row of rows || []) {\n rootRows.push(row)\n }\n\n return rootRows\n }, [\n foldersMap,\n tasksMap,\n rows,\n visibleFolders,\n childToParentMap,\n expandedFolderIds,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n ])\n}\n"],"names":["TASKS_INFINITE_QUERY_COUNT","useBuildProjectDataTable","foldersMap","tasksMap","rows","tasksByFolderMap","expanded","projectInfo","showHierarchy","loadingTasks","isLoadingMore","getEntityTypeData","useGetEntityTypeData","expandedKey","useMemo","expandedFolderIds","_","isExpanded","id","childToParentMap","parentToChildrenMap","childToParent","parentToChildren","folder","parentId","children","visibleFolders","visible","queue","folderId","childrenIds","childId","createTaskRow","task","typeData","links","linksToTableData","productTypes","flatRows","row","firstTaskAttrib","_c","_b","_a","loadingAttribs","key","count","loadingTaskRows","generateLoadingRows","rowsById","rootRows","_d","folderTasks","taskId","taskRows","i","_g","_f","_e","childRow","parentRow"],"mappings":"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"}
1
+ {"version":3,"file":"useBuildProjectDataTable.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport {\n EditorTaskNode,\n FolderNodeMap,\n TableRow,\n TaskNodeMap,\n TasksByFolderMap,\n} from '../types/table'\nimport { ExpandedState } from '@tanstack/react-table'\nimport { generateLoadingRows } from '../utils/loadingUtils'\nconst TASKS_INFINITE_QUERY_COUNT = 100\nimport { LoadingTasks } from '../types'\nimport { ProjectModel } from '../types/project'\nimport { useGetEntityTypeData } from './useGetEntityTypeData'\nimport { TableGroupBy } from '../context'\nimport { linksToTableData } from '../utils'\nimport { productTypes } from '@shared/util'\n\ntype Params = {\n foldersMap: FolderNodeMap\n tasksMap: TaskNodeMap\n tasksByFolderMap: TasksByFolderMap\n rows?: TableRow[]\n expanded: ExpandedState\n projectInfo?: ProjectModel\n showHierarchy: boolean\n loadingTasks?: LoadingTasks\n isLoadingMore?: boolean\n groupBy?: TableGroupBy\n}\n\nexport default function useBuildProjectDataTable({\n foldersMap,\n tasksMap,\n rows,\n tasksByFolderMap,\n expanded,\n projectInfo,\n showHierarchy,\n loadingTasks = {},\n isLoadingMore = false,\n}: Params): TableRow[] {\n const getEntityTypeData = useGetEntityTypeData({ projectInfo })\n\n // Convert expanded object to a stable string for memoization comparison\n const expandedKey = useMemo(() => JSON.stringify(expanded), [expanded])\n\n // Memoize expandedFolderIds set for efficient lookups\n const expandedFolderIds = useMemo(() => {\n return new Set(\n Object.entries(expanded)\n .filter(([_, isExpanded]) => isExpanded)\n .map(([id]) => id),\n )\n }, [expandedKey])\n\n // Memoize relationship maps to avoid rebuilding them on every render\n const { childToParentMap, parentToChildrenMap } = useMemo(() => {\n const childToParent = new Map<string, string>()\n const parentToChildren = new Map<string, Set<string>>()\n\n // Construct relationship maps in a single pass\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n const parentId = folder.parentId\n if (parentId) {\n childToParent.set(folder.id, parentId)\n\n let children = parentToChildren.get(parentId)\n if (!children) {\n children = new Set<string>()\n parentToChildren.set(parentId, children)\n }\n children.add(folder.id)\n }\n }\n\n return { childToParentMap: childToParent, parentToChildrenMap: parentToChildren }\n }, [foldersMap])\n\n // Memoize visible folders calculation\n const visibleFolders = useMemo(() => {\n const visible = new Set<string>()\n\n // Start with root folders and folders with non-existent parents\n const queue: string[] = []\n for (const folder of foldersMap.values()) {\n if (!folder?.id) continue\n\n // Include folders with no parent OR with a parent that doesn't exist\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n visible.add(folder.id)\n queue.push(folder.id)\n }\n }\n\n // Process queue to identify visible folders (BFS)\n while (queue.length > 0) {\n const folderId = queue.shift()!\n const isParentExpanded = expandedFolderIds.has(folderId)\n\n if (!isParentExpanded) continue\n\n // Add children of expanded folders to visible set\n const childrenIds = parentToChildrenMap.get(folderId)\n if (childrenIds) {\n for (const childId of childrenIds) {\n if (!visible.has(childId)) {\n visible.add(childId)\n queue.push(childId)\n }\n }\n }\n }\n\n return visible\n }, [foldersMap, parentToChildrenMap, expandedFolderIds])\n\n // Final memoized result - build the table tree\n return useMemo(() => {\n // Helper function to create a task row\n const createTaskRow = (task: EditorTaskNode, parentId?: string): TableRow => {\n const typeData = getEntityTypeData('task', task.taskType)\n\n const links = linksToTableData(task.links, 'task', {\n folderTypes: projectInfo?.folderTypes || [],\n productTypes: Object.values(productTypes || {}),\n taskTypes: projectInfo?.taskTypes || [],\n })\n\n return {\n id: task.id,\n entityType: 'task',\n parentId: parentId || task.folderId,\n folderId: task.folderId,\n name: task.name || '',\n label: task.label || task.name || '',\n icon: typeData?.icon || null,\n color: typeData?.color || null,\n status: task.status,\n assignees: task.assignees,\n tags: task.tags,\n img: null,\n subRows: [],\n subType: task.taskType || null,\n attrib: task.attrib,\n ownAttrib: task.ownAttrib,\n parents: task.parents || [],\n path: task.parents.join('/') || null, // todo: probably remove this and just use parents\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n hasReviewables: task.hasReviewables || false,\n links: links,\n }\n }\n\n // If showHierarchy is false, create a flat list of task rows\n if (!showHierarchy) {\n const flatRows: TableRow[] = []\n\n // Loop through all tasks\n for (const task of tasksMap.values()) {\n if (!task.id) continue\n flatRows.push(createTaskRow(task))\n }\n\n // Loop through all extra rows\n for (const row of rows || []) {\n flatRows.push(row)\n }\n\n // if we are loading more tasks, add loading rows\n if (isLoadingMore) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n // number of tasks we loading with the infinite query\n const count = TASKS_INFINITE_QUERY_COUNT\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n })\n\n flatRows.push(...loadingTaskRows)\n }\n }\n\n return flatRows\n }\n\n // Use Map for O(1) lookups\n const rowsById = new Map<string, TableRow>()\n const rootRows: TableRow[] = []\n\n // Create minimal rows for only visible folders\n for (const folderId of visibleFolders) {\n const folder = foldersMap.get(folderId)\n if (!folder) continue\n\n const links = linksToTableData(folder.links, 'folder', {\n folderTypes: projectInfo?.folderTypes || [],\n productTypes: Object.values(productTypes || {}),\n taskTypes: projectInfo?.taskTypes || [],\n })\n\n // Create row with minimal required properties\n const row: TableRow = {\n id: folderId,\n entityType: 'folder',\n parentId: folder.parentId || undefined,\n folderId: folderId || null, // root folders have no folderId\n name: folder.name || '',\n label: folder.label || folder.name || '',\n icon: getEntityTypeData('folder', folder.folderType)?.icon || null,\n color: null,\n img: null,\n subRows: [],\n status: folder.status,\n tags: folder.tags || [],\n subType: folder.folderType || null,\n ownAttrib: folder.ownAttrib || [],\n path: folder.path,\n attrib: folder.attrib || {},\n childOnlyMatch: folder.childOnlyMatch || false,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n hasReviewables: folder.hasReviewables || false,\n hasVersions: folder.hasVersions || false,\n links: links,\n }\n\n rowsById.set(folderId, row)\n\n // Add root rows directly to the rootRows array\n if (!folder.parentId || !foldersMap.has(folder.parentId)) {\n rootRows.push(row)\n }\n\n // Process tasks immediately if folder is expanded\n if (expandedFolderIds.has(folderId)) {\n // because tasksByFolderMap is a map of tasks by folder ID\n // we can directly get the tasks for the current folder\n const folderTaskIds = tasksByFolderMap.get(folderId) || []\n const folderTasks = folderTaskIds.flatMap((taskId) => tasksMap.get(taskId) || [])\n\n if (folderTasks.length || loadingTasks[folderId]) {\n // Use array literal with known length for better performance\n const taskRows = new Array<TableRow>(folderTasks.length)\n\n // Direct array assignment is faster than push operations\n for (let i = 0; i < folderTasks.length; i++) {\n taskRows[i] = createTaskRow(folderTasks[i], folderId)\n }\n\n // Add loading rows if applicable\n if (loadingTasks[folderId]) {\n const firstTaskAttrib = tasksMap.entries().next()?.value?.[1]?.attrib || {}\n const loadingAttribs = Object.keys(firstTaskAttrib).map((key) => ({\n name: key,\n }))\n const count = loadingTasks[folderId]\n if (count > 0) {\n const loadingTaskRows = generateLoadingRows(loadingAttribs, count, {\n type: 'task',\n parentId: folderId,\n })\n\n taskRows.push(...loadingTaskRows)\n }\n }\n\n row.subRows = taskRows\n }\n }\n }\n\n // Build the folder hierarchy efficiently\n for (const folderId of visibleFolders) {\n const parentId = childToParentMap.get(folderId)\n if (!parentId || !expandedFolderIds.has(parentId)) continue\n\n const childRow = rowsById.get(folderId)\n const parentRow = rowsById.get(parentId)\n\n if (!childRow || !parentRow) continue\n\n // Add folder to its parent's subRows\n parentRow.subRows.push(childRow)\n }\n\n // Add any extra rows to the root rows\n for (const row of rows || []) {\n rootRows.push(row)\n }\n\n return rootRows\n }, [\n foldersMap,\n tasksMap,\n rows,\n visibleFolders,\n childToParentMap,\n expandedFolderIds,\n showHierarchy,\n loadingTasks,\n isLoadingMore,\n ])\n}\n"],"names":["TASKS_INFINITE_QUERY_COUNT","useBuildProjectDataTable","foldersMap","tasksMap","rows","tasksByFolderMap","expanded","projectInfo","showHierarchy","loadingTasks","isLoadingMore","getEntityTypeData","useGetEntityTypeData","expandedKey","useMemo","expandedFolderIds","_","isExpanded","id","childToParentMap","parentToChildrenMap","childToParent","parentToChildren","folder","parentId","children","visibleFolders","visible","queue","folderId","childrenIds","childId","createTaskRow","task","typeData","links","linksToTableData","productTypes","flatRows","row","firstTaskAttrib","_c","_b","_a","loadingAttribs","key","count","loadingTaskRows","generateLoadingRows","rowsById","rootRows","_d","folderTasks","taskId","taskRows","i","_g","_f","_e","childRow","parentRow"],"mappings":"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"}