@lokalise/harmony 3.0.0 → 4.0.0

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 (584) hide show
  1. package/dist/harmony.cjs +72 -66
  2. package/dist/harmony.cjs.map +1 -1
  3. package/dist/harmony.mjs +65 -59
  4. package/dist/harmony102.cjs +1 -1
  5. package/dist/harmony102.mjs +1 -1
  6. package/dist/harmony103.cjs +7 -7
  7. package/dist/harmony103.mjs +7 -7
  8. package/dist/harmony105.cjs +2 -2
  9. package/dist/harmony105.mjs +2 -2
  10. package/dist/harmony106.cjs +1 -1
  11. package/dist/harmony106.mjs +1 -1
  12. package/dist/harmony107.cjs +1 -1
  13. package/dist/harmony107.mjs +1 -1
  14. package/dist/harmony108.cjs +14 -3
  15. package/dist/harmony108.cjs.map +1 -1
  16. package/dist/harmony108.mjs +14 -3
  17. package/dist/harmony108.mjs.map +1 -1
  18. package/dist/harmony109.cjs +9 -16
  19. package/dist/harmony109.cjs.map +1 -1
  20. package/dist/harmony109.mjs +11 -18
  21. package/dist/harmony109.mjs.map +1 -1
  22. package/dist/harmony110.cjs +21 -76
  23. package/dist/harmony110.cjs.map +1 -1
  24. package/dist/harmony110.mjs +20 -75
  25. package/dist/harmony110.mjs.map +1 -1
  26. package/dist/harmony111.cjs +10 -10
  27. package/dist/harmony111.cjs.map +1 -1
  28. package/dist/harmony111.mjs +10 -10
  29. package/dist/harmony111.mjs.map +1 -1
  30. package/dist/harmony112.cjs +13 -35
  31. package/dist/harmony112.cjs.map +1 -1
  32. package/dist/harmony112.mjs +12 -34
  33. package/dist/harmony112.mjs.map +1 -1
  34. package/dist/harmony113.cjs +3 -9
  35. package/dist/harmony113.cjs.map +1 -1
  36. package/dist/harmony113.mjs +3 -9
  37. package/dist/harmony113.mjs.map +1 -1
  38. package/dist/harmony114.cjs +12 -41
  39. package/dist/harmony114.cjs.map +1 -1
  40. package/dist/harmony114.mjs +14 -43
  41. package/dist/harmony114.mjs.map +1 -1
  42. package/dist/harmony115.cjs +76 -9
  43. package/dist/harmony115.cjs.map +1 -1
  44. package/dist/harmony115.mjs +75 -8
  45. package/dist/harmony115.mjs.map +1 -1
  46. package/dist/harmony116.cjs +10 -10
  47. package/dist/harmony116.cjs.map +1 -1
  48. package/dist/harmony116.mjs +10 -10
  49. package/dist/harmony116.mjs.map +1 -1
  50. package/dist/harmony117.cjs +35 -13
  51. package/dist/harmony117.cjs.map +1 -1
  52. package/dist/harmony117.mjs +34 -12
  53. package/dist/harmony117.mjs.map +1 -1
  54. package/dist/harmony118.cjs +9 -14
  55. package/dist/harmony118.cjs.map +1 -1
  56. package/dist/harmony118.mjs +9 -14
  57. package/dist/harmony118.mjs.map +1 -1
  58. package/dist/harmony119.cjs +45 -9
  59. package/dist/harmony119.cjs.map +1 -1
  60. package/dist/harmony119.mjs +47 -11
  61. package/dist/harmony119.mjs.map +1 -1
  62. package/dist/harmony120.cjs +8 -20
  63. package/dist/harmony120.cjs.map +1 -1
  64. package/dist/harmony120.mjs +8 -20
  65. package/dist/harmony120.mjs.map +1 -1
  66. package/dist/harmony121.cjs +8 -20
  67. package/dist/harmony121.cjs.map +1 -1
  68. package/dist/harmony121.mjs +8 -20
  69. package/dist/harmony121.mjs.map +1 -1
  70. package/dist/harmony122.cjs +8 -7
  71. package/dist/harmony122.cjs.map +1 -1
  72. package/dist/harmony122.mjs +8 -7
  73. package/dist/harmony122.mjs.map +1 -1
  74. package/dist/harmony123.cjs +14 -16
  75. package/dist/harmony123.cjs.map +1 -1
  76. package/dist/harmony123.mjs +14 -16
  77. package/dist/harmony123.mjs.map +1 -1
  78. package/dist/harmony124.cjs +20 -8
  79. package/dist/harmony124.cjs.map +1 -1
  80. package/dist/harmony124.mjs +20 -8
  81. package/dist/harmony124.mjs.map +1 -1
  82. package/dist/harmony125.cjs +86 -7
  83. package/dist/harmony125.cjs.map +1 -1
  84. package/dist/harmony125.mjs +86 -7
  85. package/dist/harmony125.mjs.map +1 -1
  86. package/dist/harmony126.cjs +30 -15
  87. package/dist/harmony126.cjs.map +1 -1
  88. package/dist/harmony126.mjs +30 -15
  89. package/dist/harmony126.mjs.map +1 -1
  90. package/dist/harmony127.cjs +2 -2
  91. package/dist/harmony127.mjs +2 -2
  92. package/dist/harmony128.cjs +9 -87
  93. package/dist/harmony128.cjs.map +1 -1
  94. package/dist/harmony128.mjs +8 -86
  95. package/dist/harmony128.mjs.map +1 -1
  96. package/dist/harmony129.cjs +11 -29
  97. package/dist/harmony129.cjs.map +1 -1
  98. package/dist/harmony129.mjs +11 -29
  99. package/dist/harmony129.mjs.map +1 -1
  100. package/dist/harmony130.cjs +15 -9
  101. package/dist/harmony130.cjs.map +1 -1
  102. package/dist/harmony130.mjs +14 -8
  103. package/dist/harmony130.mjs.map +1 -1
  104. package/dist/harmony131.cjs +13 -6
  105. package/dist/harmony131.cjs.map +1 -1
  106. package/dist/harmony131.mjs +15 -8
  107. package/dist/harmony131.mjs.map +1 -1
  108. package/dist/harmony132.cjs +7 -12
  109. package/dist/harmony132.cjs.map +1 -1
  110. package/dist/harmony132.mjs +9 -14
  111. package/dist/harmony132.mjs.map +1 -1
  112. package/dist/harmony133.cjs +20 -13
  113. package/dist/harmony133.cjs.map +1 -1
  114. package/dist/harmony133.mjs +21 -14
  115. package/dist/harmony133.mjs.map +1 -1
  116. package/dist/harmony134.cjs +9 -7
  117. package/dist/harmony134.cjs.map +1 -1
  118. package/dist/harmony134.mjs +11 -9
  119. package/dist/harmony134.mjs.map +1 -1
  120. package/dist/harmony135.cjs +30 -18
  121. package/dist/harmony135.cjs.map +1 -1
  122. package/dist/harmony135.mjs +32 -20
  123. package/dist/harmony135.mjs.map +1 -1
  124. package/dist/harmony136.cjs +6 -6
  125. package/dist/harmony136.cjs.map +1 -1
  126. package/dist/harmony136.mjs +6 -6
  127. package/dist/harmony136.mjs.map +1 -1
  128. package/dist/harmony137.cjs +13 -29
  129. package/dist/harmony137.cjs.map +1 -1
  130. package/dist/harmony137.mjs +14 -30
  131. package/dist/harmony137.mjs.map +1 -1
  132. package/dist/harmony138.cjs +31 -7
  133. package/dist/harmony138.cjs.map +1 -1
  134. package/dist/harmony138.mjs +32 -8
  135. package/dist/harmony138.mjs.map +1 -1
  136. package/dist/harmony139.cjs +21 -22
  137. package/dist/harmony139.cjs.map +1 -1
  138. package/dist/harmony139.mjs +20 -21
  139. package/dist/harmony139.mjs.map +1 -1
  140. package/dist/harmony140.cjs +15 -30
  141. package/dist/harmony140.cjs.map +1 -1
  142. package/dist/harmony140.mjs +17 -32
  143. package/dist/harmony140.mjs.map +1 -1
  144. package/dist/harmony141.cjs +3 -18
  145. package/dist/harmony141.cjs.map +1 -1
  146. package/dist/harmony141.mjs +3 -18
  147. package/dist/harmony141.mjs.map +1 -1
  148. package/dist/harmony142.cjs +15 -21
  149. package/dist/harmony142.cjs.map +1 -1
  150. package/dist/harmony142.mjs +14 -20
  151. package/dist/harmony142.mjs.map +1 -1
  152. package/dist/harmony143.cjs +4 -7
  153. package/dist/harmony143.cjs.map +1 -1
  154. package/dist/harmony143.mjs +3 -6
  155. package/dist/harmony143.mjs.map +1 -1
  156. package/dist/harmony144.cjs +4 -16
  157. package/dist/harmony144.cjs.map +1 -1
  158. package/dist/harmony144.mjs +3 -15
  159. package/dist/harmony144.mjs.map +1 -1
  160. package/dist/harmony145.cjs +3 -3
  161. package/dist/harmony145.cjs.map +1 -1
  162. package/dist/harmony145.mjs +3 -3
  163. package/dist/harmony145.mjs.map +1 -1
  164. package/dist/harmony146.cjs +14 -3
  165. package/dist/harmony146.cjs.map +1 -1
  166. package/dist/harmony146.mjs +14 -3
  167. package/dist/harmony146.mjs.map +1 -1
  168. package/dist/harmony147.cjs +1 -1
  169. package/dist/harmony147.cjs.map +1 -1
  170. package/dist/harmony147.mjs +1 -1
  171. package/dist/harmony147.mjs.map +1 -1
  172. package/dist/harmony148.cjs +7 -7
  173. package/dist/harmony148.cjs.map +1 -1
  174. package/dist/harmony148.mjs +7 -7
  175. package/dist/harmony148.mjs.map +1 -1
  176. package/dist/harmony149.cjs +6 -15
  177. package/dist/harmony149.cjs.map +1 -1
  178. package/dist/harmony149.mjs +5 -14
  179. package/dist/harmony149.mjs.map +1 -1
  180. package/dist/harmony150.cjs +6 -4
  181. package/dist/harmony150.cjs.map +1 -1
  182. package/dist/harmony150.mjs +5 -3
  183. package/dist/harmony150.mjs.map +1 -1
  184. package/dist/harmony151.cjs +11 -6
  185. package/dist/harmony151.cjs.map +1 -1
  186. package/dist/harmony151.mjs +10 -5
  187. package/dist/harmony151.mjs.map +1 -1
  188. package/dist/harmony152.cjs +33 -6
  189. package/dist/harmony152.cjs.map +1 -1
  190. package/dist/harmony152.mjs +32 -5
  191. package/dist/harmony152.mjs.map +1 -1
  192. package/dist/harmony153.cjs +96 -10
  193. package/dist/harmony153.cjs.map +1 -1
  194. package/dist/harmony153.mjs +96 -10
  195. package/dist/harmony153.mjs.map +1 -1
  196. package/dist/harmony154.cjs +11 -94
  197. package/dist/harmony154.cjs.map +1 -1
  198. package/dist/harmony154.mjs +11 -94
  199. package/dist/harmony154.mjs.map +1 -1
  200. package/dist/harmony155.cjs +13 -12
  201. package/dist/harmony155.cjs.map +1 -1
  202. package/dist/harmony155.mjs +13 -12
  203. package/dist/harmony155.mjs.map +1 -1
  204. package/dist/harmony156.cjs +35 -13
  205. package/dist/harmony156.cjs.map +1 -1
  206. package/dist/harmony156.mjs +35 -13
  207. package/dist/harmony156.mjs.map +1 -1
  208. package/dist/harmony157.cjs +24 -32
  209. package/dist/harmony157.cjs.map +1 -1
  210. package/dist/harmony157.mjs +24 -32
  211. package/dist/harmony157.mjs.map +1 -1
  212. package/dist/harmony158.cjs +10 -29
  213. package/dist/harmony158.cjs.map +1 -1
  214. package/dist/harmony158.mjs +9 -28
  215. package/dist/harmony158.mjs.map +1 -1
  216. package/dist/harmony159.cjs +6 -32
  217. package/dist/harmony159.cjs.map +1 -1
  218. package/dist/harmony159.mjs +5 -31
  219. package/dist/harmony159.mjs.map +1 -1
  220. package/dist/harmony160.cjs +6 -6
  221. package/dist/harmony160.mjs +6 -6
  222. package/dist/harmony161.cjs +21 -3
  223. package/dist/harmony161.cjs.map +1 -1
  224. package/dist/harmony161.mjs +21 -3
  225. package/dist/harmony161.mjs.map +1 -1
  226. package/dist/harmony162.cjs +3 -6
  227. package/dist/harmony162.cjs.map +1 -1
  228. package/dist/harmony162.mjs +3 -6
  229. package/dist/harmony162.mjs.map +1 -1
  230. package/dist/harmony163.cjs +9 -21
  231. package/dist/harmony163.cjs.map +1 -1
  232. package/dist/harmony163.mjs +9 -21
  233. package/dist/harmony163.mjs.map +1 -1
  234. package/dist/harmony164.cjs +3 -3
  235. package/dist/harmony164.mjs +3 -3
  236. package/dist/harmony165.cjs +14 -13
  237. package/dist/harmony165.cjs.map +1 -1
  238. package/dist/harmony165.mjs +13 -12
  239. package/dist/harmony165.mjs.map +1 -1
  240. package/dist/harmony166.cjs +16 -7
  241. package/dist/harmony166.cjs.map +1 -1
  242. package/dist/harmony166.mjs +15 -6
  243. package/dist/harmony166.mjs.map +1 -1
  244. package/dist/harmony167.cjs +15 -12
  245. package/dist/harmony167.cjs.map +1 -1
  246. package/dist/harmony167.mjs +15 -12
  247. package/dist/harmony167.mjs.map +1 -1
  248. package/dist/harmony168.cjs +4 -15
  249. package/dist/harmony168.cjs.map +1 -1
  250. package/dist/harmony168.mjs +4 -15
  251. package/dist/harmony168.mjs.map +1 -1
  252. package/dist/harmony169.cjs +10 -15
  253. package/dist/harmony169.cjs.map +1 -1
  254. package/dist/harmony169.mjs +10 -15
  255. package/dist/harmony169.mjs.map +1 -1
  256. package/dist/harmony17.cjs +1 -1
  257. package/dist/harmony17.mjs +1 -1
  258. package/dist/harmony170.cjs +16 -4
  259. package/dist/harmony170.cjs.map +1 -1
  260. package/dist/harmony170.mjs +16 -4
  261. package/dist/harmony170.mjs.map +1 -1
  262. package/dist/harmony171.cjs +20 -10
  263. package/dist/harmony171.cjs.map +1 -1
  264. package/dist/harmony171.mjs +20 -10
  265. package/dist/harmony171.mjs.map +1 -1
  266. package/dist/harmony172.cjs +10 -14
  267. package/dist/harmony172.cjs.map +1 -1
  268. package/dist/harmony172.mjs +10 -14
  269. package/dist/harmony172.mjs.map +1 -1
  270. package/dist/harmony173.cjs +5 -20
  271. package/dist/harmony173.cjs.map +1 -1
  272. package/dist/harmony173.mjs +5 -20
  273. package/dist/harmony173.mjs.map +1 -1
  274. package/dist/harmony174.cjs +11 -11
  275. package/dist/harmony174.cjs.map +1 -1
  276. package/dist/harmony174.mjs +11 -11
  277. package/dist/harmony174.mjs.map +1 -1
  278. package/dist/harmony175.cjs +31 -5
  279. package/dist/harmony175.cjs.map +1 -1
  280. package/dist/harmony175.mjs +31 -5
  281. package/dist/harmony175.mjs.map +1 -1
  282. package/dist/harmony176.cjs +13 -11
  283. package/dist/harmony176.cjs.map +1 -1
  284. package/dist/harmony176.mjs +13 -11
  285. package/dist/harmony176.mjs.map +1 -1
  286. package/dist/harmony20.cjs +1 -1
  287. package/dist/harmony20.mjs +1 -1
  288. package/dist/harmony26.cjs +1 -1
  289. package/dist/harmony26.mjs +1 -1
  290. package/dist/harmony27.cjs +1 -1
  291. package/dist/harmony27.mjs +1 -1
  292. package/dist/harmony28.cjs +2 -2
  293. package/dist/harmony28.mjs +2 -2
  294. package/dist/harmony29.cjs +1 -1
  295. package/dist/harmony29.mjs +1 -1
  296. package/dist/harmony30.cjs +1 -1
  297. package/dist/harmony30.mjs +1 -1
  298. package/dist/harmony31.cjs +1 -1
  299. package/dist/harmony31.mjs +1 -1
  300. package/dist/harmony32.cjs +10 -5
  301. package/dist/harmony32.cjs.map +1 -1
  302. package/dist/harmony32.mjs +11 -6
  303. package/dist/harmony32.mjs.map +1 -1
  304. package/dist/harmony33.cjs +10 -5
  305. package/dist/harmony33.cjs.map +1 -1
  306. package/dist/harmony33.mjs +11 -6
  307. package/dist/harmony33.mjs.map +1 -1
  308. package/dist/harmony34.cjs +10 -11
  309. package/dist/harmony34.cjs.map +1 -1
  310. package/dist/harmony34.mjs +11 -12
  311. package/dist/harmony34.mjs.map +1 -1
  312. package/dist/harmony35.cjs +11 -11
  313. package/dist/harmony35.cjs.map +1 -1
  314. package/dist/harmony35.mjs +11 -11
  315. package/dist/harmony35.mjs.map +1 -1
  316. package/dist/harmony36.cjs +11 -11
  317. package/dist/harmony36.cjs.map +1 -1
  318. package/dist/harmony36.mjs +12 -12
  319. package/dist/harmony36.mjs.map +1 -1
  320. package/dist/harmony37.cjs +7 -13
  321. package/dist/harmony37.cjs.map +1 -1
  322. package/dist/harmony37.mjs +7 -13
  323. package/dist/harmony37.mjs.map +1 -1
  324. package/dist/harmony38.cjs +10 -13
  325. package/dist/harmony38.cjs.map +1 -1
  326. package/dist/harmony38.mjs +10 -13
  327. package/dist/harmony38.mjs.map +1 -1
  328. package/dist/harmony39.cjs +9 -6
  329. package/dist/harmony39.cjs.map +1 -1
  330. package/dist/harmony39.mjs +9 -6
  331. package/dist/harmony39.mjs.map +1 -1
  332. package/dist/harmony40.cjs +7 -9
  333. package/dist/harmony40.cjs.map +1 -1
  334. package/dist/harmony40.mjs +7 -9
  335. package/dist/harmony40.mjs.map +1 -1
  336. package/dist/harmony41.cjs +7 -9
  337. package/dist/harmony41.cjs.map +1 -1
  338. package/dist/harmony41.mjs +7 -9
  339. package/dist/harmony41.mjs.map +1 -1
  340. package/dist/harmony42.cjs +9 -9
  341. package/dist/harmony42.cjs.map +1 -1
  342. package/dist/harmony42.mjs +9 -9
  343. package/dist/harmony42.mjs.map +1 -1
  344. package/dist/harmony43.cjs +5 -9
  345. package/dist/harmony43.cjs.map +1 -1
  346. package/dist/harmony43.mjs +5 -9
  347. package/dist/harmony43.mjs.map +1 -1
  348. package/dist/harmony44.cjs +32 -9
  349. package/dist/harmony44.cjs.map +1 -1
  350. package/dist/harmony44.mjs +32 -9
  351. package/dist/harmony44.mjs.map +1 -1
  352. package/dist/harmony45.cjs +7 -32
  353. package/dist/harmony45.cjs.map +1 -1
  354. package/dist/harmony45.mjs +7 -32
  355. package/dist/harmony45.mjs.map +1 -1
  356. package/dist/harmony46.cjs +11 -55
  357. package/dist/harmony46.cjs.map +1 -1
  358. package/dist/harmony46.mjs +11 -55
  359. package/dist/harmony46.mjs.map +1 -1
  360. package/dist/harmony47.cjs +49 -25
  361. package/dist/harmony47.cjs.map +1 -1
  362. package/dist/harmony47.mjs +50 -26
  363. package/dist/harmony47.mjs.map +1 -1
  364. package/dist/harmony48.cjs +28 -8
  365. package/dist/harmony48.cjs.map +1 -1
  366. package/dist/harmony48.mjs +29 -9
  367. package/dist/harmony48.mjs.map +1 -1
  368. package/dist/harmony49.cjs +10 -54
  369. package/dist/harmony49.cjs.map +1 -1
  370. package/dist/harmony49.mjs +10 -54
  371. package/dist/harmony49.mjs.map +1 -1
  372. package/dist/harmony5.cjs +2 -2
  373. package/dist/harmony5.mjs +2 -2
  374. package/dist/harmony50.cjs +50 -25
  375. package/dist/harmony50.cjs.map +1 -1
  376. package/dist/harmony50.mjs +51 -26
  377. package/dist/harmony50.mjs.map +1 -1
  378. package/dist/harmony51.cjs +27 -15
  379. package/dist/harmony51.cjs.map +1 -1
  380. package/dist/harmony51.mjs +28 -16
  381. package/dist/harmony51.mjs.map +1 -1
  382. package/dist/harmony52.cjs +15 -25
  383. package/dist/harmony52.cjs.map +1 -1
  384. package/dist/harmony52.mjs +16 -26
  385. package/dist/harmony52.mjs.map +1 -1
  386. package/dist/harmony53.cjs +25 -11
  387. package/dist/harmony53.cjs.map +1 -1
  388. package/dist/harmony53.mjs +26 -12
  389. package/dist/harmony53.mjs.map +1 -1
  390. package/dist/harmony54.cjs +14 -14
  391. package/dist/harmony54.cjs.map +1 -1
  392. package/dist/harmony54.mjs +14 -14
  393. package/dist/harmony54.mjs.map +1 -1
  394. package/dist/harmony55.cjs +6 -6
  395. package/dist/harmony55.cjs.map +1 -1
  396. package/dist/harmony55.mjs +6 -6
  397. package/dist/harmony55.mjs.map +1 -1
  398. package/dist/harmony56.cjs +4 -4
  399. package/dist/harmony56.cjs.map +1 -1
  400. package/dist/harmony56.mjs +4 -4
  401. package/dist/harmony56.mjs.map +1 -1
  402. package/dist/harmony57.cjs +6 -6
  403. package/dist/harmony57.cjs.map +1 -1
  404. package/dist/harmony57.mjs +6 -6
  405. package/dist/harmony57.mjs.map +1 -1
  406. package/dist/harmony58.cjs +6 -5
  407. package/dist/harmony58.cjs.map +1 -1
  408. package/dist/harmony58.mjs +6 -5
  409. package/dist/harmony58.mjs.map +1 -1
  410. package/dist/harmony59.cjs +6 -15
  411. package/dist/harmony59.cjs.map +1 -1
  412. package/dist/harmony59.mjs +7 -16
  413. package/dist/harmony59.mjs.map +1 -1
  414. package/dist/harmony60.cjs +16 -7
  415. package/dist/harmony60.cjs.map +1 -1
  416. package/dist/harmony60.mjs +16 -7
  417. package/dist/harmony60.mjs.map +1 -1
  418. package/dist/harmony61.cjs +4 -4
  419. package/dist/harmony61.cjs.map +1 -1
  420. package/dist/harmony61.mjs +4 -4
  421. package/dist/harmony61.mjs.map +1 -1
  422. package/dist/harmony62.cjs +7 -11
  423. package/dist/harmony62.cjs.map +1 -1
  424. package/dist/harmony62.mjs +9 -13
  425. package/dist/harmony62.mjs.map +1 -1
  426. package/dist/harmony63.cjs +8 -8
  427. package/dist/harmony63.cjs.map +1 -1
  428. package/dist/harmony63.mjs +8 -8
  429. package/dist/harmony63.mjs.map +1 -1
  430. package/dist/harmony64.cjs +14 -12
  431. package/dist/harmony64.cjs.map +1 -1
  432. package/dist/harmony64.mjs +14 -12
  433. package/dist/harmony64.mjs.map +1 -1
  434. package/dist/harmony65.cjs +8 -8
  435. package/dist/harmony65.cjs.map +1 -1
  436. package/dist/harmony65.mjs +9 -9
  437. package/dist/harmony65.mjs.map +1 -1
  438. package/dist/harmony66.cjs +9 -9
  439. package/dist/harmony66.cjs.map +1 -1
  440. package/dist/harmony66.mjs +10 -10
  441. package/dist/harmony66.mjs.map +1 -1
  442. package/dist/harmony67.cjs +12 -14
  443. package/dist/harmony67.cjs.map +1 -1
  444. package/dist/harmony67.mjs +12 -14
  445. package/dist/harmony67.mjs.map +1 -1
  446. package/dist/harmony68.cjs +10 -10
  447. package/dist/harmony68.cjs.map +1 -1
  448. package/dist/harmony68.mjs +10 -10
  449. package/dist/harmony68.mjs.map +1 -1
  450. package/dist/harmony69.cjs +8 -8
  451. package/dist/harmony69.cjs.map +1 -1
  452. package/dist/harmony69.mjs +8 -8
  453. package/dist/harmony69.mjs.map +1 -1
  454. package/dist/harmony70.cjs +7 -7
  455. package/dist/harmony70.cjs.map +1 -1
  456. package/dist/harmony70.mjs +7 -7
  457. package/dist/harmony70.mjs.map +1 -1
  458. package/dist/harmony71.cjs +8 -8
  459. package/dist/harmony71.cjs.map +1 -1
  460. package/dist/harmony71.mjs +8 -8
  461. package/dist/harmony71.mjs.map +1 -1
  462. package/dist/harmony72.cjs +14 -12
  463. package/dist/harmony72.cjs.map +1 -1
  464. package/dist/harmony72.mjs +14 -12
  465. package/dist/harmony72.mjs.map +1 -1
  466. package/dist/harmony73.cjs +12 -14
  467. package/dist/harmony73.cjs.map +1 -1
  468. package/dist/harmony73.mjs +12 -14
  469. package/dist/harmony73.mjs.map +1 -1
  470. package/dist/harmony74.cjs +8 -8
  471. package/dist/harmony74.cjs.map +1 -1
  472. package/dist/harmony74.mjs +8 -8
  473. package/dist/harmony74.mjs.map +1 -1
  474. package/dist/harmony75.cjs +8 -9
  475. package/dist/harmony75.cjs.map +1 -1
  476. package/dist/harmony75.mjs +9 -10
  477. package/dist/harmony75.mjs.map +1 -1
  478. package/dist/harmony76.cjs +11 -7
  479. package/dist/harmony76.cjs.map +1 -1
  480. package/dist/harmony76.mjs +12 -8
  481. package/dist/harmony76.mjs.map +1 -1
  482. package/dist/harmony77.cjs +4 -4
  483. package/dist/harmony77.cjs.map +1 -1
  484. package/dist/harmony77.mjs +4 -4
  485. package/dist/harmony77.mjs.map +1 -1
  486. package/dist/harmony78.cjs +13 -123
  487. package/dist/harmony78.cjs.map +1 -1
  488. package/dist/harmony78.mjs +13 -123
  489. package/dist/harmony78.mjs.map +1 -1
  490. package/dist/harmony79.cjs +102 -60
  491. package/dist/harmony79.cjs.map +1 -1
  492. package/dist/harmony79.mjs +102 -60
  493. package/dist/harmony79.mjs.map +1 -1
  494. package/dist/harmony80.cjs +80 -4
  495. package/dist/harmony80.cjs.map +1 -1
  496. package/dist/harmony80.mjs +80 -4
  497. package/dist/harmony80.mjs.map +1 -1
  498. package/dist/harmony81.cjs +4 -26
  499. package/dist/harmony81.cjs.map +1 -1
  500. package/dist/harmony81.mjs +4 -26
  501. package/dist/harmony81.mjs.map +1 -1
  502. package/dist/harmony82.cjs +19 -21
  503. package/dist/harmony82.cjs.map +1 -1
  504. package/dist/harmony82.mjs +19 -21
  505. package/dist/harmony82.mjs.map +1 -1
  506. package/dist/harmony83.cjs +19 -136
  507. package/dist/harmony83.cjs.map +1 -1
  508. package/dist/harmony83.mjs +17 -134
  509. package/dist/harmony83.mjs.map +1 -1
  510. package/dist/harmony84.cjs +140 -36
  511. package/dist/harmony84.cjs.map +1 -1
  512. package/dist/harmony84.mjs +139 -35
  513. package/dist/harmony84.mjs.map +1 -1
  514. package/dist/harmony85.cjs +36 -25
  515. package/dist/harmony85.cjs.map +1 -1
  516. package/dist/harmony85.mjs +36 -25
  517. package/dist/harmony85.mjs.map +1 -1
  518. package/dist/harmony86.cjs +25 -3
  519. package/dist/harmony86.cjs.map +1 -1
  520. package/dist/harmony86.mjs +25 -3
  521. package/dist/harmony86.mjs.map +1 -1
  522. package/dist/harmony87.cjs +2 -2
  523. package/dist/harmony87.mjs +2 -2
  524. package/dist/harmony88.cjs +4 -4
  525. package/dist/harmony88.cjs.map +1 -1
  526. package/dist/harmony88.mjs +4 -4
  527. package/dist/harmony88.mjs.map +1 -1
  528. package/dist/harmony89.cjs +1 -1
  529. package/dist/harmony89.mjs +1 -1
  530. package/dist/harmony96.cjs +2 -2
  531. package/dist/harmony96.mjs +2 -2
  532. package/dist/harmony99.cjs +2 -2
  533. package/dist/harmony99.mjs +2 -2
  534. package/dist/types/src/features/permissions/{action-resolvers → actionResolvers}/accessMarketingProjects.d.ts +1 -1
  535. package/dist/types/src/features/permissions/actionResolvers/createProjects.d.ts +2 -0
  536. package/dist/types/src/features/permissions/actionResolvers/deleteProjects.d.ts +2 -0
  537. package/dist/types/src/features/permissions/actionResolvers/downloadFiles.d.ts +2 -0
  538. package/dist/types/src/features/permissions/actionResolvers/manageContributors.d.ts +2 -0
  539. package/dist/types/src/features/permissions/actionResolvers/uploadFiles.d.ts +2 -0
  540. package/dist/types/src/features/permissions/{action.d.ts → actionResolvers.d.ts} +3 -3
  541. package/dist/types/src/features/permissions/components/CanPerformActionGuard.d.ts +1 -1
  542. package/dist/types/src/features/permissions/components/CanPerformAllActionsGuard.d.ts +1 -1
  543. package/dist/types/src/features/permissions/components/CanPerformAnyActionGuard.d.ts +1 -1
  544. package/dist/types/src/features/permissions/components/HasFeatureFlagGuard.d.ts +1 -1
  545. package/dist/types/src/features/permissions/context/ActionResolverContext.d.ts +5 -0
  546. package/dist/types/src/features/permissions/hooks/useCanPerformAction.d.ts +1 -1
  547. package/dist/types/src/features/permissions/hooks/useCanPerformAllActions.d.ts +1 -1
  548. package/dist/types/src/features/permissions/hooks/useCanPerformAnyAction.d.ts +1 -1
  549. package/dist/types/src/features/permissions/hooks/useHasAllFeatureFlags.d.ts +1 -1
  550. package/dist/types/src/features/permissions/hooks/useHasAnyFeatureFlags.d.ts +1 -1
  551. package/dist/types/src/features/permissions/node.d.ts +7 -4
  552. package/dist/types/src/features/permissions/types/actionResolver.d.ts +2 -0
  553. package/dist/types/src/features/permissions/types/actionResolverContext.d.ts +10 -0
  554. package/dist/types/src/features/permissions/types/featureFlagTypes.d.ts +113 -0
  555. package/dist/types/src/features/permissions/types/projectPermissionTypes.d.ts +54 -0
  556. package/dist/types/src/features/permissions/types/projectType.d.ts +10 -0
  557. package/dist/types/src/features/{publicApi → permissions}/types/teamRoleTypes.d.ts +2 -0
  558. package/dist/types/src/features/permissions/types.d.ts +0 -22
  559. package/dist/types/src/features/permissions/utils/canPerformAction.d.ts +6 -6
  560. package/dist/types/src/features/permissions/utils/canPerformActionByProjectType.d.ts +1 -1
  561. package/dist/types/src/features/publicApi/node.d.ts +0 -1
  562. package/dist/types/src/features/publicApi/types/permissionTemplateTypes.d.ts +0 -23
  563. package/package.json +1 -1
  564. package/dist/harmony177.cjs +0 -35
  565. package/dist/harmony177.cjs.map +0 -1
  566. package/dist/harmony177.mjs +0 -35
  567. package/dist/harmony177.mjs.map +0 -1
  568. package/dist/harmony178.cjs +0 -17
  569. package/dist/harmony178.cjs.map +0 -1
  570. package/dist/harmony178.mjs +0 -17
  571. package/dist/harmony178.mjs.map +0 -1
  572. package/dist/types/src/features/permissions/action-resolvers/canDownloadFiles.d.ts +0 -2
  573. package/dist/types/src/features/permissions/action-resolvers/canUploadFiles.d.ts +0 -2
  574. package/dist/types/src/features/permissions/action-resolvers/createProjects.d.ts +0 -2
  575. package/dist/types/src/features/permissions/action-resolvers/deleteProjects.d.ts +0 -2
  576. package/dist/types/src/features/permissions/action-resolvers/manageContributors.d.ts +0 -2
  577. package/dist/types/src/features/permissions/components/FeatureFlagActionResolverContextProvider.d.ts +0 -22
  578. package/dist/types/src/features/permissions/components/ProjectActionResolverContextProvider.d.ts +0 -25
  579. package/dist/types/src/features/permissions/components/ProjectActionResolverContextProvider.test.d.ts +0 -1
  580. package/dist/types/src/features/permissions/components/TeamActionResolverContextProvider.d.ts +0 -22
  581. package/dist/types/src/features/permissions/components/TeamActionResolverContextProvider.test.d.ts +0 -1
  582. package/dist/types/src/features/permissions/context/ActionsContext.d.ts +0 -9
  583. package/dist/types/src/features/permissions/hooks/useActionResolverPayload.d.ts +0 -2
  584. /package/dist/types/src/features/permissions/{components/FeatureFlagActionResolverContextProvider.test.d.ts → context/ActionResolverContext.test.d.ts} +0 -0
@@ -1,6 +1,17 @@
1
- import { has } from "./harmony125.mjs";
2
- const deleteProjects = ({ projectPermissions }) => has(projectPermissions, "settings");
1
+ import { canPerformActionByProjectType } from "./harmony152.mjs";
2
+ import { has } from "./harmony122.mjs";
3
+ import { hasAny } from "./harmony121.mjs";
4
+ const downloadFiles = ({ projectType, projectPermissions }) => canPerformActionByProjectType(projectType, {
5
+ classic: () => has(projectPermissions, "download"),
6
+ // This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported
7
+ // so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.
8
+ // The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively
9
+ // simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).
10
+ // The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,
11
+ // but will need to remove this first part of the check.
12
+ marketing: () => hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has(projectPermissions, "download")
13
+ });
3
14
  export {
4
- deleteProjects
15
+ downloadFiles
5
16
  };
6
17
  //# sourceMappingURL=harmony146.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony146.mjs","sources":["../src/features/permissions/action-resolvers/deleteProjects.ts"],"sourcesContent":["import type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const deleteProjects: ActionResolver = ({ projectPermissions }) =>\n\thas(projectPermissions, 'settings')\n"],"names":[],"mappings":";AAGO,MAAM,iBAAiC,CAAC,EAAE,mBAChD,MAAA,IAAI,oBAAoB,UAAU;"}
1
+ {"version":3,"file":"harmony146.mjs","sources":["../src/features/permissions/actionResolvers/downloadFiles.ts"],"sourcesContent":["import type { ActionResolver } from '../types/actionResolver'\nimport { canPerformActionByProjectType } from '../utils/canPerformActionByProjectType'\nimport { has } from '../utils/has'\nimport { hasAny } from '../utils/hasAny'\n\nexport const downloadFiles: ActionResolver = ({ projectType, projectPermissions }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'download'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'download'),\n\t})\n"],"names":[],"mappings":";;;AAKO,MAAM,gBAAgC,CAAC,EAAE,aAAa,mBAAmB,MAC/E,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAM,IAAI,oBAAoB,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQjD,WAAW,MACV,OAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzE,IAAI,oBAAoB,UAAU;AACpC,CAAC;"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const has = require("./harmony125.cjs");
3
+ const has = require("./harmony122.cjs");
4
4
  const manageContributors = ({ projectPermissions }) => has.has(projectPermissions, "contributors");
5
5
  exports.manageContributors = manageContributors;
6
6
  //# sourceMappingURL=harmony147.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony147.cjs","sources":["../src/features/permissions/action-resolvers/manageContributors.ts"],"sourcesContent":["import type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const manageContributors: ActionResolver = ({ projectPermissions }) =>\n\thas(projectPermissions, 'contributors')\n"],"names":["has"],"mappings":";;;AAGO,MAAM,qBAAqC,CAAC,EAAE,mBACpD,MAAAA,IAAA,IAAI,oBAAoB,cAAc;;"}
1
+ {"version":3,"file":"harmony147.cjs","sources":["../src/features/permissions/actionResolvers/manageContributors.ts"],"sourcesContent":["import type { ActionResolver } from '../types/actionResolver'\nimport { has } from '../utils/has'\n\nexport const manageContributors: ActionResolver = ({ projectPermissions }) =>\n\thas(projectPermissions, 'contributors')\n"],"names":["has"],"mappings":";;;AAGO,MAAM,qBAAqC,CAAC,EAAE,mBACpD,MAAAA,IAAA,IAAI,oBAAoB,cAAc;;"}
@@ -1,4 +1,4 @@
1
- import { has } from "./harmony125.mjs";
1
+ import { has } from "./harmony122.mjs";
2
2
  const manageContributors = ({ projectPermissions }) => has(projectPermissions, "contributors");
3
3
  export {
4
4
  manageContributors
@@ -1 +1 @@
1
- {"version":3,"file":"harmony147.mjs","sources":["../src/features/permissions/action-resolvers/manageContributors.ts"],"sourcesContent":["import type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const manageContributors: ActionResolver = ({ projectPermissions }) =>\n\thas(projectPermissions, 'contributors')\n"],"names":[],"mappings":";AAGO,MAAM,qBAAqC,CAAC,EAAE,mBACpD,MAAA,IAAI,oBAAoB,cAAc;"}
1
+ {"version":3,"file":"harmony147.mjs","sources":["../src/features/permissions/actionResolvers/manageContributors.ts"],"sourcesContent":["import type { ActionResolver } from '../types/actionResolver'\nimport { has } from '../utils/has'\n\nexport const manageContributors: ActionResolver = ({ projectPermissions }) =>\n\thas(projectPermissions, 'contributors')\n"],"names":[],"mappings":";AAGO,MAAM,qBAAqC,CAAC,EAAE,mBACpD,MAAA,IAAI,oBAAoB,cAAc;"}
@@ -1,17 +1,17 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const canPerformActionByProjectType = require("./harmony159.cjs");
4
- const hasAny = require("./harmony124.cjs");
5
- const has = require("./harmony125.cjs");
6
- const canDownloadFiles = ({ projectType, projectPermissions }) => canPerformActionByProjectType.canPerformActionByProjectType(projectType, {
7
- classic: () => has.has(projectPermissions, "download"),
3
+ const canPerformActionByProjectType = require("./harmony152.cjs");
4
+ const has = require("./harmony122.cjs");
5
+ const hasAny = require("./harmony121.cjs");
6
+ const uploadFiles = ({ projectPermissions, projectType }) => canPerformActionByProjectType.canPerformActionByProjectType(projectType, {
7
+ classic: () => has.has(projectPermissions, "upload"),
8
8
  // This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported
9
9
  // so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.
10
10
  // The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively
11
11
  // simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).
12
12
  // The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,
13
13
  // but will need to remove this first part of the check.
14
- marketing: () => hasAny.hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has.has(projectPermissions, "download")
14
+ marketing: () => hasAny.hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has.has(projectPermissions, "upload")
15
15
  });
16
- exports.canDownloadFiles = canDownloadFiles;
16
+ exports.uploadFiles = uploadFiles;
17
17
  //# sourceMappingURL=harmony148.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony148.cjs","sources":["../src/features/permissions/action-resolvers/canDownloadFiles.ts"],"sourcesContent":["import { canPerformActionByProjectType } from '@features/permissions/utils/canPerformActionByProjectType'\nimport { hasAny } from '@features/permissions/utils/hasAny'\nimport type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const canDownloadFiles: ActionResolver = ({ projectType, projectPermissions }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'download'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'download'),\n\t})\n"],"names":["canPerformActionByProjectType","has","hasAny"],"mappings":";;;;;AAKO,MAAM,mBAAmC,CAAC,EAAE,aAAa,mBAAmB,MAClFA,8BAAAA,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAMC,IAAAA,IAAI,oBAAoB,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQjD,WAAW,MACVC,cAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzED,QAAI,oBAAoB,UAAU;AACpC,CAAC;;"}
1
+ {"version":3,"file":"harmony148.cjs","sources":["../src/features/permissions/actionResolvers/uploadFiles.ts"],"sourcesContent":["import type { ActionResolver } from '../types/actionResolver'\nimport { canPerformActionByProjectType } from '../utils/canPerformActionByProjectType'\nimport { has } from '../utils/has'\nimport { hasAny } from '../utils/hasAny'\n\nexport const uploadFiles: ActionResolver = ({ projectPermissions, projectType }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'upload'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'upload'),\n\t})\n"],"names":["canPerformActionByProjectType","has","hasAny"],"mappings":";;;;;AAKO,MAAM,cAA8B,CAAC,EAAE,oBAAoB,YAAY,MAC7EA,8BAAAA,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAMC,IAAAA,IAAI,oBAAoB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ/C,WAAW,MACVC,cAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzED,QAAI,oBAAoB,QAAQ;AAClC,CAAC;;"}
@@ -1,17 +1,17 @@
1
- import { canPerformActionByProjectType } from "./harmony159.mjs";
2
- import { hasAny } from "./harmony124.mjs";
3
- import { has } from "./harmony125.mjs";
4
- const canDownloadFiles = ({ projectType, projectPermissions }) => canPerformActionByProjectType(projectType, {
5
- classic: () => has(projectPermissions, "download"),
1
+ import { canPerformActionByProjectType } from "./harmony152.mjs";
2
+ import { has } from "./harmony122.mjs";
3
+ import { hasAny } from "./harmony121.mjs";
4
+ const uploadFiles = ({ projectPermissions, projectType }) => canPerformActionByProjectType(projectType, {
5
+ classic: () => has(projectPermissions, "upload"),
6
6
  // This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported
7
7
  // so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.
8
8
  // The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively
9
9
  // simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).
10
10
  // The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,
11
11
  // but will need to remove this first part of the check.
12
- marketing: () => hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has(projectPermissions, "download")
12
+ marketing: () => hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has(projectPermissions, "upload")
13
13
  });
14
14
  export {
15
- canDownloadFiles
15
+ uploadFiles
16
16
  };
17
17
  //# sourceMappingURL=harmony148.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony148.mjs","sources":["../src/features/permissions/action-resolvers/canDownloadFiles.ts"],"sourcesContent":["import { canPerformActionByProjectType } from '@features/permissions/utils/canPerformActionByProjectType'\nimport { hasAny } from '@features/permissions/utils/hasAny'\nimport type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const canDownloadFiles: ActionResolver = ({ projectType, projectPermissions }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'download'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'download'),\n\t})\n"],"names":[],"mappings":";;;AAKO,MAAM,mBAAmC,CAAC,EAAE,aAAa,mBAAmB,MAClF,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAM,IAAI,oBAAoB,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQjD,WAAW,MACV,OAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzE,IAAI,oBAAoB,UAAU;AACpC,CAAC;"}
1
+ {"version":3,"file":"harmony148.mjs","sources":["../src/features/permissions/actionResolvers/uploadFiles.ts"],"sourcesContent":["import type { ActionResolver } from '../types/actionResolver'\nimport { canPerformActionByProjectType } from '../utils/canPerformActionByProjectType'\nimport { has } from '../utils/has'\nimport { hasAny } from '../utils/hasAny'\n\nexport const uploadFiles: ActionResolver = ({ projectPermissions, projectType }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'upload'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'upload'),\n\t})\n"],"names":[],"mappings":";;;AAKO,MAAM,cAA8B,CAAC,EAAE,oBAAoB,YAAY,MAC7E,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAM,IAAI,oBAAoB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ/C,WAAW,MACV,OAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzE,IAAI,oBAAoB,QAAQ;AAClC,CAAC;"}
@@ -1,17 +1,8 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const canPerformActionByProjectType = require("./harmony159.cjs");
4
- const hasAny = require("./harmony124.cjs");
5
- const has = require("./harmony125.cjs");
6
- const canUploadFiles = ({ projectPermissions, projectType }) => canPerformActionByProjectType.canPerformActionByProjectType(projectType, {
7
- classic: () => has.has(projectPermissions, "upload"),
8
- // This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported
9
- // so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.
10
- // The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively
11
- // simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).
12
- // The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,
13
- // but will need to remove this first part of the check.
14
- marketing: () => hasAny.hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has.has(projectPermissions, "upload")
15
- });
16
- exports.canUploadFiles = canUploadFiles;
2
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
+ const _commonjsHelpers = require("./harmony173.cjs");
4
+ const debounce$1 = require("./harmony153.cjs");
5
+ var debounceExports = debounce$1.__require();
6
+ const debounce = /* @__PURE__ */ _commonjsHelpers.getDefaultExportFromCjs(debounceExports);
7
+ exports.default = debounce;
17
8
  //# sourceMappingURL=harmony149.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony149.cjs","sources":["../src/features/permissions/action-resolvers/canUploadFiles.ts"],"sourcesContent":["import { canPerformActionByProjectType } from '@features/permissions/utils/canPerformActionByProjectType'\nimport { hasAny } from '@features/permissions/utils/hasAny'\nimport type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const canUploadFiles: ActionResolver = ({ projectPermissions, projectType }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'upload'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'upload'),\n\t})\n"],"names":["canPerformActionByProjectType","has","hasAny"],"mappings":";;;;;AAKO,MAAM,iBAAiC,CAAC,EAAE,oBAAoB,YAAY,MAChFA,8BAAAA,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAMC,IAAAA,IAAI,oBAAoB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ/C,WAAW,MACVC,cAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzED,QAAI,oBAAoB,QAAQ;AAClC,CAAC;;"}
1
+ {"version":3,"file":"harmony149.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
@@ -1,17 +1,8 @@
1
- import { canPerformActionByProjectType } from "./harmony159.mjs";
2
- import { hasAny } from "./harmony124.mjs";
3
- import { has } from "./harmony125.mjs";
4
- const canUploadFiles = ({ projectPermissions, projectType }) => canPerformActionByProjectType(projectType, {
5
- classic: () => has(projectPermissions, "upload"),
6
- // This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported
7
- // so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.
8
- // The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively
9
- // simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).
10
- // The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,
11
- // but will need to remove this first part of the check.
12
- marketing: () => hasAny(projectPermissions, "contributors", "settings", "manage_languages") || has(projectPermissions, "upload")
13
- });
1
+ import { getDefaultExportFromCjs } from "./harmony173.mjs";
2
+ import { __require as requireDebounce } from "./harmony153.mjs";
3
+ var debounceExports = requireDebounce();
4
+ const debounce = /* @__PURE__ */ getDefaultExportFromCjs(debounceExports);
14
5
  export {
15
- canUploadFiles
6
+ debounce as default
16
7
  };
17
8
  //# sourceMappingURL=harmony149.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony149.mjs","sources":["../src/features/permissions/action-resolvers/canUploadFiles.ts"],"sourcesContent":["import { canPerformActionByProjectType } from '@features/permissions/utils/canPerformActionByProjectType'\nimport { hasAny } from '@features/permissions/utils/hasAny'\nimport type { ActionResolver } from '../types'\nimport { has } from '../utils/has'\n\nexport const canUploadFiles: ActionResolver = ({ projectPermissions, projectType }) =>\n\tcanPerformActionByProjectType(projectType, {\n\t\tclassic: () => has(projectPermissions, 'upload'),\n\n\t\t// This is a temporary workaround for the marketing project type - upload and download permissions are not yet supported\n\t\t// so to restrict translators from accessing the upload/download page we are checking that they have any permissions at all.\n\t\t// The reason for this is that, at the moment, the Translators role will assign no permissions to the user. So we are effectively\n\t\t// simulating a check for 'is this user a translator?' (since project 'roles' don't actually exist).\n\t\t// The correct check is to check for upload permission, so when that is implemented this will continue to work as expected,\n\t\t// but will need to remove this first part of the check.\n\t\tmarketing: () =>\n\t\t\thasAny(projectPermissions, 'contributors', 'settings', 'manage_languages') ||\n\t\t\thas(projectPermissions, 'upload'),\n\t})\n"],"names":[],"mappings":";;;AAKO,MAAM,iBAAiC,CAAC,EAAE,oBAAoB,YAAY,MAChF,8BAA8B,aAAa;AAAA,EAC1C,SAAS,MAAM,IAAI,oBAAoB,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ/C,WAAW,MACV,OAAO,oBAAoB,gBAAgB,YAAY,kBAAkB,KACzE,IAAI,oBAAoB,QAAQ;AAClC,CAAC;"}
1
+ {"version":3,"file":"harmony149.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const hasAny = require("./harmony124.cjs");
4
- const createProjects = ({ teamRole }) => hasAny.hasAny(teamRole, "owner", "biller", "admin");
5
- exports.createProjects = createProjects;
2
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
+ const _commonjsHelpers = require("./harmony173.cjs");
4
+ const throttle$1 = require("./harmony157.cjs");
5
+ var throttleExports = throttle$1.__require();
6
+ const throttle = /* @__PURE__ */ _commonjsHelpers.getDefaultExportFromCjs(throttleExports);
7
+ exports.default = throttle;
6
8
  //# sourceMappingURL=harmony150.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony150.cjs","sources":["../src/features/permissions/action-resolvers/createProjects.ts"],"sourcesContent":["import { hasAny } from '@features/permissions/utils/hasAny'\nimport type { ActionResolver } from '../types'\n\nexport const createProjects: ActionResolver = ({ teamRole }) =>\n\thasAny(teamRole, 'owner', 'biller', 'admin')\n"],"names":["hasAny"],"mappings":";;;AAGa,MAAA,iBAAiC,CAAC,EAAE,eAChDA,OAAO,OAAA,UAAU,SAAS,UAAU,OAAO;;"}
1
+ {"version":3,"file":"harmony150.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
@@ -1,6 +1,8 @@
1
- import { hasAny } from "./harmony124.mjs";
2
- const createProjects = ({ teamRole }) => hasAny(teamRole, "owner", "biller", "admin");
1
+ import { getDefaultExportFromCjs } from "./harmony173.mjs";
2
+ import { __require as requireThrottle } from "./harmony157.mjs";
3
+ var throttleExports = requireThrottle();
4
+ const throttle = /* @__PURE__ */ getDefaultExportFromCjs(throttleExports);
3
5
  export {
4
- createProjects
6
+ throttle as default
5
7
  };
6
8
  //# sourceMappingURL=harmony150.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony150.mjs","sources":["../src/features/permissions/action-resolvers/createProjects.ts"],"sourcesContent":["import { hasAny } from '@features/permissions/utils/hasAny'\nimport type { ActionResolver } from '../types'\n\nexport const createProjects: ActionResolver = ({ teamRole }) =>\n\thasAny(teamRole, 'owner', 'biller', 'admin')\n"],"names":[],"mappings":";AAGa,MAAA,iBAAiC,CAAC,EAAE,eAChD,OAAO,UAAU,SAAS,UAAU,OAAO;"}
1
+ {"version":3,"file":"harmony150.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -1,8 +1,13 @@
1
1
  "use strict";
2
- Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const _commonjsHelpers = require("./harmony175.cjs");
4
- const debounce$1 = require("./harmony154.cjs");
5
- var debounceExports = debounce$1.__require();
6
- const debounce = /* @__PURE__ */ _commonjsHelpers.getDefaultExportFromCjs(debounceExports);
7
- exports.default = debounce;
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const hasAdminRight = (adminRights, right) => {
4
+ if (!Array.isArray(adminRights)) return false;
5
+ return adminRights.includes(right);
6
+ };
7
+ const hasAnyAdminRight = (adminRights, rights) => {
8
+ if (!Array.isArray(adminRights)) return false;
9
+ return rights.some((right) => adminRights.includes(right));
10
+ };
11
+ exports.hasAdminRight = hasAdminRight;
12
+ exports.hasAnyAdminRight = hasAnyAdminRight;
8
13
  //# sourceMappingURL=harmony151.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony151.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
1
+ {"version":3,"file":"harmony151.cjs","sources":["../src/features/auth/utils/permissions.ts"],"sourcesContent":["// Helper function to check if user has a specific admin right\nexport const hasAdminRight = (adminRights: string[], right: string): boolean => {\n\tif (!Array.isArray(adminRights)) return false\n\treturn adminRights.includes(right)\n}\n\n// Helper function to check if user has any of the specified admin rights\nexport const hasAnyAdminRight = (adminRights: string[], rights: string[]): boolean => {\n\tif (!Array.isArray(adminRights)) return false\n\treturn rights.some((right) => adminRights.includes(right))\n}\n"],"names":[],"mappings":";;AACa,MAAA,gBAAgB,CAAC,aAAuB,UAA2B;AAC/E,MAAI,CAAC,MAAM,QAAQ,WAAW,EAAU,QAAA;AACjC,SAAA,YAAY,SAAS,KAAK;AAClC;AAGa,MAAA,mBAAmB,CAAC,aAAuB,WAA8B;AACrF,MAAI,CAAC,MAAM,QAAQ,WAAW,EAAU,QAAA;AACxC,SAAO,OAAO,KAAK,CAAC,UAAU,YAAY,SAAS,KAAK,CAAC;AAC1D;;;"}
@@ -1,8 +1,13 @@
1
- import { getDefaultExportFromCjs } from "./harmony175.mjs";
2
- import { __require as requireDebounce } from "./harmony154.mjs";
3
- var debounceExports = requireDebounce();
4
- const debounce = /* @__PURE__ */ getDefaultExportFromCjs(debounceExports);
1
+ const hasAdminRight = (adminRights, right) => {
2
+ if (!Array.isArray(adminRights)) return false;
3
+ return adminRights.includes(right);
4
+ };
5
+ const hasAnyAdminRight = (adminRights, rights) => {
6
+ if (!Array.isArray(adminRights)) return false;
7
+ return rights.some((right) => adminRights.includes(right));
8
+ };
5
9
  export {
6
- debounce as default
10
+ hasAdminRight,
11
+ hasAnyAdminRight
7
12
  };
8
13
  //# sourceMappingURL=harmony151.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony151.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
1
+ {"version":3,"file":"harmony151.mjs","sources":["../src/features/auth/utils/permissions.ts"],"sourcesContent":["// Helper function to check if user has a specific admin right\nexport const hasAdminRight = (adminRights: string[], right: string): boolean => {\n\tif (!Array.isArray(adminRights)) return false\n\treturn adminRights.includes(right)\n}\n\n// Helper function to check if user has any of the specified admin rights\nexport const hasAnyAdminRight = (adminRights: string[], rights: string[]): boolean => {\n\tif (!Array.isArray(adminRights)) return false\n\treturn rights.some((right) => adminRights.includes(right))\n}\n"],"names":[],"mappings":"AACa,MAAA,gBAAgB,CAAC,aAAuB,UAA2B;AAC/E,MAAI,CAAC,MAAM,QAAQ,WAAW,EAAU,QAAA;AACjC,SAAA,YAAY,SAAS,KAAK;AAClC;AAGa,MAAA,mBAAmB,CAAC,aAAuB,WAA8B;AACrF,MAAI,CAAC,MAAM,QAAQ,WAAW,EAAU,QAAA;AACxC,SAAO,OAAO,KAAK,CAAC,UAAU,YAAY,SAAS,KAAK,CAAC;AAC1D;"}
@@ -1,8 +1,35 @@
1
1
  "use strict";
2
- Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const _commonjsHelpers = require("./harmony175.cjs");
4
- const throttle$1 = require("./harmony158.cjs");
5
- var throttleExports = throttle$1.__require();
6
- const throttle = /* @__PURE__ */ _commonjsHelpers.getDefaultExportFromCjs(throttleExports);
7
- exports.default = throttle;
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const assertIsNever = require("./harmony168.cjs");
4
+ const isCategoryProjectTypeMatch = (matcher) => "marketing" in matcher && typeof matcher.marketing === "function" && "classic" in matcher && typeof matcher.classic === "function";
5
+ const isPartialProjectTypeMatch = (matcher) => "otherwise" in matcher && typeof matcher.otherwise === "function";
6
+ const isFullProjectTypeMatch = (matcher) => !isCategoryProjectTypeMatch(matcher) && !isPartialProjectTypeMatch(matcher);
7
+ const callMatchFunction = (matcher, category, projectType) => {
8
+ if (isFullProjectTypeMatch(matcher)) {
9
+ return matcher[projectType]();
10
+ }
11
+ if (isPartialProjectTypeMatch(matcher)) {
12
+ return (matcher[projectType] || matcher.otherwise)();
13
+ }
14
+ if (isCategoryProjectTypeMatch(matcher)) {
15
+ return matcher[category]();
16
+ }
17
+ return false;
18
+ };
19
+ const canPerformActionByProjectType = (projectType, match) => {
20
+ switch (projectType) {
21
+ case void 0:
22
+ return false;
23
+ case "localization_files":
24
+ case "paged_documents":
25
+ case "content_integration":
26
+ return callMatchFunction(match, "classic", projectType);
27
+ case "marketing":
28
+ case "marketing_integrations":
29
+ return callMatchFunction(match, "marketing", projectType);
30
+ default:
31
+ return assertIsNever.assertIsNever(projectType);
32
+ }
33
+ };
34
+ exports.canPerformActionByProjectType = canPerformActionByProjectType;
8
35
  //# sourceMappingURL=harmony152.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony152.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
1
+ {"version":3,"file":"harmony152.cjs","sources":["../src/features/permissions/utils/canPerformActionByProjectType.ts"],"sourcesContent":["import { assertIsNever } from '@utils/types/assertIsNever'\n\nimport type { ProjectType } from '../types/projectType'\n\ntype FullProjectTypeMatch = { [K in ProjectType]: () => boolean }\ntype PartialProjectTypeMatch = { [K in ProjectType]?: () => boolean } & { otherwise: () => boolean }\ntype CategoryProjectTypeMatch = { classic: () => boolean; marketing: () => boolean }\n\ntype ProjectTypeMatch = FullProjectTypeMatch | PartialProjectTypeMatch | CategoryProjectTypeMatch\n\nconst isCategoryProjectTypeMatch = (\n\tmatcher: ProjectTypeMatch,\n): matcher is CategoryProjectTypeMatch =>\n\t'marketing' in matcher &&\n\ttypeof matcher.marketing === 'function' &&\n\t'classic' in matcher &&\n\ttypeof matcher.classic === 'function'\n\nconst isPartialProjectTypeMatch = (matcher: ProjectTypeMatch): matcher is PartialProjectTypeMatch =>\n\t'otherwise' in matcher && typeof matcher.otherwise === 'function'\n\nconst isFullProjectTypeMatch = (matcher: ProjectTypeMatch): matcher is FullProjectTypeMatch =>\n\t!isCategoryProjectTypeMatch(matcher) && !isPartialProjectTypeMatch(matcher)\n\nconst callMatchFunction = (\n\tmatcher: ProjectTypeMatch,\n\tcategory: 'classic' | 'marketing',\n\tprojectType: ProjectType,\n): boolean => {\n\tif (isFullProjectTypeMatch(matcher)) {\n\t\treturn matcher[projectType]()\n\t}\n\n\tif (isPartialProjectTypeMatch(matcher)) {\n\t\treturn (matcher[projectType] || matcher.otherwise)()\n\t}\n\n\tif (isCategoryProjectTypeMatch(matcher)) {\n\t\treturn matcher[category]()\n\t}\n\n\treturn false\n}\n\nexport const canPerformActionByProjectType = (\n\tprojectType: ProjectType | undefined,\n\tmatch: ProjectTypeMatch,\n) => {\n\tswitch (projectType) {\n\t\tcase undefined:\n\t\t\treturn false\n\n\t\tcase 'localization_files':\n\t\tcase 'paged_documents':\n\t\tcase 'content_integration':\n\t\t\treturn callMatchFunction(match, 'classic', projectType)\n\n\t\tcase 'marketing':\n\t\tcase 'marketing_integrations':\n\t\t\treturn callMatchFunction(match, 'marketing', projectType)\n\n\t\tdefault:\n\t\t\treturn assertIsNever(projectType)\n\t}\n}\n"],"names":["assertIsNever"],"mappings":";;;AAUA,MAAM,6BAA6B,CAClC,YAEA,eAAe,WACf,OAAO,QAAQ,cAAc,cAC7B,aAAa,WACb,OAAO,QAAQ,YAAY;AAE5B,MAAM,4BAA4B,CAAC,YAClC,eAAe,WAAW,OAAO,QAAQ,cAAc;AAExD,MAAM,yBAAyB,CAAC,YAC/B,CAAC,2BAA2B,OAAO,KAAK,CAAC,0BAA0B,OAAO;AAE3E,MAAM,oBAAoB,CACzB,SACA,UACA,gBACa;AACT,MAAA,uBAAuB,OAAO,GAAG;AAC7B,WAAA,QAAQ,WAAW,EAAE;AAAA,EAAA;AAGzB,MAAA,0BAA0B,OAAO,GAAG;AACvC,YAAQ,QAAQ,WAAW,KAAK,QAAQ,WAAW;AAAA,EAAA;AAGhD,MAAA,2BAA2B,OAAO,GAAG;AACjC,WAAA,QAAQ,QAAQ,EAAE;AAAA,EAAA;AAGnB,SAAA;AACR;AAEa,MAAA,gCAAgC,CAC5C,aACA,UACI;AACJ,UAAQ,aAAa;AAAA,IACpB,KAAK;AACG,aAAA;AAAA,IAER,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACG,aAAA,kBAAkB,OAAO,WAAW,WAAW;AAAA,IAEvD,KAAK;AAAA,IACL,KAAK;AACG,aAAA,kBAAkB,OAAO,aAAa,WAAW;AAAA,IAEzD;AACC,aAAOA,cAAAA,cAAc,WAAW;AAAA,EAAA;AAEnC;;"}
@@ -1,8 +1,35 @@
1
- import { getDefaultExportFromCjs } from "./harmony175.mjs";
2
- import { __require as requireThrottle } from "./harmony158.mjs";
3
- var throttleExports = requireThrottle();
4
- const throttle = /* @__PURE__ */ getDefaultExportFromCjs(throttleExports);
1
+ import { assertIsNever } from "./harmony168.mjs";
2
+ const isCategoryProjectTypeMatch = (matcher) => "marketing" in matcher && typeof matcher.marketing === "function" && "classic" in matcher && typeof matcher.classic === "function";
3
+ const isPartialProjectTypeMatch = (matcher) => "otherwise" in matcher && typeof matcher.otherwise === "function";
4
+ const isFullProjectTypeMatch = (matcher) => !isCategoryProjectTypeMatch(matcher) && !isPartialProjectTypeMatch(matcher);
5
+ const callMatchFunction = (matcher, category, projectType) => {
6
+ if (isFullProjectTypeMatch(matcher)) {
7
+ return matcher[projectType]();
8
+ }
9
+ if (isPartialProjectTypeMatch(matcher)) {
10
+ return (matcher[projectType] || matcher.otherwise)();
11
+ }
12
+ if (isCategoryProjectTypeMatch(matcher)) {
13
+ return matcher[category]();
14
+ }
15
+ return false;
16
+ };
17
+ const canPerformActionByProjectType = (projectType, match) => {
18
+ switch (projectType) {
19
+ case void 0:
20
+ return false;
21
+ case "localization_files":
22
+ case "paged_documents":
23
+ case "content_integration":
24
+ return callMatchFunction(match, "classic", projectType);
25
+ case "marketing":
26
+ case "marketing_integrations":
27
+ return callMatchFunction(match, "marketing", projectType);
28
+ default:
29
+ return assertIsNever(projectType);
30
+ }
31
+ };
5
32
  export {
6
- throttle as default
33
+ canPerformActionByProjectType
7
34
  };
8
35
  //# sourceMappingURL=harmony152.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony152.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
1
+ {"version":3,"file":"harmony152.mjs","sources":["../src/features/permissions/utils/canPerformActionByProjectType.ts"],"sourcesContent":["import { assertIsNever } from '@utils/types/assertIsNever'\n\nimport type { ProjectType } from '../types/projectType'\n\ntype FullProjectTypeMatch = { [K in ProjectType]: () => boolean }\ntype PartialProjectTypeMatch = { [K in ProjectType]?: () => boolean } & { otherwise: () => boolean }\ntype CategoryProjectTypeMatch = { classic: () => boolean; marketing: () => boolean }\n\ntype ProjectTypeMatch = FullProjectTypeMatch | PartialProjectTypeMatch | CategoryProjectTypeMatch\n\nconst isCategoryProjectTypeMatch = (\n\tmatcher: ProjectTypeMatch,\n): matcher is CategoryProjectTypeMatch =>\n\t'marketing' in matcher &&\n\ttypeof matcher.marketing === 'function' &&\n\t'classic' in matcher &&\n\ttypeof matcher.classic === 'function'\n\nconst isPartialProjectTypeMatch = (matcher: ProjectTypeMatch): matcher is PartialProjectTypeMatch =>\n\t'otherwise' in matcher && typeof matcher.otherwise === 'function'\n\nconst isFullProjectTypeMatch = (matcher: ProjectTypeMatch): matcher is FullProjectTypeMatch =>\n\t!isCategoryProjectTypeMatch(matcher) && !isPartialProjectTypeMatch(matcher)\n\nconst callMatchFunction = (\n\tmatcher: ProjectTypeMatch,\n\tcategory: 'classic' | 'marketing',\n\tprojectType: ProjectType,\n): boolean => {\n\tif (isFullProjectTypeMatch(matcher)) {\n\t\treturn matcher[projectType]()\n\t}\n\n\tif (isPartialProjectTypeMatch(matcher)) {\n\t\treturn (matcher[projectType] || matcher.otherwise)()\n\t}\n\n\tif (isCategoryProjectTypeMatch(matcher)) {\n\t\treturn matcher[category]()\n\t}\n\n\treturn false\n}\n\nexport const canPerformActionByProjectType = (\n\tprojectType: ProjectType | undefined,\n\tmatch: ProjectTypeMatch,\n) => {\n\tswitch (projectType) {\n\t\tcase undefined:\n\t\t\treturn false\n\n\t\tcase 'localization_files':\n\t\tcase 'paged_documents':\n\t\tcase 'content_integration':\n\t\t\treturn callMatchFunction(match, 'classic', projectType)\n\n\t\tcase 'marketing':\n\t\tcase 'marketing_integrations':\n\t\t\treturn callMatchFunction(match, 'marketing', projectType)\n\n\t\tdefault:\n\t\t\treturn assertIsNever(projectType)\n\t}\n}\n"],"names":[],"mappings":";AAUA,MAAM,6BAA6B,CAClC,YAEA,eAAe,WACf,OAAO,QAAQ,cAAc,cAC7B,aAAa,WACb,OAAO,QAAQ,YAAY;AAE5B,MAAM,4BAA4B,CAAC,YAClC,eAAe,WAAW,OAAO,QAAQ,cAAc;AAExD,MAAM,yBAAyB,CAAC,YAC/B,CAAC,2BAA2B,OAAO,KAAK,CAAC,0BAA0B,OAAO;AAE3E,MAAM,oBAAoB,CACzB,SACA,UACA,gBACa;AACT,MAAA,uBAAuB,OAAO,GAAG;AAC7B,WAAA,QAAQ,WAAW,EAAE;AAAA,EAAA;AAGzB,MAAA,0BAA0B,OAAO,GAAG;AACvC,YAAQ,QAAQ,WAAW,KAAK,QAAQ,WAAW;AAAA,EAAA;AAGhD,MAAA,2BAA2B,OAAO,GAAG;AACjC,WAAA,QAAQ,QAAQ,EAAE;AAAA,EAAA;AAGnB,SAAA;AACR;AAEa,MAAA,gCAAgC,CAC5C,aACA,UACI;AACJ,UAAQ,aAAa;AAAA,IACpB,KAAK;AACG,aAAA;AAAA,IAER,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACG,aAAA,kBAAkB,OAAO,WAAW,WAAW;AAAA,IAEvD,KAAK;AAAA,IACL,KAAK;AACG,aAAA,kBAAkB,OAAO,aAAa,WAAW;AAAA,IAEzD;AACC,aAAO,cAAc,WAAW;AAAA,EAAA;AAEnC;"}
@@ -1,13 +1,99 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const hasAdminRight = (adminRights, right) => {
4
- if (!Array.isArray(adminRights)) return false;
5
- return adminRights.includes(right);
6
- };
7
- const hasAnyAdminRight = (adminRights, rights) => {
8
- if (!Array.isArray(adminRights)) return false;
9
- return rights.some((right) => adminRights.includes(right));
10
- };
11
- exports.hasAdminRight = hasAdminRight;
12
- exports.hasAnyAdminRight = hasAnyAdminRight;
3
+ const isObject = require("./harmony154.cjs");
4
+ const now = require("./harmony155.cjs");
5
+ const toNumber = require("./harmony156.cjs");
6
+ var debounce_1;
7
+ var hasRequiredDebounce;
8
+ function requireDebounce() {
9
+ if (hasRequiredDebounce) return debounce_1;
10
+ hasRequiredDebounce = 1;
11
+ var isObject$1 = isObject.__require(), now$1 = now.__require(), toNumber$1 = toNumber.__require();
12
+ var FUNC_ERROR_TEXT = "Expected a function";
13
+ var nativeMax = Math.max, nativeMin = Math.min;
14
+ function debounce(func, wait, options) {
15
+ var lastArgs, lastThis, maxWait, result, timerId, lastCallTime, lastInvokeTime = 0, leading = false, maxing = false, trailing = true;
16
+ if (typeof func != "function") {
17
+ throw new TypeError(FUNC_ERROR_TEXT);
18
+ }
19
+ wait = toNumber$1(wait) || 0;
20
+ if (isObject$1(options)) {
21
+ leading = !!options.leading;
22
+ maxing = "maxWait" in options;
23
+ maxWait = maxing ? nativeMax(toNumber$1(options.maxWait) || 0, wait) : maxWait;
24
+ trailing = "trailing" in options ? !!options.trailing : trailing;
25
+ }
26
+ function invokeFunc(time) {
27
+ var args = lastArgs, thisArg = lastThis;
28
+ lastArgs = lastThis = void 0;
29
+ lastInvokeTime = time;
30
+ result = func.apply(thisArg, args);
31
+ return result;
32
+ }
33
+ function leadingEdge(time) {
34
+ lastInvokeTime = time;
35
+ timerId = setTimeout(timerExpired, wait);
36
+ return leading ? invokeFunc(time) : result;
37
+ }
38
+ function remainingWait(time) {
39
+ var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime, timeWaiting = wait - timeSinceLastCall;
40
+ return maxing ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) : timeWaiting;
41
+ }
42
+ function shouldInvoke(time) {
43
+ var timeSinceLastCall = time - lastCallTime, timeSinceLastInvoke = time - lastInvokeTime;
44
+ return lastCallTime === void 0 || timeSinceLastCall >= wait || timeSinceLastCall < 0 || maxing && timeSinceLastInvoke >= maxWait;
45
+ }
46
+ function timerExpired() {
47
+ var time = now$1();
48
+ if (shouldInvoke(time)) {
49
+ return trailingEdge(time);
50
+ }
51
+ timerId = setTimeout(timerExpired, remainingWait(time));
52
+ }
53
+ function trailingEdge(time) {
54
+ timerId = void 0;
55
+ if (trailing && lastArgs) {
56
+ return invokeFunc(time);
57
+ }
58
+ lastArgs = lastThis = void 0;
59
+ return result;
60
+ }
61
+ function cancel() {
62
+ if (timerId !== void 0) {
63
+ clearTimeout(timerId);
64
+ }
65
+ lastInvokeTime = 0;
66
+ lastArgs = lastCallTime = lastThis = timerId = void 0;
67
+ }
68
+ function flush() {
69
+ return timerId === void 0 ? result : trailingEdge(now$1());
70
+ }
71
+ function debounced() {
72
+ var time = now$1(), isInvoking = shouldInvoke(time);
73
+ lastArgs = arguments;
74
+ lastThis = this;
75
+ lastCallTime = time;
76
+ if (isInvoking) {
77
+ if (timerId === void 0) {
78
+ return leadingEdge(lastCallTime);
79
+ }
80
+ if (maxing) {
81
+ clearTimeout(timerId);
82
+ timerId = setTimeout(timerExpired, wait);
83
+ return invokeFunc(lastCallTime);
84
+ }
85
+ }
86
+ if (timerId === void 0) {
87
+ timerId = setTimeout(timerExpired, wait);
88
+ }
89
+ return result;
90
+ }
91
+ debounced.cancel = cancel;
92
+ debounced.flush = flush;
93
+ return debounced;
94
+ }
95
+ debounce_1 = debounce;
96
+ return debounce_1;
97
+ }
98
+ exports.__require = requireDebounce;
13
99
  //# sourceMappingURL=harmony153.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"harmony153.cjs","sources":["../src/features/auth/utils/permissions.ts"],"sourcesContent":["// Helper function to check if user has a specific admin right\nexport const hasAdminRight = (adminRights: string[], right: string): boolean => {\n\tif (!Array.isArray(adminRights)) return false\n\treturn adminRights.includes(right)\n}\n\n// Helper function to check if user has any of the specified admin rights\nexport const hasAnyAdminRight = (adminRights: string[], rights: string[]): boolean => {\n\tif (!Array.isArray(adminRights)) return false\n\treturn rights.some((right) => adminRights.includes(right))\n}\n"],"names":[],"mappings":";;AACa,MAAA,gBAAgB,CAAC,aAAuB,UAA2B;AAC/E,MAAI,CAAC,MAAM,QAAQ,WAAW,EAAU,QAAA;AACjC,SAAA,YAAY,SAAS,KAAK;AAClC;AAGa,MAAA,mBAAmB,CAAC,aAAuB,WAA8B;AACrF,MAAI,CAAC,MAAM,QAAQ,WAAW,EAAU,QAAA;AACxC,SAAO,OAAO,KAAK,CAAC,UAAU,YAAY,SAAS,KAAK,CAAC;AAC1D;;;"}
1
+ {"version":3,"file":"harmony153.cjs","sources":["../node_modules/lodash/debounce.js"],"sourcesContent":["var isObject = require('./isObject'),\n now = require('./now'),\n toNumber = require('./toNumber');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\nmodule.exports = debounce;\n"],"names":["isObject","require$$0","now","require$$1","toNumber","require$$2"],"mappings":";;;;;;;;;;AAAA,MAAIA,aAAWC,SAAAA,UAAqB,GAChCC,QAAMC,IAAAA,UAAgB,GACtBC,aAAWC,SAAAA,UAAqB;AAGpC,MAAI,kBAAkB;AAGtB,MAAI,YAAY,KAAK,KACjB,YAAY,KAAK;AAwDrB,WAAS,SAAS,MAAM,MAAM,SAAS;AACrC,QAAI,UACA,UACA,SACA,QACA,SACA,cACA,iBAAiB,GACjB,UAAU,OACV,SAAS,OACT,WAAW;AAEf,QAAI,OAAO,QAAQ,YAAY;AAC7B,YAAM,IAAI,UAAU,eAAe;AAAA,IACvC;AACE,WAAOD,WAAS,IAAI,KAAK;AACzB,QAAIJ,WAAS,OAAO,GAAG;AACrB,gBAAU,CAAC,CAAC,QAAQ;AACpB,eAAS,aAAa;AACtB,gBAAU,SAAS,UAAUI,WAAS,QAAQ,OAAO,KAAK,GAAG,IAAI,IAAI;AACrE,iBAAW,cAAc,UAAU,CAAC,CAAC,QAAQ,WAAW;AAAA,IAC5D;AAEE,aAAS,WAAW,MAAM;AACxB,UAAI,OAAO,UACP,UAAU;AAEd,iBAAW,WAAW;AACtB,uBAAiB;AACjB,eAAS,KAAK,MAAM,SAAS,IAAI;AACjC,aAAO;AAAA,IACX;AAEE,aAAS,YAAY,MAAM;AAEzB,uBAAiB;AAEjB,gBAAU,WAAW,cAAc,IAAI;AAEvC,aAAO,UAAU,WAAW,IAAI,IAAI;AAAA,IACxC;AAEE,aAAS,cAAc,MAAM;AAC3B,UAAI,oBAAoB,OAAO,cAC3B,sBAAsB,OAAO,gBAC7B,cAAc,OAAO;AAEzB,aAAO,SACH,UAAU,aAAa,UAAU,mBAAmB,IACpD;AAAA,IACR;AAEE,aAAS,aAAa,MAAM;AAC1B,UAAI,oBAAoB,OAAO,cAC3B,sBAAsB,OAAO;AAKjC,aAAQ,iBAAiB,UAAc,qBAAqB,QACzD,oBAAoB,KAAO,UAAU,uBAAuB;AAAA,IACnE;AAEE,aAAS,eAAe;AACtB,UAAI,OAAOF,MAAK;AAChB,UAAI,aAAa,IAAI,GAAG;AACtB,eAAO,aAAa,IAAI;AAAA,MAC9B;AAEI,gBAAU,WAAW,cAAc,cAAc,IAAI,CAAC;AAAA,IAC1D;AAEE,aAAS,aAAa,MAAM;AAC1B,gBAAU;AAIV,UAAI,YAAY,UAAU;AACxB,eAAO,WAAW,IAAI;AAAA,MAC5B;AACI,iBAAW,WAAW;AACtB,aAAO;AAAA,IACX;AAEE,aAAS,SAAS;AAChB,UAAI,YAAY,QAAW;AACzB,qBAAa,OAAO;AAAA,MAC1B;AACI,uBAAiB;AACjB,iBAAW,eAAe,WAAW,UAAU;AAAA,IACnD;AAEE,aAAS,QAAQ;AACf,aAAO,YAAY,SAAY,SAAS,aAAaA,MAAG,CAAE;AAAA,IAC9D;AAEE,aAAS,YAAY;AACnB,UAAI,OAAOA,MAAK,GACZ,aAAa,aAAa,IAAI;AAElC,iBAAW;AACX,iBAAW;AACX,qBAAe;AAEf,UAAI,YAAY;AACd,YAAI,YAAY,QAAW;AACzB,iBAAO,YAAY,YAAY;AAAA,QACvC;AACM,YAAI,QAAQ;AAEV,uBAAa,OAAO;AACpB,oBAAU,WAAW,cAAc,IAAI;AACvC,iBAAO,WAAW,YAAY;AAAA,QACtC;AAAA,MACA;AACI,UAAI,YAAY,QAAW;AACzB,kBAAU,WAAW,cAAc,IAAI;AAAA,MAC7C;AACI,aAAO;AAAA,IACX;AACE,cAAU,SAAS;AACnB,cAAU,QAAQ;AAClB,WAAO;AAAA,EACT;AAEA,eAAiB;;;;","x_google_ignoreList":[0]}