@cuemath/leap 3.2.18-mb → 3.2.19-aa0

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 (228) hide show
  1. package/dist/assets/illustrations/illustrations.js +5 -0
  2. package/dist/assets/illustrations/illustrations.js.map +1 -1
  3. package/dist/assets/line-icons/icons/after-noon.js +34 -0
  4. package/dist/assets/line-icons/icons/after-noon.js.map +1 -0
  5. package/dist/assets/line-icons/icons/apple-icon-white.js +42 -0
  6. package/dist/assets/line-icons/icons/apple-icon-white.js.map +1 -0
  7. package/dist/assets/line-icons/icons/cue-board-filled.js +33 -0
  8. package/dist/assets/line-icons/icons/cue-board-filled.js.map +1 -0
  9. package/dist/assets/line-icons/icons/cue-board.js +23 -0
  10. package/dist/assets/line-icons/icons/cue-board.js.map +1 -0
  11. package/dist/assets/line-icons/icons/evening.js +35 -0
  12. package/dist/assets/line-icons/icons/evening.js.map +1 -0
  13. package/dist/assets/line-icons/icons/hint-fill.js +35 -0
  14. package/dist/assets/line-icons/icons/hint-fill.js.map +1 -0
  15. package/dist/assets/line-icons/icons/morning.js +35 -0
  16. package/dist/assets/line-icons/icons/morning.js.map +1 -0
  17. package/dist/assets/line-icons/icons/screen-grab-filled.js +35 -0
  18. package/dist/assets/line-icons/icons/screen-grab-filled.js.map +1 -0
  19. package/dist/assets/line-icons/icons/screen-grab.js +23 -0
  20. package/dist/assets/line-icons/icons/screen-grab.js.map +1 -0
  21. package/dist/assets/line-icons/icons/sticker-filled.js +64 -0
  22. package/dist/assets/line-icons/icons/sticker-filled.js.map +1 -0
  23. package/dist/assets/line-icons/icons/sticker.js +46 -0
  24. package/dist/assets/line-icons/icons/sticker.js.map +1 -0
  25. package/dist/assets/lottie/lottie.js +11 -1
  26. package/dist/assets/lottie/lottie.js.map +1 -1
  27. package/dist/features/auth/account-selector/account-selector.js +26 -25
  28. package/dist/features/auth/account-selector/account-selector.js.map +1 -1
  29. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message-constants.js +9 -0
  30. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message-constants.js.map +1 -0
  31. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message-styled.js +52 -0
  32. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message-styled.js.map +1 -0
  33. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message.js +93 -0
  34. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message.js.map +1 -0
  35. package/dist/features/auth/comps/animated-avatar-message/animated-text/animated-text-styled.js +10 -0
  36. package/dist/features/auth/comps/animated-avatar-message/animated-text/animated-text-styled.js.map +1 -0
  37. package/dist/features/auth/comps/animated-avatar-message/animated-text/animated-text.js +17 -0
  38. package/dist/features/auth/comps/animated-avatar-message/animated-text/animated-text.js.map +1 -0
  39. package/dist/features/auth/comps/auth-page-layout/auth-page-layout.js +20 -14
  40. package/dist/features/auth/comps/auth-page-layout/auth-page-layout.js.map +1 -1
  41. package/dist/features/auth/comps/linear-progress-bar/linear-progress-bar-styled.js +12 -0
  42. package/dist/features/auth/comps/linear-progress-bar/linear-progress-bar-styled.js.map +1 -0
  43. package/dist/features/auth/comps/linear-progress-bar/linear-progress-bar.js +34 -0
  44. package/dist/features/auth/comps/linear-progress-bar/linear-progress-bar.js.map +1 -0
  45. package/dist/features/auth/comps/otp-input/otp-input-styled.js +26 -0
  46. package/dist/features/auth/comps/otp-input/otp-input-styled.js.map +1 -0
  47. package/dist/features/auth/comps/otp-input/otp-input.js +50 -0
  48. package/dist/features/auth/comps/otp-input/otp-input.js.map +1 -0
  49. package/dist/features/auth/comps/pill-button/pill-button-styled.js +44 -0
  50. package/dist/features/auth/comps/pill-button/pill-button-styled.js.map +1 -0
  51. package/dist/features/auth/comps/pill-button/pill-button.js +74 -0
  52. package/dist/features/auth/comps/pill-button/pill-button.js.map +1 -0
  53. package/dist/features/auth/comps/resend-otp/resend-otp.js +54 -47
  54. package/dist/features/auth/comps/resend-otp/resend-otp.js.map +1 -1
  55. package/dist/features/auth/comps/selectable-info-card/selectable-info-card-styled.js +17 -0
  56. package/dist/features/auth/comps/selectable-info-card/selectable-info-card-styled.js.map +1 -0
  57. package/dist/features/auth/comps/selectable-info-card/selectable-info-card.js +67 -0
  58. package/dist/features/auth/comps/selectable-info-card/selectable-info-card.js.map +1 -0
  59. package/dist/features/auth/comps/tabs/tab-tem/tab-item.js +29 -17
  60. package/dist/features/auth/comps/tabs/tab-tem/tab-item.js.map +1 -1
  61. package/dist/features/auth/comps/tabs/tabs-styled.js +22 -10
  62. package/dist/features/auth/comps/tabs/tabs-styled.js.map +1 -1
  63. package/dist/features/auth/comps/tabs/tabs.js +5 -5
  64. package/dist/features/auth/comps/tabs/tabs.js.map +1 -1
  65. package/dist/features/auth/comps/user-list/user-item/user-item.js +30 -31
  66. package/dist/features/auth/comps/user-list/user-item/user-item.js.map +1 -1
  67. package/dist/features/auth/comps/user-list/user-list.js +35 -34
  68. package/dist/features/auth/comps/user-list/user-list.js.map +1 -1
  69. package/dist/features/auth/forgot-password/forgot-password-styled.js +14 -15
  70. package/dist/features/auth/forgot-password/forgot-password-styled.js.map +1 -1
  71. package/dist/features/auth/login/identifier-otp-form/identifier-otp-form-styled.js +6 -7
  72. package/dist/features/auth/login/identifier-otp-form/identifier-otp-form-styled.js.map +1 -1
  73. package/dist/features/auth/login/login-styled.js +8 -9
  74. package/dist/features/auth/login/login-styled.js.map +1 -1
  75. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide-constants.js +19 -0
  76. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide-constants.js.map +1 -0
  77. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide-styled.js +32 -0
  78. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide-styled.js.map +1 -0
  79. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide.js +44 -0
  80. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide.js.map +1 -0
  81. package/dist/features/auth/pla-signup/signup-header/signup-header.js +54 -0
  82. package/dist/features/auth/pla-signup/signup-header/signup-header.js.map +1 -0
  83. package/dist/features/auth/pla-signup/signup-options/signup-options.js +83 -0
  84. package/dist/features/auth/pla-signup/signup-options/signup-options.js.map +1 -0
  85. package/dist/features/chapters-v2/utils/node-card-utils.js +7 -7
  86. package/dist/features/chapters-v2/utils/node-card-utils.js.map +1 -1
  87. package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card-styled.js +4 -4
  88. package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card-styled.js.map +1 -1
  89. package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card.js +85 -85
  90. package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card.js.map +1 -1
  91. package/dist/features/circle-games/game-launcher/hooks/use-game-launcher-journey/use-game-launcher-journey.js +121 -98
  92. package/dist/features/circle-games/game-launcher/hooks/use-game-launcher-journey/use-game-launcher-journey.js.map +1 -1
  93. package/dist/features/circle-games/game-launcher/hooks/use-table-infinite-launcher-journey/use-table-infinite-launcher-journey.js +29 -28
  94. package/dist/features/circle-games/game-launcher/hooks/use-table-infinite-launcher-journey/use-table-infinite-launcher-journey.js.map +1 -1
  95. package/dist/features/circle-games/game-launcher/hooks/use-table-launcher-journey/use-table-launcher-journey.js +43 -42
  96. package/dist/features/circle-games/game-launcher/hooks/use-table-launcher-journey/use-table-launcher-journey.js.map +1 -1
  97. package/dist/features/circle-games/games/tutorial/tutorial.js +43 -35
  98. package/dist/features/circle-games/games/tutorial/tutorial.js.map +1 -1
  99. package/dist/features/circle-games/sign-up/comp/grade-input/grade-input-styled.js +2 -2
  100. package/dist/features/circle-games/sign-up/comp/grade-input/grade-input-styled.js.map +1 -1
  101. package/dist/features/circle-games/sign-up/comp/grade-input/grade-input.js +1 -1
  102. package/dist/features/circle-games/sign-up/comp/grade-input/grade-input.js.map +1 -1
  103. package/dist/features/circle-games/sign-up/comp/username-input/username-input.js +26 -24
  104. package/dist/features/circle-games/sign-up/comp/username-input/username-input.js.map +1 -1
  105. package/dist/features/circle-games/sign-up/constants.js +3 -1
  106. package/dist/features/circle-games/sign-up/constants.js.map +1 -1
  107. package/dist/features/cue-canvas/hooks/use-canvas-sync-broker.js +42 -42
  108. package/dist/features/cue-canvas/hooks/use-canvas-sync-broker.js.map +1 -1
  109. package/dist/features/journey/comps/coachmark/coachmark.js +29 -27
  110. package/dist/features/journey/comps/coachmark/coachmark.js.map +1 -1
  111. package/dist/features/journey/journey-id/journey-id-student.js +2 -2
  112. package/dist/features/journey/journey-id/journey-id-student.js.map +1 -1
  113. package/dist/features/journey/use-journey/journey-context-provider.js +73 -72
  114. package/dist/features/journey/use-journey/journey-context-provider.js.map +1 -1
  115. package/dist/features/journey/use-journey/journey-styled.js +6 -4
  116. package/dist/features/journey/use-journey/journey-styled.js.map +1 -1
  117. package/dist/features/puzzles/app/puzzle-app-styled.js +81 -0
  118. package/dist/features/puzzles/app/puzzle-app-styled.js.map +1 -0
  119. package/dist/features/puzzles/app/puzzle-app-view.js +120 -0
  120. package/dist/features/puzzles/app/puzzle-app-view.js.map +1 -0
  121. package/dist/features/puzzles/app/puzzle-app.js +62 -0
  122. package/dist/features/puzzles/app/puzzle-app.js.map +1 -0
  123. package/dist/features/ui/arrow-tooltip/arrow-tooltip-constants.js +6 -0
  124. package/dist/features/ui/arrow-tooltip/arrow-tooltip-constants.js.map +1 -0
  125. package/dist/features/ui/arrow-tooltip/arrow-tooltip-styled.js +12 -60
  126. package/dist/features/ui/arrow-tooltip/arrow-tooltip-styled.js.map +1 -1
  127. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js +72 -77
  128. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js.map +1 -1
  129. package/dist/features/ui/arrow-tooltip/comps/tooltip-body-styled.js +63 -0
  130. package/dist/features/ui/arrow-tooltip/comps/tooltip-body-styled.js.map +1 -0
  131. package/dist/features/ui/arrow-tooltip/comps/tooltip-body.js +21 -0
  132. package/dist/features/ui/arrow-tooltip/comps/tooltip-body.js.map +1 -0
  133. package/dist/features/ui/buttons/button/button.js +41 -38
  134. package/dist/features/ui/buttons/button/button.js.map +1 -1
  135. package/dist/features/ui/buttons/icon-button/icon-button.js +31 -27
  136. package/dist/features/ui/buttons/icon-button/icon-button.js.map +1 -1
  137. package/dist/features/ui/buttons/text-button/text-button.js +26 -22
  138. package/dist/features/ui/buttons/text-button/text-button.js.map +1 -1
  139. package/dist/features/ui/drawer/drawer-styled.js +34 -0
  140. package/dist/features/ui/drawer/drawer-styled.js.map +1 -0
  141. package/dist/features/ui/drawer/drawer.js +42 -0
  142. package/dist/features/ui/drawer/drawer.js.map +1 -0
  143. package/dist/features/ui/error/error.js +65 -27
  144. package/dist/features/ui/error/error.js.map +1 -1
  145. package/dist/features/ui/grade-selector/grade-selector.js +33 -27
  146. package/dist/features/ui/grade-selector/grade-selector.js.map +1 -1
  147. package/dist/features/ui/image/image.js +1 -1
  148. package/dist/features/ui/image/image.js.map +1 -1
  149. package/dist/features/ui/lottie-animation/lottie-animation.js +25 -29
  150. package/dist/features/ui/lottie-animation/lottie-animation.js.map +1 -1
  151. package/dist/features/ui/modals/modal-styled.js +34 -58
  152. package/dist/features/ui/modals/modal-styled.js.map +1 -1
  153. package/dist/features/ui/modals/modal.js +40 -14
  154. package/dist/features/ui/modals/modal.js.map +1 -1
  155. package/dist/features/ui/nudge/nudge-styled.js +14 -7
  156. package/dist/features/ui/nudge/nudge-styled.js.map +1 -1
  157. package/dist/features/ui/nudge/nudge.js +13 -12
  158. package/dist/features/ui/nudge/nudge.js.map +1 -1
  159. package/dist/features/{stickers/sticker-selector/sticker-selector-styles.js → ui/sticker-grid/sticker-grid-styles.js} +3 -4
  160. package/dist/features/ui/sticker-grid/sticker-grid-styles.js.map +1 -0
  161. package/dist/features/ui/sticker-grid/sticker-grid.js +24 -0
  162. package/dist/features/ui/sticker-grid/sticker-grid.js.map +1 -0
  163. package/dist/features/ui/sticker-grid/sticker.js +57 -0
  164. package/dist/features/ui/sticker-grid/sticker.js.map +1 -0
  165. package/dist/features/ui/stickers/constants.js +6 -0
  166. package/dist/features/ui/stickers/constants.js.map +1 -0
  167. package/dist/features/{stickers/stickers-effects/effects.js → ui/stickers/stickers-effects.js} +6 -6
  168. package/dist/features/ui/stickers/stickers-effects.js.map +1 -0
  169. package/dist/features/{stickers/stickers-effects/stickers-effects-styled.js → ui/stickers/stickers-styled.js} +2 -2
  170. package/dist/features/ui/stickers/stickers-styled.js.map +1 -0
  171. package/dist/features/ui/stickers/stickers-utils.js +91 -0
  172. package/dist/features/ui/stickers/stickers-utils.js.map +1 -0
  173. package/dist/features/ui/stickers/stickers.js +40 -0
  174. package/dist/features/ui/stickers/stickers.js.map +1 -0
  175. package/dist/features/ui/streak-icon/streak-icon-styled.js +13 -13
  176. package/dist/features/ui/streak-icon/streak-icon-styled.js.map +1 -1
  177. package/dist/features/ui/streak-icon/streak-icon.js +17 -15
  178. package/dist/features/ui/streak-icon/streak-icon.js.map +1 -1
  179. package/dist/features/ui/tab/tab.js +30 -26
  180. package/dist/features/ui/tab/tab.js.map +1 -1
  181. package/dist/features/ui/text/text.js +40 -36
  182. package/dist/features/ui/text/text.js.map +1 -1
  183. package/dist/features/ui/theme/button.js +78 -78
  184. package/dist/features/ui/theme/button.js.map +1 -1
  185. package/dist/features/ui/theme/constants.js +4 -2
  186. package/dist/features/ui/theme/constants.js.map +1 -1
  187. package/dist/features/ui/theme/get-device.js +3 -3
  188. package/dist/features/ui/theme/get-device.js.map +1 -1
  189. package/dist/features/worksheet/worksheet/worksheet-question/learnosity-question.js +24 -24
  190. package/dist/features/worksheet/worksheet/worksheet-question/learnosity-question.js.map +1 -1
  191. package/dist/index.d.ts +194 -57
  192. package/dist/index.js +579 -541
  193. package/dist/index.js.map +1 -1
  194. package/dist/static/animated-avatar.1ad58b1d.json +1 -0
  195. package/dist/static/animated-avatar.69b07505.json +1 -0
  196. package/dist/static/animated-avatar.9c560b46.json +1 -0
  197. package/dist/static/calendar-purple.1a840b41.svg +1 -0
  198. package/dist/static/flying-disk.c7f6ed39.json +1 -0
  199. package/dist/static/graduation-cap.3be3340a.json +1 -0
  200. package/dist/static/handshake.287e7dfb.svg +1 -0
  201. package/dist/static/light-bulb.c6db0b23.json +1 -0
  202. package/dist/static/money.332aacf1.svg +1 -0
  203. package/dist/static/muscle.9bcfb8a7.json +1 -0
  204. package/dist/static/nudge-tap.0591aef4.json +1 -0
  205. package/dist/static/parent-avatar.822c7b9b.svg +1 -0
  206. package/dist/static/pencil.23df9da0.json +1 -0
  207. package/dist/static/plus-sign.de6af957.json +1 -0
  208. package/dist/static/racing-car.2cbf864e.json +1 -0
  209. package/dist/static/rocket.0a3ccab0.json +1 -0
  210. package/dist/static/shovel.abeec04c.json +1 -0
  211. package/dist/static/trustpilot.bd3d79e1.svg +1 -0
  212. package/package.json +1 -1
  213. package/dist/features/hooks/use-viewport/use-viewport.js +0 -22
  214. package/dist/features/hooks/use-viewport/use-viewport.js.map +0 -1
  215. package/dist/features/stickers/sticker-data.js +0 -234
  216. package/dist/features/stickers/sticker-data.js.map +0 -1
  217. package/dist/features/stickers/sticker-selector/sticker-selector-styles.js.map +0 -1
  218. package/dist/features/stickers/sticker-selector/sticker-selector.js +0 -25
  219. package/dist/features/stickers/sticker-selector/sticker-selector.js.map +0 -1
  220. package/dist/features/stickers/sticker-selector/sticker.js +0 -57
  221. package/dist/features/stickers/sticker-selector/sticker.js.map +0 -1
  222. package/dist/features/stickers/stickers-effects/effects.js.map +0 -1
  223. package/dist/features/stickers/stickers-effects/stickers-effects-styled.js.map +0 -1
  224. package/dist/features/stickers/stickers-effects/stickers-effects-utils.js +0 -93
  225. package/dist/features/stickers/stickers-effects/stickers-effects-utils.js.map +0 -1
  226. package/dist/features/stickers/stickers-effects/stickers-effects.js +0 -39
  227. package/dist/features/stickers/stickers-effects/stickers-effects.js.map +0 -1
  228. package/dist/static/nudge-tap.5cb30093.json +0 -1057
@@ -0,0 +1,57 @@
1
+ import { jsxs as p, jsx as s } from "react/jsx-runtime";
2
+ import { memo as S, useState as v, useRef as L, useLayoutEffect as M, useCallback as i, useMemo as $ } from "react";
3
+ import g from "../lottie-animation/lottie-animation.js";
4
+ import { StickerContainer as k, StaticEmoji as E, LottieContainer as j } from "./sticker-grid-styles.js";
5
+ const x = ({
6
+ emoji: a,
7
+ lottieUrl: c,
8
+ size: t = 48,
9
+ onClick: o,
10
+ disabled: e = !1
11
+ }) => {
12
+ const [r, u] = v(!1), n = L(null);
13
+ M(() => {
14
+ n.current && n.current.playSegments([0, 1], !0);
15
+ }, []);
16
+ const f = i(() => {
17
+ e || u(!0);
18
+ }, [e]), m = i(() => {
19
+ e || u(!1);
20
+ }, [e]), l = i(() => {
21
+ !e && o && o();
22
+ }, [e, o]), h = $(
23
+ () => ({
24
+ loop: !0,
25
+ renderer: "canvas",
26
+ autoplay: r
27
+ }),
28
+ [r]
29
+ );
30
+ return /* @__PURE__ */ p(
31
+ k,
32
+ {
33
+ $size: t,
34
+ $disabled: e,
35
+ onMouseEnter: f,
36
+ onMouseLeave: m,
37
+ onClick: l,
38
+ children: [
39
+ !r && /* @__PURE__ */ s(E, { $size: t, children: a }),
40
+ c && /* @__PURE__ */ s(j, { $size: t, children: /* @__PURE__ */ s(
41
+ g,
42
+ {
43
+ ref: n,
44
+ src: c,
45
+ width: "100%",
46
+ height: "100%",
47
+ settings: h
48
+ }
49
+ ) })
50
+ ]
51
+ }
52
+ );
53
+ }, d = S(x);
54
+ export {
55
+ d as default
56
+ };
57
+ //# sourceMappingURL=sticker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sticker.js","sources":["../../../../src/features/ui/sticker-grid/sticker.tsx"],"sourcesContent":["import type { ILottieAnimationRef } from '../lottie-animation/types';\nimport type { IStickerProps } from './sticker-grid-types';\n\nimport React, { useCallback, useMemo, useRef, useState, memo, useLayoutEffect } from 'react';\n\nimport LottieAnimation from '../lottie-animation/lottie-animation';\nimport { StickerContainer, StaticEmoji, LottieContainer } from './sticker-grid-styles';\n\nconst Sticker: React.FC<IStickerProps> = ({\n emoji,\n lottieUrl,\n size = 48,\n onClick,\n disabled = false,\n}) => {\n const [isHovered, setIsHovered] = useState(false);\n const lottieRef = useRef<ILottieAnimationRef>(null);\n\n useLayoutEffect(() => {\n if (lottieRef.current) {\n lottieRef.current.playSegments([0, 1], true);\n }\n }, []);\n\n const handleMouseEnter = useCallback(() => {\n if (!disabled) setIsHovered(true);\n }, [disabled]);\n\n const handleMouseLeave = useCallback(() => {\n if (!disabled) setIsHovered(false);\n }, [disabled]);\n\n const handleClick = useCallback(() => {\n if (!disabled && onClick) onClick();\n }, [disabled, onClick]);\n\n const lottieSettings = useMemo(\n () => ({\n loop: true,\n renderer: 'canvas',\n autoplay: isHovered,\n }),\n [isHovered],\n );\n\n return (\n <StickerContainer\n $size={size}\n $disabled={disabled}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n onClick={handleClick}\n >\n {!isHovered && <StaticEmoji $size={size}>{emoji}</StaticEmoji>}\n\n {lottieUrl && (\n <LottieContainer $size={size}>\n <LottieAnimation\n ref={lottieRef}\n src={lottieUrl}\n width=\"100%\"\n height=\"100%\"\n settings={lottieSettings}\n />\n </LottieContainer>\n )}\n </StickerContainer>\n );\n};\n\nexport default memo(Sticker);\n"],"names":["Sticker","emoji","lottieUrl","size","onClick","disabled","isHovered","setIsHovered","useState","lottieRef","useRef","useLayoutEffect","handleMouseEnter","useCallback","handleMouseLeave","handleClick","lottieSettings","useMemo","jsxs","StickerContainer","jsx","StaticEmoji","LottieContainer","LottieAnimation","Sticker$1","memo"],"mappings":";;;;AAQA,MAAMA,IAAmC,CAAC;AAAA,EACxC,OAAAC;AAAA,EACA,WAAAC;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,SAAAC;AAAA,EACA,UAAAC,IAAW;AACb,MAAM;AACJ,QAAM,CAACC,GAAWC,CAAY,IAAIC,EAAS,EAAK,GAC1CC,IAAYC,EAA4B,IAAI;AAElD,EAAAC,EAAgB,MAAM;AACpB,IAAIF,EAAU,WACZA,EAAU,QAAQ,aAAa,CAAC,GAAG,CAAC,GAAG,EAAI;AAAA,EAE/C,GAAG,CAAE,CAAA;AAEC,QAAAG,IAAmBC,EAAY,MAAM;AACrC,IAACR,KAAUE,EAAa,EAAI;AAAA,EAAA,GAC/B,CAACF,CAAQ,CAAC,GAEPS,IAAmBD,EAAY,MAAM;AACrC,IAACR,KAAUE,EAAa,EAAK;AAAA,EAAA,GAChC,CAACF,CAAQ,CAAC,GAEPU,IAAcF,EAAY,MAAM;AAChC,IAAA,CAACR,KAAYD,KAAiBA;EAAA,GACjC,CAACC,GAAUD,CAAO,CAAC,GAEhBY,IAAiBC;AAAA,IACrB,OAAO;AAAA,MACL,MAAM;AAAA,MACN,UAAU;AAAA,MACV,UAAUX;AAAA,IAAA;AAAA,IAEZ,CAACA,CAAS;AAAA,EAAA;AAIV,SAAA,gBAAAY;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,OAAOhB;AAAA,MACP,WAAWE;AAAA,MACX,cAAcO;AAAA,MACd,cAAcE;AAAA,MACd,SAASC;AAAA,MAER,UAAA;AAAA,QAAA,CAACT,KAAa,gBAAAc,EAACC,GAAY,EAAA,OAAOlB,GAAO,UAAMF,GAAA;AAAA,QAE/CC,KACC,gBAAAkB,EAACE,GAAgB,EAAA,OAAOnB,GACtB,UAAA,gBAAAiB;AAAA,UAACG;AAAA,UAAA;AAAA,YACC,KAAKd;AAAA,YACL,KAAKP;AAAA,YACL,OAAM;AAAA,YACN,QAAO;AAAA,YACP,UAAUc;AAAA,UAAA;AAAA,QAAA,GAEd;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAIR,GAEeQ,IAAAC,EAAKzB,CAAO;"}
@@ -0,0 +1,6 @@
1
+ const I = 32, E = 48;
2
+ export {
3
+ E as STICKER_MAX_SIZE,
4
+ I as STICKER_MIN_SIZE
5
+ };
6
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sources":["../../../../src/features/ui/stickers/constants.ts"],"sourcesContent":["export const STICKER_MIN_SIZE = 32;\nexport const STICKER_MAX_SIZE = 48;\n"],"names":["STICKER_MIN_SIZE","STICKER_MAX_SIZE"],"mappings":"AAAO,MAAMA,IAAmB,IACnBC,IAAmB;"}
@@ -1,5 +1,5 @@
1
1
  import { keyframes as r, css as t } from "styled-components";
2
- import { randomizeDuration as o } from "./stickers-effects-utils.js";
2
+ import { randomizeDuration as o } from "./stickers-utils.js";
3
3
  const s = r`
4
4
  0% {
5
5
  transform: translateY(0vh);
@@ -45,20 +45,20 @@ const s = r`
45
45
  opacity: 0;
46
46
  }
47
47
  `, i = {
48
- "float-up": (a) => t`
48
+ float_up: (a) => t`
49
49
  animation: ${s} ${o(a)}ms ease-out forwards;
50
50
  `,
51
- "fall-down": (a) => t`
51
+ fall_down: (a) => t`
52
52
  animation: ${n} ${o(a)}ms ease-out forwards;
53
53
  `,
54
- "burst-from-edges": (a) => t`
54
+ burst_from_edges: (a) => t`
55
55
  animation: ${e} ${o(a)}ms linear forwards;
56
56
  `,
57
- "pop-expand": (a) => t`
57
+ pop_expand: (a) => t`
58
58
  animation: ${m} ${a}ms cubic-bezier(0.5, 0.1, 0.7, 1) forwards;
59
59
  `
60
60
  };
61
61
  export {
62
62
  i as effectAnimations
63
63
  };
64
- //# sourceMappingURL=effects.js.map
64
+ //# sourceMappingURL=stickers-effects.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stickers-effects.js","sources":["../../../../src/features/ui/stickers/stickers-effects.ts"],"sourcesContent":["import type { StickersProps } from './stickers-types';\n\nimport { keyframes, css } from 'styled-components';\n\nimport { randomizeDuration } from './stickers-utils';\n\nconst floatUp = keyframes`\n 0% {\n transform: translateY(0vh);\n opacity: 1;\n }\n 100% {\n transform: translateY(-100vh);\n opacity: 0;\n }\n`;\n\nconst fallDown = keyframes`\n 0% {\n transform: translateY(0vh);\n opacity: 1;\n }\n 100% {\n transform: translateY(100vh);\n opacity: 0;\n }\n`;\n\nconst burstFromEdges = keyframes`\n 0% {\n transform: translateX(var(--from-x)) translateY(var(--from-y)) scale(1);\n opacity: 1;\n }\n 100% {\n transform: translateX(0vw) translateY(0vh) scale(1.25);\n opacity: 0;\n }\n`;\n\nconst popExpand = keyframes`\n 0% {\n transform: translateX(0) translateY(0vh);\n opacity: 1;\n }\n 35% {\n transform: translateX(0) translateY(-50vh) scale(1.25);\n opacity: 1;\n }\n 60% {\n transform: translateX(var(--from-x)) translateY(var(--from-y)) scale(1.25);\n opacity: 0.75;\n }\n 100% {\n transform: translateX(var(--from-x)) translateY(-110vh) scale(1.25);\n opacity: 0;\n }\n`;\n\nexport const effectAnimations: Record<\n StickersProps['effect'],\n (duration: number) => ReturnType<typeof css>\n> = {\n float_up: (duration: number) => css`\n animation: ${floatUp} ${randomizeDuration(duration)}ms ease-out forwards;\n `,\n fall_down: (duration: number) => css`\n animation: ${fallDown} ${randomizeDuration(duration)}ms ease-out forwards;\n `,\n burst_from_edges: (duration: number) => css`\n animation: ${burstFromEdges} ${randomizeDuration(duration)}ms linear forwards;\n `,\n pop_expand: (duration: number) => css`\n animation: ${popExpand} ${duration}ms cubic-bezier(0.5, 0.1, 0.7, 1) forwards;\n `,\n};\n"],"names":["floatUp","keyframes","fallDown","burstFromEdges","popExpand","effectAnimations","duration","css","randomizeDuration"],"mappings":";;AAMA,MAAMA,IAAUC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAWVC,IAAWD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAWXE,IAAiBF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAWjBG,IAAYH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAmBLI,IAGT;AAAA,EACF,UAAU,CAACC,MAAqBC;AAAA,iBACjBP,CAAO,IAAIQ,EAAkBF,CAAQ,CAAC;AAAA;AAAA,EAErD,WAAW,CAACA,MAAqBC;AAAA,iBAClBL,CAAQ,IAAIM,EAAkBF,CAAQ,CAAC;AAAA;AAAA,EAEtD,kBAAkB,CAACA,MAAqBC;AAAA,iBACzBJ,CAAc,IAAIK,EAAkBF,CAAQ,CAAC;AAAA;AAAA,EAE5D,YAAY,CAACA,MAAqBC;AAAA,iBACnBH,CAAS,IAAIE,CAAQ;AAAA;AAEtC;"}
@@ -1,5 +1,5 @@
1
1
  import $, { css as s } from "styled-components";
2
- import { effectAnimations as n } from "./effects.js";
2
+ import { effectAnimations as n } from "./stickers-effects.js";
3
3
  const h = $.div`
4
4
  position: relative;
5
5
  width: 100vw;
@@ -26,4 +26,4 @@ export {
26
26
  h as Container,
27
27
  a as Sticker
28
28
  };
29
- //# sourceMappingURL=stickers-effects-styled.js.map
29
+ //# sourceMappingURL=stickers-styled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stickers-styled.js","sources":["../../../../src/features/ui/stickers/stickers-styled.ts"],"sourcesContent":["import type { StickersProps } from './stickers-types';\n\nimport styled, { css } from 'styled-components';\n\nimport { effectAnimations } from './stickers-effects';\n\nexport const Container = styled.div`\n position: relative;\n width: 100vw;\n height: 100vh;\n background: transparent;\n pointer-events: none;\n`;\n\nexport const Sticker = styled.div<{\n effect: StickersProps['effect'];\n duration: number;\n fromX?: string;\n fromY?: string;\n x: number;\n y: number;\n size: number;\n}>`\n position: absolute;\n z-index: 10;\n\n left: ${({ x }) => `${x}%`};\n top: ${({ y }) => `${y}%`};\n width: ${({ size }) => `${size}px`};\n height: ${({ size }) => `${size}px`};\n font-size: ${({ size }) => `${size}px`};\n\n ${({ effect, duration, fromX, fromY }) =>\n fromX && fromY\n ? css`\n ${effectAnimations[effect](duration)}\n --from-x: ${fromX};\n --from-y: ${fromY};\n `\n : effectAnimations[effect](duration)}\n`;\n"],"names":["Container","styled","Sticker","x","y","size","effect","duration","fromX","fromY","css","effectAnimations"],"mappings":";;AAMO,MAAMA,IAAYC,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQnBC,IAAUD,EAAO;AAAA;AAAA;AAAA;AAAA,UAYpB,CAAC,EAAE,GAAAE,EAAQ,MAAA,GAAGA,CAAC,GAAG;AAAA,SACnB,CAAC,EAAE,GAAAC,EAAQ,MAAA,GAAGA,CAAC,GAAG;AAAA,WAChB,CAAC,EAAE,MAAAC,EAAW,MAAA,GAAGA,CAAI,IAAI;AAAA,YACxB,CAAC,EAAE,MAAAA,EAAW,MAAA,GAAGA,CAAI,IAAI;AAAA,eACtB,CAAC,EAAE,MAAAA,EAAW,MAAA,GAAGA,CAAI,IAAI;AAAA;AAAA,IAEpC,CAAC,EAAE,QAAAC,GAAQ,UAAAC,GAAU,OAAAC,GAAO,OAAAC,QAC5BD,KAASC,IACLC;AAAA,YACIC,EAAiBL,CAAM,EAAEC,CAAQ,CAAC;AAAA,sBACxBC,CAAK;AAAA,sBACLC,CAAK;AAAA,YAEnBE,EAAiBL,CAAM,EAAEC,CAAQ,CAAC;AAAA;"}
@@ -0,0 +1,91 @@
1
+ const f = (n, s) => {
2
+ const t = Math.ceil(s / 4), r = Math.floor(n / t), d = n % t, M = ["top", "right", "bottom", "left"][r] ?? "left", h = (d + 0.5) / t * 100, i = (Math.random() - 0.5) * 25, o = Math.min(Math.max(h + i, 0), 100), a = 45 + Math.random() * 10, e = 45 + Math.random() * 10;
3
+ let l = 0, m = 0;
4
+ switch (M) {
5
+ case "top":
6
+ l = o - a, m = -e + i;
7
+ break;
8
+ case "right":
9
+ l = 100 - a + i, m = o - e;
10
+ break;
11
+ case "bottom":
12
+ l = o - a, m = 100 - e + i;
13
+ break;
14
+ case "left":
15
+ l = -a + i, m = o - e;
16
+ break;
17
+ }
18
+ return {
19
+ fromX: `${l}vw`,
20
+ fromY: `${m}vh`,
21
+ x: a,
22
+ y: e
23
+ };
24
+ }, g = (n, s = 10) => {
25
+ const t = [];
26
+ let r = 0;
27
+ const d = n;
28
+ for (; t.length < n && r < d; ) {
29
+ const c = Math.floor(Math.random() * (100 - 2 * s) + s);
30
+ t.every((M) => Math.abs(M - c) >= s) && t.push(c), r++;
31
+ }
32
+ for (; t.length < n; )
33
+ t.push(Math.floor(Math.random() * (100 - 2 * s) + s));
34
+ return t;
35
+ };
36
+ function x({
37
+ count: n,
38
+ effect: s,
39
+ stickers: t,
40
+ minSize: r,
41
+ maxSize: d
42
+ }) {
43
+ const c = 100 / n * 2, M = () => Math.random() * (d - r) + r, h = [], i = ["float_up", "fall_down"].includes(s) ? g(n, c) : [];
44
+ for (let o = 0; o < n; o++) {
45
+ const a = t[o % t.length] ?? "", e = M();
46
+ if (s === "float_up")
47
+ h.push({
48
+ id: o,
49
+ sticker: a,
50
+ x: i[o],
51
+ y: 110 + (Math.random() - 0.5) * e,
52
+ size: e
53
+ });
54
+ else if (s === "fall_down")
55
+ h.push({
56
+ id: o,
57
+ sticker: a,
58
+ x: i[o],
59
+ y: -10 + (Math.random() - 0.5) * e,
60
+ size: e
61
+ });
62
+ else if (s === "burst_from_edges") {
63
+ const { x: l, y: m, fromX: p, fromY: u } = f(o, n);
64
+ h.push({ id: o, sticker: a, x: l, y: m, fromX: p, fromY: u, size: e });
65
+ } else s === "pop_expand" ? h.push({
66
+ id: o,
67
+ sticker: a,
68
+ x: 50,
69
+ y: 100,
70
+ fromX: `${(Math.random() - 0.5) * 27.5}vw`,
71
+ fromY: `${-50 - Math.random() * 27.5}vh`,
72
+ size: e
73
+ }) : h.push({
74
+ id: o,
75
+ sticker: a,
76
+ x: Math.random() * 100,
77
+ y: Math.random() * 100,
78
+ size: e
79
+ });
80
+ }
81
+ return h;
82
+ }
83
+ const v = (n, s = 0.2) => {
84
+ const t = n * s, r = n - t, d = n + t;
85
+ return Math.floor(Math.random() * (d - r + 1)) + r;
86
+ };
87
+ export {
88
+ x as generateStickerData,
89
+ v as randomizeDuration
90
+ };
91
+ //# sourceMappingURL=stickers-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stickers-utils.js","sources":["../../../../src/features/ui/stickers/stickers-utils.ts"],"sourcesContent":["import type { StickerDatum, StickersProps } from './stickers-types';\n\nconst getBurstPosition = (\n index: number,\n total: number,\n): {\n fromX: string;\n fromY: string;\n x: number;\n y: number;\n} => {\n const countPerSide = Math.ceil(total / 4);\n const sideIndex = Math.floor(index / countPerSide);\n const pos = index % countPerSide;\n\n const sides = ['top', 'right', 'bottom', 'left'] as const;\n const side = sides[sideIndex] ?? 'left';\n\n const basePercent = ((pos + 0.5) / countPerSide) * 100;\n const jitter = (Math.random() - 0.5) * 25;\n const edgePercent = Math.min(Math.max(basePercent + jitter, 0), 100);\n\n const centerX = 45 + Math.random() * 10;\n const centerY = 45 + Math.random() * 10;\n\n let fromX = 0;\n let fromY = 0;\n\n switch (side) {\n case 'top':\n fromX = edgePercent - centerX;\n fromY = -centerY + jitter;\n break;\n case 'right':\n fromX = 100 - centerX + jitter;\n fromY = edgePercent - centerY;\n break;\n case 'bottom':\n fromX = edgePercent - centerX;\n fromY = 100 - centerY + jitter;\n break;\n case 'left':\n fromX = -centerX + jitter;\n fromY = edgePercent - centerY;\n break;\n }\n\n return {\n fromX: `${fromX}vw`,\n fromY: `${fromY}vh`,\n x: centerX,\n y: centerY,\n };\n};\n\nconst getRandomNonOverlappingPositions = (count: number, buffer = 10): number[] => {\n const used: number[] = [];\n let attempts = 0;\n const maxAttempts = count;\n\n while (used.length < count && attempts < maxAttempts) {\n const value = Math.floor(Math.random() * (100 - 2 * buffer) + buffer);\n\n if (used.every(v => Math.abs(v - value) >= buffer)) {\n used.push(value);\n }\n attempts++;\n }\n\n while (used.length < count) {\n used.push(Math.floor(Math.random() * (100 - 2 * buffer) + buffer));\n }\n\n return used;\n};\n\nexport function generateStickerData({\n count,\n effect,\n stickers,\n minSize,\n maxSize,\n}: {\n count: number;\n effect: StickersProps['effect'];\n stickers: string[];\n minSize: number;\n maxSize: number;\n}): StickerDatum[] {\n const buffer = (100 / count) * 2;\n const getSize = () => Math.random() * (maxSize - minSize) + minSize;\n const result: StickerDatum[] = [];\n const xPositions = ['float_up', 'fall_down'].includes(effect)\n ? getRandomNonOverlappingPositions(count, buffer)\n : [];\n\n for (let i = 0; i < count; i++) {\n const sticker = stickers[i % stickers.length] ?? '';\n const size = getSize();\n\n if (effect === 'float_up') {\n result.push({\n id: i,\n sticker,\n x: xPositions[i]!,\n y: 110 + (Math.random() - 0.5) * size,\n size,\n });\n } else if (effect === 'fall_down') {\n result.push({\n id: i,\n sticker,\n x: xPositions[i]!,\n y: -10 + (Math.random() - 0.5) * size,\n size,\n });\n } else if (effect === 'burst_from_edges') {\n const { x, y, fromX, fromY } = getBurstPosition(i, count);\n\n result.push({ id: i, sticker, x, y, fromX, fromY, size });\n } else if (effect === 'pop_expand') {\n result.push({\n id: i,\n sticker,\n x: 50,\n y: 100,\n fromX: `${(Math.random() - 0.5) * 27.5}vw`,\n fromY: `${-50 - Math.random() * 27.5}vh`,\n size,\n });\n } else {\n result.push({\n id: i,\n sticker,\n x: Math.random() * 100,\n y: Math.random() * 100,\n size,\n });\n }\n }\n\n return result;\n}\n\nexport const randomizeDuration = (base: number, variancePercent = 0.2): number => {\n const delta = base * variancePercent;\n const min = base - delta;\n const max = base + delta;\n\n return Math.floor(Math.random() * (max - min + 1)) + min;\n};\n"],"names":["getBurstPosition","index","total","countPerSide","sideIndex","pos","side","basePercent","jitter","edgePercent","centerX","centerY","fromX","fromY","getRandomNonOverlappingPositions","count","buffer","used","attempts","maxAttempts","value","v","generateStickerData","effect","stickers","minSize","maxSize","getSize","result","xPositions","i","sticker","size","x","y","randomizeDuration","base","variancePercent","delta","min","max"],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ import { jsx as a } from "react/jsx-runtime";
2
+ import { memo as E, useState as I, useLayoutEffect as l } from "react";
3
+ import { STICKER_MIN_SIZE as x, STICKER_MAX_SIZE as D } from "./constants.js";
4
+ import { Container as T, Sticker as _ } from "./stickers-styled.js";
5
+ import { generateStickerData as z } from "./stickers-utils.js";
6
+ const C = ({ stickers: i, effect: t, count: m, duration: r }) => {
7
+ const [c, s] = I([]);
8
+ return l(() => {
9
+ const e = z({
10
+ count: m,
11
+ effect: t,
12
+ stickers: i,
13
+ minSize: x,
14
+ maxSize: D
15
+ });
16
+ s(e);
17
+ const o = setTimeout(() => s([]), r);
18
+ return () => clearTimeout(o);
19
+ }, [i, t, m, r]), /* @__PURE__ */ a(T, { children: c.map((e) => {
20
+ const { id: o, sticker: n, x: S, y: k, size: p, fromX: u, fromY: f } = e;
21
+ return /* @__PURE__ */ a(
22
+ _,
23
+ {
24
+ effect: t,
25
+ duration: r,
26
+ fromX: u,
27
+ fromY: f,
28
+ x: S,
29
+ y: k,
30
+ size: p,
31
+ children: n
32
+ },
33
+ o
34
+ );
35
+ }) });
36
+ }, R = E(C);
37
+ export {
38
+ R as default
39
+ };
40
+ //# sourceMappingURL=stickers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stickers.js","sources":["../../../../src/features/ui/stickers/stickers.tsx"],"sourcesContent":["import type { StickerDatum, StickersProps } from './stickers-types';\n\nimport React, { memo, useLayoutEffect, useState } from 'react';\n\nimport { STICKER_MAX_SIZE, STICKER_MIN_SIZE } from './constants';\nimport { Container, Sticker } from './stickers-styled';\nimport { generateStickerData } from './stickers-utils';\n\nconst Stickers: React.FC<StickersProps> = ({ stickers, effect, count, duration }) => {\n const [stickersData, setStickersData] = useState<ReturnType<typeof generateStickerData>>([]);\n\n useLayoutEffect(() => {\n const stickerData = generateStickerData({\n count,\n effect,\n stickers,\n minSize: STICKER_MIN_SIZE,\n maxSize: STICKER_MAX_SIZE,\n });\n\n setStickersData(stickerData);\n\n const timeout = setTimeout(() => setStickersData([]), duration);\n\n return () => clearTimeout(timeout);\n }, [stickers, effect, count, duration]);\n\n return (\n <Container>\n {stickersData.map((data: StickerDatum) => {\n const { id, sticker, x, y, size, fromX, fromY } = data;\n\n return (\n <Sticker\n key={id}\n effect={effect}\n duration={duration}\n fromX={fromX}\n fromY={fromY}\n x={x}\n y={y}\n size={size}\n >\n {sticker}\n </Sticker>\n );\n })}\n </Container>\n );\n};\n\nexport default memo(Stickers);\n"],"names":["Stickers","stickers","effect","count","duration","stickersData","setStickersData","useState","useLayoutEffect","stickerData","generateStickerData","STICKER_MIN_SIZE","STICKER_MAX_SIZE","timeout","jsx","Container","data","id","sticker","x","y","size","fromX","fromY","Sticker","memo"],"mappings":";;;;;AAQA,MAAMA,IAAoC,CAAC,EAAE,UAAAC,GAAU,QAAAC,GAAQ,OAAAC,GAAO,UAAAC,QAAe;AACnF,QAAM,CAACC,GAAcC,CAAe,IAAIC,EAAiD,CAAE,CAAA;AAE3F,SAAAC,EAAgB,MAAM;AACpB,UAAMC,IAAcC,EAAoB;AAAA,MACtC,OAAAP;AAAA,MACA,QAAAD;AAAA,MACA,UAAAD;AAAA,MACA,SAASU;AAAA,MACT,SAASC;AAAA,IAAA,CACV;AAED,IAAAN,EAAgBG,CAAW;AAE3B,UAAMI,IAAU,WAAW,MAAMP,EAAgB,CAAE,CAAA,GAAGF,CAAQ;AAEvD,WAAA,MAAM,aAAaS,CAAO;AAAA,KAChC,CAACZ,GAAUC,GAAQC,GAAOC,CAAQ,CAAC,GAGnC,gBAAAU,EAAAC,GAAA,EACE,UAAaV,EAAA,IAAI,CAACW,MAAuB;AAClC,UAAA,EAAE,IAAAC,GAAI,SAAAC,GAAS,GAAAC,GAAG,GAAAC,GAAG,MAAAC,GAAM,OAAAC,GAAO,OAAAC,EAAU,IAAAP;AAGhD,WAAA,gBAAAF;AAAA,MAACU;AAAA,MAAA;AAAA,QAEC,QAAAtB;AAAA,QACA,UAAAE;AAAA,QACA,OAAAkB;AAAA,QACA,OAAAC;AAAA,QACA,GAAAJ;AAAA,QACA,GAAAC;AAAA,QACA,MAAAC;AAAA,QAEC,UAAAH;AAAA,MAAA;AAAA,MATID;AAAA,IAAA;AAAA,EAYV,CAAA,EACH,CAAA;AAEJ,GAEehB,IAAAwB,EAAKzB,CAAQ;"}
@@ -1,4 +1,4 @@
1
- import t, { keyframes as o } from "styled-components";
1
+ import i, { keyframes as o } from "styled-components";
2
2
  const n = o`
3
3
  66%{
4
4
  opacity: 0;
@@ -6,29 +6,29 @@ const n = o`
6
6
  33%{
7
7
  opacity: 1;
8
8
  }
9
- `, a = t.div`
9
+ `, a = i.div`
10
10
  height: 32px;
11
11
  width: 32px;
12
12
  display: flex;
13
13
  align-items: center;
14
14
  justify-content: center;
15
15
  position: relative;
16
- cursor: pointer;
17
- `, s = t.div`
16
+ cursor: ${({ isInteractive: t }) => t ? "pointer" : "default"};
17
+ `, s = i.div`
18
18
  height: 90%;
19
19
  width: 90%;
20
20
  position: absolute;
21
- background: ${({ theme: i }) => i.colors.BLACK_1};
21
+ background: ${({ theme: t }) => t.colors.BLACK_1};
22
22
  border-radius: 24px;
23
- `, d = t.div`
23
+ `, d = i.div`
24
24
  height: 90%;
25
25
  width: 90%;
26
26
  position: absolute;
27
- background: ${({ theme: i }) => i.colors.RED};
27
+ background: ${({ theme: t }) => t.colors.RED};
28
28
  border-radius: 32px;
29
29
  animation: ${n}
30
- ${({ $blinkDelay: i, $blinkDuration: e }) => `${e + i}ms linear infinite`};
31
- `, c = t.div`
30
+ ${({ $blinkDelay: t, $blinkDuration: e }) => `${e + t}ms linear infinite`};
31
+ `, c = i.div`
32
32
  height: 100%;
33
33
  width: 100%;
34
34
  display: flex;
@@ -38,22 +38,22 @@ const n = o`
38
38
  align-self: center;
39
39
  padding-top: 6px;
40
40
  z-index: 1;
41
- `, p = t.div`
41
+ `, l = i.div`
42
42
  position: absolute;
43
43
  top: 0;
44
44
  left: 0;
45
45
  bottom: 0;
46
46
  right: 0;
47
- `, l = t.img`
47
+ `, p = i.img`
48
48
  width: 100%;
49
49
  height: 100%;
50
50
  `;
51
51
  export {
52
52
  d as StreakBg,
53
53
  c as StreakContent,
54
- p as StreakImg,
54
+ l as StreakImg,
55
55
  s as StreakStaticBg,
56
56
  a as StreakWrapper,
57
- l as StyledImg
57
+ p as StyledImg
58
58
  };
59
59
  //# sourceMappingURL=streak-icon-styled.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"streak-icon-styled.js","sources":["../../../../src/features/ui/streak-icon/streak-icon-styled.tsx"],"sourcesContent":["import styled, { keyframes } from 'styled-components';\n\nconst fadeInFadeOut = keyframes`\n66%{\n opacity: 0;\n}\n33%{\n opacity: 1;\n}\n`;\n\nexport const StreakWrapper = styled.div`\n height: 32px;\n width: 32px;\n display: flex;\n align-items: center;\n justify-content: center;\n position: relative;\n cursor: pointer;\n`;\n\nexport const StreakStaticBg = styled.div`\n height: 90%;\n width: 90%;\n position: absolute;\n background: ${({ theme }) => theme.colors.BLACK_1};\n border-radius: 24px;\n`;\n\nexport const StreakBg = styled.div<{ $blinkDuration: number; $blinkDelay: number }>`\n height: 90%;\n width: 90%;\n position: absolute;\n background: ${({ theme }) => theme.colors.RED};\n border-radius: 32px;\n animation: ${fadeInFadeOut}\n ${({ $blinkDelay, $blinkDuration }) => `${$blinkDuration + $blinkDelay}ms linear infinite`};\n`;\n\nexport const StreakContent = styled.div`\n height: 100%;\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n align-self: center;\n padding-top: 6px;\n z-index: 1;\n`;\n\nexport const StreakImg = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n`;\n\nexport const StyledImg = styled.img`\n width: 100%;\n height: 100%;\n`;\n"],"names":["fadeInFadeOut","keyframes","StreakWrapper","styled","StreakStaticBg","theme","StreakBg","$blinkDelay","$blinkDuration","StreakContent","StreakImg","StyledImg"],"mappings":";AAEA,MAAMA,IAAgBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GASTC,IAAgBC,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAUvBC,IAAiBD,EAAO;AAAA;AAAA;AAAA;AAAA,gBAIrB,CAAC,EAAE,OAAAE,EAAA,MAAYA,EAAM,OAAO,OAAO;AAAA;AAAA,GAItCC,IAAWH,EAAO;AAAA;AAAA;AAAA;AAAA,gBAIf,CAAC,EAAE,OAAAE,EAAA,MAAYA,EAAM,OAAO,GAAG;AAAA;AAAA,eAEhCL,CAAa;AAAA,MACtB,CAAC,EAAE,aAAAO,GAAa,gBAAAC,QAAqB,GAAGA,IAAiBD,CAAW,oBAAoB;AAAA,GAGjFE,IAAgBN,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAYvBO,IAAYP,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQnBQ,IAAYR,EAAO;AAAA;AAAA;AAAA;"}
1
+ {"version":3,"file":"streak-icon-styled.js","sources":["../../../../src/features/ui/streak-icon/streak-icon-styled.tsx"],"sourcesContent":["import type { IStreakWrapperProps } from './streak-icon-types';\n\nimport styled, { keyframes } from 'styled-components';\n\nconst fadeInFadeOut = keyframes`\n66%{\n opacity: 0;\n}\n33%{\n opacity: 1;\n}\n`;\n\nexport const StreakWrapper = styled.div<IStreakWrapperProps>`\n height: 32px;\n width: 32px;\n display: flex;\n align-items: center;\n justify-content: center;\n position: relative;\n cursor: ${({ isInteractive }) => (isInteractive ? 'pointer' : 'default')};\n`;\n\nexport const StreakStaticBg = styled.div`\n height: 90%;\n width: 90%;\n position: absolute;\n background: ${({ theme }) => theme.colors.BLACK_1};\n border-radius: 24px;\n`;\n\nexport const StreakBg = styled.div<{ $blinkDuration: number; $blinkDelay: number }>`\n height: 90%;\n width: 90%;\n position: absolute;\n background: ${({ theme }) => theme.colors.RED};\n border-radius: 32px;\n animation: ${fadeInFadeOut}\n ${({ $blinkDelay, $blinkDuration }) => `${$blinkDuration + $blinkDelay}ms linear infinite`};\n`;\n\nexport const StreakContent = styled.div`\n height: 100%;\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n align-self: center;\n padding-top: 6px;\n z-index: 1;\n`;\n\nexport const StreakImg = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n right: 0;\n`;\n\nexport const StyledImg = styled.img`\n width: 100%;\n height: 100%;\n`;\n"],"names":["fadeInFadeOut","keyframes","StreakWrapper","styled","isInteractive","StreakStaticBg","theme","StreakBg","$blinkDelay","$blinkDuration","StreakContent","StreakImg","StyledImg"],"mappings":";AAIA,MAAMA,IAAgBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GASTC,IAAgBC,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,YAOxB,CAAC,EAAE,eAAAC,EAAA,MAAqBA,IAAgB,YAAY,SAAU;AAAA,GAG7DC,IAAiBF,EAAO;AAAA;AAAA;AAAA;AAAA,gBAIrB,CAAC,EAAE,OAAAG,EAAA,MAAYA,EAAM,OAAO,OAAO;AAAA;AAAA,GAItCC,IAAWJ,EAAO;AAAA;AAAA;AAAA;AAAA,gBAIf,CAAC,EAAE,OAAAG,EAAA,MAAYA,EAAM,OAAO,GAAG;AAAA;AAAA,eAEhCN,CAAa;AAAA,MACtB,CAAC,EAAE,aAAAQ,GAAa,gBAAAC,QAAqB,GAAGA,IAAiBD,CAAW,oBAAoB;AAAA,GAGjFE,IAAgBP,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAYvBQ,IAAYR,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQnBS,IAAYT,EAAO;AAAA;AAAA;AAAA;"}
@@ -1,20 +1,22 @@
1
1
  import { jsxs as e, jsx as r } from "react/jsx-runtime";
2
- import { memo as n } from "react";
3
- import i from "../../../assets/illustrations/streak-green.svg.js";
4
- import S from "../../../assets/illustrations/streak-white.svg.js";
5
- import l from "../text/text.js";
6
- import { BLINK_DURATION as c, BLINK_DELAY as k } from "./constants.js";
7
- import { StreakWrapper as p, StreakStaticBg as s, StreakBg as f, StreakContent as d, StreakImg as I, StyledImg as o } from "./streak-icon-styled.js";
8
- const $ = n(({ value: a, blink: t = !1, ...m }) => /* @__PURE__ */ e(p, { ...m, children: [
9
- /* @__PURE__ */ r(s, {}),
10
- t && /* @__PURE__ */ r(f, { $blinkDuration: c, $blinkDelay: k }),
11
- /* @__PURE__ */ e(d, { children: [
12
- /* @__PURE__ */ r(I, { children: t ? /* @__PURE__ */ r(o, { src: S, alt: "Streak" }) : /* @__PURE__ */ r(o, { src: i, alt: "Streak" }) }),
13
- /* @__PURE__ */ r(l, { $renderAs: "ab3-bold", $color: "WHITE", $align: "center", children: a })
2
+ import { memo as i } from "react";
3
+ import S from "../../../assets/illustrations/streak-green.svg.js";
4
+ import l from "../../../assets/illustrations/streak-white.svg.js";
5
+ import c from "../text/text.js";
6
+ import { BLINK_DURATION as k, BLINK_DELAY as p } from "./constants.js";
7
+ import { StreakWrapper as s, StreakStaticBg as f, StreakBg as d, StreakContent as I, StreakImg as $, StyledImg as o } from "./streak-icon-styled.js";
8
+ const g = i(
9
+ ({ value: a, blink: t = !1, isInteractive: m = !0, ...n }) => /* @__PURE__ */ e(s, { isInteractive: m, ...n, children: [
10
+ /* @__PURE__ */ r(f, {}),
11
+ t && /* @__PURE__ */ r(d, { $blinkDuration: k, $blinkDelay: p }),
12
+ /* @__PURE__ */ e(I, { children: [
13
+ /* @__PURE__ */ r($, { children: t ? /* @__PURE__ */ r(o, { src: l, alt: "Streak" }) : /* @__PURE__ */ r(o, { src: S, alt: "Streak" }) }),
14
+ /* @__PURE__ */ r(c, { $renderAs: "ab3-bold", $color: "WHITE", $align: "center", children: a })
15
+ ] })
14
16
  ] })
15
- ] })), A = $;
17
+ ), G = g;
16
18
  export {
17
- $ as StreakIcon,
18
- A as default
19
+ g as StreakIcon,
20
+ G as default
19
21
  };
20
22
  //# sourceMappingURL=streak-icon.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"streak-icon.js","sources":["../../../../src/features/ui/streak-icon/streak-icon.tsx"],"sourcesContent":["import type { IStreakIconProps } from './streak-icon-types';\n\nimport React, { memo } from 'react';\n\nimport StreakGreenSVG from '../../../assets/illustrations/streak-green.svg';\nimport StreakWhiteSVG from '../../../assets/illustrations/streak-white.svg';\nimport Text from '../text/text';\nimport { BLINK_DELAY, BLINK_DURATION } from './constants';\nimport * as S from './streak-icon-styled';\n\nexport const StreakIcon: React.FC<IStreakIconProps> = memo(({ value, blink = false, ...rest }) => {\n return (\n <S.StreakWrapper {...rest}>\n <S.StreakStaticBg />\n {blink && <S.StreakBg $blinkDuration={BLINK_DURATION} $blinkDelay={BLINK_DELAY} />}\n <S.StreakContent>\n <S.StreakImg>\n {blink ? (\n <S.StyledImg src={StreakWhiteSVG} alt=\"Streak\" />\n ) : (\n <S.StyledImg src={StreakGreenSVG} alt=\"Streak\" />\n )}\n </S.StreakImg>\n <Text $renderAs=\"ab3-bold\" $color=\"WHITE\" $align=\"center\">\n {value}\n </Text>\n </S.StreakContent>\n </S.StreakWrapper>\n );\n});\n\nexport default StreakIcon;\n"],"names":["StreakIcon","memo","value","blink","rest","jsxs","S.StreakWrapper","jsx","S.StreakStaticBg","S.StreakBg","BLINK_DURATION","BLINK_DELAY","S.StreakContent","S.StreakImg","S.StyledImg","StreakWhiteSVG","StreakGreenSVG","Text","StreakIcon$1"],"mappings":";;;;;;;AAUa,MAAAA,IAAyCC,EAAK,CAAC,EAAE,OAAAC,GAAO,OAAAC,IAAQ,IAAO,GAAGC,QAElF,gBAAAC,EAAAC,GAAA,EAAiB,GAAGF,GACnB,UAAA;AAAA,EAAC,gBAAAG,EAAAC,GAAA,EAAiB;AAAA,EACjBL,uBAAUM,GAAA,EAAW,gBAAgBC,GAAgB,aAAaC,GAAa;AAAA,EAChF,gBAAAN,EAACO,GAAA,EACC,UAAA;AAAA,IAAC,gBAAAL,EAAAM,GAAA,EACE,UAAAV,sBACEW,GAAA,EAAY,KAAKC,GAAgB,KAAI,UAAS,sBAE9CD,GAAA,EAAY,KAAKE,GAAgB,KAAI,SAAS,CAAA,GAEnD;AAAA,IACA,gBAAAT,EAACU,KAAK,WAAU,YAAW,QAAO,SAAQ,QAAO,UAC9C,UACHf,EAAA,CAAA;AAAA,EAAA,GACF;AACF,EAAA,CAAA,CAEH,GAEDgB,IAAelB;"}
1
+ {"version":3,"file":"streak-icon.js","sources":["../../../../src/features/ui/streak-icon/streak-icon.tsx"],"sourcesContent":["import type { IStreakIconProps } from './streak-icon-types';\n\nimport React, { memo } from 'react';\n\nimport StreakGreenSVG from '../../../assets/illustrations/streak-green.svg';\nimport StreakWhiteSVG from '../../../assets/illustrations/streak-white.svg';\nimport Text from '../text/text';\nimport { BLINK_DELAY, BLINK_DURATION } from './constants';\nimport * as S from './streak-icon-styled';\n\nexport const StreakIcon: React.FC<IStreakIconProps> = memo(\n ({ value, blink = false, isInteractive = true, ...rest }) => {\n return (\n <S.StreakWrapper isInteractive={isInteractive} {...rest}>\n <S.StreakStaticBg />\n {blink && <S.StreakBg $blinkDuration={BLINK_DURATION} $blinkDelay={BLINK_DELAY} />}\n <S.StreakContent>\n <S.StreakImg>\n {blink ? (\n <S.StyledImg src={StreakWhiteSVG} alt=\"Streak\" />\n ) : (\n <S.StyledImg src={StreakGreenSVG} alt=\"Streak\" />\n )}\n </S.StreakImg>\n <Text $renderAs=\"ab3-bold\" $color=\"WHITE\" $align=\"center\">\n {value}\n </Text>\n </S.StreakContent>\n </S.StreakWrapper>\n );\n },\n);\n\nexport default StreakIcon;\n"],"names":["StreakIcon","memo","value","blink","isInteractive","rest","S.StreakWrapper","jsx","S.StreakStaticBg","S.StreakBg","BLINK_DURATION","BLINK_DELAY","jsxs","S.StreakContent","S.StreakImg","S.StyledImg","StreakWhiteSVG","StreakGreenSVG","Text","StreakIcon$1"],"mappings":";;;;;;;AAUO,MAAMA,IAAyCC;AAAA,EACpD,CAAC,EAAE,OAAAC,GAAO,OAAAC,IAAQ,IAAO,eAAAC,IAAgB,IAAM,GAAGC,0BAE7CC,GAAA,EAAgB,eAAAF,GAA+B,GAAGC,GACjD,UAAA;AAAA,IAAC,gBAAAE,EAAAC,GAAA,EAAiB;AAAA,IACjBL,uBAAUM,GAAA,EAAW,gBAAgBC,GAAgB,aAAaC,GAAa;AAAA,IAChF,gBAAAC,EAACC,GAAA,EACC,UAAA;AAAA,MAAC,gBAAAN,EAAAO,GAAA,EACE,UAAAX,sBACEY,GAAA,EAAY,KAAKC,GAAgB,KAAI,UAAS,sBAE9CD,GAAA,EAAY,KAAKE,GAAgB,KAAI,SAAS,CAAA,GAEnD;AAAA,MACA,gBAAAV,EAACW,KAAK,WAAU,YAAW,QAAO,SAAQ,QAAO,UAC9C,UACHhB,EAAA,CAAA;AAAA,IAAA,GACF;AAAA,EACF,EAAA,CAAA;AAGN,GAEAiB,IAAenB;"}
@@ -1,40 +1,44 @@
1
- import { jsx as e } from "react/jsx-runtime";
2
- import { memo as c } from "react";
3
- import { useTheme as f } from "styled-components";
4
- import u from "../text/text.js";
5
- import { TabWrapper as T } from "./tab-styled.js";
6
- const l = c(
1
+ import { jsx as m } from "react/jsx-runtime";
2
+ import { memo as h, useMemo as C } from "react";
3
+ import { useTheme as E } from "styled-components";
4
+ import y from "../text/text.js";
5
+ import { EDeviceType as a } from "../theme/constants.js";
6
+ import { TabWrapper as A } from "./tab-styled.js";
7
+ const B = h(
7
8
  ({
8
- $renderAs: o = "primary",
9
+ $renderAs: p = "primary",
9
10
  $size: r = "regular",
10
- label: m,
11
- $selected: t,
12
- $width: n,
13
- $disabled: a,
14
- onClick: p,
15
- shape: i = "square"
11
+ $sizeOnMobile: o,
12
+ $sizeOnTablet: t,
13
+ label: c,
14
+ $selected: n,
15
+ $width: i,
16
+ $disabled: f,
17
+ onClick: u,
18
+ shape: s = "square"
16
19
  }) => {
17
20
  const {
18
- tab: { sizes: s }
19
- } = f();
20
- return /* @__PURE__ */ e(
21
- T,
21
+ tab: { sizes: T },
22
+ device: e
23
+ } = E(), d = C(() => e <= a.MOBILE ? o || t || r : e <= a.TABLET && t || r, [e, r, o, t]), x = T[d].textVariant;
24
+ return /* @__PURE__ */ m(
25
+ A,
22
26
  {
23
- $selected: t,
24
- $width: n,
25
- onClick: p,
27
+ $selected: n,
28
+ $width: i,
29
+ onClick: u,
26
30
  $size: r,
27
- $renderAs: o,
28
- $disabled: a,
31
+ $renderAs: p,
32
+ $disabled: f,
29
33
  $justifyContent: "center",
30
34
  $alignItems: "center",
31
- $shape: i,
32
- children: /* @__PURE__ */ e(u, { $renderAs: s[r].textVariant, color: t ? "WHITE" : "BLACK", children: m })
35
+ $shape: s,
36
+ children: /* @__PURE__ */ m(y, { $renderAs: x, color: n ? "WHITE" : "BLACK", children: c })
33
37
  }
34
38
  );
35
39
  }
36
- ), $ = l;
40
+ ), V = B;
37
41
  export {
38
- $ as default
42
+ V as default
39
43
  };
40
44
  //# sourceMappingURL=tab.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tab.js","sources":["../../../../src/features/ui/tab/tab.tsx"],"sourcesContent":["import type { ITabProps } from './tab-types';\n\nimport React, { memo } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport Text from '../text/text';\nimport * as Styled from './tab-styled';\n\nconst TabComponent: React.FC<ITabProps> = memo(\n ({\n $renderAs = 'primary',\n $size = 'regular',\n label,\n $selected,\n $width,\n $disabled,\n onClick,\n shape = 'square',\n }) => {\n const {\n tab: { sizes },\n } = useTheme();\n\n return (\n <Styled.TabWrapper\n $selected={$selected}\n $width={$width}\n onClick={onClick}\n $size={$size}\n $renderAs={$renderAs}\n $disabled={$disabled}\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $shape={shape}\n >\n <Text $renderAs={sizes[$size].textVariant} color={$selected ? 'WHITE' : 'BLACK'}>\n {label}\n </Text>\n </Styled.TabWrapper>\n );\n },\n);\n\nexport default TabComponent;\n"],"names":["TabComponent","memo","$renderAs","$size","label","$selected","$width","$disabled","onClick","shape","sizes","useTheme","jsx","Styled.TabWrapper","Text","TabComponent$1"],"mappings":";;;;;AAQA,MAAMA,IAAoCC;AAAA,EACxC,CAAC;AAAA,IACC,WAAAC,IAAY;AAAA,IACZ,OAAAC,IAAQ;AAAA,IACR,OAAAC;AAAA,IACA,WAAAC;AAAA,IACA,QAAAC;AAAA,IACA,WAAAC;AAAA,IACA,SAAAC;AAAA,IACA,OAAAC,IAAQ;AAAA,EAAA,MACJ;AACE,UAAA;AAAA,MACJ,KAAK,EAAE,OAAAC,EAAM;AAAA,QACXC,EAAS;AAGX,WAAA,gBAAAC;AAAA,MAACC;AAAAA,MAAA;AAAA,QACC,WAAAR;AAAA,QACA,QAAAC;AAAA,QACA,SAAAE;AAAA,QACA,OAAAL;AAAA,QACA,WAAAD;AAAA,QACA,WAAAK;AAAA,QACA,iBAAgB;AAAA,QAChB,aAAY;AAAA,QACZ,QAAQE;AAAA,QAER,UAAA,gBAAAG,EAACE,GAAK,EAAA,WAAWJ,EAAMP,CAAK,EAAE,aAAa,OAAOE,IAAY,UAAU,SACrE,UACHD,EAAA,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF,GAEAW,IAAef;"}
1
+ {"version":3,"file":"tab.js","sources":["../../../../src/features/ui/tab/tab.tsx"],"sourcesContent":["import type { ITabProps } from './tab-types';\n\nimport React, { memo, useMemo } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport Text from '../text/text';\nimport { EDeviceType } from '../theme/constants';\nimport * as Styled from './tab-styled';\n\nconst TabComponent: React.FC<ITabProps> = memo(\n ({\n $renderAs = 'primary',\n $size = 'regular',\n $sizeOnMobile,\n $sizeOnTablet,\n label,\n $selected,\n $width,\n $disabled,\n onClick,\n shape = 'square',\n }) => {\n const {\n tab: { sizes },\n device,\n } = useTheme();\n\n const renderSize = useMemo(() => {\n if (device <= EDeviceType.MOBILE) {\n return $sizeOnMobile || $sizeOnTablet || $size;\n }\n\n if (device <= EDeviceType.TABLET) {\n return $sizeOnTablet || $size;\n }\n\n return $size;\n }, [device, $size, $sizeOnMobile, $sizeOnTablet]);\n\n const textVariant = sizes[renderSize].textVariant;\n\n return (\n <Styled.TabWrapper\n $selected={$selected}\n $width={$width}\n onClick={onClick}\n $size={$size}\n $renderAs={$renderAs}\n $disabled={$disabled}\n $justifyContent=\"center\"\n $alignItems=\"center\"\n $shape={shape}\n >\n <Text $renderAs={textVariant} color={$selected ? 'WHITE' : 'BLACK'}>\n {label}\n </Text>\n </Styled.TabWrapper>\n );\n },\n);\n\nexport default TabComponent;\n"],"names":["TabComponent","memo","$renderAs","$size","$sizeOnMobile","$sizeOnTablet","label","$selected","$width","$disabled","onClick","shape","sizes","device","useTheme","renderSize","useMemo","EDeviceType","textVariant","jsx","Styled.TabWrapper","Text","TabComponent$1"],"mappings":";;;;;;AASA,MAAMA,IAAoCC;AAAA,EACxC,CAAC;AAAA,IACC,WAAAC,IAAY;AAAA,IACZ,OAAAC,IAAQ;AAAA,IACR,eAAAC;AAAA,IACA,eAAAC;AAAA,IACA,OAAAC;AAAA,IACA,WAAAC;AAAA,IACA,QAAAC;AAAA,IACA,WAAAC;AAAA,IACA,SAAAC;AAAA,IACA,OAAAC,IAAQ;AAAA,EAAA,MACJ;AACE,UAAA;AAAA,MACJ,KAAK,EAAE,OAAAC,EAAM;AAAA,MACb,QAAAC;AAAA,QACEC,EAAS,GAEPC,IAAaC,EAAQ,MACrBH,KAAUI,EAAY,SACjBb,KAAiBC,KAAiBF,IAGvCU,KAAUI,EAAY,UACjBZ,KAAiBF,GAIzB,CAACU,GAAQV,GAAOC,GAAeC,CAAa,CAAC,GAE1Ca,IAAcN,EAAMG,CAAU,EAAE;AAGpC,WAAA,gBAAAI;AAAA,MAACC;AAAAA,MAAA;AAAA,QACC,WAAAb;AAAA,QACA,QAAAC;AAAA,QACA,SAAAE;AAAA,QACA,OAAAP;AAAA,QACA,WAAAD;AAAA,QACA,WAAAO;AAAA,QACA,iBAAgB;AAAA,QAChB,aAAY;AAAA,QACZ,QAAQE;AAAA,QAER,UAAA,gBAAAQ,EAACE,KAAK,WAAWH,GAAa,OAAOX,IAAY,UAAU,SACxD,UACHD,EAAA,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF,GAEAgB,IAAetB;"}
@@ -1,50 +1,54 @@
1
- import k from "styled-components";
2
- const x = k.div(
1
+ import { useMemo as C } from "react";
2
+ import F from "styled-components";
3
+ import { EDeviceType as y } from "../theme/constants.js";
4
+ const $ = F.div(
3
5
  ({
4
- theme: f,
5
- $renderAs: c,
6
+ theme: g,
7
+ $renderAs: t,
6
8
  $color: n,
7
- $align: y = "left",
8
- $width: t,
9
- $widthX: o,
10
- $marginBottom: e,
11
- $marginBottomX: i,
9
+ $align: T = "left",
10
+ $width: e,
11
+ $widthX: f,
12
+ $marginBottom: o,
13
+ $marginBottomX: r,
12
14
  $alignSelf: l,
13
- $opacity: u = 1,
14
- $inline: m,
15
- $textDecoration: p,
16
- $whiteSpace: $
15
+ $opacity: b = 1,
16
+ $inline: v,
17
+ $textDecoration: x,
18
+ $whiteSpace: a,
19
+ $renderOnMobileAs: c,
20
+ $renderOnTabletAs: i
17
21
  }) => {
18
- const { text: b, colors: r, layout: a } = f, {
19
- fontFamily: g,
20
- fontSize: d,
21
- lineHeight: T,
22
+ const { text: E, colors: m, layout: u, device: p } = g, L = C(() => p <= y.MOBILE ? c || i || t : p <= y.TABLET && i || t, [p, t, c, i]), {
23
+ fontFamily: h,
24
+ fontSize: k,
25
+ lineHeight: z,
22
26
  letterSpacing: s,
23
- textTransform: h = "none"
24
- } = b[c];
27
+ textTransform: d = "none"
28
+ } = E[L];
25
29
  return `
26
- display: ${m ? "inline-block" : "block"};
27
- font-family: ${g};
28
- font-size: ${d}px;
29
- text-align: ${y};
30
- line-height: ${T}px;
31
- text-transform: ${h};
30
+ display: ${v ? "inline-block" : "block"};
31
+ font-family: ${h};
32
+ font-size: ${k}px;
33
+ text-align: ${T};
34
+ line-height: ${z}px;
35
+ text-transform: ${d};
32
36
  ${typeof s == "number" ? `letter-spacing: ${s}px;` : ""}
33
- color: ${n ? r[n] : r.BLACK};
34
- opacity: ${u};
35
- width: ${t ? `${t}` : "auto"}${typeof t == "number" ? "px" : ""};
36
- ${o ? `width: ${o * a.gutter}px;` : ""}
37
- margin-bottom: ${e ? `${e}` : "initial"}${typeof e == "number" ? "px" : ""};
38
- ${i ? `margin-bottom: ${i * a.gutter}px;` : ""}
37
+ color: ${n ? m[n] : m.BLACK};
38
+ opacity: ${b};
39
+ width: ${e ? `${e}` : "auto"}${typeof e == "number" ? "px" : ""};
40
+ ${f ? `width: ${f * u.gutter}px;` : ""}
41
+ margin-bottom: ${o ? `${o}` : "initial"}${typeof o == "number" ? "px" : ""};
42
+ ${r ? `margin-bottom: ${r * u.gutter}px;` : ""}
39
43
  ${l ? `align-self: ${l};` : ""}
40
- ${p ? `text-decoration: ${p};` : ""}
41
- ${$ ? `white-space: ${$};` : ""}
44
+ ${x ? `text-decoration: ${x};` : ""}
45
+ ${a ? `white-space: ${a};` : ""}
42
46
  `;
43
47
  }
44
48
  );
45
- x.displayName = "Text";
46
- const v = x;
49
+ $.displayName = "Text";
50
+ const M = $;
47
51
  export {
48
- v as default
52
+ M as default
49
53
  };
50
54
  //# sourceMappingURL=text.js.map