@ynput/ayon-frontend-shared 0.3.8 → 0.3.10

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 (811) hide show
  1. package/dist/DetailsPanel.cjs.js +1 -1
  2. package/dist/DetailsPanel.es.js +24 -22
  3. package/dist/DetailsPanel.es.js.map +1 -1
  4. package/dist/ProjectTreeTable.cjs.js +1 -1
  5. package/dist/ProjectTreeTable.es.js +182 -171
  6. package/dist/ProjectTreeTable.es.js.map +1 -1
  7. package/dist/Slicer.cjs.js +1 -1
  8. package/dist/Slicer.es.js +13 -11
  9. package/dist/Slicer.es.js.map +1 -1
  10. package/dist/api.cjs.js +1 -1
  11. package/dist/api.es.js +340 -331
  12. package/dist/api.es.js.map +1 -1
  13. package/dist/context.cjs.js +1 -1
  14. package/dist/context.es.js +39 -36
  15. package/dist/context.es.js.map +1 -1
  16. package/dist/index.cjs.js +1 -1
  17. package/dist/index.es.js +11 -9
  18. package/dist/index.es.js.map +1 -1
  19. package/dist/shared/src/api/generated/actions.cjs.js.map +1 -1
  20. package/dist/shared/src/api/generated/actions.es.js.map +1 -1
  21. package/dist/shared/src/api/generated/folders.cjs.js.map +1 -1
  22. package/dist/shared/src/api/generated/folders.es.js.map +1 -1
  23. package/dist/shared/src/api/generated/projectFolders.cjs.js +2 -0
  24. package/dist/shared/src/api/generated/projectFolders.cjs.js.map +1 -0
  25. package/dist/shared/src/api/generated/projectFolders.es.js +44 -0
  26. package/dist/shared/src/api/generated/projectFolders.es.js.map +1 -0
  27. package/dist/shared/src/api/generated/projects.cjs.js +1 -1
  28. package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
  29. package/dist/shared/src/api/generated/projects.es.js +20 -0
  30. package/dist/shared/src/api/generated/projects.es.js.map +1 -1
  31. package/dist/shared/src/api/generated/system.cjs.js.map +1 -1
  32. package/dist/shared/src/api/generated/system.es.js.map +1 -1
  33. package/dist/shared/src/api/queries/actions/getActions.cjs.js +1 -1
  34. package/dist/shared/src/api/queries/actions/getActions.cjs.js.map +1 -1
  35. package/dist/shared/src/api/queries/actions/getActions.es.js +11 -10
  36. package/dist/shared/src/api/queries/actions/getActions.es.js.map +1 -1
  37. package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -1
  38. package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
  39. package/dist/shared/src/api/queries/activities/getActivities.es.js +11 -10
  40. package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
  41. package/dist/shared/src/api/queries/activities/getCategories.cjs.js +1 -1
  42. package/dist/shared/src/api/queries/activities/getCategories.cjs.js.map +1 -1
  43. package/dist/shared/src/api/queries/activities/getCategories.es.js +3 -2
  44. package/dist/shared/src/api/queries/activities/getCategories.es.js.map +1 -1
  45. package/dist/shared/src/api/queries/activities/getMentions.cjs.js +1 -1
  46. package/dist/shared/src/api/queries/activities/getMentions.cjs.js.map +1 -1
  47. package/dist/shared/src/api/queries/activities/getMentions.es.js +3 -2
  48. package/dist/shared/src/api/queries/activities/getMentions.es.js.map +1 -1
  49. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js +1 -1
  50. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js.map +1 -1
  51. package/dist/shared/src/api/queries/activities/updateReaction.es.js +4 -3
  52. package/dist/shared/src/api/queries/activities/updateReaction.es.js.map +1 -1
  53. package/dist/shared/src/api/queries/addons/getAddons.cjs.js +1 -1
  54. package/dist/shared/src/api/queries/addons/getAddons.cjs.js.map +1 -1
  55. package/dist/shared/src/api/queries/addons/getAddons.es.js +7 -6
  56. package/dist/shared/src/api/queries/addons/getAddons.es.js.map +1 -1
  57. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js +1 -1
  58. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js.map +1 -1
  59. package/dist/shared/src/api/queries/attributes/getAttributes.es.js +4 -3
  60. package/dist/shared/src/api/queries/attributes/getAttributes.es.js.map +1 -1
  61. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js +1 -1
  62. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js.map +1 -1
  63. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js +4 -3
  64. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js.map +1 -1
  65. package/dist/shared/src/api/queries/cloud/cloud.cjs.js +1 -1
  66. package/dist/shared/src/api/queries/cloud/cloud.cjs.js.map +1 -1
  67. package/dist/shared/src/api/queries/cloud/cloud.es.js +9 -8
  68. package/dist/shared/src/api/queries/cloud/cloud.es.js.map +1 -1
  69. package/dist/shared/src/api/queries/config/getConfig.cjs.js +1 -1
  70. package/dist/shared/src/api/queries/config/getConfig.cjs.js.map +1 -1
  71. package/dist/shared/src/api/queries/config/getConfig.es.js +9 -8
  72. package/dist/shared/src/api/queries/config/getConfig.es.js.map +1 -1
  73. package/dist/shared/src/api/queries/entities/getEntity.cjs.js +1 -1
  74. package/dist/shared/src/api/queries/entities/getEntity.cjs.js.map +1 -1
  75. package/dist/shared/src/api/queries/entities/getEntity.es.js +13 -12
  76. package/dist/shared/src/api/queries/entities/getEntity.es.js.map +1 -1
  77. package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js +1 -1
  78. package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js.map +1 -1
  79. package/dist/shared/src/api/queries/entities/getEntityPanel.es.js +4 -3
  80. package/dist/shared/src/api/queries/entities/getEntityPanel.es.js.map +1 -1
  81. package/dist/shared/src/api/queries/entities/patchDetailsPanel.cjs.js +1 -1
  82. package/dist/shared/src/api/queries/entities/patchDetailsPanel.cjs.js.map +1 -1
  83. package/dist/shared/src/api/queries/entities/patchDetailsPanel.es.js +4 -2
  84. package/dist/shared/src/api/queries/entities/patchDetailsPanel.es.js.map +1 -1
  85. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +1 -1
  86. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
  87. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +5 -3
  88. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
  89. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +1 -1
  90. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
  91. package/dist/shared/src/api/queries/entityLists/getLists.es.js +15 -14
  92. package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
  93. package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js +1 -1
  94. package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js.map +1 -1
  95. package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js +3 -2
  96. package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js.map +1 -1
  97. package/dist/shared/src/api/queries/entityLists/listFolders.cjs.js +1 -1
  98. package/dist/shared/src/api/queries/entityLists/listFolders.cjs.js.map +1 -1
  99. package/dist/shared/src/api/queries/entityLists/listFolders.es.js +22 -20
  100. package/dist/shared/src/api/queries/entityLists/listFolders.es.js.map +1 -1
  101. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +1 -1
  102. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
  103. package/dist/shared/src/api/queries/entityLists/updateLists.es.js +17 -16
  104. package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
  105. package/dist/shared/src/api/queries/folders/getFolders.cjs.js +1 -1
  106. package/dist/shared/src/api/queries/folders/getFolders.cjs.js.map +1 -1
  107. package/dist/shared/src/api/queries/folders/getFolders.es.js +4 -3
  108. package/dist/shared/src/api/queries/folders/getFolders.es.js.map +1 -1
  109. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js +1 -1
  110. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js.map +1 -1
  111. package/dist/shared/src/api/queries/grouping/getGrouping.es.js +22 -6
  112. package/dist/shared/src/api/queries/grouping/getGrouping.es.js.map +1 -1
  113. package/dist/shared/src/api/queries/links/getEntityLinks.cjs.js +1 -1
  114. package/dist/shared/src/api/queries/links/getEntityLinks.cjs.js.map +1 -1
  115. package/dist/shared/src/api/queries/links/getEntityLinks.es.js +3 -2
  116. package/dist/shared/src/api/queries/links/getEntityLinks.es.js.map +1 -1
  117. package/dist/shared/src/api/queries/links/getLinks.cjs.js +1 -1
  118. package/dist/shared/src/api/queries/links/getLinks.cjs.js.map +1 -1
  119. package/dist/shared/src/api/queries/links/getLinks.es.js +14 -13
  120. package/dist/shared/src/api/queries/links/getLinks.es.js.map +1 -1
  121. package/dist/shared/src/api/queries/links/updateLinks.cjs.js +1 -1
  122. package/dist/shared/src/api/queries/links/updateLinks.cjs.js.map +1 -1
  123. package/dist/shared/src/api/queries/links/updateLinks.es.js +17 -16
  124. package/dist/shared/src/api/queries/links/updateLinks.es.js.map +1 -1
  125. package/dist/shared/src/api/queries/overview/getOverview.cjs.js +1 -1
  126. package/dist/shared/src/api/queries/overview/getOverview.cjs.js.map +1 -1
  127. package/dist/shared/src/api/queries/overview/getOverview.es.js +37 -36
  128. package/dist/shared/src/api/queries/overview/getOverview.es.js.map +1 -1
  129. package/dist/shared/src/api/queries/overview/patchVersions.cjs.js +1 -1
  130. package/dist/shared/src/api/queries/overview/patchVersions.cjs.js.map +1 -1
  131. package/dist/shared/src/api/queries/overview/patchVersions.es.js +88 -53
  132. package/dist/shared/src/api/queries/overview/patchVersions.es.js.map +1 -1
  133. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +1 -1
  134. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
  135. package/dist/shared/src/api/queries/overview/updateOverview.es.js +8 -6
  136. package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
  137. package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js +1 -1
  138. package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js.map +1 -1
  139. package/dist/shared/src/api/queries/permissions/getPermissions.es.js +4 -3
  140. package/dist/shared/src/api/queries/permissions/getPermissions.es.js.map +1 -1
  141. package/dist/shared/src/api/queries/products/createProduct.cjs.js +1 -1
  142. package/dist/shared/src/api/queries/products/createProduct.cjs.js.map +1 -1
  143. package/dist/shared/src/api/queries/products/createProduct.es.js +3 -2
  144. package/dist/shared/src/api/queries/products/createProduct.es.js.map +1 -1
  145. package/dist/shared/src/api/queries/project/getProject.cjs.js +1 -1
  146. package/dist/shared/src/api/queries/project/getProject.cjs.js.map +1 -1
  147. package/dist/shared/src/api/queries/project/getProject.es.js +9 -8
  148. package/dist/shared/src/api/queries/project/getProject.es.js.map +1 -1
  149. package/dist/shared/src/api/queries/projectFolders/projectFolders.cjs.js +2 -0
  150. package/dist/shared/src/api/queries/projectFolders/projectFolders.cjs.js.map +1 -0
  151. package/dist/shared/src/api/queries/projectFolders/projectFolders.es.js +178 -0
  152. package/dist/shared/src/api/queries/projectFolders/projectFolders.es.js.map +1 -0
  153. package/dist/shared/src/api/queries/review/getReview.cjs.js +1 -1
  154. package/dist/shared/src/api/queries/review/getReview.cjs.js.map +1 -1
  155. package/dist/shared/src/api/queries/review/getReview.es.js +15 -14
  156. package/dist/shared/src/api/queries/review/getReview.es.js.map +1 -1
  157. package/dist/shared/src/api/queries/review/updateReview.cjs.js +1 -1
  158. package/dist/shared/src/api/queries/review/updateReview.cjs.js.map +1 -1
  159. package/dist/shared/src/api/queries/review/updateReview.es.js +7 -6
  160. package/dist/shared/src/api/queries/review/updateReview.es.js.map +1 -1
  161. package/dist/shared/src/api/queries/share/share.cjs.js +1 -1
  162. package/dist/shared/src/api/queries/share/share.cjs.js.map +1 -1
  163. package/dist/shared/src/api/queries/share/share.es.js +3 -2
  164. package/dist/shared/src/api/queries/share/share.es.js.map +1 -1
  165. package/dist/shared/src/api/queries/system/getSystem.cjs.js +1 -1
  166. package/dist/shared/src/api/queries/system/getSystem.cjs.js.map +1 -1
  167. package/dist/shared/src/api/queries/system/getSystem.es.js +5 -4
  168. package/dist/shared/src/api/queries/system/getSystem.es.js.map +1 -1
  169. package/dist/shared/src/api/queries/tasks/updateTasks.cjs.js +1 -1
  170. package/dist/shared/src/api/queries/tasks/updateTasks.cjs.js.map +1 -1
  171. package/dist/shared/src/api/queries/tasks/updateTasks.es.js +6 -6
  172. package/dist/shared/src/api/queries/tasks/updateTasks.es.js.map +1 -1
  173. package/dist/shared/src/api/queries/uris/getUris.cjs.js +1 -1
  174. package/dist/shared/src/api/queries/uris/getUris.cjs.js.map +1 -1
  175. package/dist/shared/src/api/queries/uris/getUris.es.js +3 -2
  176. package/dist/shared/src/api/queries/uris/getUris.es.js.map +1 -1
  177. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js +1 -1
  178. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js.map +1 -1
  179. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js +6 -5
  180. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js.map +1 -1
  181. package/dist/shared/src/api/queries/users/getUsers.cjs.js +1 -1
  182. package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
  183. package/dist/shared/src/api/queries/users/getUsers.es.js +20 -18
  184. package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
  185. package/dist/shared/src/api/queries/users/guests.cjs.js +1 -1
  186. package/dist/shared/src/api/queries/users/guests.cjs.js.map +1 -1
  187. package/dist/shared/src/api/queries/users/guests.es.js +5 -4
  188. package/dist/shared/src/api/queries/users/guests.es.js.map +1 -1
  189. package/dist/shared/src/api/queries/users/updateUsers.cjs.js +1 -1
  190. package/dist/shared/src/api/queries/users/updateUsers.cjs.js.map +1 -1
  191. package/dist/shared/src/api/queries/users/updateUsers.es.js +21 -20
  192. package/dist/shared/src/api/queries/users/updateUsers.es.js.map +1 -1
  193. package/dist/shared/src/api/queries/versions/getVersionsProducts.cjs.js +1 -1
  194. package/dist/shared/src/api/queries/versions/getVersionsProducts.cjs.js.map +1 -1
  195. package/dist/shared/src/api/queries/versions/getVersionsProducts.es.js +348 -136
  196. package/dist/shared/src/api/queries/versions/getVersionsProducts.es.js.map +1 -1
  197. package/dist/shared/src/api/queries/versions/getVersionsProductsUtils.cjs.js +1 -1
  198. package/dist/shared/src/api/queries/versions/getVersionsProductsUtils.cjs.js.map +1 -1
  199. package/dist/shared/src/api/queries/versions/getVersionsProductsUtils.es.js +57 -59
  200. package/dist/shared/src/api/queries/versions/getVersionsProductsUtils.es.js.map +1 -1
  201. package/dist/shared/src/api/queries/versions/updateVersions.cjs.js +1 -1
  202. package/dist/shared/src/api/queries/versions/updateVersions.cjs.js.map +1 -1
  203. package/dist/shared/src/api/queries/versions/updateVersions.es.js +6 -5
  204. package/dist/shared/src/api/queries/versions/updateVersions.es.js.map +1 -1
  205. package/dist/shared/src/api/queries/views/getViews.cjs.js +1 -1
  206. package/dist/shared/src/api/queries/views/getViews.cjs.js.map +1 -1
  207. package/dist/shared/src/api/queries/views/getViews.es.js +11 -10
  208. package/dist/shared/src/api/queries/views/getViews.es.js.map +1 -1
  209. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js +1 -1
  210. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js.map +1 -1
  211. package/dist/shared/src/api/queries/watchers/getWatchers.es.js +4 -3
  212. package/dist/shared/src/api/queries/watchers/getWatchers.es.js.map +1 -1
  213. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +1 -1
  214. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
  215. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +4 -2
  216. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
  217. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js +3 -3
  218. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js.map +1 -1
  219. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js +13 -13
  220. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js.map +1 -1
  221. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +3 -3
  222. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
  223. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +24 -22
  224. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
  225. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js +1 -1
  226. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js.map +1 -1
  227. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js +4 -2
  228. package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js.map +1 -1
  229. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js +1 -1
  230. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js.map +1 -1
  231. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js +4 -2
  232. package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js.map +1 -1
  233. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js +1 -1
  234. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js.map +1 -1
  235. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js +4 -2
  236. package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js.map +1 -1
  237. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +1 -1
  238. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
  239. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +4 -2
  240. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
  241. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js +1 -1
  242. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js.map +1 -1
  243. package/dist/shared/src/components/Feedback/FeedbackContext.es.js +16 -14
  244. package/dist/shared/src/components/Feedback/FeedbackContext.es.js.map +1 -1
  245. package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js +1 -1
  246. package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js.map +1 -1
  247. package/dist/shared/src/components/LinksManager/AddNewLinks.es.js +4 -2
  248. package/dist/shared/src/components/LinksManager/AddNewLinks.es.js.map +1 -1
  249. package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js +1 -1
  250. package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js.map +1 -1
  251. package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js +4 -2
  252. package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js.map +1 -1
  253. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js +1 -1
  254. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js.map +1 -1
  255. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js +4 -2
  256. package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js.map +1 -1
  257. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js +1 -1
  258. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js.map +1 -1
  259. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js +4 -2
  260. package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js.map +1 -1
  261. package/dist/shared/src/components/Menu/Menu.styled.cjs.js +0 -1
  262. package/dist/shared/src/components/Menu/Menu.styled.cjs.js.map +1 -1
  263. package/dist/shared/src/components/Menu/Menu.styled.es.js +0 -1
  264. package/dist/shared/src/components/Menu/Menu.styled.es.js.map +1 -1
  265. package/dist/shared/src/components/Menu/MenuList.cjs.js +1 -1
  266. package/dist/shared/src/components/Menu/MenuList.cjs.js.map +1 -1
  267. package/dist/shared/src/components/Menu/MenuList.es.js +21 -21
  268. package/dist/shared/src/components/Menu/MenuList.es.js.map +1 -1
  269. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +1 -1
  270. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -1
  271. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +58 -38
  272. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -1
  273. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +2 -2
  274. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
  275. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +113 -107
  276. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
  277. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +1 -1
  278. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
  279. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +4 -2
  280. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
  281. package/dist/shared/src/components/RemotePage/ProjectPageRemote.cjs.js +1 -1
  282. package/dist/shared/src/components/RemotePage/ProjectPageRemote.cjs.js.map +1 -1
  283. package/dist/shared/src/components/RemotePage/ProjectPageRemote.es.js +4 -2
  284. package/dist/shared/src/components/RemotePage/ProjectPageRemote.es.js.map +1 -1
  285. package/dist/shared/src/components/RemotePage/RemotePageWrapper.cjs.js +1 -1
  286. package/dist/shared/src/components/RemotePage/RemotePageWrapper.cjs.js.map +1 -1
  287. package/dist/shared/src/components/RemotePage/RemotePageWrapper.es.js +4 -2
  288. package/dist/shared/src/components/RemotePage/RemotePageWrapper.es.js.map +1 -1
  289. package/dist/shared/src/components/RenameForm/RenameForm.cjs.js +1 -1
  290. package/dist/shared/src/components/RenameForm/RenameForm.cjs.js.map +1 -1
  291. package/dist/shared/src/components/RenameForm/RenameForm.es.js +4 -2
  292. package/dist/shared/src/components/RenameForm/RenameForm.es.js.map +1 -1
  293. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +1 -1
  294. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
  295. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +4 -2
  296. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
  297. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +1 -1
  298. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
  299. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +32 -30
  300. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
  301. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +1 -1
  302. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
  303. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +5 -3
  304. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
  305. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +1 -1
  306. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
  307. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +4 -2
  308. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
  309. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js +1 -1
  310. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js.map +1 -1
  311. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js +4 -2
  312. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js.map +1 -1
  313. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +1 -1
  314. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
  315. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +8 -6
  316. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
  317. package/dist/shared/src/components/SimpleFormDialog/FormFile.cjs.js +31 -0
  318. package/dist/shared/src/components/SimpleFormDialog/FormFile.cjs.js.map +1 -0
  319. package/dist/shared/src/components/SimpleFormDialog/FormFile.es.js +107 -0
  320. package/dist/shared/src/components/SimpleFormDialog/FormFile.es.js.map +1 -0
  321. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +2 -2
  322. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
  323. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +33 -28
  324. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
  325. package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.cjs.js +1 -1
  326. package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.cjs.js.map +1 -1
  327. package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.es.js +12 -11
  328. package/dist/shared/src/components/SubtasksManager/SubtasksManagerWrapper.es.js.map +1 -1
  329. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +1 -1
  330. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
  331. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +4 -2
  332. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
  333. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js +1 -1
  334. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js.map +1 -1
  335. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js +6 -4
  336. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js.map +1 -1
  337. package/dist/shared/src/components/Watchers/Watchers.cjs.js +1 -1
  338. package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
  339. package/dist/shared/src/components/Watchers/Watchers.es.js +4 -2
  340. package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
  341. package/dist/shared/src/config/plannerFeatures.cjs.js +2 -0
  342. package/dist/shared/src/config/plannerFeatures.cjs.js.map +1 -0
  343. package/dist/shared/src/config/plannerFeatures.es.js +50 -0
  344. package/dist/shared/src/config/plannerFeatures.es.js.map +1 -0
  345. package/dist/shared/src/config/powerpackFeatures.cjs.js +2 -0
  346. package/dist/shared/src/config/powerpackFeatures.cjs.js.map +1 -0
  347. package/dist/shared/src/config/powerpackFeatures.es.js +74 -0
  348. package/dist/shared/src/config/powerpackFeatures.es.js.map +1 -0
  349. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +1 -1
  350. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
  351. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +4 -2
  352. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
  353. package/dist/shared/src/containers/Actions/Actions.cjs.js +1 -1
  354. package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
  355. package/dist/shared/src/containers/Actions/Actions.es.js +18 -15
  356. package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
  357. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +2 -2
  358. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
  359. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +33 -32
  360. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
  361. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +1 -1
  362. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
  363. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +4 -2
  364. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
  365. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +1 -1
  366. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
  367. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +73 -68
  368. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
  369. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.cjs.js +1 -1
  370. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
  371. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.es.js +4 -2
  372. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
  373. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.cjs.js +1 -1
  374. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
  375. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.es.js +5 -3
  376. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
  377. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.cjs.js +1 -1
  378. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
  379. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.es.js +4 -2
  380. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
  381. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +1 -1
  382. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
  383. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +4 -2
  384. package/dist/shared/src/containers/DetailsPanel/components/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
  385. package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.cjs.js +1 -1
  386. package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.cjs.js.map +1 -1
  387. package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.es.js +18 -16
  388. package/dist/shared/src/containers/DetailsPanel/components/TabHeaderAndFilters/TabHeaderAndFilters.styled.es.js.map +1 -1
  389. package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.cjs.js +1 -1
  390. package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.cjs.js.map +1 -1
  391. package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.es.js +4 -2
  392. package/dist/shared/src/containers/DetailsPanel/containers/DetailsPanelSubtasks.es.js.map +1 -1
  393. package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.cjs.js +1 -1
  394. package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.cjs.js.map +1 -1
  395. package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.es.js +4 -2
  396. package/dist/shared/src/containers/DetailsPanel/containers/FeedContextWrapper.es.js.map +1 -1
  397. package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.cjs.js +1 -1
  398. package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.cjs.js.map +1 -1
  399. package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.es.js +4 -2
  400. package/dist/shared/src/containers/DetailsPanel/containers/FeedWrapper.es.js.map +1 -1
  401. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +1 -1
  402. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
  403. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +4 -2
  404. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
  405. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js +1 -1
  406. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js.map +1 -1
  407. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js +4 -2
  408. package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js.map +1 -1
  409. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js +1 -1
  410. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js.map +1 -1
  411. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js +4 -2
  412. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js.map +1 -1
  413. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js +1 -1
  414. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js.map +1 -1
  415. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js +4 -2
  416. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js.map +1 -1
  417. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js +1 -1
  418. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js.map +1 -1
  419. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js +4 -2
  420. package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js.map +1 -1
  421. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js +1 -1
  422. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js.map +1 -1
  423. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js +4 -2
  424. package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js.map +1 -1
  425. package/dist/shared/src/containers/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.cjs.js +1 -1
  426. package/dist/shared/src/containers/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.cjs.js.map +1 -1
  427. package/dist/shared/src/containers/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.es.js +8 -8
  428. package/dist/shared/src/containers/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.es.js.map +1 -1
  429. package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.cjs.js +1 -1
  430. package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.cjs.js.map +1 -1
  431. package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.es.js +4 -2
  432. package/dist/shared/src/containers/Feed/components/ActivityCheckbox/ActivityCheckbox.es.js.map +1 -1
  433. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js +1 -1
  434. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js.map +1 -1
  435. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js +4 -2
  436. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js.map +1 -1
  437. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.cjs.js +1 -1
  438. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.cjs.js.map +1 -1
  439. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.es.js +4 -2
  440. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityCommentMenu.es.js.map +1 -1
  441. package/dist/shared/src/containers/Feed/components/ActivityItem.cjs.js.map +1 -1
  442. package/dist/shared/src/containers/Feed/components/ActivityItem.es.js.map +1 -1
  443. package/dist/shared/src/containers/Feed/components/ActivityStatusChange/ActivityStatusChange.cjs.js +1 -1
  444. package/dist/shared/src/containers/Feed/components/ActivityStatusChange/ActivityStatusChange.cjs.js.map +1 -1
  445. package/dist/shared/src/containers/Feed/components/ActivityStatusChange/ActivityStatusChange.es.js +18 -18
  446. package/dist/shared/src/containers/Feed/components/ActivityStatusChange/ActivityStatusChange.es.js.map +1 -1
  447. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js +1 -1
  448. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js.map +1 -1
  449. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js +4 -2
  450. package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
  451. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +1 -1
  452. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js.map +1 -1
  453. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js +4 -2
  454. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js.map +1 -1
  455. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +1 -1
  456. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
  457. package/dist/shared/src/containers/Feed/context/FeedContext.es.js +7 -5
  458. package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
  459. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +1 -1
  460. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
  461. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +4 -2
  462. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
  463. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +1 -1
  464. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
  465. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +686 -616
  466. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
  467. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js +26 -11
  468. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js.map +1 -1
  469. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js +40 -25
  470. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js.map +1 -1
  471. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +1 -1
  472. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
  473. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +4 -2
  474. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
  475. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.cjs.js +2 -0
  476. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.cjs.js.map +1 -0
  477. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.es.js +381 -0
  478. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnDndProvider.es.js.map +1 -0
  479. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js +1 -1
  480. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js.map +1 -1
  481. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js +4 -2
  482. package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js.map +1 -1
  483. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +1 -1
  484. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
  485. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +4 -2
  486. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
  487. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js +6 -2
  488. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js.map +1 -1
  489. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js +13 -9
  490. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js.map +1 -1
  491. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js +1 -1
  492. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js.map +1 -1
  493. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js +147 -119
  494. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js.map +1 -1
  495. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +4 -3
  496. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
  497. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +487 -262
  498. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
  499. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js +1 -1
  500. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.cjs.js.map +1 -1
  501. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js +149 -145
  502. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsProvider.es.js.map +1 -1
  503. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +1 -1
  504. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
  505. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +6 -4
  506. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
  507. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
  508. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
  509. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +1 -1
  510. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -1
  511. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +118 -109
  512. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -1
  513. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.cjs.js +1 -1
  514. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.cjs.js.map +1 -1
  515. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.es.js +30 -30
  516. package/dist/shared/src/containers/ProjectTreeTable/context/SelectedRowsProvider.es.js.map +1 -1
  517. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +1 -1
  518. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
  519. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +94 -91
  520. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
  521. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardSubtasks.cjs.js +5 -0
  522. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardSubtasks.cjs.js.map +1 -0
  523. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardSubtasks.es.js +67 -0
  524. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardSubtasks.es.js.map +1 -0
  525. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +1 -1
  526. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -1
  527. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +33 -31
  528. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -1
  529. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +1 -1
  530. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
  531. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +30 -28
  532. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
  533. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +1 -1
  534. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
  535. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +4 -2
  536. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
  537. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +1 -1
  538. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -1
  539. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +4 -2
  540. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -1
  541. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnDragRestriction.cjs.js +2 -0
  542. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnDragRestriction.cjs.js.map +1 -0
  543. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnDragRestriction.es.js +56 -0
  544. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnDragRestriction.es.js.map +1 -0
  545. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js +1 -1
  546. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js.map +1 -1
  547. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js +4 -2
  548. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js.map +1 -1
  549. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnVirtualization.cjs.js +1 -1
  550. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnVirtualization.cjs.js.map +1 -1
  551. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnVirtualization.es.js +57 -40
  552. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnVirtualization.es.js.map +1 -1
  553. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +1 -1
  554. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
  555. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +4 -2
  556. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
  557. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +1 -1
  558. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
  559. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +4 -2
  560. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
  561. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.cjs.js +1 -1
  562. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.cjs.js.map +1 -1
  563. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.es.js +4 -2
  564. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGroupBySettings.es.js.map +1 -1
  565. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +1 -1
  566. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
  567. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +4 -2
  568. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
  569. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js +1 -1
  570. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js.map +1 -1
  571. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js +4 -2
  572. package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js.map +1 -1
  573. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js +1 -1
  574. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js.map +1 -1
  575. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js +4 -2
  576. package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js.map +1 -1
  577. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +1 -1
  578. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
  579. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +30 -28
  580. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
  581. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.cjs.js +2 -0
  582. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.cjs.js.map +1 -0
  583. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.es.js +303 -0
  584. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSortBySettings.es.js.map +1 -0
  585. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js +1 -1
  586. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -1
  587. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js +175 -156
  588. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -1
  589. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +1 -1
  590. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
  591. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +15 -13
  592. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
  593. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +1 -1
  594. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
  595. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +21 -19
  596. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
  597. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js +1 -1
  598. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js.map +1 -1
  599. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js +6 -4
  600. package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js.map +1 -1
  601. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js +1 -1
  602. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js.map +1 -1
  603. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js +4 -2
  604. package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js.map +1 -1
  605. package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.cjs.js +1 -1
  606. package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.cjs.js.map +1 -1
  607. package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.es.js +21 -18
  608. package/dist/shared/src/containers/ProjectTreeTable/widgets/SubtasksWidget.es.js.map +1 -1
  609. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.cjs.js +1 -1
  610. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.cjs.js.map +1 -1
  611. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.es.js +1 -1
  612. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidget.es.js.map +1 -1
  613. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.cjs.js +1 -1
  614. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.cjs.js.map +1 -1
  615. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.es.js +29 -29
  616. package/dist/shared/src/containers/ProjectTreeTable/widgets/TextWidgetInput.es.js.map +1 -1
  617. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +1 -1
  618. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
  619. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +7 -5
  620. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
  621. package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js +1 -1
  622. package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js.map +1 -1
  623. package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js +90 -85
  624. package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js.map +1 -1
  625. package/dist/shared/src/containers/SimpleTable/SimpleTable.styled.cjs.js +9 -5
  626. package/dist/shared/src/containers/SimpleTable/SimpleTable.styled.cjs.js.map +1 -1
  627. package/dist/shared/src/containers/SimpleTable/SimpleTable.styled.es.js +11 -7
  628. package/dist/shared/src/containers/SimpleTable/SimpleTable.styled.es.js.map +1 -1
  629. package/dist/shared/src/containers/Slicer/components/SlicerSearch.cjs.js +1 -1
  630. package/dist/shared/src/containers/Slicer/components/SlicerSearch.cjs.js.map +1 -1
  631. package/dist/shared/src/containers/Slicer/components/SlicerSearch.es.js +4 -2
  632. package/dist/shared/src/containers/Slicer/components/SlicerSearch.es.js.map +1 -1
  633. package/dist/shared/src/containers/Slicer/context/SlicerContext.cjs.js +1 -1
  634. package/dist/shared/src/containers/Slicer/context/SlicerContext.cjs.js.map +1 -1
  635. package/dist/shared/src/containers/Slicer/context/SlicerContext.es.js +6 -4
  636. package/dist/shared/src/containers/Slicer/context/SlicerContext.es.js.map +1 -1
  637. package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.cjs.js +1 -1
  638. package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.cjs.js.map +1 -1
  639. package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.es.js +14 -12
  640. package/dist/shared/src/containers/Slicer/hooks/useTableDataBySlice.es.js.map +1 -1
  641. package/dist/shared/src/containers/Slicer/hooks/useUsersTable.cjs.js +1 -1
  642. package/dist/shared/src/containers/Slicer/hooks/useUsersTable.cjs.js.map +1 -1
  643. package/dist/shared/src/containers/Slicer/hooks/useUsersTable.es.js +4 -2
  644. package/dist/shared/src/containers/Slicer/hooks/useUsersTable.es.js.map +1 -1
  645. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js +1 -1
  646. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js.map +1 -1
  647. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js +4 -2
  648. package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js.map +1 -1
  649. package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.cjs.js +1 -1
  650. package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.cjs.js.map +1 -1
  651. package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.es.js +4 -2
  652. package/dist/shared/src/containers/Views/ViewsMenuContainer/BaseViewsTags.es.js.map +1 -1
  653. package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js +1 -1
  654. package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js.map +1 -1
  655. package/dist/shared/src/containers/Views/context/ViewsContext.es.js +40 -38
  656. package/dist/shared/src/containers/Views/context/ViewsContext.es.js.map +1 -1
  657. package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.cjs.js +1 -1
  658. package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.cjs.js.map +1 -1
  659. package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.es.js +10 -8
  660. package/dist/shared/src/containers/Views/hooks/useBaseViewMutations.es.js.map +1 -1
  661. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js +1 -1
  662. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js.map +1 -1
  663. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js +5 -3
  664. package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js.map +1 -1
  665. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js +1 -1
  666. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js.map +1 -1
  667. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js +4 -2
  668. package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js.map +1 -1
  669. package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js +1 -1
  670. package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js.map +1 -1
  671. package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js +4 -2
  672. package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js.map +1 -1
  673. package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js +1 -1
  674. package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js.map +1 -1
  675. package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js +12 -10
  676. package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js.map +1 -1
  677. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js +1 -1
  678. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js.map +1 -1
  679. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js +4 -2
  680. package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js.map +1 -1
  681. package/dist/shared/src/context/AddonProjectContext.cjs.js +1 -1
  682. package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
  683. package/dist/shared/src/context/AddonProjectContext.es.js +6 -4
  684. package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
  685. package/dist/shared/src/context/DetailsPanelContext.cjs.js +1 -1
  686. package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
  687. package/dist/shared/src/context/DetailsPanelContext.es.js +6 -4
  688. package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
  689. package/dist/shared/src/context/GlobalContext.cjs.js +1 -1
  690. package/dist/shared/src/context/GlobalContext.cjs.js.map +1 -1
  691. package/dist/shared/src/context/GlobalContext.es.js +6 -4
  692. package/dist/shared/src/context/GlobalContext.es.js.map +1 -1
  693. package/dist/shared/src/context/PowerpackContext.cjs.js +1 -1
  694. package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
  695. package/dist/shared/src/context/PowerpackContext.es.js +46 -94
  696. package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
  697. package/dist/shared/src/context/ProjectContext.cjs.js +1 -1
  698. package/dist/shared/src/context/ProjectContext.cjs.js.map +1 -1
  699. package/dist/shared/src/context/ProjectContext.es.js +6 -4
  700. package/dist/shared/src/context/ProjectContext.es.js.map +1 -1
  701. package/dist/shared/src/context/ProjectFoldersContext.cjs.js +1 -1
  702. package/dist/shared/src/context/ProjectFoldersContext.cjs.js.map +1 -1
  703. package/dist/shared/src/context/ProjectFoldersContext.es.js +6 -4
  704. package/dist/shared/src/context/ProjectFoldersContext.es.js.map +1 -1
  705. package/dist/shared/src/context/RemoteModulesContext.cjs.js +1 -1
  706. package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
  707. package/dist/shared/src/context/RemoteModulesContext.es.js +6 -4
  708. package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
  709. package/dist/shared/src/context/SubtasksModulesContext.cjs.js +1 -1
  710. package/dist/shared/src/context/SubtasksModulesContext.cjs.js.map +1 -1
  711. package/dist/shared/src/context/SubtasksModulesContext.es.js +21 -14
  712. package/dist/shared/src/context/SubtasksModulesContext.es.js.map +1 -1
  713. package/dist/shared/src/context/UriContext.cjs.js +1 -1
  714. package/dist/shared/src/context/UriContext.cjs.js.map +1 -1
  715. package/dist/shared/src/context/UriContext.es.js +7 -5
  716. package/dist/shared/src/context/UriContext.es.js.map +1 -1
  717. package/dist/shared/src/context/WebsocketContext.cjs.js +1 -1
  718. package/dist/shared/src/context/WebsocketContext.cjs.js.map +1 -1
  719. package/dist/shared/src/context/WebsocketContext.es.js +6 -4
  720. package/dist/shared/src/context/WebsocketContext.es.js.map +1 -1
  721. package/dist/shared/src/hooks/useActionTriggers.cjs.js +1 -1
  722. package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
  723. package/dist/shared/src/hooks/useActionTriggers.es.js +4 -2
  724. package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
  725. package/dist/shared/src/hooks/useEntityUpdate.cjs.js +1 -1
  726. package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
  727. package/dist/shared/src/hooks/useEntityUpdate.es.js +4 -2
  728. package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
  729. package/dist/shared/src/hooks/useGetEntityGroups.cjs.js +1 -1
  730. package/dist/shared/src/hooks/useGetEntityGroups.cjs.js.map +1 -1
  731. package/dist/shared/src/hooks/useGetEntityGroups.es.js +4 -2
  732. package/dist/shared/src/hooks/useGetEntityGroups.es.js.map +1 -1
  733. package/dist/shared/src/hooks/useGroupByRemoteModules.cjs.js +1 -1
  734. package/dist/shared/src/hooks/useGroupByRemoteModules.cjs.js.map +1 -1
  735. package/dist/shared/src/hooks/useGroupByRemoteModules.es.js +4 -2
  736. package/dist/shared/src/hooks/useGroupByRemoteModules.es.js.map +1 -1
  737. package/dist/shared/src/hooks/useScopedStatuses.cjs.js +1 -1
  738. package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
  739. package/dist/shared/src/hooks/useScopedStatuses.es.js +6 -4
  740. package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
  741. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +1 -1
  742. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
  743. package/dist/shared/src/hooks/useUserProjectConfig.es.js +4 -2
  744. package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
  745. package/dist/shared/src/util/buildHierarchicalTableRows.cjs.js +2 -0
  746. package/dist/shared/src/util/buildHierarchicalTableRows.cjs.js.map +1 -0
  747. package/dist/shared/src/util/buildHierarchicalTableRows.es.js +69 -0
  748. package/dist/shared/src/util/buildHierarchicalTableRows.es.js.map +1 -0
  749. package/dist/shared/src/util/errorHandling.cjs.js +2 -0
  750. package/dist/shared/src/util/errorHandling.cjs.js.map +1 -0
  751. package/dist/shared/src/util/errorHandling.es.js +9 -0
  752. package/dist/shared/src/util/errorHandling.es.js.map +1 -0
  753. package/dist/shared/src/util/folderHierarchy.cjs.js +2 -0
  754. package/dist/shared/src/util/folderHierarchy.cjs.js.map +1 -0
  755. package/dist/shared/src/util/folderHierarchy.es.js +14 -0
  756. package/dist/shared/src/util/folderHierarchy.es.js.map +1 -0
  757. package/dist/shared/src/util/folderOperations.cjs.js +2 -0
  758. package/dist/shared/src/util/folderOperations.cjs.js.map +1 -0
  759. package/dist/shared/src/util/folderOperations.es.js +27 -0
  760. package/dist/shared/src/util/folderOperations.es.js.map +1 -0
  761. package/dist/shared/src/util/keyboardShortcuts.cjs.js +2 -0
  762. package/dist/shared/src/util/keyboardShortcuts.cjs.js.map +1 -0
  763. package/dist/shared/src/util/keyboardShortcuts.es.js +8 -0
  764. package/dist/shared/src/util/keyboardShortcuts.es.js.map +1 -0
  765. package/dist/types/api/generated/actions.d.ts +2 -1
  766. package/dist/types/api/generated/folders.d.ts +3 -3
  767. package/dist/types/api/generated/index.d.ts +2 -0
  768. package/dist/types/api/generated/projectFolders.d.ts +79 -0
  769. package/dist/types/api/generated/projects.d.ts +55 -1
  770. package/dist/types/api/generated/system.d.ts +2 -1
  771. package/dist/types/api/queries/index.d.ts +1 -0
  772. package/dist/types/api/queries/project/getProject.d.ts +4 -0
  773. package/dist/types/api/queries/projectFolders/index.d.ts +1 -0
  774. package/dist/types/api/queries/projectFolders/projectFolders.d.ts +985 -0
  775. package/dist/types/api/queries/versions/getVersionsProducts.d.ts +1 -1
  776. package/dist/types/components/FolderForm/FolderForm.d.ts +24 -0
  777. package/dist/types/components/FolderForm/index.d.ts +3 -0
  778. package/dist/types/components/ProjectTableSettings/ProjectTableSettings.d.ts +1 -1
  779. package/dist/types/components/SimpleFormDialog/FormFile.d.ts +16 -0
  780. package/dist/types/components/SimpleFormDialog/SimpleFormDialog.d.ts +2 -1
  781. package/dist/types/components/SubtasksManager/SubtasksManagerWrapper.d.ts +3 -2
  782. package/dist/types/config/index.d.ts +2 -0
  783. package/dist/types/config/plannerFeatures.d.ts +13 -0
  784. package/dist/types/config/powerpackFeatures.d.ts +6 -0
  785. package/dist/types/containers/Actions/ActionsDropdown/ActionsDropdown.d.ts +2 -1
  786. package/dist/types/containers/Feed/components/ActivityAssigneeChange/ActivityAssigneeChange.d.ts +1 -0
  787. package/dist/types/containers/Feed/components/ActivityItem.d.ts +1 -0
  788. package/dist/types/containers/Feed/components/ActivityStatusChange/ActivityStatusChange.d.ts +1 -0
  789. package/dist/types/containers/ProjectTreeTable/ProjectTreeTable.d.ts +1 -0
  790. package/dist/types/containers/ProjectTreeTable/components/ColumnDndProvider.d.ts +6 -0
  791. package/dist/types/containers/ProjectTreeTable/components/index.d.ts +1 -0
  792. package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +5 -0
  793. package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +6 -1
  794. package/dist/types/containers/ProjectTreeTable/context/clipboard/clipboardSubtasks.d.ts +26 -0
  795. package/dist/types/containers/ProjectTreeTable/context/clipboard/index.d.ts +1 -0
  796. package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +1 -0
  797. package/dist/types/containers/ProjectTreeTable/hooks/useColumnDragRestriction.d.ts +19 -0
  798. package/dist/types/containers/ProjectTreeTable/hooks/useSortBySettings.d.ts +4 -0
  799. package/dist/types/containers/SimpleTable/SimpleTable.d.ts +2 -1
  800. package/dist/types/containers/Views/hooks/useBaseViewMutations.d.ts +2 -2
  801. package/dist/types/context/PowerpackContext.d.ts +17 -6
  802. package/dist/types/util/buildHierarchicalTableRows.d.ts +43 -0
  803. package/dist/types/util/errorHandling.d.ts +7 -0
  804. package/dist/types/util/folderHierarchy.d.ts +37 -0
  805. package/dist/types/util/folderOperations.d.ts +34 -0
  806. package/dist/types/util/index.d.ts +5 -0
  807. package/dist/types/util/keyboardShortcuts.d.ts +6 -0
  808. package/dist/util.cjs.js +1 -1
  809. package/dist/util.es.js +51 -41
  810. package/dist/util.es.js.map +1 -1
  811. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"useBuildFilterOptions.cjs.js","sources":["../../../../../src/components/SearchFilter/useBuildFilterOptions.tsx"],"sourcesContent":["import { getAttributeIcon, getEntityTypeIcon } from '@shared/util'\nimport {\n ProductType,\n useGetEntityGroupsQuery,\n useGetKanbanProjectUsersQuery,\n useGetProjectsInfoQuery,\n} from '@shared/api'\nimport type {\n GetProjectsInfoResponse,\n FolderType,\n Status,\n Tag,\n TaskType,\n AttributeModel,\n AttributeEnumItem,\n AttributeData,\n EntityGroup,\n} from '@shared/api'\nimport { ColumnOrderState } from '@tanstack/react-table'\nimport { Icon, Option, Filter, SEARCH_FILTER_ID } from '@ynput/ayon-react-components'\nimport { dateOptions } from './filterDates'\nimport { isEmpty } from 'lodash'\nimport { SliceFilter } from '@shared/containers'\nimport { FEATURED_VERSION_TYPES } from '../FeaturedVersionOrder'\nimport { useGlobalContext } from '@shared/context'\n\ntype ScopeType = 'folder' | 'product' | 'task' | 'user' | 'version'\ntype Scope = ScopeType | ScopeType[]\n\nexport type ScopeWithFilterTypes = {\n scope: ScopeType\n filterTypes: FilterFieldType[]\n}\n\nexport type FilterFieldType =\n | 'folderType'\n | 'taskType'\n | 'productType'\n | ('users' | 'assignees' | 'author')\n | 'attributes'\n | 'status'\n | 'tags'\n | 'version'\n | 'hasReviewables'\n | 'productName'\n | 'name'\ntype AttributeType =\n | string\n | number\n | boolean\n | Date\n | string[]\n | number[]\n | any[]\n | { [key: string]: any }\n\ntype AttributeDataValue = AttributeType | null | undefined\n\ntype FilterConfig = {\n enableExcludes?: boolean\n enableOperatorChange?: boolean\n enableRelativeValues?: boolean\n prefixes?: Partial<Record<FilterFieldType, string>> // strings that will be prepended to the id of the option\n keys?: Partial<Record<FilterFieldType, string>> // replaces the default keys for the filter\n fallbackScope?: ScopeType // used when no scope is provided\n}\n\nexport type BuildFilterOptions = {\n filterTypes?: FilterFieldType[]\n projectNames: string[]\n scope?: Scope\n scopes?: ScopeWithFilterTypes[]\n data: {\n tags?: string[]\n attributes?: Record<string, AttributeDataValue[]>\n assignees?: string[]\n productTypes?: ProductType[]\n productNames?: string[]\n }\n columnOrder?: ColumnOrderState\n config?: FilterConfig\n power?: boolean\n}\n\nexport const useBuildFilterOptions = ({\n filterTypes: globalFilterTypes = [],\n projectNames,\n scope,\n scopes: customScopes,\n data,\n config,\n columnOrder = [],\n power,\n}: BuildFilterOptions): Option[] => {\n let options: Option[] = []\n\n // Determine which scopes to use\n // If customScopes is provided, use it; otherwise, fall back to the old method\n const scopesWithTypes: Array<{ scope: ScopeType; filterTypes: FilterFieldType[] }> = customScopes\n ? customScopes\n : (() => {\n // Fallback to old method: normalize scope to array and use globalFilterTypes for all\n const normalizedScopes = scope ? (Array.isArray(scope) ? scope : [scope]) : []\n return normalizedScopes.map((s) => ({\n scope: s,\n filterTypes: globalFilterTypes,\n }))\n })()\n\n const isMultiScope = scopesWithTypes.length > 1\n\n // QUERIES\n //\n //\n // Check if any scope needs these filter types\n const anyNeedsEntitySubType = scopesWithTypes.some((s) =>\n ['entitySubType', 'status'].some((type) => s.filterTypes.includes(type as FilterFieldType)),\n )\n const anyNeedsUsers = scopesWithTypes.some((s) =>\n ['assignees', 'users', 'author'].some((type) =>\n s.filterTypes.includes(type as FilterFieldType),\n ),\n )\n // find if any search field is in any of the scopesWithTypes\n const fieldInScopes = (field: FilterFieldType): boolean => {\n return scopesWithTypes.some((s) => s.filterTypes.includes(field))\n }\n\n // get grouping options for productTypes\n // NOTE: We should revisit this to be used for all attribs and fields\n const { data: { groups: productTypes = [] } = {} } = useGetEntityGroupsQuery(\n {\n entityType: 'product',\n groupingKey: 'productType',\n projectName: projectNames[0],\n empty: true,\n },\n { skip: !projectNames?.length || !fieldInScopes('productType') },\n )\n\n const { data: projectsInfo = {} } = useGetProjectsInfoQuery(\n {\n projects: projectNames,\n },\n {\n skip: !projectNames?.length || !anyNeedsEntitySubType,\n },\n )\n\n const { data: projectUsers = [] } = useGetKanbanProjectUsersQuery(\n { projects: projectNames },\n {\n skip: !projectNames?.length || !anyNeedsUsers,\n },\n )\n\n const { attributes } = useGlobalContext()\n //\n //\n // QUERIES\n\n // ADD OPTIONS\n\n // Helper to get scope label (capitalize first letter)\n const getScopeLabel = (scope: ScopeType) => scope.charAt(0).toUpperCase() + scope.slice(1)\n\n // Loop through each scope to build options\n scopesWithTypes.forEach(({ scope: currentScope, filterTypes: scopeFilterTypes }) => {\n const scopePrefix = isMultiScope ? currentScope : undefined\n const scopeLabel = isMultiScope ? getScopeLabel(currentScope) : undefined\n\n // TASK TYPE\n // add taskType option\n if (scopeFilterTypes.includes('taskType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'taskType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'task')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // FOLDER TYPE\n // add folderType option\n if (scopeFilterTypes.includes('folderType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'folderType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'folder')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // PRODUCT TYPE\n // add productType option\n if (scopeFilterTypes.includes('productType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'productType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'product')\n entitySubTypeOption.values?.push(...subTypes)\n options.push(entitySubTypeOption)\n }\n }\n // PRODUCT NAME\n // add product name option\n if (scopeFilterTypes.includes('productName') && currentScope === 'product') {\n const productNameOption = getOptionRoot('productName', config, scopePrefix, scopeLabel)\n\n if (productNameOption) {\n // Populate with product names from data as suggestions (optional since allowsCustomValues: true)\n data.productNames?.forEach((name) => {\n if (!productNameOption.values?.some((value) => value.id === name)) {\n productNameOption.values?.push({\n id: name,\n label: name,\n })\n }\n })\n\n options.push(productNameOption)\n }\n }\n\n // STATUS\n // add status option\n if (scopeFilterTypes.includes('status')) {\n const statusOption = getOptionRoot(\n 'status',\n { ...config, enableOperatorChange: false },\n scopePrefix,\n scopeLabel,\n )\n\n if (statusOption) {\n Object.values(projectsInfo).forEach((project) => {\n const statuses = project?.statuses || []\n statuses\n .filter((status) => status.scope?.includes(currentScope))\n .forEach((status: Status) => {\n if (!statusOption.values?.some((value) => value.id === status.name)) {\n statusOption.values?.push({\n id: status.name,\n label: status.name,\n icon: status.icon,\n color: status.color,\n })\n }\n })\n })\n\n options.push(statusOption)\n }\n }\n\n // ASSIGNEES\n // add users/assignees option\n if (scopeFilterTypes.includes('assignees')) {\n const assigneesOption = getOptionRoot('assignees', config, scopePrefix, scopeLabel)\n\n if (assigneesOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!assigneesOption.values?.some((value) => value.id === user.name)) {\n assigneesOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n\n // sort the assignees based on the number of times they appear in data.assignees\n assigneesOption.values?.sort((a, b) => {\n const aCount = data.assignees?.filter((assignee) => assignee === a.id).length || 0\n const bCount = data.assignees?.filter((assignee) => assignee === b.id).length || 0\n return bCount - aCount\n })\n\n options.push(assigneesOption)\n }\n }\n\n if (scopeFilterTypes.includes('author')) {\n const authorOption = getOptionRoot('author', config, scopePrefix, scopeLabel)\n if (authorOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!authorOption.values?.some((value) => value.id === user.name)) {\n authorOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n options.push(authorOption)\n }\n }\n\n // TAGS\n // add tags options\n if (scopeFilterTypes.includes('tags')) {\n const tagsOption = getOptionRoot('tags', config, scopePrefix, scopeLabel)\n\n if (tagsOption) {\n // reduce projectsInfo to get all tags\n const tagsAnatomy = new Map<string, Tag>()\n Object.values(projectsInfo).forEach((project) => {\n if (project?.tags) {\n project.tags.forEach((tag) => {\n if (!tagsAnatomy.has(tag.name)) {\n tagsAnatomy.set(tag.name, tag)\n }\n })\n }\n })\n\n // create options for each tag, finding color if in tagsAnatomy\n const tagOptionValuesMap = new Map<string, Option & { count: number }>()\n data.tags?.forEach((tag) => {\n const existingTag = tagOptionValuesMap.get(tag)\n if (existingTag) {\n // increment count\n existingTag.count++\n return\n } else {\n // create new tag\n const tagData = tagsAnatomy.get(tag)\n\n tagOptionValuesMap.set(tag, {\n id: tag,\n type: 'string',\n label: tag,\n values: [],\n color: tagData?.color || null,\n count: 1,\n })\n }\n })\n\n // convert values map to array and sort based on count\n const tagOptionValues = Array.from(tagOptionValuesMap.values()).sort(\n (a, b) => b.count - a.count,\n )\n\n // add tag options to the tagsOption\n tagsOption.values?.push(...tagOptionValues)\n\n options.push(tagsOption)\n }\n }\n\n // VERSION\n // add version options\n if (scopeFilterTypes.includes('version')) {\n const versionOption = getOptionRoot('version', config, scopePrefix, scopeLabel)\n\n if (versionOption) {\n // add featured version types as options\n FEATURED_VERSION_TYPES.forEach((versionType) => {\n versionOption.values?.push({\n id: versionType.value,\n label: versionType.label,\n icon: versionType.icon,\n })\n })\n\n options.push(versionOption)\n }\n }\n\n // NAME\n // add name filter for custom string input\n if (scopeFilterTypes.includes('name')) {\n const nameOption = getOptionRoot('name', config, scopePrefix, scopeLabel)\n\n if (nameOption) {\n options.push(nameOption)\n }\n }\n\n // HAS REVIEWABLES\n // add hasReviewables option\n if (scopeFilterTypes.includes('hasReviewables')) {\n const hasReviewablesOption = getOptionRoot('hasReviewables', config, scopePrefix, scopeLabel)\n\n if (hasReviewablesOption) {\n const options_list = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n hasReviewablesOption.values?.push(...options_list)\n options.push(hasReviewablesOption)\n }\n }\n\n // ATTRIBUTES\n // dynamically add attributes options\n if (scopeFilterTypes.includes('attributes')) {\n const attributesByScope = attributes.filter((attribute) =>\n attribute.scope?.includes(currentScope),\n )\n // if attributesData is provided, filter out attributes that are not in the attributesData\n const attributesByValues = !isEmpty(data.attributes)\n ? attributesByScope.filter(\n (attribute) => data.attributes && data.attributes[attribute.name],\n )\n : attributesByScope\n\n const attributesWithoutDates = config?.enableRelativeValues\n ? attributesByValues\n : attributesByValues.filter((attribute) => attribute.data.type !== 'datetime')\n\n attributesWithoutDates.forEach((attribute) => {\n const realData = data.attributes && data.attributes[attribute.name]\n const enums = attribute.data.enum\n const type = attribute.data.type\n\n const isListOf = [\n 'list_of_strings',\n 'list_of_integers',\n 'list_of_any',\n 'list_of_submodels',\n ].includes(type || '')\n const isDate = type === 'datetime'\n const enableOperatorChange = isListOf ? config?.enableOperatorChange : false\n const enableRelativeValues = isListOf || isDate ? config?.enableRelativeValues : false\n // for the attribute, get the option root\n const option = getAttributeFieldOptionRoot(\n attribute,\n {\n ...config,\n allowsCustomValues: true,\n enableOperatorChange: enableOperatorChange,\n enableRelativeValues: enableRelativeValues,\n },\n scopePrefix,\n scopeLabel,\n )\n\n const suggestValuesForTypes: AttributeData['type'][] = [\n 'string',\n 'integer',\n 'float',\n 'list_of_strings',\n 'list_of_integers',\n ]\n\n const optionValues: Option[] = []\n\n // if the attribute type is in the suggestValuesForTypes, get the options based on real values\n if (suggestValuesForTypes.includes(type)) {\n const options = getAttributeOptions(realData, enums, type)\n optionValues.push(...options)\n }\n\n // if the attribute type is boolean, add yes/no options\n if (type === 'boolean') {\n const options = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n optionValues.push(...options)\n }\n\n // if the attribute type is datetime, add datetime options\n\n if (isDate) {\n optionValues.push(\n ...dateOptions.map((o) => ({\n ...o,\n contentAfter: power ? undefined : <Icon icon=\"bolt\" />,\n })),\n )\n }\n\n // add option to the list of options\n option.values?.push(...optionValues)\n\n // add option to the list of options\n options.push(option)\n })\n }\n }) // End of scopes.forEach loop\n\n // order options by columnOrder\n if (columnOrder) {\n return sortOptionsBasedOnColumns(options, columnOrder)\n } else return options\n}\n\n// HELPER FUNCTIONS\n//\n//\n//\n//\nconst getSubTypes = (\n {\n projectsInfo,\n productTypes,\n }: { projectsInfo: GetProjectsInfoResponse; productTypes: EntityGroup[] },\n type: ScopeType,\n): Option[] => {\n const options: Option[] = []\n if (type === 'product') {\n productTypes.forEach(({ icon, label, value }) => {\n options.push({\n id: value,\n type: 'string',\n label: label || value,\n icon: icon || getEntityTypeIcon('product'),\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n })\n } else if (type === 'task') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all task types and add them to the options (if they don't already exist)\n const taskTypes = project?.taskTypes || []\n taskTypes.forEach((taskType: TaskType) => {\n if (!options.some((option) => option.id === taskType.name)) {\n options.push({\n id: taskType.name,\n type: 'string',\n label: taskType.name,\n icon: taskType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n } else if (type === 'folder') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all folder types and add them to the options (if they don't already exist)\n const folderTypes = project?.folderTypes || []\n folderTypes.forEach((folderType: FolderType) => {\n if (!options.some((option) => option.id === folderType.name)) {\n options.push({\n id: folderType.name,\n type: 'string',\n label: folderType.name,\n icon: folderType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n }\n\n return options\n}\n\nconst getFormattedId = (\n base: string,\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n) => {\n const { prefixes, keys } = config || {}\n let result = base\n\n if (keys && fieldType in keys) {\n result = `${keys[fieldType]}`\n } else if (prefixes && fieldType in prefixes) {\n result = `${prefixes[fieldType]}${base}`\n }\n\n // Add scope prefix if provided\n if (scopePrefix) {\n result = `${scopePrefix}_${result}`\n }\n\n return result\n}\n\nconst formatLabel = (baseLabel: string, scopeLabel?: string) =>\n scopeLabel ? `${baseLabel} - ${scopeLabel}` : baseLabel\n\nconst getOptionRoot = (\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n scopeLabel?: string,\n) => {\n const getRootIdWithPrefix = (base: string) => getFormattedId(base, fieldType, config, scopePrefix)\n const formatLabelWithScope = (baseLabel: string) => formatLabel(baseLabel, scopeLabel)\n\n let rootOption: Option | null = null\n switch (fieldType) {\n case 'taskType':\n rootOption = {\n id: getRootIdWithPrefix(`taskType`),\n type: 'string',\n label: formatLabelWithScope(`Task Type`),\n icon: getAttributeIcon('task'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'folderType':\n rootOption = {\n id: getRootIdWithPrefix(`folderType`),\n type: 'string',\n label: formatLabelWithScope(`Folder Type`),\n icon: getAttributeIcon('folder'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productType':\n rootOption = {\n id: getRootIdWithPrefix(`productType`),\n type: 'string',\n label: formatLabelWithScope(`Product Type`),\n icon: getAttributeIcon('product'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productName':\n rootOption = {\n id: getRootIdWithPrefix(`productNames`),\n type: 'string',\n label: formatLabelWithScope(`Product Name`),\n icon: getAttributeIcon('productName', 'string'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: true,\n }\n break\n case 'status':\n rootOption = {\n id: getRootIdWithPrefix('status'),\n type: 'string',\n label: formatLabelWithScope('Status'),\n icon: getAttributeIcon('status'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'assignees':\n rootOption = {\n id: getRootIdWithPrefix('assignees'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Assignee'),\n icon: getAttributeIcon('assignees'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'author':\n rootOption = {\n id: getRootIdWithPrefix('author'),\n type: 'string',\n label: formatLabelWithScope('Author'),\n icon: getAttributeIcon('author'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'tags':\n rootOption = {\n id: getRootIdWithPrefix('tags'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Tags'),\n icon: getAttributeIcon('tags'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'version':\n rootOption = {\n id: getRootIdWithPrefix('version'),\n type: 'string',\n label: formatLabelWithScope('Version'),\n icon: getAttributeIcon('version'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: false,\n }\n break\n case 'name':\n rootOption = {\n id: getRootIdWithPrefix('name'),\n type: 'string',\n label: formatLabelWithScope('Name'),\n icon: 'text_fields',\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: false,\n }\n break\n case 'hasReviewables':\n rootOption = {\n id: getRootIdWithPrefix('hasReviewables'),\n type: 'boolean',\n label: formatLabelWithScope('Has Reviewables'),\n icon: 'play_circle',\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n singleSelect: true,\n }\n break\n default:\n break\n\n // Note: attributes are handled separately\n }\n\n return rootOption\n}\n\nconst getAttributeFieldOptionRoot = (\n attribute: AttributeModel,\n config: FilterConfig & { allowsCustomValues: boolean },\n scopePrefix?: string,\n scopeLabel?: string,\n): Option => ({\n id: getFormattedId(attribute.name, 'attributes', config, scopePrefix),\n type: attribute.data.type,\n label: scopeLabel\n ? formatLabel(attribute.data.title || attribute.name, scopeLabel)\n : attribute.data.title || attribute.name,\n operator: 'OR',\n inverted: false,\n values: [],\n allowsCustomValues: config?.allowsCustomValues,\n allowHasValue: config.enableRelativeValues,\n allowNoValue: config.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n icon: getAttributeIcon(attribute.name, attribute.data.type, !!attribute.data.enum?.length),\n singleSelect: ['boolean', 'datetime'].includes(attribute.data.type || ''),\n})\n\nconst getAttributeOptions = (\n values?: AttributeDataValue[],\n enums?: AttributeEnumItem[],\n type?: AttributeData['type'],\n): Option[] => {\n const enumOptions: Option[] = []\n const options: (Option & { count: number })[] = []\n\n // add the enum values first\n if (enums) {\n enums.forEach((enumItem) => {\n enumOptions.push({\n id: enumItem.value.toString(),\n type: type,\n label: enumItem.label,\n values: [],\n icon: enumItem.icon,\n color: enumItem.color,\n })\n })\n }\n\n values?.forEach((value) => {\n // no value? do nothing\n if (!value) return\n\n let text = ''\n\n // convert value to text\n switch (typeof value) {\n case 'string':\n case 'number':\n case 'boolean':\n text = value.toString()\n break\n case 'object':\n if (Array.isArray(value)) {\n text = value.join(', ')\n } else {\n text = JSON.stringify(value)\n }\n break\n default:\n break\n }\n\n // create id for text value\n const id = text\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9\\s]/g, '')\n .replace(/\\s+/g, '-')\n\n // check if the option already exists in enums\n const existingOption = enumOptions?.find((enumItem) => enumItem.id === id)\n if (existingOption) return\n\n // check if options already has the value, if so, increment the count\n const existingValue = options.find((option) => option.id === id)\n if (existingValue) {\n existingValue.count++\n return\n } else {\n // add option\n options.push({\n id,\n type: type,\n label: text,\n values: [],\n count: 1,\n })\n }\n })\n\n // sort options based on count\n options.sort((a, b) => b.count - a.count)\n\n // enum options first, then the rest\n return [...enumOptions, ...options]\n}\n\nconst sortOptionsBasedOnColumns = (options: Option[], columnOrder: ColumnOrderState) => {\n const columnOrderWithSubTypes = columnOrder.flatMap((col) => {\n if (col === 'subType') {\n return ['taskType', 'folderType']\n }\n return col\n })\n return [...options].sort((a, b) => {\n const aIndex = columnOrderWithSubTypes.indexOf(a.id.replace('.', '_'))\n const bIndex = columnOrderWithSubTypes.indexOf(b.id.replace('.', '_'))\n\n // If both options are in columnOrder, sort them based on their index in columnOrder\n if (aIndex !== -1 && bIndex !== -1) {\n return aIndex - bIndex\n }\n\n // If only one of the options is in columnOrder, sort the one in columnOrder first\n if (aIndex !== -1) {\n return -1\n }\n if (bIndex !== -1) {\n return 1\n }\n\n // If neither option is in columnOrder, keep their original order\n return 0\n })\n}\n\n/**\n * Splits combined filters by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope filters back into individual scope filters.\n *\n * @param combinedFilter - The filter with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param config - Filter config containing prefixes for field types\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed filters (including 'unscoped' for filters that don't match any scope), with prefixes removed from IDs\n *\n * @example\n * // Input: combinedFilter with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: { conditions: [...] }, folder: { conditions: [...] }, task: { conditions: [...] }, unscoped: { conditions: [] } }\n */\nexport const splitFiltersByScope = (\n combinedFilter: Record<string, any> | null,\n scopes: ScopeType[],\n config?: FilterConfig,\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Record<string, any>> => {\n // Initialize with all scopes having empty conditions, plus unscoped\n const result: Record<ScopeType | 'unscoped', Record<string, any>> = {\n folder: { conditions: [] },\n product: { conditions: [] },\n task: { conditions: [] },\n user: { conditions: [] },\n version: { conditions: [] },\n unscoped: { conditions: [] },\n }\n\n if (!combinedFilter?.conditions || combinedFilter?.conditions.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from an ID\n const extractScopeAndRemovePrefix = (\n id: string,\n currentConfig?: FilterConfig,\n ): { scope: ScopeType | null; cleanId: string } => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n\n if (scopeMatch) {\n // Remove scope prefix\n const cleanId = id.substring(`${scopeMatch}_`.length)\n return { scope: scopeMatch, cleanId }\n } else if (config?.fallbackScope) {\n // fallback to a default scope if provided in config\n return { scope: config.fallbackScope, cleanId: id }\n }\n\n // If no scope prefix, return null scope (shouldn't happen in multi-scope scenario)\n return { scope: null, cleanId: id }\n }\n\n // Helper to process a filter recursively\n const processConditions = (\n conditions: any[] | undefined,\n targetFilters: Record<ScopeType | 'unscoped', Record<string, any>>,\n ) => {\n if (!conditions || conditions.length === 0) return\n\n conditions.forEach((condition) => {\n // If this is a nested filter\n if ('conditions' in condition && !('key' in condition)) {\n processConditions(condition.conditions, targetFilters)\n } else if ('key' in condition) {\n // This is a QueryCondition\n const { scope, cleanId } = extractScopeAndRemovePrefix(condition.key, config)\n\n if (scope && targetFilters[scope]) {\n // Add the condition with cleaned ID to the appropriate scope\n targetFilters[scope].conditions?.push({\n ...condition,\n key: cleanId,\n })\n } else if (!scope) {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[condition.key]\n\n if (mappedScope && targetFilters[mappedScope]) {\n // Found in the map, add to mapped scope\n targetFilters[mappedScope].conditions?.push(condition)\n } else if (\n condition.key === SEARCH_FILTER_ID ||\n condition.key === 'name' ||\n condition.key?.endsWith('_name')\n ) {\n // Global search and name filters should be added to all scopes\n scopes.forEach((scopeName) => {\n if (targetFilters[scopeName]) {\n targetFilters[scopeName].conditions?.push(condition)\n }\n })\n } else {\n // Not in map, add to unscoped\n targetFilters['unscoped']?.conditions?.push(condition)\n }\n }\n }\n })\n }\n\n // Process the combined filter\n processConditions(combinedFilter.conditions, result)\n\n return result\n}\n\n/**\n * Splits combined Filter objects by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope Filter arrays back into individual scope Filter arrays.\n * This function works with Filter objects from @ynput/ayon-react-components, not QueryFilter objects.\n *\n * @param filters - Array of Filter objects with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed Filter arrays (including 'unscoped' for filters that don't match any scope)\n *\n * @example\n * // Input: filters with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: [...], folder: [...], task: [...], product: [...], user: [...], unscoped: [...] }\n */\nexport const splitClientFiltersByScope = (\n filters: (Filter | SliceFilter)[] | null | undefined,\n scopes: ScopeType[],\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Filter[]> => {\n // Initialize with all scopes having empty arrays, plus unscoped\n const result: Record<ScopeType | 'unscoped', Filter[]> = {\n folder: [],\n product: [],\n task: [],\n user: [],\n version: [],\n unscoped: [],\n }\n\n if (!filters || filters.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from a filter ID\n const extractScopeFromId = (id: string): ScopeType | null => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n return scopeMatch || null\n }\n\n // Helper to remove scope prefix from ID\n const removeScopePrefix = (id: string, scope: ScopeType): string => {\n const prefix = `${scope}_`\n return id.startsWith(prefix) ? id.substring(prefix.length) : id\n }\n\n // Process each filter\n filters.forEach((filter) => {\n if (!filter.id) return\n\n const scope = extractScopeFromId(filter.id)\n\n // If a scope was found, create a new filter without the scope prefix\n if (scope) {\n const cleanedFilter: Filter = {\n ...filter,\n id: removeScopePrefix(filter.id, scope),\n }\n result[scope].push(cleanedFilter)\n } else {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[filter.id]\n\n if (mappedScope) {\n // Found in the map, add to mapped scope\n result[mappedScope].push(filter)\n } else {\n // Not in map, add to unscoped\n result['unscoped'].push(filter)\n }\n }\n })\n\n return result\n}\n"],"names":["useBuildFilterOptions","globalFilterTypes","projectNames","scope","customScopes","data","config","columnOrder","power","options","scopesWithTypes","s","isMultiScope","anyNeedsEntitySubType","type","anyNeedsUsers","fieldInScopes","field","productTypes","useGetEntityGroupsQuery","projectsInfo","useGetProjectsInfoQuery","projectUsers","useGetKanbanProjectUsersQuery","attributes","useGlobalContext","getScopeLabel","currentScope","scopeFilterTypes","scopePrefix","scopeLabel","entitySubTypeOption","getOptionRoot","subTypes","getSubTypes","productNameOption","name","value","statusOption","project","status","assigneesOption","user","a","b","aCount","assignee","authorOption","tagsOption","tagsAnatomy","tag","tagOptionValuesMap","existingTag","tagData","tagOptionValues","versionOption","FEATURED_VERSION_TYPES","versionType","nameOption","hasReviewablesOption","options_list","attributesByScope","attribute","attributesByValues","isEmpty","realData","enums","isListOf","isDate","enableOperatorChange","enableRelativeValues","option","getAttributeFieldOptionRoot","suggestValuesForTypes","optionValues","getAttributeOptions","dateOptions","o","jsx","Icon","sortOptionsBasedOnColumns","icon","label","getEntityTypeIcon","taskType","folderType","getFormattedId","base","fieldType","prefixes","keys","result","formatLabel","baseLabel","getRootIdWithPrefix","formatLabelWithScope","rootOption","getAttributeIcon","values","enumOptions","enumItem","text","id","existingValue","columnOrderWithSubTypes","col","aIndex","bIndex","splitFiltersByScope","combinedFilter","scopes","filterIdToScopeMap","extractScopeAndRemovePrefix","currentConfig","scopeMatch","cleanId","processConditions","conditions","targetFilters","condition","mappedScope","SEARCH_FILTER_ID","scopeName","splitClientFiltersByScope","filters","extractScopeFromId","removeScopePrefix","prefix","filter","cleanedFilter"],"mappings":"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"}
1
+ {"version":3,"file":"useBuildFilterOptions.cjs.js","sources":["../../../../../src/components/SearchFilter/useBuildFilterOptions.tsx"],"sourcesContent":["import { getAttributeIcon, getEntityTypeIcon } from '@shared/util'\nimport {\n ProductType,\n useGetEntityGroupsQuery,\n useGetKanbanProjectUsersQuery,\n useGetProjectsInfoQuery,\n} from '@shared/api'\nimport type {\n GetProjectsInfoResponse,\n FolderType,\n Status,\n Tag,\n TaskType,\n AttributeModel,\n AttributeEnumItem,\n AttributeData,\n EntityGroup,\n} from '@shared/api'\nimport { ColumnOrderState } from '@tanstack/react-table'\nimport { Icon, Option, Filter, SEARCH_FILTER_ID } from '@ynput/ayon-react-components'\nimport { dateOptions } from './filterDates'\nimport { isEmpty } from 'lodash'\nimport { SliceFilter } from '@shared/containers'\nimport { FEATURED_VERSION_TYPES } from '../FeaturedVersionOrder'\nimport { useGlobalContext } from '@shared/context'\n\ntype ScopeType = 'folder' | 'product' | 'task' | 'user' | 'version'\ntype Scope = ScopeType | ScopeType[]\n\nexport type ScopeWithFilterTypes = {\n scope: ScopeType\n filterTypes: FilterFieldType[]\n}\n\nexport type FilterFieldType =\n | 'folderType'\n | 'taskType'\n | 'productType'\n | ('users' | 'assignees' | 'author')\n | 'attributes'\n | 'status'\n | 'tags'\n | 'version'\n | 'hasReviewables'\n | 'productName'\n | 'name'\ntype AttributeType =\n | string\n | number\n | boolean\n | Date\n | string[]\n | number[]\n | any[]\n | { [key: string]: any }\n\ntype AttributeDataValue = AttributeType | null | undefined\n\ntype FilterConfig = {\n enableExcludes?: boolean\n enableOperatorChange?: boolean\n enableRelativeValues?: boolean\n prefixes?: Partial<Record<FilterFieldType, string>> // strings that will be prepended to the id of the option\n keys?: Partial<Record<FilterFieldType, string>> // replaces the default keys for the filter\n fallbackScope?: ScopeType // used when no scope is provided\n}\n\nexport type BuildFilterOptions = {\n filterTypes?: FilterFieldType[]\n projectNames: string[]\n scope?: Scope\n scopes?: ScopeWithFilterTypes[]\n data: {\n tags?: string[]\n attributes?: Record<string, AttributeDataValue[]>\n assignees?: string[]\n productTypes?: ProductType[]\n productNames?: string[]\n }\n columnOrder?: ColumnOrderState\n config?: FilterConfig\n power?: boolean\n}\n\nexport const useBuildFilterOptions = ({\n filterTypes: globalFilterTypes = [],\n projectNames,\n scope,\n scopes: customScopes,\n data,\n config,\n columnOrder = [],\n power,\n}: BuildFilterOptions): Option[] => {\n let options: Option[] = []\n\n // Determine which scopes to use\n // If customScopes is provided, use it; otherwise, fall back to the old method\n const scopesWithTypes: Array<{ scope: ScopeType; filterTypes: FilterFieldType[] }> = customScopes\n ? customScopes\n : (() => {\n // Fallback to old method: normalize scope to array and use globalFilterTypes for all\n const normalizedScopes = scope ? (Array.isArray(scope) ? scope : [scope]) : []\n return normalizedScopes.map((s) => ({\n scope: s,\n filterTypes: globalFilterTypes,\n }))\n })()\n\n const isMultiScope = scopesWithTypes.length > 1\n\n // QUERIES\n //\n //\n // Check if any scope needs these filter types\n const anyNeedsEntitySubType = scopesWithTypes.some((s) =>\n ['entitySubType', 'status'].some((type) => s.filterTypes.includes(type as FilterFieldType)),\n )\n const anyNeedsUsers = scopesWithTypes.some((s) =>\n ['assignees', 'users', 'author'].some((type) =>\n s.filterTypes.includes(type as FilterFieldType),\n ),\n )\n // find if any search field is in any of the scopesWithTypes\n const fieldInScopes = (field: FilterFieldType): boolean => {\n return scopesWithTypes.some((s) => s.filterTypes.includes(field))\n }\n\n // get grouping options for productTypes\n // NOTE: We should revisit this to be used for all attribs and fields\n const { data: { groups: productTypes = [] } = {} } = useGetEntityGroupsQuery(\n {\n entityType: 'product',\n groupingKey: 'productType',\n projectName: projectNames[0],\n empty: true,\n },\n { skip: !projectNames?.length || !fieldInScopes('productType') },\n )\n\n const { data: projectsInfo = {} } = useGetProjectsInfoQuery(\n {\n projects: projectNames,\n },\n {\n skip: !projectNames?.length || !anyNeedsEntitySubType,\n },\n )\n\n const { data: projectUsers = [] } = useGetKanbanProjectUsersQuery(\n { projects: projectNames },\n {\n skip: !projectNames?.length || !anyNeedsUsers,\n },\n )\n\n const { attributes } = useGlobalContext()\n //\n //\n // QUERIES\n\n // ADD OPTIONS\n\n // Helper to get scope label (capitalize first letter)\n const getScopeLabel = (scope: ScopeType) => scope.charAt(0).toUpperCase() + scope.slice(1)\n\n // Loop through each scope to build options\n scopesWithTypes.forEach(({ scope: currentScope, filterTypes: scopeFilterTypes }) => {\n const scopePrefix = isMultiScope ? currentScope : undefined\n const scopeLabel = isMultiScope ? getScopeLabel(currentScope) : undefined\n\n // TASK TYPE\n // add taskType option\n if (scopeFilterTypes.includes('taskType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'taskType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'task')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // FOLDER TYPE\n // add folderType option\n if (scopeFilterTypes.includes('folderType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'folderType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'folder')\n\n entitySubTypeOption.values?.push(...subTypes)\n\n options.push(entitySubTypeOption)\n }\n }\n\n // PRODUCT TYPE\n // add productType option\n if (scopeFilterTypes.includes('productType') && currentScope !== 'user') {\n const entitySubTypeOption = getOptionRoot(\n 'productType',\n {\n ...config,\n enableOperatorChange: false,\n },\n scopePrefix,\n scopeLabel,\n )\n if (entitySubTypeOption) {\n // get all subTypes for the current scope (entityType)\n let subTypes = getSubTypes({ projectsInfo, productTypes }, 'product')\n entitySubTypeOption.values?.push(...subTypes)\n options.push(entitySubTypeOption)\n }\n }\n // PRODUCT NAME\n // add product name option\n if (scopeFilterTypes.includes('productName') && currentScope === 'product') {\n const productNameOption = getOptionRoot('productName', config, scopePrefix, scopeLabel)\n\n if (productNameOption) {\n // Populate with product names from data as suggestions (optional since allowsCustomValues: true)\n data.productNames?.forEach((name) => {\n if (!productNameOption.values?.some((value) => value.id === name)) {\n productNameOption.values?.push({\n id: name,\n label: name,\n })\n }\n })\n\n options.push(productNameOption)\n }\n }\n\n // STATUS\n // add status option\n if (scopeFilterTypes.includes('status')) {\n const statusOption = getOptionRoot(\n 'status',\n { ...config, enableOperatorChange: false },\n scopePrefix,\n scopeLabel,\n )\n\n if (statusOption) {\n Object.values(projectsInfo).forEach((project) => {\n const statuses = project?.statuses || []\n statuses\n .filter((status) => status.scope?.includes(currentScope))\n .forEach((status: Status) => {\n if (!statusOption.values?.some((value) => value.id === status.name)) {\n statusOption.values?.push({\n id: status.name,\n label: status.name,\n icon: status.icon,\n color: status.color,\n })\n }\n })\n })\n\n options.push(statusOption)\n }\n }\n\n // ASSIGNEES\n // add users/assignees option\n if (scopeFilterTypes.includes('assignees')) {\n const assigneesOption = getOptionRoot('assignees', config, scopePrefix, scopeLabel)\n\n if (assigneesOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!assigneesOption.values?.some((value) => value.id === user.name)) {\n assigneesOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n\n // sort the assignees based on the number of times they appear in data.assignees\n assigneesOption.values?.sort((a, b) => {\n const aCount = data.assignees?.filter((assignee) => assignee === a.id).length || 0\n const bCount = data.assignees?.filter((assignee) => assignee === b.id).length || 0\n return bCount - aCount\n })\n\n options.push(assigneesOption)\n }\n }\n\n if (scopeFilterTypes.includes('author')) {\n const authorOption = getOptionRoot('author', config, scopePrefix, scopeLabel)\n if (authorOption) {\n // add every user for the projects (skip duplicates)\n projectUsers.forEach((user) => {\n if (!authorOption.values?.some((value) => value.id === user.name)) {\n authorOption.values?.push({\n id: user.name,\n label: user.attrib.fullName || user.name,\n img: `/api/users/${user.name}/avatar`,\n icon: null,\n })\n }\n })\n options.push(authorOption)\n }\n }\n\n // TAGS\n // add tags options\n if (scopeFilterTypes.includes('tags')) {\n const tagsOption = getOptionRoot('tags', config, scopePrefix, scopeLabel)\n\n if (tagsOption) {\n // reduce projectsInfo to get all tags\n const tagsAnatomy = new Map<string, Tag>()\n Object.values(projectsInfo).forEach((project) => {\n if (project?.tags) {\n project.tags.forEach((tag) => {\n if (!tagsAnatomy.has(tag.name)) {\n tagsAnatomy.set(tag.name, tag)\n }\n })\n }\n })\n\n // create options for each tag, finding color if in tagsAnatomy\n const tagOptionValuesMap = new Map<string, Option & { count: number }>()\n data.tags?.forEach((tag) => {\n const existingTag = tagOptionValuesMap.get(tag)\n if (existingTag) {\n // increment count\n existingTag.count++\n return\n } else {\n // create new tag\n const tagData = tagsAnatomy.get(tag)\n\n tagOptionValuesMap.set(tag, {\n id: tag,\n type: 'string',\n label: tag,\n values: [],\n color: tagData?.color || null,\n count: 1,\n })\n }\n })\n\n // convert values map to array and sort based on count\n const tagOptionValues = Array.from(tagOptionValuesMap.values()).sort(\n (a, b) => b.count - a.count,\n )\n\n // add tag options to the tagsOption\n tagsOption.values?.push(...tagOptionValues)\n\n options.push(tagsOption)\n }\n }\n\n // VERSION\n // add version options\n if (scopeFilterTypes.includes('version')) {\n const versionOption = getOptionRoot('version', config, scopePrefix, scopeLabel)\n\n if (versionOption) {\n // add featured version types as options\n FEATURED_VERSION_TYPES.forEach((versionType) => {\n versionOption.values?.push({\n id: versionType.value,\n label: versionType.label,\n icon: versionType.icon,\n })\n })\n\n options.push(versionOption)\n }\n }\n\n // NAME\n // add name filter for custom string input\n if (scopeFilterTypes.includes('name')) {\n const nameOption = getOptionRoot('name', config, scopePrefix, scopeLabel)\n\n if (nameOption) {\n options.push(nameOption)\n }\n }\n\n // HAS REVIEWABLES\n // add hasReviewables option\n if (scopeFilterTypes.includes('hasReviewables')) {\n const hasReviewablesOption = getOptionRoot('hasReviewables', config, scopePrefix, scopeLabel)\n\n if (hasReviewablesOption) {\n const options_list = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n hasReviewablesOption.values?.push(...options_list)\n options.push(hasReviewablesOption)\n }\n }\n\n // ATTRIBUTES\n // dynamically add attributes options\n if (scopeFilterTypes.includes('attributes')) {\n const attributesByScope = attributes.filter((attribute) =>\n attribute.scope?.includes(currentScope),\n )\n // if attributesData is provided, filter out attributes that are not in the attributesData\n const attributesByValues = !isEmpty(data.attributes)\n ? attributesByScope.filter(\n (attribute) => data.attributes && data.attributes[attribute.name],\n )\n : attributesByScope\n\n const attributesWithoutDates = config?.enableRelativeValues\n ? attributesByValues\n : attributesByValues.filter((attribute) => attribute.data.type !== 'datetime')\n\n attributesWithoutDates.forEach((attribute) => {\n const realData = data.attributes && data.attributes[attribute.name]\n const enums = attribute.data.enum\n const type = attribute.data.type\n\n const isListOf = [\n 'list_of_strings',\n 'list_of_integers',\n 'list_of_any',\n 'list_of_submodels',\n ].includes(type || '')\n const isDate = type === 'datetime'\n const enableOperatorChange = isListOf ? config?.enableOperatorChange : false\n const enableRelativeValues = isListOf || isDate ? config?.enableRelativeValues : false\n // for the attribute, get the option root\n const option = getAttributeFieldOptionRoot(\n attribute,\n {\n ...config,\n allowsCustomValues: true,\n enableOperatorChange: enableOperatorChange,\n enableRelativeValues: enableRelativeValues,\n },\n scopePrefix,\n scopeLabel,\n )\n\n const suggestValuesForTypes: AttributeData['type'][] = [\n 'string',\n 'integer',\n 'float',\n 'list_of_strings',\n 'list_of_integers',\n ]\n\n const optionValues: Option[] = []\n\n // if the attribute type is in the suggestValuesForTypes, get the options based on real values\n if (suggestValuesForTypes.includes(type)) {\n const options = getAttributeOptions(realData, enums, type)\n optionValues.push(...options)\n }\n\n // if the attribute type is boolean, add yes/no options\n if (type === 'boolean') {\n const options = [\n {\n id: 'true',\n label: 'Yes',\n values: [],\n icon: 'radio_button_checked',\n },\n {\n id: 'false',\n label: 'No',\n values: [],\n icon: 'radio_button_unchecked',\n },\n ]\n optionValues.push(...options)\n }\n\n // if the attribute type is datetime, add datetime options\n\n if (isDate) {\n optionValues.push(\n ...dateOptions.map((o) => ({\n ...o,\n contentAfter: power ? undefined : <Icon icon=\"bolt\" />,\n })),\n )\n }\n\n // add option to the list of options\n option.values?.push(...optionValues)\n\n // add option to the list of options\n options.push(option)\n })\n }\n }) // End of scopes.forEach loop\n\n // order options by columnOrder\n if (columnOrder) {\n return sortOptionsBasedOnColumns(options, columnOrder)\n } else return options\n}\n\n// HELPER FUNCTIONS\n//\n//\n//\n//\nconst getSubTypes = (\n {\n projectsInfo,\n productTypes,\n }: { projectsInfo: GetProjectsInfoResponse; productTypes: EntityGroup[] },\n type: ScopeType,\n): Option[] => {\n const options: Option[] = []\n if (type === 'product') {\n productTypes.forEach(({ icon, label, value }) => {\n options.push({\n id: value,\n type: 'string',\n label: label || value,\n icon: icon || getEntityTypeIcon('product'),\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n })\n } else if (type === 'task') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all task types and add them to the options (if they don't already exist)\n const taskTypes = project?.taskTypes || []\n taskTypes.forEach((taskType: TaskType) => {\n if (!options.some((option) => option.id === taskType.name)) {\n options.push({\n id: taskType.name,\n type: 'string',\n label: taskType.name,\n icon: taskType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n } else if (type === 'folder') {\n Object.values(projectsInfo).forEach((project) => {\n // for each project, get all folder types and add them to the options (if they don't already exist)\n const folderTypes = project?.folderTypes || []\n folderTypes.forEach((folderType: FolderType) => {\n if (!options.some((option) => option.id === folderType.name)) {\n options.push({\n id: folderType.name,\n type: 'string',\n label: folderType.name,\n icon: folderType.icon,\n inverted: false,\n values: [],\n allowsCustomValues: false,\n })\n }\n })\n })\n }\n\n return options\n}\n\nconst getFormattedId = (\n base: string,\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n) => {\n const { prefixes, keys } = config || {}\n let result = base\n\n if (keys && fieldType in keys) {\n result = `${keys[fieldType]}`\n } else if (prefixes && fieldType in prefixes) {\n result = `${prefixes[fieldType]}${base}`\n }\n\n // Add scope prefix if provided\n if (scopePrefix) {\n result = `${scopePrefix}_${result}`\n }\n\n return result\n}\n\nconst formatLabel = (baseLabel: string, scopeLabel?: string) =>\n scopeLabel ? `${baseLabel} - ${scopeLabel}` : baseLabel\n\nconst getOptionRoot = (\n fieldType: FilterFieldType,\n config?: FilterConfig,\n scopePrefix?: string,\n scopeLabel?: string,\n) => {\n const getRootIdWithPrefix = (base: string) => getFormattedId(base, fieldType, config, scopePrefix)\n const formatLabelWithScope = (baseLabel: string) => formatLabel(baseLabel, scopeLabel)\n\n let rootOption: Option | null = null\n switch (fieldType) {\n case 'taskType':\n rootOption = {\n id: getRootIdWithPrefix(`taskType`),\n type: 'string',\n label: formatLabelWithScope(`Task Type`),\n icon: getAttributeIcon('task'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'folderType':\n rootOption = {\n id: getRootIdWithPrefix(`folderType`),\n type: 'string',\n label: formatLabelWithScope(`Folder Type`),\n icon: getAttributeIcon('folder'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productType':\n rootOption = {\n id: getRootIdWithPrefix(`productType`),\n type: 'string',\n label: formatLabelWithScope(`Product Type`),\n icon: getAttributeIcon('product'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'productName':\n rootOption = {\n id: getRootIdWithPrefix(`productNames`),\n type: 'string',\n label: formatLabelWithScope(`Product Name`),\n icon: getAttributeIcon('productName', 'string'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: true,\n }\n break\n case 'status':\n rootOption = {\n id: getRootIdWithPrefix('status'),\n type: 'string',\n label: formatLabelWithScope('Status'),\n icon: getAttributeIcon('status'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n }\n break\n case 'assignees':\n rootOption = {\n id: getRootIdWithPrefix('assignees'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Assignee'),\n icon: getAttributeIcon('assignees'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'author':\n rootOption = {\n id: getRootIdWithPrefix('author'),\n type: 'string',\n label: formatLabelWithScope('Author'),\n icon: getAttributeIcon('author'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'tags':\n rootOption = {\n id: getRootIdWithPrefix('tags'),\n type: 'list_of_strings',\n label: formatLabelWithScope('Tags'),\n icon: getAttributeIcon('tags'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: config?.enableRelativeValues,\n allowNoValue: config?.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n }\n break\n case 'version':\n rootOption = {\n id: getRootIdWithPrefix('version'),\n type: 'string',\n label: formatLabelWithScope('Version'),\n icon: getAttributeIcon('version'),\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: false,\n }\n break\n case 'name':\n rootOption = {\n id: getRootIdWithPrefix('name'),\n type: 'string',\n label: formatLabelWithScope('Name'),\n icon: 'text_fields',\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: true,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: false,\n operatorChangeable: false,\n }\n break\n case 'hasReviewables':\n rootOption = {\n id: getRootIdWithPrefix('hasReviewables'),\n type: 'boolean',\n label: formatLabelWithScope('Has Reviewables'),\n icon: 'play_circle',\n inverted: false,\n operator: 'OR',\n values: [],\n allowsCustomValues: false,\n allowHasValue: false,\n allowNoValue: false,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: false,\n singleSelect: true,\n }\n break\n default:\n break\n\n // Note: attributes are handled separately\n }\n\n return rootOption\n}\n\nconst getAttributeFieldOptionRoot = (\n attribute: AttributeModel,\n config: FilterConfig & { allowsCustomValues: boolean },\n scopePrefix?: string,\n scopeLabel?: string,\n): Option => ({\n id: getFormattedId(attribute.name, 'attributes', config, scopePrefix),\n type: attribute.data.type,\n label: scopeLabel\n ? formatLabel(attribute.data.title || attribute.name, scopeLabel)\n : attribute.data.title || attribute.name,\n operator: 'OR',\n inverted: false,\n values: [],\n allowsCustomValues: config?.allowsCustomValues,\n allowHasValue: config.enableRelativeValues,\n allowNoValue: config.enableRelativeValues,\n allowExcludes: config?.enableExcludes,\n operatorChangeable: config?.enableOperatorChange,\n icon: getAttributeIcon(attribute.name, attribute.data.type, !!attribute.data.enum?.length),\n singleSelect: ['boolean', 'datetime'].includes(attribute.data.type || ''),\n})\n\nconst getAttributeOptions = (\n values?: AttributeDataValue[],\n enums?: AttributeEnumItem[],\n type?: AttributeData['type'],\n): Option[] => {\n const enumOptions: Option[] = []\n const options: (Option & { count: number })[] = []\n\n // add the enum values first\n if (enums) {\n enums.forEach((enumItem) => {\n enumOptions.push({\n id: enumItem.value.toString(),\n type: type,\n label: enumItem.label,\n values: [],\n icon: enumItem.icon,\n color: enumItem.color,\n })\n })\n }\n\n values?.forEach((value) => {\n // no value? do nothing\n if (!value) return\n\n let text = ''\n\n // convert value to text\n switch (typeof value) {\n case 'string':\n case 'number':\n case 'boolean':\n text = value.toString()\n break\n case 'object':\n if (Array.isArray(value)) {\n text = value.join(', ')\n } else {\n text = JSON.stringify(value)\n }\n break\n default:\n break\n }\n\n // create id for text value\n const id = text\n .trim()\n .toLowerCase()\n .replace(/[^a-z0-9\\s]/g, '')\n .replace(/\\s+/g, '-')\n\n // check if the option already exists in enums\n const existingOption = enumOptions?.find((enumItem) => enumItem.id === id)\n if (existingOption) return\n\n // check if options already has the value, if so, increment the count\n const existingValue = options.find((option) => option.id === id)\n if (existingValue) {\n existingValue.count++\n return\n } else {\n // add option\n options.push({\n id,\n type: type,\n label: text,\n values: [],\n count: 1,\n })\n }\n })\n\n // sort options based on count\n options.sort((a, b) => b.count - a.count)\n\n // enum options first, then the rest\n return [...enumOptions, ...options]\n}\n\nconst sortOptionsBasedOnColumns = (options: Option[], columnOrder: ColumnOrderState) => {\n const columnOrderWithSubTypes = columnOrder.flatMap((col) => {\n if (col === 'subType') {\n return ['taskType', 'folderType']\n }\n return col\n })\n return [...options].sort((a, b) => {\n const aIndex = columnOrderWithSubTypes.indexOf(a.id.replace('.', '_'))\n const bIndex = columnOrderWithSubTypes.indexOf(b.id.replace('.', '_'))\n\n // If both options are in columnOrder, sort them based on their index in columnOrder\n if (aIndex !== -1 && bIndex !== -1) {\n return aIndex - bIndex\n }\n\n // If only one of the options is in columnOrder, sort the one in columnOrder first\n if (aIndex !== -1) {\n return -1\n }\n if (bIndex !== -1) {\n return 1\n }\n\n // If neither option is in columnOrder, keep their original order\n return 0\n })\n}\n\n/**\n * Splits combined filters by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope filters back into individual scope filters.\n *\n * @param combinedFilter - The filter with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param config - Filter config containing prefixes for field types\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed filters (including 'unscoped' for filters that don't match any scope), with prefixes removed from IDs\n *\n * @example\n * // Input: combinedFilter with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: { conditions: [...] }, folder: { conditions: [...] }, task: { conditions: [...] }, unscoped: { conditions: [] } }\n */\nexport const splitFiltersByScope = (\n combinedFilter: Record<string, any> | null,\n scopes: ScopeType[],\n config?: FilterConfig,\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Record<string, any>> => {\n // Initialize with all scopes having empty conditions, plus unscoped\n const result: Record<ScopeType | 'unscoped', Record<string, any>> = {\n folder: { conditions: [] },\n product: { conditions: [] },\n task: { conditions: [] },\n user: { conditions: [] },\n version: { conditions: [] },\n unscoped: { conditions: [] },\n }\n\n if (!combinedFilter?.conditions || combinedFilter?.conditions.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from an ID\n const extractScopeAndRemovePrefix = (\n id: string,\n currentConfig?: FilterConfig,\n ): { scope: ScopeType | null; cleanId: string } => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n\n if (scopeMatch) {\n // Remove scope prefix\n const cleanId = id.substring(`${scopeMatch}_`.length)\n return { scope: scopeMatch, cleanId }\n } else if (config?.fallbackScope) {\n // fallback to a default scope if provided in config\n return { scope: config.fallbackScope, cleanId: id }\n }\n\n // If no scope prefix, return null scope (shouldn't happen in multi-scope scenario)\n return { scope: null, cleanId: id }\n }\n\n // Helper to process a filter recursively\n const processConditions = (\n conditions: any[] | undefined,\n targetFilters: Record<ScopeType | 'unscoped', Record<string, any>>,\n ) => {\n if (!conditions || conditions.length === 0) return\n\n conditions.forEach((condition) => {\n // If this is a nested filter\n if ('conditions' in condition && !('key' in condition)) {\n processConditions(condition.conditions, targetFilters)\n } else if ('key' in condition) {\n // This is a QueryCondition\n const { scope, cleanId } = extractScopeAndRemovePrefix(condition.key, config)\n\n if (scope && targetFilters[scope]) {\n // Add the condition with cleaned ID to the appropriate scope\n targetFilters[scope].conditions?.push({\n ...condition,\n key: cleanId,\n })\n } else if (!scope) {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[condition.key]\n\n if (mappedScope && targetFilters[mappedScope]) {\n // Found in the map, add to mapped scope\n targetFilters[mappedScope].conditions?.push(condition)\n } else if (\n condition.key === SEARCH_FILTER_ID ||\n condition.key === 'name' ||\n condition.key?.endsWith('_name')\n ) {\n // Global search and name filters should be added to all scopes\n scopes.forEach((scopeName) => {\n if (targetFilters[scopeName]) {\n targetFilters[scopeName].conditions?.push(condition)\n }\n })\n } else {\n // Not in map, add to unscoped\n targetFilters['unscoped']?.conditions?.push(condition)\n }\n }\n }\n })\n }\n\n // Process the combined filter\n processConditions(combinedFilter.conditions, result)\n\n return result\n}\n\n/**\n * Splits combined Filter objects by their scope and removes the scope prefix from filter IDs.\n * Used to separate multi-scope Filter arrays back into individual scope Filter arrays.\n * This function works with Filter objects from @ynput/ayon-react-components, not QueryFilter objects.\n *\n * @param filters - Array of Filter objects with potentially scope-prefixed IDs\n * @param scopes - Array of scopes to split by\n * @param filterIdToScopeMap - Optional mapping of filter IDs (without scope prefix) to their scopes (e.g., { taskType: 'task', folderType: 'folder' })\n * @returns Object with scope-keyed Filter arrays (including 'unscoped' for filters that don't match any scope)\n *\n * @example\n * // Input: filters with IDs like \"version_status\", \"folder_status\", \"taskType\"\n * // With filterIdToScopeMap: { taskType: 'task' }\n * // Output: { version: [...], folder: [...], task: [...], product: [...], user: [...], unscoped: [...] }\n */\nexport const splitClientFiltersByScope = (\n filters: (Filter | SliceFilter)[] | null | undefined,\n scopes: ScopeType[],\n filterIdToScopeMap?: Record<string, ScopeType>,\n): Record<ScopeType | 'unscoped', Filter[]> => {\n // Initialize with all scopes having empty arrays, plus unscoped\n const result: Record<ScopeType | 'unscoped', Filter[]> = {\n folder: [],\n product: [],\n task: [],\n user: [],\n version: [],\n unscoped: [],\n }\n\n if (!filters || filters.length === 0) {\n return result\n }\n\n // Helper to extract scope prefix from a filter ID\n const extractScopeFromId = (id: string): ScopeType | null => {\n // Check if ID starts with any scope prefix\n const scopeMatch = scopes.find((scope) => id.startsWith(`${scope}_`))\n return scopeMatch || null\n }\n\n // Helper to remove scope prefix from ID\n const removeScopePrefix = (id: string, scope: ScopeType): string => {\n const prefix = `${scope}_`\n return id.startsWith(prefix) ? id.substring(prefix.length) : id\n }\n\n // Process each filter\n filters.forEach((filter) => {\n if (!filter.id) return\n\n const scope = extractScopeFromId(filter.id)\n\n // If a scope was found, create a new filter without the scope prefix\n if (scope) {\n const cleanedFilter: Filter = {\n ...filter,\n id: removeScopePrefix(filter.id, scope),\n }\n result[scope].push(cleanedFilter)\n } else {\n // No explicit scope prefix found, check filterIdToScopeMap\n const mappedScope = filterIdToScopeMap?.[filter.id]\n\n if (mappedScope) {\n // Found in the map, add to mapped scope\n result[mappedScope].push(filter)\n } else {\n // Not in map, add to unscoped\n result['unscoped'].push(filter)\n }\n }\n })\n\n return result\n}\n"],"names":["useBuildFilterOptions","globalFilterTypes","projectNames","scope","customScopes","data","config","columnOrder","power","options","scopesWithTypes","s","isMultiScope","anyNeedsEntitySubType","type","anyNeedsUsers","fieldInScopes","field","productTypes","useGetEntityGroupsQuery","projectsInfo","useGetProjectsInfoQuery","projectUsers","useGetKanbanProjectUsersQuery","attributes","useGlobalContext","getScopeLabel","currentScope","scopeFilterTypes","scopePrefix","scopeLabel","entitySubTypeOption","getOptionRoot","subTypes","getSubTypes","productNameOption","name","value","statusOption","project","status","assigneesOption","user","a","b","aCount","assignee","authorOption","tagsOption","tagsAnatomy","tag","tagOptionValuesMap","existingTag","tagData","tagOptionValues","versionOption","FEATURED_VERSION_TYPES","versionType","nameOption","hasReviewablesOption","options_list","attributesByScope","attribute","attributesByValues","isEmpty","realData","enums","isListOf","isDate","enableOperatorChange","enableRelativeValues","option","getAttributeFieldOptionRoot","suggestValuesForTypes","optionValues","getAttributeOptions","dateOptions","o","jsx","Icon","sortOptionsBasedOnColumns","icon","label","getEntityTypeIcon","taskType","folderType","getFormattedId","base","fieldType","prefixes","keys","result","formatLabel","baseLabel","getRootIdWithPrefix","formatLabelWithScope","rootOption","getAttributeIcon","values","enumOptions","enumItem","text","id","existingValue","columnOrderWithSubTypes","col","aIndex","bIndex","splitFiltersByScope","combinedFilter","scopes","filterIdToScopeMap","extractScopeAndRemovePrefix","currentConfig","scopeMatch","cleanId","processConditions","conditions","targetFilters","condition","mappedScope","SEARCH_FILTER_ID","scopeName","splitClientFiltersByScope","filters","extractScopeFromId","removeScopePrefix","prefix","filter","cleanedFilter"],"mappings":"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"}
@@ -30,6 +30,7 @@ import "../../api/generated/operations.es.js";
30
30
  import "../../api/generated/products.es.js";
31
31
  import "../../api/generated/projectDashboard.es.js";
32
32
  import "../../api/generated/projects.es.js";
33
+ import "../../api/generated/projectFolders.es.js";
33
34
  import "../../api/generated/reviewables.es.js";
34
35
  import "../../api/generated/services.es.js";
35
36
  import "../../api/generated/system.es.js";
@@ -77,6 +78,7 @@ import "../../api/queries/permissions/getPermissions.es.js";
77
78
  import "../../api/queries/products/createProduct.es.js";
78
79
  import "../../api/queries/project/getProject.es.js";
79
80
  import "../../api/queries/project/updateProject.es.js";
81
+ import "../../api/queries/projectFolders/projectFolders.es.js";
80
82
  import "../../api/queries/review/getReview.es.js";
81
83
  import "../../api/queries/review/updateReview.es.js";
82
84
  import "../../api/queries/share/share.es.js";
@@ -112,7 +114,7 @@ import { useGlobalContext as F } from "../../context/GlobalContext.es.js";
112
114
  import "../../context/ProjectContext.es.js";
113
115
  import "../../context/ProjectFoldersContext.es.js";
114
116
  import "../../context/UriContext.es.js";
115
- const ut = ({
117
+ const ct = ({
116
118
  filterTypes: r = [],
117
119
  projectNames: t,
118
120
  scope: c,
@@ -664,7 +666,7 @@ const ut = ({
664
666
  const s = c.indexOf(n.id.replace(".", "_")), e = c.indexOf(o.id.replace(".", "_"));
665
667
  return s !== -1 && e !== -1 ? s - e : s !== -1 ? -1 : e !== -1 ? 1 : 0;
666
668
  });
667
- }, pt = (r, t, c, n) => {
669
+ }, mt = (r, t, c, n) => {
668
670
  const o = {
669
671
  folder: { conditions: [] },
670
672
  product: { conditions: [] },
@@ -704,7 +706,7 @@ const ut = ({
704
706
  });
705
707
  };
706
708
  return e(r.conditions, o), o;
707
- }, ct = (r, t, c) => {
709
+ }, dt = (r, t, c) => {
708
710
  const n = {
709
711
  folder: [],
710
712
  product: [],
@@ -735,8 +737,8 @@ const ut = ({
735
737
  }), n;
736
738
  };
737
739
  export {
738
- ct as splitClientFiltersByScope,
739
- pt as splitFiltersByScope,
740
- ut as useBuildFilterOptions
740
+ dt as splitClientFiltersByScope,
741
+ mt as splitFiltersByScope,
742
+ ct as useBuildFilterOptions
741
743
  };
742
744
  //# sourceMappingURL=useBuildFilterOptions.es.js.map