@ynput/ayon-frontend-shared 0.2.14 → 0.2.16

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 (668) hide show
  1. package/dist/DetailsPanel.cjs.js +10 -0
  2. package/dist/DetailsPanel.cjs.js.map +1 -1
  3. package/dist/DetailsPanel.es.js +10 -0
  4. package/dist/DetailsPanel.es.js.map +1 -1
  5. package/dist/ProjectTreeTable.cjs.js +39 -1
  6. package/dist/ProjectTreeTable.cjs.js.map +1 -1
  7. package/dist/ProjectTreeTable.es.js +41 -3
  8. package/dist/ProjectTreeTable.es.js.map +1 -1
  9. package/dist/_virtual/index.cjs10.js +4 -4
  10. package/dist/_virtual/index.cjs5.js +3 -5
  11. package/dist/_virtual/index.cjs5.js.map +1 -1
  12. package/dist/_virtual/index.cjs6.js +5 -3
  13. package/dist/_virtual/index.cjs6.js.map +1 -1
  14. package/dist/_virtual/index.cjs8.js +4 -4
  15. package/dist/_virtual/index.cjs9.js +4 -4
  16. package/dist/_virtual/index.es10.js +4 -4
  17. package/dist/_virtual/index.es5.js +2 -5
  18. package/dist/_virtual/index.es5.js.map +1 -1
  19. package/dist/_virtual/index.es6.js +5 -2
  20. package/dist/_virtual/index.es6.js.map +1 -1
  21. package/dist/_virtual/index.es8.js +4 -4
  22. package/dist/_virtual/index.es9.js +4 -4
  23. package/dist/api.cjs.js +7 -0
  24. package/dist/api.cjs.js.map +1 -1
  25. package/dist/api.es.js +9 -2
  26. package/dist/api.es.js.map +1 -1
  27. package/dist/components.cjs.js +12 -0
  28. package/dist/components.cjs.js.map +1 -1
  29. package/dist/components.es.js +12 -0
  30. package/dist/components.es.js.map +1 -1
  31. package/dist/context.cjs.js +4 -0
  32. package/dist/context.cjs.js.map +1 -1
  33. package/dist/context.es.js +4 -0
  34. package/dist/context.es.js.map +1 -1
  35. package/dist/index.cjs.js +10 -0
  36. package/dist/index.cjs.js.map +1 -1
  37. package/dist/index.es.js +10 -0
  38. package/dist/index.es.js.map +1 -1
  39. package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +2 -2
  40. package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
  41. package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
  42. package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
  43. package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
  44. package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
  45. package/dist/node_modules/remove-accents/index.cjs.js +1 -1
  46. package/dist/node_modules/remove-accents/index.es.js +1 -1
  47. package/dist/node_modules/vfile/lib/index.cjs.js +1 -1
  48. package/dist/node_modules/vfile/lib/index.es.js +1 -1
  49. package/dist/shared/src/api/generated/actions.cjs.js.map +1 -1
  50. package/dist/shared/src/api/generated/actions.es.js.map +1 -1
  51. package/dist/shared/src/api/generated/addons.cjs.js.map +1 -1
  52. package/dist/shared/src/api/generated/addons.es.js.map +1 -1
  53. package/dist/shared/src/api/generated/anatomy.cjs.js.map +1 -1
  54. package/dist/shared/src/api/generated/anatomy.es.js.map +1 -1
  55. package/dist/shared/src/api/generated/attributes.cjs.js.map +1 -1
  56. package/dist/shared/src/api/generated/attributes.es.js.map +1 -1
  57. package/dist/shared/src/api/generated/configuration.cjs.js.map +1 -1
  58. package/dist/shared/src/api/generated/configuration.es.js.map +1 -1
  59. package/dist/shared/src/api/generated/entityLists.cjs.js.map +1 -1
  60. package/dist/shared/src/api/generated/entityLists.es.js.map +1 -1
  61. package/dist/shared/src/api/generated/events.cjs.js.map +1 -1
  62. package/dist/shared/src/api/generated/events.es.js.map +1 -1
  63. package/dist/shared/src/api/generated/files.cjs.js +5 -0
  64. package/dist/shared/src/api/generated/files.cjs.js.map +1 -1
  65. package/dist/shared/src/api/generated/files.es.js +5 -0
  66. package/dist/shared/src/api/generated/files.es.js.map +1 -1
  67. package/dist/shared/src/api/generated/graphql.cjs.js +24 -0
  68. package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
  69. package/dist/shared/src/api/generated/graphql.es.js +24 -0
  70. package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
  71. package/dist/shared/src/api/generated/grouping.cjs.js +18 -0
  72. package/dist/shared/src/api/generated/grouping.cjs.js.map +1 -0
  73. package/dist/shared/src/api/generated/grouping.es.js +18 -0
  74. package/dist/shared/src/api/generated/grouping.es.js.map +1 -0
  75. package/dist/shared/src/api/generated/operations.cjs.js.map +1 -1
  76. package/dist/shared/src/api/generated/operations.es.js.map +1 -1
  77. package/dist/shared/src/api/generated/projects.cjs.js +16 -0
  78. package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
  79. package/dist/shared/src/api/generated/projects.es.js +16 -0
  80. package/dist/shared/src/api/generated/projects.es.js.map +1 -1
  81. package/dist/shared/src/api/generated/reviewables.cjs.js.map +1 -1
  82. package/dist/shared/src/api/generated/reviewables.es.js.map +1 -1
  83. package/dist/shared/src/api/generated/system.cjs.js.map +1 -1
  84. package/dist/shared/src/api/generated/system.es.js.map +1 -1
  85. package/dist/shared/src/api/generated/tasks.cjs.js.map +1 -1
  86. package/dist/shared/src/api/generated/tasks.es.js.map +1 -1
  87. package/dist/shared/src/api/generated/users.cjs.js.map +1 -1
  88. package/dist/shared/src/api/generated/users.es.js.map +1 -1
  89. package/dist/shared/src/api/queries/actions/getActions.cjs.js +1 -0
  90. package/dist/shared/src/api/queries/actions/getActions.cjs.js.map +1 -1
  91. package/dist/shared/src/api/queries/actions/getActions.es.js +1 -0
  92. package/dist/shared/src/api/queries/actions/getActions.es.js.map +1 -1
  93. package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -0
  94. package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
  95. package/dist/shared/src/api/queries/activities/getActivities.es.js +1 -0
  96. package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
  97. package/dist/shared/src/api/queries/activities/getMentions.cjs.js +1 -0
  98. package/dist/shared/src/api/queries/activities/getMentions.cjs.js.map +1 -1
  99. package/dist/shared/src/api/queries/activities/getMentions.es.js +1 -0
  100. package/dist/shared/src/api/queries/activities/getMentions.es.js.map +1 -1
  101. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js +1 -0
  102. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js.map +1 -1
  103. package/dist/shared/src/api/queries/activities/updateReaction.es.js +1 -0
  104. package/dist/shared/src/api/queries/activities/updateReaction.es.js.map +1 -1
  105. package/dist/shared/src/api/queries/addons/getAddons.cjs.js +1 -0
  106. package/dist/shared/src/api/queries/addons/getAddons.cjs.js.map +1 -1
  107. package/dist/shared/src/api/queries/addons/getAddons.es.js +1 -0
  108. package/dist/shared/src/api/queries/addons/getAddons.es.js.map +1 -1
  109. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js +1 -0
  110. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js.map +1 -1
  111. package/dist/shared/src/api/queries/attributes/getAttributes.es.js +1 -0
  112. package/dist/shared/src/api/queries/attributes/getAttributes.es.js.map +1 -1
  113. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js +1 -0
  114. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js.map +1 -1
  115. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js +1 -0
  116. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js.map +1 -1
  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 +1 -0
  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 +1 -0
  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 +2 -0
  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 +2 -0
  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 +2 -0
  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 +2 -0
  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 +1 -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 +1 -0
  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 +1 -0
  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 +1 -0
  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 +47 -0
  150. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js.map +1 -0
  151. package/dist/shared/src/api/queries/grouping/getGrouping.es.js +47 -0
  152. package/dist/shared/src/api/queries/grouping/getGrouping.es.js.map +1 -0
  153. package/dist/shared/src/api/queries/overview/getOverview.cjs.js +64 -3
  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 +64 -3
  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 +2 -0
  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 +2 -0
  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/project/getProject.cjs.js +1 -0
  166. package/dist/shared/src/api/queries/project/getProject.cjs.js.map +1 -1
  167. package/dist/shared/src/api/queries/project/getProject.es.js +1 -0
  168. package/dist/shared/src/api/queries/project/getProject.es.js.map +1 -1
  169. package/dist/shared/src/api/queries/review/getReview.cjs.js +1 -0
  170. package/dist/shared/src/api/queries/review/getReview.cjs.js.map +1 -1
  171. package/dist/shared/src/api/queries/review/getReview.es.js +1 -0
  172. package/dist/shared/src/api/queries/review/getReview.es.js.map +1 -1
  173. package/dist/shared/src/api/queries/review/updateReview.cjs.js +1 -0
  174. package/dist/shared/src/api/queries/review/updateReview.cjs.js.map +1 -1
  175. package/dist/shared/src/api/queries/review/updateReview.es.js +1 -0
  176. package/dist/shared/src/api/queries/review/updateReview.es.js.map +1 -1
  177. package/dist/shared/src/api/queries/system/getSystem.cjs.js +1 -0
  178. package/dist/shared/src/api/queries/system/getSystem.cjs.js.map +1 -1
  179. package/dist/shared/src/api/queries/system/getSystem.es.js +1 -0
  180. package/dist/shared/src/api/queries/system/getSystem.es.js.map +1 -1
  181. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js +1 -0
  182. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js.map +1 -1
  183. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js +1 -0
  184. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js.map +1 -1
  185. package/dist/shared/src/api/queries/users/getUsers.cjs.js +2 -0
  186. package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
  187. package/dist/shared/src/api/queries/users/getUsers.es.js +2 -0
  188. package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
  189. package/dist/shared/src/api/queries/users/updateUsers.cjs.js +1 -0
  190. package/dist/shared/src/api/queries/users/updateUsers.cjs.js.map +1 -1
  191. package/dist/shared/src/api/queries/users/updateUsers.es.js +1 -0
  192. package/dist/shared/src/api/queries/users/updateUsers.es.js.map +1 -1
  193. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js +1 -0
  194. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js.map +1 -1
  195. package/dist/shared/src/api/queries/watchers/getWatchers.es.js +1 -0
  196. package/dist/shared/src/api/queries/watchers/getWatchers.es.js.map +1 -1
  197. package/dist/shared/src/components/AttributeEditor/AttributeEditor.cjs.js +2 -2
  198. package/dist/shared/src/components/AttributeEditor/AttributeEditor.cjs.js.map +1 -1
  199. package/dist/shared/src/components/AttributeEditor/AttributeEditor.es.js +2 -2
  200. package/dist/shared/src/components/AttributeEditor/AttributeEditor.es.js.map +1 -1
  201. package/dist/shared/src/components/Badge/Badge.cjs.js +31 -0
  202. package/dist/shared/src/components/Badge/Badge.cjs.js.map +1 -0
  203. package/dist/shared/src/components/Badge/Badge.es.js +31 -0
  204. package/dist/shared/src/components/Badge/Badge.es.js.map +1 -0
  205. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +2 -0
  206. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
  207. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +2 -0
  208. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
  209. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js +2 -0
  210. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js.map +1 -1
  211. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js +2 -0
  212. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js.map +1 -1
  213. package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js +1 -0
  214. package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js.map +1 -1
  215. package/dist/shared/src/components/EntityPath/SegmentProvider.es.js +1 -0
  216. package/dist/shared/src/components/EntityPath/SegmentProvider.es.js.map +1 -1
  217. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js +10 -0
  218. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js.map +1 -1
  219. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js +10 -0
  220. package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js.map +1 -1
  221. package/dist/shared/src/components/Powerpack/PowerpackButton.cjs.js +69 -0
  222. package/dist/shared/src/components/Powerpack/PowerpackButton.cjs.js.map +1 -0
  223. package/dist/shared/src/components/Powerpack/PowerpackButton.es.js +69 -0
  224. package/dist/shared/src/components/Powerpack/PowerpackButton.es.js.map +1 -0
  225. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +48 -0
  226. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -0
  227. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +48 -0
  228. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -0
  229. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js +102 -0
  230. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js.map +1 -0
  231. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js +102 -0
  232. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js.map +1 -0
  233. package/dist/shared/src/components/Powerpack/PricingLink.cjs.js +13 -0
  234. package/dist/shared/src/components/Powerpack/PricingLink.cjs.js.map +1 -0
  235. package/dist/shared/src/components/Powerpack/PricingLink.es.js +13 -0
  236. package/dist/shared/src/components/Powerpack/PricingLink.es.js.map +1 -0
  237. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js +4 -10
  238. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.cjs.js.map +1 -1
  239. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js +1 -7
  240. package/dist/shared/src/components/ProjectTableSettings/ColumnsSettings.es.js.map +1 -1
  241. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +142 -3
  242. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
  243. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +142 -3
  244. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
  245. package/dist/shared/src/components/ProjectTableSettings/TableSettings.styled.cjs.js +13 -0
  246. package/dist/shared/src/components/ProjectTableSettings/TableSettings.styled.cjs.js.map +1 -0
  247. package/dist/shared/src/components/ProjectTableSettings/TableSettings.styled.es.js +13 -0
  248. package/dist/shared/src/components/ProjectTableSettings/TableSettings.styled.es.js.map +1 -0
  249. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +50 -0
  250. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -0
  251. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +50 -0
  252. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -0
  253. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.cjs.js +5 -1
  254. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.cjs.js.map +1 -1
  255. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.es.js +5 -1
  256. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.es.js.map +1 -1
  257. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.styled.cjs.js +5 -5
  258. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.styled.cjs.js.map +1 -1
  259. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.styled.es.js +5 -5
  260. package/dist/shared/src/components/ReviewableProgressCard/ReviewableProgressCard.styled.es.js.map +1 -1
  261. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +2 -0
  262. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
  263. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +2 -0
  264. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
  265. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +100 -79
  266. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
  267. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +100 -79
  268. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
  269. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +94 -17
  270. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
  271. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +95 -18
  272. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
  273. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.styled.cjs.js +4 -0
  274. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.styled.cjs.js.map +1 -1
  275. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.styled.es.js +4 -0
  276. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.styled.es.js.map +1 -1
  277. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +10 -0
  278. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
  279. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +10 -0
  280. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
  281. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +8 -7
  282. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
  283. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +8 -7
  284. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
  285. package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js +6 -2
  286. package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js.map +1 -1
  287. package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js +6 -2
  288. package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js.map +1 -1
  289. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +223 -19
  290. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
  291. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +224 -20
  292. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
  293. package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js +1 -0
  294. package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js.map +1 -1
  295. package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js +1 -0
  296. package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js.map +1 -1
  297. package/dist/shared/src/components/Watchers/Watchers.cjs.js +2 -0
  298. package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
  299. package/dist/shared/src/components/Watchers/Watchers.es.js +2 -0
  300. package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
  301. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +10 -0
  302. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
  303. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +10 -0
  304. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
  305. package/dist/shared/src/containers/Actions/Actions.cjs.js +3 -0
  306. package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
  307. package/dist/shared/src/containers/Actions/Actions.es.js +3 -0
  308. package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
  309. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +10 -0
  310. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
  311. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +10 -0
  312. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
  313. package/dist/shared/src/containers/ContextMenu/ContextMenuItem.cjs.js +22 -0
  314. package/dist/shared/src/containers/ContextMenu/ContextMenuItem.cjs.js.map +1 -1
  315. package/dist/shared/src/containers/ContextMenu/ContextMenuItem.es.js +22 -0
  316. package/dist/shared/src/containers/ContextMenu/ContextMenuItem.es.js.map +1 -1
  317. package/dist/shared/src/containers/ContextMenu/useCreateContextMenu.cjs.js +26 -7
  318. package/dist/shared/src/containers/ContextMenu/useCreateContextMenu.cjs.js.map +1 -1
  319. package/dist/shared/src/containers/ContextMenu/useCreateContextMenu.es.js +26 -7
  320. package/dist/shared/src/containers/ContextMenu/useCreateContextMenu.es.js.map +1 -1
  321. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +10 -0
  322. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
  323. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +10 -0
  324. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
  325. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +19 -9
  326. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
  327. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +19 -9
  328. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
  329. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +10 -0
  330. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
  331. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +10 -0
  332. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
  333. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +11 -1
  334. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
  335. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +11 -1
  336. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
  337. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +3 -0
  338. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
  339. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +3 -0
  340. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
  341. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js +1 -0
  342. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js.map +1 -1
  343. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js +1 -0
  344. package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
  345. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +2 -0
  346. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
  347. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +2 -0
  348. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
  349. package/dist/shared/src/containers/Feed/Feed.cjs.js +1 -0
  350. package/dist/shared/src/containers/Feed/Feed.cjs.js.map +1 -1
  351. package/dist/shared/src/containers/Feed/Feed.es.js +1 -0
  352. package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
  353. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js +1 -0
  354. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js.map +1 -1
  355. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js +1 -0
  356. package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js.map +1 -1
  357. package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js +1 -0
  358. package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js.map +1 -1
  359. package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js +1 -0
  360. package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js.map +1 -1
  361. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js +1 -0
  362. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js.map +1 -1
  363. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js +1 -0
  364. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js.map +1 -1
  365. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js +1 -0
  366. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js.map +1 -1
  367. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js +1 -0
  368. package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js.map +1 -1
  369. package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.cjs.js +2 -1
  370. package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.cjs.js.map +1 -1
  371. package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.es.js +2 -1
  372. package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.es.js.map +1 -1
  373. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.cjs.js +8 -1
  374. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.cjs.js.map +1 -1
  375. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.es.js +9 -2
  376. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.es.js.map +1 -1
  377. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js +9 -0
  378. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js.map +1 -1
  379. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js +10 -1
  380. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js.map +1 -1
  381. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +1 -0
  382. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js.map +1 -1
  383. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js +1 -0
  384. package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js.map +1 -1
  385. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +3 -0
  386. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
  387. package/dist/shared/src/containers/Feed/context/FeedContext.es.js +3 -0
  388. package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
  389. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +2 -0
  390. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
  391. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +2 -0
  392. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
  393. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +54 -26
  394. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
  395. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +55 -27
  396. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
  397. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js +7 -0
  398. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js.map +1 -1
  399. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js +7 -0
  400. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js.map +1 -1
  401. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +53 -14
  402. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
  403. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +53 -14
  404. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
  405. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +205 -0
  406. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -0
  407. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +205 -0
  408. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -0
  409. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +25 -12
  410. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
  411. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +25 -12
  412. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
  413. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js +11 -1
  414. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js.map +1 -1
  415. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js +11 -1
  416. package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js.map +1 -1
  417. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +2 -0
  418. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
  419. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +2 -0
  420. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
  421. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js +54 -10
  422. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
  423. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js +55 -11
  424. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
  425. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.cjs.js +137 -0
  426. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.cjs.js.map +1 -0
  427. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.es.js +137 -0
  428. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableModulesContext.es.js.map +1 -0
  429. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js +1 -0
  430. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js.map +1 -1
  431. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js +1 -0
  432. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js.map +1 -1
  433. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardValidation.cjs.js +1 -1
  434. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardValidation.cjs.js.map +1 -1
  435. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardValidation.es.js +1 -1
  436. package/dist/shared/src/containers/ProjectTreeTable/context/clipboard/clipboardValidation.es.js.map +1 -1
  437. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +2 -0
  438. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -1
  439. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +2 -0
  440. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -1
  441. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +187 -0
  442. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -0
  443. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +187 -0
  444. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -0
  445. package/dist/shared/src/containers/ProjectTreeTable/hooks/{useOverviewTable.cjs.js → useBuildProjectDataTable.cjs.js} +4 -4
  446. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -0
  447. package/dist/shared/src/containers/ProjectTreeTable/hooks/{useOverviewTable.es.js → useBuildProjectDataTable.es.js} +4 -4
  448. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -0
  449. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +64 -31
  450. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
  451. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +64 -31
  452. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
  453. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnSorting.cjs.js +24 -0
  454. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnSorting.cjs.js.map +1 -0
  455. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnSorting.es.js +24 -0
  456. package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnSorting.es.js.map +1 -0
  457. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js +16 -9
  458. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js.map +1 -1
  459. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js +16 -9
  460. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js.map +1 -1
  461. package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.cjs.js +17 -0
  462. package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.cjs.js.map +1 -0
  463. package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.es.js +17 -0
  464. package/dist/shared/src/containers/ProjectTreeTable/hooks/useEntitiesMap.es.js.map +1 -0
  465. package/dist/shared/src/containers/ProjectTreeTable/hooks/useExpandedState.cjs.js +30 -0
  466. package/dist/shared/src/containers/ProjectTreeTable/hooks/useExpandedState.cjs.js.map +1 -0
  467. package/dist/shared/src/containers/ProjectTreeTable/hooks/useExpandedState.es.js +30 -0
  468. package/dist/shared/src/containers/ProjectTreeTable/hooks/useExpandedState.es.js.map +1 -0
  469. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +363 -0
  470. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -0
  471. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +363 -0
  472. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -0
  473. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.cjs.js +16 -12
  474. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.cjs.js.map +1 -1
  475. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.es.js +16 -13
  476. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetEntityTypeData.es.js.map +1 -1
  477. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +239 -0
  478. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -0
  479. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +239 -0
  480. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -0
  481. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js +82 -0
  482. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js.map +1 -0
  483. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js +82 -0
  484. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js.map +1 -0
  485. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +40 -0
  486. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -0
  487. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +40 -0
  488. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -0
  489. package/dist/shared/src/containers/ProjectTreeTable/hooks/useScopedAttributeFields.cjs.js +19 -0
  490. package/dist/shared/src/containers/ProjectTreeTable/hooks/useScopedAttributeFields.cjs.js.map +1 -0
  491. package/dist/shared/src/containers/ProjectTreeTable/hooks/useScopedAttributeFields.es.js +19 -0
  492. package/dist/shared/src/containers/ProjectTreeTable/hooks/useScopedAttributeFields.es.js.map +1 -0
  493. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSelectedFolders.cjs.js +26 -0
  494. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSelectedFolders.cjs.js.map +1 -0
  495. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSelectedFolders.es.js +26 -0
  496. package/dist/shared/src/containers/ProjectTreeTable/hooks/useSelectedFolders.es.js.map +1 -0
  497. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js +7 -4
  498. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -1
  499. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js +7 -4
  500. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -1
  501. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +12 -1
  502. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
  503. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +12 -1
  504. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
  505. package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.cjs.js.map +1 -1
  506. package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.es.js.map +1 -1
  507. package/dist/shared/src/containers/ProjectTreeTable/utils/errorExtraction.cjs.js +8 -0
  508. package/dist/shared/src/containers/ProjectTreeTable/utils/errorExtraction.cjs.js.map +1 -0
  509. package/dist/shared/src/containers/ProjectTreeTable/utils/errorExtraction.es.js +8 -0
  510. package/dist/shared/src/containers/ProjectTreeTable/utils/errorExtraction.es.js.map +1 -0
  511. package/dist/shared/src/containers/ProjectTreeTable/utils/localStorageKeys.cjs.js +7 -0
  512. package/dist/shared/src/containers/ProjectTreeTable/utils/localStorageKeys.cjs.js.map +1 -0
  513. package/dist/shared/src/containers/ProjectTreeTable/utils/localStorageKeys.es.js +7 -0
  514. package/dist/shared/src/containers/ProjectTreeTable/utils/localStorageKeys.es.js.map +1 -0
  515. package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.cjs.js +0 -1
  516. package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.cjs.js.map +1 -1
  517. package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.es.js +0 -1
  518. package/dist/shared/src/containers/ProjectTreeTable/utils/validateUpdateEntities.es.js.map +1 -1
  519. package/dist/shared/src/containers/ProjectTreeTable/widgets/GroupHeaderWidget.cjs.js +109 -0
  520. package/dist/shared/src/containers/ProjectTreeTable/widgets/GroupHeaderWidget.cjs.js.map +1 -0
  521. package/dist/shared/src/containers/ProjectTreeTable/widgets/GroupHeaderWidget.es.js +109 -0
  522. package/dist/shared/src/containers/ProjectTreeTable/widgets/GroupHeaderWidget.es.js.map +1 -0
  523. package/dist/shared/src/containers/ProjectTreeTable/widgets/LoadMoreWidget.cjs.js +29 -0
  524. package/dist/shared/src/containers/ProjectTreeTable/widgets/LoadMoreWidget.cjs.js.map +1 -0
  525. package/dist/shared/src/containers/ProjectTreeTable/widgets/LoadMoreWidget.es.js +30 -0
  526. package/dist/shared/src/containers/ProjectTreeTable/widgets/LoadMoreWidget.es.js.map +1 -0
  527. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js +0 -8
  528. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js.map +1 -1
  529. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js +0 -8
  530. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js.map +1 -1
  531. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +10 -0
  532. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
  533. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +10 -0
  534. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
  535. package/dist/shared/src/context/AddonProjectContext.cjs.js +2 -0
  536. package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
  537. package/dist/shared/src/context/AddonProjectContext.es.js +2 -0
  538. package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
  539. package/dist/shared/src/context/DetailsPanelContext.cjs.js +3 -0
  540. package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
  541. package/dist/shared/src/context/DetailsPanelContext.es.js +3 -0
  542. package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
  543. package/dist/shared/src/context/PowerpackContext.cjs.js +170 -0
  544. package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -0
  545. package/dist/shared/src/context/PowerpackContext.es.js +170 -0
  546. package/dist/shared/src/context/PowerpackContext.es.js.map +1 -0
  547. package/dist/shared/src/context/RemoteModulesContext.cjs.js +7 -1
  548. package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
  549. package/dist/shared/src/context/RemoteModulesContext.es.js +8 -2
  550. package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
  551. package/dist/shared/src/hooks/useActionTriggers.cjs.js +2 -0
  552. package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
  553. package/dist/shared/src/hooks/useActionTriggers.es.js +2 -0
  554. package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
  555. package/dist/shared/src/hooks/useEntityUpdate.cjs.js +3 -0
  556. package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
  557. package/dist/shared/src/hooks/useEntityUpdate.es.js +3 -0
  558. package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
  559. package/dist/shared/src/hooks/useLoadModule.cjs.js +8 -2
  560. package/dist/shared/src/hooks/useLoadModule.cjs.js.map +1 -1
  561. package/dist/shared/src/hooks/useLoadModule.es.js +8 -2
  562. package/dist/shared/src/hooks/useLoadModule.es.js.map +1 -1
  563. package/dist/shared/src/hooks/useScopedStatuses.cjs.js +2 -0
  564. package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
  565. package/dist/shared/src/hooks/useScopedStatuses.es.js +2 -0
  566. package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
  567. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +2 -0
  568. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
  569. package/dist/shared/src/hooks/useUserProjectConfig.es.js +2 -0
  570. package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
  571. package/dist/shared/src/util/getAttributeIcon.cjs.js +7 -1
  572. package/dist/shared/src/util/getAttributeIcon.cjs.js.map +1 -1
  573. package/dist/shared/src/util/getAttributeIcon.es.js +7 -1
  574. package/dist/shared/src/util/getAttributeIcon.es.js.map +1 -1
  575. package/dist/shared/src/util/getEntityTypeIcon.cjs.js +9 -0
  576. package/dist/shared/src/util/getEntityTypeIcon.cjs.js.map +1 -1
  577. package/dist/shared/src/util/getEntityTypeIcon.es.js +9 -0
  578. package/dist/shared/src/util/getEntityTypeIcon.es.js.map +1 -1
  579. package/dist/types/api/generated/actions.d.ts +2 -1
  580. package/dist/types/api/generated/addons.d.ts +8 -1
  581. package/dist/types/api/generated/anatomy.d.ts +1 -14
  582. package/dist/types/api/generated/attributes.d.ts +4 -2
  583. package/dist/types/api/generated/configuration.d.ts +6 -0
  584. package/dist/types/api/generated/entityLists.d.ts +2 -0
  585. package/dist/types/api/generated/events.d.ts +1 -1
  586. package/dist/types/api/generated/files.d.ts +11 -0
  587. package/dist/types/api/generated/graphql.d.ts +33 -38
  588. package/dist/types/api/generated/grouping.d.ts +40 -0
  589. package/dist/types/api/generated/index.d.ts +3 -1
  590. package/dist/types/api/generated/operations.d.ts +1 -1
  591. package/dist/types/api/generated/projects.d.ts +59 -0
  592. package/dist/types/api/generated/reviewables.d.ts +1 -0
  593. package/dist/types/api/generated/system.d.ts +5 -3
  594. package/dist/types/api/generated/tasks.d.ts +15 -1
  595. package/dist/types/api/generated/users.d.ts +1 -4
  596. package/dist/types/api/queries/activities/getActivities.d.ts +4 -0
  597. package/dist/types/api/queries/activities/updateActivities.d.ts +8 -0
  598. package/dist/types/api/queries/entities/getEntity.d.ts +4 -0
  599. package/dist/types/api/queries/entities/getEntityPanel.d.ts +4 -0
  600. package/dist/types/api/queries/entities/updateEntity.d.ts +4 -0
  601. package/dist/types/api/queries/entityLists/getLists.d.ts +4 -0
  602. package/dist/types/api/queries/grouping/getGrouping.d.ts +137 -0
  603. package/dist/types/api/queries/grouping/index.d.ts +1 -0
  604. package/dist/types/api/queries/index.d.ts +1 -0
  605. package/dist/types/api/queries/overview/getOverview.d.ts +222 -482
  606. package/dist/types/api/queries/project/getProject.d.ts +6 -0
  607. package/dist/types/api/queries/userDashboard/getUserDashboard.d.ts +4 -0
  608. package/dist/types/api/queries/users/getUsers.d.ts +4 -0
  609. package/dist/types/components/Badge/Badge.d.ts +10 -0
  610. package/dist/types/components/Badge/index.d.ts +1 -0
  611. package/dist/types/components/Powerpack/PowerpackButton.d.ts +7 -0
  612. package/dist/types/components/Powerpack/PowerpackDialog.d.ts +4 -0
  613. package/dist/types/components/Powerpack/PowerpackDialog.styled.d.ts +8 -0
  614. package/dist/types/components/Powerpack/PricingLink.d.ts +4 -0
  615. package/dist/types/components/Powerpack/index.d.ts +3 -0
  616. package/dist/types/components/ProjectTableSettings/ProjectTableSettings.d.ts +3 -2
  617. package/dist/types/components/ProjectTableSettings/TableSettings.styled.d.ts +1 -0
  618. package/dist/types/components/ProjectTableSettings/TableSettingsFallback.d.ts +10 -0
  619. package/dist/types/components/ProjectTableSettings/index.d.ts +1 -0
  620. package/dist/types/components/ReviewableProgressCard/ReviewableProgressCard.d.ts +1 -1
  621. package/dist/types/components/ReviewablesList/ReviewablesUpload.d.ts +19 -3
  622. package/dist/types/components/index.d.ts +2 -0
  623. package/dist/types/containers/ContextMenu/ContextMenuItem.d.ts +4 -0
  624. package/dist/types/containers/ContextMenu/useCreateContextMenu.d.ts +2 -1
  625. package/dist/types/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.d.ts +1 -0
  626. package/dist/types/containers/ProjectTreeTable/buildTreeTableColumns.d.ts +3 -1
  627. package/dist/types/containers/ProjectTreeTable/components/GroupSettingsFallback.d.ts +11 -0
  628. package/dist/types/containers/ProjectTreeTable/context/ColumnSettingsContext.d.ts +7 -0
  629. package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +22 -5
  630. package/dist/types/containers/ProjectTreeTable/context/ProjectTableModulesContext.d.ts +32 -0
  631. package/dist/types/containers/ProjectTreeTable/context/index.d.ts +1 -0
  632. package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +13 -0
  633. package/dist/types/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.d.ts +30 -0
  634. package/dist/types/containers/ProjectTreeTable/hooks/{useOverviewTable.d.ts → useBuildProjectDataTable.d.ts} +3 -1
  635. package/dist/types/containers/ProjectTreeTable/hooks/useCellContextMenu.d.ts +15 -2
  636. package/dist/types/containers/ProjectTreeTable/hooks/useColumnSorting.d.ts +12 -0
  637. package/dist/types/containers/ProjectTreeTable/hooks/useEntitiesMap.d.ts +7 -0
  638. package/dist/types/containers/ProjectTreeTable/hooks/useExpandedState.d.ts +11 -0
  639. package/dist/types/containers/ProjectTreeTable/hooks/useFetchOverviewData.d.ts +37 -0
  640. package/dist/types/containers/ProjectTreeTable/hooks/useFolderRelationships.d.ts +1 -1
  641. package/dist/types/containers/ProjectTreeTable/hooks/useGetEntityTypeData.d.ts +2 -2
  642. package/dist/types/containers/ProjectTreeTable/hooks/useGetGroupedFields.d.ts +9 -0
  643. package/dist/types/containers/ProjectTreeTable/hooks/useGetTaskGroups.d.ts +10 -0
  644. package/dist/types/containers/ProjectTreeTable/hooks/useQueryFilters.d.ts +14 -0
  645. package/dist/types/containers/ProjectTreeTable/hooks/useScopedAttributeFields.d.ts +10 -0
  646. package/dist/types/containers/ProjectTreeTable/hooks/useSelectedFolders.d.ts +10 -0
  647. package/dist/types/containers/ProjectTreeTable/index.d.ts +1 -4
  648. package/dist/types/containers/ProjectTreeTable/types/index.d.ts +1 -0
  649. package/dist/types/containers/ProjectTreeTable/types/overviewContext.d.ts +46 -0
  650. package/dist/types/containers/ProjectTreeTable/types/table.d.ts +13 -5
  651. package/dist/types/containers/ProjectTreeTable/utils/errorExtraction.d.ts +4 -0
  652. package/dist/types/containers/ProjectTreeTable/utils/index.d.ts +2 -0
  653. package/dist/types/containers/ProjectTreeTable/utils/localStorageKeys.d.ts +4 -0
  654. package/dist/types/containers/ProjectTreeTable/widgets/GroupHeaderWidget.d.ts +14 -0
  655. package/dist/types/containers/ProjectTreeTable/widgets/LoadMoreWidget.d.ts +8 -0
  656. package/dist/types/containers/ProjectTreeTable/widgets/index.d.ts +1 -0
  657. package/dist/types/context/PowerpackContext.d.ts +21 -0
  658. package/dist/types/context/index.d.ts +1 -0
  659. package/dist/types/hooks/useLoadModule.d.ts +2 -1
  660. package/dist/types/util/getAttributeIcon.d.ts +1 -1
  661. package/dist/types/util/getEntityTypeIcon.d.ts +1 -0
  662. package/dist/types/utils/extractVersionFromFilename.d.ts +5 -0
  663. package/dist/util.cjs.js +1 -0
  664. package/dist/util.cjs.js.map +1 -1
  665. package/dist/util.es.js +2 -1
  666. package/package.json +1 -1
  667. package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.cjs.js.map +0 -1
  668. package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.es.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"useMentionLink.es.js","sources":["../../../../../../../../src/containers/Feed/components/CommentInput/hooks/useMentionLink.ts"],"sourcesContent":["import { Quill } from 'react-quill-ayon'\nimport useReferenceTooltip from '../../../hooks/useReferenceTooltip'\nimport { useDetailsPanelContext } from '@shared/context'\nimport { DetailsPanelEntityType } from '@shared/api'\n\nconst Inline = Quill.import('blots/inline')\n\ninterface MentionLinkOptions {\n projectName: string\n}\n\n// custom mention links\nconst useMentionLink = ({ projectName }: MentionLinkOptions) => {\n const { openSlideOut } = useDetailsPanelContext()\n const [, setRefTooltip] = useReferenceTooltip()\n\n // special link for mentions\n // @ts-ignore\n class MentionLink extends Inline {\n static blotName = 'mention'\n static tagName = 'MENTION'\n // @ts-ignore\n static create(value) {\n if (!value || typeof value !== 'string') return document.createElement(MentionLink.tagName)\n\n const node = super.create(value)\n // check if this is a mention url\n const valueMentionType = value.split(':').shift() as string\n const valueMentionId = value.split(':').pop() as string\n\n node.classList.add('mention')\n node.classList.add(valueMentionType)\n // add id=id-ref\n node.setAttribute('id', `ref-${valueMentionId}`)\n // set as not editable\n node.setAttribute('contenteditable', 'false')\n\n // add data-value attribute\n node.setAttribute('data-value', value)\n\n // on mouse click open reference\n node.addEventListener('click', (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault()\n if (valueMentionType === 'user') return\n\n openSlideOut({\n entityId: valueMentionId,\n entityType: valueMentionType as DetailsPanelEntityType,\n projectName,\n })\n })\n\n // add on mouse enter\n node.addEventListener('mouseenter', (e: React.KeyboardEvent<HTMLElement>) => {\n const target = e.target || {}\n const label = (target as HTMLElement).innerText.replace('@', '')\n // get the center of the reference\n const { x, y, width } = (target as HTMLElement).getBoundingClientRect()\n const pos = { left: x + width / 2, top: y }\n\n setRefTooltip({\n id: valueMentionId,\n name: valueMentionId,\n type: valueMentionType,\n label,\n pos,\n })\n })\n\n return node || ''\n }\n\n // Added value method to retrieve the value from the DOM node\n static value(node: any) {\n return node.getAttribute('data-value')\n }\n }\n\n // @ts-ignore\n MentionLink.sanitize = (url) => url\n // @ts-ignore\n Quill.register(MentionLink, true)\n}\n\nexport default useMentionLink\n"],"names":[],"mappings":";;;;;;;;;;;;;;AAKA,MAAM,SAAS,MAAM,OAAO,cAAc;AAO1C,MAAM,iBAAiB,CAAC,EAAE,kBAAsC;AACxD,QAAA,EAAE,aAAa,IAAI,uBAAuB;AAChD,QAAM,CAAG,EAAA,aAAa,IAAI,oBAAoB;AAI9C,QAAM,eAAN,MAAM,qBAAoB,OAAO;AAAA;AAAA,IAI/B,OAAO,OAAO,OAAO;AACf,UAAA,CAAC,SAAS,OAAO,UAAU,SAAiB,QAAA,SAAS,cAAc,aAAY,OAAO;AAEpF,YAAA,OAAO,MAAM,OAAO,KAAK;AAE/B,YAAM,mBAAmB,MAAM,MAAM,GAAG,EAAE,MAAM;AAChD,YAAM,iBAAiB,MAAM,MAAM,GAAG,EAAE,IAAI;AAEvC,WAAA,UAAU,IAAI,SAAS;AACvB,WAAA,UAAU,IAAI,gBAAgB;AAEnC,WAAK,aAAa,MAAM,OAAO,cAAc,EAAE;AAE1C,WAAA,aAAa,mBAAmB,OAAO;AAGvC,WAAA,aAAa,cAAc,KAAK;AAGhC,WAAA,iBAAiB,SAAS,CAAC,MAAqC;AACnE,UAAE,eAAe;AACjB,YAAI,qBAAqB,OAAQ;AAEpB,qBAAA;AAAA,UACX,UAAU;AAAA,UACV,YAAY;AAAA,UACZ;AAAA,QAAA,CACD;AAAA,MAAA,CACF;AAGI,WAAA,iBAAiB,cAAc,CAAC,MAAwC;AACrE,cAAA,SAAS,EAAE,UAAU,CAAC;AAC5B,cAAM,QAAS,OAAuB,UAAU,QAAQ,KAAK,EAAE;AAE/D,cAAM,EAAE,GAAG,GAAG,MAAM,IAAK,OAAuB,sBAAsB;AACtE,cAAM,MAAM,EAAE,MAAM,IAAI,QAAQ,GAAG,KAAK,EAAE;AAE5B,sBAAA;AAAA,UACZ,IAAI;AAAA,UACJ,MAAM;AAAA,UACN,MAAM;AAAA,UACN;AAAA,UACA;AAAA,QAAA,CACD;AAAA,MAAA,CACF;AAED,aAAO,QAAQ;AAAA,IAAA;AAAA;AAAA,IAIjB,OAAO,MAAM,MAAW;AACf,aAAA,KAAK,aAAa,YAAY;AAAA,IAAA;AAAA,EACvC;AAxDA,gBADI,cACG,YAAW;AAClB,gBAFI,cAEG,WAAU;AAFnB,MAAM,cAAN;AA6DY,cAAA,WAAW,CAAC,QAAQ;AAE1B,QAAA,SAAS,aAAa,IAAI;AAClC;"}
1
+ {"version":3,"file":"useMentionLink.es.js","sources":["../../../../../../../../src/containers/Feed/components/CommentInput/hooks/useMentionLink.ts"],"sourcesContent":["import { Quill } from 'react-quill-ayon'\nimport useReferenceTooltip from '../../../hooks/useReferenceTooltip'\nimport { useDetailsPanelContext } from '@shared/context'\nimport { DetailsPanelEntityType } from '@shared/api'\n\nconst Inline = Quill.import('blots/inline')\n\ninterface MentionLinkOptions {\n projectName: string\n}\n\n// custom mention links\nconst useMentionLink = ({ projectName }: MentionLinkOptions) => {\n const { openSlideOut } = useDetailsPanelContext()\n const [, setRefTooltip] = useReferenceTooltip()\n\n // special link for mentions\n // @ts-ignore\n class MentionLink extends Inline {\n static blotName = 'mention'\n static tagName = 'MENTION'\n // @ts-ignore\n static create(value) {\n if (!value || typeof value !== 'string') return document.createElement(MentionLink.tagName)\n\n const node = super.create(value)\n // check if this is a mention url\n const valueMentionType = value.split(':').shift() as string\n const valueMentionId = value.split(':').pop() as string\n\n node.classList.add('mention')\n node.classList.add(valueMentionType)\n // add id=id-ref\n node.setAttribute('id', `ref-${valueMentionId}`)\n // set as not editable\n node.setAttribute('contenteditable', 'false')\n\n // add data-value attribute\n node.setAttribute('data-value', value)\n\n // on mouse click open reference\n node.addEventListener('click', (e: React.MouseEvent<HTMLElement>) => {\n e.preventDefault()\n if (valueMentionType === 'user') return\n\n openSlideOut({\n entityId: valueMentionId,\n entityType: valueMentionType as DetailsPanelEntityType,\n projectName,\n })\n })\n\n // add on mouse enter\n node.addEventListener('mouseenter', (e: React.KeyboardEvent<HTMLElement>) => {\n const target = e.target || {}\n const label = (target as HTMLElement).innerText.replace('@', '')\n // get the center of the reference\n const { x, y, width } = (target as HTMLElement).getBoundingClientRect()\n const pos = { left: x + width / 2, top: y }\n\n setRefTooltip({\n id: valueMentionId,\n name: valueMentionId,\n type: valueMentionType,\n label,\n pos,\n })\n })\n\n return node || ''\n }\n\n // Added value method to retrieve the value from the DOM node\n static value(node: any) {\n return node.getAttribute('data-value')\n }\n }\n\n // @ts-ignore\n MentionLink.sanitize = (url) => url\n // @ts-ignore\n Quill.register(MentionLink, true)\n}\n\nexport default useMentionLink\n"],"names":[],"mappings":";;;;;;;;;;;;;;;AAKA,MAAM,SAAS,MAAM,OAAO,cAAc;AAO1C,MAAM,iBAAiB,CAAC,EAAE,kBAAsC;AACxD,QAAA,EAAE,aAAa,IAAI,uBAAuB;AAChD,QAAM,CAAG,EAAA,aAAa,IAAI,oBAAoB;AAI9C,QAAM,eAAN,MAAM,qBAAoB,OAAO;AAAA;AAAA,IAI/B,OAAO,OAAO,OAAO;AACf,UAAA,CAAC,SAAS,OAAO,UAAU,SAAiB,QAAA,SAAS,cAAc,aAAY,OAAO;AAEpF,YAAA,OAAO,MAAM,OAAO,KAAK;AAE/B,YAAM,mBAAmB,MAAM,MAAM,GAAG,EAAE,MAAM;AAChD,YAAM,iBAAiB,MAAM,MAAM,GAAG,EAAE,IAAI;AAEvC,WAAA,UAAU,IAAI,SAAS;AACvB,WAAA,UAAU,IAAI,gBAAgB;AAEnC,WAAK,aAAa,MAAM,OAAO,cAAc,EAAE;AAE1C,WAAA,aAAa,mBAAmB,OAAO;AAGvC,WAAA,aAAa,cAAc,KAAK;AAGhC,WAAA,iBAAiB,SAAS,CAAC,MAAqC;AACnE,UAAE,eAAe;AACjB,YAAI,qBAAqB,OAAQ;AAEpB,qBAAA;AAAA,UACX,UAAU;AAAA,UACV,YAAY;AAAA,UACZ;AAAA,QAAA,CACD;AAAA,MAAA,CACF;AAGI,WAAA,iBAAiB,cAAc,CAAC,MAAwC;AACrE,cAAA,SAAS,EAAE,UAAU,CAAC;AAC5B,cAAM,QAAS,OAAuB,UAAU,QAAQ,KAAK,EAAE;AAE/D,cAAM,EAAE,GAAG,GAAG,MAAM,IAAK,OAAuB,sBAAsB;AACtE,cAAM,MAAM,EAAE,MAAM,IAAI,QAAQ,GAAG,KAAK,EAAE;AAE5B,sBAAA;AAAA,UACZ,IAAI;AAAA,UACJ,MAAM;AAAA,UACN,MAAM;AAAA,UACN;AAAA,UACA;AAAA,QAAA,CACD;AAAA,MAAA,CACF;AAED,aAAO,QAAQ;AAAA,IAAA;AAAA;AAAA,IAIjB,OAAO,MAAM,MAAW;AACf,aAAA,KAAK,aAAa,YAAY;AAAA,IAAA;AAAA,EACvC;AAxDA,gBADI,cACG,YAAW;AAClB,gBAFI,cAEG,WAAU;AAFnB,MAAM,cAAN;AA6DY,cAAA,WAAW,CAAC,QAAQ;AAE1B,QAAA,SAAS,aAAa,IAAI;AAClC;"}
@@ -14,6 +14,7 @@ require("react-dom");
14
14
  require("../../../../context/pip/PiPWrapper.cjs.js");
15
15
  require("../../../../context/AddonProjectContext.cjs.js");
16
16
  require("../../../../context/AddonContext.cjs.js");
17
+ require("../../../../context/PowerpackContext.cjs.js");
17
18
  const fileIcons = {
18
19
  // special cases
19
20
  description: ["doc"],
@@ -169,7 +170,7 @@ const FileUploadCard = ({
169
170
  extension
170
171
  ] })
171
172
  ] }) }),
172
- isDownloadable && (!onRemove ? /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx("a", { href: src, download: true, className: "download", children: downloadComponent }) : /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx("div", { className: "download", children: downloadComponent }))
173
+ isDownloadable && (!onRemove ? /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx("a", { href: src, target: "_blank", rel: "noopener noreferrer", className: "download", children: downloadComponent }) : /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx("div", { className: "download", children: downloadComponent }))
173
174
  ] }),
174
175
  onRemove && /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(ayonReactComponents.Button, { className: "remove", onClick: onRemove, icon: "close" })
175
176
  ]
@@ -1 +1 @@
1
- {"version":3,"file":"FileUploadCard.cjs.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadCard/FileUploadCard.tsx"],"sourcesContent":["import { Button, getFileSizeString, Icon } from '@ynput/ayon-react-components'\nimport * as Styled from './FileUploadCard.styled'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport { isFilePreviewable } from '../FileUploadPreview'\nimport { SavedAnnotationMetadata } from '@shared/containers'\nimport { useDetailsPanelContext } from '@shared/context'\nimport { AnnotationPreview } from '../CommentInput/hooks/useAnnotationsSync'\n\nexport interface FileUploadCardProps extends React.HTMLAttributes<HTMLDivElement> {\n name: string\n mime?: string\n src?: string\n unsavedAnnotation?: AnnotationPreview\n savedAnnotation?: SavedAnnotationMetadata\n size: number\n progress: number\n onRemove?: () => void\n isCompact?: boolean\n isDownloadable?: boolean\n onExpand?: () => void\n onJumpTo?: () => void\n}\n\nconst fileIcons: { [key: string]: string[] } = {\n // special cases\n description: ['doc'],\n folder_zip: ['zip'],\n code_blocks: [\n 'json',\n 'javascript',\n 'python',\n 'html',\n 'css',\n '.py',\n '.js',\n '.html',\n '.css',\n '.json',\n '.ts',\n ],\n brush: ['.psd', '.ai', '.xd', '.sketch'],\n '3d_rotation': [\n '.mb',\n '.ma',\n '.c4d',\n '.blend',\n '.max',\n '.3ds',\n '.lwo',\n '.lws',\n '.lxo',\n '.hip',\n '.hda',\n ],\n theaters: ['.aep', '.tpl', '.clip', '.nk', '.fusion', '.prproj', '.spsm', '.drp'],\n picture_as_pdf: ['pdf', '.pdf'],\n // default\n image: ['image', '.png', '.jpg', '.jpeg', '.gif', '.svg', '.webp'],\n videocam: ['video', '.mp4', '.mov', '.avi', '.mkv', '.webm', '.mxf'],\n business_center: ['application'],\n audio_file: ['audio'],\n text_snippet: ['text'],\n filter_none: ['sequence'],\n font_download: ['font'],\n deployed_code: ['model', '.obj', '.abc', '.stl', '.fbx', '.gltf', '.glb', '.usd'],\n}\n\nconst getIconForType = (type: string): string => {\n for (const [icon, keywords] of Object.entries(fileIcons)) {\n if (keywords.some((keyword) => type.includes(keyword))) {\n return icon\n }\n }\n return 'draft'\n}\n\nconst FileUploadCard = ({\n name,\n mime,\n src,\n unsavedAnnotation,\n savedAnnotation,\n size,\n progress,\n onRemove,\n isCompact,\n isDownloadable = false,\n onExpand,\n onJumpTo,\n className,\n ...props\n}: FileUploadCardProps) => {\n const inProgress = progress && progress < 100\n\n const [imageError, setImageError] = useState(false)\n const { feedAnnotationsEnabled } = useDetailsPanelContext()\n\n // split name and file extension\n const nameParts = name.split('.')\n const extension = nameParts.pop() || ''\n const fileName = nameParts.join('.')\n\n const isPreviewable = isFilePreviewable(mime || '.' + extension)\n const isImage = mime?.includes('image/') || Boolean(unsavedAnnotation)\n\n const downloadComponent = (\n <>\n <span className=\"size\">{getFileSizeString(size)}</span>\n <Icon icon=\"download\" className=\"download-icon\" />\n </>\n )\n\n const someAnnotation = unsavedAnnotation ?? savedAnnotation\n\n return (\n <Styled.File\n className={clsx(className, {\n compact: isCompact,\n isDownloadable,\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n {...props}\n >\n <Styled.ContentWrapper\n className={clsx('content-wrapper', {\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n >\n <Icon icon={getIconForType(mime || '.' + extension)} className=\"type-icon\" />\n {isImage && src && (\n <Styled.ImageWrapper\n className={clsx({\n 'image-wrapper': true,\n isDownloadable: isDownloadable || isPreviewable || unsavedAnnotation,\n })}\n >\n <img\n src={src}\n onError={() => setImageError(true)}\n style={{\n display: imageError ? 'none' : 'block',\n }}\n />\n </Styled.ImageWrapper>\n )}\n <Styled.Buttons className=\"expand-buttons\">\n {isPreviewable && (\n <Styled.ExpandButton\n data-tooltip=\"Open preview\"\n icon=\"open_in_full\"\n variant=\"nav\"\n onClick={onExpand}\n />\n )}\n {(unsavedAnnotation || (feedAnnotationsEnabled && savedAnnotation)) && (\n <Styled.ExpandButton\n data-tooltip=\"Jump to annotation\"\n icon=\"play_circle\"\n variant=\"nav\"\n onClick={onJumpTo}\n />\n )}\n </Styled.Buttons>\n </Styled.ContentWrapper>\n <Styled.Footer className={clsx({ inProgress, isPreviewable, isDownloadable })}>\n <span className=\"progress\" style={{ right: `${100 - progress}%` }} />\n <div className=\"name-wrapper\">\n {someAnnotation ? (\n <span className=\"name\">\n <Icon icon=\"draw\" />\n {someAnnotation.range[0]}\n {someAnnotation.range[1] !== someAnnotation.range[0] &&\n ` - ${someAnnotation.range[1]}`}\n </span>\n ) : (\n <span className=\"name\">\n {fileName}\n <span className=\"extension\">.{extension}</span>\n </span>\n )}\n </div>\n\n {isDownloadable &&\n (!onRemove ? (\n <a href={src} download className=\"download\">\n {downloadComponent}\n </a>\n ) : (\n <div className=\"download\">{downloadComponent}</div>\n ))}\n </Styled.Footer>\n {onRemove && <Button className=\"remove\" onClick={onRemove} icon=\"close\" />}\n </Styled.File>\n )\n}\n\nexport default FileUploadCard\n"],"names":["useState","useDetailsPanelContext","isFilePreviewable","jsxs","Fragment","jsx","getFileSizeString","Icon","Styled.File","Styled.ContentWrapper","Styled.ImageWrapper","Styled.Buttons","Styled.ExpandButton","Styled.Footer","Button"],"mappings":"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"}
1
+ {"version":3,"file":"FileUploadCard.cjs.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadCard/FileUploadCard.tsx"],"sourcesContent":["import { Button, getFileSizeString, Icon } from '@ynput/ayon-react-components'\nimport * as Styled from './FileUploadCard.styled'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport { isFilePreviewable } from '../FileUploadPreview'\nimport { SavedAnnotationMetadata } from '@shared/containers'\nimport { useDetailsPanelContext } from '@shared/context'\nimport { AnnotationPreview } from '../CommentInput/hooks/useAnnotationsSync'\n\nexport interface FileUploadCardProps extends React.HTMLAttributes<HTMLDivElement> {\n name: string\n mime?: string\n src?: string\n unsavedAnnotation?: AnnotationPreview\n savedAnnotation?: SavedAnnotationMetadata\n size: number\n progress: number\n onRemove?: () => void\n isCompact?: boolean\n isDownloadable?: boolean\n onExpand?: () => void\n onJumpTo?: () => void\n}\n\nconst fileIcons: { [key: string]: string[] } = {\n // special cases\n description: ['doc'],\n folder_zip: ['zip'],\n code_blocks: [\n 'json',\n 'javascript',\n 'python',\n 'html',\n 'css',\n '.py',\n '.js',\n '.html',\n '.css',\n '.json',\n '.ts',\n ],\n brush: ['.psd', '.ai', '.xd', '.sketch'],\n '3d_rotation': [\n '.mb',\n '.ma',\n '.c4d',\n '.blend',\n '.max',\n '.3ds',\n '.lwo',\n '.lws',\n '.lxo',\n '.hip',\n '.hda',\n ],\n theaters: ['.aep', '.tpl', '.clip', '.nk', '.fusion', '.prproj', '.spsm', '.drp'],\n picture_as_pdf: ['pdf', '.pdf'],\n // default\n image: ['image', '.png', '.jpg', '.jpeg', '.gif', '.svg', '.webp'],\n videocam: ['video', '.mp4', '.mov', '.avi', '.mkv', '.webm', '.mxf'],\n business_center: ['application'],\n audio_file: ['audio'],\n text_snippet: ['text'],\n filter_none: ['sequence'],\n font_download: ['font'],\n deployed_code: ['model', '.obj', '.abc', '.stl', '.fbx', '.gltf', '.glb', '.usd'],\n}\n\nconst getIconForType = (type: string): string => {\n for (const [icon, keywords] of Object.entries(fileIcons)) {\n if (keywords.some((keyword) => type.includes(keyword))) {\n return icon\n }\n }\n return 'draft'\n}\n\nconst FileUploadCard = ({\n name,\n mime,\n src,\n unsavedAnnotation,\n savedAnnotation,\n size,\n progress,\n onRemove,\n isCompact,\n isDownloadable = false,\n onExpand,\n onJumpTo,\n className,\n ...props\n}: FileUploadCardProps) => {\n const inProgress = progress && progress < 100\n\n const [imageError, setImageError] = useState(false)\n const { feedAnnotationsEnabled } = useDetailsPanelContext()\n\n // split name and file extension\n const nameParts = name.split('.')\n const extension = nameParts.pop() || ''\n const fileName = nameParts.join('.')\n\n const isPreviewable = isFilePreviewable(mime || '.' + extension)\n const isImage = mime?.includes('image/') || Boolean(unsavedAnnotation)\n\n const downloadComponent = (\n <>\n <span className=\"size\">{getFileSizeString(size)}</span>\n <Icon icon=\"download\" className=\"download-icon\" />\n </>\n )\n\n const someAnnotation = unsavedAnnotation ?? savedAnnotation\n\n return (\n <Styled.File\n className={clsx(className, {\n compact: isCompact,\n isDownloadable,\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n {...props}\n >\n <Styled.ContentWrapper\n className={clsx('content-wrapper', {\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n >\n <Icon icon={getIconForType(mime || '.' + extension)} className=\"type-icon\" />\n {isImage && src && (\n <Styled.ImageWrapper\n className={clsx({\n 'image-wrapper': true,\n isDownloadable: isDownloadable || isPreviewable || unsavedAnnotation,\n })}\n >\n <img\n src={src}\n onError={() => setImageError(true)}\n style={{\n display: imageError ? 'none' : 'block',\n }}\n />\n </Styled.ImageWrapper>\n )}\n <Styled.Buttons className=\"expand-buttons\">\n {isPreviewable && (\n <Styled.ExpandButton\n data-tooltip=\"Open preview\"\n icon=\"open_in_full\"\n variant=\"nav\"\n onClick={onExpand}\n />\n )}\n {(unsavedAnnotation || (feedAnnotationsEnabled && savedAnnotation)) && (\n <Styled.ExpandButton\n data-tooltip=\"Jump to annotation\"\n icon=\"play_circle\"\n variant=\"nav\"\n onClick={onJumpTo}\n />\n )}\n </Styled.Buttons>\n </Styled.ContentWrapper>\n <Styled.Footer className={clsx({ inProgress, isPreviewable, isDownloadable })}>\n <span className=\"progress\" style={{ right: `${100 - progress}%` }} />\n <div className=\"name-wrapper\">\n {someAnnotation ? (\n <span className=\"name\">\n <Icon icon=\"draw\" />\n {someAnnotation.range[0]}\n {someAnnotation.range[1] !== someAnnotation.range[0] &&\n ` - ${someAnnotation.range[1]}`}\n </span>\n ) : (\n <span className=\"name\">\n {fileName}\n <span className=\"extension\">.{extension}</span>\n </span>\n )}\n </div>\n\n {isDownloadable &&\n (!onRemove ? (\n <a href={src} target=\"_blank\" rel=\"noopener noreferrer\" className=\"download\">\n {downloadComponent}\n </a>\n ) : (\n <div className=\"download\">{downloadComponent}</div>\n ))}\n </Styled.Footer>\n {onRemove && <Button className=\"remove\" onClick={onRemove} icon=\"close\" />}\n </Styled.File>\n )\n}\n\nexport default FileUploadCard\n"],"names":["useState","useDetailsPanelContext","isFilePreviewable","jsxs","Fragment","jsx","getFileSizeString","Icon","Styled.File","Styled.ContentWrapper","Styled.ImageWrapper","Styled.Buttons","Styled.ExpandButton","Styled.Footer","Button"],"mappings":"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"}
@@ -13,6 +13,7 @@ import "react-dom";
13
13
  import "../../../../context/pip/PiPWrapper.es.js";
14
14
  import "../../../../context/AddonProjectContext.es.js";
15
15
  import "../../../../context/AddonContext.es.js";
16
+ import "../../../../context/PowerpackContext.es.js";
16
17
  const fileIcons = {
17
18
  // special cases
18
19
  description: ["doc"],
@@ -168,7 +169,7 @@ const FileUploadCard = ({
168
169
  extension
169
170
  ] })
170
171
  ] }) }),
171
- isDownloadable && (!onRemove ? /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: src, download: true, className: "download", children: downloadComponent }) : /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "download", children: downloadComponent }))
172
+ isDownloadable && (!onRemove ? /* @__PURE__ */ jsxRuntimeExports.jsx("a", { href: src, target: "_blank", rel: "noopener noreferrer", className: "download", children: downloadComponent }) : /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "download", children: downloadComponent }))
172
173
  ] }),
173
174
  onRemove && /* @__PURE__ */ jsxRuntimeExports.jsx(Button, { className: "remove", onClick: onRemove, icon: "close" })
174
175
  ]
@@ -1 +1 @@
1
- {"version":3,"file":"FileUploadCard.es.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadCard/FileUploadCard.tsx"],"sourcesContent":["import { Button, getFileSizeString, Icon } from '@ynput/ayon-react-components'\nimport * as Styled from './FileUploadCard.styled'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport { isFilePreviewable } from '../FileUploadPreview'\nimport { SavedAnnotationMetadata } from '@shared/containers'\nimport { useDetailsPanelContext } from '@shared/context'\nimport { AnnotationPreview } from '../CommentInput/hooks/useAnnotationsSync'\n\nexport interface FileUploadCardProps extends React.HTMLAttributes<HTMLDivElement> {\n name: string\n mime?: string\n src?: string\n unsavedAnnotation?: AnnotationPreview\n savedAnnotation?: SavedAnnotationMetadata\n size: number\n progress: number\n onRemove?: () => void\n isCompact?: boolean\n isDownloadable?: boolean\n onExpand?: () => void\n onJumpTo?: () => void\n}\n\nconst fileIcons: { [key: string]: string[] } = {\n // special cases\n description: ['doc'],\n folder_zip: ['zip'],\n code_blocks: [\n 'json',\n 'javascript',\n 'python',\n 'html',\n 'css',\n '.py',\n '.js',\n '.html',\n '.css',\n '.json',\n '.ts',\n ],\n brush: ['.psd', '.ai', '.xd', '.sketch'],\n '3d_rotation': [\n '.mb',\n '.ma',\n '.c4d',\n '.blend',\n '.max',\n '.3ds',\n '.lwo',\n '.lws',\n '.lxo',\n '.hip',\n '.hda',\n ],\n theaters: ['.aep', '.tpl', '.clip', '.nk', '.fusion', '.prproj', '.spsm', '.drp'],\n picture_as_pdf: ['pdf', '.pdf'],\n // default\n image: ['image', '.png', '.jpg', '.jpeg', '.gif', '.svg', '.webp'],\n videocam: ['video', '.mp4', '.mov', '.avi', '.mkv', '.webm', '.mxf'],\n business_center: ['application'],\n audio_file: ['audio'],\n text_snippet: ['text'],\n filter_none: ['sequence'],\n font_download: ['font'],\n deployed_code: ['model', '.obj', '.abc', '.stl', '.fbx', '.gltf', '.glb', '.usd'],\n}\n\nconst getIconForType = (type: string): string => {\n for (const [icon, keywords] of Object.entries(fileIcons)) {\n if (keywords.some((keyword) => type.includes(keyword))) {\n return icon\n }\n }\n return 'draft'\n}\n\nconst FileUploadCard = ({\n name,\n mime,\n src,\n unsavedAnnotation,\n savedAnnotation,\n size,\n progress,\n onRemove,\n isCompact,\n isDownloadable = false,\n onExpand,\n onJumpTo,\n className,\n ...props\n}: FileUploadCardProps) => {\n const inProgress = progress && progress < 100\n\n const [imageError, setImageError] = useState(false)\n const { feedAnnotationsEnabled } = useDetailsPanelContext()\n\n // split name and file extension\n const nameParts = name.split('.')\n const extension = nameParts.pop() || ''\n const fileName = nameParts.join('.')\n\n const isPreviewable = isFilePreviewable(mime || '.' + extension)\n const isImage = mime?.includes('image/') || Boolean(unsavedAnnotation)\n\n const downloadComponent = (\n <>\n <span className=\"size\">{getFileSizeString(size)}</span>\n <Icon icon=\"download\" className=\"download-icon\" />\n </>\n )\n\n const someAnnotation = unsavedAnnotation ?? savedAnnotation\n\n return (\n <Styled.File\n className={clsx(className, {\n compact: isCompact,\n isDownloadable,\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n {...props}\n >\n <Styled.ContentWrapper\n className={clsx('content-wrapper', {\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n >\n <Icon icon={getIconForType(mime || '.' + extension)} className=\"type-icon\" />\n {isImage && src && (\n <Styled.ImageWrapper\n className={clsx({\n 'image-wrapper': true,\n isDownloadable: isDownloadable || isPreviewable || unsavedAnnotation,\n })}\n >\n <img\n src={src}\n onError={() => setImageError(true)}\n style={{\n display: imageError ? 'none' : 'block',\n }}\n />\n </Styled.ImageWrapper>\n )}\n <Styled.Buttons className=\"expand-buttons\">\n {isPreviewable && (\n <Styled.ExpandButton\n data-tooltip=\"Open preview\"\n icon=\"open_in_full\"\n variant=\"nav\"\n onClick={onExpand}\n />\n )}\n {(unsavedAnnotation || (feedAnnotationsEnabled && savedAnnotation)) && (\n <Styled.ExpandButton\n data-tooltip=\"Jump to annotation\"\n icon=\"play_circle\"\n variant=\"nav\"\n onClick={onJumpTo}\n />\n )}\n </Styled.Buttons>\n </Styled.ContentWrapper>\n <Styled.Footer className={clsx({ inProgress, isPreviewable, isDownloadable })}>\n <span className=\"progress\" style={{ right: `${100 - progress}%` }} />\n <div className=\"name-wrapper\">\n {someAnnotation ? (\n <span className=\"name\">\n <Icon icon=\"draw\" />\n {someAnnotation.range[0]}\n {someAnnotation.range[1] !== someAnnotation.range[0] &&\n ` - ${someAnnotation.range[1]}`}\n </span>\n ) : (\n <span className=\"name\">\n {fileName}\n <span className=\"extension\">.{extension}</span>\n </span>\n )}\n </div>\n\n {isDownloadable &&\n (!onRemove ? (\n <a href={src} download className=\"download\">\n {downloadComponent}\n </a>\n ) : (\n <div className=\"download\">{downloadComponent}</div>\n ))}\n </Styled.Footer>\n {onRemove && <Button className=\"remove\" onClick={onRemove} icon=\"close\" />}\n </Styled.File>\n )\n}\n\nexport default FileUploadCard\n"],"names":["jsxs","Fragment","jsx","Styled.File","Styled.ContentWrapper","Styled.ImageWrapper","Styled.Buttons","Styled.ExpandButton","Styled.Footer"],"mappings":"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"}
1
+ {"version":3,"file":"FileUploadCard.es.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadCard/FileUploadCard.tsx"],"sourcesContent":["import { Button, getFileSizeString, Icon } from '@ynput/ayon-react-components'\nimport * as Styled from './FileUploadCard.styled'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport { isFilePreviewable } from '../FileUploadPreview'\nimport { SavedAnnotationMetadata } from '@shared/containers'\nimport { useDetailsPanelContext } from '@shared/context'\nimport { AnnotationPreview } from '../CommentInput/hooks/useAnnotationsSync'\n\nexport interface FileUploadCardProps extends React.HTMLAttributes<HTMLDivElement> {\n name: string\n mime?: string\n src?: string\n unsavedAnnotation?: AnnotationPreview\n savedAnnotation?: SavedAnnotationMetadata\n size: number\n progress: number\n onRemove?: () => void\n isCompact?: boolean\n isDownloadable?: boolean\n onExpand?: () => void\n onJumpTo?: () => void\n}\n\nconst fileIcons: { [key: string]: string[] } = {\n // special cases\n description: ['doc'],\n folder_zip: ['zip'],\n code_blocks: [\n 'json',\n 'javascript',\n 'python',\n 'html',\n 'css',\n '.py',\n '.js',\n '.html',\n '.css',\n '.json',\n '.ts',\n ],\n brush: ['.psd', '.ai', '.xd', '.sketch'],\n '3d_rotation': [\n '.mb',\n '.ma',\n '.c4d',\n '.blend',\n '.max',\n '.3ds',\n '.lwo',\n '.lws',\n '.lxo',\n '.hip',\n '.hda',\n ],\n theaters: ['.aep', '.tpl', '.clip', '.nk', '.fusion', '.prproj', '.spsm', '.drp'],\n picture_as_pdf: ['pdf', '.pdf'],\n // default\n image: ['image', '.png', '.jpg', '.jpeg', '.gif', '.svg', '.webp'],\n videocam: ['video', '.mp4', '.mov', '.avi', '.mkv', '.webm', '.mxf'],\n business_center: ['application'],\n audio_file: ['audio'],\n text_snippet: ['text'],\n filter_none: ['sequence'],\n font_download: ['font'],\n deployed_code: ['model', '.obj', '.abc', '.stl', '.fbx', '.gltf', '.glb', '.usd'],\n}\n\nconst getIconForType = (type: string): string => {\n for (const [icon, keywords] of Object.entries(fileIcons)) {\n if (keywords.some((keyword) => type.includes(keyword))) {\n return icon\n }\n }\n return 'draft'\n}\n\nconst FileUploadCard = ({\n name,\n mime,\n src,\n unsavedAnnotation,\n savedAnnotation,\n size,\n progress,\n onRemove,\n isCompact,\n isDownloadable = false,\n onExpand,\n onJumpTo,\n className,\n ...props\n}: FileUploadCardProps) => {\n const inProgress = progress && progress < 100\n\n const [imageError, setImageError] = useState(false)\n const { feedAnnotationsEnabled } = useDetailsPanelContext()\n\n // split name and file extension\n const nameParts = name.split('.')\n const extension = nameParts.pop() || ''\n const fileName = nameParts.join('.')\n\n const isPreviewable = isFilePreviewable(mime || '.' + extension)\n const isImage = mime?.includes('image/') || Boolean(unsavedAnnotation)\n\n const downloadComponent = (\n <>\n <span className=\"size\">{getFileSizeString(size)}</span>\n <Icon icon=\"download\" className=\"download-icon\" />\n </>\n )\n\n const someAnnotation = unsavedAnnotation ?? savedAnnotation\n\n return (\n <Styled.File\n className={clsx(className, {\n compact: isCompact,\n isDownloadable,\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n {...props}\n >\n <Styled.ContentWrapper\n className={clsx('content-wrapper', {\n isPreviewable,\n isUnsavedAnnotation: Boolean(unsavedAnnotation),\n })}\n >\n <Icon icon={getIconForType(mime || '.' + extension)} className=\"type-icon\" />\n {isImage && src && (\n <Styled.ImageWrapper\n className={clsx({\n 'image-wrapper': true,\n isDownloadable: isDownloadable || isPreviewable || unsavedAnnotation,\n })}\n >\n <img\n src={src}\n onError={() => setImageError(true)}\n style={{\n display: imageError ? 'none' : 'block',\n }}\n />\n </Styled.ImageWrapper>\n )}\n <Styled.Buttons className=\"expand-buttons\">\n {isPreviewable && (\n <Styled.ExpandButton\n data-tooltip=\"Open preview\"\n icon=\"open_in_full\"\n variant=\"nav\"\n onClick={onExpand}\n />\n )}\n {(unsavedAnnotation || (feedAnnotationsEnabled && savedAnnotation)) && (\n <Styled.ExpandButton\n data-tooltip=\"Jump to annotation\"\n icon=\"play_circle\"\n variant=\"nav\"\n onClick={onJumpTo}\n />\n )}\n </Styled.Buttons>\n </Styled.ContentWrapper>\n <Styled.Footer className={clsx({ inProgress, isPreviewable, isDownloadable })}>\n <span className=\"progress\" style={{ right: `${100 - progress}%` }} />\n <div className=\"name-wrapper\">\n {someAnnotation ? (\n <span className=\"name\">\n <Icon icon=\"draw\" />\n {someAnnotation.range[0]}\n {someAnnotation.range[1] !== someAnnotation.range[0] &&\n ` - ${someAnnotation.range[1]}`}\n </span>\n ) : (\n <span className=\"name\">\n {fileName}\n <span className=\"extension\">.{extension}</span>\n </span>\n )}\n </div>\n\n {isDownloadable &&\n (!onRemove ? (\n <a href={src} target=\"_blank\" rel=\"noopener noreferrer\" className=\"download\">\n {downloadComponent}\n </a>\n ) : (\n <div className=\"download\">{downloadComponent}</div>\n ))}\n </Styled.Footer>\n {onRemove && <Button className=\"remove\" onClick={onRemove} icon=\"close\" />}\n </Styled.File>\n )\n}\n\nexport default FileUploadCard\n"],"names":["jsxs","Fragment","jsx","Styled.File","Styled.ContentWrapper","Styled.ImageWrapper","Styled.Buttons","Styled.ExpandButton","Styled.Footer"],"mappings":"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"}
@@ -126,7 +126,14 @@ const FileUploadPreview = ({
126
126
  onClick: handleNavigateToPrevious
127
127
  }
128
128
  ),
129
- /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx("div", { style: { zIndex: zIndex + 1 }, children: /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(MimeComponent, { file, fullPreviews }) }),
129
+ /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
130
+ FileUploadPreview_styled.ScrollableContent,
131
+ {
132
+ style: { zIndex: zIndex + 1 },
133
+ className: clsx({ scrollable: !isImage }),
134
+ children: /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(MimeComponent, { file, fullPreviews })
135
+ }
136
+ ),
130
137
  /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
131
138
  ayonReactComponents.Icon,
132
139
  {
@@ -1 +1 @@
1
- {"version":3,"file":"FileUploadPreview.cjs.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.tsx"],"sourcesContent":["import { useEffect, useRef } from 'react'\nimport { getFileURL } from './fileUtils'\nimport ImageMime from './Mimes/ImageMime'\nimport TextMime from './Mimes/TextMime'\nimport clsx from 'clsx'\nimport { Icon } from '@ynput/ayon-react-components'\nimport useAttachmentNavigation from './hooks/useAttachmentNavigation'\nimport * as Styled from './FileUploadPreview.styled'\n\nexport type MimeTypeDefinition = {\n component: React.FC<any> | null\n mimeTypes: string[]\n fullPreviews?: string[]\n id: string\n callback?: (file: any) => void\n}\n\n// define expandable mime types and their components\nexport const expandableMimeTypes: { [key: string]: MimeTypeDefinition } = {\n image: {\n component: ImageMime,\n mimeTypes: ['image/'],\n fullPreviews: ['png', 'jpg', 'jpeg', 'gif', 'svg', 'webp'],\n id: 'image',\n },\n text: {\n component: TextMime,\n mimeTypes: ['text/', 'application/json', 'scss', 'jsx'],\n id: 'text',\n },\n pdf: {\n component: null,\n mimeTypes: ['pdf'],\n id: 'pdf',\n callback: (file: any) => window.open(getFileURL(file.id, file.projectName), '_blank'),\n },\n}\n\nexport const isFilePreviewable = (mime = '', ext = '') =>\n Object.values(expandableMimeTypes).some(({ mimeTypes = [] }) =>\n mimeTypes.some((type) => (mime || ext)?.includes(type)),\n )\n\ninterface FileUploadPreviewProps {\n files: any[] // replace with correct type\n index: number\n activityId: string\n projectName: string\n onFilePreviewClose: () => void\n onNavigate: (payload: any) => void // replace with correct type\n}\n\nconst FileUploadPreview: React.FC<FileUploadPreviewProps> = ({\n files,\n index,\n activityId,\n projectName,\n onFilePreviewClose,\n onNavigate,\n}) => {\n const {\n canNavigateDown,\n canNavigateUp,\n canNavigateLeft,\n canNavigateRight,\n getByIndexActivity,\n navigateUp,\n navigateDown,\n navigateLeft,\n navigateRight,\n } = useAttachmentNavigation({ files, index, activityId, onNavigate })\n const file = { ...getByIndexActivity(activityId, index), projectName }\n const { id, mime, extension, name } = file\n\n // when dialog open, focus on the dialog\n // we do this so that the user can navigate with the keyboard (esc works)\n const dialogRef = useRef<HTMLDivElement>(null)\n useEffect(() => {\n if (id && projectName) {\n dialogRef.current?.focus()\n }\n }, [id, projectName])\n\n const handleClose = () => {\n onFilePreviewClose()\n }\n\n if (!id || !projectName) return null\n\n // get the correct mime type component based on mimeTypes match\n const previewable = Object.values(expandableMimeTypes).find(({ mimeTypes }) =>\n mimeTypes.some((type) => (mime || extension)?.includes(type)),\n )\n\n // @ts-ignore\n const { component: MimeComponent, id: typeId, callback, fullPreviews } = previewable || {}\n\n // if there is a callback, run it and return null\n // mainly for pdfs\n if (callback) {\n callback(file)\n return null\n }\n\n const handleNavigateToPrevActivity = () => canNavigateUp() && navigateUp()\n const handleNavigateToNextActivity = () => canNavigateDown() && navigateDown()\n const handleNavigateToPrevious = () => canNavigateLeft() && navigateLeft()\n const handleNavigateToNext = () => canNavigateRight() && navigateRight()\n\n const isImage = typeId === 'image'\n const zIndex = 50\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (e.code === 'ArrowUp') {\n handleNavigateToPrevActivity()\n }\n if (e.code === 'ArrowDown') {\n handleNavigateToNextActivity()\n }\n if (e.code === 'ArrowRight') {\n handleNavigateToNext()\n }\n if (e.code === 'ArrowLeft') {\n handleNavigateToPrevious()\n }\n if (e.key === 'Escape') {\n e.preventDefault()\n handleClose()\n }\n }\n\n if (!MimeComponent) {\n return null\n }\n\n return (\n <Styled.DialogWrapper\n onKeyDown={handleKeyDown}\n size=\"full\"\n isOpen={!!(id && projectName)}\n onClose={handleClose}\n hideCancelButton={isImage}\n ref={dialogRef}\n className={clsx({ isImage }, 'block-shortcuts')}\n header={isImage ? null : name}\n >\n <div style={{ position: 'absolute', inset: 0, zIndex: zIndex }} onClick={handleClose}></div>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_left\"\n className={clsx('navIcon', 'left', { disabled: !canNavigateLeft() })}\n onClick={handleNavigateToPrevious}\n />\n\n <div style={{ zIndex: zIndex + 1 }}>\n <MimeComponent file={file} fullPreviews={fullPreviews} />\n </div>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_right\"\n className={clsx('navIcon', 'right', { disabled: !canNavigateRight() })}\n onClick={handleNavigateToNext}\n />\n </Styled.DialogWrapper>\n )\n}\n\nexport default FileUploadPreview\n"],"names":["getFileURL","useRef","useEffect","jsxs","Styled.DialogWrapper","jsx","Icon"],"mappings":"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"}
1
+ {"version":3,"file":"FileUploadPreview.cjs.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.tsx"],"sourcesContent":["import { useEffect, useRef } from 'react'\nimport { getFileURL } from './fileUtils'\nimport ImageMime from './Mimes/ImageMime'\nimport TextMime from './Mimes/TextMime'\nimport clsx from 'clsx'\nimport { Icon } from '@ynput/ayon-react-components'\nimport useAttachmentNavigation from './hooks/useAttachmentNavigation'\nimport * as Styled from './FileUploadPreview.styled'\n\nexport type MimeTypeDefinition = {\n component: React.FC<any> | null\n mimeTypes: string[]\n fullPreviews?: string[]\n id: string\n callback?: (file: any) => void\n}\n\n// define expandable mime types and their components\nexport const expandableMimeTypes: { [key: string]: MimeTypeDefinition } = {\n image: {\n component: ImageMime,\n mimeTypes: ['image/'],\n fullPreviews: ['png', 'jpg', 'jpeg', 'gif', 'svg', 'webp'],\n id: 'image',\n },\n text: {\n component: TextMime,\n mimeTypes: ['text/', 'application/json', 'scss', 'jsx'],\n id: 'text',\n },\n pdf: {\n component: null,\n mimeTypes: ['pdf'],\n id: 'pdf',\n callback: (file: any) => window.open(getFileURL(file.id, file.projectName), '_blank'),\n },\n}\n\nexport const isFilePreviewable = (mime = '', ext = '') =>\n Object.values(expandableMimeTypes).some(({ mimeTypes = [] }) =>\n mimeTypes.some((type) => (mime || ext)?.includes(type)),\n )\n\ninterface FileUploadPreviewProps {\n files: any[] // replace with correct type\n index: number\n activityId: string\n projectName: string\n onFilePreviewClose: () => void\n onNavigate: (payload: any) => void // replace with correct type\n}\n\nconst FileUploadPreview: React.FC<FileUploadPreviewProps> = ({\n files,\n index,\n activityId,\n projectName,\n onFilePreviewClose,\n onNavigate,\n}) => {\n const {\n canNavigateDown,\n canNavigateUp,\n canNavigateLeft,\n canNavigateRight,\n getByIndexActivity,\n navigateUp,\n navigateDown,\n navigateLeft,\n navigateRight,\n } = useAttachmentNavigation({ files, index, activityId, onNavigate })\n const file = { ...getByIndexActivity(activityId, index), projectName }\n const { id, mime, extension, name } = file\n\n // when dialog open, focus on the dialog\n // we do this so that the user can navigate with the keyboard (esc works)\n const dialogRef = useRef<HTMLDivElement>(null)\n useEffect(() => {\n if (id && projectName) {\n dialogRef.current?.focus()\n }\n }, [id, projectName])\n\n const handleClose = () => {\n onFilePreviewClose()\n }\n\n if (!id || !projectName) return null\n\n // get the correct mime type component based on mimeTypes match\n const previewable = Object.values(expandableMimeTypes).find(({ mimeTypes }) =>\n mimeTypes.some((type) => (mime || extension)?.includes(type)),\n )\n\n // @ts-ignore\n const { component: MimeComponent, id: typeId, callback, fullPreviews } = previewable || {}\n\n // if there is a callback, run it and return null\n // mainly for pdfs\n if (callback) {\n callback(file)\n return null\n }\n\n const handleNavigateToPrevActivity = () => canNavigateUp() && navigateUp()\n const handleNavigateToNextActivity = () => canNavigateDown() && navigateDown()\n const handleNavigateToPrevious = () => canNavigateLeft() && navigateLeft()\n const handleNavigateToNext = () => canNavigateRight() && navigateRight()\n\n const isImage = typeId === 'image'\n const zIndex = 50\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (e.code === 'ArrowUp') {\n handleNavigateToPrevActivity()\n }\n if (e.code === 'ArrowDown') {\n handleNavigateToNextActivity()\n }\n if (e.code === 'ArrowRight') {\n handleNavigateToNext()\n }\n if (e.code === 'ArrowLeft') {\n handleNavigateToPrevious()\n }\n if (e.key === 'Escape') {\n e.preventDefault()\n handleClose()\n }\n }\n\n if (!MimeComponent) {\n return null\n }\n\n return (\n <Styled.DialogWrapper\n onKeyDown={handleKeyDown}\n size=\"full\"\n isOpen={!!(id && projectName)}\n onClose={handleClose}\n hideCancelButton={isImage}\n ref={dialogRef}\n className={clsx({ isImage }, 'block-shortcuts')}\n header={isImage ? null : name}\n >\n <div style={{ position: 'absolute', inset: 0, zIndex: zIndex }} onClick={handleClose}></div>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_left\"\n className={clsx('navIcon', 'left', { disabled: !canNavigateLeft() })}\n onClick={handleNavigateToPrevious}\n />\n\n <Styled.ScrollableContent\n style={{ zIndex: zIndex + 1 }}\n className={clsx({ scrollable: !isImage })}\n >\n <MimeComponent file={file} fullPreviews={fullPreviews} />\n </Styled.ScrollableContent>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_right\"\n className={clsx('navIcon', 'right', { disabled: !canNavigateRight() })}\n onClick={handleNavigateToNext}\n />\n </Styled.DialogWrapper>\n )\n}\n\nexport default FileUploadPreview\n"],"names":["getFileURL","useRef","useEffect","jsxs","Styled.DialogWrapper","jsx","Icon","Styled.ScrollableContent"],"mappings":"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"}
@@ -6,7 +6,7 @@ import TextMime from "./Mimes/TextMime.es.js";
6
6
  import clsx from "clsx";
7
7
  import { Icon } from "@ynput/ayon-react-components";
8
8
  import useAttachmentNavigation from "./hooks/useAttachmentNavigation.es.js";
9
- import { DialogWrapper } from "./FileUploadPreview.styled.es.js";
9
+ import { DialogWrapper, ScrollableContent } from "./FileUploadPreview.styled.es.js";
10
10
  const expandableMimeTypes = {
11
11
  image: {
12
12
  component: ImageMime,
@@ -124,7 +124,14 @@ const FileUploadPreview = ({
124
124
  onClick: handleNavigateToPrevious
125
125
  }
126
126
  ),
127
- /* @__PURE__ */ jsxRuntimeExports.jsx("div", { style: { zIndex: zIndex + 1 }, children: /* @__PURE__ */ jsxRuntimeExports.jsx(MimeComponent, { file, fullPreviews }) }),
127
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
128
+ ScrollableContent,
129
+ {
130
+ style: { zIndex: zIndex + 1 },
131
+ className: clsx({ scrollable: !isImage }),
132
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx(MimeComponent, { file, fullPreviews })
133
+ }
134
+ ),
128
135
  /* @__PURE__ */ jsxRuntimeExports.jsx(
129
136
  Icon,
130
137
  {
@@ -1 +1 @@
1
- {"version":3,"file":"FileUploadPreview.es.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.tsx"],"sourcesContent":["import { useEffect, useRef } from 'react'\nimport { getFileURL } from './fileUtils'\nimport ImageMime from './Mimes/ImageMime'\nimport TextMime from './Mimes/TextMime'\nimport clsx from 'clsx'\nimport { Icon } from '@ynput/ayon-react-components'\nimport useAttachmentNavigation from './hooks/useAttachmentNavigation'\nimport * as Styled from './FileUploadPreview.styled'\n\nexport type MimeTypeDefinition = {\n component: React.FC<any> | null\n mimeTypes: string[]\n fullPreviews?: string[]\n id: string\n callback?: (file: any) => void\n}\n\n// define expandable mime types and their components\nexport const expandableMimeTypes: { [key: string]: MimeTypeDefinition } = {\n image: {\n component: ImageMime,\n mimeTypes: ['image/'],\n fullPreviews: ['png', 'jpg', 'jpeg', 'gif', 'svg', 'webp'],\n id: 'image',\n },\n text: {\n component: TextMime,\n mimeTypes: ['text/', 'application/json', 'scss', 'jsx'],\n id: 'text',\n },\n pdf: {\n component: null,\n mimeTypes: ['pdf'],\n id: 'pdf',\n callback: (file: any) => window.open(getFileURL(file.id, file.projectName), '_blank'),\n },\n}\n\nexport const isFilePreviewable = (mime = '', ext = '') =>\n Object.values(expandableMimeTypes).some(({ mimeTypes = [] }) =>\n mimeTypes.some((type) => (mime || ext)?.includes(type)),\n )\n\ninterface FileUploadPreviewProps {\n files: any[] // replace with correct type\n index: number\n activityId: string\n projectName: string\n onFilePreviewClose: () => void\n onNavigate: (payload: any) => void // replace with correct type\n}\n\nconst FileUploadPreview: React.FC<FileUploadPreviewProps> = ({\n files,\n index,\n activityId,\n projectName,\n onFilePreviewClose,\n onNavigate,\n}) => {\n const {\n canNavigateDown,\n canNavigateUp,\n canNavigateLeft,\n canNavigateRight,\n getByIndexActivity,\n navigateUp,\n navigateDown,\n navigateLeft,\n navigateRight,\n } = useAttachmentNavigation({ files, index, activityId, onNavigate })\n const file = { ...getByIndexActivity(activityId, index), projectName }\n const { id, mime, extension, name } = file\n\n // when dialog open, focus on the dialog\n // we do this so that the user can navigate with the keyboard (esc works)\n const dialogRef = useRef<HTMLDivElement>(null)\n useEffect(() => {\n if (id && projectName) {\n dialogRef.current?.focus()\n }\n }, [id, projectName])\n\n const handleClose = () => {\n onFilePreviewClose()\n }\n\n if (!id || !projectName) return null\n\n // get the correct mime type component based on mimeTypes match\n const previewable = Object.values(expandableMimeTypes).find(({ mimeTypes }) =>\n mimeTypes.some((type) => (mime || extension)?.includes(type)),\n )\n\n // @ts-ignore\n const { component: MimeComponent, id: typeId, callback, fullPreviews } = previewable || {}\n\n // if there is a callback, run it and return null\n // mainly for pdfs\n if (callback) {\n callback(file)\n return null\n }\n\n const handleNavigateToPrevActivity = () => canNavigateUp() && navigateUp()\n const handleNavigateToNextActivity = () => canNavigateDown() && navigateDown()\n const handleNavigateToPrevious = () => canNavigateLeft() && navigateLeft()\n const handleNavigateToNext = () => canNavigateRight() && navigateRight()\n\n const isImage = typeId === 'image'\n const zIndex = 50\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (e.code === 'ArrowUp') {\n handleNavigateToPrevActivity()\n }\n if (e.code === 'ArrowDown') {\n handleNavigateToNextActivity()\n }\n if (e.code === 'ArrowRight') {\n handleNavigateToNext()\n }\n if (e.code === 'ArrowLeft') {\n handleNavigateToPrevious()\n }\n if (e.key === 'Escape') {\n e.preventDefault()\n handleClose()\n }\n }\n\n if (!MimeComponent) {\n return null\n }\n\n return (\n <Styled.DialogWrapper\n onKeyDown={handleKeyDown}\n size=\"full\"\n isOpen={!!(id && projectName)}\n onClose={handleClose}\n hideCancelButton={isImage}\n ref={dialogRef}\n className={clsx({ isImage }, 'block-shortcuts')}\n header={isImage ? null : name}\n >\n <div style={{ position: 'absolute', inset: 0, zIndex: zIndex }} onClick={handleClose}></div>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_left\"\n className={clsx('navIcon', 'left', { disabled: !canNavigateLeft() })}\n onClick={handleNavigateToPrevious}\n />\n\n <div style={{ zIndex: zIndex + 1 }}>\n <MimeComponent file={file} fullPreviews={fullPreviews} />\n </div>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_right\"\n className={clsx('navIcon', 'right', { disabled: !canNavigateRight() })}\n onClick={handleNavigateToNext}\n />\n </Styled.DialogWrapper>\n )\n}\n\nexport default FileUploadPreview\n"],"names":["jsxs","Styled.DialogWrapper","jsx"],"mappings":"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"}
1
+ {"version":3,"file":"FileUploadPreview.es.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.tsx"],"sourcesContent":["import { useEffect, useRef } from 'react'\nimport { getFileURL } from './fileUtils'\nimport ImageMime from './Mimes/ImageMime'\nimport TextMime from './Mimes/TextMime'\nimport clsx from 'clsx'\nimport { Icon } from '@ynput/ayon-react-components'\nimport useAttachmentNavigation from './hooks/useAttachmentNavigation'\nimport * as Styled from './FileUploadPreview.styled'\n\nexport type MimeTypeDefinition = {\n component: React.FC<any> | null\n mimeTypes: string[]\n fullPreviews?: string[]\n id: string\n callback?: (file: any) => void\n}\n\n// define expandable mime types and their components\nexport const expandableMimeTypes: { [key: string]: MimeTypeDefinition } = {\n image: {\n component: ImageMime,\n mimeTypes: ['image/'],\n fullPreviews: ['png', 'jpg', 'jpeg', 'gif', 'svg', 'webp'],\n id: 'image',\n },\n text: {\n component: TextMime,\n mimeTypes: ['text/', 'application/json', 'scss', 'jsx'],\n id: 'text',\n },\n pdf: {\n component: null,\n mimeTypes: ['pdf'],\n id: 'pdf',\n callback: (file: any) => window.open(getFileURL(file.id, file.projectName), '_blank'),\n },\n}\n\nexport const isFilePreviewable = (mime = '', ext = '') =>\n Object.values(expandableMimeTypes).some(({ mimeTypes = [] }) =>\n mimeTypes.some((type) => (mime || ext)?.includes(type)),\n )\n\ninterface FileUploadPreviewProps {\n files: any[] // replace with correct type\n index: number\n activityId: string\n projectName: string\n onFilePreviewClose: () => void\n onNavigate: (payload: any) => void // replace with correct type\n}\n\nconst FileUploadPreview: React.FC<FileUploadPreviewProps> = ({\n files,\n index,\n activityId,\n projectName,\n onFilePreviewClose,\n onNavigate,\n}) => {\n const {\n canNavigateDown,\n canNavigateUp,\n canNavigateLeft,\n canNavigateRight,\n getByIndexActivity,\n navigateUp,\n navigateDown,\n navigateLeft,\n navigateRight,\n } = useAttachmentNavigation({ files, index, activityId, onNavigate })\n const file = { ...getByIndexActivity(activityId, index), projectName }\n const { id, mime, extension, name } = file\n\n // when dialog open, focus on the dialog\n // we do this so that the user can navigate with the keyboard (esc works)\n const dialogRef = useRef<HTMLDivElement>(null)\n useEffect(() => {\n if (id && projectName) {\n dialogRef.current?.focus()\n }\n }, [id, projectName])\n\n const handleClose = () => {\n onFilePreviewClose()\n }\n\n if (!id || !projectName) return null\n\n // get the correct mime type component based on mimeTypes match\n const previewable = Object.values(expandableMimeTypes).find(({ mimeTypes }) =>\n mimeTypes.some((type) => (mime || extension)?.includes(type)),\n )\n\n // @ts-ignore\n const { component: MimeComponent, id: typeId, callback, fullPreviews } = previewable || {}\n\n // if there is a callback, run it and return null\n // mainly for pdfs\n if (callback) {\n callback(file)\n return null\n }\n\n const handleNavigateToPrevActivity = () => canNavigateUp() && navigateUp()\n const handleNavigateToNextActivity = () => canNavigateDown() && navigateDown()\n const handleNavigateToPrevious = () => canNavigateLeft() && navigateLeft()\n const handleNavigateToNext = () => canNavigateRight() && navigateRight()\n\n const isImage = typeId === 'image'\n const zIndex = 50\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (e.code === 'ArrowUp') {\n handleNavigateToPrevActivity()\n }\n if (e.code === 'ArrowDown') {\n handleNavigateToNextActivity()\n }\n if (e.code === 'ArrowRight') {\n handleNavigateToNext()\n }\n if (e.code === 'ArrowLeft') {\n handleNavigateToPrevious()\n }\n if (e.key === 'Escape') {\n e.preventDefault()\n handleClose()\n }\n }\n\n if (!MimeComponent) {\n return null\n }\n\n return (\n <Styled.DialogWrapper\n onKeyDown={handleKeyDown}\n size=\"full\"\n isOpen={!!(id && projectName)}\n onClose={handleClose}\n hideCancelButton={isImage}\n ref={dialogRef}\n className={clsx({ isImage }, 'block-shortcuts')}\n header={isImage ? null : name}\n >\n <div style={{ position: 'absolute', inset: 0, zIndex: zIndex }} onClick={handleClose}></div>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_left\"\n className={clsx('navIcon', 'left', { disabled: !canNavigateLeft() })}\n onClick={handleNavigateToPrevious}\n />\n\n <Styled.ScrollableContent\n style={{ zIndex: zIndex + 1 }}\n className={clsx({ scrollable: !isImage })}\n >\n <MimeComponent file={file} fullPreviews={fullPreviews} />\n </Styled.ScrollableContent>\n\n <Icon\n style={{ zIndex: zIndex + 1 }}\n icon=\"chevron_right\"\n className={clsx('navIcon', 'right', { disabled: !canNavigateRight() })}\n onClick={handleNavigateToNext}\n />\n </Styled.DialogWrapper>\n )\n}\n\nexport default FileUploadPreview\n"],"names":["jsxs","Styled.DialogWrapper","jsx","Styled.ScrollableContent"],"mappings":"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"}
@@ -14,6 +14,7 @@ const DialogWrapper = styled(ayonReactComponents.Dialog)`
14
14
  justify-content: center;
15
15
  align-content: center;
16
16
  padding-top: 0;
17
+ overflow: hidden;
17
18
  }
18
19
  .navIcon {
19
20
  position: absolute;
@@ -98,6 +99,14 @@ const Image = styled.img`
98
99
  min-width: 300px;
99
100
  background-color: var(--md-sys-color-surface-container-lowest);
100
101
  `;
102
+ const ScrollableContent = styled.div`
103
+ &.scrollable {
104
+ position: absolute;
105
+ inset: 56px;
106
+ overflow: auto;
107
+ }
108
+ `;
101
109
  exports.DialogWrapper = DialogWrapper;
102
110
  exports.Image = Image;
111
+ exports.ScrollableContent = ScrollableContent;
103
112
  //# sourceMappingURL=FileUploadPreview.styled.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FileUploadPreview.styled.cjs.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.ts"],"sourcesContent":["import { Dialog } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nexport const DialogWrapper = styled(Dialog)`\n min-height: 90vh;\n max-height: 90vh;\n min-width: min(90vw, 100%);\n max-width: 1000px;\n\n .body {\n flex-direction: row;\n flex-wrap: wrap;\n justify-content: center;\n align-content: center;\n padding-top: 0;\n }\n .navIcon {\n position: absolute;\n top: 50%;\n user-select: none;\n\n &.left {\n left: 0;\n translate: -100% -50%;\n }\n &.right {\n right: 0;\n translate: 100% -50%;\n }\n align-content: center;\n font-size: 60px;\n &:hover {\n cursor: pointer;\n color: var(--md-sys-color-primary);\n }\n &.disabled {\n color: var(--md-sys-color-outline-variant);\n &:hover {\n cursor: not-allowed;\n }\n }\n }\n\n /* custom image styles */\n &.isImage {\n /* remove min/max height */\n\n background-color: unset;\n border-radius: 0;\n\n width: 0;\n\n .cancelButton {\n top: 1px;\n right: 1px;\n background-color: var(--md-sys-color-surface-container-highest);\n }\n\n /* Backdrop property affects inactive area around modal */\n &::backdrop {\n background-color: rgba(0, 0, 0, 0.7);\n }\n\n .header {\n display: none;\n }\n\n .body {\n padding: 0;\n align-items: stretch;\n user-select: none;\n overflow: hidden;\n }\n\n footer {\n display: none;\n }\n\n /* remove focus outline */\n &:focus {\n outline: none;\n }\n }\n /* remove focus outline */\n &:focus-visible {\n outline: none;\n }\n`\n\nexport const Image = styled.img`\n height: 100%;\n width: 100%;\n\n width: max-content;\n height: max-content;\n max-height: 80vh;\n max-width: 90vw;\n min-width: 300px;\n background-color: var(--md-sys-color-surface-container-lowest);\n`\n"],"names":["Dialog"],"mappings":";;;;AAGa,MAAA,gBAAgB,OAAOA,0BAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAsFnC,MAAM,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;"}
1
+ {"version":3,"file":"FileUploadPreview.styled.cjs.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.ts"],"sourcesContent":["import { Dialog } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nexport const DialogWrapper = styled(Dialog)`\n min-height: 90vh;\n max-height: 90vh;\n min-width: min(90vw, 100%);\n max-width: 1000px;\n\n .body {\n flex-direction: row;\n flex-wrap: wrap;\n justify-content: center;\n align-content: center;\n padding-top: 0;\n overflow: hidden;\n }\n .navIcon {\n position: absolute;\n top: 50%;\n user-select: none;\n\n &.left {\n left: 0;\n translate: -100% -50%;\n }\n &.right {\n right: 0;\n translate: 100% -50%;\n }\n align-content: center;\n font-size: 60px;\n &:hover {\n cursor: pointer;\n color: var(--md-sys-color-primary);\n }\n &.disabled {\n color: var(--md-sys-color-outline-variant);\n &:hover {\n cursor: not-allowed;\n }\n }\n }\n\n /* custom image styles */\n &.isImage {\n /* remove min/max height */\n\n background-color: unset;\n border-radius: 0;\n\n width: 0;\n\n .cancelButton {\n top: 1px;\n right: 1px;\n background-color: var(--md-sys-color-surface-container-highest);\n }\n\n /* Backdrop property affects inactive area around modal */\n &::backdrop {\n background-color: rgba(0, 0, 0, 0.7);\n }\n\n .header {\n display: none;\n }\n\n .body {\n padding: 0;\n align-items: stretch;\n user-select: none;\n overflow: hidden;\n }\n\n footer {\n display: none;\n }\n\n /* remove focus outline */\n &:focus {\n outline: none;\n }\n }\n /* remove focus outline */\n &:focus-visible {\n outline: none;\n }\n`\n\nexport const Image = styled.img`\n height: 100%;\n width: 100%;\n\n width: max-content;\n height: max-content;\n max-height: 80vh;\n max-width: 90vw;\n min-width: 300px;\n background-color: var(--md-sys-color-surface-container-lowest);\n`\n\nexport const ScrollableContent = styled.div`\n &.scrollable {\n position: absolute;\n inset: 56px;\n overflow: auto;\n }\n`\n"],"names":["Dialog"],"mappings":";;;;AAGa,MAAA,gBAAgB,OAAOA,0BAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAuFnC,MAAM,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYrB,MAAM,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;;"}
@@ -12,6 +12,7 @@ const DialogWrapper = styled(Dialog)`
12
12
  justify-content: center;
13
13
  align-content: center;
14
14
  padding-top: 0;
15
+ overflow: hidden;
15
16
  }
16
17
  .navIcon {
17
18
  position: absolute;
@@ -96,8 +97,16 @@ const Image = styled.img`
96
97
  min-width: 300px;
97
98
  background-color: var(--md-sys-color-surface-container-lowest);
98
99
  `;
100
+ const ScrollableContent = styled.div`
101
+ &.scrollable {
102
+ position: absolute;
103
+ inset: 56px;
104
+ overflow: auto;
105
+ }
106
+ `;
99
107
  export {
100
108
  DialogWrapper,
101
- Image
109
+ Image,
110
+ ScrollableContent
102
111
  };
103
112
  //# sourceMappingURL=FileUploadPreview.styled.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FileUploadPreview.styled.es.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.ts"],"sourcesContent":["import { Dialog } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nexport const DialogWrapper = styled(Dialog)`\n min-height: 90vh;\n max-height: 90vh;\n min-width: min(90vw, 100%);\n max-width: 1000px;\n\n .body {\n flex-direction: row;\n flex-wrap: wrap;\n justify-content: center;\n align-content: center;\n padding-top: 0;\n }\n .navIcon {\n position: absolute;\n top: 50%;\n user-select: none;\n\n &.left {\n left: 0;\n translate: -100% -50%;\n }\n &.right {\n right: 0;\n translate: 100% -50%;\n }\n align-content: center;\n font-size: 60px;\n &:hover {\n cursor: pointer;\n color: var(--md-sys-color-primary);\n }\n &.disabled {\n color: var(--md-sys-color-outline-variant);\n &:hover {\n cursor: not-allowed;\n }\n }\n }\n\n /* custom image styles */\n &.isImage {\n /* remove min/max height */\n\n background-color: unset;\n border-radius: 0;\n\n width: 0;\n\n .cancelButton {\n top: 1px;\n right: 1px;\n background-color: var(--md-sys-color-surface-container-highest);\n }\n\n /* Backdrop property affects inactive area around modal */\n &::backdrop {\n background-color: rgba(0, 0, 0, 0.7);\n }\n\n .header {\n display: none;\n }\n\n .body {\n padding: 0;\n align-items: stretch;\n user-select: none;\n overflow: hidden;\n }\n\n footer {\n display: none;\n }\n\n /* remove focus outline */\n &:focus {\n outline: none;\n }\n }\n /* remove focus outline */\n &:focus-visible {\n outline: none;\n }\n`\n\nexport const Image = styled.img`\n height: 100%;\n width: 100%;\n\n width: max-content;\n height: max-content;\n max-height: 80vh;\n max-width: 90vw;\n min-width: 300px;\n background-color: var(--md-sys-color-surface-container-lowest);\n`\n"],"names":[],"mappings":";;AAGa,MAAA,gBAAgB,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAsFnC,MAAM,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
1
+ {"version":3,"file":"FileUploadPreview.styled.es.js","sources":["../../../../../../../src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.ts"],"sourcesContent":["import { Dialog } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nexport const DialogWrapper = styled(Dialog)`\n min-height: 90vh;\n max-height: 90vh;\n min-width: min(90vw, 100%);\n max-width: 1000px;\n\n .body {\n flex-direction: row;\n flex-wrap: wrap;\n justify-content: center;\n align-content: center;\n padding-top: 0;\n overflow: hidden;\n }\n .navIcon {\n position: absolute;\n top: 50%;\n user-select: none;\n\n &.left {\n left: 0;\n translate: -100% -50%;\n }\n &.right {\n right: 0;\n translate: 100% -50%;\n }\n align-content: center;\n font-size: 60px;\n &:hover {\n cursor: pointer;\n color: var(--md-sys-color-primary);\n }\n &.disabled {\n color: var(--md-sys-color-outline-variant);\n &:hover {\n cursor: not-allowed;\n }\n }\n }\n\n /* custom image styles */\n &.isImage {\n /* remove min/max height */\n\n background-color: unset;\n border-radius: 0;\n\n width: 0;\n\n .cancelButton {\n top: 1px;\n right: 1px;\n background-color: var(--md-sys-color-surface-container-highest);\n }\n\n /* Backdrop property affects inactive area around modal */\n &::backdrop {\n background-color: rgba(0, 0, 0, 0.7);\n }\n\n .header {\n display: none;\n }\n\n .body {\n padding: 0;\n align-items: stretch;\n user-select: none;\n overflow: hidden;\n }\n\n footer {\n display: none;\n }\n\n /* remove focus outline */\n &:focus {\n outline: none;\n }\n }\n /* remove focus outline */\n &:focus-visible {\n outline: none;\n }\n`\n\nexport const Image = styled.img`\n height: 100%;\n width: 100%;\n\n width: max-content;\n height: max-content;\n max-height: 80vh;\n max-width: 90vw;\n min-width: 300px;\n background-color: var(--md-sys-color-surface-container-lowest);\n`\n\nexport const ScrollableContent = styled.div`\n &.scrollable {\n position: absolute;\n inset: 56px;\n overflow: auto;\n }\n`\n"],"names":[],"mappings":";;AAGa,MAAA,gBAAgB,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAuFnC,MAAM,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYrB,MAAM,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
@@ -30,6 +30,7 @@ require("../../../../../context/pip/PiPProvider.cjs.js");
30
30
  require("../../../../../context/pip/PiPWrapper.cjs.js");
31
31
  require("../../../../../context/AddonProjectContext.cjs.js");
32
32
  require("../../../../../context/AddonContext.cjs.js");
33
+ require("../../../../../context/PowerpackContext.cjs.js");
33
34
  require("../../CommentInput/quillToMarkdown.cjs.js");
34
35
  require("../../ActivityComment/ActivityComment.styled.cjs.js");
35
36
  require("../../ActivityCheckbox/ActivityCheckbox.styled.cjs.js");
@@ -1 +1 @@
1
- {"version":3,"file":"EntityTooltip.cjs.js","sources":["../../../../../../../../src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.tsx"],"sourcesContent":["import * as Styled from './EntityTooltip.styled'\nimport { productTypes } from '@shared/util'\nimport { useFeedContext } from '@shared/containers/Feed'\nimport { Status } from '@shared/containers/ProjectTreeTable/types/project'\n\ninterface ThumbnailUrlParams {\n entityId?: string\n entityType?: string\n thumbnailId?: string\n updatedAt?: string\n projectName?: string\n}\n\nconst getThumbnailUrl = ({\n entityId,\n entityType,\n thumbnailId,\n updatedAt,\n projectName,\n}: ThumbnailUrlParams) => {\n // If projectName is not provided or neither thumbnailId nor entityId and entityType are provided, return null\n if (!projectName || (!thumbnailId && (!entityId || !entityType))) return null\n\n // Construct the updatedAt query parameter if updatedAt is provided\n const updatedAtQueryParam = updatedAt ? `?updatedAt=${updatedAt}` : ''\n\n // If entityId and entityType are provided, construct the URL using them\n if (entityId && entityType) {\n const entityUrl = `/api/projects/${projectName}/${entityType}s/${entityId}/thumbnail`\n return `${entityUrl}${updatedAtQueryParam}`\n }\n\n // If entityId and entityType are not provided, fallback on thumbnailId\n const thumbnailUrl = `/api/projects/${projectName}/thumbnails/${thumbnailId}`\n return `${thumbnailUrl}${updatedAtQueryParam}`\n}\n\ninterface EntityTooltipProps {\n type?: string\n id?: string\n pos?: {\n left?: number\n top?: number\n }\n projectName?: string\n projectInfo?: any\n}\n\nconst EntityTooltip: React.FC<EntityTooltipProps> = ({\n type,\n id,\n pos: { left = 0, top = 0 } = {},\n}) => {\n const { entityTooltipData, isFetchingTooltip, projectInfo, projectName } = useFeedContext()\n\n const width = 220\n\n // check x is not offScreen\n if (left + width / 2 > window.innerWidth) left = window.innerWidth - width / 2\n\n const {\n title,\n subTitle,\n path,\n taskType,\n productType,\n users = [],\n thumbnailId,\n updatedAt,\n status,\n } = entityTooltipData || {}\n\n const { taskTypes = [], statuses = [] } = projectInfo\n\n const taskIcon = taskTypes.find((type: any) => type.name === taskType)?.icon\n const statusObject = statuses.find((s: Status) => s.name === status)\n const thumbnailUrl = getThumbnailUrl({\n entityId: id,\n entityType: type,\n thumbnailId,\n updatedAt,\n projectName,\n })\n const productTypeData = productTypes[productType as keyof typeof productTypes]\n const productIcon = productTypeData?.icon || 'layers'\n\n const icons: Record<string, string | undefined> = {\n task: taskIcon,\n version: productIcon,\n }\n\n if (!type) return null\n\n return (\n <Styled.TooltipEntityCard\n style={{ left, top, maxWidth: width }}\n title={title}\n header={subTitle}\n path={path}\n showPath\n status={statusObject}\n users={users}\n hidePriority\n isLoading={isFetchingTooltip}\n loadingSections={['header', 'title', 'users', 'status']}\n titleIcon={icons[type || '']}\n imageUrl={thumbnailUrl || undefined}\n />\n )\n}\n\nexport default EntityTooltip\n"],"names":["useFeedContext","type","jsx","Styled.TooltipEntityCard"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaA,MAAM,kBAAkB,CAAC;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA0B;AAEpB,MAAA,CAAC,eAAgB,CAAC,gBAAgB,CAAC,YAAY,CAAC,YAAqB,QAAA;AAGzE,QAAM,sBAAsB,YAAY,cAAc,SAAS,KAAK;AAGpE,MAAI,YAAY,YAAY;AAC1B,UAAM,YAAY,iBAAiB,WAAW,IAAI,UAAU,KAAK,QAAQ;AAClE,WAAA,GAAG,SAAS,GAAG,mBAAmB;AAAA,EAAA;AAI3C,QAAM,eAAe,iBAAiB,WAAW,eAAe,WAAW;AACpE,SAAA,GAAG,YAAY,GAAG,mBAAmB;AAC9C;AAaA,MAAM,gBAA8C,CAAC;AAAA,EACnD;AAAA,EACA;AAAA,EACA,KAAK,EAAE,OAAO,GAAG,MAAM,EAAA,IAAM,CAAA;AAC/B,MAAM;;AACJ,QAAM,EAAE,mBAAmB,mBAAmB,aAAa,YAAA,IAAgBA,YAAAA,eAAe;AAE1F,QAAM,QAAQ;AAGV,MAAA,OAAO,QAAQ,IAAI,OAAO,WAAmB,QAAA,OAAO,aAAa,QAAQ;AAEvE,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ,CAAC;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB,CAAC;AAE1B,QAAM,EAAE,YAAY,CAAA,GAAI,WAAW,CAAA,EAAO,IAAA;AAEpC,QAAA,YAAW,eAAU,KAAK,CAACC,UAAcA,MAAK,SAAS,QAAQ,MAApD,mBAAuD;AACxE,QAAM,eAAe,SAAS,KAAK,CAAC,MAAc,EAAE,SAAS,MAAM;AACnE,QAAM,eAAe,gBAAgB;AAAA,IACnC,UAAU;AAAA,IACV,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AACK,QAAA,kBAAkB,aAAa,WAAwC;AACvE,QAAA,eAAc,mDAAiB,SAAQ;AAE7C,QAAM,QAA4C;AAAA,IAChD,MAAM;AAAA,IACN,SAAS;AAAA,EACX;AAEI,MAAA,CAAC,KAAa,QAAA;AAGhB,SAAAC,2BAAA,kBAAA;AAAA,IAACC,qBAAO;AAAA,IAAP;AAAA,MACC,OAAO,EAAE,MAAM,KAAK,UAAU,MAAM;AAAA,MACpC;AAAA,MACA,QAAQ;AAAA,MACR;AAAA,MACA,UAAQ;AAAA,MACR,QAAQ;AAAA,MACR;AAAA,MACA,cAAY;AAAA,MACZ,WAAW;AAAA,MACX,iBAAiB,CAAC,UAAU,SAAS,SAAS,QAAQ;AAAA,MACtD,WAAW,MAAM,QAAQ,EAAE;AAAA,MAC3B,UAAU,gBAAgB;AAAA,IAAA;AAAA,EAC5B;AAEJ;;"}
1
+ {"version":3,"file":"EntityTooltip.cjs.js","sources":["../../../../../../../../src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.tsx"],"sourcesContent":["import * as Styled from './EntityTooltip.styled'\nimport { productTypes } from '@shared/util'\nimport { useFeedContext } from '@shared/containers/Feed'\nimport { Status } from '@shared/containers/ProjectTreeTable/types/project'\n\ninterface ThumbnailUrlParams {\n entityId?: string\n entityType?: string\n thumbnailId?: string\n updatedAt?: string\n projectName?: string\n}\n\nconst getThumbnailUrl = ({\n entityId,\n entityType,\n thumbnailId,\n updatedAt,\n projectName,\n}: ThumbnailUrlParams) => {\n // If projectName is not provided or neither thumbnailId nor entityId and entityType are provided, return null\n if (!projectName || (!thumbnailId && (!entityId || !entityType))) return null\n\n // Construct the updatedAt query parameter if updatedAt is provided\n const updatedAtQueryParam = updatedAt ? `?updatedAt=${updatedAt}` : ''\n\n // If entityId and entityType are provided, construct the URL using them\n if (entityId && entityType) {\n const entityUrl = `/api/projects/${projectName}/${entityType}s/${entityId}/thumbnail`\n return `${entityUrl}${updatedAtQueryParam}`\n }\n\n // If entityId and entityType are not provided, fallback on thumbnailId\n const thumbnailUrl = `/api/projects/${projectName}/thumbnails/${thumbnailId}`\n return `${thumbnailUrl}${updatedAtQueryParam}`\n}\n\ninterface EntityTooltipProps {\n type?: string\n id?: string\n pos?: {\n left?: number\n top?: number\n }\n projectName?: string\n projectInfo?: any\n}\n\nconst EntityTooltip: React.FC<EntityTooltipProps> = ({\n type,\n id,\n pos: { left = 0, top = 0 } = {},\n}) => {\n const { entityTooltipData, isFetchingTooltip, projectInfo, projectName } = useFeedContext()\n\n const width = 220\n\n // check x is not offScreen\n if (left + width / 2 > window.innerWidth) left = window.innerWidth - width / 2\n\n const {\n title,\n subTitle,\n path,\n taskType,\n productType,\n users = [],\n thumbnailId,\n updatedAt,\n status,\n } = entityTooltipData || {}\n\n const { taskTypes = [], statuses = [] } = projectInfo\n\n const taskIcon = taskTypes.find((type: any) => type.name === taskType)?.icon\n const statusObject = statuses.find((s: Status) => s.name === status)\n const thumbnailUrl = getThumbnailUrl({\n entityId: id,\n entityType: type,\n thumbnailId,\n updatedAt,\n projectName,\n })\n const productTypeData = productTypes[productType as keyof typeof productTypes]\n const productIcon = productTypeData?.icon || 'layers'\n\n const icons: Record<string, string | undefined> = {\n task: taskIcon,\n version: productIcon,\n }\n\n if (!type) return null\n\n return (\n <Styled.TooltipEntityCard\n style={{ left, top, maxWidth: width }}\n title={title}\n header={subTitle}\n path={path}\n showPath\n status={statusObject}\n users={users}\n hidePriority\n isLoading={isFetchingTooltip}\n loadingSections={['header', 'title', 'users', 'status']}\n titleIcon={icons[type || '']}\n imageUrl={thumbnailUrl || undefined}\n />\n )\n}\n\nexport default EntityTooltip\n"],"names":["useFeedContext","type","jsx","Styled.TooltipEntityCard"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaA,MAAM,kBAAkB,CAAC;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA0B;AAEpB,MAAA,CAAC,eAAgB,CAAC,gBAAgB,CAAC,YAAY,CAAC,YAAqB,QAAA;AAGzE,QAAM,sBAAsB,YAAY,cAAc,SAAS,KAAK;AAGpE,MAAI,YAAY,YAAY;AAC1B,UAAM,YAAY,iBAAiB,WAAW,IAAI,UAAU,KAAK,QAAQ;AAClE,WAAA,GAAG,SAAS,GAAG,mBAAmB;AAAA,EAAA;AAI3C,QAAM,eAAe,iBAAiB,WAAW,eAAe,WAAW;AACpE,SAAA,GAAG,YAAY,GAAG,mBAAmB;AAC9C;AAaA,MAAM,gBAA8C,CAAC;AAAA,EACnD;AAAA,EACA;AAAA,EACA,KAAK,EAAE,OAAO,GAAG,MAAM,EAAA,IAAM,CAAA;AAC/B,MAAM;;AACJ,QAAM,EAAE,mBAAmB,mBAAmB,aAAa,YAAA,IAAgBA,YAAAA,eAAe;AAE1F,QAAM,QAAQ;AAGV,MAAA,OAAO,QAAQ,IAAI,OAAO,WAAmB,QAAA,OAAO,aAAa,QAAQ;AAEvE,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ,CAAC;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB,CAAC;AAE1B,QAAM,EAAE,YAAY,CAAA,GAAI,WAAW,CAAA,EAAO,IAAA;AAEpC,QAAA,YAAW,eAAU,KAAK,CAACC,UAAcA,MAAK,SAAS,QAAQ,MAApD,mBAAuD;AACxE,QAAM,eAAe,SAAS,KAAK,CAAC,MAAc,EAAE,SAAS,MAAM;AACnE,QAAM,eAAe,gBAAgB;AAAA,IACnC,UAAU;AAAA,IACV,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AACK,QAAA,kBAAkB,aAAa,WAAwC;AACvE,QAAA,eAAc,mDAAiB,SAAQ;AAE7C,QAAM,QAA4C;AAAA,IAChD,MAAM;AAAA,IACN,SAAS;AAAA,EACX;AAEI,MAAA,CAAC,KAAa,QAAA;AAGhB,SAAAC,2BAAA,kBAAA;AAAA,IAACC,qBAAO;AAAA,IAAP;AAAA,MACC,OAAO,EAAE,MAAM,KAAK,UAAU,MAAM;AAAA,MACpC;AAAA,MACA,QAAQ;AAAA,MACR;AAAA,MACA,UAAQ;AAAA,MACR,QAAQ;AAAA,MACR;AAAA,MACA,cAAY;AAAA,MACZ,WAAW;AAAA,MACX,iBAAiB,CAAC,UAAU,SAAS,SAAS,QAAQ;AAAA,MACtD,WAAW,MAAM,QAAQ,EAAE;AAAA,MAC3B,UAAU,gBAAgB;AAAA,IAAA;AAAA,EAC5B;AAEJ;;"}
@@ -29,6 +29,7 @@ import "../../../../../context/pip/PiPProvider.es.js";
29
29
  import "../../../../../context/pip/PiPWrapper.es.js";
30
30
  import "../../../../../context/AddonProjectContext.es.js";
31
31
  import "../../../../../context/AddonContext.es.js";
32
+ import "../../../../../context/PowerpackContext.es.js";
32
33
  import "../../CommentInput/quillToMarkdown.es.js";
33
34
  import "../../ActivityComment/ActivityComment.styled.es.js";
34
35
  import "../../ActivityCheckbox/ActivityCheckbox.styled.es.js";
@@ -1 +1 @@
1
- {"version":3,"file":"EntityTooltip.es.js","sources":["../../../../../../../../src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.tsx"],"sourcesContent":["import * as Styled from './EntityTooltip.styled'\nimport { productTypes } from '@shared/util'\nimport { useFeedContext } from '@shared/containers/Feed'\nimport { Status } from '@shared/containers/ProjectTreeTable/types/project'\n\ninterface ThumbnailUrlParams {\n entityId?: string\n entityType?: string\n thumbnailId?: string\n updatedAt?: string\n projectName?: string\n}\n\nconst getThumbnailUrl = ({\n entityId,\n entityType,\n thumbnailId,\n updatedAt,\n projectName,\n}: ThumbnailUrlParams) => {\n // If projectName is not provided or neither thumbnailId nor entityId and entityType are provided, return null\n if (!projectName || (!thumbnailId && (!entityId || !entityType))) return null\n\n // Construct the updatedAt query parameter if updatedAt is provided\n const updatedAtQueryParam = updatedAt ? `?updatedAt=${updatedAt}` : ''\n\n // If entityId and entityType are provided, construct the URL using them\n if (entityId && entityType) {\n const entityUrl = `/api/projects/${projectName}/${entityType}s/${entityId}/thumbnail`\n return `${entityUrl}${updatedAtQueryParam}`\n }\n\n // If entityId and entityType are not provided, fallback on thumbnailId\n const thumbnailUrl = `/api/projects/${projectName}/thumbnails/${thumbnailId}`\n return `${thumbnailUrl}${updatedAtQueryParam}`\n}\n\ninterface EntityTooltipProps {\n type?: string\n id?: string\n pos?: {\n left?: number\n top?: number\n }\n projectName?: string\n projectInfo?: any\n}\n\nconst EntityTooltip: React.FC<EntityTooltipProps> = ({\n type,\n id,\n pos: { left = 0, top = 0 } = {},\n}) => {\n const { entityTooltipData, isFetchingTooltip, projectInfo, projectName } = useFeedContext()\n\n const width = 220\n\n // check x is not offScreen\n if (left + width / 2 > window.innerWidth) left = window.innerWidth - width / 2\n\n const {\n title,\n subTitle,\n path,\n taskType,\n productType,\n users = [],\n thumbnailId,\n updatedAt,\n status,\n } = entityTooltipData || {}\n\n const { taskTypes = [], statuses = [] } = projectInfo\n\n const taskIcon = taskTypes.find((type: any) => type.name === taskType)?.icon\n const statusObject = statuses.find((s: Status) => s.name === status)\n const thumbnailUrl = getThumbnailUrl({\n entityId: id,\n entityType: type,\n thumbnailId,\n updatedAt,\n projectName,\n })\n const productTypeData = productTypes[productType as keyof typeof productTypes]\n const productIcon = productTypeData?.icon || 'layers'\n\n const icons: Record<string, string | undefined> = {\n task: taskIcon,\n version: productIcon,\n }\n\n if (!type) return null\n\n return (\n <Styled.TooltipEntityCard\n style={{ left, top, maxWidth: width }}\n title={title}\n header={subTitle}\n path={path}\n showPath\n status={statusObject}\n users={users}\n hidePriority\n isLoading={isFetchingTooltip}\n loadingSections={['header', 'title', 'users', 'status']}\n titleIcon={icons[type || '']}\n imageUrl={thumbnailUrl || undefined}\n />\n )\n}\n\nexport default EntityTooltip\n"],"names":["type","jsx","Styled.TooltipEntityCard"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaA,MAAM,kBAAkB,CAAC;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA0B;AAEpB,MAAA,CAAC,eAAgB,CAAC,gBAAgB,CAAC,YAAY,CAAC,YAAqB,QAAA;AAGzE,QAAM,sBAAsB,YAAY,cAAc,SAAS,KAAK;AAGpE,MAAI,YAAY,YAAY;AAC1B,UAAM,YAAY,iBAAiB,WAAW,IAAI,UAAU,KAAK,QAAQ;AAClE,WAAA,GAAG,SAAS,GAAG,mBAAmB;AAAA,EAAA;AAI3C,QAAM,eAAe,iBAAiB,WAAW,eAAe,WAAW;AACpE,SAAA,GAAG,YAAY,GAAG,mBAAmB;AAC9C;AAaA,MAAM,gBAA8C,CAAC;AAAA,EACnD;AAAA,EACA;AAAA,EACA,KAAK,EAAE,OAAO,GAAG,MAAM,EAAA,IAAM,CAAA;AAC/B,MAAM;;AACJ,QAAM,EAAE,mBAAmB,mBAAmB,aAAa,YAAA,IAAgB,eAAe;AAE1F,QAAM,QAAQ;AAGV,MAAA,OAAO,QAAQ,IAAI,OAAO,WAAmB,QAAA,OAAO,aAAa,QAAQ;AAEvE,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ,CAAC;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB,CAAC;AAE1B,QAAM,EAAE,YAAY,CAAA,GAAI,WAAW,CAAA,EAAO,IAAA;AAEpC,QAAA,YAAW,eAAU,KAAK,CAACA,UAAcA,MAAK,SAAS,QAAQ,MAApD,mBAAuD;AACxE,QAAM,eAAe,SAAS,KAAK,CAAC,MAAc,EAAE,SAAS,MAAM;AACnE,QAAM,eAAe,gBAAgB;AAAA,IACnC,UAAU;AAAA,IACV,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AACK,QAAA,kBAAkB,aAAa,WAAwC;AACvE,QAAA,eAAc,mDAAiB,SAAQ;AAE7C,QAAM,QAA4C;AAAA,IAChD,MAAM;AAAA,IACN,SAAS;AAAA,EACX;AAEI,MAAA,CAAC,KAAa,QAAA;AAGhB,SAAAC,kCAAA;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,OAAO,EAAE,MAAM,KAAK,UAAU,MAAM;AAAA,MACpC;AAAA,MACA,QAAQ;AAAA,MACR;AAAA,MACA,UAAQ;AAAA,MACR,QAAQ;AAAA,MACR;AAAA,MACA,cAAY;AAAA,MACZ,WAAW;AAAA,MACX,iBAAiB,CAAC,UAAU,SAAS,SAAS,QAAQ;AAAA,MACtD,WAAW,MAAM,QAAQ,EAAE;AAAA,MAC3B,UAAU,gBAAgB;AAAA,IAAA;AAAA,EAC5B;AAEJ;"}
1
+ {"version":3,"file":"EntityTooltip.es.js","sources":["../../../../../../../../src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.tsx"],"sourcesContent":["import * as Styled from './EntityTooltip.styled'\nimport { productTypes } from '@shared/util'\nimport { useFeedContext } from '@shared/containers/Feed'\nimport { Status } from '@shared/containers/ProjectTreeTable/types/project'\n\ninterface ThumbnailUrlParams {\n entityId?: string\n entityType?: string\n thumbnailId?: string\n updatedAt?: string\n projectName?: string\n}\n\nconst getThumbnailUrl = ({\n entityId,\n entityType,\n thumbnailId,\n updatedAt,\n projectName,\n}: ThumbnailUrlParams) => {\n // If projectName is not provided or neither thumbnailId nor entityId and entityType are provided, return null\n if (!projectName || (!thumbnailId && (!entityId || !entityType))) return null\n\n // Construct the updatedAt query parameter if updatedAt is provided\n const updatedAtQueryParam = updatedAt ? `?updatedAt=${updatedAt}` : ''\n\n // If entityId and entityType are provided, construct the URL using them\n if (entityId && entityType) {\n const entityUrl = `/api/projects/${projectName}/${entityType}s/${entityId}/thumbnail`\n return `${entityUrl}${updatedAtQueryParam}`\n }\n\n // If entityId and entityType are not provided, fallback on thumbnailId\n const thumbnailUrl = `/api/projects/${projectName}/thumbnails/${thumbnailId}`\n return `${thumbnailUrl}${updatedAtQueryParam}`\n}\n\ninterface EntityTooltipProps {\n type?: string\n id?: string\n pos?: {\n left?: number\n top?: number\n }\n projectName?: string\n projectInfo?: any\n}\n\nconst EntityTooltip: React.FC<EntityTooltipProps> = ({\n type,\n id,\n pos: { left = 0, top = 0 } = {},\n}) => {\n const { entityTooltipData, isFetchingTooltip, projectInfo, projectName } = useFeedContext()\n\n const width = 220\n\n // check x is not offScreen\n if (left + width / 2 > window.innerWidth) left = window.innerWidth - width / 2\n\n const {\n title,\n subTitle,\n path,\n taskType,\n productType,\n users = [],\n thumbnailId,\n updatedAt,\n status,\n } = entityTooltipData || {}\n\n const { taskTypes = [], statuses = [] } = projectInfo\n\n const taskIcon = taskTypes.find((type: any) => type.name === taskType)?.icon\n const statusObject = statuses.find((s: Status) => s.name === status)\n const thumbnailUrl = getThumbnailUrl({\n entityId: id,\n entityType: type,\n thumbnailId,\n updatedAt,\n projectName,\n })\n const productTypeData = productTypes[productType as keyof typeof productTypes]\n const productIcon = productTypeData?.icon || 'layers'\n\n const icons: Record<string, string | undefined> = {\n task: taskIcon,\n version: productIcon,\n }\n\n if (!type) return null\n\n return (\n <Styled.TooltipEntityCard\n style={{ left, top, maxWidth: width }}\n title={title}\n header={subTitle}\n path={path}\n showPath\n status={statusObject}\n users={users}\n hidePriority\n isLoading={isFetchingTooltip}\n loadingSections={['header', 'title', 'users', 'status']}\n titleIcon={icons[type || '']}\n imageUrl={thumbnailUrl || undefined}\n />\n )\n}\n\nexport default EntityTooltip\n"],"names":["type","jsx","Styled.TooltipEntityCard"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaA,MAAM,kBAAkB,CAAC;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA0B;AAEpB,MAAA,CAAC,eAAgB,CAAC,gBAAgB,CAAC,YAAY,CAAC,YAAqB,QAAA;AAGzE,QAAM,sBAAsB,YAAY,cAAc,SAAS,KAAK;AAGpE,MAAI,YAAY,YAAY;AAC1B,UAAM,YAAY,iBAAiB,WAAW,IAAI,UAAU,KAAK,QAAQ;AAClE,WAAA,GAAG,SAAS,GAAG,mBAAmB;AAAA,EAAA;AAI3C,QAAM,eAAe,iBAAiB,WAAW,eAAe,WAAW;AACpE,SAAA,GAAG,YAAY,GAAG,mBAAmB;AAC9C;AAaA,MAAM,gBAA8C,CAAC;AAAA,EACnD;AAAA,EACA;AAAA,EACA,KAAK,EAAE,OAAO,GAAG,MAAM,EAAA,IAAM,CAAA;AAC/B,MAAM;;AACJ,QAAM,EAAE,mBAAmB,mBAAmB,aAAa,YAAA,IAAgB,eAAe;AAE1F,QAAM,QAAQ;AAGV,MAAA,OAAO,QAAQ,IAAI,OAAO,WAAmB,QAAA,OAAO,aAAa,QAAQ;AAEvE,QAAA;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQ,CAAC;AAAA,IACT;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,qBAAqB,CAAC;AAE1B,QAAM,EAAE,YAAY,CAAA,GAAI,WAAW,CAAA,EAAO,IAAA;AAEpC,QAAA,YAAW,eAAU,KAAK,CAACA,UAAcA,MAAK,SAAS,QAAQ,MAApD,mBAAuD;AACxE,QAAM,eAAe,SAAS,KAAK,CAAC,MAAc,EAAE,SAAS,MAAM;AACnE,QAAM,eAAe,gBAAgB;AAAA,IACnC,UAAU;AAAA,IACV,YAAY;AAAA,IACZ;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AACK,QAAA,kBAAkB,aAAa,WAAwC;AACvE,QAAA,eAAc,mDAAiB,SAAQ;AAE7C,QAAM,QAA4C;AAAA,IAChD,MAAM;AAAA,IACN,SAAS;AAAA,EACX;AAEI,MAAA,CAAC,KAAa,QAAA;AAGhB,SAAAC,kCAAA;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,OAAO,EAAE,MAAM,KAAK,UAAU,MAAM;AAAA,MACpC;AAAA,MACA,QAAQ;AAAA,MACR;AAAA,MACA,UAAQ;AAAA,MACR,QAAQ;AAAA,MACR;AAAA,MACA,cAAY;AAAA,MACZ,WAAW;AAAA,MACX,iBAAiB,CAAC,UAAU,SAAS,SAAS,QAAQ;AAAA,MACtD,WAAW,MAAM,QAAQ,EAAE;AAAA,MAC3B,UAAU,gBAAgB;AAAA,IAAA;AAAA,EAC5B;AAEJ;"}
@@ -38,6 +38,7 @@ require("../../../api/generated/users.cjs.js");
38
38
  require("../../../api/generated/versions.cjs.js");
39
39
  require("../../../api/generated/workfiles.cjs.js");
40
40
  require("../../../api/generated/ynputCloud.cjs.js");
41
+ require("../../../api/generated/grouping.cjs.js");
41
42
  require("../../../api/queries/actions/getActions.cjs.js");
42
43
  const getActivities = require("../../../api/queries/activities/getActivities.cjs.js");
43
44
  const updateActivities = require("../../../api/queries/activities/updateActivities.cjs.js");
@@ -69,6 +70,7 @@ require("../../../api/queries/users/getUsers.cjs.js");
69
70
  require("../../../api/queries/users/updateUsers.cjs.js");
70
71
  require("../../../api/queries/watchers/getWatchers.cjs.js");
71
72
  require("../../../api/queries/permissions/getPermissions.cjs.js");
73
+ require("../../../api/queries/grouping/getGrouping.cjs.js");
72
74
  require("../../../context/RemoteModulesContext.cjs.js");
73
75
  const DetailsPanelContext = require("../../../context/DetailsPanelContext.cjs.js");
74
76
  require("../../../context/ThumbnailUploaderContext.cjs.js");
@@ -78,6 +80,7 @@ require("react-dom");
78
80
  require("../../../context/pip/PiPWrapper.cjs.js");
79
81
  require("../../../context/AddonProjectContext.cjs.js");
80
82
  require("../../../context/AddonContext.cjs.js");
83
+ require("../../../context/PowerpackContext.cjs.js");
81
84
  const FEED_NEW_COMMENT = "__new__";
82
85
  const FeedContext = React.createContext(void 0);
83
86
  const FeedProvider = ({ children, ...props }) => {
@@ -1 +1 @@
1
- {"version":3,"file":"FeedContext.cjs.js","sources":["../../../../../../src/containers/Feed/context/FeedContext.tsx"],"sourcesContent":["import React, { createContext, useContext, useState } from 'react'\nimport useGetFeedActivitiesData from '../hooks/useGetFeedActivitiesData'\n\n// Queries\nimport {\n useCreateEntityActivityMutation,\n useDeleteActivityMutation,\n useUpdateActivityMutation,\n useCreateReactionToActivityMutation,\n useDeleteReactionToActivityMutation,\n useGetActivityUsersQuery,\n useGetEntityMentionsQuery,\n useGetEntityTooltipQuery,\n} from '@shared/api'\nimport type { SuggestRequest, SuggestResponse } from '@shared/api'\nimport { ActivityUser } from '../helpers/groupMinorActivities'\nimport { DetailsPanelTab, useScopedDetailsPanel } from '@shared/context'\nimport { getFilterActivityTypes } from '@shared/api'\n\nexport const FEED_NEW_COMMENT = '__new__' as const\n\nexport type EditingState = null | typeof FEED_NEW_COMMENT | string\n\n// Add type for the refTooltip\nexport interface RefTooltip {\n id: string | null\n type: string\n name: string\n label: string\n pos: {\n top: number\n left: number\n }\n}\n\nexport type FeedContextProps = {\n children: React.ReactNode\n projectName: string\n entityType: string\n activityTypes?: string[] | null\n entities: any[]\n projectInfo: any\n scope: string\n userName: string\n userFullName: string\n\n // annotations\n annotations?: Record<string, any>\n removeAnnotation?: (id: string) => void\n exportAnnotationComposite?: (id: string) => Promise<Blob | null>\n // editingId state and functions\n editingId: EditingState\n setEditingId: (id: EditingState) => void\n}\n\ninterface FeedContextType extends Omit<FeedContextProps, 'children'> {\n currentTab: DetailsPanelTab\n // activities data props\n activitiesData: any[]\n isLoadingActivities: boolean\n isLoadingNew: boolean\n isLoadingNextPage: boolean\n hasNextPage: boolean\n loadNextPage?: () => Promise<any>\n // refTooltip state and functions\n refTooltip: RefTooltip | null\n setRefTooltip: (tooltip: RefTooltip | null) => void\n // tooltip data\n entityTooltipData: any\n isFetchingTooltip: boolean\n // query functions\n createEntityActivity: (args: any) => Promise<any>\n updateActivity: (args: any) => Promise<any>\n deleteActivity: (args: any) => Promise<any>\n createReaction: (args: any) => Promise<any>\n deleteReaction: (args: any) => Promise<any>\n isUpdatingActivity: boolean\n // users data\n users: ActivityUser[]\n // mentions data\n mentionSuggestionsData: SuggestResponse\n}\n\nconst FeedContext = createContext<FeedContextType | undefined>(undefined)\n\nexport const FeedProvider = ({ children, ...props }: FeedContextProps) => {\n const { data: users = [] } = useGetActivityUsersQuery({ projects: [props.projectName] })\n const { currentTab } = useScopedDetailsPanel(props.scope)\n\n // queries\n const [createEntityActivityMutation, { isLoading: isLoadingCreate }] =\n useCreateEntityActivityMutation()\n const [updateActivityMutation, { isLoading: isLoadingUpdate }] = useUpdateActivityMutation()\n const [deleteActivityMutation, { isLoading: isLoadingDelete }] = useDeleteActivityMutation()\n const isUpdatingActivity = isLoadingCreate || isLoadingUpdate || isLoadingDelete\n\n const createEntityActivity: FeedContextType['createEntityActivity'] = async (args) =>\n await createEntityActivityMutation(args).unwrap()\n const updateActivity: FeedContextType['updateActivity'] = async (args) =>\n await updateActivityMutation(args).unwrap()\n const deleteActivity: FeedContextType['deleteActivity'] = async (args) =>\n await deleteActivityMutation(args).unwrap()\n\n const [createReactionToActivity] = useCreateReactionToActivityMutation()\n const [deleteReactionToActivity] = useDeleteReactionToActivityMutation()\n\n const createReaction: FeedContextType['createReaction'] = async (args) =>\n await createReactionToActivity(args).unwrap()\n const deleteReaction: FeedContextType['deleteReaction'] = async (args) =>\n await deleteReactionToActivity(args).unwrap()\n\n const activityTypes = getFilterActivityTypes(currentTab)\n\n const activitiesDataProps = useGetFeedActivitiesData({\n entities: props.entities,\n filter: currentTab,\n activityTypes: activityTypes,\n projectName: props.projectName,\n entityType: props.entityType,\n })\n\n const [refTooltip, setRefTooltip] = useState<RefTooltip | null>(null)\n const skip = !props.projectName || !refTooltip?.id || refTooltip.type === 'user'\n const { data: entityTooltipData, isFetching: isFetchingTooltip } = useGetEntityTooltipQuery(\n { entityType: refTooltip?.type, entityId: refTooltip?.id, projectName: props.projectName },\n { skip: skip },\n )\n\n // get all versions that can be mentioned\n const { data: mentionSuggestionsData = {} } = useGetEntityMentionsQuery(\n {\n suggestRequest: {\n entityType: props.entityType as SuggestRequest['entityType'],\n entityId: props.entities[0]?.id,\n },\n projectName: props.projectName,\n },\n { skip: !props.editingId },\n )\n\n return (\n <FeedContext.Provider\n value={{\n ...props,\n ...activitiesDataProps,\n mentionSuggestionsData,\n users,\n isUpdatingActivity,\n entityTooltipData,\n isFetchingTooltip,\n refTooltip,\n activityTypes,\n currentTab,\n setRefTooltip,\n // Query functions\n createEntityActivity,\n updateActivity,\n deleteActivity,\n createReaction,\n deleteReaction,\n }}\n >\n {children}\n </FeedContext.Provider>\n )\n}\n\nexport const useFeedContext = () => {\n const context = useContext(FeedContext)\n if (!context) {\n throw new Error('useFeedContext must be used within a FeedProvider')\n }\n return context\n}\n"],"names":["createContext","useGetActivityUsersQuery","useScopedDetailsPanel","useCreateEntityActivityMutation","useUpdateActivityMutation","useDeleteActivityMutation","useCreateReactionToActivityMutation","useDeleteReactionToActivityMutation","getFilterActivityTypes","useState","useGetEntityTooltipQuery","useGetEntityMentionsQuery","jsx","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmBO,MAAM,mBAAmB;AAgEhC,MAAM,cAAcA,oBAA2C,MAAS;AAEjE,MAAM,eAAe,CAAC,EAAE,UAAU,GAAG,YAA8B;;AACxE,QAAM,EAAE,MAAM,QAAQ,CAAA,MAAOC,cAAAA,yBAAyB,EAAE,UAAU,CAAC,MAAM,WAAW,GAAG;AACvF,QAAM,EAAE,WAAe,IAAAC,0CAAsB,MAAM,KAAK;AAGxD,QAAM,CAAC,8BAA8B,EAAE,WAAW,gBAAiB,CAAA,IACjEC,iBAAAA,gCAAgC;AAClC,QAAM,CAAC,wBAAwB,EAAE,WAAW,gBAAiB,CAAA,IAAIC,iBAAAA,0BAA0B;AAC3F,QAAM,CAAC,wBAAwB,EAAE,WAAW,gBAAiB,CAAA,IAAIC,iBAAAA,0BAA0B;AACrF,QAAA,qBAAqB,mBAAmB,mBAAmB;AAEjE,QAAM,uBAAgE,OAAO,SAC3E,MAAM,6BAA6B,IAAI,EAAE,OAAO;AAClD,QAAM,iBAAoD,OAAO,SAC/D,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAC5C,QAAM,iBAAoD,OAAO,SAC/D,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAEtC,QAAA,CAAC,wBAAwB,IAAIC,mDAAoC;AACjE,QAAA,CAAC,wBAAwB,IAAIC,mDAAoC;AAEvE,QAAM,iBAAoD,OAAO,SAC/D,MAAM,yBAAyB,IAAI,EAAE,OAAO;AAC9C,QAAM,iBAAoD,OAAO,SAC/D,MAAM,yBAAyB,IAAI,EAAE,OAAO;AAExC,QAAA,gBAAgBC,yCAAuB,UAAU;AAEvD,QAAM,sBAAsB,yBAAyB;AAAA,IACnD,UAAU,MAAM;AAAA,IAChB,QAAQ;AAAA,IACR;AAAA,IACA,aAAa,MAAM;AAAA,IACnB,YAAY,MAAM;AAAA,EAAA,CACnB;AAED,QAAM,CAAC,YAAY,aAAa,IAAIC,MAAAA,SAA4B,IAAI;AAC9D,QAAA,OAAO,CAAC,MAAM,eAAe,EAAC,yCAAY,OAAM,WAAW,SAAS;AAC1E,QAAM,EAAE,MAAM,mBAAmB,YAAY,kBAAsB,IAAAC,cAAA;AAAA,IACjE,EAAE,YAAY,yCAAY,MAAM,UAAU,yCAAY,IAAI,aAAa,MAAM,YAAY;AAAA,IACzF,EAAE,KAAW;AAAA,EACf;AAGA,QAAM,EAAE,MAAM,yBAAyB,CAAA,EAAO,IAAAC,YAAA;AAAA,IAC5C;AAAA,MACE,gBAAgB;AAAA,QACd,YAAY,MAAM;AAAA,QAClB,WAAU,WAAM,SAAS,CAAC,MAAhB,mBAAmB;AAAA,MAC/B;AAAA,MACA,aAAa,MAAM;AAAA,IACrB;AAAA,IACA,EAAE,MAAM,CAAC,MAAM,UAAU;AAAA,EAC3B;AAGE,SAAAC,2BAAA,kBAAA;AAAA,IAAC,YAAY;AAAA,IAAZ;AAAA,MACC,OAAO;AAAA,QACL,GAAG;AAAA,QACH,GAAG;AAAA,QACH;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA;AAAA,QAEA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MAEC;AAAA,IAAA;AAAA,EACH;AAEJ;AAEO,MAAM,iBAAiB,MAAM;AAC5B,QAAA,UAAUC,iBAAW,WAAW;AACtC,MAAI,CAAC,SAAS;AACN,UAAA,IAAI,MAAM,mDAAmD;AAAA,EAAA;AAE9D,SAAA;AACT;;;;"}
1
+ {"version":3,"file":"FeedContext.cjs.js","sources":["../../../../../../src/containers/Feed/context/FeedContext.tsx"],"sourcesContent":["import React, { createContext, useContext, useState } from 'react'\nimport useGetFeedActivitiesData from '../hooks/useGetFeedActivitiesData'\n\n// Queries\nimport {\n useCreateEntityActivityMutation,\n useDeleteActivityMutation,\n useUpdateActivityMutation,\n useCreateReactionToActivityMutation,\n useDeleteReactionToActivityMutation,\n useGetActivityUsersQuery,\n useGetEntityMentionsQuery,\n useGetEntityTooltipQuery,\n} from '@shared/api'\nimport type { SuggestRequest, SuggestResponse } from '@shared/api'\nimport { ActivityUser } from '../helpers/groupMinorActivities'\nimport { DetailsPanelTab, useScopedDetailsPanel } from '@shared/context'\nimport { getFilterActivityTypes } from '@shared/api'\n\nexport const FEED_NEW_COMMENT = '__new__' as const\n\nexport type EditingState = null | typeof FEED_NEW_COMMENT | string\n\n// Add type for the refTooltip\nexport interface RefTooltip {\n id: string | null\n type: string\n name: string\n label: string\n pos: {\n top: number\n left: number\n }\n}\n\nexport type FeedContextProps = {\n children: React.ReactNode\n projectName: string\n entityType: string\n activityTypes?: string[] | null\n entities: any[]\n projectInfo: any\n scope: string\n userName: string\n userFullName: string\n\n // annotations\n annotations?: Record<string, any>\n removeAnnotation?: (id: string) => void\n exportAnnotationComposite?: (id: string) => Promise<Blob | null>\n // editingId state and functions\n editingId: EditingState\n setEditingId: (id: EditingState) => void\n}\n\ninterface FeedContextType extends Omit<FeedContextProps, 'children'> {\n currentTab: DetailsPanelTab\n // activities data props\n activitiesData: any[]\n isLoadingActivities: boolean\n isLoadingNew: boolean\n isLoadingNextPage: boolean\n hasNextPage: boolean\n loadNextPage?: () => Promise<any>\n // refTooltip state and functions\n refTooltip: RefTooltip | null\n setRefTooltip: (tooltip: RefTooltip | null) => void\n // tooltip data\n entityTooltipData: any\n isFetchingTooltip: boolean\n // query functions\n createEntityActivity: (args: any) => Promise<any>\n updateActivity: (args: any) => Promise<any>\n deleteActivity: (args: any) => Promise<any>\n createReaction: (args: any) => Promise<any>\n deleteReaction: (args: any) => Promise<any>\n isUpdatingActivity: boolean\n // users data\n users: ActivityUser[]\n // mentions data\n mentionSuggestionsData: SuggestResponse\n}\n\nconst FeedContext = createContext<FeedContextType | undefined>(undefined)\n\nexport const FeedProvider = ({ children, ...props }: FeedContextProps) => {\n const { data: users = [] } = useGetActivityUsersQuery({ projects: [props.projectName] })\n const { currentTab } = useScopedDetailsPanel(props.scope)\n\n // queries\n const [createEntityActivityMutation, { isLoading: isLoadingCreate }] =\n useCreateEntityActivityMutation()\n const [updateActivityMutation, { isLoading: isLoadingUpdate }] = useUpdateActivityMutation()\n const [deleteActivityMutation, { isLoading: isLoadingDelete }] = useDeleteActivityMutation()\n const isUpdatingActivity = isLoadingCreate || isLoadingUpdate || isLoadingDelete\n\n const createEntityActivity: FeedContextType['createEntityActivity'] = async (args) =>\n await createEntityActivityMutation(args).unwrap()\n const updateActivity: FeedContextType['updateActivity'] = async (args) =>\n await updateActivityMutation(args).unwrap()\n const deleteActivity: FeedContextType['deleteActivity'] = async (args) =>\n await deleteActivityMutation(args).unwrap()\n\n const [createReactionToActivity] = useCreateReactionToActivityMutation()\n const [deleteReactionToActivity] = useDeleteReactionToActivityMutation()\n\n const createReaction: FeedContextType['createReaction'] = async (args) =>\n await createReactionToActivity(args).unwrap()\n const deleteReaction: FeedContextType['deleteReaction'] = async (args) =>\n await deleteReactionToActivity(args).unwrap()\n\n const activityTypes = getFilterActivityTypes(currentTab)\n\n const activitiesDataProps = useGetFeedActivitiesData({\n entities: props.entities,\n filter: currentTab,\n activityTypes: activityTypes,\n projectName: props.projectName,\n entityType: props.entityType,\n })\n\n const [refTooltip, setRefTooltip] = useState<RefTooltip | null>(null)\n const skip = !props.projectName || !refTooltip?.id || refTooltip.type === 'user'\n const { data: entityTooltipData, isFetching: isFetchingTooltip } = useGetEntityTooltipQuery(\n { entityType: refTooltip?.type, entityId: refTooltip?.id, projectName: props.projectName },\n { skip: skip },\n )\n\n // get all versions that can be mentioned\n const { data: mentionSuggestionsData = {} } = useGetEntityMentionsQuery(\n {\n suggestRequest: {\n entityType: props.entityType as SuggestRequest['entityType'],\n entityId: props.entities[0]?.id,\n },\n projectName: props.projectName,\n },\n { skip: !props.editingId },\n )\n\n return (\n <FeedContext.Provider\n value={{\n ...props,\n ...activitiesDataProps,\n mentionSuggestionsData,\n users,\n isUpdatingActivity,\n entityTooltipData,\n isFetchingTooltip,\n refTooltip,\n activityTypes,\n currentTab,\n setRefTooltip,\n // Query functions\n createEntityActivity,\n updateActivity,\n deleteActivity,\n createReaction,\n deleteReaction,\n }}\n >\n {children}\n </FeedContext.Provider>\n )\n}\n\nexport const useFeedContext = () => {\n const context = useContext(FeedContext)\n if (!context) {\n throw new Error('useFeedContext must be used within a FeedProvider')\n }\n return context\n}\n"],"names":["createContext","useGetActivityUsersQuery","useScopedDetailsPanel","useCreateEntityActivityMutation","useUpdateActivityMutation","useDeleteActivityMutation","useCreateReactionToActivityMutation","useDeleteReactionToActivityMutation","getFilterActivityTypes","useState","useGetEntityTooltipQuery","useGetEntityMentionsQuery","jsx","useContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmBO,MAAM,mBAAmB;AAgEhC,MAAM,cAAcA,oBAA2C,MAAS;AAEjE,MAAM,eAAe,CAAC,EAAE,UAAU,GAAG,YAA8B;;AACxE,QAAM,EAAE,MAAM,QAAQ,CAAA,MAAOC,cAAAA,yBAAyB,EAAE,UAAU,CAAC,MAAM,WAAW,GAAG;AACvF,QAAM,EAAE,WAAe,IAAAC,0CAAsB,MAAM,KAAK;AAGxD,QAAM,CAAC,8BAA8B,EAAE,WAAW,gBAAiB,CAAA,IACjEC,iBAAAA,gCAAgC;AAClC,QAAM,CAAC,wBAAwB,EAAE,WAAW,gBAAiB,CAAA,IAAIC,iBAAAA,0BAA0B;AAC3F,QAAM,CAAC,wBAAwB,EAAE,WAAW,gBAAiB,CAAA,IAAIC,iBAAAA,0BAA0B;AACrF,QAAA,qBAAqB,mBAAmB,mBAAmB;AAEjE,QAAM,uBAAgE,OAAO,SAC3E,MAAM,6BAA6B,IAAI,EAAE,OAAO;AAClD,QAAM,iBAAoD,OAAO,SAC/D,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAC5C,QAAM,iBAAoD,OAAO,SAC/D,MAAM,uBAAuB,IAAI,EAAE,OAAO;AAEtC,QAAA,CAAC,wBAAwB,IAAIC,mDAAoC;AACjE,QAAA,CAAC,wBAAwB,IAAIC,mDAAoC;AAEvE,QAAM,iBAAoD,OAAO,SAC/D,MAAM,yBAAyB,IAAI,EAAE,OAAO;AAC9C,QAAM,iBAAoD,OAAO,SAC/D,MAAM,yBAAyB,IAAI,EAAE,OAAO;AAExC,QAAA,gBAAgBC,yCAAuB,UAAU;AAEvD,QAAM,sBAAsB,yBAAyB;AAAA,IACnD,UAAU,MAAM;AAAA,IAChB,QAAQ;AAAA,IACR;AAAA,IACA,aAAa,MAAM;AAAA,IACnB,YAAY,MAAM;AAAA,EAAA,CACnB;AAED,QAAM,CAAC,YAAY,aAAa,IAAIC,MAAAA,SAA4B,IAAI;AAC9D,QAAA,OAAO,CAAC,MAAM,eAAe,EAAC,yCAAY,OAAM,WAAW,SAAS;AAC1E,QAAM,EAAE,MAAM,mBAAmB,YAAY,kBAAsB,IAAAC,cAAA;AAAA,IACjE,EAAE,YAAY,yCAAY,MAAM,UAAU,yCAAY,IAAI,aAAa,MAAM,YAAY;AAAA,IACzF,EAAE,KAAW;AAAA,EACf;AAGA,QAAM,EAAE,MAAM,yBAAyB,CAAA,EAAO,IAAAC,YAAA;AAAA,IAC5C;AAAA,MACE,gBAAgB;AAAA,QACd,YAAY,MAAM;AAAA,QAClB,WAAU,WAAM,SAAS,CAAC,MAAhB,mBAAmB;AAAA,MAC/B;AAAA,MACA,aAAa,MAAM;AAAA,IACrB;AAAA,IACA,EAAE,MAAM,CAAC,MAAM,UAAU;AAAA,EAC3B;AAGE,SAAAC,2BAAA,kBAAA;AAAA,IAAC,YAAY;AAAA,IAAZ;AAAA,MACC,OAAO;AAAA,QACL,GAAG;AAAA,QACH,GAAG;AAAA,QACH;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA;AAAA,QAEA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MAEC;AAAA,IAAA;AAAA,EACH;AAEJ;AAEO,MAAM,iBAAiB,MAAM;AAC5B,QAAA,UAAUC,iBAAW,WAAW;AACtC,MAAI,CAAC,SAAS;AACN,UAAA,IAAI,MAAM,mDAAmD;AAAA,EAAA;AAE9D,SAAA;AACT;;;;"}
@@ -36,6 +36,7 @@ import "../../../api/generated/users.es.js";
36
36
  import "../../../api/generated/versions.es.js";
37
37
  import "../../../api/generated/workfiles.es.js";
38
38
  import "../../../api/generated/ynputCloud.es.js";
39
+ import "../../../api/generated/grouping.es.js";
39
40
  import "../../../api/queries/actions/getActions.es.js";
40
41
  import { useGetActivityUsersQuery, useGetEntityTooltipQuery } from "../../../api/queries/activities/getActivities.es.js";
41
42
  import { useCreateEntityActivityMutation, useUpdateActivityMutation, useDeleteActivityMutation } from "../../../api/queries/activities/updateActivities.es.js";
@@ -67,6 +68,7 @@ import "../../../api/queries/users/getUsers.es.js";
67
68
  import "../../../api/queries/users/updateUsers.es.js";
68
69
  import "../../../api/queries/watchers/getWatchers.es.js";
69
70
  import "../../../api/queries/permissions/getPermissions.es.js";
71
+ import "../../../api/queries/grouping/getGrouping.es.js";
70
72
  import "../../../context/RemoteModulesContext.es.js";
71
73
  import { useScopedDetailsPanel } from "../../../context/DetailsPanelContext.es.js";
72
74
  import "../../../context/ThumbnailUploaderContext.es.js";
@@ -76,6 +78,7 @@ import "react-dom";
76
78
  import "../../../context/pip/PiPWrapper.es.js";
77
79
  import "../../../context/AddonProjectContext.es.js";
78
80
  import "../../../context/AddonContext.es.js";
81
+ import "../../../context/PowerpackContext.es.js";
79
82
  const FEED_NEW_COMMENT = "__new__";
80
83
  const FeedContext = createContext(void 0);
81
84
  const FeedProvider = ({ children, ...props }) => {