@ynput/ayon-frontend-shared 0.2.18 → 0.2.20

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 (695) hide show
  1. package/dist/DetailsPanel.cjs.js +16 -6
  2. package/dist/DetailsPanel.cjs.js.map +1 -1
  3. package/dist/DetailsPanel.es.js +17 -7
  4. package/dist/DetailsPanel.es.js.map +1 -1
  5. package/dist/ProjectTreeTable.cjs.js +6 -0
  6. package/dist/ProjectTreeTable.cjs.js.map +1 -1
  7. package/dist/ProjectTreeTable.es.js +6 -0
  8. package/dist/ProjectTreeTable.es.js.map +1 -1
  9. package/dist/api.cjs.js +22 -0
  10. package/dist/api.cjs.js.map +1 -1
  11. package/dist/api.es.js +27 -5
  12. package/dist/api.es.js.map +1 -1
  13. package/dist/components.cjs.js +22 -0
  14. package/dist/components.cjs.js.map +1 -1
  15. package/dist/components.es.js +23 -1
  16. package/dist/components.es.js.map +1 -1
  17. package/dist/index.cjs.js +16 -5
  18. package/dist/index.cjs.js.map +1 -1
  19. package/dist/index.es.js +16 -5
  20. package/dist/index.es.js.map +1 -1
  21. package/dist/shared/node_modules/uuid/dist/esm-browser/native.cjs.js +5 -0
  22. package/dist/shared/node_modules/uuid/dist/esm-browser/native.cjs.js.map +1 -0
  23. package/dist/shared/node_modules/uuid/dist/esm-browser/native.es.js +6 -0
  24. package/dist/shared/node_modules/uuid/dist/esm-browser/native.es.js.map +1 -0
  25. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.cjs.js +2 -2
  26. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.cjs.js.map +1 -1
  27. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.es.js +2 -2
  28. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.es.js.map +1 -1
  29. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.cjs.js +1 -1
  30. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.cjs.js.map +1 -1
  31. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.es.js +1 -1
  32. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.es.js.map +1 -1
  33. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.cjs.js +58 -41
  34. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.cjs.js.map +1 -1
  35. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.es.js +57 -41
  36. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.es.js.map +1 -1
  37. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.cjs.js +20 -0
  38. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.cjs.js.map +1 -0
  39. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.es.js +21 -0
  40. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.es.js.map +1 -0
  41. package/dist/shared/src/api/base/client.cjs.js +2 -1
  42. package/dist/shared/src/api/base/client.cjs.js.map +1 -1
  43. package/dist/shared/src/api/base/client.es.js +2 -1
  44. package/dist/shared/src/api/base/client.es.js.map +1 -1
  45. package/dist/shared/src/api/generated/actions.cjs.js +6 -1
  46. package/dist/shared/src/api/generated/actions.cjs.js.map +1 -1
  47. package/dist/shared/src/api/generated/actions.es.js +6 -1
  48. package/dist/shared/src/api/generated/actions.es.js.map +1 -1
  49. package/dist/shared/src/api/generated/activityFeed.cjs.js.map +1 -1
  50. package/dist/shared/src/api/generated/activityFeed.es.js.map +1 -1
  51. package/dist/shared/src/api/generated/addons.cjs.js +2 -1
  52. package/dist/shared/src/api/generated/addons.cjs.js.map +1 -1
  53. package/dist/shared/src/api/generated/addons.es.js +2 -1
  54. package/dist/shared/src/api/generated/addons.es.js.map +1 -1
  55. package/dist/shared/src/api/generated/anatomy.cjs.js.map +1 -1
  56. package/dist/shared/src/api/generated/anatomy.es.js.map +1 -1
  57. package/dist/shared/src/api/generated/authentication.cjs.js.map +1 -1
  58. package/dist/shared/src/api/generated/authentication.es.js.map +1 -1
  59. package/dist/shared/src/api/generated/configuration.cjs.js.map +1 -1
  60. package/dist/shared/src/api/generated/configuration.es.js.map +1 -1
  61. package/dist/shared/src/api/generated/folders.cjs.js.map +1 -1
  62. package/dist/shared/src/api/generated/folders.es.js.map +1 -1
  63. package/dist/shared/src/api/generated/graphql.cjs.js +38 -0
  64. package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
  65. package/dist/shared/src/api/generated/graphql.es.js +38 -0
  66. package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
  67. package/dist/shared/src/api/generated/links.cjs.js.map +1 -1
  68. package/dist/shared/src/api/generated/links.es.js.map +1 -1
  69. package/dist/shared/src/api/generated/onboarding.cjs.js.map +1 -1
  70. package/dist/shared/src/api/generated/onboarding.es.js.map +1 -1
  71. package/dist/shared/src/api/generated/operations.cjs.js.map +1 -1
  72. package/dist/shared/src/api/generated/operations.es.js.map +1 -1
  73. package/dist/shared/src/api/generated/projects.cjs.js +0 -8
  74. package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
  75. package/dist/shared/src/api/generated/projects.es.js +0 -8
  76. package/dist/shared/src/api/generated/projects.es.js.map +1 -1
  77. package/dist/shared/src/api/generated/system.cjs.js.map +1 -1
  78. package/dist/shared/src/api/generated/system.es.js.map +1 -1
  79. package/dist/shared/src/api/generated/tasks.cjs.js.map +1 -1
  80. package/dist/shared/src/api/generated/tasks.es.js.map +1 -1
  81. package/dist/shared/src/api/generated/views.cjs.js +53 -0
  82. package/dist/shared/src/api/generated/views.cjs.js.map +1 -0
  83. package/dist/shared/src/api/generated/views.es.js +53 -0
  84. package/dist/shared/src/api/generated/views.es.js.map +1 -0
  85. package/dist/shared/src/api/queries/actions/getActions.cjs.js +10 -1
  86. package/dist/shared/src/api/queries/actions/getActions.cjs.js.map +1 -1
  87. package/dist/shared/src/api/queries/actions/getActions.es.js +10 -1
  88. package/dist/shared/src/api/queries/actions/getActions.es.js.map +1 -1
  89. package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -0
  90. package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
  91. package/dist/shared/src/api/queries/activities/getActivities.es.js +1 -0
  92. package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
  93. package/dist/shared/src/api/queries/activities/getMentions.cjs.js +1 -0
  94. package/dist/shared/src/api/queries/activities/getMentions.cjs.js.map +1 -1
  95. package/dist/shared/src/api/queries/activities/getMentions.es.js +1 -0
  96. package/dist/shared/src/api/queries/activities/getMentions.es.js.map +1 -1
  97. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js +1 -0
  98. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js.map +1 -1
  99. package/dist/shared/src/api/queries/activities/updateReaction.es.js +1 -0
  100. package/dist/shared/src/api/queries/activities/updateReaction.es.js.map +1 -1
  101. package/dist/shared/src/api/queries/addons/getAddons.cjs.js +1 -0
  102. package/dist/shared/src/api/queries/addons/getAddons.cjs.js.map +1 -1
  103. package/dist/shared/src/api/queries/addons/getAddons.es.js +1 -0
  104. package/dist/shared/src/api/queries/addons/getAddons.es.js.map +1 -1
  105. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js +1 -0
  106. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js.map +1 -1
  107. package/dist/shared/src/api/queries/attributes/getAttributes.es.js +1 -0
  108. package/dist/shared/src/api/queries/attributes/getAttributes.es.js.map +1 -1
  109. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js +1 -0
  110. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js.map +1 -1
  111. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js +1 -0
  112. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js.map +1 -1
  113. package/dist/shared/src/api/queries/cloud/cloud.cjs.js +67 -0
  114. package/dist/shared/src/api/queries/cloud/cloud.cjs.js.map +1 -0
  115. package/dist/shared/src/api/queries/cloud/cloud.es.js +67 -0
  116. package/dist/shared/src/api/queries/cloud/cloud.es.js.map +1 -0
  117. package/dist/shared/src/api/queries/entities/getEntity.cjs.js +1 -0
  118. package/dist/shared/src/api/queries/entities/getEntity.cjs.js.map +1 -1
  119. package/dist/shared/src/api/queries/entities/getEntity.es.js +1 -0
  120. package/dist/shared/src/api/queries/entities/getEntity.es.js.map +1 -1
  121. package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js +3 -1
  122. package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js.map +1 -1
  123. package/dist/shared/src/api/queries/entities/getEntityPanel.es.js +3 -1
  124. package/dist/shared/src/api/queries/entities/getEntityPanel.es.js.map +1 -1
  125. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +16 -8
  126. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
  127. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +16 -8
  128. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
  129. package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +11 -1
  130. package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
  131. package/dist/shared/src/api/queries/entities/updateEntity.es.js +11 -1
  132. package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
  133. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +68 -0
  134. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
  135. package/dist/shared/src/api/queries/entityLists/getLists.es.js +69 -1
  136. package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
  137. package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js +1 -0
  138. package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js.map +1 -1
  139. package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js +1 -0
  140. package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js.map +1 -1
  141. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +20 -3
  142. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
  143. package/dist/shared/src/api/queries/entityLists/updateLists.es.js +20 -3
  144. package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
  145. package/dist/shared/src/api/queries/folders/getFolders.cjs.js +1 -0
  146. package/dist/shared/src/api/queries/folders/getFolders.cjs.js.map +1 -1
  147. package/dist/shared/src/api/queries/folders/getFolders.es.js +1 -0
  148. package/dist/shared/src/api/queries/folders/getFolders.es.js.map +1 -1
  149. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js +1 -0
  150. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js.map +1 -1
  151. package/dist/shared/src/api/queries/grouping/getGrouping.es.js +1 -0
  152. package/dist/shared/src/api/queries/grouping/getGrouping.es.js.map +1 -1
  153. package/dist/shared/src/api/queries/overview/getOverview.cjs.js +1 -0
  154. package/dist/shared/src/api/queries/overview/getOverview.cjs.js.map +1 -1
  155. package/dist/shared/src/api/queries/overview/getOverview.es.js +1 -0
  156. package/dist/shared/src/api/queries/overview/getOverview.es.js.map +1 -1
  157. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +30 -2
  158. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
  159. package/dist/shared/src/api/queries/overview/updateOverview.es.js +30 -2
  160. package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
  161. package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js +1 -0
  162. package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js.map +1 -1
  163. package/dist/shared/src/api/queries/permissions/getPermissions.es.js +1 -0
  164. package/dist/shared/src/api/queries/permissions/getPermissions.es.js.map +1 -1
  165. package/dist/shared/src/api/queries/products/createProduct.cjs.js +1 -0
  166. package/dist/shared/src/api/queries/products/createProduct.cjs.js.map +1 -1
  167. package/dist/shared/src/api/queries/products/createProduct.es.js +1 -0
  168. package/dist/shared/src/api/queries/products/createProduct.es.js.map +1 -1
  169. package/dist/shared/src/api/queries/project/getProject.cjs.js +1 -0
  170. package/dist/shared/src/api/queries/project/getProject.cjs.js.map +1 -1
  171. package/dist/shared/src/api/queries/project/getProject.es.js +1 -0
  172. package/dist/shared/src/api/queries/project/getProject.es.js.map +1 -1
  173. package/dist/shared/src/api/queries/review/getReview.cjs.js +1 -0
  174. package/dist/shared/src/api/queries/review/getReview.cjs.js.map +1 -1
  175. package/dist/shared/src/api/queries/review/getReview.es.js +1 -0
  176. package/dist/shared/src/api/queries/review/getReview.es.js.map +1 -1
  177. package/dist/shared/src/api/queries/review/updateReview.cjs.js +1 -0
  178. package/dist/shared/src/api/queries/review/updateReview.cjs.js.map +1 -1
  179. package/dist/shared/src/api/queries/review/updateReview.es.js +1 -0
  180. package/dist/shared/src/api/queries/review/updateReview.es.js.map +1 -1
  181. package/dist/shared/src/api/queries/system/getSystem.cjs.js +1 -0
  182. package/dist/shared/src/api/queries/system/getSystem.cjs.js.map +1 -1
  183. package/dist/shared/src/api/queries/system/getSystem.es.js +1 -0
  184. package/dist/shared/src/api/queries/system/getSystem.es.js.map +1 -1
  185. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js +1 -0
  186. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js.map +1 -1
  187. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js +1 -0
  188. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js.map +1 -1
  189. package/dist/shared/src/api/queries/users/getUsers.cjs.js +6 -0
  190. package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
  191. package/dist/shared/src/api/queries/users/getUsers.es.js +6 -0
  192. package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
  193. package/dist/shared/src/api/queries/users/updateUsers.cjs.js +1 -0
  194. package/dist/shared/src/api/queries/users/updateUsers.cjs.js.map +1 -1
  195. package/dist/shared/src/api/queries/users/updateUsers.es.js +1 -0
  196. package/dist/shared/src/api/queries/users/updateUsers.es.js.map +1 -1
  197. package/dist/shared/src/api/queries/versions/updateVersions.cjs.js +4 -1
  198. package/dist/shared/src/api/queries/versions/updateVersions.cjs.js.map +1 -1
  199. package/dist/shared/src/api/queries/versions/updateVersions.es.js +4 -1
  200. package/dist/shared/src/api/queries/versions/updateVersions.es.js.map +1 -1
  201. package/dist/shared/src/api/queries/views/getViews.cjs.js +72 -0
  202. package/dist/shared/src/api/queries/views/getViews.cjs.js.map +1 -0
  203. package/dist/shared/src/api/queries/views/getViews.es.js +72 -0
  204. package/dist/shared/src/api/queries/views/getViews.es.js.map +1 -0
  205. package/dist/shared/src/api/queries/views/updateViews.cjs.js +33 -0
  206. package/dist/shared/src/api/queries/views/updateViews.cjs.js.map +1 -0
  207. package/dist/shared/src/api/queries/views/updateViews.es.js +33 -0
  208. package/dist/shared/src/api/queries/views/updateViews.es.js.map +1 -0
  209. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js +1 -0
  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 +1 -0
  212. package/dist/shared/src/api/queries/watchers/getWatchers.es.js.map +1 -1
  213. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +4 -0
  214. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
  215. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +4 -0
  216. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
  217. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js +17 -6
  218. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js.map +1 -1
  219. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js +17 -6
  220. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js.map +1 -1
  221. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js +1 -1
  222. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js.map +1 -1
  223. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js +1 -1
  224. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js.map +1 -1
  225. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +2 -2
  226. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
  227. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +2 -2
  228. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
  229. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +25 -14
  230. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
  231. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +25 -14
  232. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
  233. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js +369 -0
  234. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js.map +1 -0
  235. package/dist/shared/src/components/Feedback/FeedbackContext.es.js +369 -0
  236. package/dist/shared/src/components/Feedback/FeedbackContext.es.js.map +1 -0
  237. package/dist/shared/src/components/Feedback/SupportBubble.cjs.js +48 -0
  238. package/dist/shared/src/components/Feedback/SupportBubble.cjs.js.map +1 -0
  239. package/dist/shared/src/components/Feedback/SupportBubble.es.js +48 -0
  240. package/dist/shared/src/components/Feedback/SupportBubble.es.js.map +1 -0
  241. package/dist/shared/src/components/PlayableIcon/PlayableIcon.cjs.js +43 -0
  242. package/dist/shared/src/components/PlayableIcon/PlayableIcon.cjs.js.map +1 -0
  243. package/dist/shared/src/components/PlayableIcon/PlayableIcon.es.js +43 -0
  244. package/dist/shared/src/components/PlayableIcon/PlayableIcon.es.js.map +1 -0
  245. package/dist/shared/src/components/Powerpack/CTAButton.cjs.js +10 -0
  246. package/dist/shared/src/components/Powerpack/CTAButton.cjs.js.map +1 -0
  247. package/dist/shared/src/components/Powerpack/CTAButton.es.js +10 -0
  248. package/dist/shared/src/components/Powerpack/CTAButton.es.js.map +1 -0
  249. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +229 -28
  250. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -1
  251. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +230 -29
  252. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -1
  253. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js +4 -1
  254. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js.map +1 -1
  255. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js +4 -1
  256. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js.map +1 -1
  257. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +19 -15
  258. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
  259. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +19 -15
  260. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
  261. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +179 -0
  262. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
  263. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +179 -0
  264. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
  265. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +4 -0
  266. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
  267. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +4 -0
  268. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
  269. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +16 -5
  270. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
  271. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +16 -5
  272. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
  273. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +16 -5
  274. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
  275. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +16 -5
  276. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
  277. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +16 -5
  278. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
  279. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +16 -5
  280. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
  281. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js +4 -0
  282. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js.map +1 -1
  283. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js +4 -0
  284. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js.map +1 -1
  285. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +4 -0
  286. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
  287. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +4 -0
  288. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
  289. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js +2 -2
  290. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js.map +1 -1
  291. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js +2 -2
  292. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js.map +1 -1
  293. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +16 -5
  294. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
  295. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +16 -5
  296. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
  297. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +16 -5
  298. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
  299. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +16 -5
  300. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
  301. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js +4 -0
  302. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js.map +1 -1
  303. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js +4 -0
  304. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js.map +1 -1
  305. package/dist/shared/src/components/Views/ViewForm/ViewForm.cjs.js +164 -0
  306. package/dist/shared/src/components/Views/ViewForm/ViewForm.cjs.js.map +1 -0
  307. package/dist/shared/src/components/Views/ViewForm/ViewForm.es.js +164 -0
  308. package/dist/shared/src/components/Views/ViewForm/ViewForm.es.js.map +1 -0
  309. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.cjs.js +71 -0
  310. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.cjs.js.map +1 -0
  311. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.es.js +71 -0
  312. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.es.js.map +1 -0
  313. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.cjs.js +189 -0
  314. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.cjs.js.map +1 -0
  315. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.es.js +189 -0
  316. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.es.js.map +1 -0
  317. package/dist/shared/src/components/Views/ViewItem/ViewItem.cjs.js +36 -0
  318. package/dist/shared/src/components/Views/ViewItem/ViewItem.cjs.js.map +1 -0
  319. package/dist/shared/src/components/Views/ViewItem/ViewItem.es.js +36 -0
  320. package/dist/shared/src/components/Views/ViewItem/ViewItem.es.js.map +1 -0
  321. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.cjs.js +63 -0
  322. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.cjs.js.map +1 -0
  323. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.es.js +63 -0
  324. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.es.js.map +1 -0
  325. package/dist/shared/src/components/Views/Views.cjs.js +21 -0
  326. package/dist/shared/src/components/Views/Views.cjs.js.map +1 -0
  327. package/dist/shared/src/components/Views/Views.es.js +21 -0
  328. package/dist/shared/src/components/Views/Views.es.js.map +1 -0
  329. package/dist/shared/src/components/Views/Views.styled.cjs.js +44 -0
  330. package/dist/shared/src/components/Views/Views.styled.cjs.js.map +1 -0
  331. package/dist/shared/src/components/Views/Views.styled.es.js +44 -0
  332. package/dist/shared/src/components/Views/Views.styled.es.js.map +1 -0
  333. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.cjs.js +32 -0
  334. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.cjs.js.map +1 -0
  335. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.es.js +32 -0
  336. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.es.js.map +1 -0
  337. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.cjs.js +31 -0
  338. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.cjs.js.map +1 -0
  339. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.es.js +31 -0
  340. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.es.js.map +1 -0
  341. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.cjs.js +33 -0
  342. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.cjs.js.map +1 -0
  343. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.es.js +33 -0
  344. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.es.js.map +1 -0
  345. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js +132 -0
  346. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js.map +1 -0
  347. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.es.js +132 -0
  348. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.es.js.map +1 -0
  349. package/dist/shared/src/components/Views/context/ViewsContext.cjs.js +145 -0
  350. package/dist/shared/src/components/Views/context/ViewsContext.cjs.js.map +1 -0
  351. package/dist/shared/src/components/Views/context/ViewsContext.es.js +145 -0
  352. package/dist/shared/src/components/Views/context/ViewsContext.es.js.map +1 -0
  353. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.cjs.js +160 -0
  354. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.cjs.js.map +1 -0
  355. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.es.js +160 -0
  356. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.es.js.map +1 -0
  357. package/dist/shared/src/components/Views/utils/generatePersonalView.cjs.js +13 -0
  358. package/dist/shared/src/components/Views/utils/generatePersonalView.cjs.js.map +1 -0
  359. package/dist/shared/src/components/Views/utils/generatePersonalView.es.js +13 -0
  360. package/dist/shared/src/components/Views/utils/generatePersonalView.es.js.map +1 -0
  361. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.cjs.js +8 -0
  362. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.cjs.js.map +1 -0
  363. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.es.js +8 -0
  364. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.es.js.map +1 -0
  365. package/dist/shared/src/components/Views/utils/portalUtils.cjs.js +11 -0
  366. package/dist/shared/src/components/Views/utils/portalUtils.cjs.js.map +1 -0
  367. package/dist/shared/src/components/Views/utils/portalUtils.es.js +11 -0
  368. package/dist/shared/src/components/Views/utils/portalUtils.es.js.map +1 -0
  369. package/dist/shared/src/components/Watchers/Watchers.cjs.js +4 -0
  370. package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
  371. package/dist/shared/src/components/Watchers/Watchers.es.js +4 -0
  372. package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
  373. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +16 -5
  374. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
  375. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +16 -5
  376. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
  377. package/dist/shared/src/containers/Actions/Actions.cjs.js +12 -2
  378. package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
  379. package/dist/shared/src/containers/Actions/Actions.es.js +12 -2
  380. package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
  381. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +10 -3
  382. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
  383. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +10 -3
  384. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
  385. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js +14 -0
  386. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js.map +1 -1
  387. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js +14 -0
  388. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js.map +1 -1
  389. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +16 -5
  390. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
  391. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +16 -5
  392. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
  393. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +15 -5
  394. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
  395. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +15 -5
  396. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
  397. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +16 -5
  398. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
  399. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +16 -5
  400. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
  401. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +16 -5
  402. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
  403. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +16 -5
  404. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
  405. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +16 -4
  406. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
  407. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +17 -5
  408. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
  409. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js +1 -31
  410. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js.map +1 -1
  411. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.es.js +1 -31
  412. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.es.js.map +1 -1
  413. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +4 -0
  414. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
  415. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +4 -0
  416. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
  417. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +4 -0
  418. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
  419. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +4 -0
  420. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
  421. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js +2 -2
  422. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js.map +1 -1
  423. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js +2 -2
  424. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js.map +1 -1
  425. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js +1 -1
  426. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js.map +1 -1
  427. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js +1 -1
  428. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js.map +1 -1
  429. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +4 -0
  430. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
  431. package/dist/shared/src/containers/Feed/context/FeedContext.es.js +4 -0
  432. package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
  433. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js +1 -1
  434. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js.map +1 -1
  435. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +4 -0
  436. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
  437. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +4 -0
  438. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
  439. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +57 -5
  440. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
  441. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +59 -7
  442. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
  443. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +47 -11
  444. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
  445. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +47 -11
  446. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
  447. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +15 -4
  448. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
  449. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +15 -4
  450. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
  451. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js +5 -3
  452. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js.map +1 -1
  453. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js +5 -3
  454. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js.map +1 -1
  455. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js +106 -2
  456. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js.map +1 -1
  457. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js +106 -2
  458. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js.map +1 -1
  459. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +14 -2
  460. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
  461. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +14 -2
  462. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
  463. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +4 -0
  464. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
  465. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +4 -0
  466. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
  467. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
  468. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
  469. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +15 -3
  470. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -1
  471. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +15 -3
  472. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -1
  473. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +110 -0
  474. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
  475. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +110 -0
  476. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
  477. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +4 -0
  478. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -1
  479. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +4 -0
  480. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -1
  481. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +4 -2
  482. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
  483. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +4 -2
  484. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
  485. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +26 -4
  486. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
  487. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +26 -4
  488. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
  489. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +139 -0
  490. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -0
  491. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +139 -0
  492. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -0
  493. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js +8 -6
  494. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js.map +1 -1
  495. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js +8 -6
  496. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js.map +1 -1
  497. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +4 -0
  498. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
  499. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +4 -0
  500. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
  501. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js +1 -2
  502. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js.map +1 -1
  503. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js +1 -2
  504. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js.map +1 -1
  505. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +92 -0
  506. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
  507. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +92 -0
  508. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
  509. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js +4 -0
  510. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js.map +1 -1
  511. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js +4 -0
  512. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js.map +1 -1
  513. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js +1 -1
  514. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js.map +1 -1
  515. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js +1 -1
  516. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js.map +1 -1
  517. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +35 -4
  518. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
  519. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +35 -4
  520. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
  521. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js +4 -0
  522. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -1
  523. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js +4 -0
  524. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js.map +1 -1
  525. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +92 -0
  526. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
  527. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +92 -0
  528. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
  529. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js +1 -1
  530. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -1
  531. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js +1 -1
  532. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -1
  533. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +94 -0
  534. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
  535. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +94 -0
  536. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
  537. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.cjs.js +19 -0
  538. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.cjs.js.map +1 -0
  539. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.es.js +19 -0
  540. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.es.js.map +1 -0
  541. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.cjs.js +26 -0
  542. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.cjs.js.map +1 -0
  543. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.es.js +26 -0
  544. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.es.js.map +1 -0
  545. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +9 -8
  546. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
  547. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +10 -9
  548. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
  549. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js +8 -2
  550. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js.map +1 -1
  551. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js +8 -2
  552. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js.map +1 -1
  553. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js +190 -0
  554. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js.map +1 -0
  555. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js +190 -0
  556. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js.map +1 -0
  557. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js +4 -147
  558. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js.map +1 -1
  559. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js +2 -145
  560. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js.map +1 -1
  561. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js +12 -2
  562. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js.map +1 -1
  563. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js +12 -2
  564. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js.map +1 -1
  565. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +16 -5
  566. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
  567. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +16 -5
  568. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
  569. package/dist/shared/src/context/AddonProjectContext.cjs.js +4 -0
  570. package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
  571. package/dist/shared/src/context/AddonProjectContext.es.js +4 -0
  572. package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
  573. package/dist/shared/src/context/DetailsPanelContext.cjs.js +9 -1
  574. package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
  575. package/dist/shared/src/context/DetailsPanelContext.es.js +9 -1
  576. package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
  577. package/dist/shared/src/context/PowerpackContext.cjs.js +9 -0
  578. package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
  579. package/dist/shared/src/context/PowerpackContext.es.js +9 -0
  580. package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
  581. package/dist/shared/src/context/RemoteModulesContext.cjs.js +4 -0
  582. package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
  583. package/dist/shared/src/context/RemoteModulesContext.es.js +4 -0
  584. package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
  585. package/dist/shared/src/hooks/useActionTriggers.cjs.js +4 -0
  586. package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
  587. package/dist/shared/src/hooks/useActionTriggers.es.js +4 -0
  588. package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
  589. package/dist/shared/src/hooks/useEntityUpdate.cjs.js +4 -0
  590. package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
  591. package/dist/shared/src/hooks/useEntityUpdate.es.js +4 -0
  592. package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
  593. package/dist/shared/src/hooks/useScopedStatuses.cjs.js +4 -0
  594. package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
  595. package/dist/shared/src/hooks/useScopedStatuses.es.js +4 -0
  596. package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
  597. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +4 -0
  598. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
  599. package/dist/shared/src/hooks/useUserProjectConfig.es.js +4 -0
  600. package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
  601. package/dist/shared/src/util/confirmDelete.cjs.js +1 -0
  602. package/dist/shared/src/util/confirmDelete.cjs.js.map +1 -1
  603. package/dist/shared/src/util/confirmDelete.es.js +2 -0
  604. package/dist/shared/src/util/confirmDelete.es.js.map +1 -1
  605. package/dist/types/SimpleTable/SimpleTable.d.ts +1 -0
  606. package/dist/types/SimpleTable/SimpleTableRowTemplate.d.ts +1 -1
  607. package/dist/types/SimpleTable/context/SimpleTableContext.d.ts +5 -1
  608. package/dist/types/api/generated/actions.d.ts +11 -4
  609. package/dist/types/api/generated/activityFeed.d.ts +3 -0
  610. package/dist/types/api/generated/addons.d.ts +1 -0
  611. package/dist/types/api/generated/anatomy.d.ts +0 -2
  612. package/dist/types/api/generated/authentication.d.ts +0 -1
  613. package/dist/types/api/generated/configuration.d.ts +6 -0
  614. package/dist/types/api/generated/folders.d.ts +1 -0
  615. package/dist/types/api/generated/graphql.d.ts +66 -5
  616. package/dist/types/api/generated/index.d.ts +2 -0
  617. package/dist/types/api/generated/links.d.ts +7 -5
  618. package/dist/types/api/generated/onboarding.d.ts +0 -1
  619. package/dist/types/api/generated/operations.d.ts +2 -0
  620. package/dist/types/api/generated/projects.d.ts +0 -35
  621. package/dist/types/api/generated/system.d.ts +2 -0
  622. package/dist/types/api/generated/tasks.d.ts +0 -14
  623. package/dist/types/api/generated/views.d.ts +122 -0
  624. package/dist/types/api/queries/actions/getActions.d.ts +132 -1
  625. package/dist/types/api/queries/activities/getActivities.d.ts +6 -0
  626. package/dist/types/api/queries/activities/updateActivities.d.ts +12 -0
  627. package/dist/types/api/queries/cloud/cloud.d.ts +593 -0
  628. package/dist/types/api/queries/cloud/index.d.ts +1 -0
  629. package/dist/types/api/queries/entities/getEntity.d.ts +6 -0
  630. package/dist/types/api/queries/entities/getEntityPanel.d.ts +6 -0
  631. package/dist/types/api/queries/entities/transformDetailsPanelData.d.ts +1 -0
  632. package/dist/types/api/queries/entities/updateEntity.d.ts +6 -0
  633. package/dist/types/api/queries/entityLists/getLists.d.ts +1517 -2
  634. package/dist/types/api/queries/entityLists/types.d.ts +30 -1
  635. package/dist/types/api/queries/entityLists/updateLists.d.ts +166 -3
  636. package/dist/types/api/queries/index.d.ts +2 -0
  637. package/dist/types/api/queries/overview/getOverview.d.ts +6 -0
  638. package/dist/types/api/queries/project/getProject.d.ts +0 -2
  639. package/dist/types/api/queries/userDashboard/getUserDashboard.d.ts +6 -0
  640. package/dist/types/api/queries/users/getUsers.d.ts +6 -0
  641. package/dist/types/api/queries/views/getViews.d.ts +412 -0
  642. package/dist/types/api/queries/views/index.d.ts +2 -0
  643. package/dist/types/api/queries/views/updateViews.d.ts +177 -0
  644. package/dist/types/components/Feedback/FeedbackContext.d.ts +17 -0
  645. package/dist/types/components/Feedback/SupportBubble.d.ts +4 -0
  646. package/dist/types/components/Feedback/index.d.ts +2 -0
  647. package/dist/types/components/PlayableIcon/PlayableIcon.d.ts +4 -0
  648. package/dist/types/components/Powerpack/CTAButton.d.ts +4 -0
  649. package/dist/types/components/Powerpack/PowerpackDialog.d.ts +8 -0
  650. package/dist/types/components/Views/ViewForm/ViewForm.d.ts +14 -0
  651. package/dist/types/components/Views/ViewForm/ViewForm.styled.d.ts +9 -0
  652. package/dist/types/components/Views/ViewForm/ViewFormContainer.d.ts +15 -0
  653. package/dist/types/components/Views/ViewItem/ViewItem.d.ts +15 -0
  654. package/dist/types/components/Views/ViewItem/ViewItem.styled.d.ts +4 -0
  655. package/dist/types/components/Views/Views.d.ts +8 -0
  656. package/dist/types/components/Views/Views.styled.d.ts +4 -0
  657. package/dist/types/components/Views/ViewsButton/ViewsButton.d.ts +2 -0
  658. package/dist/types/components/Views/ViewsMenu/ViewsMenu.d.ts +11 -0
  659. package/dist/types/components/Views/ViewsMenu/ViewsMenu.styled.d.ts +4 -0
  660. package/dist/types/components/Views/ViewsMenuContainer/ViewsMenuContainer.d.ts +4 -0
  661. package/dist/types/components/Views/context/ViewsContext.d.ts +31 -0
  662. package/dist/types/components/Views/hooks/useBuildViewMenuItems.d.ts +14 -0
  663. package/dist/types/components/Views/index.d.ts +11 -0
  664. package/dist/types/components/Views/utils/generatePersonalView.d.ts +3 -0
  665. package/dist/types/components/Views/utils/getCustomViewsFallback.d.ts +12 -0
  666. package/dist/types/components/Views/utils/portalUtils.d.ts +9 -0
  667. package/dist/types/components/index.d.ts +2 -0
  668. package/dist/types/containers/Actions/Actions.d.ts +7 -1
  669. package/dist/types/containers/Actions/ActionsDropdown/ActionsDropdown.d.ts +5 -3
  670. package/dist/types/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.d.ts +0 -1
  671. package/dist/types/containers/ProjectTreeTable/ProjectTreeTable.d.ts +6 -2
  672. package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +4 -1
  673. package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +11 -2
  674. package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +1 -0
  675. package/dist/types/containers/ProjectTreeTable/hooks/useCellContextMenu.d.ts +1 -1
  676. package/dist/types/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.d.ts +9 -0
  677. package/dist/types/containers/ProjectTreeTable/hooks/useFolderRelationships.d.ts +2 -2
  678. package/dist/types/containers/ProjectTreeTable/hooks/useKeyboardNavigation.d.ts +3 -3
  679. package/dist/types/containers/ProjectTreeTable/hooks/useUpdateTableData.d.ts +1 -1
  680. package/dist/types/containers/ProjectTreeTable/types/table.d.ts +10 -1
  681. package/dist/types/containers/ProjectTreeTable/utils/getEntityViewerIds.d.ts +4 -0
  682. package/dist/types/containers/ProjectTreeTable/utils/getTypeDefaultValue.d.ts +2 -0
  683. package/dist/types/containers/ProjectTreeTable/utils/index.d.ts +2 -0
  684. package/dist/types/containers/ProjectTreeTable/widgets/CellWidget.d.ts +2 -1
  685. package/dist/types/containers/ProjectTreeTable/widgets/EnumCellValue.d.ts +20 -0
  686. package/dist/types/containers/ProjectTreeTable/widgets/EnumWidget.d.ts +1 -11
  687. package/dist/types/containers/ProjectTreeTable/widgets/ThumbnailWidget.d.ts +1 -0
  688. package/dist/types/context/DetailsPanelContext.d.ts +1 -0
  689. package/dist/types/context/PowerpackContext.d.ts +5 -5
  690. package/dist/types/util/confirmDelete.d.ts +2 -1
  691. package/dist/util.cjs.js +2 -0
  692. package/dist/util.cjs.js.map +1 -1
  693. package/dist/util.es.js +2 -0
  694. package/dist/util.es.js.map +1 -1
  695. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"updateEntity.es.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n // update folder\n const newFolder = { ...folder, ...patch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["dashboardQueries","api","folder","task","detailsPanelQueries"],"mappings":"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"}
1
+ {"version":3,"file":"updateEntity.es.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n\n // If name is being updated, also update the path\n let updatedPatch = { ...patch }\n if (patch.name && folder.path) {\n // Construct new path by replacing the last segment with the new name\n const pathParts = folder.path.split('/')\n pathParts[pathParts.length - 1] = patch.name\n updatedPatch.path = pathParts.join('/')\n }\n\n // update folder\n const newFolder = { ...folder, ...updatedPatch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["dashboardQueries","api","folder","task","detailsPanelQueries"],"mappings":"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"}
@@ -36,6 +36,7 @@ require("../../generated/versions.cjs.js");
36
36
  require("../../generated/workfiles.cjs.js");
37
37
  require("../../generated/ynputCloud.cjs.js");
38
38
  require("../../generated/grouping.cjs.js");
39
+ require("../../generated/views.cjs.js");
39
40
  const getOverview = require("../overview/getOverview.cjs.js");
40
41
  require("../overview/updateOverview.cjs.js");
41
42
  require("lodash");
@@ -69,6 +70,14 @@ const getListsGqlApiEnhanced = graphql.api.enhanceEndpoints({
69
70
  pageInfo: response.project.entityLists.edges[0].node.items.pageInfo
70
71
  };
71
72
  }
73
+ },
74
+ GetListsItemsForReviewSession: {
75
+ transformResponse: (response) => {
76
+ return {
77
+ lists: response.project.entityLists.edges.map((edge) => edge.node),
78
+ pageInfo: response.project.entityLists.pageInfo
79
+ };
80
+ }
72
81
  }
73
82
  }
74
83
  });
@@ -118,6 +127,10 @@ const getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({
118
127
  ...((result == null ? void 0 : result.pages.flatMap((page) => page.lists)) || []).map((list) => ({
119
128
  type: "entityList",
120
129
  id: list.id
130
+ })),
131
+ ...((result == null ? void 0 : result.pages.flatMap((page) => page.lists)) || []).map((list) => ({
132
+ type: "entityList",
133
+ id: list.entityListType
121
134
  }))
122
135
  ],
123
136
  async onCacheEntryAdded(_args, { cacheDataLoaded, cacheEntryRemoved, dispatch, updateCachedData }) {
@@ -253,12 +266,64 @@ const getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({
253
266
  pubsub.unsubscribe(token);
254
267
  pubsub.unsubscribe(token2);
255
268
  }
269
+ }),
270
+ getListsItemsForReviewSession: build.infiniteQuery({
271
+ infiniteQueryOptions: {
272
+ initialPageParam: { cursor: "" },
273
+ getNextPageParam: (lastPage) => {
274
+ const { pageInfo } = lastPage;
275
+ if (!pageInfo.hasNextPage || !pageInfo.endCursor) return void 0;
276
+ return {
277
+ cursor: pageInfo.endCursor
278
+ };
279
+ }
280
+ },
281
+ queryFn: async ({ queryArg, pageParam }, api) => {
282
+ try {
283
+ const { cursor } = pageParam;
284
+ const queryParams = {
285
+ ...queryArg,
286
+ first: LISTS_PER_PAGE,
287
+ after: cursor || void 0
288
+ };
289
+ const result = await api.dispatch(
290
+ getListsGqlApiEnhanced.endpoints.GetListsItemsForReviewSession.initiate(queryParams, {
291
+ forceRefetch: true
292
+ })
293
+ );
294
+ if (result.error) throw result.error;
295
+ return {
296
+ data: result.data || {
297
+ lists: [],
298
+ pageInfo: {
299
+ hasNextPage: false,
300
+ endCursor: null,
301
+ startCursor: null,
302
+ hasPreviousPage: false
303
+ }
304
+ }
305
+ };
306
+ } catch (e) {
307
+ console.error("Error in getListsInfinite queryFn:", e);
308
+ return { error: { status: "FETCH_ERROR", error: e.message } };
309
+ }
310
+ },
311
+ providesTags: (result) => [
312
+ { type: "entityList", id: "LIST" },
313
+ ...((result == null ? void 0 : result.pages.flatMap((page) => page.lists)) || []).map((list) => ({
314
+ type: "entityList",
315
+ id: list.id
316
+ }))
317
+ ]
256
318
  })
257
319
  })
258
320
  });
259
321
  const {
260
322
  useGetListsInfiniteInfiniteQuery,
261
323
  useGetListItemsInfiniteInfiniteQuery,
324
+ useGetListsItemsForReviewSessionInfiniteQuery,
325
+ useLazyGetListsQuery,
326
+ useLazyGetListsItemsForReviewSessionQuery,
262
327
  useLazyGetListItemsQuery
263
328
  } = getListsGqlApiInjected;
264
329
  exports.LISTS_PER_PAGE = LISTS_PER_PAGE;
@@ -266,5 +331,8 @@ exports.LIST_ITEMS_PER_PAGE = LIST_ITEMS_PER_PAGE;
266
331
  exports.default = getListsGqlApiInjected;
267
332
  exports.useGetListItemsInfiniteInfiniteQuery = useGetListItemsInfiniteInfiniteQuery;
268
333
  exports.useGetListsInfiniteInfiniteQuery = useGetListsInfiniteInfiniteQuery;
334
+ exports.useGetListsItemsForReviewSessionInfiniteQuery = useGetListsItemsForReviewSessionInfiniteQuery;
269
335
  exports.useLazyGetListItemsQuery = useLazyGetListItemsQuery;
336
+ exports.useLazyGetListsItemsForReviewSessionQuery = useLazyGetListsItemsForReviewSessionQuery;
337
+ exports.useLazyGetListsQuery = useLazyGetListsQuery;
270
338
  //# sourceMappingURL=getLists.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getLists.cjs.js","sources":["../../../../../../src/api/queries/entityLists/getLists.ts"],"sourcesContent":["import { gqlApi } from '@shared/api/generated'\nimport {\n FetchBaseQueryError,\n DefinitionsFromApi,\n OverrideResultType,\n TagTypesFromApi,\n} from '@reduxjs/toolkit/query'\nimport type {\n GetListItemsQuery,\n GetListItemsQueryVariables,\n GetListsQuery,\n GetListsQueryVariables,\n} from '@shared/api'\nimport { parseAllAttribs } from '../overview'\nimport { PubSub } from '@shared/util'\nimport {\n GetListItemsResult,\n GetListsResult,\n ListItemMessage,\n ListItemsPageParam,\n ListsPageParam,\n} from './types'\n\n// GRAPHQL API (getLists and getListItems)\n// Define the LISTS_PER_PAGE constant for pagination\nexport const LISTS_PER_PAGE = 500\nexport const LIST_ITEMS_PER_PAGE = 100\n\ntype Definitions = DefinitionsFromApi<typeof gqlApi>\ntype TagTypes = TagTypesFromApi<typeof gqlApi>\n// update the definitions to include the new types\ntype UpdatedDefinitions = Omit<Definitions, 'GetLists' | 'GetListItems'> & {\n GetLists: OverrideResultType<Definitions['GetLists'], GetListsResult>\n GetListItems: OverrideResultType<Definitions['GetListItems'], GetListItemsResult>\n}\n\nconst getListsGqlApiEnhanced = gqlApi.enhanceEndpoints<TagTypes, UpdatedDefinitions>({\n endpoints: {\n GetLists: {\n transformResponse: (response: GetListsQuery): GetListsResult => {\n return {\n // @ts-expect-error - entityType is string\n lists: response.project.entityLists.edges.map((edge) => edge.node),\n pageInfo: response.project.entityLists.pageInfo,\n }\n },\n },\n GetListItems: {\n transformResponse: (response: GetListItemsQuery): GetListItemsResult => {\n return {\n items: response.project.entityLists.edges.flatMap((listEdge) =>\n listEdge.node.items.edges.map(({ node, ...edge }) => {\n return {\n ...node,\n ...edge,\n attrib: parseAllAttribs(edge.allAttrib),\n } as GetListItemsResult['items'][number]\n }),\n ),\n pageInfo: response.project.entityLists.edges[0].node.items.pageInfo,\n }\n },\n },\n },\n})\n\nconst getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({\n endpoints: (build) => ({\n getListsInfinite: build.infiniteQuery<\n GetListsResult,\n Omit<GetListsQueryVariables, 'first' | 'after' | 'before'>,\n ListsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams = {\n ...queryArg,\n first: LISTS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetLists.initiate(queryParams, { forceRefetch: true }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n lists: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result) => [\n { type: 'entityList', id: 'LIST' },\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.id,\n })),\n ],\n async onCacheEntryAdded(\n _args,\n { cacheDataLoaded, cacheEntryRemoved, dispatch, updateCachedData },\n ) {\n let token\n try {\n // wait for the initial query to resolve before proceeding\n await cacheDataLoaded\n\n const handlePubSub = (topic: string, message: ListItemMessage) => {\n if (topic !== 'entity_list.changed') return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n\n // We have all the data we need to update the cache\n updateCachedData((draft) => {\n const list = draft.pages.flatMap((page) => page.lists).find((l) => l.id === id)\n if (!list) return\n const newList = {\n ...list,\n label: summary.label,\n entityType: summary.entity_type,\n entityListType: summary.entity_list_type,\n count: summary.count,\n }\n\n Object.assign(list, newList)\n })\n // NOTE: We have to invalidate here as we don't know if other fields are updated not included in the updateCachedData\n // invalidates lists list cache\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityList', id: `LIST` }]))\n }\n\n // sub to websocket topic\n token = PubSub.subscribe('entity_list.changed', handlePubSub)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n },\n }),\n getListItemsInfinite: build.infiniteQuery<\n GetListItemsResult,\n Omit<GetListItemsQueryVariables, 'first' | 'after' | 'before' | 'last'> & { desc?: boolean },\n ListItemsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { sortBy, desc, ...rest } = queryArg\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams: GetListItemsQueryVariables = {\n ...rest,\n first: LIST_ITEMS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Add cursor-based pagination\n queryParams.after = cursor || undefined\n queryParams.first = LIST_ITEMS_PER_PAGE\n\n if (sortBy) {\n queryParams.sortBy = sortBy\n if (desc) {\n queryParams.before = cursor || undefined\n queryParams.after = undefined\n queryParams.last = LIST_ITEMS_PER_PAGE\n queryParams.first = undefined\n }\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetListItems.initiate(queryParams, {\n forceRefetch: true,\n }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n items: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result, _e, { listId, projectName }) => [\n { type: 'entityListItem', id: 'LIST' },\n { type: 'entityListItem', id: listId },\n { type: 'entityListItem', id: projectName },\n ...(result?.pages.flatMap((page) => page.items) || [])\n .filter((i) => !!i)\n .flatMap((item) => [\n {\n type: 'entityListItem',\n id: item.id,\n },\n {\n type: 'entityListItem',\n id: item.entityId,\n },\n ]),\n ],\n async onCacheEntryAdded(_args, { cacheDataLoaded, cacheEntryRemoved, dispatch }) {\n let token, token2\n try {\n // wait for the initial query to resolve before proceeding\n const cache = await cacheDataLoaded\n const pages = cache.data.pages\n const items = pages.flatMap((page) => page.items)\n // get entityType of first item\n const entityType = items[0]?.entityType\n\n const listTopic = `entity_list.changed`\n const entityTypeTopic = `entity.${entityType}`\n\n const invalidateListItems = (id: string) => {\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityListItem', id: id }]))\n }\n\n const handleListMessage = (topic: string, message: ListItemMessage) => {\n if (topic !== listTopic) return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n invalidateListItems(id)\n }\n\n const handleEntityMessage = (topic: string, message: ListItemMessage) => {\n if (!topic.startsWith(entityTypeTopic)) return\n const summary = message.summary\n const id = summary.entityId\n // check for id\n if (!id) return\n invalidateListItems(id)\n }\n\n // sub to websocket topic\n token = PubSub.subscribe(listTopic, handleListMessage)\n if (entityType) token2 = PubSub.subscribe(entityTypeTopic, handleEntityMessage)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n PubSub.unsubscribe(token2)\n },\n }),\n }),\n})\n\nexport default getListsGqlApiInjected\n\nexport const {\n useGetListsInfiniteInfiniteQuery,\n useGetListItemsInfiniteInfiniteQuery,\n useLazyGetListItemsQuery,\n} = getListsGqlApiInjected\n"],"names":["gqlApi","parseAllAttribs","PubSub"],"mappings":"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"}
1
+ {"version":3,"file":"getLists.cjs.js","sources":["../../../../../../src/api/queries/entityLists/getLists.ts"],"sourcesContent":["import { gqlApi } from '@shared/api/generated'\nimport {\n FetchBaseQueryError,\n DefinitionsFromApi,\n OverrideResultType,\n TagTypesFromApi,\n} from '@reduxjs/toolkit/query'\nimport type {\n GetListItemsQuery,\n GetListItemsQueryVariables,\n GetListsItemsForReviewSessionQuery,\n GetListsItemsForReviewSessionResult,\n GetListsQuery,\n GetListsQueryVariables,\n} from '@shared/api'\nimport { parseAllAttribs } from '../overview'\nimport { PubSub } from '@shared/util'\nimport {\n GetListItemsResult,\n GetListsResult,\n ListItemMessage,\n ListItemsPageParam,\n ListsPageParam,\n} from './types'\n\n// GRAPHQL API (getLists and getListItems)\n// Define the LISTS_PER_PAGE constant for pagination\nexport const LISTS_PER_PAGE = 500\nexport const LIST_ITEMS_PER_PAGE = 100\n\ntype Definitions = DefinitionsFromApi<typeof gqlApi>\ntype TagTypes = TagTypesFromApi<typeof gqlApi>\n// update the definitions to include the new types\ntype UpdatedDefinitions = Omit<Definitions, 'GetLists' | 'GetListItems'> & {\n GetLists: OverrideResultType<Definitions['GetLists'], GetListsResult>\n GetListItems: OverrideResultType<Definitions['GetListItems'], GetListItemsResult>\n GetListsItemsForReviewSession: OverrideResultType<\n Definitions['GetListsItemsForReviewSession'],\n GetListsItemsForReviewSessionResult\n >\n}\n\nconst getListsGqlApiEnhanced = gqlApi.enhanceEndpoints<TagTypes, UpdatedDefinitions>({\n endpoints: {\n GetLists: {\n transformResponse: (response: GetListsQuery): GetListsResult => {\n return {\n // @ts-expect-error - entityType is string\n lists: response.project.entityLists.edges.map((edge) => edge.node),\n pageInfo: response.project.entityLists.pageInfo,\n }\n },\n },\n GetListItems: {\n transformResponse: (response: GetListItemsQuery): GetListItemsResult => {\n return {\n items: response.project.entityLists.edges.flatMap((listEdge) =>\n listEdge.node.items.edges.map(({ node, ...edge }) => {\n return {\n ...node,\n ...edge,\n attrib: parseAllAttribs(edge.allAttrib),\n } as GetListItemsResult['items'][number]\n }),\n ),\n pageInfo: response.project.entityLists.edges[0].node.items.pageInfo,\n }\n },\n },\n GetListsItemsForReviewSession: {\n transformResponse: (\n response: GetListsItemsForReviewSessionQuery,\n ): GetListsItemsForReviewSessionResult => {\n return {\n lists: response.project.entityLists.edges.map((edge) => edge.node),\n pageInfo: response.project.entityLists.pageInfo,\n }\n },\n },\n },\n})\n\nconst getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({\n endpoints: (build) => ({\n getListsInfinite: build.infiniteQuery<\n GetListsResult,\n Omit<GetListsQueryVariables, 'first' | 'after' | 'before'>,\n ListsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams = {\n ...queryArg,\n first: LISTS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetLists.initiate(queryParams, { forceRefetch: true }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n lists: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result) => [\n { type: 'entityList', id: 'LIST' },\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.id,\n })),\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.entityListType,\n })),\n ],\n async onCacheEntryAdded(\n _args,\n { cacheDataLoaded, cacheEntryRemoved, dispatch, updateCachedData },\n ) {\n let token\n try {\n // wait for the initial query to resolve before proceeding\n await cacheDataLoaded\n\n const handlePubSub = (topic: string, message: ListItemMessage) => {\n if (topic !== 'entity_list.changed') return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n\n // We have all the data we need to update the cache\n updateCachedData((draft) => {\n const list = draft.pages.flatMap((page) => page.lists).find((l) => l.id === id)\n if (!list) return\n const newList = {\n ...list,\n label: summary.label,\n entityType: summary.entity_type,\n entityListType: summary.entity_list_type,\n count: summary.count,\n }\n\n Object.assign(list, newList)\n })\n // NOTE: We have to invalidate here as we don't know if other fields are updated not included in the updateCachedData\n // invalidates lists list cache\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityList', id: `LIST` }]))\n }\n\n // sub to websocket topic\n token = PubSub.subscribe('entity_list.changed', handlePubSub)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n },\n }),\n getListItemsInfinite: build.infiniteQuery<\n GetListItemsResult,\n Omit<GetListItemsQueryVariables, 'first' | 'after' | 'before' | 'last'> & { desc?: boolean },\n ListItemsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { sortBy, desc, ...rest } = queryArg\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams: GetListItemsQueryVariables = {\n ...rest,\n first: LIST_ITEMS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Add cursor-based pagination\n queryParams.after = cursor || undefined\n queryParams.first = LIST_ITEMS_PER_PAGE\n\n if (sortBy) {\n queryParams.sortBy = sortBy\n if (desc) {\n queryParams.before = cursor || undefined\n queryParams.after = undefined\n queryParams.last = LIST_ITEMS_PER_PAGE\n queryParams.first = undefined\n }\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetListItems.initiate(queryParams, {\n forceRefetch: true,\n }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n items: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result, _e, { listId, projectName }) => [\n { type: 'entityListItem', id: 'LIST' },\n { type: 'entityListItem', id: listId },\n { type: 'entityListItem', id: projectName },\n ...(result?.pages.flatMap((page) => page.items) || [])\n .filter((i) => !!i)\n .flatMap((item) => [\n {\n type: 'entityListItem',\n id: item.id,\n },\n {\n type: 'entityListItem',\n id: item.entityId,\n },\n ]),\n ],\n async onCacheEntryAdded(_args, { cacheDataLoaded, cacheEntryRemoved, dispatch }) {\n let token, token2\n try {\n // wait for the initial query to resolve before proceeding\n const cache = await cacheDataLoaded\n const pages = cache.data.pages\n const items = pages.flatMap((page) => page.items)\n // get entityType of first item\n const entityType = items[0]?.entityType\n\n const listTopic = `entity_list.changed`\n const entityTypeTopic = `entity.${entityType}`\n\n const invalidateListItems = (id: string) => {\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityListItem', id: id }]))\n }\n\n const handleListMessage = (topic: string, message: ListItemMessage) => {\n if (topic !== listTopic) return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n invalidateListItems(id)\n }\n\n const handleEntityMessage = (topic: string, message: ListItemMessage) => {\n if (!topic.startsWith(entityTypeTopic)) return\n const summary = message.summary\n const id = summary.entityId\n // check for id\n if (!id) return\n invalidateListItems(id)\n }\n\n // sub to websocket topic\n token = PubSub.subscribe(listTopic, handleListMessage)\n if (entityType) token2 = PubSub.subscribe(entityTypeTopic, handleEntityMessage)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n PubSub.unsubscribe(token2)\n },\n }),\n getListsItemsForReviewSession: build.infiniteQuery<\n GetListsItemsForReviewSessionResult,\n Omit<GetListsQueryVariables, 'first' | 'after' | 'before' | 'filter'>,\n ListsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams = {\n ...queryArg,\n first: LISTS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetListsItemsForReviewSession.initiate(queryParams, {\n forceRefetch: true,\n }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n lists: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result) => [\n { type: 'entityList', id: 'LIST' },\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.id,\n })),\n ],\n }),\n }),\n})\n\nexport default getListsGqlApiInjected\n\nexport const {\n useGetListsInfiniteInfiniteQuery,\n useGetListItemsInfiniteInfiniteQuery,\n useGetListsItemsForReviewSessionInfiniteQuery,\n useLazyGetListsQuery,\n useLazyGetListsItemsForReviewSessionQuery,\n useLazyGetListItemsQuery,\n} = getListsGqlApiInjected\n"],"names":["gqlApi","parseAllAttribs","PubSub"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BO,MAAM,iBAAiB;AACvB,MAAM,sBAAsB;AAcnC,MAAM,yBAAyBA,YAAO,iBAA+C;AAAA,EACnF,WAAW;AAAA,IACT,UAAU;AAAA,MACR,mBAAmB,CAAC,aAA4C;AACvD,eAAA;AAAA;AAAA,UAEL,OAAO,SAAS,QAAQ,YAAY,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI;AAAA,UACjE,UAAU,SAAS,QAAQ,YAAY;AAAA,QACzC;AAAA,MAAA;AAAA,IAEJ;AAAA,IACA,cAAc;AAAA,MACZ,mBAAmB,CAAC,aAAoD;AAC/D,eAAA;AAAA,UACL,OAAO,SAAS,QAAQ,YAAY,MAAM;AAAA,YAAQ,CAAC,aACjD,SAAS,KAAK,MAAM,MAAM,IAAI,CAAC,EAAE,MAAM,GAAG,WAAW;AAC5C,qBAAA;AAAA,gBACL,GAAG;AAAA,gBACH,GAAG;AAAA,gBACH,QAAQC,YAAAA,gBAAgB,KAAK,SAAS;AAAA,cACxC;AAAA,YACD,CAAA;AAAA,UACH;AAAA,UACA,UAAU,SAAS,QAAQ,YAAY,MAAM,CAAC,EAAE,KAAK,MAAM;AAAA,QAC7D;AAAA,MAAA;AAAA,IAEJ;AAAA,IACA,+BAA+B;AAAA,MAC7B,mBAAmB,CACjB,aACwC;AACjC,eAAA;AAAA,UACL,OAAO,SAAS,QAAQ,YAAY,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI;AAAA,UACjE,UAAU,SAAS,QAAQ,YAAY;AAAA,QACzC;AAAA,MAAA;AAAA,IACF;AAAA,EACF;AAEJ,CAAC;AAEK,MAAA,yBAAyB,uBAAuB,gBAAgB;AAAA,EACpE,WAAW,CAAC,WAAW;AAAA,IACrB,kBAAkB,MAAM,cAItB;AAAA,MACA,sBAAsB;AAAA,QACpB,kBAAkB,EAAE,QAAQ,GAAG;AAAA,QAC/B,kBAAkB,CAAC,aAAa;AACxB,gBAAA,EAAE,aAAa;AACrB,cAAI,CAAC,SAAS,eAAe,CAAC,SAAS,UAAkB,QAAA;AAElD,iBAAA;AAAA,YACL,QAAQ,SAAS;AAAA,UACnB;AAAA,QAAA;AAAA,MAEJ;AAAA,MACA,SAAS,OAAO,EAAE,UAAU,UAAA,GAAa,QAAQ;AAC3C,YAAA;AACI,gBAAA,EAAE,WAAW;AAGnB,gBAAM,cAAc;AAAA,YAClB,GAAG;AAAA,YACH,OAAO;AAAA,YACP,OAAO,UAAU;AAAA,UACnB;AAGM,gBAAA,SAAS,MAAM,IAAI;AAAA,YACvB,uBAAuB,UAAU,SAAS,SAAS,aAAa,EAAE,cAAc,KAAM,CAAA;AAAA,UACxF;AAEI,cAAA,OAAO,MAAO,OAAM,OAAO;AAExB,iBAAA;AAAA,YACL,MAAM,OAAO,QAAQ;AAAA,cACnB,OAAO,CAAC;AAAA,cACR,UAAU;AAAA,gBACR,aAAa;AAAA,gBACb,WAAW;AAAA,gBACX,aAAa;AAAA,gBACb,iBAAiB;AAAA,cAAA;AAAA,YACnB;AAAA,UAEJ;AAAA,iBACO,GAAQ;AACP,kBAAA,MAAM,sCAAsC,CAAC;AAC9C,iBAAA,EAAE,OAAO,EAAE,QAAQ,eAAe,OAAO,EAAE,UAAiC;AAAA,QAAA;AAAA,MAEvF;AAAA,MACA,cAAc,CAAC,WAAW;AAAA,QACxB,EAAE,MAAM,cAAc,IAAI,OAAO;AAAA,QACjC,KAAI,iCAAQ,MAAM,QAAQ,CAAC,SAAS,KAAK,WAAU,CAAA,GAAI,IAAI,CAAC,UAAU;AAAA,UACpE,MAAM;AAAA,UACN,IAAI,KAAK;AAAA,QAAA,EACT;AAAA,QACF,KAAI,iCAAQ,MAAM,QAAQ,CAAC,SAAS,KAAK,WAAU,CAAA,GAAI,IAAI,CAAC,UAAU;AAAA,UACpE,MAAM;AAAA,UACN,IAAI,KAAK;AAAA,QAAA,EACT;AAAA,MACJ;AAAA,MACA,MAAM,kBACJ,OACA,EAAE,iBAAiB,mBAAmB,UAAU,oBAChD;AACI,YAAA;AACA,YAAA;AAEI,gBAAA;AAEA,gBAAA,eAAe,CAAC,OAAe,YAA6B;AAChE,gBAAI,UAAU,sBAAuB;AACrC,kBAAM,UAAU,QAAQ;AACxB,kBAAM,KAAK,QAAQ;AACnB,gBAAI,CAAC,GAAI;AAGT,6BAAiB,CAAC,UAAU;AAC1B,oBAAM,OAAO,MAAM,MAAM,QAAQ,CAAC,SAAS,KAAK,KAAK,EAAE,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE;AAC9E,kBAAI,CAAC,KAAM;AACX,oBAAM,UAAU;AAAA,gBACd,GAAG;AAAA,gBACH,OAAO,QAAQ;AAAA,gBACf,YAAY,QAAQ;AAAA,gBACpB,gBAAgB,QAAQ;AAAA,gBACxB,OAAO,QAAQ;AAAA,cACjB;AAEO,qBAAA,OAAO,MAAM,OAAO;AAAA,YAAA,CAC5B;AAGQ,qBAAAD,QAAA,IAAO,KAAK,eAAe,CAAC,EAAE,MAAM,cAAc,IAAI,OAAA,CAAQ,CAAC,CAAC;AAAA,UAC3E;AAGQ,kBAAAE,OAAO,UAAU,uBAAuB,YAAY;AAAA,QAAA,QACtD;AAAA,QAAA;AAKF,cAAA;AAENA,eAAO,YAAY,KAAK;AAAA,MAAA;AAAA,IAC1B,CACD;AAAA,IACD,sBAAsB,MAAM,cAI1B;AAAA,MACA,sBAAsB;AAAA,QACpB,kBAAkB,EAAE,QAAQ,GAAG;AAAA,QAC/B,kBAAkB,CAAC,aAAa;AACxB,gBAAA,EAAE,aAAa;AACrB,cAAI,CAAC,SAAS,eAAe,CAAC,SAAS,UAAkB,QAAA;AAElD,iBAAA;AAAA,YACL,QAAQ,SAAS;AAAA,UACnB;AAAA,QAAA;AAAA,MAEJ;AAAA,MACA,SAAS,OAAO,EAAE,UAAU,UAAA,GAAa,QAAQ;AAC3C,YAAA;AACF,gBAAM,EAAE,QAAQ,MAAM,GAAG,KAAS,IAAA;AAC5B,gBAAA,EAAE,WAAW;AAGnB,gBAAM,cAA0C;AAAA,YAC9C,GAAG;AAAA,YACH,OAAO;AAAA,YACP,OAAO,UAAU;AAAA,UACnB;AAGA,sBAAY,QAAQ,UAAU;AAC9B,sBAAY,QAAQ;AAEpB,cAAI,QAAQ;AACV,wBAAY,SAAS;AACrB,gBAAI,MAAM;AACR,0BAAY,SAAS,UAAU;AAC/B,0BAAY,QAAQ;AACpB,0BAAY,OAAO;AACnB,0BAAY,QAAQ;AAAA,YAAA;AAAA,UACtB;AAII,gBAAA,SAAS,MAAM,IAAI;AAAA,YACvB,uBAAuB,UAAU,aAAa,SAAS,aAAa;AAAA,cAClE,cAAc;AAAA,YACf,CAAA;AAAA,UACH;AAEI,cAAA,OAAO,MAAO,OAAM,OAAO;AAExB,iBAAA;AAAA,YACL,MAAM,OAAO,QAAQ;AAAA,cACnB,OAAO,CAAC;AAAA,cACR,UAAU;AAAA,gBACR,aAAa;AAAA,gBACb,WAAW;AAAA,gBACX,aAAa;AAAA,gBACb,iBAAiB;AAAA,cAAA;AAAA,YACnB;AAAA,UAEJ;AAAA,iBACO,GAAQ;AACP,kBAAA,MAAM,sCAAsC,CAAC;AAC9C,iBAAA,EAAE,OAAO,EAAE,QAAQ,eAAe,OAAO,EAAE,UAAiC;AAAA,QAAA;AAAA,MAEvF;AAAA,MACA,cAAc,CAAC,QAAQ,IAAI,EAAE,QAAQ,kBAAkB;AAAA,QACrD,EAAE,MAAM,kBAAkB,IAAI,OAAO;AAAA,QACrC,EAAE,MAAM,kBAAkB,IAAI,OAAO;AAAA,QACrC,EAAE,MAAM,kBAAkB,IAAI,YAAY;AAAA,QAC1C,KAAI,iCAAQ,MAAM,QAAQ,CAAC,SAAS,KAAK,WAAU,IAChD,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EACjB,QAAQ,CAAC,SAAS;AAAA,UACjB;AAAA,YACE,MAAM;AAAA,YACN,IAAI,KAAK;AAAA,UACX;AAAA,UACA;AAAA,YACE,MAAM;AAAA,YACN,IAAI,KAAK;AAAA,UAAA;AAAA,QAEZ,CAAA;AAAA,MACL;AAAA,MACA,MAAM,kBAAkB,OAAO,EAAE,iBAAiB,mBAAmB,YAAY;;AAC/E,YAAI,OAAO;AACP,YAAA;AAEF,gBAAM,QAAQ,MAAM;AACd,gBAAA,QAAQ,MAAM,KAAK;AACzB,gBAAM,QAAQ,MAAM,QAAQ,CAAC,SAAS,KAAK,KAAK;AAE1C,gBAAA,cAAa,WAAM,CAAC,MAAP,mBAAU;AAE7B,gBAAM,YAAY;AACZ,gBAAA,kBAAkB,UAAU,UAAU;AAEtC,gBAAA,sBAAsB,CAAC,OAAe;AACjC,qBAAAF,QAAAA,IAAO,KAAK,eAAe,CAAC,EAAE,MAAM,kBAAkB,GAAQ,CAAA,CAAC,CAAC;AAAA,UAC3E;AAEM,gBAAA,oBAAoB,CAAC,OAAe,YAA6B;AACrE,gBAAI,UAAU,UAAW;AACzB,kBAAM,UAAU,QAAQ;AACxB,kBAAM,KAAK,QAAQ;AACnB,gBAAI,CAAC,GAAI;AACT,gCAAoB,EAAE;AAAA,UACxB;AAEM,gBAAA,sBAAsB,CAAC,OAAe,YAA6B;AACvE,gBAAI,CAAC,MAAM,WAAW,eAAe,EAAG;AACxC,kBAAM,UAAU,QAAQ;AACxB,kBAAM,KAAK,QAAQ;AAEnB,gBAAI,CAAC,GAAI;AACT,gCAAoB,EAAE;AAAA,UACxB;AAGQ,kBAAAE,OAAO,UAAU,WAAW,iBAAiB;AACrD,cAAI,WAAY,UAASA,OAAO,UAAU,iBAAiB,mBAAmB;AAAA,QAAA,QACxE;AAAA,QAAA;AAKF,cAAA;AAENA,eAAO,YAAY,KAAK;AACxBA,eAAO,YAAY,MAAM;AAAA,MAAA;AAAA,IAC3B,CACD;AAAA,IACD,+BAA+B,MAAM,cAInC;AAAA,MACA,sBAAsB;AAAA,QACpB,kBAAkB,EAAE,QAAQ,GAAG;AAAA,QAC/B,kBAAkB,CAAC,aAAa;AACxB,gBAAA,EAAE,aAAa;AACrB,cAAI,CAAC,SAAS,eAAe,CAAC,SAAS,UAAkB,QAAA;AAElD,iBAAA;AAAA,YACL,QAAQ,SAAS;AAAA,UACnB;AAAA,QAAA;AAAA,MAEJ;AAAA,MACA,SAAS,OAAO,EAAE,UAAU,UAAA,GAAa,QAAQ;AAC3C,YAAA;AACI,gBAAA,EAAE,WAAW;AAGnB,gBAAM,cAAc;AAAA,YAClB,GAAG;AAAA,YACH,OAAO;AAAA,YACP,OAAO,UAAU;AAAA,UACnB;AAGM,gBAAA,SAAS,MAAM,IAAI;AAAA,YACvB,uBAAuB,UAAU,8BAA8B,SAAS,aAAa;AAAA,cACnF,cAAc;AAAA,YACf,CAAA;AAAA,UACH;AAEI,cAAA,OAAO,MAAO,OAAM,OAAO;AAExB,iBAAA;AAAA,YACL,MAAM,OAAO,QAAQ;AAAA,cACnB,OAAO,CAAC;AAAA,cACR,UAAU;AAAA,gBACR,aAAa;AAAA,gBACb,WAAW;AAAA,gBACX,aAAa;AAAA,gBACb,iBAAiB;AAAA,cAAA;AAAA,YACnB;AAAA,UAEJ;AAAA,iBACO,GAAQ;AACP,kBAAA,MAAM,sCAAsC,CAAC;AAC9C,iBAAA,EAAE,OAAO,EAAE,QAAQ,eAAe,OAAO,EAAE,UAAiC;AAAA,QAAA;AAAA,MAEvF;AAAA,MACA,cAAc,CAAC,WAAW;AAAA,QACxB,EAAE,MAAM,cAAc,IAAI,OAAO;AAAA,QACjC,KAAI,iCAAQ,MAAM,QAAQ,CAAC,SAAS,KAAK,WAAU,CAAA,GAAI,IAAI,CAAC,UAAU;AAAA,UACpE,MAAM;AAAA,UACN,IAAI,KAAK;AAAA,QAAA,EACT;AAAA,MAAA;AAAA,IAEL,CAAA;AAAA,EACH;AACF,CAAC;AAIY,MAAA;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,IAAI;;;;;;;;;;"}
@@ -34,6 +34,7 @@ import "../../generated/versions.es.js";
34
34
  import "../../generated/workfiles.es.js";
35
35
  import "../../generated/ynputCloud.es.js";
36
36
  import "../../generated/grouping.es.js";
37
+ import "../../generated/views.es.js";
37
38
  import { parseAllAttribs } from "../overview/getOverview.es.js";
38
39
  import "../overview/updateOverview.es.js";
39
40
  import "lodash";
@@ -67,6 +68,14 @@ const getListsGqlApiEnhanced = injectedRtkApi.enhanceEndpoints({
67
68
  pageInfo: response.project.entityLists.edges[0].node.items.pageInfo
68
69
  };
69
70
  }
71
+ },
72
+ GetListsItemsForReviewSession: {
73
+ transformResponse: (response) => {
74
+ return {
75
+ lists: response.project.entityLists.edges.map((edge) => edge.node),
76
+ pageInfo: response.project.entityLists.pageInfo
77
+ };
78
+ }
70
79
  }
71
80
  }
72
81
  });
@@ -116,6 +125,10 @@ const getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({
116
125
  ...((result == null ? void 0 : result.pages.flatMap((page) => page.lists)) || []).map((list) => ({
117
126
  type: "entityList",
118
127
  id: list.id
128
+ })),
129
+ ...((result == null ? void 0 : result.pages.flatMap((page) => page.lists)) || []).map((list) => ({
130
+ type: "entityList",
131
+ id: list.entityListType
119
132
  }))
120
133
  ],
121
134
  async onCacheEntryAdded(_args, { cacheDataLoaded, cacheEntryRemoved, dispatch, updateCachedData }) {
@@ -251,12 +264,64 @@ const getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({
251
264
  PubSub.unsubscribe(token);
252
265
  PubSub.unsubscribe(token2);
253
266
  }
267
+ }),
268
+ getListsItemsForReviewSession: build.infiniteQuery({
269
+ infiniteQueryOptions: {
270
+ initialPageParam: { cursor: "" },
271
+ getNextPageParam: (lastPage) => {
272
+ const { pageInfo } = lastPage;
273
+ if (!pageInfo.hasNextPage || !pageInfo.endCursor) return void 0;
274
+ return {
275
+ cursor: pageInfo.endCursor
276
+ };
277
+ }
278
+ },
279
+ queryFn: async ({ queryArg, pageParam }, api) => {
280
+ try {
281
+ const { cursor } = pageParam;
282
+ const queryParams = {
283
+ ...queryArg,
284
+ first: LISTS_PER_PAGE,
285
+ after: cursor || void 0
286
+ };
287
+ const result = await api.dispatch(
288
+ getListsGqlApiEnhanced.endpoints.GetListsItemsForReviewSession.initiate(queryParams, {
289
+ forceRefetch: true
290
+ })
291
+ );
292
+ if (result.error) throw result.error;
293
+ return {
294
+ data: result.data || {
295
+ lists: [],
296
+ pageInfo: {
297
+ hasNextPage: false,
298
+ endCursor: null,
299
+ startCursor: null,
300
+ hasPreviousPage: false
301
+ }
302
+ }
303
+ };
304
+ } catch (e) {
305
+ console.error("Error in getListsInfinite queryFn:", e);
306
+ return { error: { status: "FETCH_ERROR", error: e.message } };
307
+ }
308
+ },
309
+ providesTags: (result) => [
310
+ { type: "entityList", id: "LIST" },
311
+ ...((result == null ? void 0 : result.pages.flatMap((page) => page.lists)) || []).map((list) => ({
312
+ type: "entityList",
313
+ id: list.id
314
+ }))
315
+ ]
254
316
  })
255
317
  })
256
318
  });
257
319
  const {
258
320
  useGetListsInfiniteInfiniteQuery,
259
321
  useGetListItemsInfiniteInfiniteQuery,
322
+ useGetListsItemsForReviewSessionInfiniteQuery,
323
+ useLazyGetListsQuery,
324
+ useLazyGetListsItemsForReviewSessionQuery,
260
325
  useLazyGetListItemsQuery
261
326
  } = getListsGqlApiInjected;
262
327
  export {
@@ -265,6 +330,9 @@ export {
265
330
  getListsGqlApiInjected as default,
266
331
  useGetListItemsInfiniteInfiniteQuery,
267
332
  useGetListsInfiniteInfiniteQuery,
268
- useLazyGetListItemsQuery
333
+ useGetListsItemsForReviewSessionInfiniteQuery,
334
+ useLazyGetListItemsQuery,
335
+ useLazyGetListsItemsForReviewSessionQuery,
336
+ useLazyGetListsQuery
269
337
  };
270
338
  //# sourceMappingURL=getLists.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getLists.es.js","sources":["../../../../../../src/api/queries/entityLists/getLists.ts"],"sourcesContent":["import { gqlApi } from '@shared/api/generated'\nimport {\n FetchBaseQueryError,\n DefinitionsFromApi,\n OverrideResultType,\n TagTypesFromApi,\n} from '@reduxjs/toolkit/query'\nimport type {\n GetListItemsQuery,\n GetListItemsQueryVariables,\n GetListsQuery,\n GetListsQueryVariables,\n} from '@shared/api'\nimport { parseAllAttribs } from '../overview'\nimport { PubSub } from '@shared/util'\nimport {\n GetListItemsResult,\n GetListsResult,\n ListItemMessage,\n ListItemsPageParam,\n ListsPageParam,\n} from './types'\n\n// GRAPHQL API (getLists and getListItems)\n// Define the LISTS_PER_PAGE constant for pagination\nexport const LISTS_PER_PAGE = 500\nexport const LIST_ITEMS_PER_PAGE = 100\n\ntype Definitions = DefinitionsFromApi<typeof gqlApi>\ntype TagTypes = TagTypesFromApi<typeof gqlApi>\n// update the definitions to include the new types\ntype UpdatedDefinitions = Omit<Definitions, 'GetLists' | 'GetListItems'> & {\n GetLists: OverrideResultType<Definitions['GetLists'], GetListsResult>\n GetListItems: OverrideResultType<Definitions['GetListItems'], GetListItemsResult>\n}\n\nconst getListsGqlApiEnhanced = gqlApi.enhanceEndpoints<TagTypes, UpdatedDefinitions>({\n endpoints: {\n GetLists: {\n transformResponse: (response: GetListsQuery): GetListsResult => {\n return {\n // @ts-expect-error - entityType is string\n lists: response.project.entityLists.edges.map((edge) => edge.node),\n pageInfo: response.project.entityLists.pageInfo,\n }\n },\n },\n GetListItems: {\n transformResponse: (response: GetListItemsQuery): GetListItemsResult => {\n return {\n items: response.project.entityLists.edges.flatMap((listEdge) =>\n listEdge.node.items.edges.map(({ node, ...edge }) => {\n return {\n ...node,\n ...edge,\n attrib: parseAllAttribs(edge.allAttrib),\n } as GetListItemsResult['items'][number]\n }),\n ),\n pageInfo: response.project.entityLists.edges[0].node.items.pageInfo,\n }\n },\n },\n },\n})\n\nconst getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({\n endpoints: (build) => ({\n getListsInfinite: build.infiniteQuery<\n GetListsResult,\n Omit<GetListsQueryVariables, 'first' | 'after' | 'before'>,\n ListsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams = {\n ...queryArg,\n first: LISTS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetLists.initiate(queryParams, { forceRefetch: true }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n lists: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result) => [\n { type: 'entityList', id: 'LIST' },\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.id,\n })),\n ],\n async onCacheEntryAdded(\n _args,\n { cacheDataLoaded, cacheEntryRemoved, dispatch, updateCachedData },\n ) {\n let token\n try {\n // wait for the initial query to resolve before proceeding\n await cacheDataLoaded\n\n const handlePubSub = (topic: string, message: ListItemMessage) => {\n if (topic !== 'entity_list.changed') return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n\n // We have all the data we need to update the cache\n updateCachedData((draft) => {\n const list = draft.pages.flatMap((page) => page.lists).find((l) => l.id === id)\n if (!list) return\n const newList = {\n ...list,\n label: summary.label,\n entityType: summary.entity_type,\n entityListType: summary.entity_list_type,\n count: summary.count,\n }\n\n Object.assign(list, newList)\n })\n // NOTE: We have to invalidate here as we don't know if other fields are updated not included in the updateCachedData\n // invalidates lists list cache\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityList', id: `LIST` }]))\n }\n\n // sub to websocket topic\n token = PubSub.subscribe('entity_list.changed', handlePubSub)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n },\n }),\n getListItemsInfinite: build.infiniteQuery<\n GetListItemsResult,\n Omit<GetListItemsQueryVariables, 'first' | 'after' | 'before' | 'last'> & { desc?: boolean },\n ListItemsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { sortBy, desc, ...rest } = queryArg\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams: GetListItemsQueryVariables = {\n ...rest,\n first: LIST_ITEMS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Add cursor-based pagination\n queryParams.after = cursor || undefined\n queryParams.first = LIST_ITEMS_PER_PAGE\n\n if (sortBy) {\n queryParams.sortBy = sortBy\n if (desc) {\n queryParams.before = cursor || undefined\n queryParams.after = undefined\n queryParams.last = LIST_ITEMS_PER_PAGE\n queryParams.first = undefined\n }\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetListItems.initiate(queryParams, {\n forceRefetch: true,\n }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n items: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result, _e, { listId, projectName }) => [\n { type: 'entityListItem', id: 'LIST' },\n { type: 'entityListItem', id: listId },\n { type: 'entityListItem', id: projectName },\n ...(result?.pages.flatMap((page) => page.items) || [])\n .filter((i) => !!i)\n .flatMap((item) => [\n {\n type: 'entityListItem',\n id: item.id,\n },\n {\n type: 'entityListItem',\n id: item.entityId,\n },\n ]),\n ],\n async onCacheEntryAdded(_args, { cacheDataLoaded, cacheEntryRemoved, dispatch }) {\n let token, token2\n try {\n // wait for the initial query to resolve before proceeding\n const cache = await cacheDataLoaded\n const pages = cache.data.pages\n const items = pages.flatMap((page) => page.items)\n // get entityType of first item\n const entityType = items[0]?.entityType\n\n const listTopic = `entity_list.changed`\n const entityTypeTopic = `entity.${entityType}`\n\n const invalidateListItems = (id: string) => {\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityListItem', id: id }]))\n }\n\n const handleListMessage = (topic: string, message: ListItemMessage) => {\n if (topic !== listTopic) return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n invalidateListItems(id)\n }\n\n const handleEntityMessage = (topic: string, message: ListItemMessage) => {\n if (!topic.startsWith(entityTypeTopic)) return\n const summary = message.summary\n const id = summary.entityId\n // check for id\n if (!id) return\n invalidateListItems(id)\n }\n\n // sub to websocket topic\n token = PubSub.subscribe(listTopic, handleListMessage)\n if (entityType) token2 = PubSub.subscribe(entityTypeTopic, handleEntityMessage)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n PubSub.unsubscribe(token2)\n },\n }),\n }),\n})\n\nexport default getListsGqlApiInjected\n\nexport const {\n useGetListsInfiniteInfiniteQuery,\n useGetListItemsInfiniteInfiniteQuery,\n useLazyGetListItemsQuery,\n} = getListsGqlApiInjected\n"],"names":["gqlApi"],"mappings":"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"}
1
+ {"version":3,"file":"getLists.es.js","sources":["../../../../../../src/api/queries/entityLists/getLists.ts"],"sourcesContent":["import { gqlApi } from '@shared/api/generated'\nimport {\n FetchBaseQueryError,\n DefinitionsFromApi,\n OverrideResultType,\n TagTypesFromApi,\n} from '@reduxjs/toolkit/query'\nimport type {\n GetListItemsQuery,\n GetListItemsQueryVariables,\n GetListsItemsForReviewSessionQuery,\n GetListsItemsForReviewSessionResult,\n GetListsQuery,\n GetListsQueryVariables,\n} from '@shared/api'\nimport { parseAllAttribs } from '../overview'\nimport { PubSub } from '@shared/util'\nimport {\n GetListItemsResult,\n GetListsResult,\n ListItemMessage,\n ListItemsPageParam,\n ListsPageParam,\n} from './types'\n\n// GRAPHQL API (getLists and getListItems)\n// Define the LISTS_PER_PAGE constant for pagination\nexport const LISTS_PER_PAGE = 500\nexport const LIST_ITEMS_PER_PAGE = 100\n\ntype Definitions = DefinitionsFromApi<typeof gqlApi>\ntype TagTypes = TagTypesFromApi<typeof gqlApi>\n// update the definitions to include the new types\ntype UpdatedDefinitions = Omit<Definitions, 'GetLists' | 'GetListItems'> & {\n GetLists: OverrideResultType<Definitions['GetLists'], GetListsResult>\n GetListItems: OverrideResultType<Definitions['GetListItems'], GetListItemsResult>\n GetListsItemsForReviewSession: OverrideResultType<\n Definitions['GetListsItemsForReviewSession'],\n GetListsItemsForReviewSessionResult\n >\n}\n\nconst getListsGqlApiEnhanced = gqlApi.enhanceEndpoints<TagTypes, UpdatedDefinitions>({\n endpoints: {\n GetLists: {\n transformResponse: (response: GetListsQuery): GetListsResult => {\n return {\n // @ts-expect-error - entityType is string\n lists: response.project.entityLists.edges.map((edge) => edge.node),\n pageInfo: response.project.entityLists.pageInfo,\n }\n },\n },\n GetListItems: {\n transformResponse: (response: GetListItemsQuery): GetListItemsResult => {\n return {\n items: response.project.entityLists.edges.flatMap((listEdge) =>\n listEdge.node.items.edges.map(({ node, ...edge }) => {\n return {\n ...node,\n ...edge,\n attrib: parseAllAttribs(edge.allAttrib),\n } as GetListItemsResult['items'][number]\n }),\n ),\n pageInfo: response.project.entityLists.edges[0].node.items.pageInfo,\n }\n },\n },\n GetListsItemsForReviewSession: {\n transformResponse: (\n response: GetListsItemsForReviewSessionQuery,\n ): GetListsItemsForReviewSessionResult => {\n return {\n lists: response.project.entityLists.edges.map((edge) => edge.node),\n pageInfo: response.project.entityLists.pageInfo,\n }\n },\n },\n },\n})\n\nconst getListsGqlApiInjected = getListsGqlApiEnhanced.injectEndpoints({\n endpoints: (build) => ({\n getListsInfinite: build.infiniteQuery<\n GetListsResult,\n Omit<GetListsQueryVariables, 'first' | 'after' | 'before'>,\n ListsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams = {\n ...queryArg,\n first: LISTS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetLists.initiate(queryParams, { forceRefetch: true }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n lists: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result) => [\n { type: 'entityList', id: 'LIST' },\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.id,\n })),\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.entityListType,\n })),\n ],\n async onCacheEntryAdded(\n _args,\n { cacheDataLoaded, cacheEntryRemoved, dispatch, updateCachedData },\n ) {\n let token\n try {\n // wait for the initial query to resolve before proceeding\n await cacheDataLoaded\n\n const handlePubSub = (topic: string, message: ListItemMessage) => {\n if (topic !== 'entity_list.changed') return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n\n // We have all the data we need to update the cache\n updateCachedData((draft) => {\n const list = draft.pages.flatMap((page) => page.lists).find((l) => l.id === id)\n if (!list) return\n const newList = {\n ...list,\n label: summary.label,\n entityType: summary.entity_type,\n entityListType: summary.entity_list_type,\n count: summary.count,\n }\n\n Object.assign(list, newList)\n })\n // NOTE: We have to invalidate here as we don't know if other fields are updated not included in the updateCachedData\n // invalidates lists list cache\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityList', id: `LIST` }]))\n }\n\n // sub to websocket topic\n token = PubSub.subscribe('entity_list.changed', handlePubSub)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n },\n }),\n getListItemsInfinite: build.infiniteQuery<\n GetListItemsResult,\n Omit<GetListItemsQueryVariables, 'first' | 'after' | 'before' | 'last'> & { desc?: boolean },\n ListItemsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { sortBy, desc, ...rest } = queryArg\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams: GetListItemsQueryVariables = {\n ...rest,\n first: LIST_ITEMS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Add cursor-based pagination\n queryParams.after = cursor || undefined\n queryParams.first = LIST_ITEMS_PER_PAGE\n\n if (sortBy) {\n queryParams.sortBy = sortBy\n if (desc) {\n queryParams.before = cursor || undefined\n queryParams.after = undefined\n queryParams.last = LIST_ITEMS_PER_PAGE\n queryParams.first = undefined\n }\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetListItems.initiate(queryParams, {\n forceRefetch: true,\n }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n items: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result, _e, { listId, projectName }) => [\n { type: 'entityListItem', id: 'LIST' },\n { type: 'entityListItem', id: listId },\n { type: 'entityListItem', id: projectName },\n ...(result?.pages.flatMap((page) => page.items) || [])\n .filter((i) => !!i)\n .flatMap((item) => [\n {\n type: 'entityListItem',\n id: item.id,\n },\n {\n type: 'entityListItem',\n id: item.entityId,\n },\n ]),\n ],\n async onCacheEntryAdded(_args, { cacheDataLoaded, cacheEntryRemoved, dispatch }) {\n let token, token2\n try {\n // wait for the initial query to resolve before proceeding\n const cache = await cacheDataLoaded\n const pages = cache.data.pages\n const items = pages.flatMap((page) => page.items)\n // get entityType of first item\n const entityType = items[0]?.entityType\n\n const listTopic = `entity_list.changed`\n const entityTypeTopic = `entity.${entityType}`\n\n const invalidateListItems = (id: string) => {\n dispatch(gqlApi.util.invalidateTags([{ type: 'entityListItem', id: id }]))\n }\n\n const handleListMessage = (topic: string, message: ListItemMessage) => {\n if (topic !== listTopic) return\n const summary = message.summary\n const id = summary.id\n if (!id) return\n invalidateListItems(id)\n }\n\n const handleEntityMessage = (topic: string, message: ListItemMessage) => {\n if (!topic.startsWith(entityTypeTopic)) return\n const summary = message.summary\n const id = summary.entityId\n // check for id\n if (!id) return\n invalidateListItems(id)\n }\n\n // sub to websocket topic\n token = PubSub.subscribe(listTopic, handleListMessage)\n if (entityType) token2 = PubSub.subscribe(entityTypeTopic, handleEntityMessage)\n } catch {\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`,\n // in which case `cacheDataLoaded` will throw\n }\n // cacheEntryRemoved will resolve when the cache subscription is no longer active\n await cacheEntryRemoved\n // perform cleanup steps once the `cacheEntryRemoved` promise resolves\n PubSub.unsubscribe(token)\n PubSub.unsubscribe(token2)\n },\n }),\n getListsItemsForReviewSession: build.infiniteQuery<\n GetListsItemsForReviewSessionResult,\n Omit<GetListsQueryVariables, 'first' | 'after' | 'before' | 'filter'>,\n ListsPageParam\n >({\n infiniteQueryOptions: {\n initialPageParam: { cursor: '' },\n getNextPageParam: (lastPage) => {\n const { pageInfo } = lastPage\n if (!pageInfo.hasNextPage || !pageInfo.endCursor) return undefined\n\n return {\n cursor: pageInfo.endCursor,\n }\n },\n },\n queryFn: async ({ queryArg, pageParam }, api) => {\n try {\n const { cursor } = pageParam\n\n // Build the query parameters for GetLists\n const queryParams = {\n ...queryArg,\n first: LISTS_PER_PAGE,\n after: cursor || undefined,\n }\n\n // Call the existing GetLists endpoint\n const result = await api.dispatch(\n getListsGqlApiEnhanced.endpoints.GetListsItemsForReviewSession.initiate(queryParams, {\n forceRefetch: true,\n }),\n )\n\n if (result.error) throw result.error\n\n return {\n data: result.data || {\n lists: [],\n pageInfo: {\n hasNextPage: false,\n endCursor: null,\n startCursor: null,\n hasPreviousPage: false,\n },\n },\n }\n } catch (e: any) {\n console.error('Error in getListsInfinite queryFn:', e)\n return { error: { status: 'FETCH_ERROR', error: e.message } as FetchBaseQueryError }\n }\n },\n providesTags: (result) => [\n { type: 'entityList', id: 'LIST' },\n ...(result?.pages.flatMap((page) => page.lists) || []).map((list) => ({\n type: 'entityList' as const,\n id: list.id,\n })),\n ],\n }),\n }),\n})\n\nexport default getListsGqlApiInjected\n\nexport const {\n useGetListsInfiniteInfiniteQuery,\n useGetListItemsInfiniteInfiniteQuery,\n useGetListsItemsForReviewSessionInfiniteQuery,\n useLazyGetListsQuery,\n useLazyGetListsItemsForReviewSessionQuery,\n useLazyGetListItemsQuery,\n} = getListsGqlApiInjected\n"],"names":["gqlApi"],"mappings":"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"}
@@ -36,6 +36,7 @@ require("../../generated/versions.cjs.js");
36
36
  require("../../generated/workfiles.cjs.js");
37
37
  require("../../generated/ynputCloud.cjs.js");
38
38
  require("../../generated/grouping.cjs.js");
39
+ require("../../generated/views.cjs.js");
39
40
  const getListsRestApiEnhanced = entityLists.api.enhanceEndpoints({
40
41
  endpoints: {
41
42
  getEntityListAttributesDefinition: {
@@ -1 +1 @@
1
- {"version":3,"file":"getListsAttributes.cjs.js","sources":["../../../../../../src/api/queries/entityLists/getListsAttributes.ts"],"sourcesContent":["import { entityListsApi } from '@shared/api/generated'\n\n// REST API (get list attributes)\nconst getListsRestApiEnhanced = entityListsApi.enhanceEndpoints({\n endpoints: {\n getEntityListAttributesDefinition: {\n providesTags: (result, _e, { listId }) =>\n result\n ? [\n { type: 'entityListAttribute', id: listId },\n ...result.map((a) => ({ type: 'entityListAttribute', id: a.name })),\n ]\n : [{ type: 'entityListAttribute', id: 'LIST' }],\n },\n },\n})\n\nexport const { useGetEntityListAttributesDefinitionQuery } = getListsRestApiEnhanced\nexport default getListsRestApiEnhanced\n"],"names":["entityListsApi"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGM,MAAA,0BAA0BA,gBAAe,iBAAiB;AAAA,EAC9D,WAAW;AAAA,IACT,mCAAmC;AAAA,MACjC,cAAc,CAAC,QAAQ,IAAI,EAAE,OAAA,MAC3B,SACI;AAAA,QACE,EAAE,MAAM,uBAAuB,IAAI,OAAO;AAAA,QAC1C,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAAA,UAEpE,CAAC,EAAE,MAAM,uBAAuB,IAAI,OAAQ,CAAA;AAAA,IAAA;AAAA,EACpD;AAEJ,CAAC;AAEY,MAAA,EAAE,8CAA8C;;;"}
1
+ {"version":3,"file":"getListsAttributes.cjs.js","sources":["../../../../../../src/api/queries/entityLists/getListsAttributes.ts"],"sourcesContent":["import { entityListsApi } from '@shared/api/generated'\n\n// REST API (get list attributes)\nconst getListsRestApiEnhanced = entityListsApi.enhanceEndpoints({\n endpoints: {\n getEntityListAttributesDefinition: {\n providesTags: (result, _e, { listId }) =>\n result\n ? [\n { type: 'entityListAttribute', id: listId },\n ...result.map((a) => ({ type: 'entityListAttribute', id: a.name })),\n ]\n : [{ type: 'entityListAttribute', id: 'LIST' }],\n },\n },\n})\n\nexport const { useGetEntityListAttributesDefinitionQuery } = getListsRestApiEnhanced\nexport default getListsRestApiEnhanced\n"],"names":["entityListsApi"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGM,MAAA,0BAA0BA,gBAAe,iBAAiB;AAAA,EAC9D,WAAW;AAAA,IACT,mCAAmC;AAAA,MACjC,cAAc,CAAC,QAAQ,IAAI,EAAE,OAAA,MAC3B,SACI;AAAA,QACE,EAAE,MAAM,uBAAuB,IAAI,OAAO;AAAA,QAC1C,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAAA,UAEpE,CAAC,EAAE,MAAM,uBAAuB,IAAI,OAAQ,CAAA;AAAA,IAAA;AAAA,EACpD;AAEJ,CAAC;AAEY,MAAA,EAAE,8CAA8C;;;"}
@@ -34,6 +34,7 @@ import "../../generated/versions.es.js";
34
34
  import "../../generated/workfiles.es.js";
35
35
  import "../../generated/ynputCloud.es.js";
36
36
  import "../../generated/grouping.es.js";
37
+ import "../../generated/views.es.js";
37
38
  const getListsRestApiEnhanced = injectedRtkApi.enhanceEndpoints({
38
39
  endpoints: {
39
40
  getEntityListAttributesDefinition: {
@@ -1 +1 @@
1
- {"version":3,"file":"getListsAttributes.es.js","sources":["../../../../../../src/api/queries/entityLists/getListsAttributes.ts"],"sourcesContent":["import { entityListsApi } from '@shared/api/generated'\n\n// REST API (get list attributes)\nconst getListsRestApiEnhanced = entityListsApi.enhanceEndpoints({\n endpoints: {\n getEntityListAttributesDefinition: {\n providesTags: (result, _e, { listId }) =>\n result\n ? [\n { type: 'entityListAttribute', id: listId },\n ...result.map((a) => ({ type: 'entityListAttribute', id: a.name })),\n ]\n : [{ type: 'entityListAttribute', id: 'LIST' }],\n },\n },\n})\n\nexport const { useGetEntityListAttributesDefinitionQuery } = getListsRestApiEnhanced\nexport default getListsRestApiEnhanced\n"],"names":["entityListsApi"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGM,MAAA,0BAA0BA,eAAe,iBAAiB;AAAA,EAC9D,WAAW;AAAA,IACT,mCAAmC;AAAA,MACjC,cAAc,CAAC,QAAQ,IAAI,EAAE,OAAA,MAC3B,SACI;AAAA,QACE,EAAE,MAAM,uBAAuB,IAAI,OAAO;AAAA,QAC1C,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAAA,UAEpE,CAAC,EAAE,MAAM,uBAAuB,IAAI,OAAQ,CAAA;AAAA,IAAA;AAAA,EACpD;AAEJ,CAAC;AAEY,MAAA,EAAE,8CAA8C;"}
1
+ {"version":3,"file":"getListsAttributes.es.js","sources":["../../../../../../src/api/queries/entityLists/getListsAttributes.ts"],"sourcesContent":["import { entityListsApi } from '@shared/api/generated'\n\n// REST API (get list attributes)\nconst getListsRestApiEnhanced = entityListsApi.enhanceEndpoints({\n endpoints: {\n getEntityListAttributesDefinition: {\n providesTags: (result, _e, { listId }) =>\n result\n ? [\n { type: 'entityListAttribute', id: listId },\n ...result.map((a) => ({ type: 'entityListAttribute', id: a.name })),\n ]\n : [{ type: 'entityListAttribute', id: 'LIST' }],\n },\n },\n})\n\nexport const { useGetEntityListAttributesDefinitionQuery } = getListsRestApiEnhanced\nexport default getListsRestApiEnhanced\n"],"names":["entityListsApi"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGM,MAAA,0BAA0BA,eAAe,iBAAiB;AAAA,EAC9D,WAAW;AAAA,IACT,mCAAmC;AAAA,MACjC,cAAc,CAAC,QAAQ,IAAI,EAAE,OAAA,MAC3B,SACI;AAAA,QACE,EAAE,MAAM,uBAAuB,IAAI,OAAO;AAAA,QAC1C,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAAA,UAEpE,CAAC,EAAE,MAAM,uBAAuB,IAAI,OAAQ,CAAA;AAAA,IAAA;AAAA,EACpD;AAEJ,CAAC;AAEY,MAAA,EAAE,8CAA8C;"}
@@ -36,6 +36,7 @@ require("../../generated/versions.cjs.js");
36
36
  require("../../generated/workfiles.cjs.js");
37
37
  require("../../generated/ynputCloud.cjs.js");
38
38
  require("../../generated/grouping.cjs.js");
39
+ require("../../generated/views.cjs.js");
39
40
  const getLists = require("./getLists.cjs.js");
40
41
  const updateListsEnhancedApi = entityLists.api.enhanceEndpoints({
41
42
  endpoints: {
@@ -211,6 +212,19 @@ const updateListsEnhancedApi = entityLists.api.enhanceEndpoints({
211
212
  }
212
213
  }
213
214
  });
215
+ const updateListsInjectedApi = updateListsEnhancedApi.injectEndpoints({
216
+ endpoints: (build) => ({
217
+ createSessionFromList: build.mutation({
218
+ query: (queryArg) => ({
219
+ url: `/api/addons/review/${queryArg.addonVersion}/${queryArg.projectName}/sessions/fromList`,
220
+ method: "POST",
221
+ body: queryArg.sessionFromListRequest
222
+ }),
223
+ transformErrorResponse: (error) => error.data.detail,
224
+ invalidatesTags: () => [{ type: "entityList", id: "LIST" }]
225
+ })
226
+ })
227
+ });
214
228
  const {
215
229
  // LIST MUTATIONS
216
230
  useCreateEntityListMutation,
@@ -220,12 +234,15 @@ const {
220
234
  useUpdateEntityListItemsMutation,
221
235
  useUpdateEntityListItemMutation,
222
236
  useCreateEntityListItemMutation,
223
- useDeleteEntityListItemMutation
224
- } = updateListsEnhancedApi;
237
+ useDeleteEntityListItemMutation,
238
+ // REVIEW SESSION MUTATIONS
239
+ useCreateSessionFromListMutation
240
+ } = updateListsInjectedApi;
225
241
  exports.entityListsQueriesGql = getLists.default;
226
- exports.entityListsQueriesRest = updateListsEnhancedApi;
242
+ exports.entityListsQueriesRest = updateListsInjectedApi;
227
243
  exports.useCreateEntityListItemMutation = useCreateEntityListItemMutation;
228
244
  exports.useCreateEntityListMutation = useCreateEntityListMutation;
245
+ exports.useCreateSessionFromListMutation = useCreateSessionFromListMutation;
229
246
  exports.useDeleteEntityListItemMutation = useDeleteEntityListItemMutation;
230
247
  exports.useDeleteEntityListMutation = useDeleteEntityListMutation;
231
248
  exports.useUpdateEntityListItemMutation = useUpdateEntityListItemMutation;