@lokalise/harmony 1.33.0-exp-louis-27.0.0.1 → 1.33.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 (399) hide show
  1. package/dist/harmony.cjs +22 -16
  2. package/dist/harmony.cjs.map +1 -1
  3. package/dist/harmony.mjs +23 -17
  4. package/dist/harmony.mjs.map +1 -1
  5. package/dist/harmony100.cjs +22 -19
  6. package/dist/harmony100.cjs.map +1 -1
  7. package/dist/harmony100.mjs +21 -18
  8. package/dist/harmony100.mjs.map +1 -1
  9. package/dist/harmony101.cjs +5 -13
  10. package/dist/harmony101.cjs.map +1 -1
  11. package/dist/harmony101.mjs +5 -13
  12. package/dist/harmony101.mjs.map +1 -1
  13. package/dist/harmony102.cjs +132 -21
  14. package/dist/harmony102.cjs.map +1 -1
  15. package/dist/harmony102.mjs +131 -20
  16. package/dist/harmony102.mjs.map +1 -1
  17. package/dist/harmony103.cjs +12 -6
  18. package/dist/harmony103.cjs.map +1 -1
  19. package/dist/harmony103.mjs +11 -5
  20. package/dist/harmony103.mjs.map +1 -1
  21. package/dist/harmony104.cjs +5 -132
  22. package/dist/harmony104.cjs.map +1 -1
  23. package/dist/harmony104.mjs +5 -132
  24. package/dist/harmony104.mjs.map +1 -1
  25. package/dist/harmony105.cjs +40 -12
  26. package/dist/harmony105.cjs.map +1 -1
  27. package/dist/harmony105.mjs +39 -11
  28. package/dist/harmony105.mjs.map +1 -1
  29. package/dist/harmony106.cjs +59 -4
  30. package/dist/harmony106.cjs.map +1 -1
  31. package/dist/harmony106.mjs +60 -5
  32. package/dist/harmony106.mjs.map +1 -1
  33. package/dist/harmony107.cjs +6 -39
  34. package/dist/harmony107.cjs.map +1 -1
  35. package/dist/harmony107.mjs +6 -39
  36. package/dist/harmony107.mjs.map +1 -1
  37. package/dist/harmony108.cjs +95 -56
  38. package/dist/harmony108.cjs.map +1 -1
  39. package/dist/harmony108.mjs +79 -57
  40. package/dist/harmony108.mjs.map +1 -1
  41. package/dist/harmony109.cjs +18 -7
  42. package/dist/harmony109.cjs.map +1 -1
  43. package/dist/harmony109.mjs +18 -7
  44. package/dist/harmony109.mjs.map +1 -1
  45. package/dist/harmony110.cjs +14 -6
  46. package/dist/harmony110.cjs.map +1 -1
  47. package/dist/harmony110.mjs +13 -5
  48. package/dist/harmony110.mjs.map +1 -1
  49. package/dist/harmony111.cjs +6 -5
  50. package/dist/harmony111.cjs.map +1 -1
  51. package/dist/harmony111.mjs +6 -5
  52. package/dist/harmony112.cjs +63 -6
  53. package/dist/harmony112.cjs.map +1 -1
  54. package/dist/harmony112.mjs +62 -5
  55. package/dist/harmony112.mjs.map +1 -1
  56. package/dist/harmony113.cjs +87 -61
  57. package/dist/harmony113.cjs.map +1 -1
  58. package/dist/harmony113.mjs +87 -61
  59. package/dist/harmony113.mjs.map +1 -1
  60. package/dist/harmony114.cjs +18 -88
  61. package/dist/harmony114.cjs.map +1 -1
  62. package/dist/harmony114.mjs +17 -87
  63. package/dist/harmony114.mjs.map +1 -1
  64. package/dist/harmony115.cjs +5 -18
  65. package/dist/harmony115.cjs.map +1 -1
  66. package/dist/harmony115.mjs +5 -18
  67. package/dist/harmony115.mjs.map +1 -1
  68. package/dist/harmony116.cjs +6 -97
  69. package/dist/harmony116.cjs.map +1 -1
  70. package/dist/harmony116.mjs +5 -96
  71. package/dist/harmony116.mjs.map +1 -1
  72. package/dist/harmony117.cjs +94 -11
  73. package/dist/harmony117.cjs.map +1 -1
  74. package/dist/harmony117.mjs +94 -11
  75. package/dist/harmony117.mjs.map +1 -1
  76. package/dist/harmony118.cjs +12 -13
  77. package/dist/harmony118.cjs.map +1 -1
  78. package/dist/harmony118.mjs +12 -13
  79. package/dist/harmony118.mjs.map +1 -1
  80. package/dist/harmony119.cjs +13 -35
  81. package/dist/harmony119.cjs.map +1 -1
  82. package/dist/harmony119.mjs +13 -35
  83. package/dist/harmony119.mjs.map +1 -1
  84. package/dist/harmony120.cjs +32 -24
  85. package/dist/harmony120.cjs.map +1 -1
  86. package/dist/harmony120.mjs +32 -24
  87. package/dist/harmony120.mjs.map +1 -1
  88. package/dist/harmony121.cjs +27 -12
  89. package/dist/harmony121.cjs.map +1 -1
  90. package/dist/harmony121.mjs +27 -12
  91. package/dist/harmony121.mjs.map +1 -1
  92. package/dist/harmony122.cjs +7 -15
  93. package/dist/harmony122.cjs.map +1 -1
  94. package/dist/harmony122.mjs +7 -15
  95. package/dist/harmony122.mjs.map +1 -1
  96. package/dist/harmony123.cjs +57 -16
  97. package/dist/harmony123.cjs.map +1 -1
  98. package/dist/harmony123.mjs +57 -16
  99. package/dist/harmony123.mjs.map +1 -1
  100. package/dist/harmony124.cjs +59 -6
  101. package/dist/harmony124.cjs.map +1 -1
  102. package/dist/harmony124.mjs +59 -6
  103. package/dist/harmony124.mjs.map +1 -1
  104. package/dist/harmony125.cjs +18 -57
  105. package/dist/harmony125.cjs.map +1 -1
  106. package/dist/harmony125.mjs +17 -56
  107. package/dist/harmony125.mjs.map +1 -1
  108. package/dist/harmony126.cjs +13 -60
  109. package/dist/harmony126.cjs.map +1 -1
  110. package/dist/harmony126.mjs +13 -60
  111. package/dist/harmony126.mjs.map +1 -1
  112. package/dist/harmony127.cjs +16 -19
  113. package/dist/harmony127.cjs.map +1 -1
  114. package/dist/harmony127.mjs +15 -18
  115. package/dist/harmony127.mjs.map +1 -1
  116. package/dist/harmony128.cjs +15 -10
  117. package/dist/harmony128.cjs.map +1 -1
  118. package/dist/harmony128.mjs +15 -10
  119. package/dist/harmony128.mjs.map +1 -1
  120. package/dist/harmony129.cjs +10 -15
  121. package/dist/harmony129.cjs.map +1 -1
  122. package/dist/harmony129.mjs +10 -15
  123. package/dist/harmony129.mjs.map +1 -1
  124. package/dist/harmony130.cjs +13 -18
  125. package/dist/harmony130.cjs.map +1 -1
  126. package/dist/harmony130.mjs +13 -18
  127. package/dist/harmony130.mjs.map +1 -1
  128. package/dist/harmony131.cjs +19 -10
  129. package/dist/harmony131.cjs.map +1 -1
  130. package/dist/harmony131.mjs +19 -10
  131. package/dist/harmony131.mjs.map +1 -1
  132. package/dist/harmony132.cjs +11 -5
  133. package/dist/harmony132.cjs.map +1 -1
  134. package/dist/harmony132.mjs +11 -5
  135. package/dist/harmony132.mjs.map +1 -1
  136. package/dist/harmony133.cjs +46 -12
  137. package/dist/harmony133.cjs.map +1 -1
  138. package/dist/harmony133.mjs +46 -12
  139. package/dist/harmony133.mjs.map +1 -1
  140. package/dist/harmony134.cjs +13 -33
  141. package/dist/harmony134.cjs.map +1 -1
  142. package/dist/harmony134.mjs +12 -32
  143. package/dist/harmony134.mjs.map +1 -1
  144. package/dist/harmony135.cjs +5 -13
  145. package/dist/harmony135.cjs.map +1 -1
  146. package/dist/harmony135.mjs +5 -13
  147. package/dist/harmony135.mjs.map +1 -1
  148. package/dist/harmony136.cjs +12 -46
  149. package/dist/harmony136.cjs.map +1 -1
  150. package/dist/harmony136.mjs +12 -46
  151. package/dist/harmony136.mjs.map +1 -1
  152. package/dist/harmony137.cjs +33 -13
  153. package/dist/harmony137.cjs.map +1 -1
  154. package/dist/harmony137.mjs +32 -12
  155. package/dist/harmony137.mjs.map +1 -1
  156. package/dist/harmony138.cjs +17 -0
  157. package/dist/harmony138.cjs.map +1 -0
  158. package/dist/harmony138.mjs +17 -0
  159. package/dist/harmony138.mjs.map +1 -0
  160. package/dist/harmony16.cjs +1 -1
  161. package/dist/harmony16.mjs +1 -1
  162. package/dist/harmony23.cjs +1 -1
  163. package/dist/harmony23.mjs +1 -1
  164. package/dist/harmony24.cjs +1 -1
  165. package/dist/harmony24.mjs +1 -1
  166. package/dist/harmony26.cjs +1 -1
  167. package/dist/harmony26.mjs +1 -1
  168. package/dist/harmony27.cjs +2 -2
  169. package/dist/harmony27.mjs +2 -2
  170. package/dist/harmony28.cjs +2 -2
  171. package/dist/harmony28.mjs +2 -2
  172. package/dist/harmony29.cjs +2 -2
  173. package/dist/harmony29.mjs +2 -2
  174. package/dist/harmony3.cjs +3 -3
  175. package/dist/harmony3.mjs +3 -3
  176. package/dist/harmony30.cjs +1 -1
  177. package/dist/harmony30.mjs +1 -1
  178. package/dist/harmony31.cjs +2 -2
  179. package/dist/harmony31.mjs +2 -2
  180. package/dist/harmony32.cjs +1 -1
  181. package/dist/harmony32.mjs +1 -1
  182. package/dist/harmony33.cjs +9 -1
  183. package/dist/harmony33.cjs.map +1 -1
  184. package/dist/harmony33.mjs +10 -2
  185. package/dist/harmony33.mjs.map +1 -1
  186. package/dist/harmony34.cjs +1 -1
  187. package/dist/harmony34.mjs +1 -1
  188. package/dist/harmony4.cjs +10 -10
  189. package/dist/harmony4.mjs +10 -10
  190. package/dist/harmony5.cjs +1 -1
  191. package/dist/harmony5.mjs +1 -1
  192. package/dist/harmony50.cjs +14 -12
  193. package/dist/harmony50.cjs.map +1 -1
  194. package/dist/harmony50.mjs +14 -12
  195. package/dist/harmony50.mjs.map +1 -1
  196. package/dist/harmony51.cjs +12 -14
  197. package/dist/harmony51.cjs.map +1 -1
  198. package/dist/harmony51.mjs +12 -14
  199. package/dist/harmony51.mjs.map +1 -1
  200. package/dist/harmony52.cjs +8 -8
  201. package/dist/harmony52.cjs.map +1 -1
  202. package/dist/harmony52.mjs +8 -8
  203. package/dist/harmony52.mjs.map +1 -1
  204. package/dist/harmony53.cjs +10 -7
  205. package/dist/harmony53.cjs.map +1 -1
  206. package/dist/harmony53.mjs +12 -9
  207. package/dist/harmony53.mjs.map +1 -1
  208. package/dist/harmony54.cjs +14 -56
  209. package/dist/harmony54.cjs.map +1 -1
  210. package/dist/harmony54.mjs +14 -56
  211. package/dist/harmony54.mjs.map +1 -1
  212. package/dist/harmony55.cjs +48 -74
  213. package/dist/harmony55.cjs.map +1 -1
  214. package/dist/harmony55.mjs +47 -73
  215. package/dist/harmony55.mjs.map +1 -1
  216. package/dist/harmony56.cjs +80 -4
  217. package/dist/harmony56.cjs.map +1 -1
  218. package/dist/harmony56.mjs +80 -4
  219. package/dist/harmony56.mjs.map +1 -1
  220. package/dist/harmony57.cjs +4 -21
  221. package/dist/harmony57.cjs.map +1 -1
  222. package/dist/harmony57.mjs +4 -21
  223. package/dist/harmony57.mjs.map +1 -1
  224. package/dist/harmony58.cjs +20 -17
  225. package/dist/harmony58.cjs.map +1 -1
  226. package/dist/harmony58.mjs +20 -17
  227. package/dist/harmony58.mjs.map +1 -1
  228. package/dist/harmony59.cjs +14 -137
  229. package/dist/harmony59.cjs.map +1 -1
  230. package/dist/harmony59.mjs +12 -135
  231. package/dist/harmony59.mjs.map +1 -1
  232. package/dist/harmony6.cjs +4 -4
  233. package/dist/harmony6.mjs +4 -4
  234. package/dist/harmony60.cjs +142 -46
  235. package/dist/harmony60.cjs.map +1 -1
  236. package/dist/harmony60.mjs +141 -45
  237. package/dist/harmony60.mjs.map +1 -1
  238. package/dist/harmony61.cjs +46 -25
  239. package/dist/harmony61.cjs.map +1 -1
  240. package/dist/harmony61.mjs +46 -25
  241. package/dist/harmony61.mjs.map +1 -1
  242. package/dist/harmony62.cjs +24 -6
  243. package/dist/harmony62.cjs.map +1 -1
  244. package/dist/harmony62.mjs +24 -6
  245. package/dist/harmony62.mjs.map +1 -1
  246. package/dist/harmony63.cjs +6 -82
  247. package/dist/harmony63.cjs.map +1 -1
  248. package/dist/harmony63.mjs +6 -82
  249. package/dist/harmony63.mjs.map +1 -1
  250. package/dist/harmony64.cjs +80 -20
  251. package/dist/harmony64.cjs.map +1 -1
  252. package/dist/harmony64.mjs +80 -20
  253. package/dist/harmony64.mjs.map +1 -1
  254. package/dist/harmony65.cjs +31 -16
  255. package/dist/harmony65.cjs.map +1 -1
  256. package/dist/harmony65.mjs +31 -16
  257. package/dist/harmony65.mjs.map +1 -1
  258. package/dist/harmony66.cjs +19 -16
  259. package/dist/harmony66.cjs.map +1 -1
  260. package/dist/harmony66.mjs +18 -15
  261. package/dist/harmony66.mjs.map +1 -1
  262. package/dist/harmony67.cjs +15 -18
  263. package/dist/harmony67.cjs.map +1 -1
  264. package/dist/harmony67.mjs +15 -18
  265. package/dist/harmony67.mjs.map +1 -1
  266. package/dist/harmony68.cjs +18 -61
  267. package/dist/harmony68.cjs.map +1 -1
  268. package/dist/harmony68.mjs +18 -61
  269. package/dist/harmony68.mjs.map +1 -1
  270. package/dist/harmony69.cjs +61 -6
  271. package/dist/harmony69.cjs.map +1 -1
  272. package/dist/harmony69.mjs +61 -6
  273. package/dist/harmony69.mjs.map +1 -1
  274. package/dist/harmony7.cjs +1 -1
  275. package/dist/harmony7.mjs +1 -1
  276. package/dist/harmony70.cjs +7 -10
  277. package/dist/harmony70.cjs.map +1 -1
  278. package/dist/harmony70.mjs +6 -9
  279. package/dist/harmony70.mjs.map +1 -1
  280. package/dist/harmony71.cjs +8 -17
  281. package/dist/harmony71.cjs.map +1 -1
  282. package/dist/harmony71.mjs +7 -16
  283. package/dist/harmony71.mjs.map +1 -1
  284. package/dist/harmony72.cjs +13 -18
  285. package/dist/harmony72.cjs.map +1 -1
  286. package/dist/harmony72.mjs +13 -18
  287. package/dist/harmony72.mjs.map +1 -1
  288. package/dist/harmony73.cjs +22 -4
  289. package/dist/harmony73.cjs.map +1 -1
  290. package/dist/harmony73.mjs +22 -4
  291. package/dist/harmony73.mjs.map +1 -1
  292. package/dist/harmony74.cjs +4 -31
  293. package/dist/harmony74.cjs.map +1 -1
  294. package/dist/harmony74.mjs +5 -32
  295. package/dist/harmony74.mjs.map +1 -1
  296. package/dist/harmony75.cjs +26 -26
  297. package/dist/harmony75.cjs.map +1 -1
  298. package/dist/harmony75.mjs +27 -27
  299. package/dist/harmony75.mjs.map +1 -1
  300. package/dist/harmony76.cjs +25 -12
  301. package/dist/harmony76.cjs.map +1 -1
  302. package/dist/harmony76.mjs +25 -12
  303. package/dist/harmony76.mjs.map +1 -1
  304. package/dist/harmony77.cjs +12 -24
  305. package/dist/harmony77.cjs.map +1 -1
  306. package/dist/harmony77.mjs +13 -25
  307. package/dist/harmony77.mjs.map +1 -1
  308. package/dist/harmony78.cjs +27 -55
  309. package/dist/harmony78.cjs.map +1 -1
  310. package/dist/harmony78.mjs +29 -57
  311. package/dist/harmony78.mjs.map +1 -1
  312. package/dist/harmony79.cjs +60 -10
  313. package/dist/harmony79.cjs.map +1 -1
  314. package/dist/harmony79.mjs +59 -9
  315. package/dist/harmony79.mjs.map +1 -1
  316. package/dist/harmony80.cjs +10 -9
  317. package/dist/harmony80.cjs.map +1 -1
  318. package/dist/harmony80.mjs +9 -8
  319. package/dist/harmony80.mjs.map +1 -1
  320. package/dist/harmony81.cjs +5 -26
  321. package/dist/harmony81.cjs.map +1 -1
  322. package/dist/harmony81.mjs +8 -29
  323. package/dist/harmony81.mjs.map +1 -1
  324. package/dist/harmony82.cjs +29 -3
  325. package/dist/harmony82.cjs.map +1 -1
  326. package/dist/harmony82.mjs +29 -3
  327. package/dist/harmony82.mjs.map +1 -1
  328. package/dist/harmony83.cjs +3 -40
  329. package/dist/harmony83.cjs.map +1 -1
  330. package/dist/harmony83.mjs +3 -40
  331. package/dist/harmony83.mjs.map +1 -1
  332. package/dist/harmony84.cjs +40 -6
  333. package/dist/harmony84.cjs.map +1 -1
  334. package/dist/harmony84.mjs +39 -5
  335. package/dist/harmony84.mjs.map +1 -1
  336. package/dist/harmony85.cjs +3 -6
  337. package/dist/harmony85.cjs.map +1 -1
  338. package/dist/harmony85.mjs +3 -6
  339. package/dist/harmony85.mjs.map +1 -1
  340. package/dist/harmony86.cjs +6 -6
  341. package/dist/harmony86.mjs +6 -6
  342. package/dist/harmony87.cjs +9 -57
  343. package/dist/harmony87.cjs.map +1 -1
  344. package/dist/harmony87.mjs +8 -56
  345. package/dist/harmony87.mjs.map +1 -1
  346. package/dist/harmony88.cjs +51 -36
  347. package/dist/harmony88.cjs.map +1 -1
  348. package/dist/harmony88.mjs +52 -37
  349. package/dist/harmony88.mjs.map +1 -1
  350. package/dist/harmony89.cjs +42 -5
  351. package/dist/harmony89.cjs.map +1 -1
  352. package/dist/harmony89.mjs +42 -5
  353. package/dist/harmony89.mjs.map +1 -1
  354. package/dist/harmony90.cjs +6 -10
  355. package/dist/harmony90.cjs.map +1 -1
  356. package/dist/harmony90.mjs +5 -9
  357. package/dist/harmony90.mjs.map +1 -1
  358. package/dist/harmony91.cjs +6 -21
  359. package/dist/harmony91.cjs.map +1 -1
  360. package/dist/harmony91.mjs +6 -21
  361. package/dist/harmony91.mjs.map +1 -1
  362. package/dist/harmony92.cjs +21 -3
  363. package/dist/harmony92.cjs.map +1 -1
  364. package/dist/harmony92.mjs +21 -3
  365. package/dist/harmony92.mjs.map +1 -1
  366. package/dist/harmony93.cjs +6 -21
  367. package/dist/harmony93.cjs.map +1 -1
  368. package/dist/harmony93.mjs +5 -20
  369. package/dist/harmony93.mjs.map +1 -1
  370. package/dist/harmony94.cjs +21 -12
  371. package/dist/harmony94.cjs.map +1 -1
  372. package/dist/harmony94.mjs +20 -11
  373. package/dist/harmony94.mjs.map +1 -1
  374. package/dist/harmony95.cjs +12 -12
  375. package/dist/harmony95.cjs.map +1 -1
  376. package/dist/harmony95.mjs +11 -11
  377. package/dist/harmony95.mjs.map +1 -1
  378. package/dist/harmony96.cjs +12 -12
  379. package/dist/harmony96.cjs.map +1 -1
  380. package/dist/harmony96.mjs +11 -11
  381. package/dist/harmony96.mjs.map +1 -1
  382. package/dist/harmony97.cjs +13 -12
  383. package/dist/harmony97.cjs.map +1 -1
  384. package/dist/harmony97.mjs +12 -11
  385. package/dist/harmony97.mjs.map +1 -1
  386. package/dist/harmony98.cjs +12 -22
  387. package/dist/harmony98.cjs.map +1 -1
  388. package/dist/harmony98.mjs +11 -21
  389. package/dist/harmony98.mjs.map +1 -1
  390. package/dist/harmony99.cjs +21 -99
  391. package/dist/harmony99.cjs.map +1 -1
  392. package/dist/harmony99.mjs +20 -81
  393. package/dist/harmony99.mjs.map +1 -1
  394. package/dist/types/src/features/publicApi/hooks/useListTeamUsersQuery.d.ts +32 -0
  395. package/dist/types/src/features/publicApi/node.d.ts +1 -0
  396. package/dist/types/src/features/publicApi/teamUsers.d.ts +110 -0
  397. package/dist/types/src/features/publicApi/types/projectTypes.d.ts +65 -0
  398. package/dist/types/src/features/publicApi/types/teamUserTypes.d.ts +54 -0
  399. package/package.json +2 -2
@@ -1,34 +1,22 @@
1
- import { jsxs, jsx } from "react/jsx-runtime";
2
- import { MenuItem } from "@lokalise/louis";
3
- import { isFreePlan } from "./harmony8.mjs";
4
- import { UpgradeIcon } from "./harmony93.mjs";
5
- import { useProfileMenu } from "./harmony89.mjs";
6
- import styles from "./harmony94.mjs";
7
- const UpgradeMenuItem = ({ upgradeOptionHref }) => {
8
- const { planId, trialDaysLeft, showUpgradeCta } = useProfileMenu();
9
- if (!showUpgradeCta) {
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { useProfileMenu } from "./harmony90.mjs";
3
+ import { TeamMenuItem } from "./harmony76.mjs";
4
+ import styles from "./harmony93.mjs";
5
+ const TeamSwitch = ({ onSwitchTeam }) => {
6
+ const { otherTeams } = useProfileMenu();
7
+ if (otherTeams.length === 0) {
10
8
  return null;
11
9
  }
12
- const isOnFreePlan = isFreePlan(planId);
13
- const daysNoun = trialDaysLeft === 1 ? "day" : "days";
14
- const ctaMessage = isOnFreePlan ? "Your team is currently on the Free plan" : `Free trial ends in ${trialDaysLeft} ${daysNoun}`;
15
- return /* @__PURE__ */ jsxs(
16
- MenuItem,
10
+ return /* @__PURE__ */ jsx(
11
+ "div",
17
12
  {
18
- "data-testid": "sidebar-upgrade-menu-item",
19
- href: upgradeOptionHref,
20
- className: `flex-col gap-1 items-start ${styles.container}`,
21
- children: [
22
- /* @__PURE__ */ jsx("span", { className: styles.planCta, children: ctaMessage }),
23
- /* @__PURE__ */ jsxs("div", { className: `flex-row items-center gap-1 ${styles.upgradeIconWrapper}`, children: [
24
- /* @__PURE__ */ jsx(UpgradeIcon, {}),
25
- /* @__PURE__ */ jsx("span", { children: "See upgrade options" })
26
- ] })
27
- ]
13
+ "data-testid": "sidebar-team-switch",
14
+ className: `flex-col items-stretch ${styles.teamsContainer}`,
15
+ children: otherTeams.map((team) => /* @__PURE__ */ jsx(TeamMenuItem, { team, onClick: onSwitchTeam, hidePlanLabel: true }, team.id))
28
16
  }
29
17
  );
30
18
  };
31
19
  export {
32
- UpgradeMenuItem
20
+ TeamSwitch
33
21
  };
34
22
  //# sourceMappingURL=harmony77.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony77.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/UpgradeMenuItem/UpgradeMenuItem.tsx"],"sourcesContent":["import { MenuItem } from '@lokalise/louis'\nimport { isFreePlan } from '@utils'\nimport { UpgradeIcon } from '../../../UpgradeIcon/UpgradeIcon'\nimport { useProfileMenu } from '../ProfileMenuContext'\nimport styles from './UpgradeMenuItem.module.css'\n\ntype UpgradeMenuItemProps = {\n\t/** URL to the upgrade page or pricing options */\n\tupgradeOptionHref: string\n}\n\n/**\n * A menu item component that displays upgrade call-to-action information.\n * Only renders when upgrade options should be shown (determined by context).\n *\n * The component displays different messages based on the team's current plan:\n * - For free plans: \"Your team is currently on the Free plan\"\n * - For trial plans: \"Free trial ends in X days\"\n *\n * Includes an upgrade icon and \"See upgrade options\" text, styled to draw attention\n * to the upgrade opportunity.\n *\n * @example\n * ```tsx\n * <UpgradeMenuItem upgradeOptionHref=\"/pricing\" />\n * ```\n *\n * @note This component must be used within a ProfileMenu component\n * as it requires access to the ProfileMenu context for plan information\n * and visibility control.\n */\nexport const UpgradeMenuItem = ({ upgradeOptionHref }: UpgradeMenuItemProps) => {\n\tconst { planId, trialDaysLeft, showUpgradeCta } = useProfileMenu()\n\n\tif (!showUpgradeCta) {\n\t\treturn null\n\t}\n\n\tconst isOnFreePlan = isFreePlan(planId)\n\n\tconst daysNoun = trialDaysLeft === 1 ? 'day' : 'days'\n\tconst ctaMessage = isOnFreePlan\n\t\t? 'Your team is currently on the Free plan'\n\t\t: `Free trial ends in ${trialDaysLeft} ${daysNoun}`\n\n\treturn (\n\t\t<MenuItem\n\t\t\tdata-testid=\"sidebar-upgrade-menu-item\"\n\t\t\thref={upgradeOptionHref}\n\t\t\tclassName={`flex-col gap-1 items-start ${styles.container}`}\n\t\t>\n\t\t\t<span className={styles.planCta}>{ctaMessage}</span>\n\t\t\t<div className={`flex-row items-center gap-1 ${styles.upgradeIconWrapper}`}>\n\t\t\t\t<UpgradeIcon />\n\t\t\t\t<span>See upgrade options</span>\n\t\t\t</div>\n\t\t</MenuItem>\n\t)\n}\n"],"names":[],"mappings":";;;;;;AA+BO,MAAM,kBAAkB,CAAC,EAAE,wBAA8C;AAC/E,QAAM,EAAE,QAAQ,eAAe,eAAA,IAAmB,eAAe;AAEjE,MAAI,CAAC,gBAAgB;AACb,WAAA;AAAA,EAAA;AAGF,QAAA,eAAe,WAAW,MAAM;AAEhC,QAAA,WAAW,kBAAkB,IAAI,QAAQ;AAC/C,QAAM,aAAa,eAChB,4CACA,sBAAsB,aAAa,IAAI,QAAQ;AAGjD,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,eAAY;AAAA,MACZ,MAAM;AAAA,MACN,WAAW,8BAA8B,OAAO,SAAS;AAAA,MAEzD,UAAA;AAAA,QAAA,oBAAC,QAAK,EAAA,WAAW,OAAO,SAAU,UAAW,YAAA;AAAA,6BAC5C,OAAI,EAAA,WAAW,+BAA+B,OAAO,kBAAkB,IACvE,UAAA;AAAA,UAAA,oBAAC,aAAY,EAAA;AAAA,UACb,oBAAC,UAAK,UAAmB,sBAAA,CAAA;AAAA,QAAA,EAC1B,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACD;AAEF;"}
1
+ {"version":3,"file":"harmony77.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/TeamSwitch/TeamSwitch.tsx"],"sourcesContent":["import type { SidebarTeam } from '../../../types'\nimport { useProfileMenu } from '../ProfileMenuContext'\nimport { TeamMenuItem } from '../TeamMenuItem/TeamMenuItem'\nimport styles from './TeamSwitch.module.css'\n\ntype TeamSwitchProps = {\n\t/** Callback function triggered when a user selects a different team */\n\tonSwitchTeam: (team: SidebarTeam) => void\n}\n\n/**\n * A component that displays a list of available teams for switching.\n * It automatically excludes the current team from the list and renders\n * nothing if there are no other teams available.\n *\n * Uses the ProfileMenu context to access the list of other teams and\n * renders each team as a TeamMenuItem with click functionality.\n *\n * @example\n * ```tsx\n * <TeamSwitch\n * onSwitchTeam={(team) => {\n * console.log(`Switching to team: ${team.name}`);\n * // Handle team switch logic\n * }}\n * />\n * ```\n *\n * @note This component must be used within a ProfileMenu component\n * as it requires access to the ProfileMenu context.\n */\nexport const TeamSwitch = ({ onSwitchTeam }: TeamSwitchProps) => {\n\tconst { otherTeams } = useProfileMenu()\n\n\tif (otherTeams.length === 0) {\n\t\treturn null\n\t}\n\n\treturn (\n\t\t<div\n\t\t\tdata-testid=\"sidebar-team-switch\"\n\t\t\tclassName={`flex-col items-stretch ${styles.teamsContainer}`}\n\t\t>\n\t\t\t{otherTeams.map((team) => (\n\t\t\t\t<TeamMenuItem team={team} key={team.id} onClick={onSwitchTeam} hidePlanLabel />\n\t\t\t))}\n\t\t</div>\n\t)\n}\n"],"names":[],"mappings":";;;;AA+BO,MAAM,aAAa,CAAC,EAAE,mBAAoC;AAC1D,QAAA,EAAE,WAAW,IAAI,eAAe;AAElC,MAAA,WAAW,WAAW,GAAG;AACrB,WAAA;AAAA,EAAA;AAIP,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,eAAY;AAAA,MACZ,WAAW,0BAA0B,OAAO,cAAc;AAAA,MAEzD,UAAW,WAAA,IAAI,CAAC,SACf,oBAAA,cAAA,EAAa,MAA0B,SAAS,cAAc,eAAa,KAA7C,GAAA,KAAK,EAAyC,CAC7E;AAAA,IAAA;AAAA,EACF;AAEF;"}
@@ -1,62 +1,34 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
- const floatingUi_core = require("./harmony104.cjs");
5
4
  const louis = require("@lokalise/louis");
6
- const useEffectOnce = require("./harmony12.cjs");
7
- const clsx = require("./harmony66.cjs");
8
- const React = require("react");
9
- const Tasks_module = require("./harmony105.cjs");
10
- const TasksContext = require("./harmony106.cjs");
11
- const TasksPopover = require("./harmony107.cjs");
12
- const TasksProvider = require("./harmony108.cjs");
13
- const taskEvents = require("./harmony109.cjs");
14
- const Tasks = TasksProvider.withTasksContext(() => {
15
- const [open, setOpen] = React.useState(false);
16
- const { tasksCount } = TasksContext.useTasks();
17
- useEffectOnce.useEffectOnce(() => {
18
- const showDialog = () => {
19
- setOpen(true);
20
- };
21
- document.addEventListener(taskEvents.TaskEvents.ShowDialog, showDialog);
22
- return () => {
23
- document.removeEventListener(taskEvents.TaskEvents.ShowDialog, showDialog);
24
- };
25
- });
26
- return /* @__PURE__ */ jsxRuntime.jsx(louis.Tooltip, { tooltip: "Tasks", placement: "right", children: /* @__PURE__ */ jsxRuntime.jsx(
27
- louis.Popover,
5
+ const plan = require("./harmony8.cjs");
6
+ const UpgradeIcon = require("./harmony94.cjs");
7
+ const ProfileMenuContext = require("./harmony90.cjs");
8
+ const UpgradeMenuItem_module = require("./harmony95.cjs");
9
+ const UpgradeMenuItem = ({ upgradeOptionHref }) => {
10
+ const { planId, trialDaysLeft, showUpgradeCta } = ProfileMenuContext.useProfileMenu();
11
+ if (!showUpgradeCta) {
12
+ return null;
13
+ }
14
+ const isOnFreePlan = plan.isFreePlan(planId);
15
+ const daysNoun = trialDaysLeft === 1 ? "day" : "days";
16
+ const ctaMessage = isOnFreePlan ? "Your team is currently on the Free plan" : `Free trial ends in ${trialDaysLeft} ${daysNoun}`;
17
+ return /* @__PURE__ */ jsxRuntime.jsxs(
18
+ louis.MenuItem,
28
19
  {
29
- content: /* @__PURE__ */ jsxRuntime.jsx(TasksPopover.TasksPopover, {}),
30
- placement: "right",
31
- open,
32
- onOpenChange: setOpen,
33
- middlewares: [
34
- floatingUi_core.shift({
35
- // Adding some spacing to the top and bottom so the popover
36
- // doesn't extend to the edges of the screen.
37
- padding: {
38
- top: 32,
39
- bottom: 32
40
- }
41
- })
42
- ],
43
- children: (visible) => /* @__PURE__ */ jsxRuntime.jsxs(
44
- louis.Button,
45
- {
46
- type: "button",
47
- "data-testid": "sidebar-tasks-widget-button",
48
- "aria-label": "Tasks",
49
- className: clsx.clsx(Tasks_module.default.navItem, {
50
- [Tasks_module.default.activeNavItem]: visible
51
- }),
52
- children: [
53
- /* @__PURE__ */ jsxRuntime.jsx(louis.JobIcon, { size: "25px" }),
54
- tasksCount > 0 && /* @__PURE__ */ jsxRuntime.jsx("div", { className: Tasks_module.default.badge, "aria-label": `${tasksCount} items requiring attention`, children: tasksCount > 9 ? "9+" : tasksCount })
55
- ]
56
- }
57
- )
20
+ "data-testid": "sidebar-upgrade-menu-item",
21
+ href: upgradeOptionHref,
22
+ className: `flex-col gap-1 items-start ${UpgradeMenuItem_module.default.container}`,
23
+ children: [
24
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: UpgradeMenuItem_module.default.planCta, children: ctaMessage }),
25
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `flex-row items-center gap-1 ${UpgradeMenuItem_module.default.upgradeIconWrapper}`, children: [
26
+ /* @__PURE__ */ jsxRuntime.jsx(UpgradeIcon.UpgradeIcon, {}),
27
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: "See upgrade options" })
28
+ ] })
29
+ ]
58
30
  }
59
- ) });
60
- });
61
- exports.Tasks = Tasks;
31
+ );
32
+ };
33
+ exports.UpgradeMenuItem = UpgradeMenuItem;
62
34
  //# sourceMappingURL=harmony78.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony78.cjs","sources":["../src/components/Sidebar/Widgets/Tasks/Tasks.tsx"],"sourcesContent":["import { shift } from '@floating-ui/core'\nimport { Button, JobIcon, Popover, Tooltip } from '@lokalise/louis'\nimport { useEffectOnce } from '@utils'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport styles from './Tasks.module.css'\nimport { useTasks } from './TasksContext'\nimport { TasksPopover } from './TasksPopover/TasksPopover'\nimport { withTasksContext } from './TasksProvider'\nimport { TaskEvents } from './utils/taskEvents'\n\nexport const Tasks = withTasksContext(() => {\n\tconst [open, setOpen] = useState(false)\n\n\tconst { tasksCount } = useTasks()\n\n\tuseEffectOnce(() => {\n\t\tconst showDialog = () => {\n\t\t\tsetOpen(true)\n\t\t}\n\n\t\tdocument.addEventListener(TaskEvents.ShowDialog, showDialog)\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(TaskEvents.ShowDialog, showDialog)\n\t\t}\n\t})\n\n\treturn (\n\t\t<Tooltip tooltip=\"Tasks\" placement=\"right\">\n\t\t\t<Popover\n\t\t\t\tcontent={<TasksPopover />}\n\t\t\t\tplacement=\"right\"\n\t\t\t\topen={open}\n\t\t\t\tonOpenChange={setOpen}\n\t\t\t\tmiddlewares={[\n\t\t\t\t\tshift({\n\t\t\t\t\t\t// Adding some spacing to the top and bottom so the popover\n\t\t\t\t\t\t// doesn't extend to the edges of the screen.\n\t\t\t\t\t\tpadding: {\n\t\t\t\t\t\t\ttop: 32,\n\t\t\t\t\t\t\tbottom: 32,\n\t\t\t\t\t\t},\n\t\t\t\t\t}),\n\t\t\t\t]}\n\t\t\t>\n\t\t\t\t{(visible) => (\n\t\t\t\t\t<Button\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\tdata-testid=\"sidebar-tasks-widget-button\"\n\t\t\t\t\t\taria-label=\"Tasks\"\n\t\t\t\t\t\tclassName={clsx(styles.navItem, {\n\t\t\t\t\t\t\t[styles.activeNavItem]: visible,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t<JobIcon size=\"25px\" />\n\t\t\t\t\t\t{tasksCount > 0 && (\n\t\t\t\t\t\t\t<div className={styles.badge} aria-label={`${tasksCount} items requiring attention`}>\n\t\t\t\t\t\t\t\t{tasksCount > 9 ? '9+' : tasksCount}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Button>\n\t\t\t\t)}\n\t\t\t</Popover>\n\t\t</Tooltip>\n\t)\n})\n"],"names":["withTasksContext","useState","useTasks","useEffectOnce","TaskEvents","jsx","Tooltip","Popover","TasksPopover","shift","jsxs","Button","clsx","styles","JobIcon"],"mappings":";;;;;;;;;;;;;AAWa,MAAA,QAAQA,+BAAiB,MAAM;AAC3C,QAAM,CAAC,MAAM,OAAO,IAAIC,MAAAA,SAAS,KAAK;AAEhC,QAAA,EAAE,WAAW,IAAIC,sBAAS;AAEhCC,gBAAAA,cAAc,MAAM;AACnB,UAAM,aAAa,MAAM;AACxB,cAAQ,IAAI;AAAA,IACb;AAES,aAAA,iBAAiBC,sBAAW,YAAY,UAAU;AAE3D,WAAO,MAAM;AACH,eAAA,oBAAoBA,sBAAW,YAAY,UAAU;AAAA,IAC/D;AAAA,EAAA,CACA;AAED,SACEC,2BAAA,IAAAC,MAAA,SAAA,EAAQ,SAAQ,SAAQ,WAAU,SAClC,UAAAD,2BAAA;AAAA,IAACE,MAAA;AAAA,IAAA;AAAA,MACA,wCAAUC,aAAa,cAAA,EAAA;AAAA,MACvB,WAAU;AAAA,MACV;AAAA,MACA,cAAc;AAAA,MACd,aAAa;AAAA,QACZC,sBAAM;AAAA;AAAA;AAAA,UAGL,SAAS;AAAA,YACR,KAAK;AAAA,YACL,QAAQ;AAAA,UAAA;AAAA,QAET,CAAA;AAAA,MACF;AAAA,MAEC,WAAC,YACDC,2BAAA;AAAA,QAACC,MAAA;AAAA,QAAA;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UACZ,cAAW;AAAA,UACX,WAAWC,KAAAA,KAAKC,aAAA,QAAO,SAAS;AAAA,YAC/B,CAACA,aAAAA,QAAO,aAAa,GAAG;AAAA,UAAA,CACxB;AAAA,UAED,UAAA;AAAA,YAACR,2BAAAA,IAAAS,MAAA,SAAA,EAAQ,MAAK,OAAO,CAAA;AAAA,YACpB,aAAa,KACZT,+BAAA,OAAA,EAAI,WAAWQ,aAAO,QAAA,OAAO,cAAY,GAAG,UAAU,8BACrD,UAAa,aAAA,IAAI,OAAO,WAC1B,CAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IAEF;AAAA,EAAA,GAGH;AAEF,CAAC;;"}
1
+ {"version":3,"file":"harmony78.cjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/UpgradeMenuItem/UpgradeMenuItem.tsx"],"sourcesContent":["import { MenuItem } from '@lokalise/louis'\nimport { isFreePlan } from '@utils'\nimport { UpgradeIcon } from '../../../UpgradeIcon/UpgradeIcon'\nimport { useProfileMenu } from '../ProfileMenuContext'\nimport styles from './UpgradeMenuItem.module.css'\n\ntype UpgradeMenuItemProps = {\n\t/** URL to the upgrade page or pricing options */\n\tupgradeOptionHref: string\n}\n\n/**\n * A menu item component that displays upgrade call-to-action information.\n * Only renders when upgrade options should be shown (determined by context).\n *\n * The component displays different messages based on the team's current plan:\n * - For free plans: \"Your team is currently on the Free plan\"\n * - For trial plans: \"Free trial ends in X days\"\n *\n * Includes an upgrade icon and \"See upgrade options\" text, styled to draw attention\n * to the upgrade opportunity.\n *\n * @example\n * ```tsx\n * <UpgradeMenuItem upgradeOptionHref=\"/pricing\" />\n * ```\n *\n * @note This component must be used within a ProfileMenu component\n * as it requires access to the ProfileMenu context for plan information\n * and visibility control.\n */\nexport const UpgradeMenuItem = ({ upgradeOptionHref }: UpgradeMenuItemProps) => {\n\tconst { planId, trialDaysLeft, showUpgradeCta } = useProfileMenu()\n\n\tif (!showUpgradeCta) {\n\t\treturn null\n\t}\n\n\tconst isOnFreePlan = isFreePlan(planId)\n\n\tconst daysNoun = trialDaysLeft === 1 ? 'day' : 'days'\n\tconst ctaMessage = isOnFreePlan\n\t\t? 'Your team is currently on the Free plan'\n\t\t: `Free trial ends in ${trialDaysLeft} ${daysNoun}`\n\n\treturn (\n\t\t<MenuItem\n\t\t\tdata-testid=\"sidebar-upgrade-menu-item\"\n\t\t\thref={upgradeOptionHref}\n\t\t\tclassName={`flex-col gap-1 items-start ${styles.container}`}\n\t\t>\n\t\t\t<span className={styles.planCta}>{ctaMessage}</span>\n\t\t\t<div className={`flex-row items-center gap-1 ${styles.upgradeIconWrapper}`}>\n\t\t\t\t<UpgradeIcon />\n\t\t\t\t<span>See upgrade options</span>\n\t\t\t</div>\n\t\t</MenuItem>\n\t)\n}\n"],"names":["useProfileMenu","isFreePlan","jsxs","MenuItem","styles","jsx","UpgradeIcon"],"mappings":";;;;;;;;AA+BO,MAAM,kBAAkB,CAAC,EAAE,wBAA8C;AAC/E,QAAM,EAAE,QAAQ,eAAe,eAAA,IAAmBA,mBAAAA,eAAe;AAEjE,MAAI,CAAC,gBAAgB;AACb,WAAA;AAAA,EAAA;AAGF,QAAA,eAAeC,gBAAW,MAAM;AAEhC,QAAA,WAAW,kBAAkB,IAAI,QAAQ;AAC/C,QAAM,aAAa,eAChB,4CACA,sBAAsB,aAAa,IAAI,QAAQ;AAGjD,SAAAC,2BAAA;AAAA,IAACC,MAAA;AAAA,IAAA;AAAA,MACA,eAAY;AAAA,MACZ,MAAM;AAAA,MACN,WAAW,8BAA8BC,uBAAA,QAAO,SAAS;AAAA,MAEzD,UAAA;AAAA,QAAAC,2BAAA,IAAC,QAAK,EAAA,WAAWD,uBAAO,QAAA,SAAU,UAAW,YAAA;AAAA,wCAC5C,OAAI,EAAA,WAAW,+BAA+BA,+BAAO,kBAAkB,IACvE,UAAA;AAAA,UAAAC,2BAAA,IAACC,YAAY,aAAA,EAAA;AAAA,UACbD,2BAAAA,IAAC,UAAK,UAAmB,sBAAA,CAAA;AAAA,QAAA,EAC1B,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACD;AAEF;;"}
@@ -1,62 +1,34 @@
1
- import { jsx, jsxs } from "react/jsx-runtime";
2
- import { shift } from "./harmony104.mjs";
3
- import { Tooltip, Popover, Button, JobIcon } from "@lokalise/louis";
4
- import { useEffectOnce } from "./harmony12.mjs";
5
- import { clsx } from "./harmony66.mjs";
6
- import { useState } from "react";
7
- import styles from "./harmony105.mjs";
8
- import { useTasks } from "./harmony106.mjs";
9
- import { TasksPopover } from "./harmony107.mjs";
10
- import { withTasksContext } from "./harmony108.mjs";
11
- import { TaskEvents } from "./harmony109.mjs";
12
- const Tasks = withTasksContext(() => {
13
- const [open, setOpen] = useState(false);
14
- const { tasksCount } = useTasks();
15
- useEffectOnce(() => {
16
- const showDialog = () => {
17
- setOpen(true);
18
- };
19
- document.addEventListener(TaskEvents.ShowDialog, showDialog);
20
- return () => {
21
- document.removeEventListener(TaskEvents.ShowDialog, showDialog);
22
- };
23
- });
24
- return /* @__PURE__ */ jsx(Tooltip, { tooltip: "Tasks", placement: "right", children: /* @__PURE__ */ jsx(
25
- Popover,
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { MenuItem } from "@lokalise/louis";
3
+ import { isFreePlan } from "./harmony8.mjs";
4
+ import { UpgradeIcon } from "./harmony94.mjs";
5
+ import { useProfileMenu } from "./harmony90.mjs";
6
+ import styles from "./harmony95.mjs";
7
+ const UpgradeMenuItem = ({ upgradeOptionHref }) => {
8
+ const { planId, trialDaysLeft, showUpgradeCta } = useProfileMenu();
9
+ if (!showUpgradeCta) {
10
+ return null;
11
+ }
12
+ const isOnFreePlan = isFreePlan(planId);
13
+ const daysNoun = trialDaysLeft === 1 ? "day" : "days";
14
+ const ctaMessage = isOnFreePlan ? "Your team is currently on the Free plan" : `Free trial ends in ${trialDaysLeft} ${daysNoun}`;
15
+ return /* @__PURE__ */ jsxs(
16
+ MenuItem,
26
17
  {
27
- content: /* @__PURE__ */ jsx(TasksPopover, {}),
28
- placement: "right",
29
- open,
30
- onOpenChange: setOpen,
31
- middlewares: [
32
- shift({
33
- // Adding some spacing to the top and bottom so the popover
34
- // doesn't extend to the edges of the screen.
35
- padding: {
36
- top: 32,
37
- bottom: 32
38
- }
39
- })
40
- ],
41
- children: (visible) => /* @__PURE__ */ jsxs(
42
- Button,
43
- {
44
- type: "button",
45
- "data-testid": "sidebar-tasks-widget-button",
46
- "aria-label": "Tasks",
47
- className: clsx(styles.navItem, {
48
- [styles.activeNavItem]: visible
49
- }),
50
- children: [
51
- /* @__PURE__ */ jsx(JobIcon, { size: "25px" }),
52
- tasksCount > 0 && /* @__PURE__ */ jsx("div", { className: styles.badge, "aria-label": `${tasksCount} items requiring attention`, children: tasksCount > 9 ? "9+" : tasksCount })
53
- ]
54
- }
55
- )
18
+ "data-testid": "sidebar-upgrade-menu-item",
19
+ href: upgradeOptionHref,
20
+ className: `flex-col gap-1 items-start ${styles.container}`,
21
+ children: [
22
+ /* @__PURE__ */ jsx("span", { className: styles.planCta, children: ctaMessage }),
23
+ /* @__PURE__ */ jsxs("div", { className: `flex-row items-center gap-1 ${styles.upgradeIconWrapper}`, children: [
24
+ /* @__PURE__ */ jsx(UpgradeIcon, {}),
25
+ /* @__PURE__ */ jsx("span", { children: "See upgrade options" })
26
+ ] })
27
+ ]
56
28
  }
57
- ) });
58
- });
29
+ );
30
+ };
59
31
  export {
60
- Tasks
32
+ UpgradeMenuItem
61
33
  };
62
34
  //# sourceMappingURL=harmony78.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony78.mjs","sources":["../src/components/Sidebar/Widgets/Tasks/Tasks.tsx"],"sourcesContent":["import { shift } from '@floating-ui/core'\nimport { Button, JobIcon, Popover, Tooltip } from '@lokalise/louis'\nimport { useEffectOnce } from '@utils'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport styles from './Tasks.module.css'\nimport { useTasks } from './TasksContext'\nimport { TasksPopover } from './TasksPopover/TasksPopover'\nimport { withTasksContext } from './TasksProvider'\nimport { TaskEvents } from './utils/taskEvents'\n\nexport const Tasks = withTasksContext(() => {\n\tconst [open, setOpen] = useState(false)\n\n\tconst { tasksCount } = useTasks()\n\n\tuseEffectOnce(() => {\n\t\tconst showDialog = () => {\n\t\t\tsetOpen(true)\n\t\t}\n\n\t\tdocument.addEventListener(TaskEvents.ShowDialog, showDialog)\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(TaskEvents.ShowDialog, showDialog)\n\t\t}\n\t})\n\n\treturn (\n\t\t<Tooltip tooltip=\"Tasks\" placement=\"right\">\n\t\t\t<Popover\n\t\t\t\tcontent={<TasksPopover />}\n\t\t\t\tplacement=\"right\"\n\t\t\t\topen={open}\n\t\t\t\tonOpenChange={setOpen}\n\t\t\t\tmiddlewares={[\n\t\t\t\t\tshift({\n\t\t\t\t\t\t// Adding some spacing to the top and bottom so the popover\n\t\t\t\t\t\t// doesn't extend to the edges of the screen.\n\t\t\t\t\t\tpadding: {\n\t\t\t\t\t\t\ttop: 32,\n\t\t\t\t\t\t\tbottom: 32,\n\t\t\t\t\t\t},\n\t\t\t\t\t}),\n\t\t\t\t]}\n\t\t\t>\n\t\t\t\t{(visible) => (\n\t\t\t\t\t<Button\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\tdata-testid=\"sidebar-tasks-widget-button\"\n\t\t\t\t\t\taria-label=\"Tasks\"\n\t\t\t\t\t\tclassName={clsx(styles.navItem, {\n\t\t\t\t\t\t\t[styles.activeNavItem]: visible,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t<JobIcon size=\"25px\" />\n\t\t\t\t\t\t{tasksCount > 0 && (\n\t\t\t\t\t\t\t<div className={styles.badge} aria-label={`${tasksCount} items requiring attention`}>\n\t\t\t\t\t\t\t\t{tasksCount > 9 ? '9+' : tasksCount}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Button>\n\t\t\t\t)}\n\t\t\t</Popover>\n\t\t</Tooltip>\n\t)\n})\n"],"names":[],"mappings":";;;;;;;;;;;AAWa,MAAA,QAAQ,iBAAiB,MAAM;AAC3C,QAAM,CAAC,MAAM,OAAO,IAAI,SAAS,KAAK;AAEhC,QAAA,EAAE,WAAW,IAAI,SAAS;AAEhC,gBAAc,MAAM;AACnB,UAAM,aAAa,MAAM;AACxB,cAAQ,IAAI;AAAA,IACb;AAES,aAAA,iBAAiB,WAAW,YAAY,UAAU;AAE3D,WAAO,MAAM;AACH,eAAA,oBAAoB,WAAW,YAAY,UAAU;AAAA,IAC/D;AAAA,EAAA,CACA;AAED,SACE,oBAAA,SAAA,EAAQ,SAAQ,SAAQ,WAAU,SAClC,UAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,6BAAU,cAAa,EAAA;AAAA,MACvB,WAAU;AAAA,MACV;AAAA,MACA,cAAc;AAAA,MACd,aAAa;AAAA,QACZ,MAAM;AAAA;AAAA;AAAA,UAGL,SAAS;AAAA,YACR,KAAK;AAAA,YACL,QAAQ;AAAA,UAAA;AAAA,QAET,CAAA;AAAA,MACF;AAAA,MAEC,WAAC,YACD;AAAA,QAAC;AAAA,QAAA;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UACZ,cAAW;AAAA,UACX,WAAW,KAAK,OAAO,SAAS;AAAA,YAC/B,CAAC,OAAO,aAAa,GAAG;AAAA,UAAA,CACxB;AAAA,UAED,UAAA;AAAA,YAAC,oBAAA,SAAA,EAAQ,MAAK,OAAO,CAAA;AAAA,YACpB,aAAa,KACZ,oBAAA,OAAA,EAAI,WAAW,OAAO,OAAO,cAAY,GAAG,UAAU,8BACrD,UAAa,aAAA,IAAI,OAAO,WAC1B,CAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IAEF;AAAA,EAAA,GAGH;AAEF,CAAC;"}
1
+ {"version":3,"file":"harmony78.mjs","sources":["../src/components/Sidebar/Widgets/ProfileMenu/UpgradeMenuItem/UpgradeMenuItem.tsx"],"sourcesContent":["import { MenuItem } from '@lokalise/louis'\nimport { isFreePlan } from '@utils'\nimport { UpgradeIcon } from '../../../UpgradeIcon/UpgradeIcon'\nimport { useProfileMenu } from '../ProfileMenuContext'\nimport styles from './UpgradeMenuItem.module.css'\n\ntype UpgradeMenuItemProps = {\n\t/** URL to the upgrade page or pricing options */\n\tupgradeOptionHref: string\n}\n\n/**\n * A menu item component that displays upgrade call-to-action information.\n * Only renders when upgrade options should be shown (determined by context).\n *\n * The component displays different messages based on the team's current plan:\n * - For free plans: \"Your team is currently on the Free plan\"\n * - For trial plans: \"Free trial ends in X days\"\n *\n * Includes an upgrade icon and \"See upgrade options\" text, styled to draw attention\n * to the upgrade opportunity.\n *\n * @example\n * ```tsx\n * <UpgradeMenuItem upgradeOptionHref=\"/pricing\" />\n * ```\n *\n * @note This component must be used within a ProfileMenu component\n * as it requires access to the ProfileMenu context for plan information\n * and visibility control.\n */\nexport const UpgradeMenuItem = ({ upgradeOptionHref }: UpgradeMenuItemProps) => {\n\tconst { planId, trialDaysLeft, showUpgradeCta } = useProfileMenu()\n\n\tif (!showUpgradeCta) {\n\t\treturn null\n\t}\n\n\tconst isOnFreePlan = isFreePlan(planId)\n\n\tconst daysNoun = trialDaysLeft === 1 ? 'day' : 'days'\n\tconst ctaMessage = isOnFreePlan\n\t\t? 'Your team is currently on the Free plan'\n\t\t: `Free trial ends in ${trialDaysLeft} ${daysNoun}`\n\n\treturn (\n\t\t<MenuItem\n\t\t\tdata-testid=\"sidebar-upgrade-menu-item\"\n\t\t\thref={upgradeOptionHref}\n\t\t\tclassName={`flex-col gap-1 items-start ${styles.container}`}\n\t\t>\n\t\t\t<span className={styles.planCta}>{ctaMessage}</span>\n\t\t\t<div className={`flex-row items-center gap-1 ${styles.upgradeIconWrapper}`}>\n\t\t\t\t<UpgradeIcon />\n\t\t\t\t<span>See upgrade options</span>\n\t\t\t</div>\n\t\t</MenuItem>\n\t)\n}\n"],"names":[],"mappings":";;;;;;AA+BO,MAAM,kBAAkB,CAAC,EAAE,wBAA8C;AAC/E,QAAM,EAAE,QAAQ,eAAe,eAAA,IAAmB,eAAe;AAEjE,MAAI,CAAC,gBAAgB;AACb,WAAA;AAAA,EAAA;AAGF,QAAA,eAAe,WAAW,MAAM;AAEhC,QAAA,WAAW,kBAAkB,IAAI,QAAQ;AAC/C,QAAM,aAAa,eAChB,4CACA,sBAAsB,aAAa,IAAI,QAAQ;AAGjD,SAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,eAAY;AAAA,MACZ,MAAM;AAAA,MACN,WAAW,8BAA8B,OAAO,SAAS;AAAA,MAEzD,UAAA;AAAA,QAAA,oBAAC,QAAK,EAAA,WAAW,OAAO,SAAU,UAAW,YAAA;AAAA,6BAC5C,OAAI,EAAA,WAAW,+BAA+B,OAAO,kBAAkB,IACvE,UAAA;AAAA,UAAA,oBAAC,aAAY,EAAA;AAAA,UACb,oBAAC,UAAK,UAAmB,sBAAA,CAAA;AAAA,QAAA,EAC1B,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACD;AAEF;"}
@@ -1,12 +1,62 @@
1
1
  "use strict";
2
- Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const breadcrumbsItem = "_breadcrumbsItem_1hm6a_1";
4
- const breadcrumbs = "_breadcrumbs_1hm6a_1";
5
- const classes = {
6
- breadcrumbsItem,
7
- breadcrumbs
8
- };
9
- exports.breadcrumbs = breadcrumbs;
10
- exports.breadcrumbsItem = breadcrumbsItem;
11
- exports.default = classes;
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const floatingUi_core = require("./harmony102.cjs");
5
+ const louis = require("@lokalise/louis");
6
+ const useEffectOnce = require("./harmony12.cjs");
7
+ const clsx = require("./harmony67.cjs");
8
+ const React = require("react");
9
+ const Tasks_module = require("./harmony103.cjs");
10
+ const TasksContext = require("./harmony104.cjs");
11
+ const TasksPopover = require("./harmony105.cjs");
12
+ const TasksProvider = require("./harmony106.cjs");
13
+ const taskEvents = require("./harmony107.cjs");
14
+ const Tasks = TasksProvider.withTasksContext(() => {
15
+ const [open, setOpen] = React.useState(false);
16
+ const { tasksCount } = TasksContext.useTasks();
17
+ useEffectOnce.useEffectOnce(() => {
18
+ const showDialog = () => {
19
+ setOpen(true);
20
+ };
21
+ document.addEventListener(taskEvents.TaskEvents.ShowDialog, showDialog);
22
+ return () => {
23
+ document.removeEventListener(taskEvents.TaskEvents.ShowDialog, showDialog);
24
+ };
25
+ });
26
+ return /* @__PURE__ */ jsxRuntime.jsx(louis.Tooltip, { tooltip: "Tasks", placement: "right", children: /* @__PURE__ */ jsxRuntime.jsx(
27
+ louis.Popover,
28
+ {
29
+ content: /* @__PURE__ */ jsxRuntime.jsx(TasksPopover.TasksPopover, {}),
30
+ placement: "right",
31
+ open,
32
+ onOpenChange: setOpen,
33
+ middlewares: [
34
+ floatingUi_core.shift({
35
+ // Adding some spacing to the top and bottom so the popover
36
+ // doesn't extend to the edges of the screen.
37
+ padding: {
38
+ top: 32,
39
+ bottom: 32
40
+ }
41
+ })
42
+ ],
43
+ children: (visible) => /* @__PURE__ */ jsxRuntime.jsxs(
44
+ louis.Button,
45
+ {
46
+ type: "button",
47
+ "data-testid": "sidebar-tasks-widget-button",
48
+ "aria-label": "Tasks",
49
+ className: clsx.clsx(Tasks_module.default.navItem, {
50
+ [Tasks_module.default.activeNavItem]: visible
51
+ }),
52
+ children: [
53
+ /* @__PURE__ */ jsxRuntime.jsx(louis.JobIcon, { size: "25px" }),
54
+ tasksCount > 0 && /* @__PURE__ */ jsxRuntime.jsx("div", { className: Tasks_module.default.badge, "aria-label": `${tasksCount} items requiring attention`, children: tasksCount > 9 ? "9+" : tasksCount })
55
+ ]
56
+ }
57
+ )
58
+ }
59
+ ) });
60
+ });
61
+ exports.Tasks = Tasks;
12
62
  //# sourceMappingURL=harmony79.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony79.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;"}
1
+ {"version":3,"file":"harmony79.cjs","sources":["../src/components/Sidebar/Widgets/Tasks/Tasks.tsx"],"sourcesContent":["import { shift } from '@floating-ui/core'\nimport { Button, JobIcon, Popover, Tooltip } from '@lokalise/louis'\nimport { useEffectOnce } from '@utils'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport styles from './Tasks.module.css'\nimport { useTasks } from './TasksContext'\nimport { TasksPopover } from './TasksPopover/TasksPopover'\nimport { withTasksContext } from './TasksProvider'\nimport { TaskEvents } from './utils/taskEvents'\n\nexport const Tasks = withTasksContext(() => {\n\tconst [open, setOpen] = useState(false)\n\n\tconst { tasksCount } = useTasks()\n\n\tuseEffectOnce(() => {\n\t\tconst showDialog = () => {\n\t\t\tsetOpen(true)\n\t\t}\n\n\t\tdocument.addEventListener(TaskEvents.ShowDialog, showDialog)\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(TaskEvents.ShowDialog, showDialog)\n\t\t}\n\t})\n\n\treturn (\n\t\t<Tooltip tooltip=\"Tasks\" placement=\"right\">\n\t\t\t<Popover\n\t\t\t\tcontent={<TasksPopover />}\n\t\t\t\tplacement=\"right\"\n\t\t\t\topen={open}\n\t\t\t\tonOpenChange={setOpen}\n\t\t\t\tmiddlewares={[\n\t\t\t\t\tshift({\n\t\t\t\t\t\t// Adding some spacing to the top and bottom so the popover\n\t\t\t\t\t\t// doesn't extend to the edges of the screen.\n\t\t\t\t\t\tpadding: {\n\t\t\t\t\t\t\ttop: 32,\n\t\t\t\t\t\t\tbottom: 32,\n\t\t\t\t\t\t},\n\t\t\t\t\t}),\n\t\t\t\t]}\n\t\t\t>\n\t\t\t\t{(visible) => (\n\t\t\t\t\t<Button\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\tdata-testid=\"sidebar-tasks-widget-button\"\n\t\t\t\t\t\taria-label=\"Tasks\"\n\t\t\t\t\t\tclassName={clsx(styles.navItem, {\n\t\t\t\t\t\t\t[styles.activeNavItem]: visible,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t<JobIcon size=\"25px\" />\n\t\t\t\t\t\t{tasksCount > 0 && (\n\t\t\t\t\t\t\t<div className={styles.badge} aria-label={`${tasksCount} items requiring attention`}>\n\t\t\t\t\t\t\t\t{tasksCount > 9 ? '9+' : tasksCount}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Button>\n\t\t\t\t)}\n\t\t\t</Popover>\n\t\t</Tooltip>\n\t)\n})\n"],"names":["withTasksContext","useState","useTasks","useEffectOnce","TaskEvents","jsx","Tooltip","Popover","TasksPopover","shift","jsxs","Button","clsx","styles","JobIcon"],"mappings":";;;;;;;;;;;;;AAWa,MAAA,QAAQA,+BAAiB,MAAM;AAC3C,QAAM,CAAC,MAAM,OAAO,IAAIC,MAAAA,SAAS,KAAK;AAEhC,QAAA,EAAE,WAAW,IAAIC,sBAAS;AAEhCC,gBAAAA,cAAc,MAAM;AACnB,UAAM,aAAa,MAAM;AACxB,cAAQ,IAAI;AAAA,IACb;AAES,aAAA,iBAAiBC,sBAAW,YAAY,UAAU;AAE3D,WAAO,MAAM;AACH,eAAA,oBAAoBA,sBAAW,YAAY,UAAU;AAAA,IAC/D;AAAA,EAAA,CACA;AAED,SACEC,2BAAA,IAAAC,MAAA,SAAA,EAAQ,SAAQ,SAAQ,WAAU,SAClC,UAAAD,2BAAA;AAAA,IAACE,MAAA;AAAA,IAAA;AAAA,MACA,wCAAUC,aAAa,cAAA,EAAA;AAAA,MACvB,WAAU;AAAA,MACV;AAAA,MACA,cAAc;AAAA,MACd,aAAa;AAAA,QACZC,sBAAM;AAAA;AAAA;AAAA,UAGL,SAAS;AAAA,YACR,KAAK;AAAA,YACL,QAAQ;AAAA,UAAA;AAAA,QAET,CAAA;AAAA,MACF;AAAA,MAEC,WAAC,YACDC,2BAAA;AAAA,QAACC,MAAA;AAAA,QAAA;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UACZ,cAAW;AAAA,UACX,WAAWC,KAAAA,KAAKC,aAAA,QAAO,SAAS;AAAA,YAC/B,CAACA,aAAAA,QAAO,aAAa,GAAG;AAAA,UAAA,CACxB;AAAA,UAED,UAAA;AAAA,YAACR,2BAAAA,IAAAS,MAAA,SAAA,EAAQ,MAAK,OAAO,CAAA;AAAA,YACpB,aAAa,KACZT,+BAAA,OAAA,EAAI,WAAWQ,aAAO,QAAA,OAAO,cAAY,GAAG,UAAU,8BACrD,UAAa,aAAA,IAAI,OAAO,WAC1B,CAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IAEF;AAAA,EAAA,GAGH;AAEF,CAAC;;"}
@@ -1,12 +1,62 @@
1
- const breadcrumbsItem = "_breadcrumbsItem_1hm6a_1";
2
- const breadcrumbs = "_breadcrumbs_1hm6a_1";
3
- const classes = {
4
- breadcrumbsItem,
5
- breadcrumbs
6
- };
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { shift } from "./harmony102.mjs";
3
+ import { Tooltip, Popover, Button, JobIcon } from "@lokalise/louis";
4
+ import { useEffectOnce } from "./harmony12.mjs";
5
+ import { clsx } from "./harmony67.mjs";
6
+ import { useState } from "react";
7
+ import styles from "./harmony103.mjs";
8
+ import { useTasks } from "./harmony104.mjs";
9
+ import { TasksPopover } from "./harmony105.mjs";
10
+ import { withTasksContext } from "./harmony106.mjs";
11
+ import { TaskEvents } from "./harmony107.mjs";
12
+ const Tasks = withTasksContext(() => {
13
+ const [open, setOpen] = useState(false);
14
+ const { tasksCount } = useTasks();
15
+ useEffectOnce(() => {
16
+ const showDialog = () => {
17
+ setOpen(true);
18
+ };
19
+ document.addEventListener(TaskEvents.ShowDialog, showDialog);
20
+ return () => {
21
+ document.removeEventListener(TaskEvents.ShowDialog, showDialog);
22
+ };
23
+ });
24
+ return /* @__PURE__ */ jsx(Tooltip, { tooltip: "Tasks", placement: "right", children: /* @__PURE__ */ jsx(
25
+ Popover,
26
+ {
27
+ content: /* @__PURE__ */ jsx(TasksPopover, {}),
28
+ placement: "right",
29
+ open,
30
+ onOpenChange: setOpen,
31
+ middlewares: [
32
+ shift({
33
+ // Adding some spacing to the top and bottom so the popover
34
+ // doesn't extend to the edges of the screen.
35
+ padding: {
36
+ top: 32,
37
+ bottom: 32
38
+ }
39
+ })
40
+ ],
41
+ children: (visible) => /* @__PURE__ */ jsxs(
42
+ Button,
43
+ {
44
+ type: "button",
45
+ "data-testid": "sidebar-tasks-widget-button",
46
+ "aria-label": "Tasks",
47
+ className: clsx(styles.navItem, {
48
+ [styles.activeNavItem]: visible
49
+ }),
50
+ children: [
51
+ /* @__PURE__ */ jsx(JobIcon, { size: "25px" }),
52
+ tasksCount > 0 && /* @__PURE__ */ jsx("div", { className: styles.badge, "aria-label": `${tasksCount} items requiring attention`, children: tasksCount > 9 ? "9+" : tasksCount })
53
+ ]
54
+ }
55
+ )
56
+ }
57
+ ) });
58
+ });
7
59
  export {
8
- breadcrumbs,
9
- breadcrumbsItem,
10
- classes as default
60
+ Tasks
11
61
  };
12
62
  //# sourceMappingURL=harmony79.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony79.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
1
+ {"version":3,"file":"harmony79.mjs","sources":["../src/components/Sidebar/Widgets/Tasks/Tasks.tsx"],"sourcesContent":["import { shift } from '@floating-ui/core'\nimport { Button, JobIcon, Popover, Tooltip } from '@lokalise/louis'\nimport { useEffectOnce } from '@utils'\nimport clsx from 'clsx'\nimport { useState } from 'react'\nimport styles from './Tasks.module.css'\nimport { useTasks } from './TasksContext'\nimport { TasksPopover } from './TasksPopover/TasksPopover'\nimport { withTasksContext } from './TasksProvider'\nimport { TaskEvents } from './utils/taskEvents'\n\nexport const Tasks = withTasksContext(() => {\n\tconst [open, setOpen] = useState(false)\n\n\tconst { tasksCount } = useTasks()\n\n\tuseEffectOnce(() => {\n\t\tconst showDialog = () => {\n\t\t\tsetOpen(true)\n\t\t}\n\n\t\tdocument.addEventListener(TaskEvents.ShowDialog, showDialog)\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(TaskEvents.ShowDialog, showDialog)\n\t\t}\n\t})\n\n\treturn (\n\t\t<Tooltip tooltip=\"Tasks\" placement=\"right\">\n\t\t\t<Popover\n\t\t\t\tcontent={<TasksPopover />}\n\t\t\t\tplacement=\"right\"\n\t\t\t\topen={open}\n\t\t\t\tonOpenChange={setOpen}\n\t\t\t\tmiddlewares={[\n\t\t\t\t\tshift({\n\t\t\t\t\t\t// Adding some spacing to the top and bottom so the popover\n\t\t\t\t\t\t// doesn't extend to the edges of the screen.\n\t\t\t\t\t\tpadding: {\n\t\t\t\t\t\t\ttop: 32,\n\t\t\t\t\t\t\tbottom: 32,\n\t\t\t\t\t\t},\n\t\t\t\t\t}),\n\t\t\t\t]}\n\t\t\t>\n\t\t\t\t{(visible) => (\n\t\t\t\t\t<Button\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\tdata-testid=\"sidebar-tasks-widget-button\"\n\t\t\t\t\t\taria-label=\"Tasks\"\n\t\t\t\t\t\tclassName={clsx(styles.navItem, {\n\t\t\t\t\t\t\t[styles.activeNavItem]: visible,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t<JobIcon size=\"25px\" />\n\t\t\t\t\t\t{tasksCount > 0 && (\n\t\t\t\t\t\t\t<div className={styles.badge} aria-label={`${tasksCount} items requiring attention`}>\n\t\t\t\t\t\t\t\t{tasksCount > 9 ? '9+' : tasksCount}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Button>\n\t\t\t\t)}\n\t\t\t</Popover>\n\t\t</Tooltip>\n\t)\n})\n"],"names":[],"mappings":";;;;;;;;;;;AAWa,MAAA,QAAQ,iBAAiB,MAAM;AAC3C,QAAM,CAAC,MAAM,OAAO,IAAI,SAAS,KAAK;AAEhC,QAAA,EAAE,WAAW,IAAI,SAAS;AAEhC,gBAAc,MAAM;AACnB,UAAM,aAAa,MAAM;AACxB,cAAQ,IAAI;AAAA,IACb;AAES,aAAA,iBAAiB,WAAW,YAAY,UAAU;AAE3D,WAAO,MAAM;AACH,eAAA,oBAAoB,WAAW,YAAY,UAAU;AAAA,IAC/D;AAAA,EAAA,CACA;AAED,SACE,oBAAA,SAAA,EAAQ,SAAQ,SAAQ,WAAU,SAClC,UAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,6BAAU,cAAa,EAAA;AAAA,MACvB,WAAU;AAAA,MACV;AAAA,MACA,cAAc;AAAA,MACd,aAAa;AAAA,QACZ,MAAM;AAAA;AAAA;AAAA,UAGL,SAAS;AAAA,YACR,KAAK;AAAA,YACL,QAAQ;AAAA,UAAA;AAAA,QAET,CAAA;AAAA,MACF;AAAA,MAEC,WAAC,YACD;AAAA,QAAC;AAAA,QAAA;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UACZ,cAAW;AAAA,UACX,WAAW,KAAK,OAAO,SAAS;AAAA,YAC/B,CAAC,OAAO,aAAa,GAAG;AAAA,UAAA,CACxB;AAAA,UAED,UAAA;AAAA,YAAC,oBAAA,SAAA,EAAQ,MAAK,OAAO,CAAA;AAAA,YACpB,aAAa,KACZ,oBAAA,OAAA,EAAI,WAAW,OAAO,OAAO,cAAY,GAAG,UAAU,8BACrD,UAAa,aAAA,IAAI,OAAO,WAC1B,CAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IAEF;AAAA,EAAA,GAGH;AAEF,CAAC;"}
@@ -1,11 +1,12 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const jsxRuntime = require("react/jsx-runtime");
4
- const louis = require("@lokalise/louis");
5
- const React = require("react");
6
- const DropdownContent = ({ items }) => /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: items.map((item, index) => /* @__PURE__ */ jsxRuntime.jsxs(React.Fragment, { children: [
7
- !!index && item.some((value) => value.visible) && /* @__PURE__ */ jsxRuntime.jsx(louis.MenuDivider, {}),
8
- item.filter(({ visible }) => visible).map(({ link, label, onClick }) => /* @__PURE__ */ jsxRuntime.jsx(louis.MenuItem, { href: link || "#", "aria-label": label, onClick, children: label }, label))
9
- ] }, item[0].label)) });
10
- exports.DropdownContent = DropdownContent;
2
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
+ const breadcrumbsItem = "_breadcrumbsItem_1hm6a_1";
4
+ const breadcrumbs = "_breadcrumbs_1hm6a_1";
5
+ const classes = {
6
+ breadcrumbsItem,
7
+ breadcrumbs
8
+ };
9
+ exports.breadcrumbs = breadcrumbs;
10
+ exports.breadcrumbsItem = breadcrumbsItem;
11
+ exports.default = classes;
11
12
  //# sourceMappingURL=harmony80.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony80.cjs","sources":["../src/components/NavigationPanel/components/DropdownContent/DropdownContent.tsx"],"sourcesContent":["import { MenuDivider, MenuItem } from '@lokalise/louis'\nimport { Fragment } from 'react'\nimport type { DropdownItem } from '../../types/navigation'\n\nexport const DropdownContent = ({ items }: { items: DropdownItem[][] }) => (\n\t<>\n\t\t{items.map((item, index) => (\n\t\t\t<Fragment key={item[0].label}>\n\t\t\t\t{!!index && item.some((value) => value.visible) && <MenuDivider />}\n\t\t\t\t{item\n\t\t\t\t\t.filter(({ visible }) => visible)\n\t\t\t\t\t.map(({ link, label, onClick }) => (\n\t\t\t\t\t\t<MenuItem key={label} href={link || '#'} aria-label={label} onClick={onClick}>\n\t\t\t\t\t\t\t{label}\n\t\t\t\t\t\t</MenuItem>\n\t\t\t\t\t))}\n\t\t\t</Fragment>\n\t\t))}\n\t</>\n)\n"],"names":["jsx","Fragment","jsxs","MenuDivider","MenuItem"],"mappings":";;;;;AAIO,MAAM,kBAAkB,CAAC,EAAE,MAAA,MACjCA,2BAAAA,IAAAC,WAAAA,UAAA,EACE,UAAM,MAAA,IAAI,CAAC,MAAM,UACjBC,2BAAAA,KAACD,MAAAA,UAAA,EACC,UAAA;AAAA,EAAC,CAAA,CAAC,SAAS,KAAK,KAAK,CAAC,UAAU,MAAM,OAAO,KAAKD,+BAACG,MAAAA,aAAY,CAAA,CAAA;AAAA,EAC/D,KACC,OAAO,CAAC,EAAE,cAAc,OAAO,EAC/B,IAAI,CAAC,EAAE,MAAM,OAAO,QAAQ,MAC3BH,+BAAAI,MAAAA,UAAA,EAAqB,MAAM,QAAQ,KAAK,cAAY,OAAO,SAC1D,UADa,MAAA,GAAA,KAEf,CACA;AAAA,EAAA,GARY,KAAK,CAAC,EAAE,KASvB,CACA,EACF,CAAA;;"}
1
+ {"version":3,"file":"harmony80.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;"}
@@ -1,11 +1,12 @@
1
- import { jsx, Fragment, jsxs } from "react/jsx-runtime";
2
- import { MenuDivider, MenuItem } from "@lokalise/louis";
3
- import { Fragment as Fragment$1 } from "react";
4
- const DropdownContent = ({ items }) => /* @__PURE__ */ jsx(Fragment, { children: items.map((item, index) => /* @__PURE__ */ jsxs(Fragment$1, { children: [
5
- !!index && item.some((value) => value.visible) && /* @__PURE__ */ jsx(MenuDivider, {}),
6
- item.filter(({ visible }) => visible).map(({ link, label, onClick }) => /* @__PURE__ */ jsx(MenuItem, { href: link || "#", "aria-label": label, onClick, children: label }, label))
7
- ] }, item[0].label)) });
1
+ const breadcrumbsItem = "_breadcrumbsItem_1hm6a_1";
2
+ const breadcrumbs = "_breadcrumbs_1hm6a_1";
3
+ const classes = {
4
+ breadcrumbsItem,
5
+ breadcrumbs
6
+ };
8
7
  export {
9
- DropdownContent
8
+ breadcrumbs,
9
+ breadcrumbsItem,
10
+ classes as default
10
11
  };
11
12
  //# sourceMappingURL=harmony80.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony80.mjs","sources":["../src/components/NavigationPanel/components/DropdownContent/DropdownContent.tsx"],"sourcesContent":["import { MenuDivider, MenuItem } from '@lokalise/louis'\nimport { Fragment } from 'react'\nimport type { DropdownItem } from '../../types/navigation'\n\nexport const DropdownContent = ({ items }: { items: DropdownItem[][] }) => (\n\t<>\n\t\t{items.map((item, index) => (\n\t\t\t<Fragment key={item[0].label}>\n\t\t\t\t{!!index && item.some((value) => value.visible) && <MenuDivider />}\n\t\t\t\t{item\n\t\t\t\t\t.filter(({ visible }) => visible)\n\t\t\t\t\t.map(({ link, label, onClick }) => (\n\t\t\t\t\t\t<MenuItem key={label} href={link || '#'} aria-label={label} onClick={onClick}>\n\t\t\t\t\t\t\t{label}\n\t\t\t\t\t\t</MenuItem>\n\t\t\t\t\t))}\n\t\t\t</Fragment>\n\t\t))}\n\t</>\n)\n"],"names":["Fragment"],"mappings":";;;AAIO,MAAM,kBAAkB,CAAC,EAAE,MAAA,MACjC,oBAAA,UAAA,EACE,UAAM,MAAA,IAAI,CAAC,MAAM,UACjB,qBAACA,YAAA,EACC,UAAA;AAAA,EAAC,CAAA,CAAC,SAAS,KAAK,KAAK,CAAC,UAAU,MAAM,OAAO,KAAK,oBAAC,aAAY,CAAA,CAAA;AAAA,EAC/D,KACC,OAAO,CAAC,EAAE,cAAc,OAAO,EAC/B,IAAI,CAAC,EAAE,MAAM,OAAO,QAAQ,MAC3B,oBAAA,UAAA,EAAqB,MAAM,QAAQ,KAAK,cAAY,OAAO,SAC1D,UADa,MAAA,GAAA,KAEf,CACA;AAAA,EAAA,GARY,KAAK,CAAC,EAAE,KASvB,CACA,EACF,CAAA;"}
1
+ {"version":3,"file":"harmony80.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -2,31 +2,10 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
4
  const louis = require("@lokalise/louis");
5
- const clsx = require("./harmony66.cjs");
6
5
  const React = require("react");
7
- const NavItemContents = require("./harmony97.cjs");
8
- const styles_module = require("./harmony98.cjs");
9
- const NavigationTabsItem = React.forwardRef(
10
- ({ label, href = "", disabled = false, badge, onClick, novel }, ref) => /* @__PURE__ */ jsxRuntime.jsx(louis.Tooltip, { tooltip: "You do not have access to this function", show: disabled, children: /* @__PURE__ */ jsxRuntime.jsx(
11
- "div",
12
- {
13
- className: disabled ? styles_module.default.projectNavigationItemDisabled : styles_module.default.projectNavigationItem,
14
- children: onClick || disabled || !href ? /* @__PURE__ */ jsxRuntime.jsx(
15
- "button",
16
- {
17
- type: "button",
18
- ref,
19
- className: clsx.clsx(styles_module.default.withNavLinkStyle, {
20
- [styles_module.default.disabled]: disabled
21
- }),
22
- disabled,
23
- onClick,
24
- children: /* @__PURE__ */ jsxRuntime.jsx(NavItemContents.NavItemContents, { label, badge, novel })
25
- }
26
- ) : /* @__PURE__ */ jsxRuntime.jsx("a", { href, className: styles_module.default.withNavLinkStyle, children: /* @__PURE__ */ jsxRuntime.jsx(NavItemContents.NavItemContents, { label, badge, novel }) })
27
- }
28
- ) })
29
- );
30
- NavigationTabsItem.displayName = "NavigationTabsItem";
31
- exports.NavigationTabsItem = NavigationTabsItem;
6
+ const DropdownContent = ({ items }) => /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: items.map((item, index) => /* @__PURE__ */ jsxRuntime.jsxs(React.Fragment, { children: [
7
+ !!index && item.some((value) => value.visible) && /* @__PURE__ */ jsxRuntime.jsx(louis.MenuDivider, {}),
8
+ item.filter(({ visible }) => visible).map(({ link, label, onClick }) => /* @__PURE__ */ jsxRuntime.jsx(louis.MenuItem, { href: link || "#", "aria-label": label, onClick, children: label }, label))
9
+ ] }, item[0].label)) });
10
+ exports.DropdownContent = DropdownContent;
32
11
  //# sourceMappingURL=harmony81.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony81.cjs","sources":["../src/components/NavigationPanel/components/NavigationTabs/NavigationTabsItem/NavigationTabsItem.tsx"],"sourcesContent":["import { Tooltip } from '@lokalise/louis'\nimport clsx from 'clsx'\nimport { forwardRef } from 'react'\nimport { NavItemContents } from './NavItemContents'\nimport classes from './styles.module.css'\n\ntype NavigationTabsItemProps = {\n\tlabel: string\n\tbadge?: number\n\tdisabled?: boolean\n\tactive?: boolean\n\tonClick?: () => void\n\thref?: string\n\tnovel?: string\n}\n\nexport const NavigationTabsItem = forwardRef<HTMLButtonElement, NavigationTabsItemProps>(\n\t({ label, href = '', disabled = false, badge, onClick, novel }, ref) => (\n\t\t<Tooltip tooltip=\"You do not have access to this function\" show={disabled}>\n\t\t\t<div\n\t\t\t\tclassName={disabled ? classes.projectNavigationItemDisabled : classes.projectNavigationItem}\n\t\t\t>\n\t\t\t\t{onClick || disabled || !href ? (\n\t\t\t\t\t<button\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\tref={ref}\n\t\t\t\t\t\tclassName={clsx(classes.withNavLinkStyle, {\n\t\t\t\t\t\t\t[classes.disabled]: disabled,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\t\tonClick={onClick}\n\t\t\t\t\t>\n\t\t\t\t\t\t<NavItemContents label={label} badge={badge} novel={novel} />\n\t\t\t\t\t</button>\n\t\t\t\t) : (\n\t\t\t\t\t<a href={href} className={classes.withNavLinkStyle}>\n\t\t\t\t\t\t<NavItemContents label={label} badge={badge} novel={novel} />\n\t\t\t\t\t</a>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t</Tooltip>\n\t),\n)\n\nNavigationTabsItem.displayName = 'NavigationTabsItem'\n"],"names":["forwardRef","jsx","Tooltip","classes","clsx","NavItemContents"],"mappings":";;;;;;;;AAgBO,MAAM,qBAAqBA,MAAA;AAAA,EACjC,CAAC,EAAE,OAAO,OAAO,IAAI,WAAW,OAAO,OAAO,SAAS,MAAA,GAAS,QAC/DC,2BAAA,IAACC,iBAAQ,SAAQ,2CAA0C,MAAM,UAChE,UAAAD,2BAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACA,WAAW,WAAWE,cAAAA,QAAQ,gCAAgCA,cAAQ,QAAA;AAAA,MAErE,UAAA,WAAW,YAAY,CAAC,OACxBF,2BAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACA,MAAK;AAAA,UACL;AAAA,UACA,WAAWG,KAAAA,KAAKD,cAAA,QAAQ,kBAAkB;AAAA,YACzC,CAACA,cAAAA,QAAQ,QAAQ,GAAG;AAAA,UAAA,CACpB;AAAA,UACD;AAAA,UACA;AAAA,UAEA,UAACF,2BAAA,IAAAI,gBAAA,iBAAA,EAAgB,OAAc,OAAc,MAAc,CAAA;AAAA,QAAA;AAAA,MAAA,IAG5DJ,2BAAAA,IAAC,KAAE,EAAA,MAAY,WAAWE,cAAA,QAAQ,kBACjC,UAAAF,2BAAA,IAACI,gBAAgB,iBAAA,EAAA,OAAc,OAAc,MAAc,CAAA,EAC5D,CAAA;AAAA,IAAA;AAAA,EAAA,EAGH,CAAA;AAEF;AAEA,mBAAmB,cAAc;;"}
1
+ {"version":3,"file":"harmony81.cjs","sources":["../src/components/NavigationPanel/components/DropdownContent/DropdownContent.tsx"],"sourcesContent":["import { MenuDivider, MenuItem } from '@lokalise/louis'\nimport { Fragment } from 'react'\nimport type { DropdownItem } from '../../types/navigation'\n\nexport const DropdownContent = ({ items }: { items: DropdownItem[][] }) => (\n\t<>\n\t\t{items.map((item, index) => (\n\t\t\t<Fragment key={item[0].label}>\n\t\t\t\t{!!index && item.some((value) => value.visible) && <MenuDivider />}\n\t\t\t\t{item\n\t\t\t\t\t.filter(({ visible }) => visible)\n\t\t\t\t\t.map(({ link, label, onClick }) => (\n\t\t\t\t\t\t<MenuItem key={label} href={link || '#'} aria-label={label} onClick={onClick}>\n\t\t\t\t\t\t\t{label}\n\t\t\t\t\t\t</MenuItem>\n\t\t\t\t\t))}\n\t\t\t</Fragment>\n\t\t))}\n\t</>\n)\n"],"names":["jsx","Fragment","jsxs","MenuDivider","MenuItem"],"mappings":";;;;;AAIO,MAAM,kBAAkB,CAAC,EAAE,MAAA,MACjCA,2BAAAA,IAAAC,WAAAA,UAAA,EACE,UAAM,MAAA,IAAI,CAAC,MAAM,UACjBC,2BAAAA,KAACD,MAAAA,UAAA,EACC,UAAA;AAAA,EAAC,CAAA,CAAC,SAAS,KAAK,KAAK,CAAC,UAAU,MAAM,OAAO,KAAKD,+BAACG,MAAAA,aAAY,CAAA,CAAA;AAAA,EAC/D,KACC,OAAO,CAAC,EAAE,cAAc,OAAO,EAC/B,IAAI,CAAC,EAAE,MAAM,OAAO,QAAQ,MAC3BH,+BAAAI,MAAAA,UAAA,EAAqB,MAAM,QAAQ,KAAK,cAAY,OAAO,SAC1D,UADa,MAAA,GAAA,KAEf,CACA;AAAA,EAAA,GARY,KAAK,CAAC,EAAE,KASvB,CACA,EACF,CAAA;;"}