@cuemath/leap 2.8.25 → 2.8.26

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 (238) hide show
  1. package/dist/assets/lottie/lottie.js +61 -0
  2. package/dist/assets/lottie/lottie.js.map +1 -0
  3. package/dist/features/circle-games/game-launcher/comps/segmented-game-card/segmented-game-card.js +81 -79
  4. package/dist/features/circle-games/game-launcher/comps/segmented-game-card/segmented-game-card.js.map +1 -1
  5. package/dist/features/circle-games/game-launcher/game-launcher.js +61 -65
  6. package/dist/features/circle-games/game-launcher/game-launcher.js.map +1 -1
  7. package/dist/features/circle-games/leaderboard/comps/banner/banner.js +35 -53
  8. package/dist/features/circle-games/leaderboard/comps/banner/banner.js.map +1 -1
  9. package/dist/features/circle-games/leaderboard/leaderboard.js +56 -55
  10. package/dist/features/circle-games/leaderboard/leaderboard.js.map +1 -1
  11. package/dist/features/circle-games/sign-up/comp/circular-steps/circular-steps.js +40 -41
  12. package/dist/features/circle-games/sign-up/comp/circular-steps/circular-steps.js.map +1 -1
  13. package/dist/features/circle-games/sign-up/comp/spinner/spinner-styled.js +4 -8
  14. package/dist/features/circle-games/sign-up/comp/spinner/spinner-styled.js.map +1 -1
  15. package/dist/features/circle-games/sign-up/comp/spinner/spinner.js +6 -23
  16. package/dist/features/circle-games/sign-up/comp/spinner/spinner.js.map +1 -1
  17. package/dist/features/circle-games/sign-up/comp/splash-screen/splash-screen.js +40 -35
  18. package/dist/features/circle-games/sign-up/comp/splash-screen/splash-screen.js.map +1 -1
  19. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/difficulty-and-duration-selection/difficulty-and-duration-selection.js +2 -2
  20. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/difficulty-and-duration-selection/test-radio-card/test-card-lottie-animation.js +8 -23
  21. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/difficulty-and-duration-selection/test-radio-card/test-card-lottie-animation.js.map +1 -1
  22. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/difficulty-and-duration-selection/test-radio-card/test-radio-card.js +11 -11
  23. package/dist/features/milestone/milestone-tests/tests-creation/test-stages/difficulty-and-duration-selection/test-radio-card/test-radio-card.js.map +1 -1
  24. package/dist/features/milestone/milestone-tests/tests-creation/utils/index.js +37 -43
  25. package/dist/features/milestone/milestone-tests/tests-creation/utils/index.js.map +1 -1
  26. package/dist/features/post-game-stats/accuracy/accuracy.js +38 -34
  27. package/dist/features/post-game-stats/accuracy/accuracy.js.map +1 -1
  28. package/dist/features/post-game-stats/clock/clock.js +43 -39
  29. package/dist/features/post-game-stats/clock/clock.js.map +1 -1
  30. package/dist/features/post-game-stats/points/points.js +43 -44
  31. package/dist/features/post-game-stats/points/points.js.map +1 -1
  32. package/dist/features/post-game-stats/streak/streak.js +30 -28
  33. package/dist/features/post-game-stats/streak/streak.js.map +1 -1
  34. package/dist/features/trial-session/comps/av-panels/teacher-av-panel/teacher-av-panel.js +56 -54
  35. package/dist/features/trial-session/comps/av-panels/teacher-av-panel/teacher-av-panel.js.map +1 -1
  36. package/dist/features/trial-session/comps/parent-app/parent-app.js +25 -20
  37. package/dist/features/trial-session/comps/parent-app/parent-app.js.map +1 -1
  38. package/dist/features/trial-session/comps/school-goals/school-goals-view.js +4 -4
  39. package/dist/features/trial-session/comps/school-goals/school-goals-view.js.map +1 -1
  40. package/dist/features/trial-session/comps/session-insights/session-insights.js +40 -39
  41. package/dist/features/trial-session/comps/session-insights/session-insights.js.map +1 -1
  42. package/dist/features/trial-session/trial-session-view.js +95 -79
  43. package/dist/features/trial-session/trial-session-view.js.map +1 -1
  44. package/dist/features/ui/loader/circular-loader/circular-loader.js +16 -20
  45. package/dist/features/ui/loader/circular-loader/circular-loader.js.map +1 -1
  46. package/dist/features/ui/lottie-animation/helper.js +13 -0
  47. package/dist/features/ui/lottie-animation/helper.js.map +1 -0
  48. package/dist/features/ui/lottie-animation/lottie-animation.js +37 -0
  49. package/dist/features/ui/lottie-animation/lottie-animation.js.map +1 -0
  50. package/dist/features/ui/nudge/nudge-styled.js +4 -8
  51. package/dist/features/ui/nudge/nudge-styled.js.map +1 -1
  52. package/dist/features/ui/nudge/nudge.js +13 -30
  53. package/dist/features/ui/nudge/nudge.js.map +1 -1
  54. package/dist/features/ui/perfect-hits/perfect-hits-helpers.js +22 -20
  55. package/dist/features/ui/perfect-hits/perfect-hits-helpers.js.map +1 -1
  56. package/dist/features/worksheet/worksheet/worksheet-permissions/error.js +25 -48
  57. package/dist/features/worksheet/worksheet/worksheet-permissions/error.js.map +1 -1
  58. package/dist/features/worksheet/worksheet/worksheet-question/header/validated-animation.js +12 -26
  59. package/dist/features/worksheet/worksheet/worksheet-question/header/validated-animation.js.map +1 -1
  60. package/dist/index.d.ts +58 -0
  61. package/dist/index.js +466 -464
  62. package/dist/index.js.map +1 -1
  63. package/dist/static/accuracy-meter.99585cba.json +4218 -0
  64. package/dist/static/accuracy-needle.cd6e63ac.json +618 -0
  65. package/dist/static/beginner1x.489908a7.json +3508 -0
  66. package/dist/static/bronze-1.da4e4b5f.json +4176 -0
  67. package/dist/static/bronze-2.97f9c639.json +4433 -0
  68. package/dist/static/bronze-3.6a433ebd.json +4786 -0
  69. package/dist/static/circular-loader.a5a1a0a6.json +238 -0
  70. package/dist/static/clock-30min.eae818b8.json +1197 -0
  71. package/dist/static/clock-45min.df8adf51.json +1197 -0
  72. package/dist/static/clock-60min.2b48d875.json +1197 -0
  73. package/dist/static/clock-90min.3e557ed7.json +1407 -0
  74. package/dist/static/color-1.45101b9a.json +4545 -0
  75. package/dist/static/color-2.ccdc7d0a.json +4828 -0
  76. package/dist/static/color-3.5e8e1422.json +5273 -0
  77. package/dist/static/difficult.6846c064.json +2755 -0
  78. package/dist/static/easy-rescheduling-lottie.28026af9.json +9301 -0
  79. package/dist/static/easy.68242ddd.json +2658 -0
  80. package/dist/static/elite-circle.3df58972.json +6876 -0
  81. package/dist/static/error-lottie.b3507a4b.json +5255 -0
  82. package/dist/static/familiar1x.7c9c7f15.json +3046 -0
  83. package/dist/static/fifteen-min-clock.0af4e303.json +715 -0
  84. package/dist/static/five-min-clock.6be5cc41.json +721 -0
  85. package/dist/static/gold-1.ab2489fe.json +4176 -0
  86. package/dist/static/gold-2.34045826.json +4441 -0
  87. package/dist/static/gold-3.d704698b.json +4810 -0
  88. package/dist/static/levelup-rings.b1055283.json +549 -0
  89. package/dist/static/medium.94c3829b.json +2289 -0
  90. package/dist/static/nudge-tap.5cb30093.json +1057 -0
  91. package/dist/static/point1.b53831de.json +2942 -0
  92. package/dist/static/point10.7b5e536d.json +3179 -0
  93. package/dist/static/point100.1df16f82.json +3196 -0
  94. package/dist/static/point15.fea00c32.json +3179 -0
  95. package/dist/static/point20.c88d776d.json +3178 -0
  96. package/dist/static/point25.a18c346a.json +3178 -0
  97. package/dist/static/point30.c5224b0b.json +3202 -0
  98. package/dist/static/point35.fad343dd.json +3058 -0
  99. package/dist/static/point40.10a16f72.json +3082 -0
  100. package/dist/static/point45.2ad7561f.json +3082 -0
  101. package/dist/static/point5.da40ed1f.json +2948 -0
  102. package/dist/static/point50.5718cb3d.json +3046 -0
  103. package/dist/static/point60.17380d9f.json +3076 -0
  104. package/dist/static/proficient1x.fa6e7b80.json +3430 -0
  105. package/dist/static/silver-1.0396328a.json +4168 -0
  106. package/dist/static/silver-2.bf50615f.json +4433 -0
  107. package/dist/static/silver-3.13d66b84.json +4810 -0
  108. package/dist/static/sleepy-boi.031a1165.json +1008 -0
  109. package/dist/static/spinner-white.639e0d87.json +122 -0
  110. package/dist/static/splash-screen.bbf567ce.json +2411 -0
  111. package/dist/static/stay-connected-lottie.111439b3.json +3547 -0
  112. package/dist/static/teacher-validation.7577ecdc.json +245 -0
  113. package/dist/static/total-streak.d5ce7669.json +842 -0
  114. package/dist/static/total-time-spent.434005d3.json +200 -0
  115. package/dist/static/total-time.d979cbb9.json +24383 -0
  116. package/dist/static/tournament-ripple.e5c239a5.json +1047 -0
  117. package/dist/static/track-progress-lottie.422108cf.json +2972 -0
  118. package/package.json +1 -1
  119. package/dist/assets/lotties/circle/100pts.json.js +0 -7957
  120. package/dist/assets/lotties/circle/100pts.json.js.map +0 -1
  121. package/dist/assets/lotties/circle/10pts.json.js +0 -7753
  122. package/dist/assets/lotties/circle/10pts.json.js.map +0 -1
  123. package/dist/assets/lotties/circle/15pts.json.js +0 -7879
  124. package/dist/assets/lotties/circle/15pts.json.js.map +0 -1
  125. package/dist/assets/lotties/circle/1pts.json.js +0 -7257
  126. package/dist/assets/lotties/circle/1pts.json.js.map +0 -1
  127. package/dist/assets/lotties/circle/20pts.json.js +0 -7845
  128. package/dist/assets/lotties/circle/20pts.json.js.map +0 -1
  129. package/dist/assets/lotties/circle/25pts.json.js +0 -7971
  130. package/dist/assets/lotties/circle/25pts.json.js.map +0 -1
  131. package/dist/assets/lotties/circle/30pts.json.js +0 -7941
  132. package/dist/assets/lotties/circle/30pts.json.js.map +0 -1
  133. package/dist/assets/lotties/circle/35pts.json.js +0 -7881
  134. package/dist/assets/lotties/circle/35pts.json.js.map +0 -1
  135. package/dist/assets/lotties/circle/40pts.json.js +0 -7725
  136. package/dist/assets/lotties/circle/40pts.json.js.map +0 -1
  137. package/dist/assets/lotties/circle/45pts.json.js +0 -7851
  138. package/dist/assets/lotties/circle/45pts.json.js.map +0 -1
  139. package/dist/assets/lotties/circle/50pts.json.js +0 -7707
  140. package/dist/assets/lotties/circle/50pts.json.js.map +0 -1
  141. package/dist/assets/lotties/circle/5pts.json.js +0 -7420
  142. package/dist/assets/lotties/circle/5pts.json.js.map +0 -1
  143. package/dist/assets/lotties/circle/60pts.json.js +0 -7701
  144. package/dist/assets/lotties/circle/60pts.json.js.map +0 -1
  145. package/dist/assets/lotties/circle/accuracy-meter-lottie.json.js +0 -6811
  146. package/dist/assets/lotties/circle/accuracy-meter-lottie.json.js.map +0 -1
  147. package/dist/assets/lotties/circle/accuracy-needle-lottie.json.js +0 -1503
  148. package/dist/assets/lotties/circle/accuracy-needle-lottie.json.js.map +0 -1
  149. package/dist/assets/lotties/circle/circular-loader.json.js +0 -635
  150. package/dist/assets/lotties/circle/circular-loader.json.js.map +0 -1
  151. package/dist/assets/lotties/circle/elite-circle-lottie.json.js +0 -12079
  152. package/dist/assets/lotties/circle/elite-circle-lottie.json.js.map +0 -1
  153. package/dist/assets/lotties/circle/levelup-rings-lottie.json.js +0 -1412
  154. package/dist/assets/lotties/circle/levelup-rings-lottie.json.js.map +0 -1
  155. package/dist/assets/lotties/circle/sleepy-boi-lottie.json.js +0 -2632
  156. package/dist/assets/lotties/circle/sleepy-boi-lottie.json.js.map +0 -1
  157. package/dist/assets/lotties/circle/spinner-white.json.js +0 -316
  158. package/dist/assets/lotties/circle/spinner-white.json.js.map +0 -1
  159. package/dist/assets/lotties/circle/splash-screen.json.js +0 -5864
  160. package/dist/assets/lotties/circle/splash-screen.json.js.map +0 -1
  161. package/dist/assets/lotties/circle/total-streak-lottie.json.js +0 -2103
  162. package/dist/assets/lotties/circle/total-streak-lottie.json.js.map +0 -1
  163. package/dist/assets/lotties/circle/total-time-lottie.json.js +0 -33016
  164. package/dist/assets/lotties/circle/total-time-lottie.json.js.map +0 -1
  165. package/dist/assets/lotties/circle/total-time-spent-lottie.json.js +0 -260
  166. package/dist/assets/lotties/circle/total-time-spent-lottie.json.js.map +0 -1
  167. package/dist/assets/lotties/circle/tournament-ripple-lottie.json.js +0 -1563
  168. package/dist/assets/lotties/circle/tournament-ripple-lottie.json.js.map +0 -1
  169. package/dist/assets/lotties/common/nudge-tap.json.js +0 -3597
  170. package/dist/assets/lotties/common/nudge-tap.json.js.map +0 -1
  171. package/dist/assets/lotties/error-lottie.json.js +0 -12755
  172. package/dist/assets/lotties/error-lottie.json.js.map +0 -1
  173. package/dist/assets/lotties/perfect-hits/bronze-1.json.js +0 -10871
  174. package/dist/assets/lotties/perfect-hits/bronze-1.json.js.map +0 -1
  175. package/dist/assets/lotties/perfect-hits/bronze-2.json.js +0 -11389
  176. package/dist/assets/lotties/perfect-hits/bronze-2.json.js.map +0 -1
  177. package/dist/assets/lotties/perfect-hits/bronze-3.json.js +0 -12169
  178. package/dist/assets/lotties/perfect-hits/bronze-3.json.js.map +0 -1
  179. package/dist/assets/lotties/perfect-hits/color-1.json.js +0 -12348
  180. package/dist/assets/lotties/perfect-hits/color-1.json.js.map +0 -1
  181. package/dist/assets/lotties/perfect-hits/color-2.json.js +0 -12941
  182. package/dist/assets/lotties/perfect-hits/color-2.json.js.map +0 -1
  183. package/dist/assets/lotties/perfect-hits/color-3.json.js +0 -14034
  184. package/dist/assets/lotties/perfect-hits/color-3.json.js.map +0 -1
  185. package/dist/assets/lotties/perfect-hits/gold-1.json.js +0 -10871
  186. package/dist/assets/lotties/perfect-hits/gold-1.json.js.map +0 -1
  187. package/dist/assets/lotties/perfect-hits/gold-2.json.js +0 -11389
  188. package/dist/assets/lotties/perfect-hits/gold-2.json.js.map +0 -1
  189. package/dist/assets/lotties/perfect-hits/gold-3.json.js +0 -12169
  190. package/dist/assets/lotties/perfect-hits/gold-3.json.js.map +0 -1
  191. package/dist/assets/lotties/perfect-hits/silver-1.json.js +0 -10871
  192. package/dist/assets/lotties/perfect-hits/silver-1.json.js.map +0 -1
  193. package/dist/assets/lotties/perfect-hits/silver-2.json.js +0 -11389
  194. package/dist/assets/lotties/perfect-hits/silver-2.json.js.map +0 -1
  195. package/dist/assets/lotties/perfect-hits/silver-3.json.js +0 -12169
  196. package/dist/assets/lotties/perfect-hits/silver-3.json.js.map +0 -1
  197. package/dist/assets/lotties/teacher-validation.json.js +0 -649
  198. package/dist/assets/lotties/teacher-validation.json.js.map +0 -1
  199. package/dist/assets/lotties/tests-creation/clock_30_min.json.js +0 -2857
  200. package/dist/assets/lotties/tests-creation/clock_30_min.json.js.map +0 -1
  201. package/dist/assets/lotties/tests-creation/clock_45_min.json.js +0 -2857
  202. package/dist/assets/lotties/tests-creation/clock_45_min.json.js.map +0 -1
  203. package/dist/assets/lotties/tests-creation/clock_60_min.json.js +0 -2857
  204. package/dist/assets/lotties/tests-creation/clock_60_min.json.js.map +0 -1
  205. package/dist/assets/lotties/tests-creation/clock_90_min.json.js +0 -3345
  206. package/dist/assets/lotties/tests-creation/clock_90_min.json.js.map +0 -1
  207. package/dist/assets/lotties/tests-creation/difficult.json.js +0 -6713
  208. package/dist/assets/lotties/tests-creation/difficult.json.js.map +0 -1
  209. package/dist/assets/lotties/tests-creation/easy.json.js +0 -6525
  210. package/dist/assets/lotties/tests-creation/easy.json.js.map +0 -1
  211. package/dist/assets/lotties/tests-creation/medium.json.js +0 -5603
  212. package/dist/assets/lotties/tests-creation/medium.json.js.map +0 -1
  213. package/dist/assets/lotties/trial-v3/15min-clock.json.js +0 -2037
  214. package/dist/assets/lotties/trial-v3/15min-clock.json.js.map +0 -1
  215. package/dist/assets/lotties/trial-v3/5min-clock.json.js +0 -2062
  216. package/dist/assets/lotties/trial-v3/5min-clock.json.js.map +0 -1
  217. package/dist/assets/lotties/trial-v3/insight/beginner1x.json.js +0 -8517
  218. package/dist/assets/lotties/trial-v3/insight/beginner1x.json.js.map +0 -1
  219. package/dist/assets/lotties/trial-v3/insight/familiar1x.json.js +0 -7396
  220. package/dist/assets/lotties/trial-v3/insight/familiar1x.json.js.map +0 -1
  221. package/dist/assets/lotties/trial-v3/insight/proficient1x.json.js +0 -8559
  222. package/dist/assets/lotties/trial-v3/insight/proficient1x.json.js.map +0 -1
  223. package/dist/assets/lotties/trial-v3/parent-app/easy-rescheduling-lottie.json.js +0 -23284
  224. package/dist/assets/lotties/trial-v3/parent-app/easy-rescheduling-lottie.json.js.map +0 -1
  225. package/dist/assets/lotties/trial-v3/parent-app/stay-connected-lottie.json.js +0 -9090
  226. package/dist/assets/lotties/trial-v3/parent-app/stay-connected-lottie.json.js.map +0 -1
  227. package/dist/assets/lotties/trial-v3/parent-app/track-progress-lottie.json.js +0 -8675
  228. package/dist/assets/lotties/trial-v3/parent-app/track-progress-lottie.json.js.map +0 -1
  229. package/dist/features/circle-games/game-launcher/comps/segmented-game-card/fetch-lottie.js +0 -13
  230. package/dist/features/circle-games/game-launcher/comps/segmented-game-card/fetch-lottie.js.map +0 -1
  231. package/dist/features/circle-games/game-launcher/game-launcher-styled.js +0 -10
  232. package/dist/features/circle-games/game-launcher/game-launcher-styled.js.map +0 -1
  233. package/dist/features/post-game-stats/points/points-styled.js +0 -10
  234. package/dist/features/post-game-stats/points/points-styled.js.map +0 -1
  235. package/dist/features/trial-session/comps/render-lottie/index.js +0 -26
  236. package/dist/features/trial-session/comps/render-lottie/index.js.map +0 -1
  237. package/dist/features/ui/loader/circular-loader/circular-loader-styled.js +0 -17
  238. package/dist/features/ui/loader/circular-loader/circular-loader-styled.js.map +0 -1
@@ -1,58 +1,40 @@
1
- import { jsxs as t, jsx as e } from "react/jsx-runtime";
2
- import p from "lottie-web";
3
- import { memo as h, useRef as x, useEffect as A } from "react";
4
- import T from "../../../../ui/separator/separator.js";
5
- import i from "../../../../ui/text/text.js";
6
- import { BannerContainer as C, CircleLottieView as $, BannerTextContainer as y, CountTextWrapper as B } from "./banner-styled.js";
7
- const _ = h(
1
+ import { jsxs as n, jsx as r } from "react/jsx-runtime";
2
+ import { memo as d } from "react";
3
+ import h from "../../../../ui/lottie-animation/lottie-animation.js";
4
+ import p from "../../../../ui/separator/separator.js";
5
+ import o from "../../../../ui/text/text.js";
6
+ import { BannerContainer as f, CircleLottieView as x, BannerTextContainer as T, CountTextWrapper as C } from "./banner-styled.js";
7
+ const $ = { renderer: "canvas" }, H = d(
8
8
  ({
9
- primaryText: l,
10
- secondaryText: c,
11
- topInset: n = 0,
12
- isLoading: m = !1,
13
- lottiePromise: a,
14
- bgFromTopPosition: d = 0,
15
- bgFromRightPosition: u = 0,
16
- custEle: f
17
- }) => {
18
- const o = x(null);
19
- return A(() => {
20
- let r = null;
21
- return (async () => {
22
- const s = (await a()).default;
23
- o.current && (r = p.loadAnimation({
24
- container: o.current,
25
- // Ref to the div
26
- renderer: "canvas",
27
- loop: !0,
28
- autoplay: !0,
29
- animationData: s
30
- }));
31
- })(), () => {
32
- r == null || r.destroy();
33
- };
34
- }, [a]), /* @__PURE__ */ t(C, { topInset: n, children: [
35
- /* @__PURE__ */ e(
36
- $,
37
- {
38
- ref: o,
39
- topInset: n,
40
- bgFromTopPosition: d,
41
- bgFromRightPosition: u
42
- }
43
- ),
44
- /* @__PURE__ */ t(y, { children: [
45
- /* @__PURE__ */ t(B, { topInset: n, children: [
46
- /* @__PURE__ */ e(i, { $renderAs: "ac4", $color: "WHITE", children: l }),
47
- /* @__PURE__ */ e(T, { height: 4 }),
48
- /* @__PURE__ */ e(i, { $renderAs: "ah4", $color: "WHITE", children: m ? "__" : c })
49
- ] }),
50
- f
51
- ] })
52
- ] });
53
- }
9
+ primaryText: i,
10
+ secondaryText: t,
11
+ topInset: e = 0,
12
+ isLoading: a = !1,
13
+ lottiePath: m,
14
+ bgFromTopPosition: c = 0,
15
+ bgFromRightPosition: s = 0,
16
+ custEle: l
17
+ }) => /* @__PURE__ */ n(f, { topInset: e, children: [
18
+ /* @__PURE__ */ r(
19
+ x,
20
+ {
21
+ topInset: e,
22
+ bgFromTopPosition: c,
23
+ bgFromRightPosition: s,
24
+ children: /* @__PURE__ */ r(h, { src: m, settings: $ })
25
+ }
26
+ ),
27
+ /* @__PURE__ */ n(T, { children: [
28
+ /* @__PURE__ */ n(C, { topInset: e, children: [
29
+ /* @__PURE__ */ r(o, { $renderAs: "ac4", $color: "WHITE", children: i }),
30
+ /* @__PURE__ */ r(p, { height: 4 }),
31
+ /* @__PURE__ */ r(o, { $renderAs: "ah4", $color: "WHITE", children: a ? "__" : t })
32
+ ] }),
33
+ l
34
+ ] })
35
+ ] })
54
36
  );
55
37
  export {
56
- _ as Banner
38
+ H as Banner
57
39
  };
58
40
  //# sourceMappingURL=banner.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"banner.js","sources":["../../../../../../src/features/circle-games/leaderboard/comps/banner/banner.tsx"],"sourcesContent":["import type { IBannerProps } from './banner-types';\nimport type { AnimationItem } from 'lottie-web';\nimport type { FC } from 'react';\n\nimport Lottie from 'lottie-web';\nimport { memo, useEffect, useRef } from 'react';\n\nimport Separator from '../../../../ui/separator/separator';\nimport Text from '../../../../ui/text/text';\nimport * as Styled from './banner-styled';\n\nexport const Banner: FC<IBannerProps> = memo(\n ({\n primaryText,\n secondaryText,\n topInset = 0,\n isLoading = false,\n lottiePromise,\n bgFromTopPosition = 0,\n bgFromRightPosition = 0,\n custEle,\n }) => {\n const lottieAnimationRef = useRef<HTMLDivElement>(null);\n\n // Initialize Lottie animation\n useEffect(() => {\n let animation: AnimationItem | null = null;\n\n const loadAnimation = async () => {\n const animationModule = await lottiePromise();\n const animationData = animationModule.default;\n\n if (lottieAnimationRef.current) {\n animation = Lottie.loadAnimation({\n container: lottieAnimationRef.current, // Ref to the div\n renderer: 'canvas',\n loop: true,\n autoplay: true,\n animationData: animationData,\n });\n }\n };\n\n loadAnimation();\n\n return () => {\n animation?.destroy();\n };\n }, [lottiePromise]);\n\n return (\n <Styled.BannerContainer topInset={topInset}>\n {/* Render Lottie animation */}\n <Styled.CircleLottieView\n ref={lottieAnimationRef}\n topInset={topInset}\n bgFromTopPosition={bgFromTopPosition}\n bgFromRightPosition={bgFromRightPosition}\n />\n\n <Styled.BannerTextContainer>\n <Styled.CountTextWrapper topInset={topInset}>\n <Text $renderAs=\"ac4\" $color=\"WHITE\">\n {primaryText}\n </Text>\n <Separator height={4} />\n <Text $renderAs=\"ah4\" $color=\"WHITE\">\n {isLoading ? '__' : secondaryText}\n </Text>\n </Styled.CountTextWrapper>\n\n {custEle}\n </Styled.BannerTextContainer>\n </Styled.BannerContainer>\n );\n },\n);\n"],"names":["Banner","memo","primaryText","secondaryText","topInset","isLoading","lottiePromise","bgFromTopPosition","bgFromRightPosition","custEle","lottieAnimationRef","useRef","useEffect","animation","animationData","Lottie","jsxs","Styled.BannerContainer","jsx","Styled.CircleLottieView","Styled.BannerTextContainer","Styled.CountTextWrapper","Text","Separator"],"mappings":";;;;;;AAWO,MAAMA,IAA2BC;AAAA,EACtC,CAAC;AAAA,IACC,aAAAC;AAAA,IACA,eAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,WAAAC,IAAY;AAAA,IACZ,eAAAC;AAAA,IACA,mBAAAC,IAAoB;AAAA,IACpB,qBAAAC,IAAsB;AAAA,IACtB,SAAAC;AAAA,EAAA,MACI;AACE,UAAAC,IAAqBC,EAAuB,IAAI;AAGtD,WAAAC,EAAU,MAAM;AACd,UAAIC,IAAkC;AAiBxB,cAfQ,YAAY;AAEhC,cAAMC,KADkB,MAAMR,KACQ;AAEtC,QAAII,EAAmB,YACrBG,IAAYE,EAAO,cAAc;AAAA,UAC/B,WAAWL,EAAmB;AAAA;AAAA,UAC9B,UAAU;AAAA,UACV,MAAM;AAAA,UACN,UAAU;AAAA,UACV,eAAAI;AAAA,QAAA,CACD;AAAA,MACH,MAKK,MAAM;AACX,QAAAD,KAAA,QAAAA,EAAW;AAAA,MAAQ;AAAA,IACrB,GACC,CAACP,CAAa,CAAC,GAGf,gBAAAU,EAAAC,GAAA,EAAuB,UAAAb,GAEtB,UAAA;AAAA,MAAA,gBAAAc;AAAA,QAACC;AAAAA,QAAA;AAAA,UACC,KAAKT;AAAA,UACL,UAAAN;AAAA,UACA,mBAAAG;AAAA,UACA,qBAAAC;AAAA,QAAA;AAAA,MACF;AAAA,MAEA,gBAAAQ,EAACI,GAAA,EACC,UAAA;AAAA,QAAC,gBAAAJ,EAAAK,GAAA,EAAwB,UAAAjB,GACvB,UAAA;AAAA,UAAA,gBAAAc,EAACI,GAAK,EAAA,WAAU,OAAM,QAAO,SAC1B,UACHpB,GAAA;AAAA,UACA,gBAAAgB,EAACK,GAAU,EAAA,QAAQ,EAAG,CAAA;AAAA,UACtB,gBAAAL,EAACI,KAAK,WAAU,OAAM,QAAO,SAC1B,UAAAjB,IAAY,OAAOF,EACtB,CAAA;AAAA,QAAA,GACF;AAAA,QAECM;AAAA,MAAA,GACH;AAAA,IACF,EAAA,CAAA;AAAA,EAEJ;AACF;"}
1
+ {"version":3,"file":"banner.js","sources":["../../../../../../src/features/circle-games/leaderboard/comps/banner/banner.tsx"],"sourcesContent":["import type { IBannerProps } from './banner-types';\nimport type { FC } from 'react';\n\nimport { memo } from 'react';\n\nimport LottieAnimation from '../../../../ui/lottie-animation/lottie-animation';\nimport Separator from '../../../../ui/separator/separator';\nimport Text from '../../../../ui/text/text';\nimport * as Styled from './banner-styled';\n\nconst animationSettings = { renderer: 'canvas' };\n\nexport const Banner: FC<IBannerProps> = memo(\n ({\n primaryText,\n secondaryText,\n topInset = 0,\n isLoading = false,\n lottiePath,\n bgFromTopPosition = 0,\n bgFromRightPosition = 0,\n custEle,\n }) => (\n <Styled.BannerContainer topInset={topInset}>\n <Styled.CircleLottieView\n topInset={topInset}\n bgFromTopPosition={bgFromTopPosition}\n bgFromRightPosition={bgFromRightPosition}\n >\n <LottieAnimation src={lottiePath} settings={animationSettings} />\n </Styled.CircleLottieView>\n\n <Styled.BannerTextContainer>\n <Styled.CountTextWrapper topInset={topInset}>\n <Text $renderAs=\"ac4\" $color=\"WHITE\">\n {primaryText}\n </Text>\n <Separator height={4} />\n <Text $renderAs=\"ah4\" $color=\"WHITE\">\n {isLoading ? '__' : secondaryText}\n </Text>\n </Styled.CountTextWrapper>\n\n {custEle}\n </Styled.BannerTextContainer>\n </Styled.BannerContainer>\n ),\n);\n"],"names":["animationSettings","Banner","memo","primaryText","secondaryText","topInset","isLoading","lottiePath","bgFromTopPosition","bgFromRightPosition","custEle","jsxs","Styled.BannerContainer","jsx","Styled.CircleLottieView","LottieAnimation","Styled.BannerTextContainer","Styled.CountTextWrapper","Text","Separator"],"mappings":";;;;;;AAUA,MAAMA,IAAoB,EAAE,UAAU,YAEzBC,IAA2BC;AAAA,EACtC,CAAC;AAAA,IACC,aAAAC;AAAA,IACA,eAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,WAAAC,IAAY;AAAA,IACZ,YAAAC;AAAA,IACA,mBAAAC,IAAoB;AAAA,IACpB,qBAAAC,IAAsB;AAAA,IACtB,SAAAC;AAAA,EAEA,MAAA,gBAAAC,EAACC,GAAA,EAAuB,UAAAP,GACtB,UAAA;AAAA,IAAA,gBAAAQ;AAAA,MAACC;AAAAA,MAAA;AAAA,QACC,UAAAT;AAAA,QACA,mBAAAG;AAAA,QACA,qBAAAC;AAAA,QAEA,UAAC,gBAAAI,EAAAE,GAAA,EAAgB,KAAKR,GAAY,UAAUP,GAAmB;AAAA,MAAA;AAAA,IACjE;AAAA,IAEA,gBAAAW,EAACK,GAAA,EACC,UAAA;AAAA,MAAC,gBAAAL,EAAAM,GAAA,EAAwB,UAAAZ,GACvB,UAAA;AAAA,QAAA,gBAAAQ,EAACK,GAAK,EAAA,WAAU,OAAM,QAAO,SAC1B,UACHf,GAAA;AAAA,QACA,gBAAAU,EAACM,GAAU,EAAA,QAAQ,EAAG,CAAA;AAAA,QACtB,gBAAAN,EAACK,KAAK,WAAU,OAAM,QAAO,SAC1B,UAAAZ,IAAY,OAAOF,EACtB,CAAA;AAAA,MAAA,GACF;AAAA,MAECM;AAAA,IAAA,GACH;AAAA,EAAA,GACF;AAEJ;"}
@@ -1,20 +1,21 @@
1
- import { jsx as e, jsxs as c } from "react/jsx-runtime";
2
- import { useState as T, useEffect as g } from "react";
3
- import { ILLUSTRATIONS as $ } from "../../../assets/illustrations/illustrations.js";
4
- import { CircularLoader as j } from "../../ui/loader/circular-loader/circular-loader.js";
5
- import v from "../../ui/text/text.js";
6
- import { useCircleSounds as w } from "../hooks/use-circle-sounds/use-circle-sounds.js";
1
+ import { jsx as e, jsxs as T } from "react/jsx-runtime";
2
+ import { useState as c, useEffect as b } from "react";
3
+ import { ILLUSTRATIONS as j } from "../../../assets/illustrations/illustrations.js";
4
+ import { LOTTIE as E } from "../../../assets/lottie/lottie.js";
5
+ import { CircularLoader as v } from "../../ui/loader/circular-loader/circular-loader.js";
6
+ import w from "../../ui/text/text.js";
7
+ import { useCircleSounds as U } from "../hooks/use-circle-sounds/use-circle-sounds.js";
7
8
  import { Banner as d } from "./comps/banner/banner.js";
8
9
  import { LeaderboardItemWithObserver as H } from "./comps/leaderboard-item/leaderboard-item.js";
9
- import { NavigationButton as U } from "./comps/navigation-button/navigation-button.js";
10
- import { Timer as q } from "./comps/timer/timer.js";
10
+ import { NavigationButton as q } from "./comps/navigation-button/navigation-button.js";
11
+ import { Timer as z } from "./comps/timer/timer.js";
11
12
  import { ELeaderboardType as t } from "./enums/leaderboard-type-enum.js";
12
- import { Leaderboard as z, LeaderboardContainer as G, BannerWrapper as J, TournamentBannerCustContainer as Q, TrophyWrapper as V, ItemsWrapper as X, Banner as Z, ActionButtonWrapper as D } from "./leaderboard-styled.js";
13
- import { useTimer as ee } from "./hooks/useTimer.js";
14
- const u = {
15
- [t.ALL_TIME_STREAK]: () => import("../../../assets/lotties/circle/elite-circle-lottie.json.js"),
16
- [t.ALL_TIME]: () => import("../../../assets/lotties/circle/elite-circle-lottie.json.js"),
17
- [t.BI_WEEKLY]: () => import("../../../assets/lotties/circle/tournament-ripple-lottie.json.js")
13
+ import { Leaderboard as G, LeaderboardContainer as J, BannerWrapper as Q, TournamentBannerCustContainer as V, TrophyWrapper as X, ItemsWrapper as Z, Banner as D, ActionButtonWrapper as ee } from "./leaderboard-styled.js";
14
+ import { useTimer as re } from "./hooks/useTimer.js";
15
+ const L = {
16
+ [t.ALL_TIME_STREAK]: E.ELITE_CIRCLE,
17
+ [t.ALL_TIME]: E.ELITE_CIRCLE,
18
+ [t.BI_WEEKLY]: E.TOURNAMENT_RIPPLE
18
19
  }, i = [
19
20
  {
20
21
  name: "TOURNAMENT",
@@ -28,38 +29,38 @@ const u = {
28
29
  name: "ALL TIME",
29
30
  type: t.ALL_TIME
30
31
  }
31
- ], Ee = ({
32
+ ], le = ({
32
33
  leaderboardData: m,
33
- type: E = t.BI_WEEKLY,
34
- userId: C,
35
- onClose: P,
34
+ type: u = t.BI_WEEKLY,
35
+ userId: g,
36
+ onClose: W,
36
37
  isLoading: p
37
38
  }) => {
38
- var f, y, A, S, _, x, B;
39
- const [s, l] = T(
40
- i.findIndex((r) => E === r.type)
41
- ), [n, W] = T(((f = m == null ? void 0 : m[E]) == null ? void 0 : f.leaderboardPlayers) || []), [L, K] = T({
39
+ var _, A, y, S, R, C, x;
40
+ const [s, l] = c(
41
+ i.findIndex((r) => u === r.type)
42
+ ), [n, K] = c(((_ = m == null ? void 0 : m[u]) == null ? void 0 : _.leaderboardPlayers) || []), [I, M] = c({
42
43
  current: 0,
43
44
  end: 0
44
- }), [M, h] = ee(0), [a, k] = T(!1), N = (y = n == null ? void 0 : n[0]) == null ? void 0 : y.points, Y = ((A = n == null ? void 0 : n[0]) == null ? void 0 : A.streakDays) || 0, { playButtonSound: I } = w(), F = () => {
45
- I(), l((r) => r - 1 < 0 ? i.length - 1 : r - 1);
46
- }, O = () => {
47
- I(), l((r) => r + 1 === i.length ? 0 : r + 1);
45
+ }), [N, h] = re(0), [a, k] = c(!1), O = (A = n == null ? void 0 : n[0]) == null ? void 0 : A.points, Y = ((y = n == null ? void 0 : n[0]) == null ? void 0 : y.streakDays) || 0, { playButtonSound: f } = U(), F = () => {
46
+ f(), l((r) => r - 1 < 0 ? i.length - 1 : r - 1);
47
+ }, $ = () => {
48
+ f(), l((r) => r + 1 === i.length ? 0 : r + 1);
48
49
  };
49
- return g(() => {
50
+ return b(() => {
50
51
  h(0);
51
- }, [h]), g(() => {
52
- var R;
53
- const r = (R = i[s]) == null ? void 0 : R.type, o = r && (m == null ? void 0 : m[r]);
52
+ }, [h]), b(() => {
53
+ var B;
54
+ const r = (B = i[s]) == null ? void 0 : B.type, o = r && (m == null ? void 0 : m[r]);
54
55
  if (o) {
55
- const b = o.leaderboardPlayers || [];
56
- r === t.BI_WEEKLY && (K({
56
+ const P = o.leaderboardPlayers || [];
57
+ r === t.BI_WEEKLY && (M({
57
58
  current: o.currentTimestamp,
58
59
  end: o.endTimestamp
59
- }), o.currentTimestamp > o.endTimestamp && (b.splice(10), k(!0))), W([...b]);
60
+ }), o.currentTimestamp > o.endTimestamp && (P.splice(10), k(!0))), K([...P]);
60
61
  }
61
- }, [s, m]), /* @__PURE__ */ e(z, { children: /* @__PURE__ */ c(G, { children: [
62
- /* @__PURE__ */ c(J, { children: [
62
+ }, [s, m]), /* @__PURE__ */ e(G, { children: /* @__PURE__ */ T(J, { children: [
63
+ /* @__PURE__ */ T(Q, { children: [
63
64
  ((S = i[s]) == null ? void 0 : S.type) === t.BI_WEEKLY && /* @__PURE__ */ e(
64
65
  d,
65
66
  {
@@ -67,23 +68,23 @@ const u = {
67
68
  bgFromTopPosition: -120,
68
69
  bgFromRightPosition: -110,
69
70
  primaryText: a ? /* @__PURE__ */ e("span", { children: "New Tournament" }) : /* @__PURE__ */ e("span", { children: "Tournament" }),
70
- secondaryText: a ? /* @__PURE__ */ e("span", { children: "Starts Soon" }) : /* @__PURE__ */ c("span", { children: [
71
+ secondaryText: a ? /* @__PURE__ */ e("span", { children: "Starts Soon" }) : /* @__PURE__ */ T("span", { children: [
71
72
  " ",
72
73
  /* @__PURE__ */ e(
73
- q,
74
+ z,
74
75
  {
75
- fromTimestamp: M + L.current,
76
- endTimestamp: L.end
76
+ fromTimestamp: N + I.current,
77
+ endTimestamp: I.end
77
78
  }
78
79
  ),
79
80
  " ",
80
81
  "left"
81
82
  ] }),
82
- lottiePromise: u[t.BI_WEEKLY],
83
- custEle: /* @__PURE__ */ e(Q, { children: /* @__PURE__ */ e(V, { children: /* @__PURE__ */ e("img", { src: $.TROPHY_CIRCLE }) }) })
83
+ lottiePath: L[t.BI_WEEKLY],
84
+ custEle: /* @__PURE__ */ e(V, { children: /* @__PURE__ */ e(X, { children: /* @__PURE__ */ e("img", { src: j.TROPHY_CIRCLE }) }) })
84
85
  }
85
86
  ),
86
- ((_ = i[s]) == null ? void 0 : _.type) === t.ALL_TIME_STREAK && /* @__PURE__ */ e(
87
+ ((R = i[s]) == null ? void 0 : R.type) === t.ALL_TIME_STREAK && /* @__PURE__ */ e(
87
88
  d,
88
89
  {
89
90
  isLoading: p,
@@ -91,10 +92,10 @@ const u = {
91
92
  bgFromRightPosition: -90,
92
93
  primaryText: /* @__PURE__ */ e("span", { children: "Streak Stars" }),
93
94
  secondaryText: /* @__PURE__ */ e("span", { children: "Top 50" }),
94
- lottiePromise: u[t.ALL_TIME_STREAK]
95
+ lottiePath: L[t.ALL_TIME_STREAK]
95
96
  }
96
97
  ),
97
- ((x = i[s]) == null ? void 0 : x.type) === t.ALL_TIME && /* @__PURE__ */ e(
98
+ ((C = i[s]) == null ? void 0 : C.type) === t.ALL_TIME && /* @__PURE__ */ e(
98
99
  d,
99
100
  {
100
101
  isLoading: p,
@@ -102,13 +103,13 @@ const u = {
102
103
  bgFromRightPosition: -90,
103
104
  primaryText: /* @__PURE__ */ e("span", { children: "Elite Circle" }),
104
105
  secondaryText: /* @__PURE__ */ e("span", { children: "Top 50" }),
105
- lottiePromise: u[t.ALL_TIME]
106
+ lottiePath: L[t.ALL_TIME]
106
107
  }
107
108
  )
108
109
  ] }),
109
- p && /* @__PURE__ */ e(j, {}),
110
- !p && n && /* @__PURE__ */ c(X, { topInset: 0, children: [
111
- a && ((B = i[s]) == null ? void 0 : B.type) === t.BI_WEEKLY && /* @__PURE__ */ e(Z, { children: /* @__PURE__ */ e(v, { $renderAs: "ab3", $color: "WHITE", children: "Congratulating winners of the last tournament!" }) }),
110
+ p && /* @__PURE__ */ e(v, {}),
111
+ !p && n && /* @__PURE__ */ T(Z, { topInset: 0, children: [
112
+ a && ((x = i[s]) == null ? void 0 : x.type) === t.BI_WEEKLY && /* @__PURE__ */ e(D, { children: /* @__PURE__ */ e(w, { $renderAs: "ab3", $color: "WHITE", children: "Congratulating winners of the last tournament!" }) }),
112
113
  n.map((r) => {
113
114
  var o;
114
115
  return /* @__PURE__ */ e(
@@ -117,28 +118,28 @@ const u = {
117
118
  player: r,
118
119
  rank: r.rank,
119
120
  maxStreakDays: Y,
120
- maxPoints: N,
121
+ maxPoints: O,
121
122
  leaderboardType: (o = i[s]) == null ? void 0 : o.type,
122
- isActive: r.userId === C
123
+ isActive: r.userId === g
123
124
  },
124
125
  r.rank
125
126
  );
126
127
  })
127
128
  ] }),
128
- /* @__PURE__ */ e(D, { children: /* @__PURE__ */ e(
129
- U,
129
+ /* @__PURE__ */ e(ee, { children: /* @__PURE__ */ e(
130
+ q,
130
131
  {
131
132
  labels: Object.values(t),
132
133
  onLeftClick: F,
133
- onRightClick: O,
134
+ onRightClick: $,
134
135
  currIndex: s,
135
- onClose: P,
136
+ onClose: W,
136
137
  disableSwipe: p || n.length === 0
137
138
  }
138
139
  ) })
139
140
  ] }) });
140
141
  };
141
142
  export {
142
- Ee as Leaderboard
143
+ le as Leaderboard
143
144
  };
144
145
  //# sourceMappingURL=leaderboard.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"leaderboard.js","sources":["../../../../src/features/circle-games/leaderboard/leaderboard.tsx"],"sourcesContent":["import type {\n ILeaderboardPlayerWithPoints,\n ILeaderboardPlayerWithStreak,\n} from './dal/use-get-leaderboard-dal/use-get-leaderboard-dal-types';\nimport type { ILeaderboardProps } from './leaderboard-types';\n\nimport { useState, useEffect } from 'react';\n\nimport { ILLUSTRATIONS } from '../../../assets/illustrations/illustrations';\nimport { CircularLoader } from '../../ui/loader/circular-loader/circular-loader';\nimport Text from '../../ui/text/text';\nimport { useCircleSounds } from '../hooks/use-circle-sounds/use-circle-sounds';\nimport { Banner } from './comps/banner/banner';\nimport { LeaderboardItemWithObserver } from './comps/leaderboard-item/leaderboard-item';\nimport { NavigationButton } from './comps/navigation-button/navigation-button';\nimport { Timer } from './comps/timer/timer';\nimport { ELeaderboardType } from './enums/leaderboard-type-enum';\nimport { useTimer } from './hooks';\nimport * as Styled from './leaderboard-styled';\n\n// lazy load banner lotties\nconst BANNER_LOTTIES: Record<ELeaderboardType, () => Promise<Record<string, unknown>>> = {\n [ELeaderboardType.ALL_TIME_STREAK]: () =>\n import('../../../assets/lotties/circle/elite-circle-lottie.json'),\n [ELeaderboardType.ALL_TIME]: () =>\n import('../../../assets/lotties/circle/elite-circle-lottie.json'),\n [ELeaderboardType.BI_WEEKLY]: () =>\n import('../../../assets/lotties/circle/tournament-ripple-lottie.json'),\n};\n\nconst leaderboards = [\n {\n name: 'TOURNAMENT',\n type: ELeaderboardType.BI_WEEKLY,\n },\n {\n name: 'STREAK STARS',\n type: ELeaderboardType.ALL_TIME_STREAK,\n },\n {\n name: 'ALL TIME',\n type: ELeaderboardType.ALL_TIME,\n },\n];\n\nexport const Leaderboard = ({\n leaderboardData,\n type = ELeaderboardType.BI_WEEKLY,\n userId,\n onClose,\n isLoading,\n}: ILeaderboardProps) => {\n const [currentLeaderBoardIndex, setCurrentLeaderboardIndex] = useState(\n leaderboards.findIndex(leaderboard => type === leaderboard.type),\n );\n\n const [currLeaderboardData, setCurrLeaderboardData] = useState<\n (ILeaderboardPlayerWithPoints | ILeaderboardPlayerWithStreak)[] | []\n >(leaderboardData?.[type]?.leaderboardPlayers || []);\n\n const [currLeaderboardTimeStamps, setCurrLeaderboardTimeStamps] = useState<{\n current: number;\n end: number;\n }>({\n current: 0,\n end: 0,\n });\n\n const [time, setTimer] = useTimer(0);\n const [isTournamentEnded, setIsTournamentEnded] = useState(false);\n const maxPoints = (currLeaderboardData?.[0] as ILeaderboardPlayerWithPoints)?.points;\n const maxStreakDays = (currLeaderboardData?.[0] as ILeaderboardPlayerWithStreak)?.streakDays || 0;\n const { playButtonSound } = useCircleSounds();\n\n const handlePrevious = () => {\n playButtonSound();\n setCurrentLeaderboardIndex(prev => {\n if (prev - 1 < 0) {\n return leaderboards.length - 1;\n }\n\n return prev - 1;\n });\n };\n\n const handleNext = () => {\n playButtonSound();\n setCurrentLeaderboardIndex(prev => {\n if (prev + 1 === leaderboards.length) {\n return 0;\n }\n\n return prev + 1;\n });\n };\n\n useEffect(() => {\n setTimer(0);\n }, [setTimer]);\n\n useEffect(() => {\n const currType = leaderboards[currentLeaderBoardIndex]?.type;\n const currLeaderboard = currType && leaderboardData?.[currType];\n\n if (currLeaderboard) {\n const leaderboardList = currLeaderboard.leaderboardPlayers || [];\n\n if (currType === ELeaderboardType.BI_WEEKLY) {\n setCurrLeaderboardTimeStamps({\n current: currLeaderboard.currentTimestamp,\n end: currLeaderboard.endTimestamp,\n });\n\n if (currLeaderboard.currentTimestamp > currLeaderboard.endTimestamp) {\n leaderboardList.splice(10);\n setIsTournamentEnded(true);\n }\n }\n\n setCurrLeaderboardData([...leaderboardList]);\n }\n }, [currentLeaderBoardIndex, leaderboardData]);\n\n return (\n <Styled.Leaderboard>\n <Styled.LeaderboardContainer>\n <Styled.BannerWrapper>\n {/* tournament banner */}\n {leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.BI_WEEKLY && (\n <Banner\n isLoading={isLoading || currLeaderboardData.length === 0}\n bgFromTopPosition={-120}\n bgFromRightPosition={-110}\n primaryText={\n isTournamentEnded ? <span>New Tournament</span> : <span>Tournament</span>\n }\n secondaryText={\n isTournamentEnded ? (\n <span>Starts Soon</span>\n ) : (\n <span>\n {' '}\n <Timer\n fromTimestamp={(time as number) + currLeaderboardTimeStamps.current}\n endTimestamp={currLeaderboardTimeStamps.end}\n />{' '}\n {'left'}\n </span>\n )\n }\n lottiePromise={BANNER_LOTTIES[ELeaderboardType.BI_WEEKLY]}\n custEle={\n <Styled.TournamentBannerCustContainer>\n <Styled.TrophyWrapper>\n <img src={ILLUSTRATIONS.TROPHY_CIRCLE} />\n </Styled.TrophyWrapper>\n </Styled.TournamentBannerCustContainer>\n }\n />\n )}\n\n {/* top streak banner */}\n {leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.ALL_TIME_STREAK && (\n <Banner\n isLoading={isLoading}\n bgFromTopPosition={-140}\n bgFromRightPosition={-90}\n primaryText={<span>Streak Stars</span>}\n secondaryText={<span>Top 50</span>}\n lottiePromise={BANNER_LOTTIES[ELeaderboardType.ALL_TIME_STREAK]}\n />\n )}\n\n {/* elite circle banner */}\n {leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.ALL_TIME && (\n <Banner\n isLoading={isLoading}\n bgFromTopPosition={-140}\n bgFromRightPosition={-90}\n primaryText={<span>Elite Circle</span>}\n secondaryText={<span>Top 50</span>}\n lottiePromise={BANNER_LOTTIES[ELeaderboardType.ALL_TIME]}\n />\n )}\n </Styled.BannerWrapper>\n\n {isLoading && <CircularLoader />}\n\n {!isLoading && currLeaderboardData && (\n <Styled.ItemsWrapper topInset={0}>\n {isTournamentEnded &&\n leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.BI_WEEKLY && (\n <Styled.Banner>\n <Text $renderAs=\"ab3\" $color=\"WHITE\">\n Congratulating winners of the last tournament!\n </Text>\n </Styled.Banner>\n )}\n {currLeaderboardData.map(player => {\n return (\n <LeaderboardItemWithObserver\n key={player.rank}\n player={player}\n rank={player.rank}\n maxStreakDays={maxStreakDays}\n maxPoints={maxPoints}\n leaderboardType={leaderboards[currentLeaderBoardIndex]?.type}\n isActive={player.userId === userId}\n />\n );\n })}\n </Styled.ItemsWrapper>\n )}\n\n <Styled.ActionButtonWrapper>\n <NavigationButton\n labels={Object.values(ELeaderboardType)}\n onLeftClick={handlePrevious}\n onRightClick={handleNext}\n currIndex={currentLeaderBoardIndex}\n onClose={onClose}\n disableSwipe={isLoading || currLeaderboardData.length === 0}\n />\n </Styled.ActionButtonWrapper>\n </Styled.LeaderboardContainer>\n </Styled.Leaderboard>\n );\n};\n"],"names":["BANNER_LOTTIES","ELeaderboardType","leaderboards","Leaderboard","leaderboardData","type","userId","onClose","isLoading","currentLeaderBoardIndex","setCurrentLeaderboardIndex","useState","leaderboard","currLeaderboardData","setCurrLeaderboardData","_a","currLeaderboardTimeStamps","setCurrLeaderboardTimeStamps","time","setTimer","useTimer","isTournamentEnded","setIsTournamentEnded","maxPoints","_b","maxStreakDays","_c","playButtonSound","useCircleSounds","handlePrevious","prev","handleNext","useEffect","currType","currLeaderboard","leaderboardList","Styled.Leaderboard","jsxs","Styled.LeaderboardContainer","Styled.BannerWrapper","_d","jsx","Banner","Timer","Styled.TournamentBannerCustContainer","Styled.TrophyWrapper","ILLUSTRATIONS","_e","_f","CircularLoader","Styled.ItemsWrapper","_g","Styled.Banner","Text","player","LeaderboardItemWithObserver","Styled.ActionButtonWrapper","NavigationButton"],"mappings":"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"}
1
+ {"version":3,"file":"leaderboard.js","sources":["../../../../src/features/circle-games/leaderboard/leaderboard.tsx"],"sourcesContent":["import type {\n ILeaderboardPlayerWithPoints,\n ILeaderboardPlayerWithStreak,\n} from './dal/use-get-leaderboard-dal/use-get-leaderboard-dal-types';\nimport type { ILeaderboardProps } from './leaderboard-types';\n\nimport { useState, useEffect } from 'react';\n\nimport { ILLUSTRATIONS } from '../../../assets/illustrations/illustrations';\nimport { LOTTIE } from '../../../assets/lottie/lottie';\nimport { CircularLoader } from '../../ui/loader/circular-loader/circular-loader';\nimport Text from '../../ui/text/text';\nimport { useCircleSounds } from '../hooks/use-circle-sounds/use-circle-sounds';\nimport { Banner } from './comps/banner/banner';\nimport { LeaderboardItemWithObserver } from './comps/leaderboard-item/leaderboard-item';\nimport { NavigationButton } from './comps/navigation-button/navigation-button';\nimport { Timer } from './comps/timer/timer';\nimport { ELeaderboardType } from './enums/leaderboard-type-enum';\nimport { useTimer } from './hooks';\nimport * as Styled from './leaderboard-styled';\n\nconst BANNER_LOTTIES: Record<ELeaderboardType, string> = {\n [ELeaderboardType.ALL_TIME_STREAK]: LOTTIE.ELITE_CIRCLE,\n [ELeaderboardType.ALL_TIME]: LOTTIE.ELITE_CIRCLE,\n [ELeaderboardType.BI_WEEKLY]: LOTTIE.TOURNAMENT_RIPPLE,\n};\n\nconst leaderboards = [\n {\n name: 'TOURNAMENT',\n type: ELeaderboardType.BI_WEEKLY,\n },\n {\n name: 'STREAK STARS',\n type: ELeaderboardType.ALL_TIME_STREAK,\n },\n {\n name: 'ALL TIME',\n type: ELeaderboardType.ALL_TIME,\n },\n];\n\nexport const Leaderboard = ({\n leaderboardData,\n type = ELeaderboardType.BI_WEEKLY,\n userId,\n onClose,\n isLoading,\n}: ILeaderboardProps) => {\n const [currentLeaderBoardIndex, setCurrentLeaderboardIndex] = useState(\n leaderboards.findIndex(leaderboard => type === leaderboard.type),\n );\n\n const [currLeaderboardData, setCurrLeaderboardData] = useState<\n (ILeaderboardPlayerWithPoints | ILeaderboardPlayerWithStreak)[] | []\n >(leaderboardData?.[type]?.leaderboardPlayers || []);\n\n const [currLeaderboardTimeStamps, setCurrLeaderboardTimeStamps] = useState<{\n current: number;\n end: number;\n }>({\n current: 0,\n end: 0,\n });\n\n const [time, setTimer] = useTimer(0);\n const [isTournamentEnded, setIsTournamentEnded] = useState(false);\n const maxPoints = (currLeaderboardData?.[0] as ILeaderboardPlayerWithPoints)?.points;\n const maxStreakDays = (currLeaderboardData?.[0] as ILeaderboardPlayerWithStreak)?.streakDays || 0;\n const { playButtonSound } = useCircleSounds();\n\n const handlePrevious = () => {\n playButtonSound();\n setCurrentLeaderboardIndex(prev => {\n if (prev - 1 < 0) {\n return leaderboards.length - 1;\n }\n\n return prev - 1;\n });\n };\n\n const handleNext = () => {\n playButtonSound();\n setCurrentLeaderboardIndex(prev => {\n if (prev + 1 === leaderboards.length) {\n return 0;\n }\n\n return prev + 1;\n });\n };\n\n useEffect(() => {\n setTimer(0);\n }, [setTimer]);\n\n useEffect(() => {\n const currType = leaderboards[currentLeaderBoardIndex]?.type;\n const currLeaderboard = currType && leaderboardData?.[currType];\n\n if (currLeaderboard) {\n const leaderboardList = currLeaderboard.leaderboardPlayers || [];\n\n if (currType === ELeaderboardType.BI_WEEKLY) {\n setCurrLeaderboardTimeStamps({\n current: currLeaderboard.currentTimestamp,\n end: currLeaderboard.endTimestamp,\n });\n\n if (currLeaderboard.currentTimestamp > currLeaderboard.endTimestamp) {\n leaderboardList.splice(10);\n setIsTournamentEnded(true);\n }\n }\n\n setCurrLeaderboardData([...leaderboardList]);\n }\n }, [currentLeaderBoardIndex, leaderboardData]);\n\n return (\n <Styled.Leaderboard>\n <Styled.LeaderboardContainer>\n <Styled.BannerWrapper>\n {/* tournament banner */}\n {leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.BI_WEEKLY && (\n <Banner\n isLoading={isLoading || currLeaderboardData.length === 0}\n bgFromTopPosition={-120}\n bgFromRightPosition={-110}\n primaryText={\n isTournamentEnded ? <span>New Tournament</span> : <span>Tournament</span>\n }\n secondaryText={\n isTournamentEnded ? (\n <span>Starts Soon</span>\n ) : (\n <span>\n {' '}\n <Timer\n fromTimestamp={(time as number) + currLeaderboardTimeStamps.current}\n endTimestamp={currLeaderboardTimeStamps.end}\n />{' '}\n {'left'}\n </span>\n )\n }\n lottiePath={BANNER_LOTTIES[ELeaderboardType.BI_WEEKLY]}\n custEle={\n <Styled.TournamentBannerCustContainer>\n <Styled.TrophyWrapper>\n <img src={ILLUSTRATIONS.TROPHY_CIRCLE} />\n </Styled.TrophyWrapper>\n </Styled.TournamentBannerCustContainer>\n }\n />\n )}\n\n {/* top streak banner */}\n {leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.ALL_TIME_STREAK && (\n <Banner\n isLoading={isLoading}\n bgFromTopPosition={-140}\n bgFromRightPosition={-90}\n primaryText={<span>Streak Stars</span>}\n secondaryText={<span>Top 50</span>}\n lottiePath={BANNER_LOTTIES[ELeaderboardType.ALL_TIME_STREAK]}\n />\n )}\n\n {/* elite circle banner */}\n {leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.ALL_TIME && (\n <Banner\n isLoading={isLoading}\n bgFromTopPosition={-140}\n bgFromRightPosition={-90}\n primaryText={<span>Elite Circle</span>}\n secondaryText={<span>Top 50</span>}\n lottiePath={BANNER_LOTTIES[ELeaderboardType.ALL_TIME]}\n />\n )}\n </Styled.BannerWrapper>\n\n {isLoading && <CircularLoader />}\n\n {!isLoading && currLeaderboardData && (\n <Styled.ItemsWrapper topInset={0}>\n {isTournamentEnded &&\n leaderboards[currentLeaderBoardIndex]?.type === ELeaderboardType.BI_WEEKLY && (\n <Styled.Banner>\n <Text $renderAs=\"ab3\" $color=\"WHITE\">\n Congratulating winners of the last tournament!\n </Text>\n </Styled.Banner>\n )}\n {currLeaderboardData.map(player => {\n return (\n <LeaderboardItemWithObserver\n key={player.rank}\n player={player}\n rank={player.rank}\n maxStreakDays={maxStreakDays}\n maxPoints={maxPoints}\n leaderboardType={leaderboards[currentLeaderBoardIndex]?.type}\n isActive={player.userId === userId}\n />\n );\n })}\n </Styled.ItemsWrapper>\n )}\n\n <Styled.ActionButtonWrapper>\n <NavigationButton\n labels={Object.values(ELeaderboardType)}\n onLeftClick={handlePrevious}\n onRightClick={handleNext}\n currIndex={currentLeaderBoardIndex}\n onClose={onClose}\n disableSwipe={isLoading || currLeaderboardData.length === 0}\n />\n </Styled.ActionButtonWrapper>\n </Styled.LeaderboardContainer>\n </Styled.Leaderboard>\n );\n};\n"],"names":["BANNER_LOTTIES","ELeaderboardType","LOTTIE","leaderboards","Leaderboard","leaderboardData","type","userId","onClose","isLoading","currentLeaderBoardIndex","setCurrentLeaderboardIndex","useState","leaderboard","currLeaderboardData","setCurrLeaderboardData","_a","currLeaderboardTimeStamps","setCurrLeaderboardTimeStamps","time","setTimer","useTimer","isTournamentEnded","setIsTournamentEnded","maxPoints","_b","maxStreakDays","_c","playButtonSound","useCircleSounds","handlePrevious","prev","handleNext","useEffect","currType","currLeaderboard","leaderboardList","Styled.Leaderboard","jsxs","Styled.LeaderboardContainer","Styled.BannerWrapper","_d","jsx","Banner","Timer","Styled.TournamentBannerCustContainer","Styled.TrophyWrapper","ILLUSTRATIONS","_e","_f","CircularLoader","Styled.ItemsWrapper","_g","Styled.Banner","Text","player","LeaderboardItemWithObserver","Styled.ActionButtonWrapper","NavigationButton"],"mappings":";;;;;;;;;;;;;;AAqBA,MAAMA,IAAmD;AAAA,EACvD,CAACC,EAAiB,eAAe,GAAGC,EAAO;AAAA,EAC3C,CAACD,EAAiB,QAAQ,GAAGC,EAAO;AAAA,EACpC,CAACD,EAAiB,SAAS,GAAGC,EAAO;AACvC,GAEMC,IAAe;AAAA,EACnB;AAAA,IACE,MAAM;AAAA,IACN,MAAMF,EAAiB;AAAA,EACzB;AAAA,EACA;AAAA,IACE,MAAM;AAAA,IACN,MAAMA,EAAiB;AAAA,EACzB;AAAA,EACA;AAAA,IACE,MAAM;AAAA,IACN,MAAMA,EAAiB;AAAA,EACzB;AACF,GAEaG,KAAc,CAAC;AAAA,EAC1B,iBAAAC;AAAA,EACA,MAAAC,IAAOL,EAAiB;AAAA,EACxB,QAAAM;AAAA,EACA,SAAAC;AAAA,EACA,WAAAC;AACF,MAAyB;;AACjB,QAAA,CAACC,GAAyBC,CAA0B,IAAIC;AAAA,IAC5DT,EAAa,UAAU,CAAeU,MAAAP,MAASO,EAAY,IAAI;AAAA,EAAA,GAG3D,CAACC,GAAqBC,CAAsB,IAAIH,IAEpDI,IAAAX,KAAA,gBAAAA,EAAkBC,OAAlB,gBAAAU,EAAyB,uBAAsB,CAAA,CAAE,GAE7C,CAACC,GAA2BC,CAA4B,IAAIN,EAG/D;AAAA,IACD,SAAS;AAAA,IACT,KAAK;AAAA,EAAA,CACN,GAEK,CAACO,GAAMC,CAAQ,IAAIC,GAAS,CAAC,GAC7B,CAACC,GAAmBC,CAAoB,IAAIX,EAAS,EAAK,GAC1DY,KAAaC,IAAAX,KAAA,gBAAAA,EAAsB,OAAtB,gBAAAW,EAA2D,QACxEC,MAAiBC,IAAAb,KAAA,gBAAAA,EAAsB,OAAtB,gBAAAa,EAA2D,eAAc,GAC1F,EAAE,iBAAAC,MAAoBC,KAEtBC,IAAiB,MAAM;AACX,IAAAF,KAChBjB,EAA2B,CAAQoB,MAC7BA,IAAO,IAAI,IACN5B,EAAa,SAAS,IAGxB4B,IAAO,CACf;AAAA,EAAA,GAGGC,IAAa,MAAM;AACP,IAAAJ,KAChBjB,EAA2B,CAAQoB,MAC7BA,IAAO,MAAM5B,EAAa,SACrB,IAGF4B,IAAO,CACf;AAAA,EAAA;AAGH,SAAAE,EAAU,MAAM;AACd,IAAAb,EAAS,CAAC;AAAA,EAAA,GACT,CAACA,CAAQ,CAAC,GAEba,EAAU,MAAM;;AACR,UAAAC,KAAWlB,IAAAb,EAAaO,CAAuB,MAApC,gBAAAM,EAAuC,MAClDmB,IAAkBD,MAAY7B,KAAA,gBAAAA,EAAkB6B;AAEtD,QAAIC,GAAiB;AACb,YAAAC,IAAkBD,EAAgB,sBAAsB;AAE1D,MAAAD,MAAajC,EAAiB,cACHiB,EAAA;AAAA,QAC3B,SAASiB,EAAgB;AAAA,QACzB,KAAKA,EAAgB;AAAA,MAAA,CACtB,GAEGA,EAAgB,mBAAmBA,EAAgB,iBACrDC,EAAgB,OAAO,EAAE,GACzBb,EAAqB,EAAI,KAINR,EAAA,CAAC,GAAGqB,CAAe,CAAC;AAAA,IAC7C;AAAA,EAAA,GACC,CAAC1B,GAAyBL,CAAe,CAAC,qBAG1CgC,GAAA,EACC,UAAC,gBAAAC,EAAAC,GAAA,EACC,UAAA;AAAA,IAAC,gBAAAD,EAAAE,GAAA,EAEE,UAAA;AAAA,QAAAC,IAAAtC,EAAaO,CAAuB,MAApC,gBAAA+B,EAAuC,UAASxC,EAAiB,aAChE,gBAAAyC;AAAA,QAACC;AAAA,QAAA;AAAA,UACC,WAAWlC,KAAaK,EAAoB,WAAW;AAAA,UACvD,mBAAmB;AAAA,UACnB,qBAAqB;AAAA,UACrB,aACEQ,IAAqB,gBAAAoB,EAAA,QAAA,EAAK,4BAAc,IAAU,gBAAAA,EAAC,UAAK,UAAU,aAAA,CAAA;AAAA,UAEpE,eACEpB,IACE,gBAAAoB,EAAC,UAAK,UAAW,cAAA,CAAA,sBAEhB,QACE,EAAA,UAAA;AAAA,YAAA;AAAA,YACD,gBAAAA;AAAA,cAACE;AAAA,cAAA;AAAA,gBACC,eAAgBzB,IAAkBF,EAA0B;AAAA,gBAC5D,cAAcA,EAA0B;AAAA,cAAA;AAAA,YAC1C;AAAA,YAAG;AAAA,YACF;AAAA,UAAA,GACH;AAAA,UAGJ,YAAYjB,EAAeC,EAAiB,SAAS;AAAA,UACrD,SACE,gBAAAyC,EAACG,GAAA,EACC,UAAC,gBAAAH,EAAAI,GAAA,EACC,4BAAC,OAAI,EAAA,KAAKC,EAAc,cAAe,CAAA,EACzC,CAAA,GACF;AAAA,QAAA;AAAA,MAEJ;AAAA,QAIDC,IAAA7C,EAAaO,CAAuB,MAApC,gBAAAsC,EAAuC,UAAS/C,EAAiB,mBAChE,gBAAAyC;AAAA,QAACC;AAAA,QAAA;AAAA,UACC,WAAAlC;AAAA,UACA,mBAAmB;AAAA,UACnB,qBAAqB;AAAA,UACrB,aAAc,gBAAAiC,EAAA,QAAA,EAAK,UAAY,eAAA,CAAA;AAAA,UAC/B,eAAgB,gBAAAA,EAAA,QAAA,EAAK,UAAM,SAAA,CAAA;AAAA,UAC3B,YAAY1C,EAAeC,EAAiB,eAAe;AAAA,QAAA;AAAA,MAC7D;AAAA,QAIDgD,IAAA9C,EAAaO,CAAuB,MAApC,gBAAAuC,EAAuC,UAAShD,EAAiB,YAChE,gBAAAyC;AAAA,QAACC;AAAA,QAAA;AAAA,UACC,WAAAlC;AAAA,UACA,mBAAmB;AAAA,UACnB,qBAAqB;AAAA,UACrB,aAAc,gBAAAiC,EAAA,QAAA,EAAK,UAAY,eAAA,CAAA;AAAA,UAC/B,eAAgB,gBAAAA,EAAA,QAAA,EAAK,UAAM,SAAA,CAAA;AAAA,UAC3B,YAAY1C,EAAeC,EAAiB,QAAQ;AAAA,QAAA;AAAA,MACtD;AAAA,IAAA,GAEJ;AAAA,IAECQ,uBAAcyC,GAAe,EAAA;AAAA,IAE7B,CAACzC,KAAaK,KACb,gBAAAwB,EAACa,GAAA,EAAoB,UAAU,GAC5B,UAAA;AAAA,MAAA7B,OACC8B,IAAAjD,EAAaO,CAAuB,MAApC,gBAAA0C,EAAuC,UAASnD,EAAiB,aAC9D,gBAAAyC,EAAAW,GAAA,EACC,4BAACC,GAAK,EAAA,WAAU,OAAM,QAAO,SAAQ,2DAErC,CAAA,GACF;AAAA,MAEHxC,EAAoB,IAAI,CAAUyC,MAAA;;AAE/B,eAAA,gBAAAb;AAAA,UAACc;AAAA,UAAA;AAAA,YAEC,QAAAD;AAAA,YACA,MAAMA,EAAO;AAAA,YACb,eAAA7B;AAAA,YACA,WAAAF;AAAA,YACA,kBAAiBR,IAAAb,EAAaO,CAAuB,MAApC,gBAAAM,EAAuC;AAAA,YACxD,UAAUuC,EAAO,WAAWhD;AAAA,UAAA;AAAA,UANvBgD,EAAO;AAAA,QAAA;AAAA,MAOd,CAEH;AAAA,IAAA,GACH;AAAA,IAGF,gBAAAb,EAACe,IAAA,EACC,UAAA,gBAAAf;AAAA,MAACgB;AAAA,MAAA;AAAA,QACC,QAAQ,OAAO,OAAOzD,CAAgB;AAAA,QACtC,aAAa6B;AAAA,QACb,cAAcE;AAAA,QACd,WAAWtB;AAAA,QACX,SAAAF;AAAA,QACA,cAAcC,KAAaK,EAAoB,WAAW;AAAA,MAAA;AAAA,IAAA,GAE9D;AAAA,EAAA,EACF,CAAA,EACF,CAAA;AAEJ;"}
@@ -1,50 +1,49 @@
1
- import { jsx as e, Fragment as E, jsxs as s } from "react/jsx-runtime";
2
- import R from "lottie-web";
3
- import { useRef as l, useEffect as g } from "react";
4
- import S from "../../../../../assets/line-icons/icons/circle-back.js";
5
- import P from "../../../../../assets/lotties/circle/levelup-rings-lottie.json.js";
6
- import b from "../../../../ui/text/text.js";
7
- import { BackgroundImage as I, ScreenWrapper as T, TransparentIconButton as q, CircularStepsContainer as F, CircularStepsWrapper as v, CustEleContainer as y, CircularProgressContainer as L, CircularProgress as w, Label as M, CustomDataContainer as W } from "./circular-steps-styled.js";
1
+ import { jsx as e, Fragment as k, jsxs as c } from "react/jsx-runtime";
2
+ import { useRef as m, useCallback as S } from "react";
3
+ import B from "../../../../../assets/line-icons/icons/circle-back.js";
4
+ import { LOTTIE as R } from "../../../../../assets/lottie/lottie.js";
5
+ import A from "../../../../ui/lottie-animation/lottie-animation.js";
6
+ import I from "../../../../ui/text/text.js";
7
+ import { BackgroundImage as P, ScreenWrapper as b, TransparentIconButton as L, CircularStepsContainer as T, CircularStepsWrapper as q, CustEleContainer as v, CircularProgressContainer as F, CircularProgress as w, Label as M, CustomDataContainer as W } from "./circular-steps-styled.js";
8
8
  import { TOTAL_FRAMES as $ } from "./constants.js";
9
- const j = ({ img: t }) => /* @__PURE__ */ e(I, { children: t }), K = ({ steps: t, currentStepIndex: i, dimensions: f }) => {
10
- const { width: u, height: m } = f, r = t[i], d = l(null), a = l(null), c = l(-1), h = () => {
11
- var o, n;
12
- (n = (o = t[i]) == null ? void 0 : o.onBack) == null || n.call(o);
13
- }, p = (o, n) => {
14
- a.current && a.current.playSegments([o, n], !0);
15
- };
16
- return g(() => ((async () => {
17
- a.current = R.loadAnimation({
18
- container: d.current,
19
- animationData: P,
20
- autoplay: !1,
21
- loop: !1,
22
- renderer: "canvas"
23
- });
24
- })(), () => {
25
- var n;
26
- (n = a.current) == null || n.destroy();
27
- }), [r == null ? void 0 : r.isProgressAnimationRequired]), g(() => {
28
- if (a.current && (r != null && r.isProgressAnimationRequired)) {
29
- const o = t.filter((B) => B.isProgressAnimationRequired), n = $ / o.length, C = c.current >= 0 ? c.current : 0, A = Math.round(C * n), k = Math.round(i * n);
30
- p(A, k), c.current = i;
9
+ const j = ({ img: n }) => /* @__PURE__ */ e(P, { children: n }), x = {
10
+ autoplay: !1,
11
+ loop: !1,
12
+ renderer: "canvas"
13
+ }, U = ({ steps: n, currentStepIndex: t, dimensions: d }) => {
14
+ const { width: s, height: u } = d, r = n[t], l = m(null), a = m(-1), g = () => {
15
+ var o, i;
16
+ (i = (o = n[t]) == null ? void 0 : o.onBack) == null || i.call(o);
17
+ }, h = S(() => {
18
+ if (l.current && (r != null && r.isProgressAnimationRequired)) {
19
+ const o = n.filter((E) => E.isProgressAnimationRequired), i = $ / o.length, p = a.current >= 0 ? a.current : 0, f = Math.round(p * i + 1), C = Math.round(t * i);
20
+ a.current = t, l.current.playSegments([f, C], !0);
31
21
  }
32
- }, [i, r == null ? void 0 : r.isProgressAnimationRequired, t]), /* @__PURE__ */ e(E, { children: r && /* @__PURE__ */ s(T, { width: u, height: m, children: [
33
- r.onBack && /* @__PURE__ */ e(q, { children: /* @__PURE__ */ e(S, { onClick: h }) }),
34
- r.background && /* @__PURE__ */ e(j, { img: r.background }),
35
- /* @__PURE__ */ e(F, { children: /* @__PURE__ */ s(v, { children: [
36
- r.custEle ? /* @__PURE__ */ e(y, { children: r.custEle }) : null,
37
- r.custEleInsideStep && /* @__PURE__ */ s(L, { width: u, height: m, children: [
38
- r.isProgressAnimationRequired && /* @__PURE__ */ e(w, { ref: d }),
39
- r.label && /* @__PURE__ */ e(M, { children: /* @__PURE__ */ e(b, { $renderAs: "ab2", $color: "WHITE", children: r.label }) }),
22
+ }, [t, r == null ? void 0 : r.isProgressAnimationRequired, n]);
23
+ return /* @__PURE__ */ e(k, { children: r ? /* @__PURE__ */ c(b, { width: s, height: u, children: [
24
+ r.onBack ? /* @__PURE__ */ e(L, { children: /* @__PURE__ */ e(B, { onClick: g }) }) : null,
25
+ r.background ? /* @__PURE__ */ e(j, { img: r.background }) : null,
26
+ /* @__PURE__ */ e(T, { children: /* @__PURE__ */ c(q, { children: [
27
+ r.custEle ? /* @__PURE__ */ e(v, { children: r.custEle }) : null,
28
+ r.custEleInsideStep ? /* @__PURE__ */ c(F, { width: s, height: u, children: [
29
+ r.isProgressAnimationRequired ? /* @__PURE__ */ e(w, { children: /* @__PURE__ */ e(
30
+ A,
31
+ {
32
+ ref: l,
33
+ src: R.LEVELUP_RINGS,
34
+ settings: x,
35
+ onRender: h
36
+ }
37
+ ) }) : null,
38
+ r.label ? /* @__PURE__ */ e(M, { children: /* @__PURE__ */ e(I, { $renderAs: "ab2", $color: "WHITE", children: r.label }) }) : null,
40
39
  r.custEleInsideStep
41
- ] })
40
+ ] }) : null
42
41
  ] }) }),
43
- r.custEleBelowStep && /* @__PURE__ */ e(W, { children: r.custEleBelowStep })
44
- ] }) });
42
+ r.custEleBelowStep ? /* @__PURE__ */ e(W, { children: r.custEleBelowStep }) : null
43
+ ] }) : null });
45
44
  };
46
45
  export {
47
46
  j as BackgroundImage,
48
- K as CircularSteps
47
+ U as CircularSteps
49
48
  };
50
49
  //# sourceMappingURL=circular-steps.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"circular-steps.js","sources":["../../../../../../src/features/circle-games/sign-up/comp/circular-steps/circular-steps.tsx"],"sourcesContent":["import type { ICircularStepsProps } from './circular-steps-types';\nimport type { AnimationItem } from 'lottie-web';\nimport type { FC } from 'react';\n\nimport Lottie from 'lottie-web';\nimport { useEffect, useRef } from 'react';\n\nimport CircleBackIcon from '../../../../../assets/line-icons/icons/circle-back';\nimport progressRingLottie from '../../../../../assets/lotties/circle/levelup-rings-lottie.json';\nimport Text from '../../../../ui/text/text';\nimport * as Styled from './circular-steps-styled';\nimport { TOTAL_FRAMES } from './constants';\n\nexport const BackgroundImage = ({ img }: { img: React.ReactNode }) => {\n return <Styled.BackgroundImage>{img}</Styled.BackgroundImage>;\n};\n\nexport const CircularSteps: FC<ICircularStepsProps> = ({ steps, currentStepIndex, dimensions }) => {\n const { width, height } = dimensions;\n\n const step = steps[currentStepIndex];\n const lottieAnimationRef = useRef<HTMLDivElement>(null);\n const animationRef = useRef<AnimationItem | null>(null);\n const previousStepIndex = useRef<number>(-1);\n\n const handleBack = () => {\n steps[currentStepIndex]?.onBack?.();\n };\n const goToFrame = (fromFrame: number, toFrame: number) => {\n if (animationRef.current) {\n animationRef.current.playSegments([fromFrame, toFrame], true);\n }\n };\n\n // Load animation\n useEffect(() => {\n const loadAnimation = async () => {\n animationRef.current = Lottie.loadAnimation({\n container: lottieAnimationRef.current as Element,\n animationData: progressRingLottie,\n autoplay: false,\n loop: false,\n renderer: 'canvas',\n });\n };\n\n loadAnimation();\n\n return () => {\n animationRef.current?.destroy();\n };\n }, [step?.isProgressAnimationRequired]);\n\n useEffect(() => {\n if (animationRef.current && step?.isProgressAnimationRequired) {\n const actualSteps = steps.filter(_step => _step.isProgressAnimationRequired);\n const stepSize = TOTAL_FRAMES / actualSteps.length;\n\n const validPreviousIndex = previousStepIndex.current >= 0 ? previousStepIndex.current : 0;\n\n const fromFrame = Math.round(validPreviousIndex * stepSize);\n const toFrame = Math.round(currentStepIndex * stepSize);\n\n goToFrame(fromFrame, toFrame);\n previousStepIndex.current = currentStepIndex;\n }\n }, [currentStepIndex, step?.isProgressAnimationRequired, steps]);\n\n return (\n <>\n {step && (\n <Styled.ScreenWrapper width={width} height={height}>\n {step.onBack && (\n <Styled.TransparentIconButton>\n <CircleBackIcon onClick={handleBack} />\n </Styled.TransparentIconButton>\n )}\n {step.background && <BackgroundImage img={step.background} />}\n <Styled.CircularStepsContainer>\n <Styled.CircularStepsWrapper>\n {step.custEle ? (\n <Styled.CustEleContainer>{step.custEle}</Styled.CustEleContainer>\n ) : null}\n\n {/*circular data container*/}\n {step.custEleInsideStep && (\n <Styled.CircularProgressContainer width={width} height={height}>\n {step.isProgressAnimationRequired && (\n <Styled.CircularProgress ref={lottieAnimationRef} />\n )}\n\n {step.label && (\n <Styled.Label>\n <Text $renderAs=\"ab2\" $color=\"WHITE\">\n {step.label}\n </Text>\n </Styled.Label>\n )}\n {step.custEleInsideStep}\n </Styled.CircularProgressContainer>\n )}\n </Styled.CircularStepsWrapper>\n </Styled.CircularStepsContainer>\n {/* custom data container below circle */}\n {step.custEleBelowStep && (\n <Styled.CustomDataContainer>{step.custEleBelowStep}</Styled.CustomDataContainer>\n )}\n </Styled.ScreenWrapper>\n )}\n </>\n );\n};\n"],"names":["BackgroundImage","img","jsx","Styled.BackgroundImage","CircularSteps","steps","currentStepIndex","dimensions","width","height","step","lottieAnimationRef","useRef","animationRef","previousStepIndex","handleBack","_b","_a","goToFrame","fromFrame","toFrame","useEffect","Lottie","progressRingLottie","actualSteps","_step","stepSize","TOTAL_FRAMES","validPreviousIndex","jsxs","Styled.ScreenWrapper","Styled.TransparentIconButton","CircleBackIcon","Styled.CircularStepsContainer","Styled.CircularStepsWrapper","Styled.CustEleContainer","Styled.CircularProgressContainer","Styled.CircularProgress","Styled.Label","Text","Styled.CustomDataContainer"],"mappings":";;;;;;;;AAaO,MAAMA,IAAkB,CAAC,EAAE,KAAAC,QACxB,gBAAAC,EAAAC,GAAA,EAAwB,UAAIF,EAAA,CAAA,GAGzBG,IAAyC,CAAC,EAAE,OAAAC,GAAO,kBAAAC,GAAkB,YAAAC,QAAiB;AAC3F,QAAA,EAAE,OAAAC,GAAO,QAAAC,EAAW,IAAAF,GAEpBG,IAAOL,EAAMC,CAAgB,GAC7BK,IAAqBC,EAAuB,IAAI,GAChDC,IAAeD,EAA6B,IAAI,GAChDE,IAAoBF,EAAe,EAAE,GAErCG,IAAa,MAAM;;AACjB,KAAAC,KAAAC,IAAAZ,EAAAC,CAAgB,MAAhB,gBAAAW,EAAmB,WAAnB,QAAAD,EAAA,KAAAC;AAAA,EAA4B,GAE9BC,IAAY,CAACC,GAAmBC,MAAoB;AACxD,IAAIP,EAAa,WACfA,EAAa,QAAQ,aAAa,CAACM,GAAWC,CAAO,GAAG,EAAI;AAAA,EAC9D;AAIF,SAAAC,EAAU,QACc,YAAY;AACnB,IAAAR,EAAA,UAAUS,EAAO,cAAc;AAAA,MAC1C,WAAWX,EAAmB;AAAA,MAC9B,eAAeY;AAAA,MACf,UAAU;AAAA,MACV,MAAM;AAAA,MACN,UAAU;AAAA,IAAA,CACX;AAAA,EAAA,MAKI,MAAM;;AACX,KAAAN,IAAAJ,EAAa,YAAb,QAAAI,EAAsB;AAAA,EAAQ,IAE/B,CAACP,KAAA,gBAAAA,EAAM,2BAA2B,CAAC,GAEtCW,EAAU,MAAM;AACV,QAAAR,EAAa,YAAWH,KAAA,QAAAA,EAAM,8BAA6B;AAC7D,YAAMc,IAAcnB,EAAM,OAAO,CAAAoB,MAASA,EAAM,2BAA2B,GACrEC,IAAWC,IAAeH,EAAY,QAEtCI,IAAqBd,EAAkB,WAAW,IAAIA,EAAkB,UAAU,GAElFK,IAAY,KAAK,MAAMS,IAAqBF,CAAQ,GACpDN,IAAU,KAAK,MAAMd,IAAmBoB,CAAQ;AAEtD,MAAAR,EAAUC,GAAWC,CAAO,GAC5BN,EAAkB,UAAUR;AAAA,IAC9B;AAAA,KACC,CAACA,GAAkBI,KAAA,gBAAAA,EAAM,6BAA6BL,CAAK,CAAC,0BAI1D,UACCK,KAAA,gBAAAmB,EAACC,GAAA,EAAqB,OAAAtB,GAAc,QAAAC,GACjC,UAAA;AAAA,IAAKC,EAAA,4BACHqB,GAAA,EACC,UAAC,gBAAA7B,EAAA8B,GAAA,EAAe,SAASjB,EAAA,CAAY,EACvC,CAAA;AAAA,IAEDL,EAAK,cAAc,gBAAAR,EAACF,GAAgB,EAAA,KAAKU,EAAK,YAAY;AAAA,sBAC1DuB,GAAA,EACC,UAAC,gBAAAJ,EAAAK,GAAA,EACE,UAAA;AAAA,MAAAxB,EAAK,UACH,gBAAAR,EAAAiC,GAAA,EAAyB,UAAAzB,EAAK,QAAQ,CAAA,IACrC;AAAA,MAGHA,EAAK,qBACJ,gBAAAmB,EAACO,GAAA,EAAiC,OAAA5B,GAAc,QAAAC,GAC7C,UAAA;AAAA,QAAAC,EAAK,+BACH,gBAAAR,EAAAmC,GAAA,EAAwB,KAAK1B,GAAoB;AAAA,QAGnDD,EAAK,SACH,gBAAAR,EAAAoC,GAAA,EACC,UAAA,gBAAApC,EAACqC,GAAK,EAAA,WAAU,OAAM,QAAO,SAC1B,UAAA7B,EAAK,MACR,CAAA,GACF;AAAA,QAEDA,EAAK;AAAA,MAAA,GACR;AAAA,IAAA,EAAA,CAEJ,EACF,CAAA;AAAA,IAECA,EAAK,oBACJ,gBAAAR,EAACsC,GAAA,EAA4B,YAAK,kBAAiB;AAAA,EAAA,EAEvD,CAAA,EAEJ,CAAA;AAEJ;"}
1
+ {"version":3,"file":"circular-steps.js","sources":["../../../../../../src/features/circle-games/sign-up/comp/circular-steps/circular-steps.tsx"],"sourcesContent":["import type { ILottieAnimationRef } from '../../../../ui/lottie-animation/types';\nimport type { ICircularStepsProps } from './circular-steps-types';\nimport type { FC } from 'react';\n\nimport { useCallback, useRef } from 'react';\n\nimport CircleBackIcon from '../../../../../assets/line-icons/icons/circle-back';\nimport { LOTTIE } from '../../../../../assets/lottie/lottie';\nimport LottieAnimation from '../../../../ui/lottie-animation/lottie-animation';\nimport Text from '../../../../ui/text/text';\nimport * as Styled from './circular-steps-styled';\nimport { TOTAL_FRAMES } from './constants';\n\nexport const BackgroundImage = ({ img }: { img: React.ReactNode }) => {\n return <Styled.BackgroundImage>{img}</Styled.BackgroundImage>;\n};\n\nconst animationSettings = {\n autoplay: false,\n loop: false,\n renderer: 'canvas',\n};\n\nexport const CircularSteps: FC<ICircularStepsProps> = ({ steps, currentStepIndex, dimensions }) => {\n const { width, height } = dimensions;\n\n const step = steps[currentStepIndex];\n const animationRef = useRef<ILottieAnimationRef | null>(null);\n const previousStepIndex = useRef<number>(-1);\n\n const handleBack = () => {\n steps[currentStepIndex]?.onBack?.();\n };\n\n const onLottieRender = useCallback(() => {\n if (animationRef.current && step?.isProgressAnimationRequired) {\n const actualSteps = steps.filter(_step => _step.isProgressAnimationRequired);\n const stepSize = TOTAL_FRAMES / actualSteps.length;\n\n const validPreviousIndex = previousStepIndex.current >= 0 ? previousStepIndex.current : 0;\n\n const fromFrame = Math.round(validPreviousIndex * stepSize + 1);\n const toFrame = Math.round(currentStepIndex * stepSize);\n\n previousStepIndex.current = currentStepIndex;\n animationRef.current.playSegments([fromFrame, toFrame], true);\n }\n }, [currentStepIndex, step?.isProgressAnimationRequired, steps]);\n\n return (\n <>\n {step ? (\n <Styled.ScreenWrapper width={width} height={height}>\n {step.onBack ? (\n <Styled.TransparentIconButton>\n <CircleBackIcon onClick={handleBack} />\n </Styled.TransparentIconButton>\n ) : null}\n {step.background ? <BackgroundImage img={step.background} /> : null}\n <Styled.CircularStepsContainer>\n <Styled.CircularStepsWrapper>\n {step.custEle ? (\n <Styled.CustEleContainer>{step.custEle}</Styled.CustEleContainer>\n ) : null}\n\n {/*circular data container*/}\n {step.custEleInsideStep ? (\n <Styled.CircularProgressContainer width={width} height={height}>\n {step.isProgressAnimationRequired ? (\n <Styled.CircularProgress>\n <LottieAnimation\n ref={animationRef}\n src={LOTTIE.LEVELUP_RINGS}\n settings={animationSettings}\n onRender={onLottieRender}\n />\n </Styled.CircularProgress>\n ) : null}\n\n {step.label ? (\n <Styled.Label>\n <Text $renderAs=\"ab2\" $color=\"WHITE\">\n {step.label}\n </Text>\n </Styled.Label>\n ) : null}\n {step.custEleInsideStep}\n </Styled.CircularProgressContainer>\n ) : null}\n </Styled.CircularStepsWrapper>\n </Styled.CircularStepsContainer>\n {/* custom data container below circle */}\n {step.custEleBelowStep ? (\n <Styled.CustomDataContainer>{step.custEleBelowStep}</Styled.CustomDataContainer>\n ) : null}\n </Styled.ScreenWrapper>\n ) : null}\n </>\n );\n};\n"],"names":["BackgroundImage","img","jsx","Styled.BackgroundImage","animationSettings","CircularSteps","steps","currentStepIndex","dimensions","width","height","step","animationRef","useRef","previousStepIndex","handleBack","_b","_a","onLottieRender","useCallback","actualSteps","_step","stepSize","TOTAL_FRAMES","validPreviousIndex","fromFrame","toFrame","jsxs","Styled.ScreenWrapper","Styled.TransparentIconButton","CircleBackIcon","Styled.CircularStepsContainer","Styled.CircularStepsWrapper","Styled.CustEleContainer","Styled.CircularProgressContainer","Styled.CircularProgress","LottieAnimation","LOTTIE","Styled.Label","Text","Styled.CustomDataContainer"],"mappings":";;;;;;;;AAaO,MAAMA,IAAkB,CAAC,EAAE,KAAAC,QACxB,gBAAAC,EAAAC,GAAA,EAAwB,UAAIF,EAAA,CAAA,GAGhCG,IAAoB;AAAA,EACxB,UAAU;AAAA,EACV,MAAM;AAAA,EACN,UAAU;AACZ,GAEaC,IAAyC,CAAC,EAAE,OAAAC,GAAO,kBAAAC,GAAkB,YAAAC,QAAiB;AAC3F,QAAA,EAAE,OAAAC,GAAO,QAAAC,EAAW,IAAAF,GAEpBG,IAAOL,EAAMC,CAAgB,GAC7BK,IAAeC,EAAmC,IAAI,GACtDC,IAAoBD,EAAe,EAAE,GAErCE,IAAa,MAAM;;AACjB,KAAAC,KAAAC,IAAAX,EAAAC,CAAgB,MAAhB,gBAAAU,EAAmB,WAAnB,QAAAD,EAAA,KAAAC;AAAA,EAA4B,GAG9BC,IAAiBC,EAAY,MAAM;AACnC,QAAAP,EAAa,YAAWD,KAAA,QAAAA,EAAM,8BAA6B;AAC7D,YAAMS,IAAcd,EAAM,OAAO,CAAAe,MAASA,EAAM,2BAA2B,GACrEC,IAAWC,IAAeH,EAAY,QAEtCI,IAAqBV,EAAkB,WAAW,IAAIA,EAAkB,UAAU,GAElFW,IAAY,KAAK,MAAMD,IAAqBF,IAAW,CAAC,GACxDI,IAAU,KAAK,MAAMnB,IAAmBe,CAAQ;AAEtD,MAAAR,EAAkB,UAAUP,GAC5BK,EAAa,QAAQ,aAAa,CAACa,GAAWC,CAAO,GAAG,EAAI;AAAA,IAC9D;AAAA,KACC,CAACnB,GAAkBI,KAAA,gBAAAA,EAAM,6BAA6BL,CAAK,CAAC;AAE/D,gCAEK,UACCK,IAAA,gBAAAgB,EAACC,GAAA,EAAqB,OAAAnB,GAAc,QAAAC,GACjC,UAAA;AAAA,IAAKC,EAAA,SACH,gBAAAT,EAAA2B,GAAA,EACC,4BAACC,GAAe,EAAA,SAASf,GAAY,EAAA,CACvC,IACE;AAAA,IACHJ,EAAK,aAAa,gBAAAT,EAACF,KAAgB,KAAKW,EAAK,WAAY,CAAA,IAAK;AAAA,sBAC9DoB,GAAA,EACC,UAAC,gBAAAJ,EAAAK,GAAA,EACE,UAAA;AAAA,MAAArB,EAAK,UACH,gBAAAT,EAAA+B,GAAA,EAAyB,UAAAtB,EAAK,QAAQ,CAAA,IACrC;AAAA,MAGHA,EAAK,oBACJ,gBAAAgB,EAACO,GAAA,EAAiC,OAAAzB,GAAc,QAAAC,GAC7C,UAAA;AAAA,QAAAC,EAAK,8BACJ,gBAAAT,EAACiC,GAAA,EACC,UAAA,gBAAAjC;AAAA,UAACkC;AAAA,UAAA;AAAA,YACC,KAAKxB;AAAA,YACL,KAAKyB,EAAO;AAAA,YACZ,UAAUjC;AAAA,YACV,UAAUc;AAAA,UAAA;AAAA,WAEd,IACE;AAAA,QAEHP,EAAK,QACH,gBAAAT,EAAAoC,GAAA,EACC,UAAA,gBAAApC,EAACqC,GAAK,EAAA,WAAU,OAAM,QAAO,SAC1B,UAAK5B,EAAA,MACR,CAAA,EACF,CAAA,IACE;AAAA,QACHA,EAAK;AAAA,MAAA,EAAA,CACR,IACE;AAAA,IAAA,EAAA,CACN,EACF,CAAA;AAAA,IAECA,EAAK,mBACH,gBAAAT,EAAAsC,GAAA,EAA4B,UAAA7B,EAAK,iBAAiB,CAAA,IACjD;AAAA,EAAA,GACN,IACE,KACN,CAAA;AAEJ;"}
@@ -1,15 +1,11 @@
1
- import t from "styled-components";
2
- const p = t.div`
1
+ import n from "styled-components";
2
+ const i = n.div`
3
3
  display: flex;
4
4
  justify-content: center;
5
5
  align-items: center;
6
- margin: ${({ marginY: e, marginX: i }) => `${e}px ${i}px`};
7
- `, r = t.div`
8
- height: ${({ height: e }) => e}px;
9
- width: ${({ width: e }) => e}px;
6
+ margin: ${({ marginY: e, marginX: t }) => `${e}px ${t}px`};
10
7
  `;
11
8
  export {
12
- r as Spinner,
13
- p as SpinnerWrapper
9
+ i as SpinnerWrapper
14
10
  };
15
11
  //# sourceMappingURL=spinner-styled.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"spinner-styled.js","sources":["../../../../../../src/features/circle-games/sign-up/comp/spinner/spinner-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nexport const SpinnerWrapper = styled.div<{ marginY: number; marginX: number }>`\n display: flex;\n justify-content: center;\n align-items: center;\n margin: ${({ marginY, marginX }) => `${marginY}px ${marginX}px`};\n`;\n\nexport const Spinner = styled.div<{ height: number; width: number }>`\n height: ${({ height }) => height}px;\n width: ${({ width }) => width}px;\n`;\n"],"names":["SpinnerWrapper","styled","marginY","marginX","Spinner","height","width"],"mappings":";AAEO,MAAMA,IAAiBC,EAAO;AAAA;AAAA;AAAA;AAAA,YAIzB,CAAC,EAAE,SAAAC,GAAS,SAAAC,QAAc,GAAGD,CAAO,MAAMC,CAAO,IAAI;AAAA,GAGpDC,IAAUH,EAAO;AAAA,YAClB,CAAC,EAAE,QAAAI,EAAO,MAAMA,CAAM;AAAA,WACvB,CAAC,EAAE,OAAAC,EAAM,MAAMA,CAAK;AAAA;"}
1
+ {"version":3,"file":"spinner-styled.js","sources":["../../../../../../src/features/circle-games/sign-up/comp/spinner/spinner-styled.tsx"],"sourcesContent":["import styled from 'styled-components';\n\nexport const SpinnerWrapper = styled.div<{ marginY: number; marginX: number }>`\n display: flex;\n justify-content: center;\n align-items: center;\n margin: ${({ marginY, marginX }) => `${marginY}px ${marginX}px`};\n`;\n"],"names":["SpinnerWrapper","styled","marginY","marginX"],"mappings":";AAEO,MAAMA,IAAiBC,EAAO;AAAA;AAAA;AAAA;AAAA,YAIzB,CAAC,EAAE,SAAAC,GAAS,SAAAC,QAAc,GAAGD,CAAO,MAAMC,CAAO,IAAI;AAAA;"}
@@ -1,26 +1,9 @@
1
- import { jsx as o } from "react/jsx-runtime";
2
- import p from "lottie-web";
3
- import { useRef as m, useEffect as s } from "react";
4
- import { SpinnerWrapper as u, Spinner as c } from "./spinner-styled.js";
5
- const d = () => import("../../../../../assets/lotties/circle/spinner-white.json.js"), M = ({ height: r = 24, width: e = 24, marginX: i = 0, marginY: a = 0 }) => {
6
- const t = m(null);
7
- return s(() => {
8
- let n = null;
9
- return (async () => {
10
- const l = (await d()).default;
11
- n = p.loadAnimation({
12
- container: t.current,
13
- animationData: l,
14
- autoplay: !0,
15
- loop: !0,
16
- renderer: "canvas"
17
- });
18
- })(), () => {
19
- n == null || n.destroy();
20
- };
21
- }, []), /* @__PURE__ */ o(u, { marginX: i, marginY: a, children: /* @__PURE__ */ o(c, { ref: t, height: r, width: e }) });
22
- };
1
+ import { jsx as r } from "react/jsx-runtime";
2
+ import { LOTTIE as t } from "../../../../../assets/lottie/lottie.js";
3
+ import n from "../../../../ui/lottie-animation/lottie-animation.js";
4
+ import { SpinnerWrapper as e } from "./spinner-styled.js";
5
+ const I = ({ height: o = 24, width: i = 24, marginX: m = 0, marginY: p = 0 }) => /* @__PURE__ */ r(e, { marginX: m, marginY: p, children: /* @__PURE__ */ r(n, { src: t.SPINNER_WHITE, height: o, width: i }) });
23
6
  export {
24
- M as Spinner
7
+ I as Spinner
25
8
  };
26
9
  //# sourceMappingURL=spinner.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"spinner.js","sources":["../../../../../../src/features/circle-games/sign-up/comp/spinner/spinner.tsx"],"sourcesContent":["import type { TSpinnerProps } from './spinner-types';\nimport type { AnimationItem } from 'lottie-web';\n\nimport Lottie from 'lottie-web';\nimport { useEffect, useRef } from 'react';\n\nimport * as S from './spinner-styled';\n\nconst spinnerWhite = () => import('../../../../../assets/lotties/circle/spinner-white.json');\n\nexport const Spinner = ({ height = 24, width = 24, marginX = 0, marginY = 0 }: TSpinnerProps) => {\n const lottieContainer = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n let animation: AnimationItem | null = null;\n const loadAnimation = async () => {\n const animationModule = await spinnerWhite();\n const animationData = animationModule.default;\n\n animation = Lottie.loadAnimation({\n container: lottieContainer.current as Element,\n animationData: animationData,\n autoplay: true,\n loop: true,\n renderer: 'canvas',\n });\n };\n\n loadAnimation();\n\n return () => {\n animation?.destroy();\n };\n }, []);\n\n return (\n <S.SpinnerWrapper marginX={marginX} marginY={marginY}>\n <S.Spinner ref={lottieContainer} height={height} width={width} />\n </S.SpinnerWrapper>\n );\n};\n"],"names":["spinnerWhite","Spinner","height","width","marginX","marginY","lottieContainer","useRef","useEffect","animation","animationData","Lottie","jsx","S.SpinnerWrapper","S.Spinner"],"mappings":";;;;AAQA,MAAMA,IAAe,MAAM,OAAO,4DAAyD,GAE9EC,IAAU,CAAC,EAAE,QAAAC,IAAS,IAAI,OAAAC,IAAQ,IAAI,SAAAC,IAAU,GAAG,SAAAC,IAAU,QAAuB;AACzF,QAAAC,IAAkBC,EAAuB,IAAI;AAEnD,SAAAC,EAAU,MAAM;AACd,QAAIC,IAAkC;AAcxB,YAbQ,YAAY;AAEhC,YAAMC,KADkB,MAAMV,KACQ;AAEtC,MAAAS,IAAYE,EAAO,cAAc;AAAA,QAC/B,WAAWL,EAAgB;AAAA,QAC3B,eAAAI;AAAA,QACA,UAAU;AAAA,QACV,MAAM;AAAA,QACN,UAAU;AAAA,MAAA,CACX;AAAA,IAAA,MAKI,MAAM;AACX,MAAAD,KAAA,QAAAA,EAAW;AAAA,IAAQ;AAAA,EAEvB,GAAG,CAAE,CAAA,GAGF,gBAAAG,EAAAC,GAAA,EAAiB,SAAAT,GAAkB,SAAAC,GAClC,UAAA,gBAAAO,EAACE,GAAA,EAAU,KAAKR,GAAiB,QAAAJ,GAAgB,OAAAC,EAAc,CAAA,EACjE,CAAA;AAEJ;"}
1
+ {"version":3,"file":"spinner.js","sources":["../../../../../../src/features/circle-games/sign-up/comp/spinner/spinner.tsx"],"sourcesContent":["import type { TSpinnerProps } from './spinner-types';\n\nimport { LOTTIE } from '../../../../../assets/lottie/lottie';\nimport LottieAnimation from '../../../../ui/lottie-animation/lottie-animation';\nimport * as Styled from './spinner-styled';\n\nexport const Spinner = ({ height = 24, width = 24, marginX = 0, marginY = 0 }: TSpinnerProps) => (\n <Styled.SpinnerWrapper marginX={marginX} marginY={marginY}>\n <LottieAnimation src={LOTTIE.SPINNER_WHITE} height={height} width={width} />\n </Styled.SpinnerWrapper>\n);\n"],"names":["Spinner","height","width","marginX","marginY","Styled.SpinnerWrapper","jsx","LottieAnimation","LOTTIE"],"mappings":";;;;AAMa,MAAAA,IAAU,CAAC,EAAE,QAAAC,IAAS,IAAI,OAAAC,IAAQ,IAAI,SAAAC,IAAU,GAAG,SAAAC,IAAU,EAAE,wBACzEC,GAAA,EAAsB,SAAAF,GAAkB,SAAAC,GACvC,UAAA,gBAAAE,EAACC,GAAgB,EAAA,KAAKC,EAAO,eAAe,QAAAP,GAAgB,OAAAC,EAAc,CAAA,EAC5E,CAAA;"}