@cuemath/leap 3.2.33 → 3.2.34-mb

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 (106) hide show
  1. package/dist/assets/gif/gif.js +1 -4
  2. package/dist/assets/gif/gif.js.map +1 -1
  3. package/dist/assets/illustrations/illustrations.js +0 -17
  4. package/dist/assets/illustrations/illustrations.js.map +1 -1
  5. package/dist/assets/lottie/lottie.js +0 -3
  6. package/dist/assets/lottie/lottie.js.map +1 -1
  7. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message-styled.js +1 -1
  8. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message-styled.js.map +1 -1
  9. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message.js +22 -22
  10. package/dist/features/auth/comps/animated-avatar-message/animated-avatar-message.js.map +1 -1
  11. package/dist/features/auth/comps/pill-button/pill-button-styled.js +11 -12
  12. package/dist/features/auth/comps/pill-button/pill-button-styled.js.map +1 -1
  13. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide-styled.js +4 -11
  14. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide-styled.js.map +1 -1
  15. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide.js +17 -17
  16. package/dist/features/auth/pla-signup/onboarding-guide/onboarding-guide.js.map +1 -1
  17. package/dist/features/auth/pla-signup/signup-options/signup-options.js +1 -1
  18. package/dist/features/auth/pla-signup/signup-options/signup-options.js.map +1 -1
  19. package/dist/features/stickers/sticker-data.js +234 -0
  20. package/dist/features/stickers/sticker-data.js.map +1 -0
  21. package/dist/features/stickers/sticker-selector/sticker-selector-grid.js +39 -0
  22. package/dist/features/stickers/sticker-selector/sticker-selector-grid.js.map +1 -0
  23. package/dist/features/{ui/sticker-grid/sticker-grid-styles.js → stickers/sticker-selector/sticker-selector-styles.js} +23 -31
  24. package/dist/features/stickers/sticker-selector/sticker-selector-styles.js.map +1 -0
  25. package/dist/features/stickers/sticker-selector/sticker-selector.js +88 -0
  26. package/dist/features/stickers/sticker-selector/sticker-selector.js.map +1 -0
  27. package/dist/features/stickers/sticker-selector/sticker.js +60 -0
  28. package/dist/features/stickers/sticker-selector/sticker.js.map +1 -0
  29. package/dist/features/stickers/stickers-effects/effects.js +82 -0
  30. package/dist/features/stickers/stickers-effects/effects.js.map +1 -0
  31. package/dist/features/stickers/stickers-effects/stickers-cache.js +19 -0
  32. package/dist/features/stickers/stickers-effects/stickers-cache.js.map +1 -0
  33. package/dist/features/stickers/stickers-effects/stickers-effects-helper.js +105 -0
  34. package/dist/features/stickers/stickers-effects/stickers-effects-helper.js.map +1 -0
  35. package/dist/features/stickers/stickers-effects/stickers-effects-styled.js +37 -0
  36. package/dist/features/stickers/stickers-effects/stickers-effects-styled.js.map +1 -0
  37. package/dist/features/stickers/stickers-effects/stickers-effects.js +67 -0
  38. package/dist/features/stickers/stickers-effects/stickers-effects.js.map +1 -0
  39. package/dist/features/ui/arrow-tooltip/arrow-tooltip-styled.js +8 -3
  40. package/dist/features/ui/arrow-tooltip/arrow-tooltip-styled.js.map +1 -1
  41. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js +40 -40
  42. package/dist/features/ui/arrow-tooltip/arrow-tooltip.js.map +1 -1
  43. package/dist/features/ui/dot-lottie-animations/dot-lottie-animation.js +88 -75
  44. package/dist/features/ui/dot-lottie-animations/dot-lottie-animation.js.map +1 -1
  45. package/dist/features/ui/drawer/drawer-styled.js +2 -4
  46. package/dist/features/ui/drawer/drawer-styled.js.map +1 -1
  47. package/dist/features/ui/lottie-animation/lottie-animation.js +36 -31
  48. package/dist/features/ui/lottie-animation/lottie-animation.js.map +1 -1
  49. package/dist/features/ui/modals/modal-styled.js +48 -15
  50. package/dist/features/ui/modals/modal-styled.js.map +1 -1
  51. package/dist/features/ui/modals/modal.js +43 -35
  52. package/dist/features/ui/modals/modal.js.map +1 -1
  53. package/dist/index.d.ts +85 -57
  54. package/dist/index.js +343 -341
  55. package/dist/index.js.map +1 -1
  56. package/dist/node_modules/uuid/dist/esm-browser/regex.js +5 -0
  57. package/dist/node_modules/uuid/dist/esm-browser/regex.js.map +1 -0
  58. package/dist/node_modules/uuid/dist/esm-browser/rng.js +2 -3
  59. package/dist/node_modules/uuid/dist/esm-browser/rng.js.map +1 -1
  60. package/dist/node_modules/uuid/dist/esm-browser/stringify.js +10 -6
  61. package/dist/node_modules/uuid/dist/esm-browser/stringify.js.map +1 -1
  62. package/dist/node_modules/uuid/dist/esm-browser/v4.js +9 -12
  63. package/dist/node_modules/uuid/dist/esm-browser/v4.js.map +1 -1
  64. package/dist/node_modules/uuid/dist/esm-browser/validate.js +8 -0
  65. package/dist/node_modules/uuid/dist/esm-browser/validate.js.map +1 -0
  66. package/package.json +1 -1
  67. package/dist/features/ui/sticker-grid/sticker-grid-styles.js.map +0 -1
  68. package/dist/features/ui/sticker-grid/sticker-grid.js +0 -24
  69. package/dist/features/ui/sticker-grid/sticker-grid.js.map +0 -1
  70. package/dist/features/ui/sticker-grid/sticker.js +0 -57
  71. package/dist/features/ui/sticker-grid/sticker.js.map +0 -1
  72. package/dist/features/ui/stickers/constants.js +0 -6
  73. package/dist/features/ui/stickers/constants.js.map +0 -1
  74. package/dist/features/ui/stickers/stickers-effects.js +0 -64
  75. package/dist/features/ui/stickers/stickers-effects.js.map +0 -1
  76. package/dist/features/ui/stickers/stickers-styled.js +0 -29
  77. package/dist/features/ui/stickers/stickers-styled.js.map +0 -1
  78. package/dist/features/ui/stickers/stickers-utils.js +0 -91
  79. package/dist/features/ui/stickers/stickers-utils.js.map +0 -1
  80. package/dist/features/ui/stickers/stickers.js +0 -40
  81. package/dist/features/ui/stickers/stickers.js.map +0 -1
  82. package/dist/node_modules/uuid/dist/esm-browser/native.js +0 -7
  83. package/dist/node_modules/uuid/dist/esm-browser/native.js.map +0 -1
  84. package/dist/static/arrow-board-green.11e75bca.svg +0 -1
  85. package/dist/static/book-checked-green.c275dbd9.svg +0 -1
  86. package/dist/static/book-checked-orange.53ea6880.svg +0 -1
  87. package/dist/static/book-checked-purple.df628f3e.svg +0 -1
  88. package/dist/static/calendar-check-green.ab0e24d2.svg +0 -1
  89. package/dist/static/calendar-cross-orange.8e7a23bd.svg +0 -1
  90. package/dist/static/calendar-hour-glass-orange.e99f8ffd.json +0 -1
  91. package/dist/static/equal-outlined.b705bf5d.svg +0 -1
  92. package/dist/static/handshake-green.f8d24216.svg +0 -1
  93. package/dist/static/heart-outlined.5b5415fe.svg +0 -1
  94. package/dist/static/knowledge-blue.ead536f1.svg +0 -1
  95. package/dist/static/learning-session-grid-bg.fb60e64b.gif +0 -0
  96. package/dist/static/platform-green.eb853207.svg +0 -1
  97. package/dist/static/platform-purple.ecf6fa46.svg +0 -1
  98. package/dist/static/radial-gradient-bg-2.6657c758.svg +0 -1
  99. package/dist/static/radial-gradient-bg.5ae0cde5.svg +0 -1
  100. package/dist/static/star-outlined.bde83c7c.svg +0 -1
  101. package/dist/static/student-avatar.24bc2875.svg +0 -1
  102. package/dist/static/teacher-found.0ba07d4a.json +0 -1
  103. package/dist/static/teacher-search.552c8ba2.json +0 -1
  104. package/dist/static/trophy-outlined.f946b362.svg +0 -1
  105. package/dist/static/way-forward-grid-bg.ab5d2dc6.gif +0 -0
  106. package/dist/static/your-goals-grid-bg.87fa9c60.gif +0 -0
@@ -1,18 +1,18 @@
1
- import { jsxs as o, jsx as e } from "react/jsx-runtime";
2
- import { useTheme as c } from "styled-components";
3
- import n from "../../../ui/layout/flex-view.js";
4
- import m from "../../../ui/separator/separator.js";
1
+ import { jsxs as n, jsx as e } from "react/jsx-runtime";
2
+ import { useTheme as m } from "styled-components";
3
+ import t from "../../../ui/layout/flex-view.js";
4
+ import a from "../../../ui/separator/separator.js";
5
5
  import l from "../../../ui/text/text.js";
6
6
  import { EDeviceType as p } from "../../../ui/theme/constants.js";
7
7
  import { onboardingGuideSteps as s } from "./onboarding-guide-constants.js";
8
- import { StepWrapper as $, StepItem as d } from "./onboarding-guide-styled.js";
9
- const f = () => {
10
- const { device: a } = c(), r = a <= p.TABLET;
11
- return /* @__PURE__ */ o(n, { $flex: 1, $alignItems: "center", $justifyContent: "center", children: [
8
+ import { StepItem as $ } from "./onboarding-guide-styled.js";
9
+ const d = () => {
10
+ const { device: c } = m(), r = c <= p.TABLET;
11
+ return /* @__PURE__ */ n(t, { $flex: 1, $alignItems: "center", $justifyContent: "center", children: [
12
12
  /* @__PURE__ */ e(l, { $whiteSpace: "pre-line", $renderAs: "ah4", $color: "WHITE", $renderOnTabletAs: "ab1", children: "Get started in 3 easy steps!" }),
13
- /* @__PURE__ */ e(m, { heightX: r ? 1 : 2.75 }),
14
- /* @__PURE__ */ e($, { $flexDirection: r ? "row" : "column", $flexColumnGapX: 1, children: s.map((t, i) => /* @__PURE__ */ o(
15
- d,
13
+ /* @__PURE__ */ e(a, { heightX: r ? 1 : 2.75 }),
14
+ /* @__PURE__ */ e(t, { $flexDirection: r ? "row" : "column", $flexColumnGapX: 1.5, children: s.map((i, o) => /* @__PURE__ */ n(
15
+ $,
16
16
  {
17
17
  $flex: 1,
18
18
  $flexDirection: r ? "column" : "row",
@@ -20,8 +20,8 @@ const f = () => {
20
20
  $flexRowGapX: 0.5,
21
21
  $alignItems: "center",
22
22
  children: [
23
- /* @__PURE__ */ e("img", { src: t.icon, alt: `Step ${i + 1}`, width: 56, height: 56 }),
24
- /* @__PURE__ */ e(n, { $width: r ? 101 : 210, children: /* @__PURE__ */ e(
23
+ /* @__PURE__ */ e("img", { src: i.icon, alt: `Step ${o + 1}`, width: 56, height: 56 }),
24
+ /* @__PURE__ */ e(t, { $width: r ? 101 : 210, children: /* @__PURE__ */ e(
25
25
  l,
26
26
  {
27
27
  $whiteSpace: "pre-line",
@@ -29,16 +29,16 @@ const f = () => {
29
29
  $renderOnTabletAs: "ab3",
30
30
  $color: "WHITE",
31
31
  $align: r ? "center" : "left",
32
- children: t.title
32
+ children: i.title
33
33
  }
34
34
  ) })
35
35
  ]
36
36
  },
37
- i
37
+ o
38
38
  )) })
39
39
  ] });
40
- }, S = f;
40
+ }, G = d;
41
41
  export {
42
- S as default
42
+ G as default
43
43
  };
44
44
  //# sourceMappingURL=onboarding-guide.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"onboarding-guide.js","sources":["../../../../../src/features/auth/pla-signup/onboarding-guide/onboarding-guide.tsx"],"sourcesContent":["import { useTheme } from 'styled-components';\n\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { EDeviceType } from '../../../ui/theme/constants';\nimport { onboardingGuideSteps } from './onboarding-guide-constants';\nimport * as Styled from './onboarding-guide-styled';\n\nconst OnboardingGuide = () => {\n const { device } = useTheme();\n const isCompact = device <= EDeviceType.TABLET;\n\n return (\n <FlexView $flex={1} $alignItems=\"center\" $justifyContent=\"center\">\n <Text $whiteSpace=\"pre-line\" $renderAs=\"ah4\" $color=\"WHITE\" $renderOnTabletAs=\"ab1\">\n Get started in 3 easy steps!\n </Text>\n <Separator heightX={isCompact ? 1 : 2.75} />\n <Styled.StepWrapper $flexDirection={isCompact ? 'row' : 'column'} $flexColumnGapX={1}>\n {onboardingGuideSteps.map((step, index) => (\n <Styled.StepItem\n key={index}\n $flex={1}\n $flexDirection={isCompact ? 'column' : 'row'}\n $flexColumnGapX={1.5}\n $flexRowGapX={0.5}\n $alignItems={'center'}\n >\n <img src={step.icon} alt={`Step ${index + 1}`} width={56} height={56} />\n <FlexView $width={isCompact ? 101 : 210}>\n <Text\n $whiteSpace=\"pre-line\"\n $renderAs=\"ab2\"\n $renderOnTabletAs=\"ab3\"\n $color=\"WHITE\"\n $align={isCompact ? 'center' : 'left'}\n >\n {step.title}\n </Text>\n </FlexView>\n </Styled.StepItem>\n ))}\n </Styled.StepWrapper>\n </FlexView>\n );\n};\n\nexport default OnboardingGuide;\n"],"names":["OnboardingGuide","device","useTheme","isCompact","EDeviceType","FlexView","jsx","Text","Separator","Styled.StepWrapper","onboardingGuideSteps","step","index","jsxs","Styled.StepItem","OnboardingGuide$1"],"mappings":";;;;;;;;AASA,MAAMA,IAAkB,MAAM;AACtB,QAAA,EAAE,QAAAC,MAAWC,KACbC,IAAYF,KAAUG,EAAY;AAExC,2BACGC,GAAS,EAAA,OAAO,GAAG,aAAY,UAAS,iBAAgB,UACvD,UAAA;AAAA,IAAC,gBAAAC,EAAAC,GAAA,EAAK,aAAY,YAAW,WAAU,OAAM,QAAO,SAAQ,mBAAkB,OAAM,UAEpF,+BAAA,CAAA;AAAA,IACC,gBAAAD,EAAAE,GAAA,EAAU,SAASL,IAAY,IAAI,MAAM;AAAA,IACzC,gBAAAG,EAAAG,GAAA,EAAmB,gBAAgBN,IAAY,QAAQ,UAAU,iBAAiB,GAChF,UAAAO,EAAqB,IAAI,CAACC,GAAMC,MAC/B,gBAAAC;AAAA,MAACC;AAAAA,MAAA;AAAA,QAEC,OAAO;AAAA,QACP,gBAAgBX,IAAY,WAAW;AAAA,QACvC,iBAAiB;AAAA,QACjB,cAAc;AAAA,QACd,aAAa;AAAA,QAEb,UAAA;AAAA,UAAA,gBAAAG,EAAC,OAAI,EAAA,KAAKK,EAAK,MAAM,KAAK,QAAQC,IAAQ,CAAC,IAAI,OAAO,IAAI,QAAQ,IAAI;AAAA,UACrE,gBAAAN,EAAAD,GAAA,EAAS,QAAQF,IAAY,MAAM,KAClC,UAAA,gBAAAG;AAAA,YAACC;AAAA,YAAA;AAAA,cACC,aAAY;AAAA,cACZ,WAAU;AAAA,cACV,mBAAkB;AAAA,cAClB,QAAO;AAAA,cACP,QAAQJ,IAAY,WAAW;AAAA,cAE9B,UAAKQ,EAAA;AAAA,YAAA;AAAA,UAAA,GAEV;AAAA,QAAA;AAAA,MAAA;AAAA,MAlBKC;AAAA,IAoBR,CAAA,GACH;AAAA,EACF,EAAA,CAAA;AAEJ,GAEAG,IAAef;"}
1
+ {"version":3,"file":"onboarding-guide.js","sources":["../../../../../src/features/auth/pla-signup/onboarding-guide/onboarding-guide.tsx"],"sourcesContent":["import { useTheme } from 'styled-components';\n\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { EDeviceType } from '../../../ui/theme/constants';\nimport { onboardingGuideSteps } from './onboarding-guide-constants';\nimport * as Styled from './onboarding-guide-styled';\n\nconst OnboardingGuide = () => {\n const { device } = useTheme();\n const isCompact = device <= EDeviceType.TABLET;\n\n return (\n <FlexView $flex={1} $alignItems=\"center\" $justifyContent=\"center\">\n <Text $whiteSpace=\"pre-line\" $renderAs=\"ah4\" $color=\"WHITE\" $renderOnTabletAs=\"ab1\">\n Get started in 3 easy steps!\n </Text>\n <Separator heightX={isCompact ? 1 : 2.75} />\n <FlexView $flexDirection={isCompact ? 'row' : 'column'} $flexColumnGapX={1.5}>\n {onboardingGuideSteps.map((step, index) => (\n <Styled.StepItem\n key={index}\n $flex={1}\n $flexDirection={isCompact ? 'column' : 'row'}\n $flexColumnGapX={1.5}\n $flexRowGapX={0.5}\n $alignItems={'center'}\n >\n <img src={step.icon} alt={`Step ${index + 1}`} width={56} height={56} />\n <FlexView $width={isCompact ? 101 : 210}>\n <Text\n $whiteSpace=\"pre-line\"\n $renderAs=\"ab2\"\n $renderOnTabletAs=\"ab3\"\n $color=\"WHITE\"\n $align={isCompact ? 'center' : 'left'}\n >\n {step.title}\n </Text>\n </FlexView>\n </Styled.StepItem>\n ))}\n </FlexView>\n </FlexView>\n );\n};\n\nexport default OnboardingGuide;\n"],"names":["OnboardingGuide","device","useTheme","isCompact","EDeviceType","FlexView","jsx","Text","Separator","onboardingGuideSteps","step","index","jsxs","Styled.StepItem","OnboardingGuide$1"],"mappings":";;;;;;;;AASA,MAAMA,IAAkB,MAAM;AACtB,QAAA,EAAE,QAAAC,MAAWC,KACbC,IAAYF,KAAUG,EAAY;AAExC,2BACGC,GAAS,EAAA,OAAO,GAAG,aAAY,UAAS,iBAAgB,UACvD,UAAA;AAAA,IAAC,gBAAAC,EAAAC,GAAA,EAAK,aAAY,YAAW,WAAU,OAAM,QAAO,SAAQ,mBAAkB,OAAM,UAEpF,+BAAA,CAAA;AAAA,IACC,gBAAAD,EAAAE,GAAA,EAAU,SAASL,IAAY,IAAI,MAAM;AAAA,IACzC,gBAAAG,EAAAD,GAAA,EAAS,gBAAgBF,IAAY,QAAQ,UAAU,iBAAiB,KACtE,UAAqBM,EAAA,IAAI,CAACC,GAAMC,MAC/B,gBAAAC;AAAA,MAACC;AAAAA,MAAA;AAAA,QAEC,OAAO;AAAA,QACP,gBAAgBV,IAAY,WAAW;AAAA,QACvC,iBAAiB;AAAA,QACjB,cAAc;AAAA,QACd,aAAa;AAAA,QAEb,UAAA;AAAA,UAAA,gBAAAG,EAAC,OAAI,EAAA,KAAKI,EAAK,MAAM,KAAK,QAAQC,IAAQ,CAAC,IAAI,OAAO,IAAI,QAAQ,IAAI;AAAA,UACrE,gBAAAL,EAAAD,GAAA,EAAS,QAAQF,IAAY,MAAM,KAClC,UAAA,gBAAAG;AAAA,YAACC;AAAA,YAAA;AAAA,cACC,aAAY;AAAA,cACZ,WAAU;AAAA,cACV,mBAAkB;AAAA,cAClB,QAAO;AAAA,cACP,QAAQJ,IAAY,WAAW;AAAA,cAE9B,UAAKO,EAAA;AAAA,YAAA;AAAA,UAAA,GAEV;AAAA,QAAA;AAAA,MAAA;AAAA,MAlBKC;AAAA,IAoBR,CAAA,GACH;AAAA,EACF,EAAA,CAAA;AAEJ,GAEAG,IAAed;"}
@@ -20,7 +20,7 @@ const S = ({
20
20
  }) => {
21
21
  const { device: f } = g(), o = f <= $.TABLET, a = n === "google", s = n === "apple";
22
22
  return /* @__PURE__ */ i(r, { $alignItems: "flex-start", children: [
23
- /* @__PURE__ */ e(c, { $renderAs: "ah3-bold", $renderOnMobileAs: "ah4-bold", $color: "WHITE", $whiteSpace: "pre-line", children: T }),
23
+ /* @__PURE__ */ e(c, { $renderAs: "ah3-bold", $renderOnMobileAs: "ah4-bold", $color: "WHITE", $whiteSpace: "pre", children: T }),
24
24
  /* @__PURE__ */ e(p, { heightX: o ? 1.5 : 2.5 }),
25
25
  /* @__PURE__ */ i(
26
26
  r,
@@ -1 +1 @@
1
- {"version":3,"file":"signup-options.js","sources":["../../../../../src/features/auth/pla-signup/signup-options/signup-options.tsx"],"sourcesContent":["import type { ISignupOptionsProps } from './signup-options-types';\n\nimport { memo, type FC } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport AppleIcon from '../../../../assets/line-icons/icons/apple-icon-white';\nimport GoogleIcon from '../../../../assets/line-icons/icons/google-icon';\nimport Button from '../../../ui/buttons/button/button';\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { EDeviceType } from '../../../ui/theme/constants';\nimport { PLA_ANALYTICS_EVENTS } from '../pla-analytics-events';\n\nconst SignupOptions: FC<ISignupOptionsProps> = ({\n onEmailSignup,\n onAppleSignup,\n onGoogleSignup,\n loadingProvider,\n onGoToLogin,\n title,\n}) => {\n const { device } = useTheme();\n const isCompact = device <= EDeviceType.TABLET;\n const isLoadingGoogle = loadingProvider === 'google';\n const isLoadingApple = loadingProvider === 'apple';\n\n return (\n <FlexView $alignItems=\"flex-start\">\n <Text $renderAs=\"ah3-bold\" $renderOnMobileAs=\"ah4-bold\" $color=\"WHITE\" $whiteSpace=\"pre-line\">\n {title}\n </Text>\n <Separator heightX={isCompact ? 1.5 : 2.5} />\n <FlexView\n $flexGapX={1}\n $flex={1}\n $justifyContent=\"center\"\n $alignItems=\"flex-start\"\n $width=\"100%\"\n >\n <Button\n renderAs=\"black-dark\"\n Icon={GoogleIcon}\n width={isCompact ? '100%' : 320}\n label=\"Signup with Google\"\n onClick={onGoogleSignup}\n size=\"small\"\n busy={isLoadingGoogle}\n disabled={isLoadingGoogle}\n analyticsLabel={PLA_ANALYTICS_EVENTS.START_SIGNUP_CTA_CLICKED}\n analyticsProps={{ provider: 'google' }}\n />\n <Button\n renderAs=\"black-dark\"\n size=\"small\"\n width={isCompact ? '100%' : 320}\n Icon={AppleIcon}\n label=\"Signup with Apple\"\n onClick={onAppleSignup}\n busy={isLoadingApple}\n disabled={isLoadingApple}\n analyticsLabel={PLA_ANALYTICS_EVENTS.START_SIGNUP_CTA_CLICKED}\n analyticsProps={{ provider: 'apple' }}\n />\n <Button\n renderAs=\"black-dark\"\n size=\"small\"\n width={isCompact ? '100%' : 320}\n label=\"Continue with Email\"\n onClick={onEmailSignup}\n analyticsLabel={PLA_ANALYTICS_EVENTS.START_SIGNUP_CTA_CLICKED}\n analyticsProps={{ provider: 'email' }}\n />\n </FlexView>\n <Separator heightX={1.5} />\n <FlexView $flexDirection=\"row\" $alignItems=\"center\">\n <Text $renderAs=\"ub3\" $color=\"WHITE\">\n Already have an account?\n </Text>\n &nbsp;\n <TextButton size=\"small\" label=\"Log In\" color=\"WHITE\" onClick={onGoToLogin} />\n </FlexView>\n </FlexView>\n );\n};\n\nexport default memo(SignupOptions);\n"],"names":["SignupOptions","onEmailSignup","onAppleSignup","onGoogleSignup","loadingProvider","onGoToLogin","title","device","useTheme","isCompact","EDeviceType","isLoadingGoogle","isLoadingApple","jsxs","FlexView","jsx","Text","Separator","Button","GoogleIcon","PLA_ANALYTICS_EVENTS","AppleIcon","TextButton","signupOptions","memo"],"mappings":";;;;;;;;;;;;AAeA,MAAMA,IAAyC,CAAC;AAAA,EAC9C,eAAAC;AAAA,EACA,eAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,OAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAC,MAAWC,KACbC,IAAYF,KAAUG,EAAY,QAClCC,IAAkBP,MAAoB,UACtCQ,IAAiBR,MAAoB;AAGzC,SAAA,gBAAAS,EAACC,GAAS,EAAA,aAAY,cACpB,UAAA;AAAA,IAAC,gBAAAC,EAAAC,GAAA,EAAK,WAAU,YAAW,mBAAkB,YAAW,QAAO,SAAQ,aAAY,YAChF,UACHV,EAAA,CAAA;AAAA,IACC,gBAAAS,EAAAE,GAAA,EAAU,SAASR,IAAY,MAAM,KAAK;AAAA,IAC3C,gBAAAI;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,WAAW;AAAA,QACX,OAAO;AAAA,QACP,iBAAgB;AAAA,QAChB,aAAY;AAAA,QACZ,QAAO;AAAA,QAEP,UAAA;AAAA,UAAA,gBAAAC;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,MAAMC;AAAA,cACN,OAAOV,IAAY,SAAS;AAAA,cAC5B,OAAM;AAAA,cACN,SAASN;AAAA,cACT,MAAK;AAAA,cACL,MAAMQ;AAAA,cACN,UAAUA;AAAA,cACV,gBAAgBS,EAAqB;AAAA,cACrC,gBAAgB,EAAE,UAAU,SAAS;AAAA,YAAA;AAAA,UACvC;AAAA,UACA,gBAAAL;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,MAAK;AAAA,cACL,OAAOT,IAAY,SAAS;AAAA,cAC5B,MAAMY;AAAAA,cACN,OAAM;AAAA,cACN,SAASnB;AAAA,cACT,MAAMU;AAAA,cACN,UAAUA;AAAA,cACV,gBAAgBQ,EAAqB;AAAA,cACrC,gBAAgB,EAAE,UAAU,QAAQ;AAAA,YAAA;AAAA,UACtC;AAAA,UACA,gBAAAL;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,MAAK;AAAA,cACL,OAAOT,IAAY,SAAS;AAAA,cAC5B,OAAM;AAAA,cACN,SAASR;AAAA,cACT,gBAAgBmB,EAAqB;AAAA,cACrC,gBAAgB,EAAE,UAAU,QAAQ;AAAA,YAAA;AAAA,UACtC;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,IACA,gBAAAL,EAACE,GAAU,EAAA,SAAS,IAAK,CAAA;AAAA,IACxB,gBAAAJ,EAAAC,GAAA,EAAS,gBAAe,OAAM,aAAY,UACzC,UAAA;AAAA,MAAA,gBAAAC,EAACC,GAAK,EAAA,WAAU,OAAM,QAAO,SAAQ,UAErC,4BAAA;AAAA,MAAO;AAAA,MAEP,gBAAAD,EAACO,KAAW,MAAK,SAAQ,OAAM,UAAS,OAAM,SAAQ,SAASjB,EAAa,CAAA;AAAA,IAAA,GAC9E;AAAA,EACF,EAAA,CAAA;AAEJ,GAEekB,IAAAC,EAAKxB,CAAa;"}
1
+ {"version":3,"file":"signup-options.js","sources":["../../../../../src/features/auth/pla-signup/signup-options/signup-options.tsx"],"sourcesContent":["import type { ISignupOptionsProps } from './signup-options-types';\n\nimport { memo, type FC } from 'react';\nimport { useTheme } from 'styled-components';\n\nimport AppleIcon from '../../../../assets/line-icons/icons/apple-icon-white';\nimport GoogleIcon from '../../../../assets/line-icons/icons/google-icon';\nimport Button from '../../../ui/buttons/button/button';\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Separator from '../../../ui/separator/separator';\nimport Text from '../../../ui/text/text';\nimport { EDeviceType } from '../../../ui/theme/constants';\nimport { PLA_ANALYTICS_EVENTS } from '../pla-analytics-events';\n\nconst SignupOptions: FC<ISignupOptionsProps> = ({\n onEmailSignup,\n onAppleSignup,\n onGoogleSignup,\n loadingProvider,\n onGoToLogin,\n title,\n}) => {\n const { device } = useTheme();\n const isCompact = device <= EDeviceType.TABLET;\n const isLoadingGoogle = loadingProvider === 'google';\n const isLoadingApple = loadingProvider === 'apple';\n\n return (\n <FlexView $alignItems=\"flex-start\">\n <Text $renderAs=\"ah3-bold\" $renderOnMobileAs=\"ah4-bold\" $color=\"WHITE\" $whiteSpace=\"pre\">\n {title}\n </Text>\n <Separator heightX={isCompact ? 1.5 : 2.5} />\n <FlexView\n $flexGapX={1}\n $flex={1}\n $justifyContent=\"center\"\n $alignItems=\"flex-start\"\n $width=\"100%\"\n >\n <Button\n renderAs=\"black-dark\"\n Icon={GoogleIcon}\n width={isCompact ? '100%' : 320}\n label=\"Signup with Google\"\n onClick={onGoogleSignup}\n size=\"small\"\n busy={isLoadingGoogle}\n disabled={isLoadingGoogle}\n analyticsLabel={PLA_ANALYTICS_EVENTS.START_SIGNUP_CTA_CLICKED}\n analyticsProps={{ provider: 'google' }}\n />\n <Button\n renderAs=\"black-dark\"\n size=\"small\"\n width={isCompact ? '100%' : 320}\n Icon={AppleIcon}\n label=\"Signup with Apple\"\n onClick={onAppleSignup}\n busy={isLoadingApple}\n disabled={isLoadingApple}\n analyticsLabel={PLA_ANALYTICS_EVENTS.START_SIGNUP_CTA_CLICKED}\n analyticsProps={{ provider: 'apple' }}\n />\n <Button\n renderAs=\"black-dark\"\n size=\"small\"\n width={isCompact ? '100%' : 320}\n label=\"Continue with Email\"\n onClick={onEmailSignup}\n analyticsLabel={PLA_ANALYTICS_EVENTS.START_SIGNUP_CTA_CLICKED}\n analyticsProps={{ provider: 'email' }}\n />\n </FlexView>\n <Separator heightX={1.5} />\n <FlexView $flexDirection=\"row\" $alignItems=\"center\">\n <Text $renderAs=\"ub3\" $color=\"WHITE\">\n Already have an account?\n </Text>\n &nbsp;\n <TextButton size=\"small\" label=\"Log In\" color=\"WHITE\" onClick={onGoToLogin} />\n </FlexView>\n </FlexView>\n );\n};\n\nexport default memo(SignupOptions);\n"],"names":["SignupOptions","onEmailSignup","onAppleSignup","onGoogleSignup","loadingProvider","onGoToLogin","title","device","useTheme","isCompact","EDeviceType","isLoadingGoogle","isLoadingApple","jsxs","FlexView","jsx","Text","Separator","Button","GoogleIcon","PLA_ANALYTICS_EVENTS","AppleIcon","TextButton","signupOptions","memo"],"mappings":";;;;;;;;;;;;AAeA,MAAMA,IAAyC,CAAC;AAAA,EAC9C,eAAAC;AAAA,EACA,eAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,OAAAC;AACF,MAAM;AACE,QAAA,EAAE,QAAAC,MAAWC,KACbC,IAAYF,KAAUG,EAAY,QAClCC,IAAkBP,MAAoB,UACtCQ,IAAiBR,MAAoB;AAGzC,SAAA,gBAAAS,EAACC,GAAS,EAAA,aAAY,cACpB,UAAA;AAAA,IAAC,gBAAAC,EAAAC,GAAA,EAAK,WAAU,YAAW,mBAAkB,YAAW,QAAO,SAAQ,aAAY,OAChF,UACHV,EAAA,CAAA;AAAA,IACC,gBAAAS,EAAAE,GAAA,EAAU,SAASR,IAAY,MAAM,KAAK;AAAA,IAC3C,gBAAAI;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,WAAW;AAAA,QACX,OAAO;AAAA,QACP,iBAAgB;AAAA,QAChB,aAAY;AAAA,QACZ,QAAO;AAAA,QAEP,UAAA;AAAA,UAAA,gBAAAC;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,MAAMC;AAAA,cACN,OAAOV,IAAY,SAAS;AAAA,cAC5B,OAAM;AAAA,cACN,SAASN;AAAA,cACT,MAAK;AAAA,cACL,MAAMQ;AAAA,cACN,UAAUA;AAAA,cACV,gBAAgBS,EAAqB;AAAA,cACrC,gBAAgB,EAAE,UAAU,SAAS;AAAA,YAAA;AAAA,UACvC;AAAA,UACA,gBAAAL;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,MAAK;AAAA,cACL,OAAOT,IAAY,SAAS;AAAA,cAC5B,MAAMY;AAAAA,cACN,OAAM;AAAA,cACN,SAASnB;AAAA,cACT,MAAMU;AAAA,cACN,UAAUA;AAAA,cACV,gBAAgBQ,EAAqB;AAAA,cACrC,gBAAgB,EAAE,UAAU,QAAQ;AAAA,YAAA;AAAA,UACtC;AAAA,UACA,gBAAAL;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,UAAS;AAAA,cACT,MAAK;AAAA,cACL,OAAOT,IAAY,SAAS;AAAA,cAC5B,OAAM;AAAA,cACN,SAASR;AAAA,cACT,gBAAgBmB,EAAqB;AAAA,cACrC,gBAAgB,EAAE,UAAU,QAAQ;AAAA,YAAA;AAAA,UACtC;AAAA,QAAA;AAAA,MAAA;AAAA,IACF;AAAA,IACA,gBAAAL,EAACE,GAAU,EAAA,SAAS,IAAK,CAAA;AAAA,IACxB,gBAAAJ,EAAAC,GAAA,EAAS,gBAAe,OAAM,aAAY,UACzC,UAAA;AAAA,MAAA,gBAAAC,EAACC,GAAK,EAAA,WAAU,OAAM,QAAO,SAAQ,UAErC,4BAAA;AAAA,MAAO;AAAA,MAEP,gBAAAD,EAACO,KAAW,MAAK,SAAQ,OAAM,UAAS,OAAM,SAAQ,SAASjB,EAAa,CAAA;AAAA,IAAA,GAC9E;AAAA,EACF,EAAA,CAAA;AAEJ,GAEekB,IAAAC,EAAKxB,CAAa;"}
@@ -0,0 +1,234 @@
1
+ const t = [
2
+ {
3
+ id: "star-struck",
4
+ emoji: "🤩",
5
+ name: "Star-Struck",
6
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f929/lottie.json"
7
+ },
8
+ {
9
+ id: "heart-eyes",
10
+ emoji: "😍",
11
+ name: "Heart Eyes",
12
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f60d/lottie.json"
13
+ },
14
+ {
15
+ id: "holding-back-tears",
16
+ emoji: "🥹",
17
+ name: "Holding Back Tears",
18
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f979/lottie.json"
19
+ },
20
+ {
21
+ id: "sunglasses",
22
+ emoji: "😎",
23
+ name: "Sunglasses",
24
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f60e/lottie.json"
25
+ },
26
+ {
27
+ id: "exploding-head",
28
+ emoji: "🤯",
29
+ name: "Exploding Head",
30
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f92f/lottie.json"
31
+ },
32
+ {
33
+ id: "thinking",
34
+ emoji: "🤔",
35
+ name: "Thinking",
36
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f914/lottie.json"
37
+ },
38
+ {
39
+ id: "party",
40
+ emoji: "🥳",
41
+ name: "Party",
42
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f973/lottie.json"
43
+ },
44
+ {
45
+ id: "confetti-ball",
46
+ emoji: "🎊",
47
+ name: "Confetti Ball",
48
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f38a/lottie.json"
49
+ },
50
+ {
51
+ id: "celebration",
52
+ emoji: "🎉",
53
+ name: "Celebration",
54
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f389/lottie.json"
55
+ },
56
+ {
57
+ id: "balloon",
58
+ emoji: "🎈",
59
+ name: "Balloon",
60
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f388/lottie.json"
61
+ },
62
+ {
63
+ id: "cake",
64
+ emoji: "🎂",
65
+ name: "Cake",
66
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f382/lottie.json"
67
+ },
68
+ {
69
+ id: "clapping",
70
+ emoji: "👏",
71
+ name: "Clapping",
72
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f44f/lottie.json"
73
+ },
74
+ {
75
+ id: "thumbs-up",
76
+ emoji: "👍",
77
+ name: "Thumbs Up",
78
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f44d/lottie.json"
79
+ },
80
+ {
81
+ id: "peace",
82
+ emoji: "✌️",
83
+ name: "Peace",
84
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/270c_fe0f/lottie.json"
85
+ },
86
+ {
87
+ id: "ok-hand",
88
+ emoji: "👌",
89
+ name: "OK Hand",
90
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f44c/lottie.json"
91
+ },
92
+ {
93
+ id: "muscle",
94
+ emoji: "💪",
95
+ name: "Muscle",
96
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f4aa/lottie.json"
97
+ },
98
+ {
99
+ id: "rock-on",
100
+ emoji: "🤟",
101
+ name: "Rock On",
102
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f91f/lottie.json"
103
+ },
104
+ {
105
+ id: "heart",
106
+ emoji: "❤️",
107
+ name: "Heart",
108
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/2764_fe0f/lottie.json"
109
+ },
110
+ {
111
+ id: "trophy",
112
+ emoji: "🏆",
113
+ name: "Trophy",
114
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f3c6/lottie.json"
115
+ },
116
+ {
117
+ id: "hundred",
118
+ emoji: "💯",
119
+ name: "Hundred",
120
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f4af/lottie.json"
121
+ },
122
+ {
123
+ id: "gold-medal",
124
+ emoji: "🥇",
125
+ name: "Gold Medal",
126
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f947/lottie.json"
127
+ },
128
+ {
129
+ id: "silver-medal",
130
+ emoji: "🥈",
131
+ name: "Silver Medal",
132
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f948/lottie.json"
133
+ },
134
+ {
135
+ id: "bronze-medal",
136
+ emoji: "🥉",
137
+ name: "Bronze Medal",
138
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f949/lottie.json"
139
+ },
140
+ {
141
+ id: "target",
142
+ emoji: "🎯",
143
+ name: "Target",
144
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f3af/lottie.json"
145
+ },
146
+ {
147
+ id: "glowing-star",
148
+ emoji: "🌟",
149
+ name: "Glowing Star",
150
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f31f/lottie.json"
151
+ },
152
+ {
153
+ id: "lightning",
154
+ emoji: "⚡️",
155
+ name: "Lightning",
156
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/26a1/lottie.json"
157
+ },
158
+ {
159
+ id: "rocket",
160
+ emoji: "🚀",
161
+ name: "Rocket",
162
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f680/lottie.json"
163
+ },
164
+ {
165
+ id: "explosion",
166
+ emoji: "💥",
167
+ name: "Explosion",
168
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f4a5/lottie.json"
169
+ },
170
+ {
171
+ id: "graduation",
172
+ emoji: "🎓",
173
+ name: "Graduation",
174
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f393/lottie.json"
175
+ },
176
+ {
177
+ id: "clock",
178
+ emoji: "⏰",
179
+ name: "Clock",
180
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/23f0/lottie.json"
181
+ },
182
+ {
183
+ id: "bulb",
184
+ emoji: "💡",
185
+ name: "Bulb",
186
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f4a1/lottie.json"
187
+ },
188
+ {
189
+ id: "rainbow",
190
+ emoji: "🌈",
191
+ name: "Rainbow",
192
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f308/lottie.json"
193
+ },
194
+ {
195
+ id: "clown",
196
+ emoji: "🤡",
197
+ name: "Clown",
198
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f921/lottie.json"
199
+ },
200
+ {
201
+ id: "dancer",
202
+ emoji: "💃",
203
+ name: "Dancer",
204
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f483/lottie.json"
205
+ },
206
+ {
207
+ id: "flowers",
208
+ emoji: "💐",
209
+ name: "Flowers",
210
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f490/lottie.json"
211
+ },
212
+ {
213
+ id: "unicorn",
214
+ emoji: "🦄",
215
+ name: "Unicorn",
216
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f984/lottie.json"
217
+ },
218
+ {
219
+ id: "drum",
220
+ emoji: "🥁",
221
+ name: "Drum",
222
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f941/lottie.json"
223
+ },
224
+ {
225
+ id: "diamond",
226
+ emoji: "💎",
227
+ name: "Diamond",
228
+ lottieUrl: "https://fonts.gstatic.com/s/e/notoemoji/latest/1f48e/lottie.json"
229
+ }
230
+ ];
231
+ export {
232
+ t as stickerData
233
+ };
234
+ //# sourceMappingURL=sticker-data.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sticker-data.js","sources":["../../../src/features/stickers/sticker-data.ts"],"sourcesContent":["import type { IStickerData } from './sticker-selector/sticker-selector-types';\n\nexport const stickerData: IStickerData[] = [\n {\n id: 'star-struck',\n emoji: '🤩',\n name: 'Star-Struck',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f929/lottie.json',\n },\n {\n id: 'heart-eyes',\n emoji: '😍',\n name: 'Heart Eyes',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f60d/lottie.json',\n },\n {\n id: 'holding-back-tears',\n emoji: '🥹',\n name: 'Holding Back Tears',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f979/lottie.json',\n },\n {\n id: 'sunglasses',\n emoji: '😎',\n name: 'Sunglasses',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f60e/lottie.json',\n },\n {\n id: 'exploding-head',\n emoji: '🤯',\n name: 'Exploding Head',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f92f/lottie.json',\n },\n {\n id: 'thinking',\n emoji: '🤔',\n name: 'Thinking',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f914/lottie.json',\n },\n {\n id: 'party',\n emoji: '🥳',\n name: 'Party',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f973/lottie.json',\n },\n {\n id: 'confetti-ball',\n emoji: '🎊',\n name: 'Confetti Ball',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f38a/lottie.json',\n },\n {\n id: 'celebration',\n emoji: '🎉',\n name: 'Celebration',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f389/lottie.json',\n },\n {\n id: 'balloon',\n emoji: '🎈',\n name: 'Balloon',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f388/lottie.json',\n },\n {\n id: 'cake',\n emoji: '🎂',\n name: 'Cake',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f382/lottie.json',\n },\n {\n id: 'clapping',\n emoji: '👏',\n name: 'Clapping',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f44f/lottie.json',\n },\n {\n id: 'thumbs-up',\n emoji: '👍',\n name: 'Thumbs Up',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f44d/lottie.json',\n },\n {\n id: 'peace',\n emoji: '✌️',\n name: 'Peace',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/270c_fe0f/lottie.json',\n },\n {\n id: 'ok-hand',\n emoji: '👌',\n name: 'OK Hand',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f44c/lottie.json',\n },\n {\n id: 'muscle',\n emoji: '💪',\n name: 'Muscle',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f4aa/lottie.json',\n },\n {\n id: 'rock-on',\n emoji: '🤟',\n name: 'Rock On',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f91f/lottie.json',\n },\n {\n id: 'heart',\n emoji: '❤️',\n name: 'Heart',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/2764_fe0f/lottie.json',\n },\n {\n id: 'trophy',\n emoji: '🏆',\n name: 'Trophy',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f3c6/lottie.json',\n },\n {\n id: 'hundred',\n emoji: '💯',\n name: 'Hundred',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f4af/lottie.json',\n },\n {\n id: 'gold-medal',\n emoji: '🥇',\n name: 'Gold Medal',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f947/lottie.json',\n },\n {\n id: 'silver-medal',\n emoji: '🥈',\n name: 'Silver Medal',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f948/lottie.json',\n },\n {\n id: 'bronze-medal',\n emoji: '🥉',\n name: 'Bronze Medal',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f949/lottie.json',\n },\n {\n id: 'target',\n emoji: '🎯',\n name: 'Target',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f3af/lottie.json',\n },\n {\n id: 'glowing-star',\n emoji: '🌟',\n name: 'Glowing Star',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f31f/lottie.json',\n },\n {\n id: 'lightning',\n emoji: '⚡️',\n name: 'Lightning',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/26a1/lottie.json',\n },\n {\n id: 'rocket',\n emoji: '🚀',\n name: 'Rocket',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f680/lottie.json',\n },\n {\n id: 'explosion',\n emoji: '💥',\n name: 'Explosion',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f4a5/lottie.json',\n },\n {\n id: 'graduation',\n emoji: '🎓',\n name: 'Graduation',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f393/lottie.json',\n },\n {\n id: 'clock',\n emoji: '⏰',\n name: 'Clock',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/23f0/lottie.json',\n },\n {\n id: 'bulb',\n emoji: '💡',\n name: 'Bulb',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f4a1/lottie.json',\n },\n {\n id: 'rainbow',\n emoji: '🌈',\n name: 'Rainbow',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f308/lottie.json',\n },\n {\n id: 'clown',\n emoji: '🤡',\n name: 'Clown',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f921/lottie.json',\n },\n {\n id: 'dancer',\n emoji: '💃',\n name: 'Dancer',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f483/lottie.json',\n },\n {\n id: 'flowers',\n emoji: '💐',\n name: 'Flowers',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f490/lottie.json',\n },\n {\n id: 'unicorn',\n emoji: '🦄',\n name: 'Unicorn',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f984/lottie.json',\n },\n {\n id: 'drum',\n emoji: '🥁',\n name: 'Drum',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f941/lottie.json',\n },\n {\n id: 'diamond',\n emoji: '💎',\n name: 'Diamond',\n lottieUrl: 'https://fonts.gstatic.com/s/e/notoemoji/latest/1f48e/lottie.json',\n },\n];\n"],"names":["stickerData"],"mappings":"AAEO,MAAMA,IAA8B;AAAA,EACzC;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AAAA,EACA;AAAA,IACE,IAAI;AAAA,IACJ,OAAO;AAAA,IACP,MAAM;AAAA,IACN,WAAW;AAAA,EACb;AACF;"}
@@ -0,0 +1,39 @@
1
+ import { jsx as i } from "react/jsx-runtime";
2
+ import { memo as u, useState as c, useCallback as f } from "react";
3
+ import { stickerData as b } from "../sticker-data.js";
4
+ import h from "./sticker.js";
5
+ import { StickerGridContainer as $, StickerGrid as x } from "./sticker-selector-styles.js";
6
+ const D = ({
7
+ stickers: a = b,
8
+ columns: m = 4,
9
+ gap: s = 8,
10
+ stickerSize: l = 72,
11
+ onStickerClick: r
12
+ }) => {
13
+ const [d, o] = c(!1), t = d, p = f(
14
+ (e) => {
15
+ if (t) return;
16
+ r == null || r(e), o(!0);
17
+ const n = setTimeout(() => {
18
+ o(!1);
19
+ }, 5e3);
20
+ return () => clearTimeout(n);
21
+ },
22
+ [r, t]
23
+ );
24
+ return /* @__PURE__ */ i($, { $width: "350px", $height: "400px", $disabled: t, children: /* @__PURE__ */ i(x, { $columns: m, $gap: s, children: a.map((e) => /* @__PURE__ */ i(
25
+ h,
26
+ {
27
+ emoji: e.emoji,
28
+ lottieUrl: e.lottieUrl,
29
+ size: l,
30
+ onClick: () => p(e),
31
+ disabled: t
32
+ },
33
+ e.id
34
+ )) }) });
35
+ }, y = u(D);
36
+ export {
37
+ y as default
38
+ };
39
+ //# sourceMappingURL=sticker-selector-grid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sticker-selector-grid.js","sources":["../../../../src/features/stickers/sticker-selector/sticker-selector-grid.tsx"],"sourcesContent":["import type { IStickerSelectorGridProps } from './sticker-selector-types';\n\nimport React, { memo, useCallback, useState } from 'react';\n\nimport { stickerData } from '../sticker-data';\nimport Sticker from './sticker';\nimport * as S from './sticker-selector-styles';\n\nconst StickerSelectorGrid: React.FC<IStickerSelectorGridProps> = ({\n stickers = stickerData,\n columns = 4,\n gap = 8,\n stickerSize = 72,\n onStickerClick,\n}) => {\n const [isTemporarilyDisabled, setIsTemporarilyDisabled] = useState(false);\n\n const gridDisabled = isTemporarilyDisabled;\n\n const handleStickerClick = useCallback(\n (sticker: (typeof stickers)[0]) => {\n if (gridDisabled) return;\n\n onStickerClick?.(sticker);\n setIsTemporarilyDisabled(true);\n\n const timeout = setTimeout(() => {\n setIsTemporarilyDisabled(false);\n }, 5000);\n\n return () => clearTimeout(timeout);\n },\n [onStickerClick, gridDisabled],\n );\n\n return (\n <S.StickerGridContainer $width=\"350px\" $height=\"400px\" $disabled={gridDisabled}>\n <S.StickerGrid $columns={columns} $gap={gap}>\n {stickers.map(sticker => (\n <Sticker\n key={sticker.id}\n emoji={sticker.emoji}\n lottieUrl={sticker.lottieUrl}\n size={stickerSize}\n onClick={() => handleStickerClick(sticker)}\n disabled={gridDisabled}\n />\n ))}\n </S.StickerGrid>\n </S.StickerGridContainer>\n );\n};\n\nexport default memo(StickerSelectorGrid);\n"],"names":["StickerSelectorGrid","stickers","stickerData","columns","gap","stickerSize","onStickerClick","isTemporarilyDisabled","setIsTemporarilyDisabled","useState","gridDisabled","handleStickerClick","useCallback","sticker","timeout","jsx","S.StickerGridContainer","S.StickerGrid","Sticker","StickerSelectorGrid$1","memo"],"mappings":";;;;;AAQA,MAAMA,IAA2D,CAAC;AAAA,EAChE,UAAAC,IAAWC;AAAA,EACX,SAAAC,IAAU;AAAA,EACV,KAAAC,IAAM;AAAA,EACN,aAAAC,IAAc;AAAA,EACd,gBAAAC;AACF,MAAM;AACJ,QAAM,CAACC,GAAuBC,CAAwB,IAAIC,EAAS,EAAK,GAElEC,IAAeH,GAEfI,IAAqBC;AAAA,IACzB,CAACC,MAAkC;AACjC,UAAIH,EAAc;AAElB,MAAAJ,KAAA,QAAAA,EAAiBO,IACjBL,EAAyB,EAAI;AAEvB,YAAAM,IAAU,WAAW,MAAM;AAC/B,QAAAN,EAAyB,EAAK;AAAA,SAC7B,GAAI;AAEA,aAAA,MAAM,aAAaM,CAAO;AAAA,IACnC;AAAA,IACA,CAACR,GAAgBI,CAAY;AAAA,EAAA;AAI7B,SAAA,gBAAAK,EAACC,GAAA,EAAuB,QAAO,SAAQ,SAAQ,SAAQ,WAAWN,GAChE,4BAACO,GAAA,EAAc,UAAUd,GAAS,MAAMC,GACrC,UAAAH,EAAS,IAAI,CACZY,MAAA,gBAAAE;AAAA,IAACG;AAAA,IAAA;AAAA,MAEC,OAAOL,EAAQ;AAAA,MACf,WAAWA,EAAQ;AAAA,MACnB,MAAMR;AAAA,MACN,SAAS,MAAMM,EAAmBE,CAAO;AAAA,MACzC,UAAUH;AAAA,IAAA;AAAA,IALLG,EAAQ;AAAA,EAAA,CAOhB,GACH,EACF,CAAA;AAEJ,GAEeM,IAAAC,EAAKpB,CAAmB;"}
@@ -1,5 +1,5 @@
1
- import r from "styled-components";
2
- const e = r.div`
1
+ import e from "styled-components";
2
+ const o = e.div`
3
3
  position: relative;
4
4
  width: ${({ $size: t }) => typeof t == "number" ? `${t}px` : t};
5
5
  height: ${({ $size: t }) => typeof t == "number" ? `${t}px` : t};
@@ -12,6 +12,7 @@ const e = r.div`
12
12
  transition: all 0.2s ease;
13
13
  background-color: transparent;
14
14
  opacity: ${({ $disabled: t }) => t ? 0.5 : 1};
15
+ pointer-events: ${({ $disabled: t }) => t ? "none" : "auto"};
15
16
 
16
17
  &:hover {
17
18
  transform: ${({ $disabled: t }) => t ? "none" : "scale(1.1)"};
@@ -21,30 +22,31 @@ const e = r.div`
21
22
  &:active {
22
23
  transform: ${({ $disabled: t }) => t ? "none" : "scale(0.95)"};
23
24
  }
24
- `, n = r.div`
25
+ `, r = e.div`
25
26
  font-size: ${({ $size: t }) => typeof t == "number" ? `${t * 0.7}px` : "70%"};
26
27
  line-height: 1;
27
- display: flex;
28
+ display: ${({ $visible: t }) => t ? "flex" : "none"};
28
29
  align-items: center;
29
30
  justify-content: center;
30
31
  width: 100%;
31
32
  height: 100%;
32
33
  transition: opacity 0.2s ease;
33
- `, a = r.div`
34
+ `, i = e.div`
34
35
  position: absolute;
35
36
  top: 50%;
36
37
  left: 50%;
37
38
  width: ${({ $size: t }) => typeof t == "number" ? `${t * 0.7}px` : t};
38
39
  height: ${({ $size: t }) => typeof t == "number" ? `${t * 0.7}px` : t};
39
- opacity: 0;
40
- transition: opacity 0.2s ease;
41
40
  transform: translate(-50%, -50%);
42
41
  pointer-events: none;
42
+ display: 'flex';
43
+ opacity: ${({ $visible: t }) => t ? 1 : 0};
44
+ transition: opacity 0.2s ease;
43
45
 
44
- ${e}:hover & {
46
+ ${o}:hover & {
45
47
  opacity: 1;
46
48
  }
47
- `, i = r.div`
49
+ `, a = e.div`
48
50
  display: grid;
49
51
  grid-template-columns: repeat(${({ $columns: t }) => t}, 1fr);
50
52
  gap: ${({ $gap: t }) => t}px;
@@ -53,34 +55,24 @@ const e = r.div`
53
55
  border-radius: 12px;
54
56
  max-height: 400px;
55
57
  overflow-y: auto;
58
+ scrollbar-gutter: stable;
56
59
 
60
+ scrollbar-width: none;
61
+ -ms-overflow-style: none;
57
62
  &::-webkit-scrollbar {
58
- width: 8px;
59
- }
60
-
61
- &::-webkit-scrollbar-track {
62
- background: rgba(255, 255, 255, 0.1);
63
- border-radius: 4px;
64
- }
65
-
66
- &::-webkit-scrollbar-thumb {
67
- background: rgba(255, 255, 255, 0.3);
68
- border-radius: 4px;
69
- }
70
-
71
- &::-webkit-scrollbar-thumb:hover {
72
- background: rgba(255, 255, 255, 0.5);
63
+ display: none;
73
64
  }
74
- `, c = r.div`
65
+ `, p = e.div`
75
66
  width: 100%;
76
67
  max-width: ${({ $width: t }) => t};
77
68
  max-height: ${({ $height: t }) => t};
69
+ cursor: ${({ $disabled: t }) => t ? "default" : "pointer"};
78
70
  `;
79
71
  export {
80
- a as LottieContainer,
81
- n as StaticEmoji,
82
- e as StickerContainer,
83
- i as StickerGrid,
84
- c as StickerGridContainer
72
+ i as LottieContainer,
73
+ r as StaticEmoji,
74
+ o as StickerContainer,
75
+ a as StickerGrid,
76
+ p as StickerGridContainer
85
77
  };
86
- //# sourceMappingURL=sticker-grid-styles.js.map
78
+ //# sourceMappingURL=sticker-selector-styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sticker-selector-styles.js","sources":["../../../../src/features/stickers/sticker-selector/sticker-selector-styles.ts"],"sourcesContent":["import styled from 'styled-components';\n\nexport const StickerContainer = styled.div<{\n $size: number | string;\n $disabled?: boolean;\n}>`\n position: relative;\n width: ${({ $size }) => (typeof $size === 'number' ? `${$size}px` : $size)};\n height: ${({ $size }) => (typeof $size === 'number' ? `${$size}px` : $size)};\n cursor: ${({ $disabled }) => ($disabled ? 'none' : 'pointer')};\n border-radius: 8px;\n overflow: hidden;\n display: flex;\n align-items: center;\n justify-content: center;\n transition: all 0.2s ease;\n background-color: transparent;\n opacity: ${({ $disabled }) => ($disabled ? 0.5 : 1)};\n pointer-events: ${({ $disabled }) => ($disabled ? 'none' : 'auto')};\n\n &:hover {\n transform: ${({ $disabled }) => ($disabled ? 'none' : 'scale(1.1)')};\n background-color: rgba(255, 255, 255, 0.1);\n }\n\n &:active {\n transform: ${({ $disabled }) => ($disabled ? 'none' : 'scale(0.95)')};\n }\n`;\n\nexport const StaticEmoji = styled.div<{ $size: number | string; $visible: boolean }>`\n font-size: ${({ $size }) => {\n if (typeof $size === 'number') {\n return `${$size * 0.7}px`;\n }\n\n return '70%';\n }};\n line-height: 1;\n display: ${({ $visible }) => ($visible ? 'flex' : 'none')};\n align-items: center;\n justify-content: center;\n width: 100%;\n height: 100%;\n transition: opacity 0.2s ease;\n`;\n\nexport const LottieContainer = styled.div<{\n $size: number | string;\n $visible?: boolean;\n}>`\n position: absolute;\n top: 50%;\n left: 50%;\n width: ${({ $size }) => (typeof $size === 'number' ? `${$size * 0.7}px` : $size)};\n height: ${({ $size }) => (typeof $size === 'number' ? `${$size * 0.7}px` : $size)};\n transform: translate(-50%, -50%);\n pointer-events: none;\n display: 'flex';\n opacity: ${({ $visible }) => ($visible ? 1 : 0)};\n transition: opacity 0.2s ease;\n\n ${StickerContainer}:hover & {\n opacity: 1;\n }\n`;\n\nexport const StickerGrid = styled.div<{\n $columns: number;\n $gap: number;\n}>`\n display: grid;\n grid-template-columns: repeat(${({ $columns }) => $columns}, 1fr);\n gap: ${({ $gap }) => $gap}px;\n padding: 16px;\n background-color: #2a2a2a;\n border-radius: 12px;\n max-height: 400px;\n overflow-y: auto;\n scrollbar-gutter: stable;\n\n scrollbar-width: none;\n -ms-overflow-style: none;\n &::-webkit-scrollbar {\n display: none;\n }\n`;\n\nexport const StickerGridContainer = styled.div<{\n $width: string;\n $height: string;\n $disabled?: boolean;\n}>`\n width: 100%;\n max-width: ${({ $width }) => $width};\n max-height: ${({ $height }) => $height};\n cursor: ${({ $disabled }) => ($disabled ? 'default' : 'pointer')};\n`;\n"],"names":["StickerContainer","styled","$size","$disabled","StaticEmoji","$visible","LottieContainer","StickerGrid","$columns","$gap","StickerGridContainer","$width","$height"],"mappings":";AAEO,MAAMA,IAAmBC,EAAO;AAAA;AAAA,WAK5B,CAAC,EAAE,OAAAC,EAAa,MAAA,OAAOA,KAAU,WAAW,GAAGA,CAAK,OAAOA,CAAM;AAAA,YAChE,CAAC,EAAE,OAAAA,EAAa,MAAA,OAAOA,KAAU,WAAW,GAAGA,CAAK,OAAOA,CAAM;AAAA,YACjE,CAAC,EAAE,WAAAC,EAAA,MAAiBA,IAAY,SAAS,SAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,aAQlD,CAAC,EAAE,WAAAA,EAAA,MAAiBA,IAAY,MAAM,CAAE;AAAA,oBACjC,CAAC,EAAE,WAAAA,EAAA,MAAiBA,IAAY,SAAS,MAAO;AAAA;AAAA;AAAA,iBAGnD,CAAC,EAAE,WAAAA,EAAA,MAAiBA,IAAY,SAAS,YAAa;AAAA;AAAA;AAAA;AAAA;AAAA,iBAKtD,CAAC,EAAE,WAAAA,EAAA,MAAiBA,IAAY,SAAS,aAAc;AAAA;AAAA,GAI3DC,IAAcH,EAAO;AAAA,eACnB,CAAC,EAAE,OAAAC,QACV,OAAOA,KAAU,WACZ,GAAGA,IAAQ,GAAG,OAGhB,KACR;AAAA;AAAA,aAEU,CAAC,EAAE,UAAAG,EAAA,MAAgBA,IAAW,SAAS,MAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAQ9CC,IAAkBL,EAAO;AAAA;AAAA;AAAA;AAAA,WAO3B,CAAC,EAAE,OAAAC,QAAa,OAAOA,KAAU,WAAW,GAAGA,IAAQ,GAAG,OAAOA,CAAM;AAAA,YACtE,CAAC,EAAE,OAAAA,QAAa,OAAOA,KAAU,WAAW,GAAGA,IAAQ,GAAG,OAAOA,CAAM;AAAA;AAAA;AAAA;AAAA,aAItE,CAAC,EAAE,UAAAG,EAAA,MAAgBA,IAAW,IAAI,CAAE;AAAA;AAAA;AAAA,IAG7CL,CAAgB;AAAA;AAAA;AAAA,GAKPO,IAAcN,EAAO;AAAA;AAAA,kCAKA,CAAC,EAAE,UAAAO,EAAS,MAAMA,CAAQ;AAAA,SACnD,CAAC,EAAE,MAAAC,EAAK,MAAMA,CAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAedC,IAAuBT,EAAO;AAAA;AAAA,eAM5B,CAAC,EAAE,QAAAU,EAAO,MAAMA,CAAM;AAAA,gBACrB,CAAC,EAAE,SAAAC,EAAQ,MAAMA,CAAO;AAAA,YAC5B,CAAC,EAAE,WAAAT,EAAA,MAAiBA,IAAY,YAAY,SAAU;AAAA;"}
@@ -0,0 +1,88 @@
1
+ import { jsx as s } from "react/jsx-runtime";
2
+ import { memo as v, useCallback as D, useMemo as G } from "react";
3
+ import M from "../../communication/hooks/use-inclass-message-broker/use-inclass-message-broker.js";
4
+ import T from "../../ui/arrow-tooltip/arrow-tooltip.js";
5
+ import { stickerData as V } from "../sticker-data.js";
6
+ import Y from "./sticker-selector-grid.js";
7
+ const j = ({
8
+ triggerNode: n,
9
+ studentClassroomId: d,
10
+ gridConfig: l,
11
+ tooltipConfig: m,
12
+ visible: c
13
+ }) => {
14
+ const { columns: t = 4, gap: r = 8, stickerSize: i = 48 } = l, {
15
+ isAnimated: p,
16
+ arrowColor: C,
17
+ arrowSize: f,
18
+ arrowXCoOrdinates: k,
19
+ arrowYCoOrdinates: S,
20
+ backgroundColor: w,
21
+ borderColor: u,
22
+ position: g = "bottom",
23
+ renderAs: b = "primary",
24
+ textVariant: h,
25
+ tooltipOffset: A,
26
+ tooltipXCoOrdinates: O,
27
+ tooltipYCoOrdinates: x,
28
+ width: B,
29
+ widthX: I,
30
+ zIndex: y,
31
+ parentWidth: z,
32
+ isBlocking: E = !1
33
+ } = m, { publish: o } = M({ studentClassroomId: d }), a = D(
34
+ (e) => o == null ? void 0 : o({
35
+ eventName: "TEACHER_BADGE",
36
+ eventPayload: {
37
+ data: {
38
+ selectedBadge: { id: e.id, name: e.name },
39
+ badgeId: e.id
40
+ }
41
+ }
42
+ }),
43
+ [o]
44
+ ), X = G(
45
+ () => /* @__PURE__ */ s(
46
+ Y,
47
+ {
48
+ stickers: V,
49
+ columns: t,
50
+ gap: r,
51
+ stickerSize: i,
52
+ onStickerClick: a
53
+ }
54
+ ),
55
+ [t, r, a, i]
56
+ );
57
+ return /* @__PURE__ */ s(
58
+ T,
59
+ {
60
+ children: n,
61
+ alwaysVisible: !0,
62
+ hidden: !c,
63
+ tooltipItem: X,
64
+ renderAs: b,
65
+ position: g,
66
+ isBlocking: E,
67
+ isAnimated: p,
68
+ zIndex: y,
69
+ width: B,
70
+ widthX: I,
71
+ parentWidth: z,
72
+ backgroundColor: w,
73
+ borderColor: u,
74
+ textVariant: h,
75
+ tooltipOffset: A,
76
+ arrowColor: C,
77
+ arrowSize: f,
78
+ arrowXCoOrdinates: k,
79
+ arrowYCoOrdinates: S,
80
+ tooltipXCoOrdinates: O,
81
+ tooltipYCoOrdinates: x
82
+ }
83
+ );
84
+ }, q = v(j);
85
+ export {
86
+ q as default
87
+ };
88
+ //# sourceMappingURL=sticker-selector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sticker-selector.js","sources":["../../../../src/features/stickers/sticker-selector/sticker-selector.tsx"],"sourcesContent":["import type { IStickerSelectorProps, IStickerData } from './sticker-selector-types';\n\nimport React, { memo, useCallback, useMemo } from 'react';\n\nimport useInClassMessageBroker from '../../communication/hooks/use-inclass-message-broker/use-inclass-message-broker';\nimport ArrowTooltip from '../../ui/arrow-tooltip/arrow-tooltip';\nimport { stickerData } from '../sticker-data';\nimport StickerSelectorGrid from './sticker-selector-grid';\n\nconst StickerSelector: React.FC<IStickerSelectorProps> = ({\n triggerNode,\n studentClassroomId,\n gridConfig,\n tooltipConfig,\n visible,\n}) => {\n const { columns = 4, gap = 8, stickerSize = 48 } = gridConfig;\n const {\n isAnimated,\n arrowColor,\n arrowSize,\n arrowXCoOrdinates,\n arrowYCoOrdinates,\n backgroundColor,\n borderColor,\n position = 'bottom',\n renderAs = 'primary',\n textVariant,\n tooltipOffset,\n tooltipXCoOrdinates,\n tooltipYCoOrdinates,\n width,\n widthX,\n zIndex,\n parentWidth,\n isBlocking = false,\n } = tooltipConfig;\n const { publish } = useInClassMessageBroker({ studentClassroomId });\n\n const handleSend = useCallback(\n (sticker: IStickerData) =>\n publish?.({\n eventName: 'TEACHER_BADGE',\n eventPayload: {\n data: {\n selectedBadge: { id: sticker.id, name: sticker.name },\n badgeId: sticker.id,\n },\n },\n }),\n [publish],\n );\n\n const tooltipItem = useMemo(\n () => (\n <StickerSelectorGrid\n stickers={stickerData}\n columns={columns}\n gap={gap}\n stickerSize={stickerSize}\n onStickerClick={handleSend}\n />\n ),\n [columns, gap, handleSend, stickerSize],\n );\n\n return (\n <ArrowTooltip\n children={triggerNode}\n alwaysVisible\n hidden={!visible}\n tooltipItem={tooltipItem}\n renderAs={renderAs}\n position={position}\n isBlocking={isBlocking}\n isAnimated={isAnimated}\n zIndex={zIndex}\n width={width}\n widthX={widthX}\n parentWidth={parentWidth}\n backgroundColor={backgroundColor}\n borderColor={borderColor}\n textVariant={textVariant}\n tooltipOffset={tooltipOffset}\n arrowColor={arrowColor}\n arrowSize={arrowSize}\n arrowXCoOrdinates={arrowXCoOrdinates}\n arrowYCoOrdinates={arrowYCoOrdinates}\n tooltipXCoOrdinates={tooltipXCoOrdinates}\n tooltipYCoOrdinates={tooltipYCoOrdinates}\n />\n );\n};\n\nexport default memo(StickerSelector);\n"],"names":["StickerSelector","triggerNode","studentClassroomId","gridConfig","tooltipConfig","visible","columns","gap","stickerSize","isAnimated","arrowColor","arrowSize","arrowXCoOrdinates","arrowYCoOrdinates","backgroundColor","borderColor","position","renderAs","textVariant","tooltipOffset","tooltipXCoOrdinates","tooltipYCoOrdinates","width","widthX","zIndex","parentWidth","isBlocking","publish","useInClassMessageBroker","handleSend","useCallback","sticker","tooltipItem","useMemo","jsx","StickerSelectorGrid","stickerData","ArrowTooltip","stickerSelector","memo"],"mappings":";;;;;;AASA,MAAMA,IAAmD,CAAC;AAAA,EACxD,aAAAC;AAAA,EACA,oBAAAC;AAAA,EACA,YAAAC;AAAA,EACA,eAAAC;AAAA,EACA,SAAAC;AACF,MAAM;AACJ,QAAM,EAAE,SAAAC,IAAU,GAAG,KAAAC,IAAM,GAAG,aAAAC,IAAc,GAAO,IAAAL,GAC7C;AAAA,IACJ,YAAAM;AAAA,IACA,YAAAC;AAAA,IACA,WAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,mBAAAC;AAAA,IACA,iBAAAC;AAAA,IACA,aAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,UAAAC,IAAW;AAAA,IACX,aAAAC;AAAA,IACA,eAAAC;AAAA,IACA,qBAAAC;AAAA,IACA,qBAAAC;AAAA,IACA,OAAAC;AAAA,IACA,QAAAC;AAAA,IACA,QAAAC;AAAA,IACA,aAAAC;AAAA,IACA,YAAAC,IAAa;AAAA,EACX,IAAAtB,GACE,EAAE,SAAAuB,EAAQ,IAAIC,EAAwB,EAAE,oBAAA1B,EAAoB,CAAA,GAE5D2B,IAAaC;AAAA,IACjB,CAACC,MACCJ,KAAA,gBAAAA,EAAU;AAAA,MACR,WAAW;AAAA,MACX,cAAc;AAAA,QACZ,MAAM;AAAA,UACJ,eAAe,EAAE,IAAII,EAAQ,IAAI,MAAMA,EAAQ,KAAK;AAAA,UACpD,SAASA,EAAQ;AAAA,QACnB;AAAA,MACF;AAAA,IAAA;AAAA,IAEJ,CAACJ,CAAO;AAAA,EAAA,GAGJK,IAAcC;AAAA,IAClB,MACE,gBAAAC;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,UAAUC;AAAA,QACV,SAAA9B;AAAA,QACA,KAAAC;AAAA,QACA,aAAAC;AAAA,QACA,gBAAgBqB;AAAA,MAAA;AAAA,IAClB;AAAA,IAEF,CAACvB,GAASC,GAAKsB,GAAYrB,CAAW;AAAA,EAAA;AAItC,SAAA,gBAAA0B;AAAA,IAACG;AAAA,IAAA;AAAA,MACC,UAAUpC;AAAA,MACV,eAAa;AAAA,MACb,QAAQ,CAACI;AAAA,MACT,aAAA2B;AAAA,MACA,UAAAf;AAAA,MACA,UAAAD;AAAA,MACA,YAAAU;AAAA,MACA,YAAAjB;AAAA,MACA,QAAAe;AAAA,MACA,OAAAF;AAAA,MACA,QAAAC;AAAA,MACA,aAAAE;AAAA,MACA,iBAAAX;AAAA,MACA,aAAAC;AAAA,MACA,aAAAG;AAAA,MACA,eAAAC;AAAA,MACA,YAAAT;AAAA,MACA,WAAAC;AAAA,MACA,mBAAAC;AAAA,MACA,mBAAAC;AAAA,MACA,qBAAAO;AAAA,MACA,qBAAAC;AAAA,IAAA;AAAA,EAAA;AAGN,GAEeiB,IAAAC,EAAKvC,CAAe;"}