@ynput/ayon-frontend-shared 0.2.18 → 0.2.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (695) hide show
  1. package/dist/DetailsPanel.cjs.js +16 -6
  2. package/dist/DetailsPanel.cjs.js.map +1 -1
  3. package/dist/DetailsPanel.es.js +17 -7
  4. package/dist/DetailsPanel.es.js.map +1 -1
  5. package/dist/ProjectTreeTable.cjs.js +6 -0
  6. package/dist/ProjectTreeTable.cjs.js.map +1 -1
  7. package/dist/ProjectTreeTable.es.js +6 -0
  8. package/dist/ProjectTreeTable.es.js.map +1 -1
  9. package/dist/api.cjs.js +22 -0
  10. package/dist/api.cjs.js.map +1 -1
  11. package/dist/api.es.js +27 -5
  12. package/dist/api.es.js.map +1 -1
  13. package/dist/components.cjs.js +22 -0
  14. package/dist/components.cjs.js.map +1 -1
  15. package/dist/components.es.js +23 -1
  16. package/dist/components.es.js.map +1 -1
  17. package/dist/index.cjs.js +16 -5
  18. package/dist/index.cjs.js.map +1 -1
  19. package/dist/index.es.js +16 -5
  20. package/dist/index.es.js.map +1 -1
  21. package/dist/shared/node_modules/uuid/dist/esm-browser/native.cjs.js +5 -0
  22. package/dist/shared/node_modules/uuid/dist/esm-browser/native.cjs.js.map +1 -0
  23. package/dist/shared/node_modules/uuid/dist/esm-browser/native.es.js +6 -0
  24. package/dist/shared/node_modules/uuid/dist/esm-browser/native.es.js.map +1 -0
  25. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.cjs.js +2 -2
  26. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.cjs.js.map +1 -1
  27. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.es.js +2 -2
  28. package/dist/shared/node_modules/uuid/dist/esm-browser/rng.es.js.map +1 -1
  29. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.cjs.js +1 -1
  30. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.cjs.js.map +1 -1
  31. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.es.js +1 -1
  32. package/dist/shared/node_modules/uuid/dist/esm-browser/stringify.es.js.map +1 -1
  33. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.cjs.js +58 -41
  34. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.cjs.js.map +1 -1
  35. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.es.js +57 -41
  36. package/dist/shared/node_modules/uuid/dist/esm-browser/v1.es.js.map +1 -1
  37. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.cjs.js +20 -0
  38. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.cjs.js.map +1 -0
  39. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.es.js +21 -0
  40. package/dist/shared/node_modules/uuid/dist/esm-browser/v4.es.js.map +1 -0
  41. package/dist/shared/src/api/base/client.cjs.js +2 -1
  42. package/dist/shared/src/api/base/client.cjs.js.map +1 -1
  43. package/dist/shared/src/api/base/client.es.js +2 -1
  44. package/dist/shared/src/api/base/client.es.js.map +1 -1
  45. package/dist/shared/src/api/generated/actions.cjs.js +6 -1
  46. package/dist/shared/src/api/generated/actions.cjs.js.map +1 -1
  47. package/dist/shared/src/api/generated/actions.es.js +6 -1
  48. package/dist/shared/src/api/generated/actions.es.js.map +1 -1
  49. package/dist/shared/src/api/generated/activityFeed.cjs.js.map +1 -1
  50. package/dist/shared/src/api/generated/activityFeed.es.js.map +1 -1
  51. package/dist/shared/src/api/generated/addons.cjs.js +2 -1
  52. package/dist/shared/src/api/generated/addons.cjs.js.map +1 -1
  53. package/dist/shared/src/api/generated/addons.es.js +2 -1
  54. package/dist/shared/src/api/generated/addons.es.js.map +1 -1
  55. package/dist/shared/src/api/generated/anatomy.cjs.js.map +1 -1
  56. package/dist/shared/src/api/generated/anatomy.es.js.map +1 -1
  57. package/dist/shared/src/api/generated/authentication.cjs.js.map +1 -1
  58. package/dist/shared/src/api/generated/authentication.es.js.map +1 -1
  59. package/dist/shared/src/api/generated/configuration.cjs.js.map +1 -1
  60. package/dist/shared/src/api/generated/configuration.es.js.map +1 -1
  61. package/dist/shared/src/api/generated/folders.cjs.js.map +1 -1
  62. package/dist/shared/src/api/generated/folders.es.js.map +1 -1
  63. package/dist/shared/src/api/generated/graphql.cjs.js +38 -0
  64. package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
  65. package/dist/shared/src/api/generated/graphql.es.js +38 -0
  66. package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
  67. package/dist/shared/src/api/generated/links.cjs.js.map +1 -1
  68. package/dist/shared/src/api/generated/links.es.js.map +1 -1
  69. package/dist/shared/src/api/generated/onboarding.cjs.js.map +1 -1
  70. package/dist/shared/src/api/generated/onboarding.es.js.map +1 -1
  71. package/dist/shared/src/api/generated/operations.cjs.js.map +1 -1
  72. package/dist/shared/src/api/generated/operations.es.js.map +1 -1
  73. package/dist/shared/src/api/generated/projects.cjs.js +0 -8
  74. package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
  75. package/dist/shared/src/api/generated/projects.es.js +0 -8
  76. package/dist/shared/src/api/generated/projects.es.js.map +1 -1
  77. package/dist/shared/src/api/generated/system.cjs.js.map +1 -1
  78. package/dist/shared/src/api/generated/system.es.js.map +1 -1
  79. package/dist/shared/src/api/generated/tasks.cjs.js.map +1 -1
  80. package/dist/shared/src/api/generated/tasks.es.js.map +1 -1
  81. package/dist/shared/src/api/generated/views.cjs.js +53 -0
  82. package/dist/shared/src/api/generated/views.cjs.js.map +1 -0
  83. package/dist/shared/src/api/generated/views.es.js +53 -0
  84. package/dist/shared/src/api/generated/views.es.js.map +1 -0
  85. package/dist/shared/src/api/queries/actions/getActions.cjs.js +10 -1
  86. package/dist/shared/src/api/queries/actions/getActions.cjs.js.map +1 -1
  87. package/dist/shared/src/api/queries/actions/getActions.es.js +10 -1
  88. package/dist/shared/src/api/queries/actions/getActions.es.js.map +1 -1
  89. package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -0
  90. package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
  91. package/dist/shared/src/api/queries/activities/getActivities.es.js +1 -0
  92. package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
  93. package/dist/shared/src/api/queries/activities/getMentions.cjs.js +1 -0
  94. package/dist/shared/src/api/queries/activities/getMentions.cjs.js.map +1 -1
  95. package/dist/shared/src/api/queries/activities/getMentions.es.js +1 -0
  96. package/dist/shared/src/api/queries/activities/getMentions.es.js.map +1 -1
  97. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js +1 -0
  98. package/dist/shared/src/api/queries/activities/updateReaction.cjs.js.map +1 -1
  99. package/dist/shared/src/api/queries/activities/updateReaction.es.js +1 -0
  100. package/dist/shared/src/api/queries/activities/updateReaction.es.js.map +1 -1
  101. package/dist/shared/src/api/queries/addons/getAddons.cjs.js +1 -0
  102. package/dist/shared/src/api/queries/addons/getAddons.cjs.js.map +1 -1
  103. package/dist/shared/src/api/queries/addons/getAddons.es.js +1 -0
  104. package/dist/shared/src/api/queries/addons/getAddons.es.js.map +1 -1
  105. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js +1 -0
  106. package/dist/shared/src/api/queries/attributes/getAttributes.cjs.js.map +1 -1
  107. package/dist/shared/src/api/queries/attributes/getAttributes.es.js +1 -0
  108. package/dist/shared/src/api/queries/attributes/getAttributes.es.js.map +1 -1
  109. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js +1 -0
  110. package/dist/shared/src/api/queries/authentication/getAuthentication.cjs.js.map +1 -1
  111. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js +1 -0
  112. package/dist/shared/src/api/queries/authentication/getAuthentication.es.js.map +1 -1
  113. package/dist/shared/src/api/queries/cloud/cloud.cjs.js +67 -0
  114. package/dist/shared/src/api/queries/cloud/cloud.cjs.js.map +1 -0
  115. package/dist/shared/src/api/queries/cloud/cloud.es.js +67 -0
  116. package/dist/shared/src/api/queries/cloud/cloud.es.js.map +1 -0
  117. package/dist/shared/src/api/queries/entities/getEntity.cjs.js +1 -0
  118. package/dist/shared/src/api/queries/entities/getEntity.cjs.js.map +1 -1
  119. package/dist/shared/src/api/queries/entities/getEntity.es.js +1 -0
  120. package/dist/shared/src/api/queries/entities/getEntity.es.js.map +1 -1
  121. package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js +3 -1
  122. package/dist/shared/src/api/queries/entities/getEntityPanel.cjs.js.map +1 -1
  123. package/dist/shared/src/api/queries/entities/getEntityPanel.es.js +3 -1
  124. package/dist/shared/src/api/queries/entities/getEntityPanel.es.js.map +1 -1
  125. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +16 -8
  126. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
  127. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +16 -8
  128. package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
  129. package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +11 -1
  130. package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
  131. package/dist/shared/src/api/queries/entities/updateEntity.es.js +11 -1
  132. package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
  133. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +68 -0
  134. package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
  135. package/dist/shared/src/api/queries/entityLists/getLists.es.js +69 -1
  136. package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
  137. package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js +1 -0
  138. package/dist/shared/src/api/queries/entityLists/getListsAttributes.cjs.js.map +1 -1
  139. package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js +1 -0
  140. package/dist/shared/src/api/queries/entityLists/getListsAttributes.es.js.map +1 -1
  141. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +20 -3
  142. package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
  143. package/dist/shared/src/api/queries/entityLists/updateLists.es.js +20 -3
  144. package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
  145. package/dist/shared/src/api/queries/folders/getFolders.cjs.js +1 -0
  146. package/dist/shared/src/api/queries/folders/getFolders.cjs.js.map +1 -1
  147. package/dist/shared/src/api/queries/folders/getFolders.es.js +1 -0
  148. package/dist/shared/src/api/queries/folders/getFolders.es.js.map +1 -1
  149. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js +1 -0
  150. package/dist/shared/src/api/queries/grouping/getGrouping.cjs.js.map +1 -1
  151. package/dist/shared/src/api/queries/grouping/getGrouping.es.js +1 -0
  152. package/dist/shared/src/api/queries/grouping/getGrouping.es.js.map +1 -1
  153. package/dist/shared/src/api/queries/overview/getOverview.cjs.js +1 -0
  154. package/dist/shared/src/api/queries/overview/getOverview.cjs.js.map +1 -1
  155. package/dist/shared/src/api/queries/overview/getOverview.es.js +1 -0
  156. package/dist/shared/src/api/queries/overview/getOverview.es.js.map +1 -1
  157. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +30 -2
  158. package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
  159. package/dist/shared/src/api/queries/overview/updateOverview.es.js +30 -2
  160. package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
  161. package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js +1 -0
  162. package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js.map +1 -1
  163. package/dist/shared/src/api/queries/permissions/getPermissions.es.js +1 -0
  164. package/dist/shared/src/api/queries/permissions/getPermissions.es.js.map +1 -1
  165. package/dist/shared/src/api/queries/products/createProduct.cjs.js +1 -0
  166. package/dist/shared/src/api/queries/products/createProduct.cjs.js.map +1 -1
  167. package/dist/shared/src/api/queries/products/createProduct.es.js +1 -0
  168. package/dist/shared/src/api/queries/products/createProduct.es.js.map +1 -1
  169. package/dist/shared/src/api/queries/project/getProject.cjs.js +1 -0
  170. package/dist/shared/src/api/queries/project/getProject.cjs.js.map +1 -1
  171. package/dist/shared/src/api/queries/project/getProject.es.js +1 -0
  172. package/dist/shared/src/api/queries/project/getProject.es.js.map +1 -1
  173. package/dist/shared/src/api/queries/review/getReview.cjs.js +1 -0
  174. package/dist/shared/src/api/queries/review/getReview.cjs.js.map +1 -1
  175. package/dist/shared/src/api/queries/review/getReview.es.js +1 -0
  176. package/dist/shared/src/api/queries/review/getReview.es.js.map +1 -1
  177. package/dist/shared/src/api/queries/review/updateReview.cjs.js +1 -0
  178. package/dist/shared/src/api/queries/review/updateReview.cjs.js.map +1 -1
  179. package/dist/shared/src/api/queries/review/updateReview.es.js +1 -0
  180. package/dist/shared/src/api/queries/review/updateReview.es.js.map +1 -1
  181. package/dist/shared/src/api/queries/system/getSystem.cjs.js +1 -0
  182. package/dist/shared/src/api/queries/system/getSystem.cjs.js.map +1 -1
  183. package/dist/shared/src/api/queries/system/getSystem.es.js +1 -0
  184. package/dist/shared/src/api/queries/system/getSystem.es.js.map +1 -1
  185. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js +1 -0
  186. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.cjs.js.map +1 -1
  187. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js +1 -0
  188. package/dist/shared/src/api/queries/userDashboard/getUserDashboard.es.js.map +1 -1
  189. package/dist/shared/src/api/queries/users/getUsers.cjs.js +6 -0
  190. package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
  191. package/dist/shared/src/api/queries/users/getUsers.es.js +6 -0
  192. package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
  193. package/dist/shared/src/api/queries/users/updateUsers.cjs.js +1 -0
  194. package/dist/shared/src/api/queries/users/updateUsers.cjs.js.map +1 -1
  195. package/dist/shared/src/api/queries/users/updateUsers.es.js +1 -0
  196. package/dist/shared/src/api/queries/users/updateUsers.es.js.map +1 -1
  197. package/dist/shared/src/api/queries/versions/updateVersions.cjs.js +4 -1
  198. package/dist/shared/src/api/queries/versions/updateVersions.cjs.js.map +1 -1
  199. package/dist/shared/src/api/queries/versions/updateVersions.es.js +4 -1
  200. package/dist/shared/src/api/queries/versions/updateVersions.es.js.map +1 -1
  201. package/dist/shared/src/api/queries/views/getViews.cjs.js +72 -0
  202. package/dist/shared/src/api/queries/views/getViews.cjs.js.map +1 -0
  203. package/dist/shared/src/api/queries/views/getViews.es.js +72 -0
  204. package/dist/shared/src/api/queries/views/getViews.es.js.map +1 -0
  205. package/dist/shared/src/api/queries/views/updateViews.cjs.js +33 -0
  206. package/dist/shared/src/api/queries/views/updateViews.cjs.js.map +1 -0
  207. package/dist/shared/src/api/queries/views/updateViews.es.js +33 -0
  208. package/dist/shared/src/api/queries/views/updateViews.es.js.map +1 -0
  209. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js +1 -0
  210. package/dist/shared/src/api/queries/watchers/getWatchers.cjs.js.map +1 -1
  211. package/dist/shared/src/api/queries/watchers/getWatchers.es.js +1 -0
  212. package/dist/shared/src/api/queries/watchers/getWatchers.es.js.map +1 -1
  213. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +4 -0
  214. package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
  215. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +4 -0
  216. package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
  217. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js +17 -6
  218. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js.map +1 -1
  219. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js +17 -6
  220. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js.map +1 -1
  221. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js +1 -1
  222. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.cjs.js.map +1 -1
  223. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js +1 -1
  224. package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributesEditor.es.js.map +1 -1
  225. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +2 -2
  226. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
  227. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +2 -2
  228. package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
  229. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +25 -14
  230. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
  231. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +25 -14
  232. package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
  233. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js +369 -0
  234. package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js.map +1 -0
  235. package/dist/shared/src/components/Feedback/FeedbackContext.es.js +369 -0
  236. package/dist/shared/src/components/Feedback/FeedbackContext.es.js.map +1 -0
  237. package/dist/shared/src/components/Feedback/SupportBubble.cjs.js +48 -0
  238. package/dist/shared/src/components/Feedback/SupportBubble.cjs.js.map +1 -0
  239. package/dist/shared/src/components/Feedback/SupportBubble.es.js +48 -0
  240. package/dist/shared/src/components/Feedback/SupportBubble.es.js.map +1 -0
  241. package/dist/shared/src/components/PlayableIcon/PlayableIcon.cjs.js +43 -0
  242. package/dist/shared/src/components/PlayableIcon/PlayableIcon.cjs.js.map +1 -0
  243. package/dist/shared/src/components/PlayableIcon/PlayableIcon.es.js +43 -0
  244. package/dist/shared/src/components/PlayableIcon/PlayableIcon.es.js.map +1 -0
  245. package/dist/shared/src/components/Powerpack/CTAButton.cjs.js +10 -0
  246. package/dist/shared/src/components/Powerpack/CTAButton.cjs.js.map +1 -0
  247. package/dist/shared/src/components/Powerpack/CTAButton.es.js +10 -0
  248. package/dist/shared/src/components/Powerpack/CTAButton.es.js.map +1 -0
  249. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +229 -28
  250. package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -1
  251. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +230 -29
  252. package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -1
  253. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js +4 -1
  254. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.cjs.js.map +1 -1
  255. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js +4 -1
  256. package/dist/shared/src/components/Powerpack/PowerpackDialog.styled.es.js.map +1 -1
  257. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +19 -15
  258. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
  259. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +19 -15
  260. package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
  261. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +179 -0
  262. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
  263. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +179 -0
  264. package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
  265. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +4 -0
  266. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
  267. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +4 -0
  268. package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
  269. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +16 -5
  270. package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
  271. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +16 -5
  272. package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
  273. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +16 -5
  274. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
  275. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +16 -5
  276. package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
  277. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +16 -5
  278. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
  279. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +16 -5
  280. package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
  281. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js +4 -0
  282. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js.map +1 -1
  283. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js +4 -0
  284. package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js.map +1 -1
  285. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +4 -0
  286. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
  287. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +4 -0
  288. package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
  289. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js +2 -2
  290. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.cjs.js.map +1 -1
  291. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js +2 -2
  292. package/dist/shared/src/components/SettingsPanel/SettingsPanelItemTemplate.es.js.map +1 -1
  293. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +16 -5
  294. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
  295. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +16 -5
  296. package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
  297. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +16 -5
  298. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
  299. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +16 -5
  300. package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
  301. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js +4 -0
  302. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js.map +1 -1
  303. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js +4 -0
  304. package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js.map +1 -1
  305. package/dist/shared/src/components/Views/ViewForm/ViewForm.cjs.js +164 -0
  306. package/dist/shared/src/components/Views/ViewForm/ViewForm.cjs.js.map +1 -0
  307. package/dist/shared/src/components/Views/ViewForm/ViewForm.es.js +164 -0
  308. package/dist/shared/src/components/Views/ViewForm/ViewForm.es.js.map +1 -0
  309. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.cjs.js +71 -0
  310. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.cjs.js.map +1 -0
  311. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.es.js +71 -0
  312. package/dist/shared/src/components/Views/ViewForm/ViewForm.styled.es.js.map +1 -0
  313. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.cjs.js +189 -0
  314. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.cjs.js.map +1 -0
  315. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.es.js +189 -0
  316. package/dist/shared/src/components/Views/ViewForm/ViewFormContainer.es.js.map +1 -0
  317. package/dist/shared/src/components/Views/ViewItem/ViewItem.cjs.js +36 -0
  318. package/dist/shared/src/components/Views/ViewItem/ViewItem.cjs.js.map +1 -0
  319. package/dist/shared/src/components/Views/ViewItem/ViewItem.es.js +36 -0
  320. package/dist/shared/src/components/Views/ViewItem/ViewItem.es.js.map +1 -0
  321. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.cjs.js +63 -0
  322. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.cjs.js.map +1 -0
  323. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.es.js +63 -0
  324. package/dist/shared/src/components/Views/ViewItem/ViewItem.styled.es.js.map +1 -0
  325. package/dist/shared/src/components/Views/Views.cjs.js +21 -0
  326. package/dist/shared/src/components/Views/Views.cjs.js.map +1 -0
  327. package/dist/shared/src/components/Views/Views.es.js +21 -0
  328. package/dist/shared/src/components/Views/Views.es.js.map +1 -0
  329. package/dist/shared/src/components/Views/Views.styled.cjs.js +44 -0
  330. package/dist/shared/src/components/Views/Views.styled.cjs.js.map +1 -0
  331. package/dist/shared/src/components/Views/Views.styled.es.js +44 -0
  332. package/dist/shared/src/components/Views/Views.styled.es.js.map +1 -0
  333. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.cjs.js +32 -0
  334. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.cjs.js.map +1 -0
  335. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.es.js +32 -0
  336. package/dist/shared/src/components/Views/ViewsButton/ViewsButton.es.js.map +1 -0
  337. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.cjs.js +31 -0
  338. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.cjs.js.map +1 -0
  339. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.es.js +31 -0
  340. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.es.js.map +1 -0
  341. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.cjs.js +33 -0
  342. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.cjs.js.map +1 -0
  343. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.es.js +33 -0
  344. package/dist/shared/src/components/Views/ViewsMenu/ViewsMenu.styled.es.js.map +1 -0
  345. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js +132 -0
  346. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js.map +1 -0
  347. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.es.js +132 -0
  348. package/dist/shared/src/components/Views/ViewsMenuContainer/ViewsMenuContainer.es.js.map +1 -0
  349. package/dist/shared/src/components/Views/context/ViewsContext.cjs.js +145 -0
  350. package/dist/shared/src/components/Views/context/ViewsContext.cjs.js.map +1 -0
  351. package/dist/shared/src/components/Views/context/ViewsContext.es.js +145 -0
  352. package/dist/shared/src/components/Views/context/ViewsContext.es.js.map +1 -0
  353. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.cjs.js +160 -0
  354. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.cjs.js.map +1 -0
  355. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.es.js +160 -0
  356. package/dist/shared/src/components/Views/hooks/useBuildViewMenuItems.es.js.map +1 -0
  357. package/dist/shared/src/components/Views/utils/generatePersonalView.cjs.js +13 -0
  358. package/dist/shared/src/components/Views/utils/generatePersonalView.cjs.js.map +1 -0
  359. package/dist/shared/src/components/Views/utils/generatePersonalView.es.js +13 -0
  360. package/dist/shared/src/components/Views/utils/generatePersonalView.es.js.map +1 -0
  361. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.cjs.js +8 -0
  362. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.cjs.js.map +1 -0
  363. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.es.js +8 -0
  364. package/dist/shared/src/components/Views/utils/getCustomViewsFallback.es.js.map +1 -0
  365. package/dist/shared/src/components/Views/utils/portalUtils.cjs.js +11 -0
  366. package/dist/shared/src/components/Views/utils/portalUtils.cjs.js.map +1 -0
  367. package/dist/shared/src/components/Views/utils/portalUtils.es.js +11 -0
  368. package/dist/shared/src/components/Views/utils/portalUtils.es.js.map +1 -0
  369. package/dist/shared/src/components/Watchers/Watchers.cjs.js +4 -0
  370. package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
  371. package/dist/shared/src/components/Watchers/Watchers.es.js +4 -0
  372. package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
  373. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +16 -5
  374. package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
  375. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +16 -5
  376. package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
  377. package/dist/shared/src/containers/Actions/Actions.cjs.js +12 -2
  378. package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
  379. package/dist/shared/src/containers/Actions/Actions.es.js +12 -2
  380. package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
  381. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +10 -3
  382. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
  383. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +10 -3
  384. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
  385. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js +14 -0
  386. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js.map +1 -1
  387. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js +14 -0
  388. package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js.map +1 -1
  389. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +16 -5
  390. package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
  391. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +16 -5
  392. package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
  393. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +15 -5
  394. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
  395. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +15 -5
  396. package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
  397. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +16 -5
  398. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
  399. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +16 -5
  400. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
  401. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +16 -5
  402. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
  403. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +16 -5
  404. package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
  405. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +16 -4
  406. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
  407. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +17 -5
  408. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
  409. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js +1 -31
  410. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.cjs.js.map +1 -1
  411. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.es.js +1 -31
  412. package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.es.js.map +1 -1
  413. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +4 -0
  414. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
  415. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +4 -0
  416. package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
  417. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +4 -0
  418. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
  419. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +4 -0
  420. package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
  421. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js +2 -2
  422. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.cjs.js.map +1 -1
  423. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js +2 -2
  424. package/dist/shared/src/containers/Feed/components/ActivityReference/ActivityReference.styled.es.js.map +1 -1
  425. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js +1 -1
  426. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.cjs.js.map +1 -1
  427. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js +1 -1
  428. package/dist/shared/src/containers/Feed/components/FileUploadPreview/FileUploadPreview.styled.es.js.map +1 -1
  429. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +4 -0
  430. package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
  431. package/dist/shared/src/containers/Feed/context/FeedContext.es.js +4 -0
  432. package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
  433. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js +1 -1
  434. package/dist/shared/src/containers/Feed/hooks/useCommentMutations.cjs.js.map +1 -1
  435. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +4 -0
  436. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
  437. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +4 -0
  438. package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
  439. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +57 -5
  440. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
  441. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +59 -7
  442. package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
  443. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +47 -11
  444. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
  445. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +47 -11
  446. package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
  447. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +15 -4
  448. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
  449. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +15 -4
  450. package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
  451. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js +5 -3
  452. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.cjs.js.map +1 -1
  453. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js +5 -3
  454. package/dist/shared/src/containers/ProjectTreeTable/components/HeaderActionButton.es.js.map +1 -1
  455. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js +106 -2
  456. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.cjs.js.map +1 -1
  457. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js +106 -2
  458. package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingContext.es.js.map +1 -1
  459. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js +14 -2
  460. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.cjs.js.map +1 -1
  461. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js +14 -2
  462. package/dist/shared/src/containers/ProjectTreeTable/context/ClipboardContext.es.js.map +1 -1
  463. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +4 -0
  464. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
  465. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +4 -0
  466. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
  467. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.cjs.js.map +1 -1
  468. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableContext.es.js.map +1 -1
  469. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js +15 -3
  470. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.cjs.js.map +1 -1
  471. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js +15 -3
  472. package/dist/shared/src/containers/ProjectTreeTable/context/ProjectTableProvider.es.js.map +1 -1
  473. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +110 -0
  474. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
  475. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +110 -0
  476. package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
  477. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +4 -0
  478. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -1
  479. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +4 -0
  480. package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -1
  481. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +4 -2
  482. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
  483. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +4 -2
  484. package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
  485. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +26 -4
  486. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
  487. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +26 -4
  488. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
  489. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +139 -0
  490. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -0
  491. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +139 -0
  492. package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -0
  493. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js +8 -6
  494. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.cjs.js.map +1 -1
  495. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js +8 -6
  496. package/dist/shared/src/containers/ProjectTreeTable/hooks/useDeleteEntities.es.js.map +1 -1
  497. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +4 -0
  498. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
  499. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +4 -0
  500. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
  501. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js +1 -2
  502. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.cjs.js.map +1 -1
  503. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js +1 -2
  504. package/dist/shared/src/containers/ProjectTreeTable/hooks/useFolderRelationships.es.js.map +1 -1
  505. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +92 -0
  506. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
  507. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +92 -0
  508. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
  509. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js +4 -0
  510. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js.map +1 -1
  511. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js +4 -0
  512. package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js.map +1 -1
  513. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js +1 -1
  514. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.cjs.js.map +1 -1
  515. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js +1 -1
  516. package/dist/shared/src/containers/ProjectTreeTable/hooks/useHistory.es.js.map +1 -1
  517. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +35 -4
  518. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
  519. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +35 -4
  520. package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
  521. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js +4 -0
  522. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -1
  523. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js +4 -0
  524. package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js.map +1 -1
  525. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +92 -0
  526. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
  527. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +92 -0
  528. package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
  529. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js +1 -1
  530. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.cjs.js.map +1 -1
  531. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js +1 -1
  532. package/dist/shared/src/containers/ProjectTreeTable/hooks/useUpdateTableData.es.js.map +1 -1
  533. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +94 -0
  534. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
  535. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +94 -0
  536. package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
  537. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.cjs.js +19 -0
  538. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.cjs.js.map +1 -0
  539. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.es.js +19 -0
  540. package/dist/shared/src/containers/ProjectTreeTable/utils/getEntityViewerIds.es.js.map +1 -0
  541. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.cjs.js +26 -0
  542. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.cjs.js.map +1 -0
  543. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.es.js +26 -0
  544. package/dist/shared/src/containers/ProjectTreeTable/utils/getTypeDefaultValue.es.js.map +1 -0
  545. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +9 -8
  546. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
  547. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +10 -9
  548. package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
  549. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js +8 -2
  550. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.cjs.js.map +1 -1
  551. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js +8 -2
  552. package/dist/shared/src/containers/ProjectTreeTable/widgets/EntityNameWidget.es.js.map +1 -1
  553. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js +190 -0
  554. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.cjs.js.map +1 -0
  555. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js +190 -0
  556. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumCellValue.es.js.map +1 -0
  557. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js +4 -147
  558. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.cjs.js.map +1 -1
  559. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js +2 -145
  560. package/dist/shared/src/containers/ProjectTreeTable/widgets/EnumWidget.es.js.map +1 -1
  561. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js +12 -2
  562. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js.map +1 -1
  563. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js +12 -2
  564. package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js.map +1 -1
  565. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +16 -5
  566. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
  567. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +16 -5
  568. package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
  569. package/dist/shared/src/context/AddonProjectContext.cjs.js +4 -0
  570. package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
  571. package/dist/shared/src/context/AddonProjectContext.es.js +4 -0
  572. package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
  573. package/dist/shared/src/context/DetailsPanelContext.cjs.js +9 -1
  574. package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
  575. package/dist/shared/src/context/DetailsPanelContext.es.js +9 -1
  576. package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
  577. package/dist/shared/src/context/PowerpackContext.cjs.js +9 -0
  578. package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
  579. package/dist/shared/src/context/PowerpackContext.es.js +9 -0
  580. package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
  581. package/dist/shared/src/context/RemoteModulesContext.cjs.js +4 -0
  582. package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
  583. package/dist/shared/src/context/RemoteModulesContext.es.js +4 -0
  584. package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
  585. package/dist/shared/src/hooks/useActionTriggers.cjs.js +4 -0
  586. package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
  587. package/dist/shared/src/hooks/useActionTriggers.es.js +4 -0
  588. package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
  589. package/dist/shared/src/hooks/useEntityUpdate.cjs.js +4 -0
  590. package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
  591. package/dist/shared/src/hooks/useEntityUpdate.es.js +4 -0
  592. package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
  593. package/dist/shared/src/hooks/useScopedStatuses.cjs.js +4 -0
  594. package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
  595. package/dist/shared/src/hooks/useScopedStatuses.es.js +4 -0
  596. package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
  597. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +4 -0
  598. package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
  599. package/dist/shared/src/hooks/useUserProjectConfig.es.js +4 -0
  600. package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
  601. package/dist/shared/src/util/confirmDelete.cjs.js +1 -0
  602. package/dist/shared/src/util/confirmDelete.cjs.js.map +1 -1
  603. package/dist/shared/src/util/confirmDelete.es.js +2 -0
  604. package/dist/shared/src/util/confirmDelete.es.js.map +1 -1
  605. package/dist/types/SimpleTable/SimpleTable.d.ts +1 -0
  606. package/dist/types/SimpleTable/SimpleTableRowTemplate.d.ts +1 -1
  607. package/dist/types/SimpleTable/context/SimpleTableContext.d.ts +5 -1
  608. package/dist/types/api/generated/actions.d.ts +11 -4
  609. package/dist/types/api/generated/activityFeed.d.ts +3 -0
  610. package/dist/types/api/generated/addons.d.ts +1 -0
  611. package/dist/types/api/generated/anatomy.d.ts +0 -2
  612. package/dist/types/api/generated/authentication.d.ts +0 -1
  613. package/dist/types/api/generated/configuration.d.ts +6 -0
  614. package/dist/types/api/generated/folders.d.ts +1 -0
  615. package/dist/types/api/generated/graphql.d.ts +66 -5
  616. package/dist/types/api/generated/index.d.ts +2 -0
  617. package/dist/types/api/generated/links.d.ts +7 -5
  618. package/dist/types/api/generated/onboarding.d.ts +0 -1
  619. package/dist/types/api/generated/operations.d.ts +2 -0
  620. package/dist/types/api/generated/projects.d.ts +0 -35
  621. package/dist/types/api/generated/system.d.ts +2 -0
  622. package/dist/types/api/generated/tasks.d.ts +0 -14
  623. package/dist/types/api/generated/views.d.ts +122 -0
  624. package/dist/types/api/queries/actions/getActions.d.ts +132 -1
  625. package/dist/types/api/queries/activities/getActivities.d.ts +6 -0
  626. package/dist/types/api/queries/activities/updateActivities.d.ts +12 -0
  627. package/dist/types/api/queries/cloud/cloud.d.ts +593 -0
  628. package/dist/types/api/queries/cloud/index.d.ts +1 -0
  629. package/dist/types/api/queries/entities/getEntity.d.ts +6 -0
  630. package/dist/types/api/queries/entities/getEntityPanel.d.ts +6 -0
  631. package/dist/types/api/queries/entities/transformDetailsPanelData.d.ts +1 -0
  632. package/dist/types/api/queries/entities/updateEntity.d.ts +6 -0
  633. package/dist/types/api/queries/entityLists/getLists.d.ts +1517 -2
  634. package/dist/types/api/queries/entityLists/types.d.ts +30 -1
  635. package/dist/types/api/queries/entityLists/updateLists.d.ts +166 -3
  636. package/dist/types/api/queries/index.d.ts +2 -0
  637. package/dist/types/api/queries/overview/getOverview.d.ts +6 -0
  638. package/dist/types/api/queries/project/getProject.d.ts +0 -2
  639. package/dist/types/api/queries/userDashboard/getUserDashboard.d.ts +6 -0
  640. package/dist/types/api/queries/users/getUsers.d.ts +6 -0
  641. package/dist/types/api/queries/views/getViews.d.ts +412 -0
  642. package/dist/types/api/queries/views/index.d.ts +2 -0
  643. package/dist/types/api/queries/views/updateViews.d.ts +177 -0
  644. package/dist/types/components/Feedback/FeedbackContext.d.ts +17 -0
  645. package/dist/types/components/Feedback/SupportBubble.d.ts +4 -0
  646. package/dist/types/components/Feedback/index.d.ts +2 -0
  647. package/dist/types/components/PlayableIcon/PlayableIcon.d.ts +4 -0
  648. package/dist/types/components/Powerpack/CTAButton.d.ts +4 -0
  649. package/dist/types/components/Powerpack/PowerpackDialog.d.ts +8 -0
  650. package/dist/types/components/Views/ViewForm/ViewForm.d.ts +14 -0
  651. package/dist/types/components/Views/ViewForm/ViewForm.styled.d.ts +9 -0
  652. package/dist/types/components/Views/ViewForm/ViewFormContainer.d.ts +15 -0
  653. package/dist/types/components/Views/ViewItem/ViewItem.d.ts +15 -0
  654. package/dist/types/components/Views/ViewItem/ViewItem.styled.d.ts +4 -0
  655. package/dist/types/components/Views/Views.d.ts +8 -0
  656. package/dist/types/components/Views/Views.styled.d.ts +4 -0
  657. package/dist/types/components/Views/ViewsButton/ViewsButton.d.ts +2 -0
  658. package/dist/types/components/Views/ViewsMenu/ViewsMenu.d.ts +11 -0
  659. package/dist/types/components/Views/ViewsMenu/ViewsMenu.styled.d.ts +4 -0
  660. package/dist/types/components/Views/ViewsMenuContainer/ViewsMenuContainer.d.ts +4 -0
  661. package/dist/types/components/Views/context/ViewsContext.d.ts +31 -0
  662. package/dist/types/components/Views/hooks/useBuildViewMenuItems.d.ts +14 -0
  663. package/dist/types/components/Views/index.d.ts +11 -0
  664. package/dist/types/components/Views/utils/generatePersonalView.d.ts +3 -0
  665. package/dist/types/components/Views/utils/getCustomViewsFallback.d.ts +12 -0
  666. package/dist/types/components/Views/utils/portalUtils.d.ts +9 -0
  667. package/dist/types/components/index.d.ts +2 -0
  668. package/dist/types/containers/Actions/Actions.d.ts +7 -1
  669. package/dist/types/containers/Actions/ActionsDropdown/ActionsDropdown.d.ts +5 -3
  670. package/dist/types/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.styled.d.ts +0 -1
  671. package/dist/types/containers/ProjectTreeTable/ProjectTreeTable.d.ts +6 -2
  672. package/dist/types/containers/ProjectTreeTable/context/ProjectTableContext.d.ts +4 -1
  673. package/dist/types/containers/ProjectTreeTable/context/ProjectTableProvider.d.ts +11 -2
  674. package/dist/types/containers/ProjectTreeTable/hooks/index.d.ts +1 -0
  675. package/dist/types/containers/ProjectTreeTable/hooks/useCellContextMenu.d.ts +1 -1
  676. package/dist/types/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.d.ts +9 -0
  677. package/dist/types/containers/ProjectTreeTable/hooks/useFolderRelationships.d.ts +2 -2
  678. package/dist/types/containers/ProjectTreeTable/hooks/useKeyboardNavigation.d.ts +3 -3
  679. package/dist/types/containers/ProjectTreeTable/hooks/useUpdateTableData.d.ts +1 -1
  680. package/dist/types/containers/ProjectTreeTable/types/table.d.ts +10 -1
  681. package/dist/types/containers/ProjectTreeTable/utils/getEntityViewerIds.d.ts +4 -0
  682. package/dist/types/containers/ProjectTreeTable/utils/getTypeDefaultValue.d.ts +2 -0
  683. package/dist/types/containers/ProjectTreeTable/utils/index.d.ts +2 -0
  684. package/dist/types/containers/ProjectTreeTable/widgets/CellWidget.d.ts +2 -1
  685. package/dist/types/containers/ProjectTreeTable/widgets/EnumCellValue.d.ts +20 -0
  686. package/dist/types/containers/ProjectTreeTable/widgets/EnumWidget.d.ts +1 -11
  687. package/dist/types/containers/ProjectTreeTable/widgets/ThumbnailWidget.d.ts +1 -0
  688. package/dist/types/context/DetailsPanelContext.d.ts +1 -0
  689. package/dist/types/context/PowerpackContext.d.ts +5 -5
  690. package/dist/types/util/confirmDelete.d.ts +2 -1
  691. package/dist/util.cjs.js +2 -0
  692. package/dist/util.cjs.js.map +1 -1
  693. package/dist/util.es.js +2 -0
  694. package/dist/util.es.js.map +1 -1
  695. package/package.json +1 -1
@@ -1,5 +1,5 @@
1
1
  import { j as jsxRuntimeExports } from "../../../../../_virtual/jsx-runtime.es.js";
2
- import { memo, useRef, useCallback, useMemo } from "react";
2
+ import { useRef, useCallback, useMemo } from "react";
3
3
  import styled from "styled-components";
4
4
  import { BooleanWidget } from "./BooleanWidget.es.js";
5
5
  import { CollapsedWidget } from "./CollapsedWidget.es.js";
@@ -32,7 +32,7 @@ const Cell = styled.div`
32
32
  opacity: 1;
33
33
  }
34
34
  `;
35
- const EditorCellComponent = ({
35
+ const CellWidget = ({
36
36
  rowId,
37
37
  columnId,
38
38
  value,
@@ -83,7 +83,10 @@ const EditorCellComponent = ({
83
83
  }
84
84
  };
85
85
  const handleCancel = () => {
86
+ var _a;
86
87
  setEditingCellId(null);
88
+ const td = (_a = ref.current) == null ? void 0 : _a.closest("td");
89
+ if (td) td.focus();
87
90
  };
88
91
  const widget = useMemo(() => {
89
92
  const sharedProps = {
@@ -158,7 +161,11 @@ const EditorCellComponent = ({
158
161
  Cell,
159
162
  {
160
163
  ...props,
161
- className: clsx(props.className, { inherited: isInherited && !isCurrentCellEditing }),
164
+ className: clsx(props.className, {
165
+ inherited: isInherited && !isCurrentCellEditing,
166
+ readonly: isReadOnly,
167
+ editable: !isReadOnly
168
+ }),
162
169
  ref,
163
170
  onDoubleClick: handleDoubleClick,
164
171
  onClick: handleSingleClick,
@@ -169,12 +176,6 @@ const EditorCellComponent = ({
169
176
  }
170
177
  );
171
178
  };
172
- function arePropsEqual(prevProps, nextProps) {
173
- var _a, _b, _c, _d, _e, _f;
174
- return prevProps.rowId === nextProps.rowId && prevProps.columnId === nextProps.columnId && prevProps.isCollapsed === nextProps.isCollapsed && JSON.stringify(prevProps.value) === JSON.stringify(nextProps.value) && ((_a = prevProps == null ? void 0 : prevProps.attributeData) == null ? void 0 : _a.type) === ((_b = nextProps == null ? void 0 : nextProps.attributeData) == null ? void 0 : _b.type) && // Only check options length for list types to avoid deep comparison
175
- (!((_c = prevProps == null ? void 0 : prevProps.attributeData) == null ? void 0 : _c.type.includes("list")) && !((_d = nextProps == null ? void 0 : nextProps.attributeData) == null ? void 0 : _d.type.includes("list")) || ((_e = prevProps.options) == null ? void 0 : _e.length) === ((_f = nextProps.options) == null ? void 0 : _f.length)) && prevProps.isInherited === nextProps.isInherited && prevProps.enableCustomValues === nextProps.enableCustomValues && prevProps.isReadOnly === nextProps.isReadOnly && prevProps.isPlaceholder === nextProps.isPlaceholder && prevProps.isFocused === nextProps.isFocused && prevProps.isCollapsed === nextProps.isCollapsed;
176
- }
177
- const CellWidget = memo(EditorCellComponent, arePropsEqual);
178
179
  export {
179
180
  CellWidget
180
181
  };
@@ -1 +1 @@
1
- {"version":3,"file":"CellWidget.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/CellWidget.tsx"],"sourcesContent":["import { useMemo, memo, useCallback, useRef, FC } from 'react'\nimport styled from 'styled-components'\n\n// Widgets\nimport { BooleanWidget, BooleanWidgetProps } from './BooleanWidget'\nimport { CollapsedWidget } from './CollapsedWidget'\nimport { DateWidget, DateWidgetProps } from './DateWidget'\nimport { EnumWidget, EnumWidgetProps } from './EnumWidget'\nimport { TextWidget, TextWidgetProps, TextWidgetType } from './TextWidget'\n\n// Contexts\nimport { useCellEditing } from '../context/CellEditingContext'\n\n// Utils\nimport { getCellId } from '../utils/cellUtils'\nimport clsx from 'clsx'\nimport { useSelectionCellsContext } from '../context/SelectionCellsContext'\nimport { AttributeData, AttributeEnumItem } from '../types'\n\nconst Cell = styled.div`\n position: absolute;\n inset: 0;\n padding: 4px 8px;\n display: flex;\n align-items: center;\n\n &:focus-visible {\n outline: none;\n }\n\n &.inherited {\n opacity: 0.6;\n font-style: italic;\n }\n\n &.loading {\n inset: 4px;\n border-radius: 4px;\n opacity: 1;\n }\n`\n\ntype WidgetAttributeData = Pick<AttributeData, 'type'>\n\nexport type CellValue = string | number | boolean\n\ninterface EditorCellProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n rowId: string\n columnId: string\n value: CellValue | CellValue[]\n attributeData?: WidgetAttributeData\n options?: AttributeEnumItem[]\n isCollapsed?: boolean\n isInherited?: boolean\n isPlaceholder?: boolean\n isFocused?: boolean\n isReadOnly?: boolean\n enableCustomValues?: boolean\n onChange?: (value: CellValue | CellValue[], key?: 'Enter' | 'Click' | 'Escape') => void\n // options passthrough props\n pt?: {\n enum?: Partial<EnumWidgetProps>\n text?: Partial<TextWidgetProps>\n date?: Partial<DateWidgetProps>\n boolean?: Partial<BooleanWidgetProps>\n }\n}\n\nexport interface WidgetBaseProps {\n isEditing?: boolean\n onChange: Required<EditorCellProps>['onChange']\n onCancelEdit?: () => void\n}\n\nconst EditorCellComponent: FC<EditorCellProps> = ({\n rowId,\n columnId,\n value,\n attributeData,\n options = [],\n isCollapsed,\n isInherited,\n isPlaceholder,\n isReadOnly,\n enableCustomValues,\n onChange,\n pt,\n ...props\n}) => {\n const ref = useRef<HTMLDivElement>(null)\n const type = attributeData?.type\n\n const { isEditing, setEditingCellId } = useCellEditing()\n const { isCellFocused, gridMap, selectCell, focusCell } = useSelectionCellsContext()\n const cellId = getCellId(rowId, columnId)\n\n const isCurrentCellEditing = isEditing(cellId)\n const isCurrentCellFocused = isCellFocused(cellId)\n\n const handleDoubleClick = useCallback(() => {\n if (isPlaceholder || isReadOnly) return\n setEditingCellId(cellId)\n }, [cellId, setEditingCellId, isPlaceholder])\n\n const handleSingleClick = () => {\n // clicking a cell that is not editing will close the editor on this cell\n if (!isCurrentCellEditing) {\n setEditingCellId(null)\n }\n }\n\n const moveToNextRow = () => {\n const rowIndex = gridMap.rowIdToIndex.get(rowId)\n if (rowIndex === undefined) return\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, columnId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n setEditingCellId(newCellId)\n }\n }\n\n const handleOnChange: WidgetBaseProps['onChange'] = (newValue, key) => {\n setEditingCellId(null)\n if (isReadOnly) return\n // move to the next cell row\n key === 'Enter' && moveToNextRow()\n // make change if the value is different or if the key is 'Enter'\n if (newValue !== value || key === 'Enter') {\n onChange?.(newValue, key)\n }\n }\n\n const handleCancel = () => {\n setEditingCellId(null)\n }\n\n const widget = useMemo(() => {\n // Common props shared across all widgets\n const sharedProps: WidgetBaseProps = {\n onChange: handleOnChange,\n onCancelEdit: handleCancel,\n isEditing: isCurrentCellEditing,\n }\n\n const textTypes: TextWidgetType[] = ['string', 'integer', 'float']\n\n // Determine widget type based on attribute type\n switch (true) {\n // this is showing the collapsed widget (dot)\n case isCollapsed: {\n // if enum, find the first selected option and get its color\n const firstSelectedOption = type?.includes('list')\n ? options.find((option) =>\n Array.isArray(value) ? value.includes(option.value) : value === option.value,\n )\n : undefined\n const color = firstSelectedOption?.color\n return <CollapsedWidget color={color} />\n }\n\n case !!options.length: {\n const enumValue = Array.isArray(value) ? value : [value]\n if (isReadOnly) {\n return (\n <TextWidget\n value={enumValue.join(', ')}\n option={\n enumValue.length === 1 ? options.find((o) => o.value === enumValue[0]) : undefined\n }\n {...sharedProps}\n />\n )\n }\n return (\n <EnumWidget\n value={enumValue}\n options={options}\n type={type}\n onOpen={() => !isReadOnly && setEditingCellId(cellId)}\n enableCustomValues={enableCustomValues}\n {...sharedProps}\n {...pt?.enum}\n />\n )\n }\n\n case textTypes.includes(type as TextWidgetType):\n return (\n <TextWidget\n value={value as string}\n isInherited={isInherited}\n {...sharedProps}\n {...pt?.text}\n />\n )\n\n case type === 'datetime':\n return (\n <DateWidget\n value={value ? (value as string) : undefined}\n isInherited={isInherited}\n {...sharedProps}\n {...pt?.date}\n />\n )\n\n case type === 'boolean':\n return <BooleanWidget value={value as boolean} {...sharedProps} {...pt?.boolean} />\n\n case isPlaceholder:\n return null\n\n default:\n // TODO: We should not allow editing unrecognized types\n // At this point, only list_of_strings without proper options is unrecognized\n // (tags if not tags are specified in anatomy) and in that case, validation\n // on the server fails with a string value. Unless we have a widget that\n // accepts a string value AND options at the same time we shouldn't show\n // any edit widget\n\n //console.log(`Unrecognized type \"${type}\" for cell ${cellId}.`)\n return null\n }\n }, [cellId, value, type, isCurrentCellEditing, options, isCollapsed])\n\n return (\n <Cell\n {...props}\n className={clsx(props.className, { inherited: isInherited && !isCurrentCellEditing })}\n ref={ref}\n onDoubleClick={handleDoubleClick}\n onClick={handleSingleClick}\n id={cellId}\n data-tooltip={\n isInherited && !isCurrentCellEditing && isCurrentCellFocused ? 'Inherited' : undefined\n }\n data-tooltip-delay={200}\n >\n {widget}\n </Cell>\n )\n}\n\n// Custom comparison function for memo\nfunction arePropsEqual(prevProps: EditorCellProps, nextProps: EditorCellProps) {\n // Only re-render if these props change\n return (\n prevProps.rowId === nextProps.rowId &&\n prevProps.columnId === nextProps.columnId &&\n prevProps.isCollapsed === nextProps.isCollapsed &&\n JSON.stringify(prevProps.value) === JSON.stringify(nextProps.value) &&\n prevProps?.attributeData?.type === nextProps?.attributeData?.type &&\n // Only check options length for list types to avoid deep comparison\n ((!prevProps?.attributeData?.type.includes('list') &&\n !nextProps?.attributeData?.type.includes('list')) ||\n prevProps.options?.length === nextProps.options?.length) &&\n prevProps.isInherited === nextProps.isInherited &&\n prevProps.enableCustomValues === nextProps.enableCustomValues &&\n prevProps.isReadOnly === nextProps.isReadOnly &&\n prevProps.isPlaceholder === nextProps.isPlaceholder &&\n prevProps.isFocused === nextProps.isFocused &&\n prevProps.isCollapsed === nextProps.isCollapsed\n )\n}\n\nexport const CellWidget = memo(EditorCellComponent, arePropsEqual)\n"],"names":["jsx"],"mappings":"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"}
1
+ {"version":3,"file":"CellWidget.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/CellWidget.tsx"],"sourcesContent":["import { useMemo, memo, useCallback, useRef, FC } from 'react'\nimport styled from 'styled-components'\n\n// Widgets\nimport { BooleanWidget, BooleanWidgetProps } from './BooleanWidget'\nimport { CollapsedWidget } from './CollapsedWidget'\nimport { DateWidget, DateWidgetProps } from './DateWidget'\nimport { EnumWidget, EnumWidgetProps } from './EnumWidget'\nimport { TextWidget, TextWidgetProps, TextWidgetType } from './TextWidget'\n\n// Contexts\nimport { useCellEditing } from '../context/CellEditingContext'\n\n// Utils\nimport { getCellId } from '../utils/cellUtils'\nimport clsx from 'clsx'\nimport { useSelectionCellsContext } from '../context/SelectionCellsContext'\nimport { AttributeData, AttributeEnumItem } from '../types'\n\nconst Cell = styled.div`\n position: absolute;\n inset: 0;\n padding: 4px 8px;\n display: flex;\n align-items: center;\n\n &:focus-visible {\n outline: none;\n }\n\n &.inherited {\n opacity: 0.6;\n font-style: italic;\n }\n\n &.loading {\n inset: 4px;\n border-radius: 4px;\n opacity: 1;\n }\n`\n\ntype WidgetAttributeData = Pick<AttributeData, 'type'>\n\nexport type CellValue = string | number | boolean\n\ninterface EditorCellProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange'> {\n rowId: string\n columnId: string\n value: CellValue | CellValue[]\n attributeData?: WidgetAttributeData\n options?: AttributeEnumItem[]\n isCollapsed?: boolean\n isInherited?: boolean\n isPlaceholder?: boolean\n isFocused?: boolean\n isReadOnly?: boolean\n enableCustomValues?: boolean\n onChange?: (value: CellValue | CellValue[], key?: 'Enter' | 'Click' | 'Escape') => void\n // options passthrough props\n pt?: {\n enum?: Partial<EnumWidgetProps>\n text?: Partial<TextWidgetProps>\n date?: Partial<DateWidgetProps>\n boolean?: Partial<BooleanWidgetProps>\n }\n}\n\nexport interface WidgetBaseProps {\n isEditing?: boolean\n onChange: Required<EditorCellProps>['onChange']\n onCancelEdit?: () => void\n}\n\nexport const CellWidget: FC<EditorCellProps> = ({\n rowId,\n columnId,\n value,\n attributeData,\n options = [],\n isCollapsed,\n isInherited,\n isPlaceholder,\n isReadOnly,\n enableCustomValues,\n onChange,\n pt,\n ...props\n}) => {\n const ref = useRef<HTMLDivElement>(null)\n const type = attributeData?.type\n\n const { isEditing, setEditingCellId } = useCellEditing()\n const { isCellFocused, gridMap, selectCell, focusCell } = useSelectionCellsContext()\n const cellId = getCellId(rowId, columnId)\n\n const isCurrentCellEditing = isEditing(cellId)\n const isCurrentCellFocused = isCellFocused(cellId)\n\n const handleDoubleClick = useCallback(() => {\n if (isPlaceholder || isReadOnly) return\n setEditingCellId(cellId)\n }, [cellId, setEditingCellId, isPlaceholder])\n\n const handleSingleClick = () => {\n // clicking a cell that is not editing will close the editor on this cell\n if (!isCurrentCellEditing) {\n setEditingCellId(null)\n }\n }\n\n const moveToNextRow = () => {\n const rowIndex = gridMap.rowIdToIndex.get(rowId)\n if (rowIndex === undefined) return\n const newRowId = gridMap.indexToRowId.get(rowIndex + 1)\n if (newRowId) {\n const newCellId = getCellId(newRowId, columnId)\n selectCell(newCellId, false, false)\n focusCell(newCellId)\n setEditingCellId(newCellId)\n }\n }\n\n const handleOnChange: WidgetBaseProps['onChange'] = (newValue, key) => {\n setEditingCellId(null)\n if (isReadOnly) return\n // move to the next cell row\n key === 'Enter' && moveToNextRow()\n // make change if the value is different or if the key is 'Enter'\n if (newValue !== value || key === 'Enter') {\n onChange?.(newValue, key)\n }\n }\n\n const handleCancel = () => {\n setEditingCellId(null)\n // ensure the browser focus moves back to the parent <td>\n const td = ref.current?.closest('td') as HTMLElement | null\n if (td) td.focus()\n }\n\n const widget = useMemo(() => {\n // Common props shared across all widgets\n const sharedProps: WidgetBaseProps = {\n onChange: handleOnChange,\n onCancelEdit: handleCancel,\n isEditing: isCurrentCellEditing,\n }\n\n const textTypes: TextWidgetType[] = ['string', 'integer', 'float']\n\n // Determine widget type based on attribute type\n switch (true) {\n // this is showing the collapsed widget (dot)\n case isCollapsed: {\n // if enum, find the first selected option and get its color\n const firstSelectedOption = type?.includes('list')\n ? options.find((option) =>\n Array.isArray(value) ? value.includes(option.value) : value === option.value,\n )\n : undefined\n const color = firstSelectedOption?.color\n return <CollapsedWidget color={color} />\n }\n\n case !!options.length: {\n const enumValue = Array.isArray(value) ? value : [value]\n if (isReadOnly) {\n return (\n <TextWidget\n value={enumValue.join(', ')}\n option={\n enumValue.length === 1 ? options.find((o) => o.value === enumValue[0]) : undefined\n }\n {...sharedProps}\n />\n )\n }\n return (\n <EnumWidget\n value={enumValue}\n options={options}\n type={type}\n onOpen={() => !isReadOnly && setEditingCellId(cellId)}\n enableCustomValues={enableCustomValues}\n {...sharedProps}\n {...pt?.enum}\n />\n )\n }\n\n case textTypes.includes(type as TextWidgetType):\n return (\n <TextWidget\n value={value as string}\n isInherited={isInherited}\n {...sharedProps}\n {...pt?.text}\n />\n )\n\n case type === 'datetime':\n return (\n <DateWidget\n value={value ? (value as string) : undefined}\n isInherited={isInherited}\n {...sharedProps}\n {...pt?.date}\n />\n )\n\n case type === 'boolean':\n return <BooleanWidget value={value as boolean} {...sharedProps} {...pt?.boolean} />\n\n case isPlaceholder:\n return null\n\n default:\n // TODO: We should not allow editing unrecognized types\n // At this point, only list_of_strings without proper options is unrecognized\n // (tags if not tags are specified in anatomy) and in that case, validation\n // on the server fails with a string value. Unless we have a widget that\n // accepts a string value AND options at the same time we shouldn't show\n // any edit widget\n\n //console.log(`Unrecognized type \"${type}\" for cell ${cellId}.`)\n return null\n }\n }, [cellId, value, type, isCurrentCellEditing, options, isCollapsed])\n\n return (\n <Cell\n {...props}\n className={clsx(props.className, {\n inherited: isInherited && !isCurrentCellEditing,\n readonly: isReadOnly,\n editable: !isReadOnly,\n })}\n ref={ref}\n onDoubleClick={handleDoubleClick}\n onClick={handleSingleClick}\n id={cellId}\n data-tooltip={\n isInherited && !isCurrentCellEditing && isCurrentCellFocused ? 'Inherited' : undefined\n }\n data-tooltip-delay={200}\n >\n {widget}\n </Cell>\n )\n}\n"],"names":["jsx"],"mappings":"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"}
@@ -4,8 +4,14 @@ const jsxRuntime = require("../../../../../_virtual/jsx-runtime.cjs.js");
4
4
  const ayonReactComponents = require("@ynput/ayon-react-components");
5
5
  const styled = require("styled-components");
6
6
  const Expander = styled(ayonReactComponents.Button)`
7
- background-color: unset !important;
8
- padding: 2px !important;
7
+ &.expander {
8
+ background-color: unset;
9
+ padding: 2px;
10
+
11
+ &:hover {
12
+ background-color: var(--md-sys-color-surface-container-high-hover);
13
+ }
14
+ }
9
15
  cursor: pointer;
10
16
  `;
11
17
  const StyledEntityNameWidget = styled.div`
@@ -1 +1 @@
1
- {"version":3,"file":"EntityNameWidget.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/EntityNameWidget.tsx"],"sourcesContent":["import { Button, Icon, theme } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nconst Expander = styled(Button)`\n background-color: unset !important;\n padding: 2px !important;\n cursor: pointer;\n`\n\nconst StyledEntityNameWidget = styled.div`\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 100%;\n width: 100%;\n padding-right: 8px;\n`\n\nconst StyledContentWrapper = styled.div`\n width: 100%;\n height: 24px;\n overflow: hidden;\n position: relative;\n`\n\nconst StyledContentAbsolute = styled.div`\n position: absolute;\n inset: 0;\n`\n\nconst StyledContent = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-large);\n padding: 2px 4px;\n border-radius: var(--border-radius-m);\n cursor: pointer;\n overflow: hidden;\n width: fit-content;\n max-width: 100%;\n height: 100%;\n\n /* &:hover {\n &,\n .icon,\n .path {\n color: var(--md-sys-color-primary);\n }\n } */\n`\n\nconst StyledTextContent = styled.div`\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n .path {\n ${theme.labelSmall}\n margin-bottom: -4px;\n color: var(--md-sys-color-outline);\n }\n\n span {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n`\n\ntype EntityNameWidgetProps = {\n id: string\n label: string\n name: string\n path?: string | null\n showHierarchy?: boolean\n icon?: string | null\n type: string\n isExpanded: boolean\n toggleExpandAll: (id: string) => void\n toggleExpanded: () => void\n}\n\nexport const EntityNameWidget = ({\n id,\n label,\n name,\n path,\n showHierarchy,\n icon,\n type,\n isExpanded,\n toggleExpandAll,\n toggleExpanded,\n}: EntityNameWidgetProps) => {\n return (\n <StyledEntityNameWidget>\n {showHierarchy ? (\n type === 'folder' ? (\n <Expander\n onClick={(e) => {\n e.stopPropagation()\n if (e.altKey) {\n // expand/collapse all children\n toggleExpandAll(id)\n } else {\n // use built-in toggleExpanded function\n toggleExpanded()\n }\n }}\n className=\"expander\"\n icon={isExpanded ? 'expand_more' : 'chevron_right'}\n />\n ) : (\n <div style={{ display: 'inline-block', minWidth: 24 }} />\n )\n ) : null}\n <StyledContentWrapper style={{ height: path ? 32 : 24 }}>\n <StyledContentAbsolute>\n <StyledContent>\n {icon && <Icon icon={icon} />}\n <StyledTextContent>\n {path && <span className=\"path\">{path}</span>}\n <span className=\"label\">{label || name}</span>\n </StyledTextContent>\n </StyledContent>\n </StyledContentAbsolute>\n </StyledContentWrapper>\n </StyledEntityNameWidget>\n )\n}\n"],"names":["Button","theme","jsx","jsxs","Icon"],"mappings":";;;;;AAGA,MAAM,WAAW,OAAOA,0BAAM;AAAA;AAAA;AAAA;AAAA;AAM9B,MAAM,yBAAyB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUtC,MAAM,uBAAuB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAOpC,MAAM,wBAAwB,OAAO;AAAA;AAAA;AAAA;AAKrC,MAAM,gBAAgB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAqB7B,MAAM,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAM3BC,0BAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyBf,MAAM,mBAAmB,CAAC;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA6B;AAC3B,2DACG,wBACE,EAAA,UAAA;AAAA,IAAA,gBACC,SAAS,WACPC,2BAAA,kBAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,SAAS,CAAC,MAAM;AACd,YAAE,gBAAgB;AAClB,cAAI,EAAE,QAAQ;AAEZ,4BAAgB,EAAE;AAAA,UAAA,OACb;AAEU,2BAAA;AAAA,UAAA;AAAA,QAEnB;AAAA,QACA,WAAU;AAAA,QACV,MAAM,aAAa,gBAAgB;AAAA,MAAA;AAAA,IACrC,IAECA,iDAAA,OAAA,EAAI,OAAO,EAAE,SAAS,gBAAgB,UAAU,KAAM,CAAA,IAEvD;AAAA,IACHA,2BAAA,kBAAA,IAAA,sBAAA,EAAqB,OAAO,EAAE,QAAQ,OAAO,KAAK,GAAA,GACjD,UAAAA,2BAAAA,kBAAAA,IAAC,uBACC,EAAA,UAAAC,2BAAAA,kBAAAA,KAAC,eACE,EAAA,UAAA;AAAA,MAAQ,QAAAD,2BAAA,kBAAA,IAACE,4BAAK,KAAY,CAAA;AAAA,wDAC1B,mBACE,EAAA,UAAA;AAAA,QAAA,QAASF,2BAAA,kBAAA,IAAA,QAAA,EAAK,WAAU,QAAQ,UAAK,MAAA;AAAA,QACrCA,2BAAA,kBAAA,IAAA,QAAA,EAAK,WAAU,SAAS,mBAAS,KAAK,CAAA;AAAA,MAAA,EACzC,CAAA;AAAA,IAAA,EACF,CAAA,EACF,CAAA,EACF,CAAA;AAAA,EAAA,GACF;AAEJ;;"}
1
+ {"version":3,"file":"EntityNameWidget.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/EntityNameWidget.tsx"],"sourcesContent":["import { Button, Icon, theme } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nconst Expander = styled(Button)`\n &.expander {\n background-color: unset;\n padding: 2px;\n\n &:hover {\n background-color: var(--md-sys-color-surface-container-high-hover);\n }\n }\n cursor: pointer;\n`\n\nconst StyledEntityNameWidget = styled.div`\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 100%;\n width: 100%;\n padding-right: 8px;\n`\n\nconst StyledContentWrapper = styled.div`\n width: 100%;\n height: 24px;\n overflow: hidden;\n position: relative;\n`\n\nconst StyledContentAbsolute = styled.div`\n position: absolute;\n inset: 0;\n`\n\nconst StyledContent = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-large);\n padding: 2px 4px;\n border-radius: var(--border-radius-m);\n cursor: pointer;\n overflow: hidden;\n width: fit-content;\n max-width: 100%;\n height: 100%;\n\n /* &:hover {\n &,\n .icon,\n .path {\n color: var(--md-sys-color-primary);\n }\n } */\n`\n\nconst StyledTextContent = styled.div`\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n .path {\n ${theme.labelSmall}\n margin-bottom: -4px;\n color: var(--md-sys-color-outline);\n }\n\n span {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n`\n\ntype EntityNameWidgetProps = {\n id: string\n label: string\n name: string\n path?: string | null\n showHierarchy?: boolean\n icon?: string | null\n type: string\n isExpanded: boolean\n toggleExpandAll: (id: string) => void\n toggleExpanded: () => void\n}\n\nexport const EntityNameWidget = ({\n id,\n label,\n name,\n path,\n showHierarchy,\n icon,\n type,\n isExpanded,\n toggleExpandAll,\n toggleExpanded,\n}: EntityNameWidgetProps) => {\n return (\n <StyledEntityNameWidget>\n {showHierarchy ? (\n type === 'folder' ? (\n <Expander\n onClick={(e) => {\n e.stopPropagation()\n if (e.altKey) {\n // expand/collapse all children\n toggleExpandAll(id)\n } else {\n // use built-in toggleExpanded function\n toggleExpanded()\n }\n }}\n className=\"expander\"\n icon={isExpanded ? 'expand_more' : 'chevron_right'}\n />\n ) : (\n <div style={{ display: 'inline-block', minWidth: 24 }} />\n )\n ) : null}\n <StyledContentWrapper style={{ height: path ? 32 : 24 }}>\n <StyledContentAbsolute>\n <StyledContent>\n {icon && <Icon icon={icon} />}\n <StyledTextContent>\n {path && <span className=\"path\">{path}</span>}\n <span className=\"label\">{label || name}</span>\n </StyledTextContent>\n </StyledContent>\n </StyledContentAbsolute>\n </StyledContentWrapper>\n </StyledEntityNameWidget>\n )\n}\n"],"names":["Button","theme","jsx","jsxs","Icon"],"mappings":";;;;;AAGA,MAAM,WAAW,OAAOA,0BAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAY9B,MAAM,yBAAyB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUtC,MAAM,uBAAuB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAOpC,MAAM,wBAAwB,OAAO;AAAA;AAAA;AAAA;AAKrC,MAAM,gBAAgB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAqB7B,MAAM,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAM3BC,0BAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyBf,MAAM,mBAAmB,CAAC;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA6B;AAC3B,2DACG,wBACE,EAAA,UAAA;AAAA,IAAA,gBACC,SAAS,WACPC,2BAAA,kBAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,SAAS,CAAC,MAAM;AACd,YAAE,gBAAgB;AAClB,cAAI,EAAE,QAAQ;AAEZ,4BAAgB,EAAE;AAAA,UAAA,OACb;AAEU,2BAAA;AAAA,UAAA;AAAA,QAEnB;AAAA,QACA,WAAU;AAAA,QACV,MAAM,aAAa,gBAAgB;AAAA,MAAA;AAAA,IACrC,IAECA,iDAAA,OAAA,EAAI,OAAO,EAAE,SAAS,gBAAgB,UAAU,KAAM,CAAA,IAEvD;AAAA,IACHA,2BAAA,kBAAA,IAAA,sBAAA,EAAqB,OAAO,EAAE,QAAQ,OAAO,KAAK,GAAA,GACjD,UAAAA,2BAAAA,kBAAAA,IAAC,uBACC,EAAA,UAAAC,2BAAAA,kBAAAA,KAAC,eACE,EAAA,UAAA;AAAA,MAAQ,QAAAD,2BAAA,kBAAA,IAACE,4BAAK,KAAY,CAAA;AAAA,wDAC1B,mBACE,EAAA,UAAA;AAAA,QAAA,QAASF,2BAAA,kBAAA,IAAA,QAAA,EAAK,WAAU,QAAQ,UAAK,MAAA;AAAA,QACrCA,2BAAA,kBAAA,IAAA,QAAA,EAAK,WAAU,SAAS,mBAAS,KAAK,CAAA;AAAA,MAAA,EACzC,CAAA;AAAA,IAAA,EACF,CAAA,EACF,CAAA,EACF,CAAA;AAAA,EAAA,GACF;AAEJ;;"}
@@ -2,8 +2,14 @@ import { j as jsxRuntimeExports } from "../../../../../_virtual/jsx-runtime.es.j
2
2
  import { Button, theme, Icon } from "@ynput/ayon-react-components";
3
3
  import styled from "styled-components";
4
4
  const Expander = styled(Button)`
5
- background-color: unset !important;
6
- padding: 2px !important;
5
+ &.expander {
6
+ background-color: unset;
7
+ padding: 2px;
8
+
9
+ &:hover {
10
+ background-color: var(--md-sys-color-surface-container-high-hover);
11
+ }
12
+ }
7
13
  cursor: pointer;
8
14
  `;
9
15
  const StyledEntityNameWidget = styled.div`
@@ -1 +1 @@
1
- {"version":3,"file":"EntityNameWidget.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/EntityNameWidget.tsx"],"sourcesContent":["import { Button, Icon, theme } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nconst Expander = styled(Button)`\n background-color: unset !important;\n padding: 2px !important;\n cursor: pointer;\n`\n\nconst StyledEntityNameWidget = styled.div`\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 100%;\n width: 100%;\n padding-right: 8px;\n`\n\nconst StyledContentWrapper = styled.div`\n width: 100%;\n height: 24px;\n overflow: hidden;\n position: relative;\n`\n\nconst StyledContentAbsolute = styled.div`\n position: absolute;\n inset: 0;\n`\n\nconst StyledContent = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-large);\n padding: 2px 4px;\n border-radius: var(--border-radius-m);\n cursor: pointer;\n overflow: hidden;\n width: fit-content;\n max-width: 100%;\n height: 100%;\n\n /* &:hover {\n &,\n .icon,\n .path {\n color: var(--md-sys-color-primary);\n }\n } */\n`\n\nconst StyledTextContent = styled.div`\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n .path {\n ${theme.labelSmall}\n margin-bottom: -4px;\n color: var(--md-sys-color-outline);\n }\n\n span {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n`\n\ntype EntityNameWidgetProps = {\n id: string\n label: string\n name: string\n path?: string | null\n showHierarchy?: boolean\n icon?: string | null\n type: string\n isExpanded: boolean\n toggleExpandAll: (id: string) => void\n toggleExpanded: () => void\n}\n\nexport const EntityNameWidget = ({\n id,\n label,\n name,\n path,\n showHierarchy,\n icon,\n type,\n isExpanded,\n toggleExpandAll,\n toggleExpanded,\n}: EntityNameWidgetProps) => {\n return (\n <StyledEntityNameWidget>\n {showHierarchy ? (\n type === 'folder' ? (\n <Expander\n onClick={(e) => {\n e.stopPropagation()\n if (e.altKey) {\n // expand/collapse all children\n toggleExpandAll(id)\n } else {\n // use built-in toggleExpanded function\n toggleExpanded()\n }\n }}\n className=\"expander\"\n icon={isExpanded ? 'expand_more' : 'chevron_right'}\n />\n ) : (\n <div style={{ display: 'inline-block', minWidth: 24 }} />\n )\n ) : null}\n <StyledContentWrapper style={{ height: path ? 32 : 24 }}>\n <StyledContentAbsolute>\n <StyledContent>\n {icon && <Icon icon={icon} />}\n <StyledTextContent>\n {path && <span className=\"path\">{path}</span>}\n <span className=\"label\">{label || name}</span>\n </StyledTextContent>\n </StyledContent>\n </StyledContentAbsolute>\n </StyledContentWrapper>\n </StyledEntityNameWidget>\n )\n}\n"],"names":["jsx","jsxs"],"mappings":";;;AAGA,MAAM,WAAW,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAM9B,MAAM,yBAAyB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUtC,MAAM,uBAAuB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAOpC,MAAM,wBAAwB,OAAO;AAAA;AAAA;AAAA;AAKrC,MAAM,gBAAgB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAqB7B,MAAM,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAM3B,MAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyBf,MAAM,mBAAmB,CAAC;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA6B;AAC3B,gDACG,wBACE,EAAA,UAAA;AAAA,IAAA,gBACC,SAAS,WACPA,kCAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,SAAS,CAAC,MAAM;AACd,YAAE,gBAAgB;AAClB,cAAI,EAAE,QAAQ;AAEZ,4BAAgB,EAAE;AAAA,UAAA,OACb;AAEU,2BAAA;AAAA,UAAA;AAAA,QAEnB;AAAA,QACA,WAAU;AAAA,QACV,MAAM,aAAa,gBAAgB;AAAA,MAAA;AAAA,IACrC,IAECA,sCAAA,OAAA,EAAI,OAAO,EAAE,SAAS,gBAAgB,UAAU,KAAM,CAAA,IAEvD;AAAA,IACHA,kCAAA,IAAA,sBAAA,EAAqB,OAAO,EAAE,QAAQ,OAAO,KAAK,GAAA,GACjD,UAAAA,kCAAAA,IAAC,uBACC,EAAA,UAAAC,kCAAAA,KAAC,eACE,EAAA,UAAA;AAAA,MAAQ,QAAAD,kCAAA,IAAC,QAAK,KAAY,CAAA;AAAA,6CAC1B,mBACE,EAAA,UAAA;AAAA,QAAA,QAASA,kCAAA,IAAA,QAAA,EAAK,WAAU,QAAQ,UAAK,MAAA;AAAA,QACrCA,kCAAA,IAAA,QAAA,EAAK,WAAU,SAAS,mBAAS,KAAK,CAAA;AAAA,MAAA,EACzC,CAAA;AAAA,IAAA,EACF,CAAA,EACF,CAAA,EACF,CAAA;AAAA,EAAA,GACF;AAEJ;"}
1
+ {"version":3,"file":"EntityNameWidget.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/EntityNameWidget.tsx"],"sourcesContent":["import { Button, Icon, theme } from '@ynput/ayon-react-components'\nimport styled from 'styled-components'\n\nconst Expander = styled(Button)`\n &.expander {\n background-color: unset;\n padding: 2px;\n\n &:hover {\n background-color: var(--md-sys-color-surface-container-high-hover);\n }\n }\n cursor: pointer;\n`\n\nconst StyledEntityNameWidget = styled.div`\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 100%;\n width: 100%;\n padding-right: 8px;\n`\n\nconst StyledContentWrapper = styled.div`\n width: 100%;\n height: 24px;\n overflow: hidden;\n position: relative;\n`\n\nconst StyledContentAbsolute = styled.div`\n position: absolute;\n inset: 0;\n`\n\nconst StyledContent = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-large);\n padding: 2px 4px;\n border-radius: var(--border-radius-m);\n cursor: pointer;\n overflow: hidden;\n width: fit-content;\n max-width: 100%;\n height: 100%;\n\n /* &:hover {\n &,\n .icon,\n .path {\n color: var(--md-sys-color-primary);\n }\n } */\n`\n\nconst StyledTextContent = styled.div`\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n .path {\n ${theme.labelSmall}\n margin-bottom: -4px;\n color: var(--md-sys-color-outline);\n }\n\n span {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n`\n\ntype EntityNameWidgetProps = {\n id: string\n label: string\n name: string\n path?: string | null\n showHierarchy?: boolean\n icon?: string | null\n type: string\n isExpanded: boolean\n toggleExpandAll: (id: string) => void\n toggleExpanded: () => void\n}\n\nexport const EntityNameWidget = ({\n id,\n label,\n name,\n path,\n showHierarchy,\n icon,\n type,\n isExpanded,\n toggleExpandAll,\n toggleExpanded,\n}: EntityNameWidgetProps) => {\n return (\n <StyledEntityNameWidget>\n {showHierarchy ? (\n type === 'folder' ? (\n <Expander\n onClick={(e) => {\n e.stopPropagation()\n if (e.altKey) {\n // expand/collapse all children\n toggleExpandAll(id)\n } else {\n // use built-in toggleExpanded function\n toggleExpanded()\n }\n }}\n className=\"expander\"\n icon={isExpanded ? 'expand_more' : 'chevron_right'}\n />\n ) : (\n <div style={{ display: 'inline-block', minWidth: 24 }} />\n )\n ) : null}\n <StyledContentWrapper style={{ height: path ? 32 : 24 }}>\n <StyledContentAbsolute>\n <StyledContent>\n {icon && <Icon icon={icon} />}\n <StyledTextContent>\n {path && <span className=\"path\">{path}</span>}\n <span className=\"label\">{label || name}</span>\n </StyledTextContent>\n </StyledContent>\n </StyledContentAbsolute>\n </StyledContentWrapper>\n </StyledEntityNameWidget>\n )\n}\n"],"names":["jsx","jsxs"],"mappings":";;;AAGA,MAAM,WAAW,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAY9B,MAAM,yBAAyB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUtC,MAAM,uBAAuB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAOpC,MAAM,wBAAwB,OAAO;AAAA;AAAA;AAAA;AAKrC,MAAM,gBAAgB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAqB7B,MAAM,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAM3B,MAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyBf,MAAM,mBAAmB,CAAC;AAAA,EAC/B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAA6B;AAC3B,gDACG,wBACE,EAAA,UAAA;AAAA,IAAA,gBACC,SAAS,WACPA,kCAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,SAAS,CAAC,MAAM;AACd,YAAE,gBAAgB;AAClB,cAAI,EAAE,QAAQ;AAEZ,4BAAgB,EAAE;AAAA,UAAA,OACb;AAEU,2BAAA;AAAA,UAAA;AAAA,QAEnB;AAAA,QACA,WAAU;AAAA,QACV,MAAM,aAAa,gBAAgB;AAAA,MAAA;AAAA,IACrC,IAECA,sCAAA,OAAA,EAAI,OAAO,EAAE,SAAS,gBAAgB,UAAU,KAAM,CAAA,IAEvD;AAAA,IACHA,kCAAA,IAAA,sBAAA,EAAqB,OAAO,EAAE,QAAQ,OAAO,KAAK,GAAA,GACjD,UAAAA,kCAAAA,IAAC,uBACC,EAAA,UAAAC,kCAAAA,KAAC,eACE,EAAA,UAAA;AAAA,MAAQ,QAAAD,kCAAA,IAAC,QAAK,KAAY,CAAA;AAAA,6CAC1B,mBACE,EAAA,UAAA;AAAA,QAAA,QAASA,kCAAA,IAAA,QAAA,EAAK,WAAU,QAAQ,UAAK,MAAA;AAAA,QACrCA,kCAAA,IAAA,QAAA,EAAK,WAAU,SAAS,mBAAS,KAAK,CAAA;AAAA,MAAA,EACzC,CAAA;AAAA,IAAA,EACF,CAAA,EACF,CAAA,EACF,CAAA;AAAA,EAAA,GACF;AAEJ;"}
@@ -0,0 +1,190 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("../../../../../_virtual/jsx-runtime.cjs.js");
4
+ const ayonReactComponents = require("@ynput/ayon-react-components");
5
+ const clsx = require("clsx");
6
+ const styled = require("styled-components");
7
+ const StyledWidget = styled.div`
8
+ display: flex;
9
+ gap: var(--base-gap-small);
10
+ align-items: center;
11
+ width: 100%;
12
+ height: 100%;
13
+ overflow: hidden;
14
+ border-radius: var(--border-radius-m);
15
+
16
+ &.item {
17
+ padding: 4px 2px;
18
+ border-radius: 0;
19
+
20
+ &:hover {
21
+ background-color: var(--md-sys-color-surface-container-hover);
22
+ }
23
+ }
24
+
25
+ &.selected {
26
+ background-color: var(--md-sys-color-primary-container);
27
+
28
+ &:hover {
29
+ background-color: var(--md-sys-color-primary-container-hover);
30
+ }
31
+ }
32
+ `;
33
+ const StyledValuesContainer = styled.div`
34
+ flex: 1;
35
+ display: flex;
36
+ gap: var(--base-gap-small);
37
+ align-items: center;
38
+ overflow: hidden;
39
+ border-radius: var(--border-radius-m);
40
+ padding: 0px 2px;
41
+ `;
42
+ const StyledValueWrapper = styled.div`
43
+ display: flex;
44
+ gap: var(--base-gap-small);
45
+ align-items: center;
46
+
47
+ overflow: hidden;
48
+ max-width: 100%;
49
+ min-width: 20px;
50
+ `;
51
+ const StyledValue = styled.span`
52
+ overflow: hidden;
53
+ white-space: nowrap;
54
+ width: 100%;
55
+ text-overflow: ellipsis;
56
+ text-align: left;
57
+ border-radius: var(--border-radius-m);
58
+ padding: 0px 2px;
59
+
60
+ &.placeholder {
61
+ color: var(--md-sys-color-outline);
62
+ }
63
+ `;
64
+ const StyledImg = styled.img`
65
+ width: 20px;
66
+ height: 20px;
67
+ object-fit: cover;
68
+
69
+ &.avatar {
70
+ border-radius: 50%;
71
+ }
72
+ `;
73
+ const StyledExpandButton = styled.div`
74
+ width: 32px;
75
+ height: 32px;
76
+ border-radius: var(--border-radius-m);
77
+ display: flex;
78
+ justify-content: center;
79
+ align-items: center;
80
+ cursor: pointer;
81
+
82
+ &:hover {
83
+ background-color: var(--md-sys-color-surface-container-highest-hover);
84
+ }
85
+
86
+ &.open {
87
+ background-color: transparent;
88
+ }
89
+ `;
90
+ const StyledExpandIcon = styled(ayonReactComponents.Icon)`
91
+ transition: rotate 0.2s;
92
+ `;
93
+ const EnumCellValue = ({
94
+ selectedOptions,
95
+ placeholder,
96
+ hasMultipleValues,
97
+ isMultiSelect,
98
+ isOpen,
99
+ isItem,
100
+ isSelected,
101
+ isReadOnly,
102
+ className,
103
+ pt,
104
+ ...props
105
+ }) => {
106
+ const {
107
+ icon: ptIcon = {},
108
+ img: ptImg = {},
109
+ value: ptValue = {},
110
+ expand: ptExpand = {},
111
+ close: ptClose = {}
112
+ } = pt || {};
113
+ const { style: iconStyle, className: iconClassName, ...iconRest } = ptIcon;
114
+ const { style: imgStyle, className: imgClassName, ...imgRest } = ptImg;
115
+ const { style: valueStyle, className: valueClassName, ...valueRest } = ptValue;
116
+ const { style: expandStyle, className: expandClassName, ...expandRest } = ptExpand;
117
+ const { style: closeStyle, className: closeClassName, ...closeRest } = ptClose;
118
+ const allOptionsHaveIcon = selectedOptions.every((option) => option.icon);
119
+ const showLabels = !hasMultipleValues || !allOptionsHaveIcon;
120
+ const backgroundColor = !allOptionsHaveIcon && isMultiSelect && !isItem;
121
+ const isPlaceholder = !selectedOptions.length && placeholder;
122
+ if (isPlaceholder) {
123
+ selectedOptions = [
124
+ {
125
+ label: placeholder,
126
+ value: ""
127
+ }
128
+ ];
129
+ }
130
+ return /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsxs(StyledWidget, { className: clsx(className, { selected: isSelected, item: isItem }), ...props, children: [
131
+ /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(StyledValuesContainer, { children: selectedOptions.map((option, i) => /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsxs(StyledValueWrapper, { children: [
132
+ option.icon && checkForImgSrc(option.icon) ? /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
133
+ StyledImg,
134
+ {
135
+ src: option.icon,
136
+ className: clsx({ avatar: checkAvatarImg(option.icon) }, imgClassName),
137
+ style: imgStyle,
138
+ ...imgRest
139
+ }
140
+ ) : option.icon ? /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
141
+ ayonReactComponents.Icon,
142
+ {
143
+ icon: option.icon,
144
+ style: { color: option.color, ...iconStyle },
145
+ className: iconClassName,
146
+ ...iconRest
147
+ }
148
+ ) : null,
149
+ (showLabels || !option.icon) && /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
150
+ StyledValue,
151
+ {
152
+ style: {
153
+ color: backgroundColor ? "inherit" : option.color,
154
+ backgroundColor: backgroundColor ? option.color || "var(--md-sys-color-surface-container)" : "transparent",
155
+ ...valueStyle
156
+ },
157
+ className: clsx({ placeholder: isPlaceholder }, valueClassName),
158
+ "aria-label": option.label,
159
+ ...valueRest,
160
+ children: option.label
161
+ }
162
+ )
163
+ ] }, option.value.toString() + i)) }),
164
+ !isItem && !isReadOnly && /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(StyledExpandButton, { className: clsx("expand", { open: isOpen }, expandClassName), children: /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
165
+ StyledExpandIcon,
166
+ {
167
+ icon: "expand_more",
168
+ style: { rotate: isOpen ? "180deg" : "0", ...expandStyle },
169
+ "aria-label": "Expand options",
170
+ ...expandRest
171
+ }
172
+ ) }),
173
+ isItem && isSelected && isMultiSelect && /* @__PURE__ */ jsxRuntime.jsxRuntimeExports.jsx(
174
+ ayonReactComponents.Icon,
175
+ {
176
+ icon: "close",
177
+ style: { marginLeft: "auto", marginRight: 4, ...closeStyle },
178
+ "aria-label": "Deselect item",
179
+ className: clsx("close", closeClassName),
180
+ ...closeRest
181
+ }
182
+ )
183
+ ] });
184
+ };
185
+ const checkForImgSrc = (icon = "") => {
186
+ return icon.startsWith("/") || icon.startsWith("./") || icon.startsWith("../") || icon.startsWith("http://") || icon.startsWith("https://");
187
+ };
188
+ const checkAvatarImg = (src) => src.includes("avatar");
189
+ exports.EnumCellValue = EnumCellValue;
190
+ //# sourceMappingURL=EnumCellValue.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EnumCellValue.cjs.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/EnumCellValue.tsx"],"sourcesContent":["import { AttributeEnumItem } from '@shared/api'\nimport { Icon, IconProps } from '@ynput/ayon-react-components'\nimport clsx from 'clsx'\nimport styled from 'styled-components'\n\nconst StyledWidget = styled.div`\n display: flex;\n gap: var(--base-gap-small);\n align-items: center;\n width: 100%;\n height: 100%;\n overflow: hidden;\n border-radius: var(--border-radius-m);\n\n &.item {\n padding: 4px 2px;\n border-radius: 0;\n\n &:hover {\n background-color: var(--md-sys-color-surface-container-hover);\n }\n }\n\n &.selected {\n background-color: var(--md-sys-color-primary-container);\n\n &:hover {\n background-color: var(--md-sys-color-primary-container-hover);\n }\n }\n`\n\nconst StyledValuesContainer = styled.div`\n flex: 1;\n display: flex;\n gap: var(--base-gap-small);\n align-items: center;\n overflow: hidden;\n border-radius: var(--border-radius-m);\n padding: 0px 2px;\n`\n\nconst StyledValueWrapper = styled.div`\n display: flex;\n gap: var(--base-gap-small);\n align-items: center;\n\n overflow: hidden;\n max-width: 100%;\n min-width: 20px;\n`\n\nconst StyledValue = styled.span`\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n text-overflow: ellipsis;\n text-align: left;\n border-radius: var(--border-radius-m);\n padding: 0px 2px;\n\n &.placeholder {\n color: var(--md-sys-color-outline);\n }\n`\n\nconst StyledImg = styled.img`\n width: 20px;\n height: 20px;\n object-fit: cover;\n\n &.avatar {\n border-radius: 50%;\n }\n`\n\nconst StyledExpandButton = styled.div`\n width: 32px;\n height: 32px;\n border-radius: var(--border-radius-m);\n display: flex;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n\n &:hover {\n background-color: var(--md-sys-color-surface-container-highest-hover);\n }\n\n &.open {\n background-color: transparent;\n }\n`\n\nconst StyledExpandIcon = styled(Icon)`\n transition: rotate 0.2s;\n`\n\nexport interface EnumTemplateProps extends React.HTMLAttributes<HTMLSpanElement> {\n selectedOptions: AttributeEnumItem[]\n placeholder?: string\n hasMultipleValues: boolean\n isMultiSelect: boolean\n isOpen?: boolean\n isItem?: boolean\n isSelected?: boolean\n isReadOnly?: boolean\n pt?: {\n icon?: Partial<IconProps>\n img?: Partial<React.ImgHTMLAttributes<HTMLImageElement>>\n value?: Partial<React.ImgHTMLAttributes<HTMLSpanElement>>\n expand?: Partial<IconProps>\n close?: Partial<IconProps>\n }\n}\n\nexport const EnumCellValue = ({\n selectedOptions,\n placeholder,\n hasMultipleValues,\n isMultiSelect,\n isOpen,\n isItem,\n isSelected,\n isReadOnly,\n className,\n pt,\n ...props\n}: EnumTemplateProps) => {\n // Destructure pt subprops and their relevant props at the top\n const {\n icon: ptIcon = {},\n img: ptImg = {},\n value: ptValue = {},\n expand: ptExpand = {},\n close: ptClose = {},\n } = pt || {}\n\n const { style: iconStyle, className: iconClassName, ...iconRest } = ptIcon\n const { style: imgStyle, className: imgClassName, ...imgRest } = ptImg\n const { style: valueStyle, className: valueClassName, ...valueRest } = ptValue\n const { style: expandStyle, className: expandClassName, ...expandRest } = ptExpand\n const { style: closeStyle, className: closeClassName, ...closeRest } = ptClose\n\n // Check if all options have icons\n const allOptionsHaveIcon = selectedOptions.every((option) => option.icon)\n\n // Determine if we should show labels based on the requirements\n const showLabels = !hasMultipleValues || !allOptionsHaveIcon\n // Show the colors be backgrounds instead of the text\n const backgroundColor = !allOptionsHaveIcon && isMultiSelect && !isItem\n\n const isPlaceholder = !selectedOptions.length && placeholder\n if (isPlaceholder) {\n selectedOptions = [\n {\n label: placeholder,\n value: '',\n },\n ]\n }\n\n return (\n <StyledWidget className={clsx(className, { selected: isSelected, item: isItem })} {...props}>\n <StyledValuesContainer>\n {selectedOptions.map((option, i) => (\n <StyledValueWrapper key={option.value.toString() + i}>\n {option.icon && checkForImgSrc(option.icon) ? (\n <StyledImg\n src={option.icon}\n className={clsx({ avatar: checkAvatarImg(option.icon) }, imgClassName)}\n style={imgStyle}\n {...imgRest}\n />\n ) : option.icon ? (\n <Icon\n icon={option.icon}\n style={{ color: option.color, ...iconStyle }}\n className={iconClassName}\n {...iconRest}\n />\n ) : null}\n\n {(showLabels || !option.icon) && (\n <StyledValue\n style={{\n color: backgroundColor ? 'inherit' : option.color,\n backgroundColor: backgroundColor\n ? option.color || 'var(--md-sys-color-surface-container)'\n : 'transparent',\n ...valueStyle,\n }}\n className={clsx({ placeholder: isPlaceholder }, valueClassName)}\n aria-label={option.label}\n {...valueRest}\n >\n {option.label}\n </StyledValue>\n )}\n </StyledValueWrapper>\n ))}\n </StyledValuesContainer>\n {!isItem && !isReadOnly && (\n <StyledExpandButton className={clsx('expand', { open: isOpen }, expandClassName)}>\n <StyledExpandIcon\n icon=\"expand_more\"\n style={{ rotate: isOpen ? '180deg' : '0', ...expandStyle }}\n aria-label=\"Expand options\"\n {...expandRest}\n />\n </StyledExpandButton>\n )}\n {isItem && isSelected && isMultiSelect && (\n <Icon\n icon=\"close\"\n style={{ marginLeft: 'auto', marginRight: 4, ...closeStyle }}\n aria-label=\"Deselect item\"\n className={clsx('close', closeClassName)}\n {...closeRest}\n />\n )}\n </StyledWidget>\n )\n}\n\n// Helper functions to check if the icon is a valid image source\nconst checkForImgSrc = (icon: string | undefined = ''): boolean => {\n return (\n icon.startsWith('/') ||\n icon.startsWith('./') ||\n icon.startsWith('../') ||\n icon.startsWith('http://') ||\n icon.startsWith('https://')\n )\n}\n\nconst checkAvatarImg = (src: string): boolean => src.includes('avatar')\n"],"names":["Icon","jsxs","jsx"],"mappings":";;;;;;AAKA,MAAM,eAAe,OAAO;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;AA2B5B,MAAM,wBAAwB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUrC,MAAM,qBAAqB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUlC,MAAM,cAAc,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAc3B,MAAM,YAAY,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUzB,MAAM,qBAAqB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkBlC,MAAM,mBAAmB,OAAOA,wBAAI;AAAA;AAAA;AAsB7B,MAAM,gBAAgB,CAAC;AAAA,EAC5B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAyB;AAEjB,QAAA;AAAA,IACJ,MAAM,SAAS,CAAC;AAAA,IAChB,KAAK,QAAQ,CAAC;AAAA,IACd,OAAO,UAAU,CAAC;AAAA,IAClB,QAAQ,WAAW,CAAC;AAAA,IACpB,OAAO,UAAU,CAAA;AAAA,EACnB,IAAI,MAAM,CAAC;AAEX,QAAM,EAAE,OAAO,WAAW,WAAW,eAAe,GAAG,aAAa;AACpE,QAAM,EAAE,OAAO,UAAU,WAAW,cAAc,GAAG,YAAY;AACjE,QAAM,EAAE,OAAO,YAAY,WAAW,gBAAgB,GAAG,cAAc;AACvE,QAAM,EAAE,OAAO,aAAa,WAAW,iBAAiB,GAAG,eAAe;AAC1E,QAAM,EAAE,OAAO,YAAY,WAAW,gBAAgB,GAAG,cAAc;AAGvE,QAAM,qBAAqB,gBAAgB,MAAM,CAAC,WAAW,OAAO,IAAI;AAGlE,QAAA,aAAa,CAAC,qBAAqB,CAAC;AAE1C,QAAM,kBAAkB,CAAC,sBAAsB,iBAAiB,CAAC;AAE3D,QAAA,gBAAgB,CAAC,gBAAgB,UAAU;AACjD,MAAI,eAAe;AACC,sBAAA;AAAA,MAChB;AAAA,QACE,OAAO;AAAA,QACP,OAAO;AAAA,MAAA;AAAA,IAEX;AAAA,EAAA;AAGF,SACGC,2BAAA,kBAAA,KAAA,cAAA,EAAa,WAAW,KAAK,WAAW,EAAE,UAAU,YAAY,MAAM,OAAA,CAAQ,GAAI,GAAG,OACpF,UAAA;AAAA,IAAAC,2BAAAA,kBAAAA,IAAC,yBACE,UAAgB,gBAAA,IAAI,CAAC,QAAQ,wDAC3B,oBACE,EAAA,UAAA;AAAA,MAAA,OAAO,QAAQ,eAAe,OAAO,IAAI,IACxCA,2BAAA,kBAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,KAAK,OAAO;AAAA,UACZ,WAAW,KAAK,EAAE,QAAQ,eAAe,OAAO,IAAI,EAAE,GAAG,YAAY;AAAA,UACrE,OAAO;AAAA,UACN,GAAG;AAAA,QAAA;AAAA,MAAA,IAEJ,OAAO,OACTA,2BAAA,kBAAA;AAAA,QAACF,oBAAA;AAAA,QAAA;AAAA,UACC,MAAM,OAAO;AAAA,UACb,OAAO,EAAE,OAAO,OAAO,OAAO,GAAG,UAAU;AAAA,UAC3C,WAAW;AAAA,UACV,GAAG;AAAA,QAAA;AAAA,MAAA,IAEJ;AAAA,OAEF,cAAc,CAAC,OAAO,SACtBE,2BAAA,kBAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAO;AAAA,YACL,OAAO,kBAAkB,YAAY,OAAO;AAAA,YAC5C,iBAAiB,kBACb,OAAO,SAAS,0CAChB;AAAA,YACJ,GAAG;AAAA,UACL;AAAA,UACA,WAAW,KAAK,EAAE,aAAa,cAAA,GAAiB,cAAc;AAAA,UAC9D,cAAY,OAAO;AAAA,UAClB,GAAG;AAAA,UAEH,UAAO,OAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IACV,EAAA,GA/BqB,OAAO,MAAM,SAAA,IAAa,CAiCnD,CACD,GACH;AAAA,IACC,CAAC,UAAU,CAAC,+DACV,oBAAmB,EAAA,WAAW,KAAK,UAAU,EAAE,MAAM,OAAO,GAAG,eAAe,GAC7E,UAAAA,2BAAA,kBAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,OAAO,EAAE,QAAQ,SAAS,WAAW,KAAK,GAAG,YAAY;AAAA,QACzD,cAAW;AAAA,QACV,GAAG;AAAA,MAAA;AAAA,IAAA,GAER;AAAA,IAED,UAAU,cAAc,iBACvBA,2BAAA,kBAAA;AAAA,MAACF,oBAAA;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,OAAO,EAAE,YAAY,QAAQ,aAAa,GAAG,GAAG,WAAW;AAAA,QAC3D,cAAW;AAAA,QACX,WAAW,KAAK,SAAS,cAAc;AAAA,QACtC,GAAG;AAAA,MAAA;AAAA,IAAA;AAAA,EACN,GAEJ;AAEJ;AAGA,MAAM,iBAAiB,CAAC,OAA2B,OAAgB;AACjE,SACE,KAAK,WAAW,GAAG,KACnB,KAAK,WAAW,IAAI,KACpB,KAAK,WAAW,KAAK,KACrB,KAAK,WAAW,SAAS,KACzB,KAAK,WAAW,UAAU;AAE9B;AAEA,MAAM,iBAAiB,CAAC,QAAyB,IAAI,SAAS,QAAQ;;"}
@@ -0,0 +1,190 @@
1
+ import { j as jsxRuntimeExports } from "../../../../../_virtual/jsx-runtime.es.js";
2
+ import { Icon } from "@ynput/ayon-react-components";
3
+ import clsx from "clsx";
4
+ import styled from "styled-components";
5
+ const StyledWidget = styled.div`
6
+ display: flex;
7
+ gap: var(--base-gap-small);
8
+ align-items: center;
9
+ width: 100%;
10
+ height: 100%;
11
+ overflow: hidden;
12
+ border-radius: var(--border-radius-m);
13
+
14
+ &.item {
15
+ padding: 4px 2px;
16
+ border-radius: 0;
17
+
18
+ &:hover {
19
+ background-color: var(--md-sys-color-surface-container-hover);
20
+ }
21
+ }
22
+
23
+ &.selected {
24
+ background-color: var(--md-sys-color-primary-container);
25
+
26
+ &:hover {
27
+ background-color: var(--md-sys-color-primary-container-hover);
28
+ }
29
+ }
30
+ `;
31
+ const StyledValuesContainer = styled.div`
32
+ flex: 1;
33
+ display: flex;
34
+ gap: var(--base-gap-small);
35
+ align-items: center;
36
+ overflow: hidden;
37
+ border-radius: var(--border-radius-m);
38
+ padding: 0px 2px;
39
+ `;
40
+ const StyledValueWrapper = styled.div`
41
+ display: flex;
42
+ gap: var(--base-gap-small);
43
+ align-items: center;
44
+
45
+ overflow: hidden;
46
+ max-width: 100%;
47
+ min-width: 20px;
48
+ `;
49
+ const StyledValue = styled.span`
50
+ overflow: hidden;
51
+ white-space: nowrap;
52
+ width: 100%;
53
+ text-overflow: ellipsis;
54
+ text-align: left;
55
+ border-radius: var(--border-radius-m);
56
+ padding: 0px 2px;
57
+
58
+ &.placeholder {
59
+ color: var(--md-sys-color-outline);
60
+ }
61
+ `;
62
+ const StyledImg = styled.img`
63
+ width: 20px;
64
+ height: 20px;
65
+ object-fit: cover;
66
+
67
+ &.avatar {
68
+ border-radius: 50%;
69
+ }
70
+ `;
71
+ const StyledExpandButton = styled.div`
72
+ width: 32px;
73
+ height: 32px;
74
+ border-radius: var(--border-radius-m);
75
+ display: flex;
76
+ justify-content: center;
77
+ align-items: center;
78
+ cursor: pointer;
79
+
80
+ &:hover {
81
+ background-color: var(--md-sys-color-surface-container-highest-hover);
82
+ }
83
+
84
+ &.open {
85
+ background-color: transparent;
86
+ }
87
+ `;
88
+ const StyledExpandIcon = styled(Icon)`
89
+ transition: rotate 0.2s;
90
+ `;
91
+ const EnumCellValue = ({
92
+ selectedOptions,
93
+ placeholder,
94
+ hasMultipleValues,
95
+ isMultiSelect,
96
+ isOpen,
97
+ isItem,
98
+ isSelected,
99
+ isReadOnly,
100
+ className,
101
+ pt,
102
+ ...props
103
+ }) => {
104
+ const {
105
+ icon: ptIcon = {},
106
+ img: ptImg = {},
107
+ value: ptValue = {},
108
+ expand: ptExpand = {},
109
+ close: ptClose = {}
110
+ } = pt || {};
111
+ const { style: iconStyle, className: iconClassName, ...iconRest } = ptIcon;
112
+ const { style: imgStyle, className: imgClassName, ...imgRest } = ptImg;
113
+ const { style: valueStyle, className: valueClassName, ...valueRest } = ptValue;
114
+ const { style: expandStyle, className: expandClassName, ...expandRest } = ptExpand;
115
+ const { style: closeStyle, className: closeClassName, ...closeRest } = ptClose;
116
+ const allOptionsHaveIcon = selectedOptions.every((option) => option.icon);
117
+ const showLabels = !hasMultipleValues || !allOptionsHaveIcon;
118
+ const backgroundColor = !allOptionsHaveIcon && isMultiSelect && !isItem;
119
+ const isPlaceholder = !selectedOptions.length && placeholder;
120
+ if (isPlaceholder) {
121
+ selectedOptions = [
122
+ {
123
+ label: placeholder,
124
+ value: ""
125
+ }
126
+ ];
127
+ }
128
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs(StyledWidget, { className: clsx(className, { selected: isSelected, item: isItem }), ...props, children: [
129
+ /* @__PURE__ */ jsxRuntimeExports.jsx(StyledValuesContainer, { children: selectedOptions.map((option, i) => /* @__PURE__ */ jsxRuntimeExports.jsxs(StyledValueWrapper, { children: [
130
+ option.icon && checkForImgSrc(option.icon) ? /* @__PURE__ */ jsxRuntimeExports.jsx(
131
+ StyledImg,
132
+ {
133
+ src: option.icon,
134
+ className: clsx({ avatar: checkAvatarImg(option.icon) }, imgClassName),
135
+ style: imgStyle,
136
+ ...imgRest
137
+ }
138
+ ) : option.icon ? /* @__PURE__ */ jsxRuntimeExports.jsx(
139
+ Icon,
140
+ {
141
+ icon: option.icon,
142
+ style: { color: option.color, ...iconStyle },
143
+ className: iconClassName,
144
+ ...iconRest
145
+ }
146
+ ) : null,
147
+ (showLabels || !option.icon) && /* @__PURE__ */ jsxRuntimeExports.jsx(
148
+ StyledValue,
149
+ {
150
+ style: {
151
+ color: backgroundColor ? "inherit" : option.color,
152
+ backgroundColor: backgroundColor ? option.color || "var(--md-sys-color-surface-container)" : "transparent",
153
+ ...valueStyle
154
+ },
155
+ className: clsx({ placeholder: isPlaceholder }, valueClassName),
156
+ "aria-label": option.label,
157
+ ...valueRest,
158
+ children: option.label
159
+ }
160
+ )
161
+ ] }, option.value.toString() + i)) }),
162
+ !isItem && !isReadOnly && /* @__PURE__ */ jsxRuntimeExports.jsx(StyledExpandButton, { className: clsx("expand", { open: isOpen }, expandClassName), children: /* @__PURE__ */ jsxRuntimeExports.jsx(
163
+ StyledExpandIcon,
164
+ {
165
+ icon: "expand_more",
166
+ style: { rotate: isOpen ? "180deg" : "0", ...expandStyle },
167
+ "aria-label": "Expand options",
168
+ ...expandRest
169
+ }
170
+ ) }),
171
+ isItem && isSelected && isMultiSelect && /* @__PURE__ */ jsxRuntimeExports.jsx(
172
+ Icon,
173
+ {
174
+ icon: "close",
175
+ style: { marginLeft: "auto", marginRight: 4, ...closeStyle },
176
+ "aria-label": "Deselect item",
177
+ className: clsx("close", closeClassName),
178
+ ...closeRest
179
+ }
180
+ )
181
+ ] });
182
+ };
183
+ const checkForImgSrc = (icon = "") => {
184
+ return icon.startsWith("/") || icon.startsWith("./") || icon.startsWith("../") || icon.startsWith("http://") || icon.startsWith("https://");
185
+ };
186
+ const checkAvatarImg = (src) => src.includes("avatar");
187
+ export {
188
+ EnumCellValue
189
+ };
190
+ //# sourceMappingURL=EnumCellValue.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EnumCellValue.es.js","sources":["../../../../../../src/containers/ProjectTreeTable/widgets/EnumCellValue.tsx"],"sourcesContent":["import { AttributeEnumItem } from '@shared/api'\nimport { Icon, IconProps } from '@ynput/ayon-react-components'\nimport clsx from 'clsx'\nimport styled from 'styled-components'\n\nconst StyledWidget = styled.div`\n display: flex;\n gap: var(--base-gap-small);\n align-items: center;\n width: 100%;\n height: 100%;\n overflow: hidden;\n border-radius: var(--border-radius-m);\n\n &.item {\n padding: 4px 2px;\n border-radius: 0;\n\n &:hover {\n background-color: var(--md-sys-color-surface-container-hover);\n }\n }\n\n &.selected {\n background-color: var(--md-sys-color-primary-container);\n\n &:hover {\n background-color: var(--md-sys-color-primary-container-hover);\n }\n }\n`\n\nconst StyledValuesContainer = styled.div`\n flex: 1;\n display: flex;\n gap: var(--base-gap-small);\n align-items: center;\n overflow: hidden;\n border-radius: var(--border-radius-m);\n padding: 0px 2px;\n`\n\nconst StyledValueWrapper = styled.div`\n display: flex;\n gap: var(--base-gap-small);\n align-items: center;\n\n overflow: hidden;\n max-width: 100%;\n min-width: 20px;\n`\n\nconst StyledValue = styled.span`\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n text-overflow: ellipsis;\n text-align: left;\n border-radius: var(--border-radius-m);\n padding: 0px 2px;\n\n &.placeholder {\n color: var(--md-sys-color-outline);\n }\n`\n\nconst StyledImg = styled.img`\n width: 20px;\n height: 20px;\n object-fit: cover;\n\n &.avatar {\n border-radius: 50%;\n }\n`\n\nconst StyledExpandButton = styled.div`\n width: 32px;\n height: 32px;\n border-radius: var(--border-radius-m);\n display: flex;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n\n &:hover {\n background-color: var(--md-sys-color-surface-container-highest-hover);\n }\n\n &.open {\n background-color: transparent;\n }\n`\n\nconst StyledExpandIcon = styled(Icon)`\n transition: rotate 0.2s;\n`\n\nexport interface EnumTemplateProps extends React.HTMLAttributes<HTMLSpanElement> {\n selectedOptions: AttributeEnumItem[]\n placeholder?: string\n hasMultipleValues: boolean\n isMultiSelect: boolean\n isOpen?: boolean\n isItem?: boolean\n isSelected?: boolean\n isReadOnly?: boolean\n pt?: {\n icon?: Partial<IconProps>\n img?: Partial<React.ImgHTMLAttributes<HTMLImageElement>>\n value?: Partial<React.ImgHTMLAttributes<HTMLSpanElement>>\n expand?: Partial<IconProps>\n close?: Partial<IconProps>\n }\n}\n\nexport const EnumCellValue = ({\n selectedOptions,\n placeholder,\n hasMultipleValues,\n isMultiSelect,\n isOpen,\n isItem,\n isSelected,\n isReadOnly,\n className,\n pt,\n ...props\n}: EnumTemplateProps) => {\n // Destructure pt subprops and their relevant props at the top\n const {\n icon: ptIcon = {},\n img: ptImg = {},\n value: ptValue = {},\n expand: ptExpand = {},\n close: ptClose = {},\n } = pt || {}\n\n const { style: iconStyle, className: iconClassName, ...iconRest } = ptIcon\n const { style: imgStyle, className: imgClassName, ...imgRest } = ptImg\n const { style: valueStyle, className: valueClassName, ...valueRest } = ptValue\n const { style: expandStyle, className: expandClassName, ...expandRest } = ptExpand\n const { style: closeStyle, className: closeClassName, ...closeRest } = ptClose\n\n // Check if all options have icons\n const allOptionsHaveIcon = selectedOptions.every((option) => option.icon)\n\n // Determine if we should show labels based on the requirements\n const showLabels = !hasMultipleValues || !allOptionsHaveIcon\n // Show the colors be backgrounds instead of the text\n const backgroundColor = !allOptionsHaveIcon && isMultiSelect && !isItem\n\n const isPlaceholder = !selectedOptions.length && placeholder\n if (isPlaceholder) {\n selectedOptions = [\n {\n label: placeholder,\n value: '',\n },\n ]\n }\n\n return (\n <StyledWidget className={clsx(className, { selected: isSelected, item: isItem })} {...props}>\n <StyledValuesContainer>\n {selectedOptions.map((option, i) => (\n <StyledValueWrapper key={option.value.toString() + i}>\n {option.icon && checkForImgSrc(option.icon) ? (\n <StyledImg\n src={option.icon}\n className={clsx({ avatar: checkAvatarImg(option.icon) }, imgClassName)}\n style={imgStyle}\n {...imgRest}\n />\n ) : option.icon ? (\n <Icon\n icon={option.icon}\n style={{ color: option.color, ...iconStyle }}\n className={iconClassName}\n {...iconRest}\n />\n ) : null}\n\n {(showLabels || !option.icon) && (\n <StyledValue\n style={{\n color: backgroundColor ? 'inherit' : option.color,\n backgroundColor: backgroundColor\n ? option.color || 'var(--md-sys-color-surface-container)'\n : 'transparent',\n ...valueStyle,\n }}\n className={clsx({ placeholder: isPlaceholder }, valueClassName)}\n aria-label={option.label}\n {...valueRest}\n >\n {option.label}\n </StyledValue>\n )}\n </StyledValueWrapper>\n ))}\n </StyledValuesContainer>\n {!isItem && !isReadOnly && (\n <StyledExpandButton className={clsx('expand', { open: isOpen }, expandClassName)}>\n <StyledExpandIcon\n icon=\"expand_more\"\n style={{ rotate: isOpen ? '180deg' : '0', ...expandStyle }}\n aria-label=\"Expand options\"\n {...expandRest}\n />\n </StyledExpandButton>\n )}\n {isItem && isSelected && isMultiSelect && (\n <Icon\n icon=\"close\"\n style={{ marginLeft: 'auto', marginRight: 4, ...closeStyle }}\n aria-label=\"Deselect item\"\n className={clsx('close', closeClassName)}\n {...closeRest}\n />\n )}\n </StyledWidget>\n )\n}\n\n// Helper functions to check if the icon is a valid image source\nconst checkForImgSrc = (icon: string | undefined = ''): boolean => {\n return (\n icon.startsWith('/') ||\n icon.startsWith('./') ||\n icon.startsWith('../') ||\n icon.startsWith('http://') ||\n icon.startsWith('https://')\n )\n}\n\nconst checkAvatarImg = (src: string): boolean => src.includes('avatar')\n"],"names":["jsxs","jsx"],"mappings":"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"}