@lokalise/harmony 1.40.1 → 1.40.3-exp-epic2x.1

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 (408) hide show
  1. package/dist/harmony.css +110 -317
  2. package/dist/harmony100.cjs +8 -11
  3. package/dist/harmony100.cjs.map +1 -1
  4. package/dist/harmony100.mjs +8 -11
  5. package/dist/harmony100.mjs.map +1 -1
  6. package/dist/harmony101.cjs +47 -12
  7. package/dist/harmony101.cjs.map +1 -1
  8. package/dist/harmony101.mjs +46 -11
  9. package/dist/harmony101.mjs.map +1 -1
  10. package/dist/harmony102.cjs +6 -3
  11. package/dist/harmony102.cjs.map +1 -1
  12. package/dist/harmony102.mjs +6 -3
  13. package/dist/harmony102.mjs.map +1 -1
  14. package/dist/harmony103.cjs +99 -9
  15. package/dist/harmony103.cjs.map +1 -1
  16. package/dist/harmony103.mjs +81 -8
  17. package/dist/harmony103.mjs.map +1 -1
  18. package/dist/harmony104.cjs +14 -9
  19. package/dist/harmony104.cjs.map +1 -1
  20. package/dist/harmony104.mjs +13 -8
  21. package/dist/harmony104.mjs.map +1 -1
  22. package/dist/harmony105.cjs +20 -57
  23. package/dist/harmony105.cjs.map +1 -1
  24. package/dist/harmony105.mjs +20 -57
  25. package/dist/harmony105.mjs.map +1 -1
  26. package/dist/harmony106.cjs +9 -42
  27. package/dist/harmony106.cjs.map +1 -1
  28. package/dist/harmony106.mjs +8 -41
  29. package/dist/harmony106.mjs.map +1 -1
  30. package/dist/harmony107.cjs +14 -5
  31. package/dist/harmony107.cjs.map +1 -1
  32. package/dist/harmony107.mjs +14 -5
  33. package/dist/harmony107.mjs.map +1 -1
  34. package/dist/harmony108.cjs +17 -9
  35. package/dist/harmony108.cjs.map +1 -1
  36. package/dist/harmony108.mjs +16 -8
  37. package/dist/harmony108.mjs.map +1 -1
  38. package/dist/harmony109.cjs +21 -24
  39. package/dist/harmony109.cjs.map +1 -1
  40. package/dist/harmony109.mjs +20 -23
  41. package/dist/harmony109.mjs.map +1 -1
  42. package/dist/harmony110.cjs +10 -6
  43. package/dist/harmony110.cjs.map +1 -1
  44. package/dist/harmony110.mjs +9 -5
  45. package/dist/harmony110.mjs.map +1 -1
  46. package/dist/harmony111.cjs +22 -14
  47. package/dist/harmony111.cjs.map +1 -1
  48. package/dist/harmony111.mjs +24 -16
  49. package/dist/harmony111.mjs.map +1 -1
  50. package/dist/harmony112.cjs +14 -12
  51. package/dist/harmony112.cjs.map +1 -1
  52. package/dist/harmony112.mjs +13 -11
  53. package/dist/harmony112.mjs.map +1 -1
  54. package/dist/harmony113.cjs +35 -12
  55. package/dist/harmony113.cjs.map +1 -1
  56. package/dist/harmony113.mjs +35 -12
  57. package/dist/harmony113.mjs.map +1 -1
  58. package/dist/harmony114.cjs +14 -18
  59. package/dist/harmony114.cjs.map +1 -1
  60. package/dist/harmony114.mjs +14 -18
  61. package/dist/harmony114.mjs.map +1 -1
  62. package/dist/harmony115.cjs +19 -84
  63. package/dist/harmony115.cjs.map +1 -1
  64. package/dist/harmony115.mjs +19 -84
  65. package/dist/harmony115.mjs.map +1 -1
  66. package/dist/harmony116.cjs +34 -29
  67. package/dist/harmony116.cjs.map +1 -1
  68. package/dist/harmony116.mjs +34 -29
  69. package/dist/harmony116.mjs.map +1 -1
  70. package/dist/harmony117.cjs +21 -99
  71. package/dist/harmony117.cjs.map +1 -1
  72. package/dist/harmony117.mjs +20 -81
  73. package/dist/harmony117.mjs.map +1 -1
  74. package/dist/harmony118.cjs +21 -21
  75. package/dist/harmony118.cjs.map +1 -1
  76. package/dist/harmony118.mjs +20 -20
  77. package/dist/harmony118.mjs.map +1 -1
  78. package/dist/harmony119.cjs +6 -6
  79. package/dist/harmony119.cjs.map +1 -1
  80. package/dist/harmony119.mjs +5 -5
  81. package/dist/harmony119.mjs.map +1 -1
  82. package/dist/harmony120.cjs +15 -132
  83. package/dist/harmony120.cjs.map +1 -1
  84. package/dist/harmony120.mjs +14 -131
  85. package/dist/harmony120.mjs.map +1 -1
  86. package/dist/harmony121.cjs +87 -12
  87. package/dist/harmony121.cjs.map +1 -1
  88. package/dist/harmony121.mjs +86 -11
  89. package/dist/harmony121.mjs.map +1 -1
  90. package/dist/harmony122.cjs +30 -5
  91. package/dist/harmony122.cjs.map +1 -1
  92. package/dist/harmony122.mjs +30 -5
  93. package/dist/harmony122.mjs.map +1 -1
  94. package/dist/harmony123.cjs +6 -41
  95. package/dist/harmony123.cjs.map +1 -1
  96. package/dist/harmony123.mjs +5 -40
  97. package/dist/harmony123.mjs.map +1 -1
  98. package/dist/harmony124.cjs +6 -61
  99. package/dist/harmony124.cjs.map +1 -1
  100. package/dist/harmony124.mjs +5 -60
  101. package/dist/harmony124.mjs.map +1 -1
  102. package/dist/harmony125.cjs +96 -7
  103. package/dist/harmony125.cjs.map +1 -1
  104. package/dist/harmony125.mjs +96 -7
  105. package/dist/harmony125.mjs.map +1 -1
  106. package/dist/harmony126.cjs +14 -7
  107. package/dist/harmony126.cjs.map +1 -1
  108. package/dist/harmony126.mjs +13 -6
  109. package/dist/harmony126.mjs.map +1 -1
  110. package/dist/harmony127.cjs +14 -10
  111. package/dist/harmony127.cjs.map +1 -1
  112. package/dist/harmony127.mjs +14 -10
  113. package/dist/harmony127.mjs.map +1 -1
  114. package/dist/harmony128.cjs +37 -6
  115. package/dist/harmony128.cjs.map +1 -1
  116. package/dist/harmony128.mjs +36 -5
  117. package/dist/harmony128.mjs.map +1 -1
  118. package/dist/harmony129.cjs +29 -6
  119. package/dist/harmony129.cjs.map +1 -1
  120. package/dist/harmony129.mjs +28 -5
  121. package/dist/harmony129.mjs.map +1 -1
  122. package/dist/harmony130.cjs +10 -63
  123. package/dist/harmony130.cjs.map +1 -1
  124. package/dist/harmony130.mjs +9 -62
  125. package/dist/harmony130.mjs.map +1 -1
  126. package/dist/harmony131.cjs +6 -88
  127. package/dist/harmony131.cjs.map +1 -1
  128. package/dist/harmony131.mjs +5 -87
  129. package/dist/harmony131.mjs.map +1 -1
  130. package/dist/harmony132.cjs +6 -15
  131. package/dist/harmony132.cjs.map +1 -1
  132. package/dist/harmony132.mjs +6 -15
  133. package/dist/harmony132.mjs.map +1 -1
  134. package/dist/harmony133.cjs +25 -97
  135. package/dist/harmony133.cjs.map +1 -1
  136. package/dist/harmony133.mjs +24 -96
  137. package/dist/harmony133.mjs.map +1 -1
  138. package/dist/harmony134.cjs +7 -14
  139. package/dist/harmony134.cjs.map +1 -1
  140. package/dist/harmony134.mjs +6 -13
  141. package/dist/harmony134.mjs.map +1 -1
  142. package/dist/harmony135.cjs +13 -15
  143. package/dist/harmony135.cjs.map +1 -1
  144. package/dist/harmony135.mjs +12 -14
  145. package/dist/harmony135.mjs.map +1 -1
  146. package/dist/harmony136.cjs +7 -37
  147. package/dist/harmony136.cjs.map +1 -1
  148. package/dist/harmony136.mjs +6 -36
  149. package/dist/harmony136.mjs.map +1 -1
  150. package/dist/harmony137.cjs +10 -28
  151. package/dist/harmony137.cjs.map +1 -1
  152. package/dist/harmony137.mjs +10 -28
  153. package/dist/harmony137.mjs.map +1 -1
  154. package/dist/harmony138.cjs +13 -7
  155. package/dist/harmony138.cjs.map +1 -1
  156. package/dist/harmony138.mjs +13 -7
  157. package/dist/harmony138.mjs.map +1 -1
  158. package/dist/harmony139.cjs +15 -57
  159. package/dist/harmony139.cjs.map +1 -1
  160. package/dist/harmony139.mjs +15 -57
  161. package/dist/harmony139.mjs.map +1 -1
  162. package/dist/harmony14.cjs +1 -1
  163. package/dist/harmony14.mjs +1 -1
  164. package/dist/harmony140.cjs +15 -59
  165. package/dist/harmony140.cjs.map +1 -1
  166. package/dist/harmony140.mjs +15 -59
  167. package/dist/harmony140.mjs.map +1 -1
  168. package/dist/harmony141.cjs +12 -19
  169. package/dist/harmony141.cjs.map +1 -1
  170. package/dist/harmony141.mjs +11 -18
  171. package/dist/harmony141.mjs.map +1 -1
  172. package/dist/harmony142.cjs +15 -12
  173. package/dist/harmony142.cjs.map +1 -1
  174. package/dist/harmony142.mjs +15 -12
  175. package/dist/harmony142.mjs.map +1 -1
  176. package/dist/harmony143.cjs +19 -13
  177. package/dist/harmony143.cjs.map +1 -1
  178. package/dist/harmony143.mjs +19 -13
  179. package/dist/harmony143.mjs.map +1 -1
  180. package/dist/harmony144.cjs +10 -14
  181. package/dist/harmony144.cjs.map +1 -1
  182. package/dist/harmony144.mjs +10 -14
  183. package/dist/harmony144.mjs.map +1 -1
  184. package/dist/harmony145.cjs +5 -10
  185. package/dist/harmony145.cjs.map +1 -1
  186. package/dist/harmony145.mjs +5 -10
  187. package/dist/harmony145.mjs.map +1 -1
  188. package/dist/harmony146.cjs +11 -15
  189. package/dist/harmony146.cjs.map +1 -1
  190. package/dist/harmony146.mjs +11 -15
  191. package/dist/harmony146.mjs.map +1 -1
  192. package/dist/harmony147.cjs +28 -17
  193. package/dist/harmony147.cjs.map +1 -1
  194. package/dist/harmony147.mjs +28 -17
  195. package/dist/harmony147.mjs.map +1 -1
  196. package/dist/harmony148.cjs +12 -10
  197. package/dist/harmony148.cjs.map +1 -1
  198. package/dist/harmony148.mjs +12 -10
  199. package/dist/harmony148.mjs.map +1 -1
  200. package/dist/harmony17.cjs +1 -1
  201. package/dist/harmony17.mjs +1 -1
  202. package/dist/harmony25.cjs +1 -1
  203. package/dist/harmony25.mjs +1 -1
  204. package/dist/harmony26.cjs +1 -1
  205. package/dist/harmony26.mjs +1 -1
  206. package/dist/harmony4.cjs +15 -24
  207. package/dist/harmony4.cjs.map +1 -1
  208. package/dist/harmony4.mjs +15 -24
  209. package/dist/harmony4.mjs.map +1 -1
  210. package/dist/harmony5.cjs +1 -1
  211. package/dist/harmony5.mjs +1 -1
  212. package/dist/harmony6.cjs +3 -3
  213. package/dist/harmony6.mjs +3 -3
  214. package/dist/harmony66.cjs +1 -0
  215. package/dist/harmony66.cjs.map +1 -1
  216. package/dist/harmony66.mjs +1 -0
  217. package/dist/harmony66.mjs.map +1 -1
  218. package/dist/harmony7.cjs +1 -1
  219. package/dist/harmony7.mjs +1 -1
  220. package/dist/harmony75.cjs +1 -1
  221. package/dist/harmony75.mjs +1 -1
  222. package/dist/harmony76.cjs +51 -6
  223. package/dist/harmony76.cjs.map +1 -1
  224. package/dist/harmony76.mjs +50 -5
  225. package/dist/harmony76.mjs.map +1 -1
  226. package/dist/harmony77.cjs +38 -8
  227. package/dist/harmony77.cjs.map +1 -1
  228. package/dist/harmony77.mjs +38 -8
  229. package/dist/harmony77.mjs.map +1 -1
  230. package/dist/harmony78.cjs +9 -18
  231. package/dist/harmony78.cjs.map +1 -1
  232. package/dist/harmony78.mjs +8 -17
  233. package/dist/harmony78.mjs.map +1 -1
  234. package/dist/harmony79.cjs +6 -21
  235. package/dist/harmony79.cjs.map +1 -1
  236. package/dist/harmony79.mjs +8 -23
  237. package/dist/harmony79.mjs.map +1 -1
  238. package/dist/harmony8.cjs +5 -5
  239. package/dist/harmony8.mjs +5 -5
  240. package/dist/harmony80.cjs +28 -4
  241. package/dist/harmony80.cjs.map +1 -1
  242. package/dist/harmony80.mjs +28 -4
  243. package/dist/harmony80.mjs.map +1 -1
  244. package/dist/harmony81.cjs +3 -32
  245. package/dist/harmony81.cjs.map +1 -1
  246. package/dist/harmony81.mjs +3 -32
  247. package/dist/harmony81.mjs.map +1 -1
  248. package/dist/harmony82.cjs +30 -29
  249. package/dist/harmony82.cjs.map +1 -1
  250. package/dist/harmony82.mjs +31 -30
  251. package/dist/harmony82.mjs.map +1 -1
  252. package/dist/harmony83.cjs +43 -19
  253. package/dist/harmony83.cjs.map +1 -1
  254. package/dist/harmony83.mjs +43 -19
  255. package/dist/harmony83.mjs.map +1 -1
  256. package/dist/harmony84.cjs +27 -29
  257. package/dist/harmony84.cjs.map +1 -1
  258. package/dist/harmony84.mjs +27 -29
  259. package/dist/harmony84.mjs.map +1 -1
  260. package/dist/harmony85.cjs +64 -57
  261. package/dist/harmony85.cjs.map +1 -1
  262. package/dist/harmony85.mjs +64 -57
  263. package/dist/harmony85.mjs.map +1 -1
  264. package/dist/harmony86.cjs +15 -9
  265. package/dist/harmony86.cjs.map +1 -1
  266. package/dist/harmony86.mjs +14 -8
  267. package/dist/harmony86.mjs.map +1 -1
  268. package/dist/harmony87.cjs +3 -8
  269. package/dist/harmony87.cjs.map +1 -1
  270. package/dist/harmony87.mjs +3 -8
  271. package/dist/harmony87.mjs.map +1 -1
  272. package/dist/harmony88.cjs +10 -27
  273. package/dist/harmony88.cjs.map +1 -1
  274. package/dist/harmony88.mjs +11 -28
  275. package/dist/harmony88.mjs.map +1 -1
  276. package/dist/harmony89.cjs +13 -4
  277. package/dist/harmony89.cjs.map +1 -1
  278. package/dist/harmony89.mjs +12 -3
  279. package/dist/harmony89.mjs.map +1 -1
  280. package/dist/harmony90.cjs +9 -31
  281. package/dist/harmony90.cjs.map +1 -1
  282. package/dist/harmony90.mjs +10 -32
  283. package/dist/harmony90.mjs.map +1 -1
  284. package/dist/harmony91.cjs +22 -44
  285. package/dist/harmony91.cjs.map +1 -1
  286. package/dist/harmony91.mjs +21 -43
  287. package/dist/harmony91.mjs.map +1 -1
  288. package/dist/harmony92.cjs +160 -23
  289. package/dist/harmony92.cjs.map +1 -1
  290. package/dist/harmony92.mjs +160 -23
  291. package/dist/harmony92.mjs.map +1 -1
  292. package/dist/harmony93.cjs +41 -63
  293. package/dist/harmony93.cjs.map +1 -1
  294. package/dist/harmony93.mjs +41 -63
  295. package/dist/harmony93.mjs.map +1 -1
  296. package/dist/harmony94.cjs +25 -13
  297. package/dist/harmony94.cjs.map +1 -1
  298. package/dist/harmony94.mjs +26 -14
  299. package/dist/harmony94.mjs.map +1 -1
  300. package/dist/harmony95.cjs +3 -3
  301. package/dist/harmony95.cjs.map +1 -1
  302. package/dist/harmony95.mjs +3 -3
  303. package/dist/harmony95.mjs.map +1 -1
  304. package/dist/harmony96.cjs +16 -164
  305. package/dist/harmony96.cjs.map +1 -1
  306. package/dist/harmony96.mjs +16 -164
  307. package/dist/harmony96.mjs.map +1 -1
  308. package/dist/harmony97.cjs +73 -42
  309. package/dist/harmony97.cjs.map +1 -1
  310. package/dist/harmony97.mjs +73 -42
  311. package/dist/harmony97.mjs.map +1 -1
  312. package/dist/harmony98.cjs +12 -11
  313. package/dist/harmony98.cjs.map +1 -1
  314. package/dist/harmony98.mjs +12 -11
  315. package/dist/harmony98.mjs.map +1 -1
  316. package/dist/harmony99.cjs +31 -22
  317. package/dist/harmony99.cjs.map +1 -1
  318. package/dist/harmony99.mjs +30 -21
  319. package/dist/harmony99.mjs.map +1 -1
  320. package/dist/types/src/components/Sidebar/Sidebar.d.ts +15 -49
  321. package/dist/types/src/components/Sidebar/SidebarContent/SidebarContent.d.ts +7 -0
  322. package/dist/types/src/components/Sidebar/SidebarContext.d.ts +3 -0
  323. package/dist/types/src/components/Sidebar/SidebarProvider.d.ts +3 -0
  324. package/dist/types/src/components/Sidebar/Widgets/Avatar/Avatar.d.ts +5 -0
  325. package/dist/types/src/components/Sidebar/Widgets/HelpMenu/HelpMenu.d.ts +13 -0
  326. package/dist/types/src/components/Sidebar/Widgets/HelpMenu/HelpMenu.test.d.ts +1 -0
  327. package/dist/types/src/components/Sidebar/Widgets/IconLink/IconLink.test.d.ts +1 -0
  328. package/dist/types/src/components/Sidebar/Widgets/Menu/Menu.d.ts +3 -2
  329. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/BillingMenuItem/BillingMenuItem.d.ts +13 -0
  330. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/CreateNewTeam/CreateNewTeam.d.ts +17 -0
  331. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/CreateNewTeam/CreateNewTeam.test.d.ts +1 -0
  332. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/CreateNewTeamPlaceholder/CreateNewTeamPlaceholder.d.ts +17 -0
  333. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/CreateNewTeamPlaceholder/CreateNewTeamPlaceholder.test.d.ts +1 -0
  334. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/DarkModeToggle/DarkModeToggle.d.ts +18 -0
  335. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileMenu.d.ts +11 -24
  336. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileMenu.stories.d.ts +3 -5
  337. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileSettingsMenuItem/ProfileSettingsMenuItem.d.ts +10 -35
  338. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileSettingsMenuItem/ProfileSettingsMenuItem.test.d.ts +1 -0
  339. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProviderMenuItem/ProviderMenuItem.d.ts +13 -0
  340. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProviderMenuItem/ProviderMenuItem.test.d.ts +1 -0
  341. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/TeamMenuItem/TeamMenuItem.d.ts +1 -3
  342. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/TeamMenuItem/TeamMenuItem.test.d.ts +1 -0
  343. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/TeamSettingsMenuItem/TeamSettingsMenuItem.d.ts +13 -0
  344. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/TeamSettingsMenuItem/TeamSettingsMenuItem.test.d.ts +1 -0
  345. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/TeamSwitch/TeamSwitch.d.ts +5 -7
  346. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/TeamSwitch/TeamSwitch.test.d.ts +1 -0
  347. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/UpgradeMenuItem/UpgradeMenuItem.d.ts +6 -9
  348. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/UpgradeMenuItem/UpgradeMenuItem.test.d.ts +1 -0
  349. package/dist/types/src/components/Sidebar/Widgets/Tasks/utils/content.d.ts +4 -0
  350. package/dist/types/src/components/Sidebar/hooks/useSidebar.d.ts +1 -0
  351. package/dist/types/src/components/Sidebar/hooks/useSidebarDataLoader.d.ts +5 -0
  352. package/dist/types/src/components/Sidebar/types.d.ts +72 -0
  353. package/dist/types/src/features/auth/core/types/jwtTokenPayload.d.ts +16 -10
  354. package/dist/types/src/features/auth/core/types/jwtTokenPayload.fixture.d.ts +15 -11
  355. package/dist/types/src/features/auth/frontend/hooks/useAuthenticatedSessionPayload.d.ts +7 -5
  356. package/dist/types/src/features/auth/frontend/hooks/useAuthenticatedUser.d.ts +1 -1
  357. package/dist/types/src/features/navigation/hooks/useNavigation.d.ts +1 -1
  358. package/dist/types/src/features/navigation/hooks/useNavigationQueries.d.ts +3 -3
  359. package/dist/types/src/features/publicApi/hooks/useCreateProjectMutation.d.ts +2 -2
  360. package/dist/types/src/features/publicApi/hooks/useGetProjectPermissionMetaQuery.d.ts +2 -2
  361. package/dist/types/src/features/publicApi/hooks/useGetTeamUsersQuery.d.ts +1 -1
  362. package/dist/types/src/features/publicApi/hooks/useListPermissionTemplates.d.ts +1 -1
  363. package/dist/types/src/features/publicApi/hooks/useListProjectsQuery.d.ts +2 -2
  364. package/dist/types/src/features/publicApi/hooks/useListTeamUsersQuery.d.ts +1 -1
  365. package/dist/types/src/features/publicApi/hooks/useRetrieveProjectQuery.d.ts +1 -1
  366. package/dist/types/src/features/publicApi/hooks/useUpdateProjectMutation.d.ts +1 -1
  367. package/dist/types/src/features/publicApi/permissionTemplates.d.ts +4 -4
  368. package/dist/types/src/features/publicApi/projects.d.ts +28 -28
  369. package/dist/types/src/features/publicApi/teamUsers.d.ts +8 -8
  370. package/dist/types/src/features/publicApi/types/permissionTemplateTypes.d.ts +6 -6
  371. package/dist/types/src/features/publicApi/types/permissionTypes.d.ts +2 -2
  372. package/dist/types/src/features/publicApi/types/projectTypes.d.ts +27 -27
  373. package/dist/types/src/features/publicApi/types/teamUserTypes.d.ts +10 -10
  374. package/dist/types/src/utils/user/permissions.d.ts +9 -0
  375. package/dist/types/src/utils/user/permissions.test.d.ts +1 -0
  376. package/dist/types/tests/mocks/sidebar/sidebar.d.ts +19 -0
  377. package/dist/types/tests/utils/sidebar.d.ts +4 -0
  378. package/package.json +1 -1
  379. package/dist/harmony149.cjs +0 -9
  380. package/dist/harmony149.cjs.map +0 -1
  381. package/dist/harmony149.mjs +0 -9
  382. package/dist/harmony149.mjs.map +0 -1
  383. package/dist/harmony150.cjs +0 -15
  384. package/dist/harmony150.cjs.map +0 -1
  385. package/dist/harmony150.mjs +0 -15
  386. package/dist/harmony150.mjs.map +0 -1
  387. package/dist/harmony151.cjs +0 -35
  388. package/dist/harmony151.cjs.map +0 -1
  389. package/dist/harmony151.mjs +0 -35
  390. package/dist/harmony151.mjs.map +0 -1
  391. package/dist/harmony152.cjs +0 -17
  392. package/dist/harmony152.cjs.map +0 -1
  393. package/dist/harmony152.mjs +0 -17
  394. package/dist/harmony152.mjs.map +0 -1
  395. package/dist/harmony153.cjs +0 -49
  396. package/dist/harmony153.cjs.map +0 -1
  397. package/dist/harmony153.mjs +0 -49
  398. package/dist/harmony153.mjs.map +0 -1
  399. package/dist/harmony154.cjs +0 -15
  400. package/dist/harmony154.cjs.map +0 -1
  401. package/dist/harmony154.mjs +0 -15
  402. package/dist/harmony154.mjs.map +0 -1
  403. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuContent.d.ts +0 -6
  404. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuContext.d.ts +0 -3
  405. package/dist/types/src/components/Sidebar/Widgets/ProfileMenu/ProfileMenuProvider.d.ts +0 -7
  406. package/dist/types/src/components/Sidebar/utils/index.d.ts +0 -4
  407. /package/dist/types/src/components/Sidebar/Widgets/{ProfileMenu/ProfileMenu.test.d.ts → Avatar/Avatar.test.d.ts} +0 -0
  408. /package/dist/types/src/components/Sidebar/{UpgradeIcon → Widgets/ProfileMenu/UpgradeIcon}/UpgradeIcon.d.ts +0 -0
@@ -1,69 +1,47 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const headerBuilderFactories = require("./harmony21.cjs");
4
- const useRetrieveContributorQuery = require("./harmony55.cjs");
5
- const useRetrieveProjectQuery = require("./harmony56.cjs");
6
- const NavigationClientProvider = require("./harmony94.cjs");
7
- function useNavigationProjectQuery(projectId) {
3
+ const React = require("react");
4
+ const NavigationClientProvider = require("./harmony86.cjs");
5
+ const navigationSchema = require("./harmony122.cjs");
6
+ const useNextgenNavigation = (activeKey, enabled, project, contributor) => {
8
7
  const navigationClient = NavigationClientProvider.useNavigationClient();
9
- const expertPublicApiUrl = navigationClient.getExpertPublicApiUrl();
10
- return useRetrieveProjectQuery.useRetrieveProjectQuery(
11
- navigationClient.getPublicApiClient(),
12
- headerBuilderFactories.createPublicApiHeaderBuilder(expertPublicApiUrl),
13
- {
14
- queryKey: useRetrieveProjectQuery.retrieveProjectQueryKey.projectIdKey(projectId),
15
- enabled: !!projectId,
16
- staleTime: 5 * 60 * 1e3
17
- // 5 minutes
18
- }
19
- );
20
- }
21
- function useNavigationContributorQuery(projectId) {
22
- const navigationClient = NavigationClientProvider.useNavigationClient();
23
- const expertPublicApiUrl = navigationClient.getExpertPublicApiUrl();
24
- return useRetrieveContributorQuery.useRetrieveContributorQuery(
25
- navigationClient.getPublicApiClient(),
26
- headerBuilderFactories.createPublicApiHeaderBuilder(expertPublicApiUrl),
27
- {
28
- queryKey: useRetrieveContributorQuery.retrieveContributorKeys.projectUserKey({
29
- project: { id: projectId },
30
- contributor: { authenticatedUser: true }
31
- }),
32
- enabled: !!projectId,
33
- staleTime: 5 * 60 * 1e3
34
- // 5 minutes
35
- }
36
- );
37
- }
38
- function useNavigationData(projectId) {
39
- var _a;
40
- const projectQuery = useNavigationProjectQuery(projectId);
41
- const contributorQuery = useNavigationContributorQuery(projectId);
42
- return {
43
- // Individual queries
44
- projectQuery,
45
- contributorQuery,
46
- // Combined data
47
- data: {
48
- project: projectQuery.data,
49
- contributor: (_a = contributorQuery.data) == null ? void 0 : _a.contributor
8
+ const nextgenUrl = navigationClient.getNextgenUrl();
9
+ const navigate = React.useCallback(
10
+ (path) => {
11
+ window.location.href = `${nextgenUrl}${path}`;
50
12
  },
51
- // Combined loading state
52
- isLoading: projectQuery.isLoading || contributorQuery.isLoading,
53
- // Combined error state
54
- error: projectQuery.error || contributorQuery.error,
55
- // Check if any query is still loading
56
- isAnyLoading: projectQuery.isLoading || contributorQuery.isLoading,
57
- // Check if all queries have data
58
- hasAllData: !!(projectQuery.data && contributorQuery.data),
59
- // Refetch all queries
60
- refetchAll: () => {
61
- projectQuery.refetch();
62
- contributorQuery.refetch();
13
+ [nextgenUrl]
14
+ );
15
+ return React.useMemo(() => {
16
+ if (!enabled) {
17
+ return [];
63
18
  }
64
- };
65
- }
66
- exports.useNavigationContributorQuery = useNavigationContributorQuery;
67
- exports.useNavigationData = useNavigationData;
68
- exports.useNavigationProjectQuery = useNavigationProjectQuery;
19
+ const projectId = (project == null ? void 0 : project.project_id) || "";
20
+ const context = {
21
+ flags: {},
22
+ // TODO: getFeatureFlags(features),
23
+ pathname: window.location.pathname,
24
+ permissions: []
25
+ };
26
+ return navigationSchema.navigationItems.filter((item) => item.shouldShow ? item.shouldShow(context) : true).map((item) => {
27
+ const disabled = typeof item.disabled === "function" ? item.disabled(context) : !!item.disabled;
28
+ const badge = typeof item.badge === "function" ? item.badge(context) : item.badge;
29
+ const isActive = (input) => item.isActive ? item.isActive(input) : item.key === activeKey || input === item.key;
30
+ return {
31
+ key: item.key,
32
+ label: item.labelKey,
33
+ // You can apply translations here if needed
34
+ icon: item.icon,
35
+ visible: true,
36
+ badge,
37
+ disabled,
38
+ dropdown: item.dropdown,
39
+ isActive,
40
+ link: `${nextgenUrl}${item.path({ projectId })}`,
41
+ onClick: () => navigate(item.path({ projectId }))
42
+ };
43
+ });
44
+ }, [project, activeKey, enabled, navigate, contributor, nextgenUrl]);
45
+ };
46
+ exports.useNextgenNavigation = useNextgenNavigation;
69
47
  //# sourceMappingURL=harmony93.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony93.cjs","sources":["../src/features/navigation/hooks/useNavigationQueries.ts"],"sourcesContent":["import { createPublicApiHeaderBuilder } from '@features/auth/factories/headerBuilderFactories'\nimport {\n\tretrieveContributorKeys,\n\tuseRetrieveContributorQuery,\n} from '@features/publicApi/hooks/useRetrieveContributorQuery'\nimport {\n\tretrieveProjectQueryKey,\n\tuseRetrieveProjectQuery,\n} from '@features/publicApi/hooks/useRetrieveProjectQuery'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\n\n/**\n * Hook to fetch project data for navigation\n */\nexport function useNavigationProjectQuery(projectId: string) {\n\tconst navigationClient = useNavigationClient()\n\tconst expertPublicApiUrl = navigationClient.getExpertPublicApiUrl()\n\n\treturn useRetrieveProjectQuery(\n\t\tnavigationClient.getPublicApiClient(),\n\t\tcreatePublicApiHeaderBuilder(expertPublicApiUrl),\n\t\t{\n\t\t\tqueryKey: retrieveProjectQueryKey.projectIdKey(projectId),\n\t\t\tenabled: !!projectId,\n\t\t\tstaleTime: 5 * 60 * 1000, // 5 minutes\n\t\t},\n\t)\n}\n\n/**\n * Hook to fetch contributor data for navigation\n */\nexport function useNavigationContributorQuery(projectId: string) {\n\tconst navigationClient = useNavigationClient()\n\tconst expertPublicApiUrl = navigationClient.getExpertPublicApiUrl()\n\n\treturn useRetrieveContributorQuery(\n\t\tnavigationClient.getPublicApiClient(),\n\t\tcreatePublicApiHeaderBuilder(expertPublicApiUrl),\n\t\t{\n\t\t\tqueryKey: retrieveContributorKeys.projectUserKey({\n\t\t\t\tproject: { id: projectId },\n\t\t\t\tcontributor: { authenticatedUser: true },\n\t\t\t}),\n\t\t\tenabled: !!projectId,\n\t\t\tstaleTime: 5 * 60 * 1000, // 5 minutes\n\t\t},\n\t)\n}\n\n/**\n * Composite hook that fetches all navigation data\n */\nexport function useNavigationData(projectId: string) {\n\tconst projectQuery = useNavigationProjectQuery(projectId)\n\tconst contributorQuery = useNavigationContributorQuery(projectId)\n\n\treturn {\n\t\t// Individual queries\n\t\tprojectQuery,\n\t\tcontributorQuery,\n\n\t\t// Combined data\n\t\tdata: {\n\t\t\tproject: projectQuery.data,\n\t\t\tcontributor: contributorQuery.data?.contributor,\n\t\t},\n\n\t\t// Combined loading state\n\t\tisLoading: projectQuery.isLoading || contributorQuery.isLoading,\n\n\t\t// Combined error state\n\t\terror: projectQuery.error || contributorQuery.error,\n\n\t\t// Check if any query is still loading\n\t\tisAnyLoading: projectQuery.isLoading || contributorQuery.isLoading,\n\n\t\t// Check if all queries have data\n\t\thasAllData: !!(projectQuery.data && contributorQuery.data),\n\n\t\t// Refetch all queries\n\t\trefetchAll: () => {\n\t\t\tprojectQuery.refetch()\n\t\t\tcontributorQuery.refetch()\n\t\t},\n\t}\n}\n"],"names":["useNavigationClient","useRetrieveProjectQuery","createPublicApiHeaderBuilder","retrieveProjectQueryKey","useRetrieveContributorQuery","retrieveContributorKeys"],"mappings":";;;;;;AAcO,SAAS,0BAA0B,WAAmB;AAC5D,QAAM,mBAAmBA,yBAAAA,oBAAoB;AACvC,QAAA,qBAAqB,iBAAiB,sBAAsB;AAE3D,SAAAC,wBAAA;AAAA,IACN,iBAAiB,mBAAmB;AAAA,IACpCC,uBAAAA,6BAA6B,kBAAkB;AAAA,IAC/C;AAAA,MACC,UAAUC,wBAAAA,wBAAwB,aAAa,SAAS;AAAA,MACxD,SAAS,CAAC,CAAC;AAAA,MACX,WAAW,IAAI,KAAK;AAAA;AAAA,IAAA;AAAA,EAEtB;AACD;AAKO,SAAS,8BAA8B,WAAmB;AAChE,QAAM,mBAAmBH,yBAAAA,oBAAoB;AACvC,QAAA,qBAAqB,iBAAiB,sBAAsB;AAE3D,SAAAI,4BAAA;AAAA,IACN,iBAAiB,mBAAmB;AAAA,IACpCF,uBAAAA,6BAA6B,kBAAkB;AAAA,IAC/C;AAAA,MACC,UAAUG,oDAAwB,eAAe;AAAA,QAChD,SAAS,EAAE,IAAI,UAAU;AAAA,QACzB,aAAa,EAAE,mBAAmB,KAAK;AAAA,MAAA,CACvC;AAAA,MACD,SAAS,CAAC,CAAC;AAAA,MACX,WAAW,IAAI,KAAK;AAAA;AAAA,IAAA;AAAA,EAEtB;AACD;AAKO,SAAS,kBAAkB,WAAmB;;AAC9C,QAAA,eAAe,0BAA0B,SAAS;AAClD,QAAA,mBAAmB,8BAA8B,SAAS;AAEzD,SAAA;AAAA;AAAA,IAEN;AAAA,IACA;AAAA;AAAA,IAGA,MAAM;AAAA,MACL,SAAS,aAAa;AAAA,MACtB,cAAa,sBAAiB,SAAjB,mBAAuB;AAAA,IACrC;AAAA;AAAA,IAGA,WAAW,aAAa,aAAa,iBAAiB;AAAA;AAAA,IAGtD,OAAO,aAAa,SAAS,iBAAiB;AAAA;AAAA,IAG9C,cAAc,aAAa,aAAa,iBAAiB;AAAA;AAAA,IAGzD,YAAY,CAAC,EAAE,aAAa,QAAQ,iBAAiB;AAAA;AAAA,IAGrD,YAAY,MAAM;AACjB,mBAAa,QAAQ;AACrB,uBAAiB,QAAQ;AAAA,IAAA;AAAA,EAE3B;AACD;;;;"}
1
+ {"version":3,"file":"harmony93.cjs","sources":["../src/features/navigation/hooks/useNextgenNavigation.ts"],"sourcesContent":["import type { Contributor, Project } from '@features/node'\nimport { useCallback, useMemo } from 'react'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\n// TODO: react-router-dom as peer dependencies works only inside next-gen apps. It shouldn't be like that.\n// Because of that we can't use THE WHOLE package in legacy apps, therefore it should be implemented in legacy apps as well(almost impossible),\n// so this dependency should be installed as direct dependency. or we should think about other options\n// import { useNavigate } from \"react-router-dom\";\nimport { navigationItems } from '../schemas/navigationSchema'\n\n// TODO: Unify navigation items for next-gen and legacy apps\n/**\n * Hook to generate navigation items for new applications\n */\nexport const useNextgenNavigation = (\n\tactiveKey: string,\n\tenabled: boolean,\n\tproject?: Project,\n\tcontributor?: Contributor,\n) => {\n\tconst navigationClient = useNavigationClient()\n\tconst nextgenUrl = navigationClient.getNextgenUrl()\n\n\tconst navigate = useCallback(\n\t\t(path: string) => {\n\t\t\t// TODO: Define navigate logic here\n\t\t\twindow.location.href = `${nextgenUrl}${path}`\n\t\t},\n\t\t[nextgenUrl],\n\t)\n\n\treturn useMemo(() => {\n\t\tif (!enabled) {\n\t\t\treturn []\n\t\t}\n\n\t\tconst projectId = project?.project_id || ''\n\n\t\t// Context for filtering and transforming navigation items\n\t\tconst context = {\n\t\t\tflags: {}, // TODO: getFeatureFlags(features),\n\t\t\tpathname: window.location.pathname,\n\t\t\tpermissions: contributor?.admin_rights || [],\n\t\t}\n\n\t\t// Filter and map items\n\t\treturn (\n\t\t\tnavigationItems\n\t\t\t\t// Filter based on conditions\n\t\t\t\t.filter((item) => (item.shouldShow ? item.shouldShow(context) : true))\n\t\t\t\t// Map to NavigationTabsItem shape\n\t\t\t\t.map((item) => {\n\t\t\t\t\tconst disabled =\n\t\t\t\t\t\ttypeof item.disabled === 'function' ? item.disabled(context) : !!item.disabled\n\n\t\t\t\t\tconst badge = typeof item.badge === 'function' ? item.badge(context) : item.badge\n\n\t\t\t\t\t// Create isActive function\n\t\t\t\t\tconst isActive = (input: string) =>\n\t\t\t\t\t\titem.isActive ? item.isActive(input) : item.key === activeKey || input === item.key\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tkey: item.key,\n\t\t\t\t\t\tlabel: item.labelKey, // You can apply translations here if needed\n\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\tvisible: true,\n\t\t\t\t\t\tbadge,\n\t\t\t\t\t\tdisabled,\n\t\t\t\t\t\tdropdown: item.dropdown,\n\t\t\t\t\t\tisActive,\n\t\t\t\t\t\tlink: `${nextgenUrl}${item.path({ projectId })}`,\n\t\t\t\t\t\tonClick: () => navigate(item.path({ projectId })),\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t)\n\t}, [project, activeKey, enabled, navigate, contributor, nextgenUrl])\n}\n\n// TODO: Helper to convert features to flags format\n// const getFeatureFlags = (features) => {\n// \tif (!features) return {}\n//\n// \t// Convert features to the format expected by navigation schema\n// \treturn Object.keys(features).reduce((flags, key) => {\n// \t\tflags[key] = features[key] ? 'on' : 'off'\n// \t\treturn flags\n// \t}, {})\n// }\n"],"names":["useNavigationClient","useCallback","useMemo","navigationItems"],"mappings":";;;;;AAaO,MAAM,uBAAuB,CACnC,WACA,SACA,SACA,gBACI;AACJ,QAAM,mBAAmBA,yBAAAA,oBAAoB;AACvC,QAAA,aAAa,iBAAiB,cAAc;AAElD,QAAM,WAAWC,MAAA;AAAA,IAChB,CAAC,SAAiB;AAEjB,aAAO,SAAS,OAAO,GAAG,UAAU,GAAG,IAAI;AAAA,IAC5C;AAAA,IACA,CAAC,UAAU;AAAA,EACZ;AAEA,SAAOC,cAAQ,MAAM;AACpB,QAAI,CAAC,SAAS;AACb,aAAO,CAAC;AAAA,IAAA;AAGH,UAAA,aAAY,mCAAS,eAAc;AAGzC,UAAM,UAAU;AAAA,MACf,OAAO,CAAC;AAAA;AAAA,MACR,UAAU,OAAO,SAAS;AAAA,MAC1B,aAA0C,CAAA;AAAA,IAC3C;AAGA,WACCC,iBAEE,gBAAA,OAAO,CAAC,SAAU,KAAK,aAAa,KAAK,WAAW,OAAO,IAAI,IAAK,EAEpE,IAAI,CAAC,SAAS;AACR,YAAA,WACL,OAAO,KAAK,aAAa,aAAa,KAAK,SAAS,OAAO,IAAI,CAAC,CAAC,KAAK;AAEjE,YAAA,QAAQ,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,OAAO,IAAI,KAAK;AAG5E,YAAM,WAAW,CAAC,UACjB,KAAK,WAAW,KAAK,SAAS,KAAK,IAAI,KAAK,QAAQ,aAAa,UAAU,KAAK;AAE1E,aAAA;AAAA,QACN,KAAK,KAAK;AAAA,QACV,OAAO,KAAK;AAAA;AAAA,QACZ,MAAM,KAAK;AAAA,QACX,SAAS;AAAA,QACT;AAAA,QACA;AAAA,QACA,UAAU,KAAK;AAAA,QACf;AAAA,QACA,MAAM,GAAG,UAAU,GAAG,KAAK,KAAK,EAAE,UAAW,CAAA,CAAC;AAAA,QAC9C,SAAS,MAAM,SAAS,KAAK,KAAK,EAAE,UAAA,CAAW,CAAC;AAAA,MACjD;AAAA,IAAA,CACA;AAAA,EAAA,GAED,CAAC,SAAS,WAAW,SAAS,UAAU,aAAa,UAAU,CAAC;AACpE;;"}
@@ -1,69 +1,47 @@
1
- import { createPublicApiHeaderBuilder } from "./harmony21.mjs";
2
- import { useRetrieveContributorQuery, retrieveContributorKeys } from "./harmony55.mjs";
3
- import { useRetrieveProjectQuery, retrieveProjectQueryKey } from "./harmony56.mjs";
4
- import { useNavigationClient } from "./harmony94.mjs";
5
- function useNavigationProjectQuery(projectId) {
1
+ import { useCallback, useMemo } from "react";
2
+ import { useNavigationClient } from "./harmony86.mjs";
3
+ import { navigationItems } from "./harmony122.mjs";
4
+ const useNextgenNavigation = (activeKey, enabled, project, contributor) => {
6
5
  const navigationClient = useNavigationClient();
7
- const expertPublicApiUrl = navigationClient.getExpertPublicApiUrl();
8
- return useRetrieveProjectQuery(
9
- navigationClient.getPublicApiClient(),
10
- createPublicApiHeaderBuilder(expertPublicApiUrl),
11
- {
12
- queryKey: retrieveProjectQueryKey.projectIdKey(projectId),
13
- enabled: !!projectId,
14
- staleTime: 5 * 60 * 1e3
15
- // 5 minutes
16
- }
17
- );
18
- }
19
- function useNavigationContributorQuery(projectId) {
20
- const navigationClient = useNavigationClient();
21
- const expertPublicApiUrl = navigationClient.getExpertPublicApiUrl();
22
- return useRetrieveContributorQuery(
23
- navigationClient.getPublicApiClient(),
24
- createPublicApiHeaderBuilder(expertPublicApiUrl),
25
- {
26
- queryKey: retrieveContributorKeys.projectUserKey({
27
- project: { id: projectId },
28
- contributor: { authenticatedUser: true }
29
- }),
30
- enabled: !!projectId,
31
- staleTime: 5 * 60 * 1e3
32
- // 5 minutes
33
- }
34
- );
35
- }
36
- function useNavigationData(projectId) {
37
- var _a;
38
- const projectQuery = useNavigationProjectQuery(projectId);
39
- const contributorQuery = useNavigationContributorQuery(projectId);
40
- return {
41
- // Individual queries
42
- projectQuery,
43
- contributorQuery,
44
- // Combined data
45
- data: {
46
- project: projectQuery.data,
47
- contributor: (_a = contributorQuery.data) == null ? void 0 : _a.contributor
6
+ const nextgenUrl = navigationClient.getNextgenUrl();
7
+ const navigate = useCallback(
8
+ (path) => {
9
+ window.location.href = `${nextgenUrl}${path}`;
48
10
  },
49
- // Combined loading state
50
- isLoading: projectQuery.isLoading || contributorQuery.isLoading,
51
- // Combined error state
52
- error: projectQuery.error || contributorQuery.error,
53
- // Check if any query is still loading
54
- isAnyLoading: projectQuery.isLoading || contributorQuery.isLoading,
55
- // Check if all queries have data
56
- hasAllData: !!(projectQuery.data && contributorQuery.data),
57
- // Refetch all queries
58
- refetchAll: () => {
59
- projectQuery.refetch();
60
- contributorQuery.refetch();
11
+ [nextgenUrl]
12
+ );
13
+ return useMemo(() => {
14
+ if (!enabled) {
15
+ return [];
61
16
  }
62
- };
63
- }
17
+ const projectId = (project == null ? void 0 : project.project_id) || "";
18
+ const context = {
19
+ flags: {},
20
+ // TODO: getFeatureFlags(features),
21
+ pathname: window.location.pathname,
22
+ permissions: []
23
+ };
24
+ return navigationItems.filter((item) => item.shouldShow ? item.shouldShow(context) : true).map((item) => {
25
+ const disabled = typeof item.disabled === "function" ? item.disabled(context) : !!item.disabled;
26
+ const badge = typeof item.badge === "function" ? item.badge(context) : item.badge;
27
+ const isActive = (input) => item.isActive ? item.isActive(input) : item.key === activeKey || input === item.key;
28
+ return {
29
+ key: item.key,
30
+ label: item.labelKey,
31
+ // You can apply translations here if needed
32
+ icon: item.icon,
33
+ visible: true,
34
+ badge,
35
+ disabled,
36
+ dropdown: item.dropdown,
37
+ isActive,
38
+ link: `${nextgenUrl}${item.path({ projectId })}`,
39
+ onClick: () => navigate(item.path({ projectId }))
40
+ };
41
+ });
42
+ }, [project, activeKey, enabled, navigate, contributor, nextgenUrl]);
43
+ };
64
44
  export {
65
- useNavigationContributorQuery,
66
- useNavigationData,
67
- useNavigationProjectQuery
45
+ useNextgenNavigation
68
46
  };
69
47
  //# sourceMappingURL=harmony93.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony93.mjs","sources":["../src/features/navigation/hooks/useNavigationQueries.ts"],"sourcesContent":["import { createPublicApiHeaderBuilder } from '@features/auth/factories/headerBuilderFactories'\nimport {\n\tretrieveContributorKeys,\n\tuseRetrieveContributorQuery,\n} from '@features/publicApi/hooks/useRetrieveContributorQuery'\nimport {\n\tretrieveProjectQueryKey,\n\tuseRetrieveProjectQuery,\n} from '@features/publicApi/hooks/useRetrieveProjectQuery'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\n\n/**\n * Hook to fetch project data for navigation\n */\nexport function useNavigationProjectQuery(projectId: string) {\n\tconst navigationClient = useNavigationClient()\n\tconst expertPublicApiUrl = navigationClient.getExpertPublicApiUrl()\n\n\treturn useRetrieveProjectQuery(\n\t\tnavigationClient.getPublicApiClient(),\n\t\tcreatePublicApiHeaderBuilder(expertPublicApiUrl),\n\t\t{\n\t\t\tqueryKey: retrieveProjectQueryKey.projectIdKey(projectId),\n\t\t\tenabled: !!projectId,\n\t\t\tstaleTime: 5 * 60 * 1000, // 5 minutes\n\t\t},\n\t)\n}\n\n/**\n * Hook to fetch contributor data for navigation\n */\nexport function useNavigationContributorQuery(projectId: string) {\n\tconst navigationClient = useNavigationClient()\n\tconst expertPublicApiUrl = navigationClient.getExpertPublicApiUrl()\n\n\treturn useRetrieveContributorQuery(\n\t\tnavigationClient.getPublicApiClient(),\n\t\tcreatePublicApiHeaderBuilder(expertPublicApiUrl),\n\t\t{\n\t\t\tqueryKey: retrieveContributorKeys.projectUserKey({\n\t\t\t\tproject: { id: projectId },\n\t\t\t\tcontributor: { authenticatedUser: true },\n\t\t\t}),\n\t\t\tenabled: !!projectId,\n\t\t\tstaleTime: 5 * 60 * 1000, // 5 minutes\n\t\t},\n\t)\n}\n\n/**\n * Composite hook that fetches all navigation data\n */\nexport function useNavigationData(projectId: string) {\n\tconst projectQuery = useNavigationProjectQuery(projectId)\n\tconst contributorQuery = useNavigationContributorQuery(projectId)\n\n\treturn {\n\t\t// Individual queries\n\t\tprojectQuery,\n\t\tcontributorQuery,\n\n\t\t// Combined data\n\t\tdata: {\n\t\t\tproject: projectQuery.data,\n\t\t\tcontributor: contributorQuery.data?.contributor,\n\t\t},\n\n\t\t// Combined loading state\n\t\tisLoading: projectQuery.isLoading || contributorQuery.isLoading,\n\n\t\t// Combined error state\n\t\terror: projectQuery.error || contributorQuery.error,\n\n\t\t// Check if any query is still loading\n\t\tisAnyLoading: projectQuery.isLoading || contributorQuery.isLoading,\n\n\t\t// Check if all queries have data\n\t\thasAllData: !!(projectQuery.data && contributorQuery.data),\n\n\t\t// Refetch all queries\n\t\trefetchAll: () => {\n\t\t\tprojectQuery.refetch()\n\t\t\tcontributorQuery.refetch()\n\t\t},\n\t}\n}\n"],"names":[],"mappings":";;;;AAcO,SAAS,0BAA0B,WAAmB;AAC5D,QAAM,mBAAmB,oBAAoB;AACvC,QAAA,qBAAqB,iBAAiB,sBAAsB;AAE3D,SAAA;AAAA,IACN,iBAAiB,mBAAmB;AAAA,IACpC,6BAA6B,kBAAkB;AAAA,IAC/C;AAAA,MACC,UAAU,wBAAwB,aAAa,SAAS;AAAA,MACxD,SAAS,CAAC,CAAC;AAAA,MACX,WAAW,IAAI,KAAK;AAAA;AAAA,IAAA;AAAA,EAEtB;AACD;AAKO,SAAS,8BAA8B,WAAmB;AAChE,QAAM,mBAAmB,oBAAoB;AACvC,QAAA,qBAAqB,iBAAiB,sBAAsB;AAE3D,SAAA;AAAA,IACN,iBAAiB,mBAAmB;AAAA,IACpC,6BAA6B,kBAAkB;AAAA,IAC/C;AAAA,MACC,UAAU,wBAAwB,eAAe;AAAA,QAChD,SAAS,EAAE,IAAI,UAAU;AAAA,QACzB,aAAa,EAAE,mBAAmB,KAAK;AAAA,MAAA,CACvC;AAAA,MACD,SAAS,CAAC,CAAC;AAAA,MACX,WAAW,IAAI,KAAK;AAAA;AAAA,IAAA;AAAA,EAEtB;AACD;AAKO,SAAS,kBAAkB,WAAmB;;AAC9C,QAAA,eAAe,0BAA0B,SAAS;AAClD,QAAA,mBAAmB,8BAA8B,SAAS;AAEzD,SAAA;AAAA;AAAA,IAEN;AAAA,IACA;AAAA;AAAA,IAGA,MAAM;AAAA,MACL,SAAS,aAAa;AAAA,MACtB,cAAa,sBAAiB,SAAjB,mBAAuB;AAAA,IACrC;AAAA;AAAA,IAGA,WAAW,aAAa,aAAa,iBAAiB;AAAA;AAAA,IAGtD,OAAO,aAAa,SAAS,iBAAiB;AAAA;AAAA,IAG9C,cAAc,aAAa,aAAa,iBAAiB;AAAA;AAAA,IAGzD,YAAY,CAAC,EAAE,aAAa,QAAQ,iBAAiB;AAAA;AAAA,IAGrD,YAAY,MAAM;AACjB,mBAAa,QAAQ;AACrB,uBAAiB,QAAQ;AAAA,IAAA;AAAA,EAE3B;AACD;"}
1
+ {"version":3,"file":"harmony93.mjs","sources":["../src/features/navigation/hooks/useNextgenNavigation.ts"],"sourcesContent":["import type { Contributor, Project } from '@features/node'\nimport { useCallback, useMemo } from 'react'\nimport { useNavigationClient } from '../providers/NavigationClientProvider'\n// TODO: react-router-dom as peer dependencies works only inside next-gen apps. It shouldn't be like that.\n// Because of that we can't use THE WHOLE package in legacy apps, therefore it should be implemented in legacy apps as well(almost impossible),\n// so this dependency should be installed as direct dependency. or we should think about other options\n// import { useNavigate } from \"react-router-dom\";\nimport { navigationItems } from '../schemas/navigationSchema'\n\n// TODO: Unify navigation items for next-gen and legacy apps\n/**\n * Hook to generate navigation items for new applications\n */\nexport const useNextgenNavigation = (\n\tactiveKey: string,\n\tenabled: boolean,\n\tproject?: Project,\n\tcontributor?: Contributor,\n) => {\n\tconst navigationClient = useNavigationClient()\n\tconst nextgenUrl = navigationClient.getNextgenUrl()\n\n\tconst navigate = useCallback(\n\t\t(path: string) => {\n\t\t\t// TODO: Define navigate logic here\n\t\t\twindow.location.href = `${nextgenUrl}${path}`\n\t\t},\n\t\t[nextgenUrl],\n\t)\n\n\treturn useMemo(() => {\n\t\tif (!enabled) {\n\t\t\treturn []\n\t\t}\n\n\t\tconst projectId = project?.project_id || ''\n\n\t\t// Context for filtering and transforming navigation items\n\t\tconst context = {\n\t\t\tflags: {}, // TODO: getFeatureFlags(features),\n\t\t\tpathname: window.location.pathname,\n\t\t\tpermissions: contributor?.admin_rights || [],\n\t\t}\n\n\t\t// Filter and map items\n\t\treturn (\n\t\t\tnavigationItems\n\t\t\t\t// Filter based on conditions\n\t\t\t\t.filter((item) => (item.shouldShow ? item.shouldShow(context) : true))\n\t\t\t\t// Map to NavigationTabsItem shape\n\t\t\t\t.map((item) => {\n\t\t\t\t\tconst disabled =\n\t\t\t\t\t\ttypeof item.disabled === 'function' ? item.disabled(context) : !!item.disabled\n\n\t\t\t\t\tconst badge = typeof item.badge === 'function' ? item.badge(context) : item.badge\n\n\t\t\t\t\t// Create isActive function\n\t\t\t\t\tconst isActive = (input: string) =>\n\t\t\t\t\t\titem.isActive ? item.isActive(input) : item.key === activeKey || input === item.key\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tkey: item.key,\n\t\t\t\t\t\tlabel: item.labelKey, // You can apply translations here if needed\n\t\t\t\t\t\ticon: item.icon,\n\t\t\t\t\t\tvisible: true,\n\t\t\t\t\t\tbadge,\n\t\t\t\t\t\tdisabled,\n\t\t\t\t\t\tdropdown: item.dropdown,\n\t\t\t\t\t\tisActive,\n\t\t\t\t\t\tlink: `${nextgenUrl}${item.path({ projectId })}`,\n\t\t\t\t\t\tonClick: () => navigate(item.path({ projectId })),\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t)\n\t}, [project, activeKey, enabled, navigate, contributor, nextgenUrl])\n}\n\n// TODO: Helper to convert features to flags format\n// const getFeatureFlags = (features) => {\n// \tif (!features) return {}\n//\n// \t// Convert features to the format expected by navigation schema\n// \treturn Object.keys(features).reduce((flags, key) => {\n// \t\tflags[key] = features[key] ? 'on' : 'off'\n// \t\treturn flags\n// \t}, {})\n// }\n"],"names":[],"mappings":";;;AAaO,MAAM,uBAAuB,CACnC,WACA,SACA,SACA,gBACI;AACJ,QAAM,mBAAmB,oBAAoB;AACvC,QAAA,aAAa,iBAAiB,cAAc;AAElD,QAAM,WAAW;AAAA,IAChB,CAAC,SAAiB;AAEjB,aAAO,SAAS,OAAO,GAAG,UAAU,GAAG,IAAI;AAAA,IAC5C;AAAA,IACA,CAAC,UAAU;AAAA,EACZ;AAEA,SAAO,QAAQ,MAAM;AACpB,QAAI,CAAC,SAAS;AACb,aAAO,CAAC;AAAA,IAAA;AAGH,UAAA,aAAY,mCAAS,eAAc;AAGzC,UAAM,UAAU;AAAA,MACf,OAAO,CAAC;AAAA;AAAA,MACR,UAAU,OAAO,SAAS;AAAA,MAC1B,aAA0C,CAAA;AAAA,IAC3C;AAGA,WACC,gBAEE,OAAO,CAAC,SAAU,KAAK,aAAa,KAAK,WAAW,OAAO,IAAI,IAAK,EAEpE,IAAI,CAAC,SAAS;AACR,YAAA,WACL,OAAO,KAAK,aAAa,aAAa,KAAK,SAAS,OAAO,IAAI,CAAC,CAAC,KAAK;AAEjE,YAAA,QAAQ,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,OAAO,IAAI,KAAK;AAG5E,YAAM,WAAW,CAAC,UACjB,KAAK,WAAW,KAAK,SAAS,KAAK,IAAI,KAAK,QAAQ,aAAa,UAAU,KAAK;AAE1E,aAAA;AAAA,QACN,KAAK,KAAK;AAAA,QACV,OAAO,KAAK;AAAA;AAAA,QACZ,MAAM,KAAK;AAAA,QACX,SAAS;AAAA,QACT;AAAA,QACA;AAAA,QACA,UAAU,KAAK;AAAA,QACf;AAAA,QACA,MAAM,GAAG,UAAU,GAAG,KAAK,KAAK,EAAE,UAAW,CAAA,CAAC;AAAA,QAC9C,SAAS,MAAM,SAAS,KAAK,KAAK,EAAE,UAAA,CAAW,CAAC;AAAA,MACjD;AAAA,IAAA,CACA;AAAA,EAAA,GAED,CAAC,SAAS,WAAW,SAAS,UAAU,aAAa,UAAU,CAAC;AACpE;"}
@@ -1,18 +1,30 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const jsxRuntime = require("react/jsx-runtime");
4
3
  const React = require("react");
5
- const NavigationClientContext = React.createContext(void 0);
6
- const NavigationClientProvider = ({ client, children }) => {
7
- return /* @__PURE__ */ jsxRuntime.jsx(NavigationClientContext.Provider, { value: client, children });
4
+ const useSidebarDataLoader = (callback) => {
5
+ const [result, setResult] = React.useState(null);
6
+ const [loading, setLoading] = React.useState(true);
7
+ const [error, setError] = React.useState(false);
8
+ const loadData = async (args) => {
9
+ const result2 = await callback(args);
10
+ if (result2) {
11
+ setResult(result2);
12
+ setLoading(false);
13
+ setError(false);
14
+ return result2;
15
+ }
16
+ setError(true);
17
+ setLoading(false);
18
+ return null;
19
+ };
20
+ return {
21
+ data: {
22
+ result,
23
+ loading,
24
+ error
25
+ },
26
+ loadData
27
+ };
8
28
  };
9
- const useNavigationClient = () => {
10
- const context = React.useContext(NavigationClientContext);
11
- if (context === void 0) {
12
- throw new Error("useNavigationClient must be used within a NavigationClientProvider");
13
- }
14
- return context;
15
- };
16
- exports.NavigationClientProvider = NavigationClientProvider;
17
- exports.useNavigationClient = useNavigationClient;
29
+ exports.useSidebarDataLoader = useSidebarDataLoader;
18
30
  //# sourceMappingURL=harmony94.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony94.cjs","sources":["../src/features/navigation/providers/NavigationClientProvider.tsx"],"sourcesContent":["import { type ReactNode, createContext, useContext } from 'react'\nimport type { NavigationClient } from '../core/NavigationClient'\n\ninterface NavigationClientProviderProps {\n\tclient: NavigationClient\n\tchildren: ReactNode\n}\n\nconst NavigationClientContext = createContext<NavigationClient | undefined>(undefined)\n\nexport const NavigationClientProvider = ({ client, children }: NavigationClientProviderProps) => {\n\treturn (\n\t\t<NavigationClientContext.Provider value={client}>{children}</NavigationClientContext.Provider>\n\t)\n}\n\nexport const useNavigationClient = (): NavigationClient => {\n\tconst context = useContext(NavigationClientContext)\n\tif (context === undefined) {\n\t\tthrow new Error('useNavigationClient must be used within a NavigationClientProvider')\n\t}\n\treturn context\n}\n"],"names":["createContext","useContext"],"mappings":";;;;AAQA,MAAM,0BAA0BA,oBAA4C,MAAS;AAE9E,MAAM,2BAA2B,CAAC,EAAE,QAAQ,eAA8C;AAChG,wCACE,wBAAwB,UAAxB,EAAiC,OAAO,QAAS,UAAS;AAE7D;AAEO,MAAM,sBAAsB,MAAwB;AACpD,QAAA,UAAUC,iBAAW,uBAAuB;AAClD,MAAI,YAAY,QAAW;AACpB,UAAA,IAAI,MAAM,oEAAoE;AAAA,EAAA;AAE9E,SAAA;AACR;;;"}
1
+ {"version":3,"file":"harmony94.cjs","sources":["../src/components/Sidebar/hooks/useSidebarDataLoader.ts"],"sourcesContent":["import type { SidebarDataBase } from '@components/Sidebar/types'\nimport { useState } from 'react'\n\nexport const useSidebarDataLoader = <T, A = void>(\n\tcallback: (args: A) => Promise<T | null>,\n): {\n\tdata: SidebarDataBase<T>\n\tloadData: (args: A) => Promise<T | null>\n} => {\n\tconst [result, setResult] = useState<T | null>(null)\n\n\tconst [loading, setLoading] = useState(true)\n\n\tconst [error, setError] = useState(false)\n\n\tconst loadData = async (args: A): Promise<T | null> => {\n\t\tconst result = await callback(args)\n\n\t\tif (result) {\n\t\t\tsetResult(result)\n\t\t\tsetLoading(false)\n\t\t\tsetError(false)\n\n\t\t\treturn result\n\t\t}\n\n\t\tsetError(true)\n\t\tsetLoading(false)\n\t\treturn null\n\t}\n\n\treturn {\n\t\tdata: {\n\t\t\tresult,\n\t\t\tloading,\n\t\t\terror,\n\t\t},\n\t\tloadData,\n\t}\n}\n"],"names":["useState","result"],"mappings":";;;AAGa,MAAA,uBAAuB,CACnC,aAII;AACJ,QAAM,CAAC,QAAQ,SAAS,IAAIA,MAAAA,SAAmB,IAAI;AAEnD,QAAM,CAAC,SAAS,UAAU,IAAIA,MAAAA,SAAS,IAAI;AAE3C,QAAM,CAAC,OAAO,QAAQ,IAAIA,MAAAA,SAAS,KAAK;AAElC,QAAA,WAAW,OAAO,SAA+B;AAChDC,UAAAA,UAAS,MAAM,SAAS,IAAI;AAElC,QAAIA,SAAQ;AACX,gBAAUA,OAAM;AAChB,iBAAW,KAAK;AAChB,eAAS,KAAK;AAEPA,aAAAA;AAAAA,IAAA;AAGR,aAAS,IAAI;AACb,eAAW,KAAK;AACT,WAAA;AAAA,EACR;AAEO,SAAA;AAAA,IACN,MAAM;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,IACA;AAAA,EACD;AACD;;"}
@@ -1,18 +1,30 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { createContext, useContext } from "react";
3
- const NavigationClientContext = createContext(void 0);
4
- const NavigationClientProvider = ({ client, children }) => {
5
- return /* @__PURE__ */ jsx(NavigationClientContext.Provider, { value: client, children });
6
- };
7
- const useNavigationClient = () => {
8
- const context = useContext(NavigationClientContext);
9
- if (context === void 0) {
10
- throw new Error("useNavigationClient must be used within a NavigationClientProvider");
11
- }
12
- return context;
1
+ import { useState } from "react";
2
+ const useSidebarDataLoader = (callback) => {
3
+ const [result, setResult] = useState(null);
4
+ const [loading, setLoading] = useState(true);
5
+ const [error, setError] = useState(false);
6
+ const loadData = async (args) => {
7
+ const result2 = await callback(args);
8
+ if (result2) {
9
+ setResult(result2);
10
+ setLoading(false);
11
+ setError(false);
12
+ return result2;
13
+ }
14
+ setError(true);
15
+ setLoading(false);
16
+ return null;
17
+ };
18
+ return {
19
+ data: {
20
+ result,
21
+ loading,
22
+ error
23
+ },
24
+ loadData
25
+ };
13
26
  };
14
27
  export {
15
- NavigationClientProvider,
16
- useNavigationClient
28
+ useSidebarDataLoader
17
29
  };
18
30
  //# sourceMappingURL=harmony94.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony94.mjs","sources":["../src/features/navigation/providers/NavigationClientProvider.tsx"],"sourcesContent":["import { type ReactNode, createContext, useContext } from 'react'\nimport type { NavigationClient } from '../core/NavigationClient'\n\ninterface NavigationClientProviderProps {\n\tclient: NavigationClient\n\tchildren: ReactNode\n}\n\nconst NavigationClientContext = createContext<NavigationClient | undefined>(undefined)\n\nexport const NavigationClientProvider = ({ client, children }: NavigationClientProviderProps) => {\n\treturn (\n\t\t<NavigationClientContext.Provider value={client}>{children}</NavigationClientContext.Provider>\n\t)\n}\n\nexport const useNavigationClient = (): NavigationClient => {\n\tconst context = useContext(NavigationClientContext)\n\tif (context === undefined) {\n\t\tthrow new Error('useNavigationClient must be used within a NavigationClientProvider')\n\t}\n\treturn context\n}\n"],"names":[],"mappings":";;AAQA,MAAM,0BAA0B,cAA4C,MAAS;AAE9E,MAAM,2BAA2B,CAAC,EAAE,QAAQ,eAA8C;AAChG,6BACE,wBAAwB,UAAxB,EAAiC,OAAO,QAAS,UAAS;AAE7D;AAEO,MAAM,sBAAsB,MAAwB;AACpD,QAAA,UAAU,WAAW,uBAAuB;AAClD,MAAI,YAAY,QAAW;AACpB,UAAA,IAAI,MAAM,oEAAoE;AAAA,EAAA;AAE9E,SAAA;AACR;"}
1
+ {"version":3,"file":"harmony94.mjs","sources":["../src/components/Sidebar/hooks/useSidebarDataLoader.ts"],"sourcesContent":["import type { SidebarDataBase } from '@components/Sidebar/types'\nimport { useState } from 'react'\n\nexport const useSidebarDataLoader = <T, A = void>(\n\tcallback: (args: A) => Promise<T | null>,\n): {\n\tdata: SidebarDataBase<T>\n\tloadData: (args: A) => Promise<T | null>\n} => {\n\tconst [result, setResult] = useState<T | null>(null)\n\n\tconst [loading, setLoading] = useState(true)\n\n\tconst [error, setError] = useState(false)\n\n\tconst loadData = async (args: A): Promise<T | null> => {\n\t\tconst result = await callback(args)\n\n\t\tif (result) {\n\t\t\tsetResult(result)\n\t\t\tsetLoading(false)\n\t\t\tsetError(false)\n\n\t\t\treturn result\n\t\t}\n\n\t\tsetError(true)\n\t\tsetLoading(false)\n\t\treturn null\n\t}\n\n\treturn {\n\t\tdata: {\n\t\t\tresult,\n\t\t\tloading,\n\t\t\terror,\n\t\t},\n\t\tloadData,\n\t}\n}\n"],"names":["result"],"mappings":";AAGa,MAAA,uBAAuB,CACnC,aAII;AACJ,QAAM,CAAC,QAAQ,SAAS,IAAI,SAAmB,IAAI;AAEnD,QAAM,CAAC,SAAS,UAAU,IAAI,SAAS,IAAI;AAE3C,QAAM,CAAC,OAAO,QAAQ,IAAI,SAAS,KAAK;AAElC,QAAA,WAAW,OAAO,SAA+B;AAChDA,UAAAA,UAAS,MAAM,SAAS,IAAI;AAElC,QAAIA,SAAQ;AACX,gBAAUA,OAAM;AAChB,iBAAW,KAAK;AAChB,eAAS,KAAK;AAEPA,aAAAA;AAAAA,IAAA;AAGR,aAAS,IAAI;AACb,eAAW,KAAK;AACT,WAAA;AAAA,EACR;AAEO,SAAA;AAAA,IACN,MAAM;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,IACA;AAAA,EACD;AACD;"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const reactQuery = require("@tanstack/react-query");
4
- const queryClient = new reactQuery.QueryClient({});
5
- exports.queryClient = queryClient;
3
+ const React = require("react");
4
+ const SidebarContext = React.createContext({});
5
+ exports.SidebarContext = SidebarContext;
6
6
  //# sourceMappingURL=harmony95.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony95.cjs","sources":["../src/shared/queryClient.ts"],"sourcesContent":["import { QueryClient } from '@tanstack/react-query'\n\nexport const queryClient = new QueryClient({})\n"],"names":["QueryClient"],"mappings":";;;AAEO,MAAM,cAAc,IAAIA,WAAAA,YAAY,CAAE,CAAA;;"}
1
+ {"version":3,"file":"harmony95.cjs","sources":["../src/components/Sidebar/SidebarContext.ts"],"sourcesContent":["import { createContext, useContext } from 'react'\nimport type { SidebarContextProps } from './types'\n\nexport const SidebarContext = createContext({} as SidebarContextProps)\n\nexport const useSidebar = () => {\n\tconst context = useContext(SidebarContext)\n\n\tif (!context) {\n\t\tthrow new Error(\n\t\t\t'You are using useSidebar hook outside its context. Please review your code implementation',\n\t\t)\n\t}\n\n\treturn context\n}\n"],"names":["createContext"],"mappings":";;;AAGa,MAAA,iBAAiBA,MAAc,cAAA,CAAyB,CAAA;;"}
@@ -1,6 +1,6 @@
1
- import { QueryClient } from "@tanstack/react-query";
2
- const queryClient = new QueryClient({});
1
+ import { createContext } from "react";
2
+ const SidebarContext = createContext({});
3
3
  export {
4
- queryClient
4
+ SidebarContext
5
5
  };
6
6
  //# sourceMappingURL=harmony95.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony95.mjs","sources":["../src/shared/queryClient.ts"],"sourcesContent":["import { QueryClient } from '@tanstack/react-query'\n\nexport const queryClient = new QueryClient({})\n"],"names":[],"mappings":";AAEO,MAAM,cAAc,IAAI,YAAY,CAAE,CAAA;"}
1
+ {"version":3,"file":"harmony95.mjs","sources":["../src/components/Sidebar/SidebarContext.ts"],"sourcesContent":["import { createContext, useContext } from 'react'\nimport type { SidebarContextProps } from './types'\n\nexport const SidebarContext = createContext({} as SidebarContextProps)\n\nexport const useSidebar = () => {\n\tconst context = useContext(SidebarContext)\n\n\tif (!context) {\n\t\tthrow new Error(\n\t\t\t'You are using useSidebar hook outside its context. Please review your code implementation',\n\t\t)\n\t}\n\n\treturn context\n}\n"],"names":[],"mappings":";AAGa,MAAA,iBAAiB,cAAc,CAAyB,CAAA;"}
@@ -1,169 +1,21 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const React = require("react");
4
- const NavigationClientProvider = require("./harmony94.cjs");
5
- const toolbarVisibility = require("./harmony115.cjs");
6
- const useExpertNavigation = (enabled, project, contributor) => {
7
- const adminRights = (contributor == null ? void 0 : contributor.admin_rights) || [];
8
- const marketingSupportProjectSelectedAppSlug = "selected-app-slug";
9
- const navigationClient = NavigationClientProvider.useNavigationClient();
10
- const expertUrl = navigationClient.getExpertUrl();
11
- return React.useMemo(() => {
12
- if (!project || !enabled) {
13
- return [];
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const louis = require("@lokalise/louis");
5
+ const clsx = require("./harmony73.cjs");
6
+ const IconLink_module = require("./harmony106.cjs");
7
+ const IconLink = ({ label, to, icon: Icon }) => {
8
+ return /* @__PURE__ */ jsxRuntime.jsx(louis.Tooltip, { placement: "right", tooltip: label, children: /* @__PURE__ */ jsxRuntime.jsx(
9
+ louis.Link,
10
+ {
11
+ "aria-label": label,
12
+ className: clsx.clsx(IconLink_module.default.link, {
13
+ [IconLink_module.default.active]: typeof window !== "undefined" && window.location.pathname.startsWith(to)
14
+ }),
15
+ href: to,
16
+ children: /* @__PURE__ */ jsxRuntime.jsx(Icon, { size: "25px" })
14
17
  }
15
- const navigationVisibility = toolbarVisibility.getProjectNavigationVisibilityMap(
16
- project,
17
- adminRights,
18
- () => true
19
- );
20
- const appsNavigationItem = {
21
- key: "apps",
22
- label: "Apps",
23
- isActive: (input) => input === "apps",
24
- link: `${expertUrl}/apps/${project.project_id}/`,
25
- ...navigationVisibility.apps
26
- };
27
- const appsNavigationItemArrInMainMenu = [];
28
- const appsNavigationItemArrInMoreMenu = [];
29
- if (project.project_type === "content_integration") {
30
- appsNavigationItemArrInMoreMenu.push(appsNavigationItem);
31
- } else {
32
- appsNavigationItemArrInMainMenu.push(appsNavigationItem);
33
- }
34
- return [
35
- {
36
- key: "edit",
37
- label: "Editor",
38
- link: `${expertUrl}/project/${project.project_id}/`,
39
- isActive: (input) => input === "edit",
40
- ...navigationVisibility.editor
41
- },
42
- {
43
- key: "files",
44
- label: "Files",
45
- link: `${expertUrl}/files/${project.project_id}/`,
46
- isActive: (input) => input === "files",
47
- ...navigationVisibility.files
48
- },
49
- ...project.project_type === "content_integration" ? [
50
- {
51
- key: "contentManagement",
52
- label: "Content management",
53
- isActive: (input) => input === "apps",
54
- link: `${expertUrl}/apps/${project.project_id}/${marketingSupportProjectSelectedAppSlug}`,
55
- ...navigationVisibility.contentManagement
56
- }
57
- ] : [
58
- {
59
- key: "upload",
60
- label: "Upload",
61
- link: `${expertUrl}/upload/${project.project_id}/`,
62
- isActive: (input) => input === "upload",
63
- ...navigationVisibility.upload
64
- },
65
- {
66
- key: "download",
67
- label: "Download",
68
- link: `${expertUrl}/download/${project.project_id}/`,
69
- isActive: (input) => input === "download",
70
- ...navigationVisibility.download
71
- }
72
- ],
73
- {
74
- key: "tasks",
75
- label: "Tasks",
76
- link: `${expertUrl}/tasks/${project.project_id}/`,
77
- isActive: (input) => input === "tasks",
78
- // TODO: Add task count
79
- // badge: taskCount,
80
- ...navigationVisibility.tasks
81
- },
82
- {
83
- key: "workflows",
84
- label: "Workflows",
85
- link: `${expertUrl}/workflows/${project.project_id}/`,
86
- isActive: (input) => input === "workflows",
87
- novel: "New",
88
- onClick: () => {
89
- window.location.assign(`${expertUrl}/workflows/${project.project_id}/`);
90
- },
91
- ...navigationVisibility.workflows
92
- },
93
- {
94
- key: "contributors",
95
- label: "Contributors",
96
- link: `${expertUrl}/contributors/${project.project_id}/`,
97
- isActive: (input) => input === "contributors",
98
- ...navigationVisibility.contributors
99
- },
100
- {
101
- key: "screenshots",
102
- label: "Screenshots",
103
- link: `${expertUrl}/screenshots/${project.project_id}/`,
104
- isActive: (input) => input === "screenshots",
105
- ...navigationVisibility.screenshots
106
- },
107
- {
108
- key: "glossary",
109
- label: "Glossary",
110
- link: `${expertUrl}/glossary/${project.project_id}/`,
111
- isActive: (input) => input === "glossary",
112
- ...navigationVisibility.glossary
113
- },
114
- ...appsNavigationItemArrInMainMenu,
115
- {
116
- key: "more",
117
- label: "More...",
118
- isActive: (input) => ["settings", "statistics", "duplicates", "live edit"].includes(input),
119
- ...navigationVisibility.more,
120
- dropdown: [
121
- [
122
- {
123
- link: `${expertUrl}/settings/${project.project_id}/`,
124
- label: "Settings",
125
- ...navigationVisibility.settings
126
- },
127
- {
128
- link: `${expertUrl}/settings/${project.project_id}/#branches`,
129
- label: "Branches",
130
- ...navigationVisibility.branches
131
- },
132
- {
133
- link: `${expertUrl}/settings/${project.project_id}/#ota-bundles`,
134
- label: "OTA Bundles",
135
- ...navigationVisibility.otaBundles
136
- },
137
- {
138
- link: `${expertUrl}/settings/${project.project_id}/#project-automations`,
139
- label: "Automations",
140
- ...navigationVisibility.automations
141
- },
142
- {
143
- link: `${expertUrl}/dupes/${project.project_id}/`,
144
- label: "Duplicate finder",
145
- ...navigationVisibility.duplicateFinder
146
- }
147
- ],
148
- [
149
- ...appsNavigationItemArrInMoreMenu,
150
- {
151
- // TODO: This could be problematic tab, because it is not a link and we can't just redirect. We need to find a workaround for that.
152
- label: "Activity",
153
- onClick: () => {
154
- },
155
- ...navigationVisibility.activity
156
- },
157
- {
158
- link: `${expertUrl}/statistics/${project.project_id}/`,
159
- label: "Statistics",
160
- ...navigationVisibility.statistics
161
- }
162
- ]
163
- ]
164
- }
165
- ];
166
- }, [project, adminRights, enabled, expertUrl]);
18
+ ) });
167
19
  };
168
- exports.useExpertNavigation = useExpertNavigation;
20
+ exports.IconLink = IconLink;
169
21
  //# sourceMappingURL=harmony96.cjs.map