fansunited-widgets-cdn 0.0.84 → 0.0.86-RC1

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 (75) hide show
  1. package/chunks/Alert-CuOsmojH.js +149 -0
  2. package/chunks/AspectRatio-D3Sgxj7p.js +125 -0
  3. package/chunks/Avatar-BTsEKfhc.js +186 -0
  4. package/chunks/Button-BV7YIFkS.js +858 -0
  5. package/chunks/Card-DRIT0wtY.js +129 -0
  6. package/chunks/CardContent-CD-WZh1l.js +60 -0
  7. package/chunks/ChevronRight-BrCKlr3T.js +11 -0
  8. package/chunks/Chip-6HLNTHMI.js +281 -0
  9. package/chunks/ClassicQuizWrapper-t04e9_6c.js +4883 -0
  10. package/chunks/CollectLeadForm-DtmR2Vuf-B_3JkHJC.js +1560 -0
  11. package/chunks/CollectLeadWrapper-CVAVswua.js +1294 -0
  12. package/chunks/DialogActions-C5kAgHal.js +45 -0
  13. package/chunks/DialogContent-MIXff4nd.js +60 -0
  14. package/chunks/EitherOrById-CAo8gPjm.js +1496 -0
  15. package/chunks/EitherOrPreviewWrapper-DFi2bviS.js +47 -0
  16. package/chunks/Error-DhQL89pn-BwTV1meb.js +418 -0
  17. package/chunks/EventGameWrapper-BxyLL3eA.js +7633 -0
  18. package/chunks/Grid-Dpv_ZL23.js +279 -0
  19. package/chunks/IconButton-Lt9Xks7c.js +207 -0
  20. package/chunks/Link-DLuj1USf.js +228 -0
  21. package/chunks/List-DLPlZGTP.js +397 -0
  22. package/chunks/ListItemDecorator-CE2eQLip.js +1882 -0
  23. package/chunks/MatchPredictionContainer-Ct6gXvLw.js +751 -0
  24. package/chunks/MatchQuizWrapper-Fu6RfWVn.js +11046 -0
  25. package/chunks/ModalDialog-Ci3hulZA.js +619 -0
  26. package/chunks/NotFoundSkeleton-BYJTzYJR-Be3R34nS.js +2764 -0
  27. package/chunks/OverlayLeadAfterCollection-DnqztPJ5-CpELr0AC.js +896 -0
  28. package/chunks/OverlayScoreStateSkeleton-C9FUhcnd-DMFELrvA.js +146 -0
  29. package/chunks/PersonalityQuizWrapper-MpUK4n3Y.js +34374 -0
  30. package/chunks/PlayerOfTheMatch-D4vuR7pz.js +1406 -0
  31. package/chunks/PollWrapper-CzKj8xxE.js +4198 -0
  32. package/chunks/Portal-BWqqFvVm-TuHZWjxn.js +12717 -0
  33. package/chunks/Portal-DA1mxzSo.js +41 -0
  34. package/chunks/PreviewQuizById-WWS_LyJR.js +4864 -0
  35. package/chunks/Select-p_cHpLhi.js +3418 -0
  36. package/chunks/Sheet-BaCzogZK.js +167 -0
  37. package/chunks/Snackbar-DHxnbCA3.js +358 -0
  38. package/chunks/Stack-Dgf2LXN0.js +117 -0
  39. package/chunks/Tabs-CSu_cWNi.js +784 -0
  40. package/chunks/TeamNextMatchPrediction-C7HilNqW.js +6 -0
  41. package/chunks/Tutorial-DFNZxmAx.js +427 -0
  42. package/chunks/createLucideIcon-B6NxpYkb.js +79 -0
  43. package/chunks/createSvgIcon-7h7XC877.js +119 -0
  44. package/chunks/createSvgIcon-DVA0KIUd.js +2490 -0
  45. package/chunks/dataAttributeParser-CF9vxaVN.js +28 -0
  46. package/chunks/default-quiz-bg-CTzaADn7.js +4 -0
  47. package/chunks/getReactElementRef-BD-S8A24.js +25 -0
  48. package/chunks/index-24AwmTVJ.js +85 -0
  49. package/chunks/index-3vJS8JzK.js +63 -0
  50. package/chunks/index-BSD7mvEU.js +57 -0
  51. package/chunks/index-BU6iona7.js +57 -0
  52. package/chunks/index-BqCHiyI6.js +59 -0
  53. package/chunks/index-C5qRf4TV.js +20 -0
  54. package/chunks/index-C9MpfjqV.js +35 -0
  55. package/chunks/index-CMmQs5A5.js +56 -0
  56. package/chunks/index-CicEY2Jv.js +5 -0
  57. package/chunks/index-DNeawo0R.js +17 -0
  58. package/chunks/index-DePIySlY.js +29 -0
  59. package/chunks/index-DoRYU_1L.js +41 -0
  60. package/chunks/index-DvgG9XJj.js +20 -0
  61. package/chunks/index-QpZE-92Y.js +33 -0
  62. package/chunks/index-rgFj976B.js +17 -0
  63. package/chunks/index-tzsdMoo-.js +16 -0
  64. package/chunks/index.es-CHqz6mjo.js +6162 -0
  65. package/chunks/init-BEkECL0v.js +32 -0
  66. package/chunks/main-XP7dqk6g.js +39843 -0
  67. package/chunks/resolveProps-BfYZubfk.js +37 -0
  68. package/chunks/users-D_xgC4iQ.js +16 -0
  69. package/chunks/variantColorInheritance-DI3wUohX.js +28 -0
  70. package/fu-widgets-loader.es.js +76 -0
  71. package/fu-widgets-loader.js +1 -0
  72. package/fu-widgets.es.js +4 -0
  73. package/fu-widgets.iife.js +621 -682
  74. package/manifest.json +84 -0
  75. package/package.json +9 -2
@@ -0,0 +1,4198 @@
1
+ import { j as n, r as M, N as _o, O as on, B as l, m as Ko, a as nn, h as An, e as ln, n as en, i as tn, k as an, f as rn, g as sn, p as pn, q as cn } from "./main-XP7dqk6g.js";
2
+ import { b as gn, p as dn, C as I, h as G, o as J, Y as X, y as eo, K as L, J as Z, Z as Y, e as j, r as Ho, u as Io, d as $o, a as bo, G as mo, X as fn, n as go, t as Do, q as xn, m as Un, i as Kn, j as qo, f as co, $ as Po, g as mn, l as Pn, R as yn, N as un } from "./Portal-BWqqFvVm-TuHZWjxn.js";
3
+ import { H as Cn, V as Fn, L as Sn, p as Bn, j as jn, W as Tn, z as Rn, B as hn, l as Go, P as Zo, v as Mo, D as kn } from "./NotFoundSkeleton-BYJTzYJR-Be3R34nS.js";
4
+ import { p as zn } from "./CollectLeadForm-DtmR2Vuf-B_3JkHJC.js";
5
+ import { w as Hn } from "./OverlayScoreStateSkeleton-C9FUhcnd-DMFELrvA.js";
6
+ import { y as bn, u as Vn, f as qn, C as Qn, h as In, b as Dn } from "./OverlayLeadAfterCollection-DnqztPJ5-CpELr0AC.js";
7
+ import { B as W, T as K } from "./Button-BV7YIFkS.js";
8
+ import { A as Qo } from "./AspectRatio-D3Sgxj7p.js";
9
+ import { A as vn } from "./Alert-CuOsmojH.js";
10
+ import { S as On } from "./Stack-Dgf2LXN0.js";
11
+ import { w as ho } from "./index.es-CHqz6mjo.js";
12
+ const Mn = (o) => {
13
+ var A, i, e;
14
+ return {
15
+ // Mobile headline with image background
16
+ mobileHeadlineWithImage: {
17
+ display: o.isMobile ? "flex" : "none",
18
+ flexDirection: "column",
19
+ justifyContent: "space-between",
20
+ gap: "10px",
21
+ backgroundImage: `url(${o.finalImage})`,
22
+ backgroundSize: "cover",
23
+ backgroundPosition: "center",
24
+ borderTopLeftRadius: "5px",
25
+ borderTopRightRadius: "5px",
26
+ position: "relative",
27
+ minHeight: "210px",
28
+ overflow: "hidden",
29
+ height: "auto",
30
+ "&::before": {
31
+ content: '""',
32
+ position: "absolute",
33
+ width: "100%",
34
+ height: "100%",
35
+ background: o.imageBackgroundGradient,
36
+ borderTopLeftRadius: "5px",
37
+ borderTopRightRadius: "5px"
38
+ }
39
+ },
40
+ // Mobile headline content
41
+ mobileHeadlineContent: {
42
+ zIndex: 1,
43
+ height: "100%",
44
+ p: o.spacingScale.xl,
45
+ display: "flex",
46
+ flexDirection: "column",
47
+ justifyContent: "space-between"
48
+ },
49
+ // Mobile headline without image
50
+ mobileHeadlineWithoutImage: {
51
+ display: o.isMobile ? "flex" : "none",
52
+ flexDirection: "column",
53
+ justifyContent: "space-between",
54
+ p: o.isMobile ? o.spacingScale.sm : o.spacingScale.md
55
+ },
56
+ // Headline typography (mobile with image)
57
+ headlineTypographyMobileImage: {
58
+ fontWeight: 500,
59
+ lineHeight: "166%",
60
+ letterSpacing: "1px",
61
+ fontSize: "0.75em",
62
+ color: ((A = o.brandingColors) == null ? void 0 : A.secondaryColor) || o.darkTextColor,
63
+ opacity: "70%",
64
+ textTransform: "uppercase",
65
+ fontFamily: o.fontFamilySecondary,
66
+ textAlign: "center"
67
+ },
68
+ // Headline typography (mobile without image & desktop)
69
+ headlineTypography: {
70
+ fontWeight: 500,
71
+ lineHeight: "166%",
72
+ letterSpacing: "1px",
73
+ textTransform: "uppercase",
74
+ fontSize: "0.75em",
75
+ color: o.secondaryColor,
76
+ opacity: o.opacity,
77
+ fontFamily: o.fontFamilySecondary,
78
+ textAlign: o.isMobile ? "center" : "left"
79
+ },
80
+ // Headline typography (desktop centered)
81
+ headlineTypographyDesktop: {
82
+ fontWeight: 500,
83
+ lineHeight: "166%",
84
+ letterSpacing: "1px",
85
+ textTransform: "uppercase",
86
+ fontSize: "0.75em",
87
+ color: o.secondaryColor,
88
+ opacity: o.opacity,
89
+ fontFamily: o.fontFamilySecondary
90
+ },
91
+ // Content container
92
+ contentContainer: {
93
+ display: "flex",
94
+ flexDirection: "column",
95
+ gap: o.spacingScale["3xs"]
96
+ },
97
+ // Title typography (mobile with image)
98
+ titleTypographyMobileImage: {
99
+ fontWeight: 700,
100
+ lineHeight: "133%",
101
+ fontSize: "1.5em",
102
+ letterSpacing: "0.15px",
103
+ color: ((i = o.brandingColors) == null ? void 0 : i.contentColor) || o.darkTextColor,
104
+ fontFamily: o.fontFamilyPrimary,
105
+ textAlign: "center"
106
+ },
107
+ // Title typography (mobile without image & desktop responsive)
108
+ titleTypography: {
109
+ fontWeight: 700,
110
+ lineHeight: "133%",
111
+ letterSpacing: "0px",
112
+ fontSize: "1.5em",
113
+ color: o.textColor,
114
+ fontFamily: o.fontFamilyPrimary,
115
+ textAlign: o.isMobile ? "center" : "left"
116
+ },
117
+ // Title typography (desktop centered)
118
+ titleTypographyDesktop: {
119
+ fontWeight: 700,
120
+ lineHeight: "133%",
121
+ letterSpacing: "0px",
122
+ fontSize: "1.5em",
123
+ color: o.textColor,
124
+ fontFamily: o.fontFamilyPrimary
125
+ },
126
+ // Description typography (mobile with image)
127
+ descriptionTypographyMobileImage: {
128
+ fontWeight: 400,
129
+ lineHeight: "140%",
130
+ fontSize: "1.25em",
131
+ letterSpacing: "0.15px",
132
+ color: ((e = o.brandingColors) == null ? void 0 : e.secondaryColor) || o.darkTextColor,
133
+ opacity: "70%",
134
+ fontFamily: o.fontFamilyPrimary,
135
+ textAlign: "center"
136
+ },
137
+ // Description typography (mobile without image & desktop responsive)
138
+ descriptionTypography: {
139
+ fontWeight: 400,
140
+ lineHeight: "140%",
141
+ letterSpacing: "0.15px",
142
+ fontSize: "1.25em",
143
+ color: o.secondaryColor,
144
+ opacity: o.opacity,
145
+ fontFamily: o.fontFamilyPrimary,
146
+ textAlign: o.isMobile ? "center" : "left"
147
+ },
148
+ // Description typography (desktop centered)
149
+ descriptionTypographyDesktop: {
150
+ fontWeight: 400,
151
+ lineHeight: "140%",
152
+ letterSpacing: "0.15px",
153
+ fontSize: "1.25em",
154
+ color: o.secondaryColor,
155
+ opacity: o.opacity,
156
+ fontFamily: o.fontFamilyPrimary
157
+ },
158
+ // Image container (left position)
159
+ imageContainerLeft: {
160
+ display: o.isMobile ? "none" : "block",
161
+ flex: "0.3",
162
+ overflow: "hidden",
163
+ height: "auto",
164
+ position: "relative",
165
+ minHeight: "auto",
166
+ backgroundImage: `url(${o.finalImage})`,
167
+ backgroundSize: "cover",
168
+ backgroundPosition: "center center",
169
+ backgroundRepeat: "no-repeat",
170
+ alignItems: "center",
171
+ justifyContent: "center"
172
+ },
173
+ // Image container (right position)
174
+ imageContainerRight: {
175
+ display: o.isMobile ? "none" : "block",
176
+ flex: "0.3",
177
+ overflow: "hidden",
178
+ height: "auto",
179
+ position: "relative",
180
+ minHeight: "auto",
181
+ backgroundImage: `url(${o.finalImage})`,
182
+ backgroundSize: "cover",
183
+ backgroundPosition: "center center",
184
+ backgroundRepeat: "no-repeat",
185
+ alignItems: "center",
186
+ justifyContent: "center"
187
+ },
188
+ // Image safe area (placeholder for image space)
189
+ imageSafeArea: {
190
+ width: "100%",
191
+ height: "100%"
192
+ },
193
+ // Main content area
194
+ mainContentArea: {
195
+ flex: o.isMobile ? "1" : o.finalImage ? "0.7" : "1",
196
+ display: "flex",
197
+ flexDirection: "column",
198
+ px: o.isMobile ? o.spacingScale.sm : o.spacingScale.md,
199
+ pt: o.spacingScale.lg,
200
+ pb: o.isMobile ? o.spacingScale.sm : o.spacingScale.md,
201
+ gap: o.spacingScale.md
202
+ },
203
+ // Desktop headline container
204
+ desktopHeadlineContainer: {
205
+ display: o.isMobile ? "none" : "flex",
206
+ flexDirection: "column",
207
+ justifyContent: "space-between",
208
+ textAlign: "center"
209
+ }
210
+ };
211
+ }, wn = ({
212
+ entity: o,
213
+ headline: A,
214
+ finalImage: i,
215
+ imagePosition: e = "left",
216
+ children: a,
217
+ rulesDisplay: r
218
+ }) => {
219
+ var t;
220
+ const s = J(), p = X(), c = L(), U = Z().primary, m = Z().secondary;
221
+ Y();
222
+ const x = ((t = o.branding) == null ? void 0 : t.colors) || null, y = (x == null ? void 0 : x.contentColor) || j().textColor, d = (x == null ? void 0 : x.secondaryColor) || j().textColor, g = (x == null ? void 0 : x.backgroundColor) || j().surfaceVariant, B = "60%", f = Ho(
223
+ I.STANDARD
224
+ ), P = Mn({
225
+ finalImage: i,
226
+ spacingScale: c,
227
+ fontFamilyPrimary: U,
228
+ fontFamilySecondary: m,
229
+ textColor: y,
230
+ secondaryColor: d,
231
+ bgcolor: go(g || ""),
232
+ opacity: B,
233
+ brandingColors: x,
234
+ darkTextColor: p.colorSchemes.dark.textColor,
235
+ imageBackgroundGradient: f,
236
+ isMobile: s
237
+ });
238
+ return /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
239
+ s && (i ? /* @__PURE__ */ n.jsx(l, { sx: P.mobileHeadlineWithImage, children: /* @__PURE__ */ n.jsxs(l, { sx: P.mobileHeadlineContent, children: [
240
+ /* @__PURE__ */ n.jsxs(
241
+ l,
242
+ {
243
+ sx: {
244
+ display: "flex",
245
+ alignItems: "center",
246
+ justifyContent: "center",
247
+ gap: c["3xs"]
248
+ },
249
+ children: [
250
+ /* @__PURE__ */ n.jsx(
251
+ K,
252
+ {
253
+ level: "body-sm",
254
+ sx: P.headlineTypographyMobileImage,
255
+ children: A
256
+ }
257
+ ),
258
+ /* @__PURE__ */ n.jsx(
259
+ Mo,
260
+ {
261
+ rules: o.rules || "",
262
+ rulesDisplay: r,
263
+ isOverlayVariant: !1
264
+ }
265
+ )
266
+ ]
267
+ }
268
+ ),
269
+ /* @__PURE__ */ n.jsxs(l, { sx: P.contentContainer, children: [
270
+ /* @__PURE__ */ n.jsx(K, { sx: P.titleTypographyMobileImage, children: o.title }),
271
+ /* @__PURE__ */ n.jsx(K, { sx: P.descriptionTypographyMobileImage, children: qo(o.description) })
272
+ ] })
273
+ ] }) }) : /* @__PURE__ */ n.jsx(l, { sx: P.mobileHeadlineWithoutImage, children: /* @__PURE__ */ n.jsxs(l, { children: [
274
+ /* @__PURE__ */ n.jsxs(
275
+ l,
276
+ {
277
+ sx: {
278
+ display: "flex",
279
+ alignItems: "center",
280
+ justifyContent: "center",
281
+ gap: c["3xs"]
282
+ },
283
+ children: [
284
+ /* @__PURE__ */ n.jsx(K, { level: "body-sm", sx: P.headlineTypography, children: A }),
285
+ /* @__PURE__ */ n.jsx(
286
+ Mo,
287
+ {
288
+ rules: o.rules || "",
289
+ rulesDisplay: r,
290
+ isOverlayVariant: !1
291
+ }
292
+ )
293
+ ]
294
+ }
295
+ ),
296
+ /* @__PURE__ */ n.jsxs(l, { sx: P.contentContainer, children: [
297
+ /* @__PURE__ */ n.jsx(K, { level: "h4", sx: P.titleTypography, children: o.title }),
298
+ /* @__PURE__ */ n.jsx(K, { sx: P.descriptionTypography, children: qo(o.description) })
299
+ ] })
300
+ ] }) })),
301
+ e === "left" && i ? /* @__PURE__ */ n.jsx(l, { sx: P.imageContainerLeft, children: /* @__PURE__ */ n.jsx(l, { sx: P.imageSafeArea }) }) : null,
302
+ /* @__PURE__ */ n.jsxs(l, { sx: P.mainContentArea, children: [
303
+ !s && /* @__PURE__ */ n.jsx(l, { children: /* @__PURE__ */ n.jsxs(l, { sx: P.desktopHeadlineContainer, children: [
304
+ /* @__PURE__ */ n.jsxs(
305
+ l,
306
+ {
307
+ sx: {
308
+ display: "flex",
309
+ alignItems: "center",
310
+ justifyContent: "center",
311
+ gap: c["3xs"]
312
+ },
313
+ children: [
314
+ /* @__PURE__ */ n.jsx(
315
+ K,
316
+ {
317
+ level: "body-sm",
318
+ sx: P.headlineTypographyDesktop,
319
+ children: A
320
+ }
321
+ ),
322
+ /* @__PURE__ */ n.jsx(
323
+ Mo,
324
+ {
325
+ rules: o.rules || "",
326
+ rulesDisplay: r,
327
+ isOverlayVariant: !1
328
+ }
329
+ )
330
+ ]
331
+ }
332
+ ),
333
+ /* @__PURE__ */ n.jsxs(l, { sx: P.contentContainer, children: [
334
+ /* @__PURE__ */ n.jsx(K, { level: "h4", sx: P.titleTypographyDesktop, children: o.title }),
335
+ /* @__PURE__ */ n.jsx(K, { sx: P.descriptionTypographyDesktop, children: qo(o.description) })
336
+ ] })
337
+ ] }) }),
338
+ a
339
+ ] }),
340
+ e === "right" && i ? /* @__PURE__ */ n.jsx(l, { sx: P.imageContainerRight, children: /* @__PURE__ */ n.jsx(l, { sx: P.imageSafeArea }) }) : null
341
+ ] });
342
+ }, Jn = (o, A) => {
343
+ const [i, e] = M.useState(null), a = async () => {
344
+ try {
345
+ const r = await A.voting.getPollById(o, !0);
346
+ e(r);
347
+ } catch (r) {
348
+ console.error(r), e(new _o());
349
+ }
350
+ };
351
+ return M.useEffect(() => (a(), () => e(null)), [o, A]), { poll: i, setPoll: e };
352
+ }, Wn = (o, A, i) => {
353
+ const [e, a] = M.useState(null), [r, t] = M.useState(!1), [s, p] = M.useState(!1), c = async () => {
354
+ try {
355
+ const U = await A.voting.getMyPollVote(o);
356
+ a(U);
357
+ } catch (U) {
358
+ if (a(new on()), A.helpers.getSDKConfiguration().errorHandlingMode === "standard") {
359
+ const x = U;
360
+ if (x.error.code === 404)
361
+ return;
362
+ if (x.error.code === 401 || x.error.code === 403) {
363
+ t(!0);
364
+ return;
365
+ }
366
+ p(!0);
367
+ return;
368
+ }
369
+ const m = U;
370
+ if (m.data.error.code === 404)
371
+ return;
372
+ if (m.data.error.code === 401 || m.data.error.code === 403) {
373
+ t(!0);
374
+ return;
375
+ }
376
+ p(!0);
377
+ }
378
+ };
379
+ return M.useEffect(() => (c(), () => {
380
+ a(null), t(!1), p(!1);
381
+ }), [o, A, i]), {
382
+ myVote: e,
383
+ setMyVote: a,
384
+ isUnauthorized: r,
385
+ isApiError: s,
386
+ setIsUnauthorized: t,
387
+ setIsApiError: p
388
+ };
389
+ }, io = "", to = "", w = (o) => {
390
+ const A = Z().secondary, i = xn(), e = o.isSplitVariant && i, a = J(), r = Un(o.primaryUrl, o.secondaryUrl, "logo");
391
+ if (!o.brandingLogo)
392
+ return null;
393
+ const t = () => {
394
+ r && window.open(r, "_blank", "noopener,noreferrer");
395
+ }, s = /* @__PURE__ */ n.jsx(
396
+ "img",
397
+ {
398
+ src: o.brandingLogo,
399
+ alt: "branding-logo",
400
+ style: {
401
+ maxHeight: "50px",
402
+ maxWidth: "100px"
403
+ }
404
+ }
405
+ ), p = r ? typeof window > "u" ? /* @__PURE__ */ n.jsx(
406
+ l,
407
+ {
408
+ component: "a",
409
+ href: r,
410
+ target: "_blank",
411
+ rel: "noopener noreferrer",
412
+ sx: {
413
+ cursor: "pointer",
414
+ textDecoration: "none",
415
+ display: "inline-flex"
416
+ },
417
+ children: s
418
+ }
419
+ ) : /* @__PURE__ */ n.jsx(
420
+ l,
421
+ {
422
+ onClick: t,
423
+ sx: {
424
+ cursor: "pointer",
425
+ display: "inline-flex"
426
+ },
427
+ children: s
428
+ }
429
+ ) : s;
430
+ return o.isCentered || e || a ? /* @__PURE__ */ n.jsxs(
431
+ l,
432
+ {
433
+ sx: {
434
+ display: "flex",
435
+ flexDirection: "column",
436
+ gap: "8px",
437
+ alignItems: "center",
438
+ minWidth: "180px",
439
+ fontSize: "1em",
440
+ zIndex: 1
441
+ },
442
+ children: [
443
+ o.label && /* @__PURE__ */ n.jsx(
444
+ K,
445
+ {
446
+ level: "body-sm",
447
+ sx: {
448
+ fontWeight: 400,
449
+ lineHeight: "166%",
450
+ letterSpacing: "0.4px",
451
+ fontSize: "1em",
452
+ color: o.textColor,
453
+ textAlign: "right",
454
+ fontFamily: A
455
+ },
456
+ children: o.label
457
+ }
458
+ ),
459
+ p
460
+ ]
461
+ }
462
+ ) : /* @__PURE__ */ n.jsxs(
463
+ l,
464
+ {
465
+ sx: {
466
+ minWidth: "180px",
467
+ display: "flex",
468
+ gap: "8px",
469
+ alignItems: "center",
470
+ zIndex: 10,
471
+ fontSize: "1em"
472
+ },
473
+ children: [
474
+ o.label && /* @__PURE__ */ n.jsx(
475
+ K,
476
+ {
477
+ level: "body-sm",
478
+ sx: {
479
+ fontWeight: 400,
480
+ lineHeight: "166%",
481
+ letterSpacing: "0.4px",
482
+ textAlign: "right",
483
+ fontSize: "1em",
484
+ color: o.textColor,
485
+ fontFamily: A
486
+ },
487
+ children: o.label
488
+ }
489
+ ),
490
+ p
491
+ ]
492
+ }
493
+ );
494
+ }, yo = ({
495
+ sdk: o,
496
+ contentId: A,
497
+ contentName: i,
498
+ brandingColors: e,
499
+ brandingUrls: a,
500
+ campaignId: r,
501
+ campaignName: t,
502
+ startGame: s,
503
+ fields: p = ["fullName", "email"],
504
+ leadTitle: c,
505
+ leadDescription: U,
506
+ leadCta: m,
507
+ leadSuccessTitle: x,
508
+ leadSuccessDescription: y,
509
+ syncWithProfile: d = !1,
510
+ isAfterPosition: g = !1,
511
+ isSubmittingParticipation: B = !1
512
+ }) => {
513
+ const f = c ?? co("leads.header.title"), P = U ?? co("leads.header.description"), T = m ?? co("leads.buttons.submit"), h = x ?? co("leads.success.title"), C = y ?? co("leads.success.description"), k = {
514
+ defaultLabel: g ? co("poll.buttons.vote") : co("poll.buttons.start"),
515
+ onClick: s
516
+ };
517
+ return /* @__PURE__ */ n.jsx(
518
+ zn,
519
+ {
520
+ sdk: o,
521
+ content: {
522
+ id: A,
523
+ type: "poll",
524
+ name: i
525
+ },
526
+ onSuccessCta: k,
527
+ branding: {
528
+ colors: e,
529
+ urls: a
530
+ },
531
+ campaign: {
532
+ id: r,
533
+ name: t
534
+ },
535
+ fields: p,
536
+ labels: {
537
+ title: f,
538
+ description: P,
539
+ submitButtonLabel: T,
540
+ successTitle: h,
541
+ successDescription: C
542
+ },
543
+ syncWithProfile: d,
544
+ isSubmittingParticipation: B
545
+ }
546
+ );
547
+ }, vo = (o) => {
548
+ const A = M.useRef(null);
549
+ return M.useEffect(() => {
550
+ var i;
551
+ if (o && A.current) {
552
+ A.current.innerHTML = o;
553
+ const e = A.current.getElementsByTagName("iframe");
554
+ for (let r = 0; r < e.length; r++) {
555
+ const t = e[r], s = t.src;
556
+ t.src = "", setTimeout(() => {
557
+ t.src = s;
558
+ }, 100);
559
+ }
560
+ const a = A.current.getElementsByTagName("script");
561
+ for (let r = 0; r < a.length; r++) {
562
+ const t = a[r], s = document.createElement("script");
563
+ Array.from(t.attributes).forEach((p) => {
564
+ s.setAttribute(p.name, p.value);
565
+ }), s.innerHTML = t.innerHTML, (i = t.parentNode) == null || i.replaceChild(s, t);
566
+ }
567
+ }
568
+ return () => {
569
+ A.current && (A.current.innerHTML = "");
570
+ };
571
+ }, [o]), A;
572
+ }, Gn = (o) => ({
573
+ // Main content section (non-filter screen)
574
+ mainContentSection: {
575
+ display: "flex",
576
+ flexDirection: "column",
577
+ gap: "24px"
578
+ },
579
+ // Content container with backdrop
580
+ contentContainerWithBackdrop: {
581
+ borderRadius: o.smBorderRadius,
582
+ p: o.spacingScale.md,
583
+ display: "flex",
584
+ flexDirection: "column",
585
+ gap: o.spacingScale.md,
586
+ backdropFilter: "blur(4px)",
587
+ position: "relative",
588
+ "&::before": {
589
+ content: '""',
590
+ position: "absolute",
591
+ top: 0,
592
+ left: 0,
593
+ right: 0,
594
+ bottom: 0,
595
+ backgroundColor: o.contentBgColor,
596
+ opacity: 0.5,
597
+ borderRadius: "inherit",
598
+ zIndex: 0
599
+ },
600
+ "& > *": {
601
+ position: "relative",
602
+ zIndex: 1
603
+ }
604
+ },
605
+ // Alternative title section
606
+ alternativeTitleSection: {
607
+ display: "flex",
608
+ gap: "8px",
609
+ alignItems: "flex-start",
610
+ justifyContent: "center"
611
+ },
612
+ // Alternative title text
613
+ alternativeTitleText: {
614
+ fontFamily: o.fontFamilyPrimary,
615
+ lineHeight: "150%",
616
+ letterSpacing: "0.15px",
617
+ fontWeight: 500,
618
+ fontSize: "1.25em",
619
+ textAlign: "center",
620
+ color: o.darkTextColor
621
+ },
622
+ // Bottom footer container
623
+ bottomFooterContainer: {
624
+ display: "flex",
625
+ alignItems: "center",
626
+ justifyContent: o.isMobile ? "center" : "space-between",
627
+ flexDirection: o.isMobile ? "column-reverse" : "row",
628
+ gap: o.spacingScale.md
629
+ },
630
+ // Next button
631
+ nextButton: {
632
+ borderRadius: o.buttonRadius,
633
+ py: "10px",
634
+ px: "16px",
635
+ bgcolor: o.primaryColor,
636
+ color: o.onPrimaryColor,
637
+ transition: "all 300ms cubic-bezier(0.2, 0, 0, 1)",
638
+ transform: "scale(1)",
639
+ ml: o.isMobile ? 0 : { md: "auto" },
640
+ "&:hover": {
641
+ bgcolor: o.primaryColor,
642
+ transform: "scale(1.02)",
643
+ boxShadow: "var(--joy-shadow-md)"
644
+ },
645
+ "&:active": {
646
+ color: o.onPrimaryColor,
647
+ transform: "scale(0.98)",
648
+ boxShadow: "var(--joy-shadow-md)"
649
+ },
650
+ "&:disabled": {
651
+ bgcolor: o.primaryColor,
652
+ color: o.onPrimaryColor,
653
+ opacity: "34%",
654
+ boxShadow: "var(--joy-shadow-md)"
655
+ },
656
+ "--Icon-color": o.onPrimaryColor,
657
+ fontSize: "0.9375em",
658
+ boxShadow: "var(--joy-shadow-md)"
659
+ },
660
+ // Next button text
661
+ nextButtonText: {
662
+ fontFamily: o.fontFamilyPrimary,
663
+ fontWeight: 500,
664
+ fontSize: "0.9375em",
665
+ lineHeight: "24px",
666
+ letterSpacing: "0.46px",
667
+ textTransform: "uppercase",
668
+ color: o.onPrimaryColor,
669
+ gap: "8px",
670
+ display: "flex",
671
+ alignItems: "center"
672
+ }
673
+ }), wo = (o) => {
674
+ var A;
675
+ const i = X(), e = j(), a = Y().sm, r = Z().primary, t = Y().xs, s = L(), p = Do().size, c = vo(o.option.embedCode || ""), U = !!o.option.embedCode, m = ((A = o.brandingColors) == null ? void 0 : A.primaryColor) || e.palette.primary.plainColor, x = e.palette.primary.onPrimary, y = o.selectedOptions.includes(o.option.id) ? x : i.colorSchemes.light.textColor, d = o.optionsImages.get(o.option.id), g = () => {
676
+ o.multipleChoice ? o.answerPoll([o.option.id]) : o.answerPoll([o.option.id]);
677
+ }, B = o.selectedOptions.includes(o.option.id), f = o.isVoting || o.multipleChoice && !B && o.selectedOptions.length >= (o.maxChoices || 1), P = () => U ? /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
678
+ /* @__PURE__ */ n.jsx(
679
+ l,
680
+ {
681
+ sx: {
682
+ borderRadius: t,
683
+ overflow: "hidden",
684
+ flexGrow: 1
685
+ },
686
+ children: /* @__PURE__ */ n.jsx(Qo, { ratio: "16/9", sx: { borderRadius: t }, children: /* @__PURE__ */ n.jsx(l, { ref: c }) })
687
+ }
688
+ ),
689
+ /* @__PURE__ */ n.jsx(
690
+ K,
691
+ {
692
+ level: "body-md",
693
+ sx: {
694
+ fontFamily: r,
695
+ fontWeight: 500,
696
+ fontSize: "0.935em",
697
+ lineHeight: "24px",
698
+ letterSpacing: "0.46px",
699
+ textAlign: "center",
700
+ color: y,
701
+ px: s["2xs"]
702
+ },
703
+ children: o.option.title
704
+ }
705
+ )
706
+ ] }) : d ? /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
707
+ /* @__PURE__ */ n.jsx(
708
+ l,
709
+ {
710
+ sx: {
711
+ borderRadius: t,
712
+ overflow: "hidden",
713
+ flexGrow: 1
714
+ },
715
+ children: /* @__PURE__ */ n.jsx(Qo, { ratio: "16/9", sx: { borderRadius: t }, children: /* @__PURE__ */ n.jsx(
716
+ "img",
717
+ {
718
+ src: d,
719
+ alt: "Option illustration",
720
+ style: {
721
+ width: "100%",
722
+ height: "100%",
723
+ objectFit: "cover"
724
+ }
725
+ }
726
+ ) })
727
+ }
728
+ ),
729
+ /* @__PURE__ */ n.jsx(
730
+ K,
731
+ {
732
+ level: "body-md",
733
+ sx: {
734
+ fontFamily: r,
735
+ fontWeight: 500,
736
+ fontSize: "0.935em",
737
+ lineHeight: "24px",
738
+ letterSpacing: "0.46px",
739
+ textAlign: "center",
740
+ color: y,
741
+ px: s["2xs"]
742
+ },
743
+ children: o.option.title
744
+ }
745
+ )
746
+ ] }) : /* @__PURE__ */ n.jsx(
747
+ K,
748
+ {
749
+ level: "body-md",
750
+ sx: {
751
+ fontFamily: r,
752
+ fontWeight: 500,
753
+ fontSize: "0.935em",
754
+ lineHeight: "16px",
755
+ letterSpacing: "0.46px",
756
+ textAlign: "center",
757
+ color: y,
758
+ px: s["2xs"],
759
+ my: "auto"
760
+ },
761
+ children: o.option.title
762
+ }
763
+ );
764
+ return /* @__PURE__ */ n.jsx(
765
+ l,
766
+ {
767
+ sx: {
768
+ borderRadius: a,
769
+ flex: 1,
770
+ p: s.xs,
771
+ gap: s.xs,
772
+ bgcolor: B ? m : "#FFFFFF",
773
+ boxShadow: B ? `inset 0 0 0 ${p} ${m}` : "none",
774
+ cursor: f ? "not-allowed" : "pointer",
775
+ opacity: f ? 0.5 : 1,
776
+ transition: "all 300ms cubic-bezier(0.2, 0, 0, 1)",
777
+ transform: "scale(1)",
778
+ "&:hover": {
779
+ transform: f ? "scale(1)" : "scale(1.02)"
780
+ },
781
+ "&:active": {
782
+ transform: f ? "scale(1)" : "scale(0.98)"
783
+ },
784
+ display: "flex",
785
+ flexDirection: "column"
786
+ },
787
+ onClick: f ? void 0 : g,
788
+ children: P()
789
+ },
790
+ o.option.id
791
+ );
792
+ }, Yo = (o) => {
793
+ if (o.optionsLayout === "twoByTwo") {
794
+ const A = [];
795
+ for (let i = 0; i < o.options.length; i += 2) {
796
+ const e = o.options.slice(i, i + 2);
797
+ A.push(e);
798
+ }
799
+ return /* @__PURE__ */ n.jsx(l, { sx: { py: 2, display: "flex", flexDirection: "column", gap: 2 }, children: A.map((i, e) => /* @__PURE__ */ n.jsx(
800
+ l,
801
+ {
802
+ sx: {
803
+ display: "flex",
804
+ flexDirection: {
805
+ xs: "column",
806
+ md: "row"
807
+ },
808
+ gap: 2
809
+ },
810
+ children: i.map((a) => /* @__PURE__ */ n.jsx(
811
+ wo,
812
+ {
813
+ option: a,
814
+ optionsImages: o.optionsImages,
815
+ selectedOptions: o.selectedOptions,
816
+ answerPoll: o.answerPoll,
817
+ brandingColors: o.brandingColors,
818
+ multipleChoice: o.multipleChoice,
819
+ maxChoices: o.maxChoices,
820
+ isVoting: o.isVoting
821
+ },
822
+ a.id
823
+ ))
824
+ },
825
+ `row-${e}`
826
+ )) });
827
+ }
828
+ return o.optionsLayout === "column" ? /* @__PURE__ */ n.jsx(l, { sx: { py: 2, display: "flex", flexDirection: "column", gap: 2 }, children: o.options.map((A) => /* @__PURE__ */ n.jsx(
829
+ wo,
830
+ {
831
+ option: A,
832
+ selectedOptions: o.selectedOptions,
833
+ optionsImages: o.optionsImages,
834
+ answerPoll: o.answerPoll,
835
+ brandingColors: o.brandingColors,
836
+ multipleChoice: o.multipleChoice,
837
+ maxChoices: o.maxChoices,
838
+ isVoting: o.isVoting
839
+ },
840
+ A.id
841
+ )) }) : /* @__PURE__ */ n.jsx(
842
+ l,
843
+ {
844
+ sx: {
845
+ py: 2,
846
+ display: "flex",
847
+ flexWrap: "wrap",
848
+ flexDirection: { xs: "column", md: "row" },
849
+ gap: 2
850
+ },
851
+ children: o.options.map((A) => /* @__PURE__ */ n.jsx(
852
+ wo,
853
+ {
854
+ option: A,
855
+ selectedOptions: o.selectedOptions,
856
+ optionsImages: o.optionsImages,
857
+ answerPoll: o.answerPoll,
858
+ brandingColors: o.brandingColors,
859
+ multipleChoice: o.multipleChoice,
860
+ maxChoices: o.maxChoices,
861
+ isVoting: o.isVoting
862
+ },
863
+ A.id
864
+ ))
865
+ }
866
+ );
867
+ }, uo = (o) => {
868
+ const A = /* @__PURE__ */ new Map(), i = J();
869
+ return o.forEach((e) => {
870
+ var a, r;
871
+ const t = (i ? (a = e.images) == null ? void 0 : a.mobile : (r = e.images) == null ? void 0 : r.main) || "";
872
+ A.set(e.id, t);
873
+ }), A;
874
+ }, Zn = (o) => {
875
+ var A, i, e, a, r, t, s, p, c, U, m, x, y, d, g, B, f, P, T, h, C, k, S, z, H, u;
876
+ const [D, V] = Ko.useState(
877
+ ((A = o.leads) == null ? void 0 : A.position) === "before" && o.poll.authRequirement === "LEAD"
878
+ );
879
+ Ko.useEffect(() => {
880
+ var _;
881
+ V(
882
+ ((_ = o.leads) == null ? void 0 : _.position) === "before" && o.poll.authRequirement === "LEAD" || !1
883
+ );
884
+ }, [(i = o.leads) == null ? void 0 : i.position, o.poll.authRequirement]);
885
+ const { optionsLayout: v } = mo(Po), O = L(), R = X(), b = uo(o.options), { t: F } = G(), q = J(), ro = bo(), oo = vo(o.poll.embedCode), no = !D && !!o.poll.embedCode, Co = ((e = o.leads) == null ? void 0 : e.position) === "after" ? F("poll.buttons.continue") : F("poll.buttons.vote"), { brandingImage: Fo, brandingColors: Ao, brandingLogo: So } = Io(o.poll.branding || null), Bo = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : J() ? to : io, E = Fo || eo(
886
+ {
887
+ images: o.poll.images,
888
+ imagePlaceholder: Bo
889
+ },
890
+ I.OVERLAY
891
+ ), ao = R.customRadius.dark.sm, so = (Ao == null ? void 0 : Ao.backgroundColor) || ((r = (a = R.colorSchemes) == null ? void 0 : a.dark) == null ? void 0 : r.surfaceVariant), N = (s = (t = R.customRadius) == null ? void 0 : t.light) == null ? void 0 : s.xl, lo = (Ao == null ? void 0 : Ao.primaryColor) || ((m = (U = (c = (p = R.colorSchemes) == null ? void 0 : p.light) == null ? void 0 : c.palette) == null ? void 0 : U.primary) == null ? void 0 : m.plainColor), fo = (g = (d = (y = (x = R.colorSchemes) == null ? void 0 : x.light) == null ? void 0 : y.palette) == null ? void 0 : d.primary) == null ? void 0 : g.onPrimary, xo = R.customFontFamily.dark.primary, Uo = R.colorSchemes.dark.textColor, Q = Gn({
892
+ spacingScale: O,
893
+ smBorderRadius: ao,
894
+ contentBgColor: so,
895
+ buttonRadius: N,
896
+ primaryColor: lo,
897
+ onPrimaryColor: fo,
898
+ fontFamilyPrimary: xo,
899
+ darkTextColor: Uo,
900
+ isMobile: q
901
+ }), Oo = () => {
902
+ V(!1);
903
+ }, po = () => {
904
+ var _, Vo, jo, To, Ro;
905
+ return /* @__PURE__ */ n.jsx(
906
+ w,
907
+ {
908
+ brandingLogo: So,
909
+ textColor: R.colorSchemes.dark.textColor,
910
+ label: ((_ = o.poll.labels) == null ? void 0 : _.sponsor) || null,
911
+ primaryUrl: (jo = (Vo = o.poll.branding) == null ? void 0 : Vo.urls) == null ? void 0 : jo.primaryUrl,
912
+ secondaryUrl: (Ro = (To = o.poll.branding) == null ? void 0 : To.urls) == null ? void 0 : Ro.secondaryUrl
913
+ }
914
+ );
915
+ };
916
+ return /* @__PURE__ */ n.jsx(
917
+ Tn,
918
+ {
919
+ entity: o.poll,
920
+ headline: F("poll.headline"),
921
+ finalImage: E,
922
+ rulesDisplay: o.rulesDisplay,
923
+ children: /* @__PURE__ */ n.jsxs(l, { sx: Q.mainContentSection, children: [
924
+ /* @__PURE__ */ n.jsx(l, { sx: Q.contentContainerWithBackdrop, children: D ? /* @__PURE__ */ n.jsx(
925
+ yo,
926
+ {
927
+ sdk: o.sdk,
928
+ startGame: Oo,
929
+ contentId: o.poll.id,
930
+ contentName: o.poll.title,
931
+ brandingColors: (B = o.poll.branding) == null ? void 0 : B.colors,
932
+ brandingUrls: (f = o.poll.branding) == null ? void 0 : f.urls,
933
+ campaignId: (P = o.leads) == null ? void 0 : P.campaignId,
934
+ campaignName: (T = o.leads) == null ? void 0 : T.campaignName,
935
+ fields: (h = o.leads) == null ? void 0 : h.fields,
936
+ leadTitle: (C = o.poll.labels) == null ? void 0 : C.leadTitle,
937
+ leadDescription: (k = o.poll.labels) == null ? void 0 : k.leadDescription,
938
+ leadCta: (S = o.poll.labels) == null ? void 0 : S.leadCta,
939
+ leadSuccessTitle: (z = o.poll.labels) == null ? void 0 : z.leadSuccessTitle,
940
+ leadSuccessDescription: (H = o.poll.labels) == null ? void 0 : H.leadSuccessDescription,
941
+ syncWithProfile: (u = o.leads) == null ? void 0 : u.syncWithProfile
942
+ }
943
+ ) : /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
944
+ no && /* @__PURE__ */ n.jsx(l, { sx: { overflow: "hidden", borderRadius: ao }, children: /* @__PURE__ */ n.jsx(
945
+ Qo,
946
+ {
947
+ ratio: "16/9",
948
+ slotProps: { content: { sx: { height: "100%" } } },
949
+ children: /* @__PURE__ */ n.jsx(l, { ref: oo })
950
+ }
951
+ ) }),
952
+ o.poll.alternativeTitle ? /* @__PURE__ */ n.jsx(l, { sx: Q.alternativeTitleSection, children: /* @__PURE__ */ n.jsx(K, { level: "body-lg", sx: Q.alternativeTitleText, children: o.poll.alternativeTitle }) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
953
+ /* @__PURE__ */ n.jsx(
954
+ Yo,
955
+ {
956
+ options: o.options || [],
957
+ answerPoll: o.answerPoll,
958
+ selectedOptions: o.selectedOptions,
959
+ optionsLayout: ro ? "column" : v ?? "row",
960
+ brandingColors: Ao,
961
+ optionsImages: b,
962
+ multipleChoice: o.poll.multipleChoice,
963
+ maxChoices: o.optionChoices,
964
+ isVoting: o.isVoting
965
+ }
966
+ )
967
+ ] }) }),
968
+ /* @__PURE__ */ n.jsxs(l, { sx: Q.bottomFooterContainer, children: [
969
+ po(),
970
+ !D && /* @__PURE__ */ n.jsx(
971
+ W,
972
+ {
973
+ variant: "soft",
974
+ sx: Q.nextButton,
975
+ onClick: o.voteForPoll,
976
+ loading: o.isVoting,
977
+ disabled: o.selectedOptions.length === 0 || o.isVoting,
978
+ children: /* @__PURE__ */ n.jsx(K, { sx: Q.nextButtonText, children: Co })
979
+ }
980
+ )
981
+ ] })
982
+ ] })
983
+ }
984
+ );
985
+ }, Wo = (o) => {
986
+ const A = Z().primary, i = Y().xl, e = j().palette.primary.onPrimary, a = o.selectedOptions.length === 0 || o.isVoting;
987
+ return /* @__PURE__ */ n.jsx(n.Fragment, { children: /* @__PURE__ */ n.jsx(
988
+ W,
989
+ {
990
+ variant: "soft",
991
+ disabled: a,
992
+ loading: o.isVoting,
993
+ sx: {
994
+ borderRadius: i,
995
+ py: "10px",
996
+ px: "16px",
997
+ bgcolor: o.buttonColor,
998
+ color: e,
999
+ transition: "all 300ms cubic-bezier(0.2, 0, 0, 1)",
1000
+ transform: "scale(1)",
1001
+ alignSelf: "center",
1002
+ "&:hover": {
1003
+ bgcolor: o.buttonColor,
1004
+ transform: "scale(1.02)"
1005
+ },
1006
+ "&:active": {
1007
+ color: e,
1008
+ transform: "scale(0.98)"
1009
+ },
1010
+ "&:disabled": {
1011
+ bgcolor: o.buttonColor,
1012
+ color: e,
1013
+ opacity: "12%"
1014
+ },
1015
+ "--Icon-color": e,
1016
+ fontSize: "0.9375em"
1017
+ },
1018
+ onClick: o.onClick,
1019
+ slotProps: {
1020
+ loadingIndicatorCenter: {
1021
+ sx: {
1022
+ "& .MuiCircularProgress-track": {
1023
+ stroke: "#FFFFFF"
1024
+ }
1025
+ }
1026
+ }
1027
+ },
1028
+ children: /* @__PURE__ */ n.jsx(
1029
+ K,
1030
+ {
1031
+ sx: {
1032
+ fontFamily: A,
1033
+ fontWeight: 500,
1034
+ fontSize: "0.9375em",
1035
+ lineHeight: "24px",
1036
+ letterSpacing: "0.46px",
1037
+ textTransform: "uppercase",
1038
+ color: e,
1039
+ gap: "8px",
1040
+ display: "flex",
1041
+ alignItems: "center",
1042
+ visibility: o.isVoting ? "hidden" : "visible"
1043
+ },
1044
+ children: o.label
1045
+ }
1046
+ )
1047
+ }
1048
+ ) });
1049
+ }, $ = ({
1050
+ children: o,
1051
+ brandingBorderColor: A,
1052
+ state: i
1053
+ }) => {
1054
+ const e = J(), a = bo(), r = i === "play" ? a : e, t = Y().md, s = A || j().secondaryContainer, p = Do().size + " solid " + s;
1055
+ return /* @__PURE__ */ n.jsx(
1056
+ l,
1057
+ {
1058
+ sx: {
1059
+ display: "flex",
1060
+ // flexDirection: mobile ? "column" : "row",
1061
+ flexDirection: r ? "column" : "row",
1062
+ width: "100%",
1063
+ borderRadius: t,
1064
+ boxShadow: "md",
1065
+ border: p,
1066
+ overflow: "hidden",
1067
+ background: j().surface,
1068
+ minHeight: "250px"
1069
+ },
1070
+ children: o
1071
+ }
1072
+ );
1073
+ }, Yn = (o) => ({
1074
+ // Lead collection container
1075
+ leadCollectionContainer: {
1076
+ display: "flex",
1077
+ flexDirection: "column",
1078
+ p: o.spacingScale.md
1079
+ },
1080
+ // Lead question container
1081
+ leadQuestionContainer: {
1082
+ display: "flex",
1083
+ flexDirection: "column",
1084
+ gap: { xs: o.spacingScale.lg, md: o.spacingScale.md }
1085
+ },
1086
+ // Lead content container
1087
+ leadContentContainer: {
1088
+ borderRadius: o.mdBorderRadius,
1089
+ px: o.spacingScale.md,
1090
+ pt: o.spacingScale.md,
1091
+ pb: o.spacingScale.lg,
1092
+ gap: o.spacingScale.md,
1093
+ bgcolor: `rgba(${o.bgcolor ? o.bgcolor.replace(/[^\d,]/g, "") : ""}, 0.5)`,
1094
+ display: "flex",
1095
+ flexDirection: "column",
1096
+ backdropFilter: "blur(4px)"
1097
+ },
1098
+ // Question area
1099
+ questionArea: {
1100
+ display: "flex",
1101
+ flexDirection: "column",
1102
+ p: o.spacingScale.md
1103
+ },
1104
+ // Question container
1105
+ questionContainer: {
1106
+ display: "flex",
1107
+ flexDirection: "column",
1108
+ gap: { xs: o.spacingScale.lg, md: o.spacingScale.md }
1109
+ },
1110
+ // Question content container
1111
+ questionContentContainer: {
1112
+ borderRadius: o.mdBorderRadius,
1113
+ px: o.spacingScale.md,
1114
+ pt: o.spacingScale.md,
1115
+ pb: o.spacingScale.lg,
1116
+ gap: o.spacingScale.md,
1117
+ bgcolor: `rgba(${o.bgcolor ? o.bgcolor.replace(/[^\d,]/g, "") : ""}, 0.5)`,
1118
+ display: "flex",
1119
+ flexDirection: "column",
1120
+ backdropFilter: "blur(4px)"
1121
+ },
1122
+ // Question text container
1123
+ questionTextContainer: {
1124
+ gap: "8px",
1125
+ display: "flex",
1126
+ justifyContent: "center"
1127
+ },
1128
+ // Question text
1129
+ questionText: {
1130
+ fontFamily: o.fontFamilyPrimary,
1131
+ lineHeight: "150%",
1132
+ letterSpacing: "0.15px",
1133
+ fontWeight: 500,
1134
+ fontSize: "1.25em",
1135
+ textAlign: "center",
1136
+ color: o.textColor
1137
+ },
1138
+ // Footer container
1139
+ footerContainer: {
1140
+ display: "flex",
1141
+ flexDirection: o.isExtraSmall ? "column" : "row",
1142
+ justifyContent: "space-between",
1143
+ alignItems: "center",
1144
+ gap: o.spacingScale.lg
1145
+ },
1146
+ // Footer container (no logo)
1147
+ footerContainerNoLogo: {
1148
+ display: "flex",
1149
+ flexDirection: o.isExtraSmall ? "column" : "row",
1150
+ justifyContent: "flex-end",
1151
+ alignItems: "center",
1152
+ gap: o.spacingScale.lg
1153
+ },
1154
+ // Navigation container
1155
+ navigationContainer: {
1156
+ display: "flex",
1157
+ gap: o.spacingScale.md,
1158
+ justifyContent: "center",
1159
+ alignItems: "center"
1160
+ }
1161
+ }), En = (o) => {
1162
+ var A, i, e, a, r, t, s, p, c, U, m, x, y, d, g, B, f, P, T, h, C;
1163
+ const [k, S] = Ko.useState(
1164
+ ((A = o.leads) == null ? void 0 : A.position) === "before" && o.poll.authRequirement === "LEAD"
1165
+ );
1166
+ Ko.useEffect(() => {
1167
+ var N;
1168
+ S(
1169
+ ((N = o.leads) == null ? void 0 : N.position) === "before" && o.poll.authRequirement === "LEAD" || !1
1170
+ );
1171
+ }, [(i = o.leads) == null ? void 0 : i.position, o.poll.authRequirement]);
1172
+ const { optionsLayout: z } = mo(Po), H = vo(o.poll.embedCode), u = !k && !!o.poll.embedCode, D = uo(o.options), { t: V } = G(), v = J(), O = Kn(), R = ((e = o.poll.branding) == null ? void 0 : e.colors) || null, b = v ? ((r = (a = o.poll.branding) == null ? void 0 : a.images) == null ? void 0 : r.mobileLogo) || ((s = (t = o.poll.branding) == null ? void 0 : t.images) == null ? void 0 : s.mainLogo) || "" : ((c = (p = o.poll.branding) == null ? void 0 : p.images) == null ? void 0 : c.mainLogo) || "", F = o.imagePosition || "left", q = eo(
1173
+ {
1174
+ images: o.poll.images,
1175
+ imagePlaceholder: o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : ""
1176
+ },
1177
+ I.STANDARD
1178
+ ), ro = ((U = o.leads) == null ? void 0 : U.position) === "after" ? V("poll.buttons.continue") : V("poll.buttons.vote"), oo = O || v && !!q, no = (R == null ? void 0 : R.contentColor) || j().textColor, Co = Z().primary, Fo = (R == null ? void 0 : R.backgroundColor) || j().surfaceVariant, Ao = Y().md, So = (R == null ? void 0 : R.primaryColor) || j().palette.primary.plainColor, Bo = L(), E = Yn({
1179
+ spacingScale: Bo,
1180
+ fontFamilyPrimary: Co,
1181
+ textColor: no,
1182
+ bgcolor: go(Fo || ""),
1183
+ mdBorderRadius: Ao,
1184
+ isExtraSmall: oo
1185
+ }), ao = () => {
1186
+ S(!1);
1187
+ }, so = (N) => {
1188
+ var lo, fo, xo, Uo, Q;
1189
+ return /* @__PURE__ */ n.jsx(
1190
+ w,
1191
+ {
1192
+ brandingLogo: b,
1193
+ textColor: N,
1194
+ label: ((lo = o.poll.labels) == null ? void 0 : lo.sponsor) || null,
1195
+ primaryUrl: (xo = (fo = o.poll.branding) == null ? void 0 : fo.urls) == null ? void 0 : xo.primaryUrl,
1196
+ secondaryUrl: (Q = (Uo = o.poll.branding) == null ? void 0 : Uo.urls) == null ? void 0 : Q.secondaryUrl
1197
+ }
1198
+ );
1199
+ };
1200
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (R == null ? void 0 : R.borderColor) || null, children: /* @__PURE__ */ n.jsx(
1201
+ Rn,
1202
+ {
1203
+ entity: o.poll,
1204
+ headline: V("poll.headline"),
1205
+ finalImage: q,
1206
+ imagePosition: F,
1207
+ rulesDisplay: o.rulesDisplay,
1208
+ embedCodeContainerRef: H,
1209
+ hasEmbedCode: u,
1210
+ children: /* @__PURE__ */ n.jsx(n.Fragment, { children: k ? /* @__PURE__ */ n.jsx(l, { sx: E.leadCollectionContainer, children: /* @__PURE__ */ n.jsxs(l, { sx: E.leadQuestionContainer, children: [
1211
+ /* @__PURE__ */ n.jsx(l, { sx: E.leadContentContainer, children: /* @__PURE__ */ n.jsx(
1212
+ yo,
1213
+ {
1214
+ sdk: o.sdk,
1215
+ startGame: ao,
1216
+ contentId: o.poll.id,
1217
+ contentName: o.poll.title,
1218
+ brandingColors: (m = o.poll.branding) == null ? void 0 : m.colors,
1219
+ brandingUrls: (x = o.poll.branding) == null ? void 0 : x.urls,
1220
+ campaignId: (y = o.leads) == null ? void 0 : y.campaignId,
1221
+ campaignName: (d = o.leads) == null ? void 0 : d.campaignName,
1222
+ fields: (g = o.leads) == null ? void 0 : g.fields,
1223
+ leadTitle: (B = o.poll.labels) == null ? void 0 : B.leadTitle,
1224
+ leadDescription: (f = o.poll.labels) == null ? void 0 : f.leadDescription,
1225
+ leadCta: (P = o.poll.labels) == null ? void 0 : P.leadCta,
1226
+ leadSuccessTitle: (T = o.poll.labels) == null ? void 0 : T.leadSuccessTitle,
1227
+ leadSuccessDescription: (h = o.poll.labels) == null ? void 0 : h.leadSuccessDescription,
1228
+ syncWithProfile: (C = o.leads) == null ? void 0 : C.syncWithProfile
1229
+ }
1230
+ ) }),
1231
+ so(no)
1232
+ ] }) }) : /* @__PURE__ */ n.jsx(n.Fragment, { children: /* @__PURE__ */ n.jsx(l, { sx: E.questionArea, children: /* @__PURE__ */ n.jsxs(l, { sx: E.questionContainer, children: [
1233
+ /* @__PURE__ */ n.jsxs(l, { sx: E.questionContentContainer, children: [
1234
+ o.poll.alternativeTitle ? /* @__PURE__ */ n.jsx(l, { sx: E.questionTextContainer, children: /* @__PURE__ */ n.jsx(K, { level: "body-lg", sx: E.questionText, children: o.poll.alternativeTitle }) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
1235
+ /* @__PURE__ */ n.jsx(
1236
+ Yo,
1237
+ {
1238
+ options: o.options || [],
1239
+ answerPoll: o.answerPoll,
1240
+ selectedOptions: o.selectedOptions,
1241
+ optionsLayout: z ?? "twoByTwo",
1242
+ optionsImages: D,
1243
+ brandingColors: R,
1244
+ multipleChoice: o.poll.multipleChoice,
1245
+ maxChoices: o.optionChoices,
1246
+ isVoting: o.isVoting
1247
+ }
1248
+ )
1249
+ ] }),
1250
+ /* @__PURE__ */ n.jsxs(
1251
+ l,
1252
+ {
1253
+ sx: b ? E.footerContainer : E.footerContainerNoLogo,
1254
+ children: [
1255
+ b && !oo ? so(no) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
1256
+ /* @__PURE__ */ n.jsx(l, { sx: E.navigationContainer, children: /* @__PURE__ */ n.jsx(
1257
+ Wo,
1258
+ {
1259
+ selectedOptions: o.selectedOptions,
1260
+ label: ro,
1261
+ buttonColor: So,
1262
+ onClick: o.voteForPoll,
1263
+ isVoting: o.isVoting
1264
+ }
1265
+ ) })
1266
+ ]
1267
+ }
1268
+ ),
1269
+ b && oo ? so(no) : /* @__PURE__ */ n.jsx(n.Fragment, {})
1270
+ ] }) }) }) })
1271
+ }
1272
+ ) });
1273
+ }, Nn = (o) => {
1274
+ var A, i, e, a, r, t;
1275
+ return {
1276
+ // Main headline section with background image
1277
+ headlineSection: {
1278
+ display: "flex",
1279
+ flexDirection: "column",
1280
+ justifyContent: "space-between",
1281
+ gap: "10px",
1282
+ flex: o.isLarge ? "1" : "0 0 50%",
1283
+ width: o.isLarge ? "100%" : "50%",
1284
+ minWidth: o.isLarge ? "100%" : "50%",
1285
+ maxWidth: o.isLarge ? "100%" : "50%",
1286
+ backgroundImage: `url(${o.finalImage})`,
1287
+ backgroundSize: "cover",
1288
+ backgroundPosition: "center",
1289
+ borderTopLeftRadius: o.borderRadius.md,
1290
+ borderTopRightRadius: o.isLarge ? o.borderRadius.md : 0,
1291
+ borderBottomLeftRadius: o.isLarge ? 0 : o.borderRadius.md,
1292
+ overflow: "hidden",
1293
+ height: "auto",
1294
+ position: "relative",
1295
+ minHeight: o.isLarge ? "210px" : "430px",
1296
+ "&::before": {
1297
+ content: '""',
1298
+ position: "absolute",
1299
+ width: "100%",
1300
+ height: "100%",
1301
+ background: o.imageBackgroundGradient,
1302
+ borderTopLeftRadius: "5px",
1303
+ borderTopRightRadius: "5px"
1304
+ }
1305
+ },
1306
+ embedCodeHeadlineSection: {
1307
+ flex: o.isLarge ? "1" : "0 0 50%",
1308
+ width: o.isLarge ? "100%" : "50%",
1309
+ minWidth: o.isLarge ? "100%" : "50%",
1310
+ maxWidth: o.isLarge ? "100%" : "50%",
1311
+ borderTopLeftRadius: o.borderRadius.md,
1312
+ borderTopRightRadius: o.isLarge ? o.borderRadius.md : 0,
1313
+ borderBottomLeftRadius: o.isLarge ? 0 : o.borderRadius.md,
1314
+ overflow: "hidden",
1315
+ height: "auto",
1316
+ position: "relative",
1317
+ minHeight: o.isLarge ? "210px" : "430px"
1318
+ },
1319
+ // Headline content wrapper
1320
+ embedCodeHeadlineContent: {
1321
+ gap: o.spacingScale.xl,
1322
+ display: "flex",
1323
+ flexDirection: "column",
1324
+ alignItems: "center"
1325
+ },
1326
+ // Filter screen area
1327
+ filterScreenArea: {
1328
+ flex: "0.5",
1329
+ display: "flex",
1330
+ flexDirection: "column",
1331
+ p: o.spacingScale.lg
1332
+ },
1333
+ // Filter screen headline section
1334
+ filterScreenHeadlineContent: {
1335
+ display: "flex",
1336
+ flexDirection: "column",
1337
+ justifyContent: "space-between",
1338
+ gap: o.spacingScale["2xl"],
1339
+ textAlign: "center"
1340
+ },
1341
+ // Filter screen headline text
1342
+ filterScreenHeadlineText: {
1343
+ fontWeight: 500,
1344
+ lineHeight: "166%",
1345
+ letterSpacing: "1px",
1346
+ textTransform: "uppercase",
1347
+ fontSize: "0.75em",
1348
+ color: o.secondaryColor,
1349
+ opacity: o.opacity,
1350
+ fontFamily: o.fontFamilySecondary
1351
+ },
1352
+ // Filter screen title text
1353
+ filterScreenTitleText: {
1354
+ fontWeight: 700,
1355
+ lineHeight: "133%",
1356
+ letterSpacing: "0px",
1357
+ fontSize: "1.5em",
1358
+ color: o.textColor,
1359
+ fontFamily: o.fontFamilyPrimary
1360
+ },
1361
+ // Filter screen description text
1362
+ filterScreenDescriptionText: {
1363
+ fontWeight: 400,
1364
+ lineHeight: "140%",
1365
+ letterSpacing: "0.15px",
1366
+ fontSize: "1.25em",
1367
+ color: o.secondaryColor,
1368
+ opacity: o.opacity,
1369
+ fontFamily: o.fontFamilyPrimary
1370
+ },
1371
+ // Filter screen CTA wrapper
1372
+ filterScreenCtaWrapper: {
1373
+ display: "flex",
1374
+ flexDirection: "column",
1375
+ justifyContent: "space-between",
1376
+ alignItems: "center",
1377
+ gap: o.spacingScale["2xl"]
1378
+ },
1379
+ // Headline content wrapper
1380
+ headlineContent: {
1381
+ zIndex: 1,
1382
+ height: "100%",
1383
+ p: o.spacingScale.xl,
1384
+ gap: o.spacingScale.xl,
1385
+ display: "flex",
1386
+ flexDirection: "column",
1387
+ justifyContent: "space-between"
1388
+ },
1389
+ // Poll headline typography
1390
+ pollHeadlineText: {
1391
+ fontWeight: 500,
1392
+ lineHeight: "166%",
1393
+ letterSpacing: "1px",
1394
+ fontSize: "0.75em",
1395
+ color: ((A = o.brandingColors) == null ? void 0 : A.secondaryColor) || o.darkTextColor,
1396
+ opacity: "70%",
1397
+ textTransform: "uppercase",
1398
+ fontFamily: o.fontFamilySecondary,
1399
+ textAlign: o.isLarge ? "center" : "left"
1400
+ },
1401
+ // Poll headline typography on filter screen
1402
+ pollHeadlineTextFilterScreen: {
1403
+ fontWeight: 500,
1404
+ lineHeight: "166%",
1405
+ letterSpacing: "1px",
1406
+ fontSize: "0.75em",
1407
+ color: ((i = o.brandingColors) == null ? void 0 : i.secondaryColor) || o.textColor,
1408
+ opacity: "70%",
1409
+ textTransform: "uppercase",
1410
+ fontFamily: o.fontFamilySecondary,
1411
+ textAlign: o.isLarge ? "center" : "left"
1412
+ },
1413
+ // Content container
1414
+ contentContainer: {
1415
+ display: "flex",
1416
+ flexDirection: "column",
1417
+ gap: o.spacingScale["3xs"]
1418
+ },
1419
+ // Poll title typography
1420
+ pollTitleText: {
1421
+ fontWeight: 700,
1422
+ lineHeight: "133%",
1423
+ fontSize: "1.5em",
1424
+ letterSpacing: "0.15px",
1425
+ color: ((e = o.brandingColors) == null ? void 0 : e.contentColor) || o.darkTextColor,
1426
+ fontFamily: o.fontFamilyPrimary,
1427
+ textAlign: o.isLarge ? "center" : "left"
1428
+ },
1429
+ // Poll title typography on filter screen
1430
+ pollTitleTextFilterScreen: {
1431
+ fontWeight: 700,
1432
+ lineHeight: "133%",
1433
+ fontSize: "1.5em",
1434
+ letterSpacing: "0.15px",
1435
+ color: ((a = o.brandingColors) == null ? void 0 : a.contentColor) || o.textColor,
1436
+ fontFamily: o.fontFamilyPrimary,
1437
+ textAlign: o.isLarge ? "center" : "left"
1438
+ },
1439
+ // Poll description typography
1440
+ pollDescriptionText: {
1441
+ fontWeight: 400,
1442
+ lineHeight: "140%",
1443
+ fontSize: "1.25em",
1444
+ letterSpacing: "0.15px",
1445
+ color: ((r = o.brandingColors) == null ? void 0 : r.secondaryColor) || o.darkTextColor,
1446
+ opacity: "70%",
1447
+ fontFamily: o.fontFamilyPrimary,
1448
+ textAlign: o.isLarge ? "center" : "left"
1449
+ },
1450
+ // Poll description typography on filter screen
1451
+ pollDescriptionTextFilterScreen: {
1452
+ fontWeight: 400,
1453
+ lineHeight: "140%",
1454
+ fontSize: "1.25em",
1455
+ letterSpacing: "0.15px",
1456
+ color: ((t = o.brandingColors) == null ? void 0 : t.secondaryColor) || o.textColor,
1457
+ opacity: "70%",
1458
+ fontFamily: o.fontFamilyPrimary,
1459
+ textAlign: o.isLarge ? "center" : "left"
1460
+ },
1461
+ // Filter screen bottom container
1462
+ filterScreenBottomContainer: {
1463
+ display: "flex",
1464
+ flexDirection: o.isLarge ? "column-reverse" : "row",
1465
+ justifyContent: "space-between",
1466
+ alignItems: "center",
1467
+ gap: o.spacingScale.lg
1468
+ },
1469
+ // Start button (filter screen)
1470
+ startButton: {
1471
+ borderRadius: o.buttonRadius,
1472
+ bgcolor: o.primaryColor,
1473
+ color: o.onPrimaryColor,
1474
+ "&:hover": {
1475
+ bgcolor: o.primaryColor
1476
+ },
1477
+ "&:active": {
1478
+ color: o.onPrimaryColor
1479
+ },
1480
+ animation: "pulse 1s infinite",
1481
+ fontSize: "0.9375em",
1482
+ py: "10px",
1483
+ pr: "12px",
1484
+ pl: "16px",
1485
+ "--Icon-color": o.onPrimaryColor
1486
+ },
1487
+ // Start button text
1488
+ startButtonText: {
1489
+ fontFamily: o.fontFamilyPrimary,
1490
+ fontWeight: 500,
1491
+ fontSize: "0.9375em",
1492
+ lineHeight: "24px",
1493
+ letterSpacing: "0.46px",
1494
+ textTransform: "uppercase",
1495
+ color: o.onPrimaryColor,
1496
+ gap: "8px",
1497
+ display: "flex",
1498
+ alignItems: "center"
1499
+ },
1500
+ // Presented by desktop container
1501
+ presentedByDesktop: {
1502
+ display: o.isLarge ? "none" : "block"
1503
+ },
1504
+ // Question area
1505
+ questionArea: {
1506
+ width: "100%",
1507
+ display: "flex",
1508
+ flexDirection: "column",
1509
+ justifyContent: "center"
1510
+ },
1511
+ // Stopwatch container
1512
+ stopwatchContainer: {
1513
+ display: "flex",
1514
+ justifyContent: "center"
1515
+ },
1516
+ // Lead content container (filter screen)
1517
+ leadContentContainer: {
1518
+ p: o.spacingScale.md,
1519
+ gap: o.spacingScale.md,
1520
+ display: "flex",
1521
+ flexDirection: "column",
1522
+ backdropFilter: "blur(4px)",
1523
+ bgcolor: `rgba(${o.bgcolor ? o.bgcolor.replace(/[^\d,]/g, "") : ""}, 0.5)`,
1524
+ borderRadius: o.borderRadius.sm
1525
+ },
1526
+ // Question area content wrapper
1527
+ questionAreaContent: {
1528
+ p: o.spacingScale.lg,
1529
+ display: "flex",
1530
+ flexDirection: "column",
1531
+ justifyContent: "center",
1532
+ gap: "16px"
1533
+ },
1534
+ // Main content container
1535
+ mainContentContainer: {
1536
+ p: o.spacingScale.lg,
1537
+ gap: o.spacingScale.md,
1538
+ display: "flex",
1539
+ flexDirection: "column",
1540
+ backdropFilter: "blur(4px)",
1541
+ bgcolor: `rgba(${o.bgcolor ? o.bgcolor.replace(/[^\d,]/g, "") : ""}, 0.5)`,
1542
+ borderRadius: o.borderRadius.sm
1543
+ },
1544
+ // Aspect ratio container for embed/image
1545
+ aspectRatioContainer: {
1546
+ borderRadius: o.borderRadius.sm,
1547
+ height: "100%",
1548
+ flex: 1,
1549
+ // Take all available space
1550
+ "& > div": {
1551
+ height: "100% !important",
1552
+ flex: "1 !important"
1553
+ // Force flex growth
1554
+ }
1555
+ },
1556
+ // Question image container
1557
+ questionImageContainer: {
1558
+ overflow: "hidden",
1559
+ borderRadius: o.borderRadius.sm
1560
+ },
1561
+ // Question image box
1562
+ questionImageBox: {
1563
+ borderRadius: o.borderRadius.sm,
1564
+ overflow: "hidden",
1565
+ height: "auto"
1566
+ },
1567
+ // Question image
1568
+ questionImage: {
1569
+ width: "100%",
1570
+ height: "100%",
1571
+ objectFit: "cover"
1572
+ },
1573
+ // Alternative title section
1574
+ alternativeTitleSection: {
1575
+ gap: "8px",
1576
+ display: "flex",
1577
+ justifyContent: "center"
1578
+ },
1579
+ // Alternative title text
1580
+ alternativeTitleText: {
1581
+ fontFamily: o.fontFamilyPrimary,
1582
+ lineHeight: "150%",
1583
+ letterSpacing: "0.15px",
1584
+ fontWeight: 500,
1585
+ fontSize: "1.25em",
1586
+ textAlign: "center",
1587
+ color: o.textColor
1588
+ },
1589
+ // Button and footer container
1590
+ buttonFooterContainer: {
1591
+ display: "flex",
1592
+ flexDirection: "column",
1593
+ gap: o.spacingScale.lg
1594
+ },
1595
+ // Presented by mobile container
1596
+ presentedByMobile: {
1597
+ display: o.isLarge ? "flex" : "none",
1598
+ justifyContent: "center"
1599
+ }
1600
+ };
1601
+ }, Xn = (o) => {
1602
+ var A, i, e, a, r, t, s, p, c, U, m, x, y, d, g, B, f, P, T, h, C, k;
1603
+ const [S, z] = Ko.useState(
1604
+ ((A = o.leads) == null ? void 0 : A.position) === "before" && o.poll.authRequirement === "LEAD"
1605
+ );
1606
+ Ko.useEffect(() => {
1607
+ var _;
1608
+ z(
1609
+ ((_ = o.leads) == null ? void 0 : _.position) === "before" && o.poll.authRequirement === "LEAD" || !1
1610
+ );
1611
+ }, [(i = o.leads) == null ? void 0 : i.position, o.poll.authRequirement]);
1612
+ const { optionsLayout: H } = mo(Po), u = X(), D = J(), V = bo(), v = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : D ? to : io, O = eo(
1613
+ {
1614
+ images: o.poll.images,
1615
+ imagePlaceholder: v
1616
+ },
1617
+ I.SPLIT
1618
+ ), R = uo(o.options), { t: b } = G(), F = ((e = o.poll.branding) == null ? void 0 : e.colors) || null, q = D ? ((a = o.poll.branding) == null ? void 0 : a.images.mobileLogo) || ((r = o.poll.branding) == null ? void 0 : r.images.mainLogo) || "" : ((t = o.poll.branding) == null ? void 0 : t.images.mainLogo) || "", ro = vo(o.poll.embedCode), oo = !S && !!o.poll.embedCode, no = ((s = o.leads) == null ? void 0 : s.position) === "after" ? b("poll.buttons.continue") : b("poll.buttons.vote"), Co = (F == null ? void 0 : F.contentColor) || j().textColor, Fo = Z().secondary, Ao = "60%", So = Z().primary, Bo = Y().xl, E = (F == null ? void 0 : F.backgroundColor) || j().surfaceVariant, ao = (F == null ? void 0 : F.primaryColor) || ((c = (p = j().palette) == null ? void 0 : p.primary) == null ? void 0 : c.plainColor), so = (m = (U = j().palette) == null ? void 0 : U.primary) == null ? void 0 : m.onPrimary, N = j().textColor, lo = L(), fo = Y(), xo = Ho(
1619
+ I.SPLIT
1620
+ ), Uo = go(E || ""), Q = Nn({
1621
+ finalImage: O,
1622
+ spacingScale: lo,
1623
+ borderRadius: fo,
1624
+ fontFamilyPrimary: So,
1625
+ fontFamilySecondary: Fo,
1626
+ secondaryColor: Co,
1627
+ opacity: Ao,
1628
+ buttonRadius: Bo,
1629
+ bgcolor: Uo,
1630
+ primaryColor: ao,
1631
+ onPrimaryColor: so,
1632
+ textColor: N,
1633
+ brandingColors: F,
1634
+ darkTextColor: u.colorSchemes.dark.textColor,
1635
+ imageBackgroundGradient: xo,
1636
+ isLarge: V
1637
+ }), Oo = () => {
1638
+ z(!1);
1639
+ }, po = (_, Vo) => {
1640
+ var jo, To, Ro, Xo, Lo;
1641
+ return /* @__PURE__ */ n.jsx(
1642
+ w,
1643
+ {
1644
+ brandingLogo: q,
1645
+ textColor: _,
1646
+ label: ((jo = o.poll.labels) == null ? void 0 : jo.sponsor) || null,
1647
+ primaryUrl: (Ro = (To = o.poll.branding) == null ? void 0 : To.urls) == null ? void 0 : Ro.primaryUrl,
1648
+ secondaryUrl: (Lo = (Xo = o.poll.branding) == null ? void 0 : Xo.urls) == null ? void 0 : Lo.secondaryUrl,
1649
+ isCentered: Vo || !1
1650
+ }
1651
+ );
1652
+ };
1653
+ return /* @__PURE__ */ n.jsxs(
1654
+ $,
1655
+ {
1656
+ brandingBorderColor: (F == null ? void 0 : F.borderColor) || null,
1657
+ state: "play",
1658
+ children: [
1659
+ /* @__PURE__ */ n.jsx(
1660
+ hn,
1661
+ {
1662
+ entity: { ...o.poll, type: "poll" },
1663
+ headline: b("poll.headline"),
1664
+ finalImage: O,
1665
+ rulesDisplay: o.rulesDisplay,
1666
+ embedCodeContainerRef: ro,
1667
+ hasEmbedCode: oo,
1668
+ brandingLogo: q,
1669
+ renderPresentedBy: po,
1670
+ children: /* @__PURE__ */ n.jsx(l, { sx: Q.questionArea, children: /* @__PURE__ */ n.jsxs(l, { sx: Q.questionAreaContent, children: [
1671
+ oo && /* @__PURE__ */ n.jsx(l, { sx: Q.embedCodeHeadlineContent, children: /* @__PURE__ */ n.jsxs(l, { children: [
1672
+ /* @__PURE__ */ n.jsx(
1673
+ K,
1674
+ {
1675
+ sx: {
1676
+ ...Q.pollHeadlineText,
1677
+ color: N,
1678
+ textAlign: "center"
1679
+ },
1680
+ children: b("poll.headline")
1681
+ }
1682
+ ),
1683
+ /* @__PURE__ */ n.jsxs(l, { sx: Q.contentContainer, children: [
1684
+ /* @__PURE__ */ n.jsx(
1685
+ K,
1686
+ {
1687
+ sx: {
1688
+ ...Q.pollTitleText,
1689
+ color: N,
1690
+ textAlign: "center"
1691
+ },
1692
+ children: o.poll.title
1693
+ }
1694
+ ),
1695
+ /* @__PURE__ */ n.jsx(
1696
+ K,
1697
+ {
1698
+ sx: {
1699
+ ...Q.pollDescriptionText,
1700
+ color: N,
1701
+ textAlign: "center"
1702
+ },
1703
+ children: qo(o.poll.description)
1704
+ }
1705
+ )
1706
+ ] })
1707
+ ] }) }),
1708
+ S ? /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
1709
+ /* @__PURE__ */ n.jsx(l, { sx: Q.leadContentContainer, children: /* @__PURE__ */ n.jsx(
1710
+ yo,
1711
+ {
1712
+ sdk: o.sdk,
1713
+ startGame: Oo,
1714
+ contentId: o.poll.id,
1715
+ contentName: o.poll.title,
1716
+ brandingColors: (x = o.poll.branding) == null ? void 0 : x.colors,
1717
+ brandingUrls: (y = o.poll.branding) == null ? void 0 : y.urls,
1718
+ campaignId: (d = o.leads) == null ? void 0 : d.campaignId,
1719
+ campaignName: (g = o.leads) == null ? void 0 : g.campaignName,
1720
+ fields: (B = o.leads) == null ? void 0 : B.fields,
1721
+ leadTitle: (f = o.poll.labels) == null ? void 0 : f.leadTitle,
1722
+ leadDescription: (P = o.poll.labels) == null ? void 0 : P.leadDescription,
1723
+ leadCta: (T = o.poll.labels) == null ? void 0 : T.leadCta,
1724
+ leadSuccessTitle: (h = o.poll.labels) == null ? void 0 : h.leadSuccessTitle,
1725
+ leadSuccessDescription: (C = o.poll.labels) == null ? void 0 : C.leadSuccessDescription,
1726
+ syncWithProfile: (k = o.leads) == null ? void 0 : k.syncWithProfile
1727
+ }
1728
+ ) }),
1729
+ q ? /* @__PURE__ */ n.jsx(l, { sx: { display: V ? "block" : "none" }, children: po(N) }) : /* @__PURE__ */ n.jsx(n.Fragment, {})
1730
+ ] }) : /* @__PURE__ */ n.jsx(n.Fragment, { children: /* @__PURE__ */ n.jsxs(l, { sx: Q.mainContentContainer, children: [
1731
+ o.poll.alternativeTitle ? /* @__PURE__ */ n.jsx(l, { sx: Q.alternativeTitleSection, children: /* @__PURE__ */ n.jsx(
1732
+ K,
1733
+ {
1734
+ level: "body-lg",
1735
+ sx: Q.alternativeTitleText,
1736
+ children: o.poll.alternativeTitle
1737
+ }
1738
+ ) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
1739
+ /* @__PURE__ */ n.jsx(
1740
+ Yo,
1741
+ {
1742
+ options: o.options || [],
1743
+ answerPoll: o.answerPoll,
1744
+ selectedOptions: o.selectedOptions,
1745
+ optionsLayout: V ? "column" : H ?? "twoByTwo",
1746
+ brandingColors: F,
1747
+ optionsImages: R,
1748
+ multipleChoice: o.poll.multipleChoice,
1749
+ maxChoices: o.optionChoices,
1750
+ isVoting: o.isVoting
1751
+ }
1752
+ ),
1753
+ oo ? /* @__PURE__ */ n.jsxs(
1754
+ l,
1755
+ {
1756
+ sx: {
1757
+ display: "flex",
1758
+ flexDirection: V ? "column-reverse" : "row",
1759
+ gap: lo.lg,
1760
+ justifyContent: q ? "space-between" : "center"
1761
+ },
1762
+ children: [
1763
+ po(
1764
+ (F == null ? void 0 : F.contentColor) || N
1765
+ ),
1766
+ /* @__PURE__ */ n.jsx(
1767
+ Wo,
1768
+ {
1769
+ selectedOptions: o.selectedOptions,
1770
+ label: no,
1771
+ buttonColor: ao,
1772
+ onClick: o.voteForPoll,
1773
+ isVoting: o.isVoting
1774
+ }
1775
+ )
1776
+ ]
1777
+ }
1778
+ ) : /* @__PURE__ */ n.jsx(n.Fragment, { children: /* @__PURE__ */ n.jsxs(l, { sx: Q.buttonFooterContainer, children: [
1779
+ /* @__PURE__ */ n.jsx(
1780
+ Wo,
1781
+ {
1782
+ selectedOptions: o.selectedOptions,
1783
+ label: no,
1784
+ buttonColor: ao,
1785
+ onClick: o.voteForPoll,
1786
+ isVoting: o.isVoting
1787
+ }
1788
+ ),
1789
+ q && !V ? /* @__PURE__ */ n.jsx(l, { sx: Q.presentedByMobile, children: po(
1790
+ (F == null ? void 0 : F.contentColor) || N
1791
+ ) }) : /* @__PURE__ */ n.jsx(n.Fragment, {})
1792
+ ] }) })
1793
+ ] }) })
1794
+ ] }) })
1795
+ }
1796
+ ),
1797
+ q && V && /* @__PURE__ */ n.jsx(l, { sx: { mb: lo.lg, px: lo.lg }, children: po(
1798
+ (F == null ? void 0 : F.contentColor) || u.colorSchemes.dark.textColor,
1799
+ !0
1800
+ ) })
1801
+ ]
1802
+ }
1803
+ );
1804
+ }, Ln = (o) => {
1805
+ const A = Y(), i = J(), e = Do().size, a = j(), r = Z(), t = a.palette.primary.plainColor, s = a.textPrimary, p = a.textSecondary, c = a.secondaryContainer, U = a.surface, m = a.onSurface, x = `rgba(${go(a.surfaceVariant)}, 0.5)`;
1806
+ return {
1807
+ // Question area
1808
+ questionArea: {
1809
+ display: "flex",
1810
+ flexDirection: "column",
1811
+ px: o.spacingScale.md
1812
+ },
1813
+ // Question container
1814
+ questionContainer: {
1815
+ display: "flex",
1816
+ flexDirection: "column",
1817
+ gap: i ? o.spacingScale.lg : o.spacingScale.md
1818
+ },
1819
+ // Question content container
1820
+ questionContentContainer: {
1821
+ borderRadius: A.md,
1822
+ px: o.spacingScale.md,
1823
+ pt: o.spacingScale.md,
1824
+ pb: o.spacingScale.lg,
1825
+ gap: o.spacingScale.md,
1826
+ bgcolor: x,
1827
+ display: "flex",
1828
+ flexDirection: "column",
1829
+ backdropFilter: "blur(4px)"
1830
+ },
1831
+ // Vote again button
1832
+ voteAgainButton: {
1833
+ display: "flex",
1834
+ py: o.spacingScale.xs,
1835
+ px: "16px",
1836
+ flexDirection: "column",
1837
+ justifyContent: "center",
1838
+ alignItems: "center",
1839
+ gap: "8px",
1840
+ borderRadius: A.xl,
1841
+ border: e + " solid " + t,
1842
+ bgcolor: U,
1843
+ "&:hover": {
1844
+ bgcolor: m,
1845
+ borderColor: t
1846
+ },
1847
+ fontSize: "0.8125em"
1848
+ },
1849
+ // Play again button content
1850
+ playAgainButtonContent: {
1851
+ display: "flex",
1852
+ justifyContent: "center",
1853
+ alignItems: "center",
1854
+ gap: "8px",
1855
+ alignSelf: "stretch"
1856
+ },
1857
+ // Play again icon
1858
+ playAgainIcon: {
1859
+ display: "flex",
1860
+ width: "16px",
1861
+ height: "16px",
1862
+ justifyContent: "flex-end",
1863
+ alignItems: "center",
1864
+ color: s
1865
+ },
1866
+ // Play again text
1867
+ playAgainText: {
1868
+ color: s,
1869
+ textAlign: "center",
1870
+ fontFamily: r.primary,
1871
+ fontSize: "0.8125em",
1872
+ fontStyle: "normal",
1873
+ fontWeight: 500,
1874
+ lineHeight: "22px",
1875
+ letterSpacing: "0.46px",
1876
+ textTransform: "uppercase"
1877
+ },
1878
+ // Additional CTA button (secondary style)
1879
+ additionalCTAButton: {
1880
+ display: "flex",
1881
+ py: o.spacingScale.xs,
1882
+ px: o.spacingScale.md,
1883
+ flexDirection: "column",
1884
+ justifyContent: "center",
1885
+ alignItems: "center",
1886
+ gap: "8px",
1887
+ borderRadius: A.xl,
1888
+ border: e + " solid " + c,
1889
+ bgcolor: c,
1890
+ "&:hover": {
1891
+ bgcolor: c,
1892
+ opacity: 0.9
1893
+ },
1894
+ fontSize: "0.8125em"
1895
+ },
1896
+ // Additional CTA button content
1897
+ additionalCTAButtonContent: {
1898
+ display: "flex",
1899
+ justifyContent: "center",
1900
+ alignItems: "center",
1901
+ gap: "8px"
1902
+ },
1903
+ // Additional CTA text
1904
+ additionalCTAText: {
1905
+ color: p,
1906
+ fontFamily: r.primary,
1907
+ fontSize: "0.8125em",
1908
+ fontStyle: "normal",
1909
+ fontWeight: 500,
1910
+ lineHeight: "22px",
1911
+ letterSpacing: "0.46px",
1912
+ textTransform: "uppercase"
1913
+ },
1914
+ // Footer container
1915
+ footerContainer: {
1916
+ display: "flex",
1917
+ flexDirection: i ? "column" : "row",
1918
+ justifyContent: "space-between",
1919
+ alignItems: "center",
1920
+ gap: o.spacingScale.lg
1921
+ },
1922
+ // Footer container (no logo)
1923
+ footerContainerNoLogo: {
1924
+ display: "flex",
1925
+ flexDirection: i ? "column" : "row",
1926
+ justifyContent: "flex-end",
1927
+ alignItems: "center",
1928
+ gap: o.spacingScale.lg
1929
+ },
1930
+ // Presented by desktop
1931
+ presentedByDesktop: {
1932
+ display: i ? "none" : "block"
1933
+ },
1934
+ // Presented by mobile
1935
+ presentedByMobile: {
1936
+ display: i ? "block" : "none"
1937
+ },
1938
+ // Alternative title section
1939
+ alternativeTitleSection: {
1940
+ gap: "8px",
1941
+ display: "flex",
1942
+ justifyContent: "center"
1943
+ },
1944
+ // Alternative title text
1945
+ alternativeTitleText: {
1946
+ fontFamily: r.primary,
1947
+ lineHeight: "150%",
1948
+ letterSpacing: "0.15px",
1949
+ fontWeight: 500,
1950
+ fontSize: "1.25em",
1951
+ textAlign: "center",
1952
+ color: o.textColor
1953
+ }
1954
+ };
1955
+ }, $n = (o, A) => {
1956
+ switch (o) {
1957
+ case "success":
1958
+ return /* @__PURE__ */ n.jsx(un, {});
1959
+ case "error":
1960
+ return /* @__PURE__ */ n.jsx(yn, { sx: { color: A } });
1961
+ case "info":
1962
+ return /* @__PURE__ */ n.jsx(Pn, {});
1963
+ }
1964
+ }, _n = (o) => {
1965
+ switch (o) {
1966
+ case "success":
1967
+ return "success";
1968
+ case "error":
1969
+ return "danger";
1970
+ case "info":
1971
+ return "primary";
1972
+ }
1973
+ }, Eo = ({
1974
+ variant: o,
1975
+ title: A,
1976
+ message: i,
1977
+ description: e
1978
+ }) => {
1979
+ const a = X(), r = Y(), t = Z().secondary, s = _n(o);
1980
+ return /* @__PURE__ */ n.jsx(
1981
+ vn,
1982
+ {
1983
+ variant: "soft",
1984
+ color: s,
1985
+ startDecorator: $n(
1986
+ o,
1987
+ a.colorSchemes.light.palette.danger.plainColor
1988
+ ),
1989
+ sx: {
1990
+ gap: 1,
1991
+ borderRadius: r.sm,
1992
+ fontSize: "0.875em",
1993
+ "--Icon-fontSize": "1.25em"
1994
+ },
1995
+ children: /* @__PURE__ */ n.jsxs(
1996
+ On,
1997
+ {
1998
+ sx: {
1999
+ fontSize: "1.5em"
2000
+ },
2001
+ children: [
2002
+ A && /* @__PURE__ */ n.jsx(
2003
+ K,
2004
+ {
2005
+ level: "title-md",
2006
+ color: s,
2007
+ fontWeight: "bold",
2008
+ sx: { fontFamily: t, fontSize: "0.875em" },
2009
+ children: A
2010
+ }
2011
+ ),
2012
+ /* @__PURE__ */ n.jsx(
2013
+ K,
2014
+ {
2015
+ level: "body-sm",
2016
+ sx: { fontFamily: t, fontSize: "0.675em" },
2017
+ children: i
2018
+ }
2019
+ ),
2020
+ e && /* @__PURE__ */ n.jsx(
2021
+ K,
2022
+ {
2023
+ level: "body-xs",
2024
+ sx: { fontFamily: t, fontSize: "0.6em" },
2025
+ children: e
2026
+ }
2027
+ )
2028
+ ]
2029
+ }
2030
+ )
2031
+ }
2032
+ );
2033
+ }, zo = mn(/* @__PURE__ */ n.jsx("path", {
2034
+ d: "M16 11c1.66 0 2.99-1.34 2.99-3S17.66 5 16 5s-3 1.34-3 3 1.34 3 3 3m-8 0c1.66 0 2.99-1.34 2.99-3S9.66 5 8 5 5 6.34 5 8s1.34 3 3 3m0 2c-2.33 0-7 1.17-7 3.5V19h14v-2.5c0-2.33-4.67-3.5-7-3.5m8 0c-.29 0-.62.02-.97.05 1.16.84 1.97 1.97 1.97 3.45V19h6v-2.5c0-2.33-4.67-3.5-7-3.5"
2035
+ }), "People"), Jo = (o) => {
2036
+ var A;
2037
+ const [i, e] = M.useState(0), a = X(), r = j(), t = Y().sm, s = Z(), p = Y().xs, c = L(), U = o.optionsImages.get(o.option.id), m = o.selectedOptions.includes(o.option.id), x = ((A = o.brandingColors) == null ? void 0 : A.primaryColor) || r.palette.primary.plainColor, y = r.palette.primary.onPrimary, d = m ? y : a.colorSchemes.light.textColor, g = o.option.votes, B = o.totalVotes > 0 ? g / o.totalVotes * 100 : 0;
2038
+ M.useEffect(() => {
2039
+ const P = setTimeout(() => {
2040
+ e(B);
2041
+ }, 100);
2042
+ return () => clearTimeout(P);
2043
+ }, [B]);
2044
+ const f = () => U ? /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
2045
+ /* @__PURE__ */ n.jsx(
2046
+ l,
2047
+ {
2048
+ sx: {
2049
+ borderRadius: p,
2050
+ overflow: "hidden",
2051
+ flexGrow: 1,
2052
+ mb: c["2xs"]
2053
+ },
2054
+ children: /* @__PURE__ */ n.jsx(Qo, { ratio: "16/9", sx: { borderRadius: p }, children: /* @__PURE__ */ n.jsx(
2055
+ "img",
2056
+ {
2057
+ src: U,
2058
+ alt: "Option illustration",
2059
+ style: {
2060
+ width: "100%",
2061
+ height: "100%",
2062
+ objectFit: "cover"
2063
+ }
2064
+ }
2065
+ ) })
2066
+ }
2067
+ ),
2068
+ /* @__PURE__ */ n.jsxs(
2069
+ l,
2070
+ {
2071
+ sx: {
2072
+ display: "flex",
2073
+ alignItems: "center",
2074
+ justifyContent: "center",
2075
+ gap: c["2xs"],
2076
+ my: c["2xs"]
2077
+ },
2078
+ children: [
2079
+ /* @__PURE__ */ n.jsx(
2080
+ zo,
2081
+ {
2082
+ sx: {
2083
+ fontSize: 12,
2084
+ color: m ? y : a.colorSchemes.light.textColor
2085
+ }
2086
+ }
2087
+ ),
2088
+ /* @__PURE__ */ n.jsxs(
2089
+ K,
2090
+ {
2091
+ level: "body-sm",
2092
+ sx: {
2093
+ fontSize: "0.7em",
2094
+ fontWeight: 500,
2095
+ color: m ? y : a.colorSchemes.light.textColor,
2096
+ fontFamily: s.secondary,
2097
+ whiteSpace: "nowrap",
2098
+ lineHeight: 1
2099
+ },
2100
+ children: [
2101
+ g.toLocaleString(),
2102
+ " (",
2103
+ B.toFixed(1),
2104
+ "%)"
2105
+ ]
2106
+ }
2107
+ )
2108
+ ]
2109
+ }
2110
+ ),
2111
+ /* @__PURE__ */ n.jsx(
2112
+ K,
2113
+ {
2114
+ level: "body-md",
2115
+ sx: {
2116
+ fontFamily: s.primary,
2117
+ fontWeight: 500,
2118
+ fontSize: "0.935em",
2119
+ lineHeight: "24px",
2120
+ letterSpacing: "0.46px",
2121
+ textAlign: "center",
2122
+ color: d,
2123
+ px: c["2xs"]
2124
+ },
2125
+ children: o.option.title
2126
+ }
2127
+ )
2128
+ ] }) : /* @__PURE__ */ n.jsxs(
2129
+ l,
2130
+ {
2131
+ sx: {
2132
+ position: "relative",
2133
+ zIndex: 1,
2134
+ display: "flex",
2135
+ gap: c.xs
2136
+ },
2137
+ children: [
2138
+ /* @__PURE__ */ n.jsxs(
2139
+ l,
2140
+ {
2141
+ sx: {
2142
+ display: "flex",
2143
+ flexDirection: "column",
2144
+ justifyContent: "center",
2145
+ gap: c["2xs"],
2146
+ flexShrink: 0,
2147
+ minWidth: "fit-content"
2148
+ },
2149
+ children: [
2150
+ /* @__PURE__ */ n.jsxs(
2151
+ l,
2152
+ {
2153
+ sx: {
2154
+ display: "flex",
2155
+ alignItems: "center",
2156
+ gap: c["2xs"]
2157
+ },
2158
+ children: [
2159
+ /* @__PURE__ */ n.jsx(
2160
+ zo,
2161
+ {
2162
+ sx: {
2163
+ fontSize: 12,
2164
+ color: m ? y : a.colorSchemes.light.textColor
2165
+ }
2166
+ }
2167
+ ),
2168
+ /* @__PURE__ */ n.jsx(
2169
+ K,
2170
+ {
2171
+ level: "body-sm",
2172
+ sx: {
2173
+ fontSize: "0.7em",
2174
+ fontWeight: 500,
2175
+ color: m ? y : a.colorSchemes.light.textColor,
2176
+ fontFamily: s.secondary,
2177
+ whiteSpace: "nowrap",
2178
+ lineHeight: 0
2179
+ },
2180
+ children: g.toLocaleString()
2181
+ }
2182
+ )
2183
+ ]
2184
+ }
2185
+ ),
2186
+ /* @__PURE__ */ n.jsxs(
2187
+ K,
2188
+ {
2189
+ level: "body-sm",
2190
+ sx: {
2191
+ fontSize: "0.65em",
2192
+ fontWeight: 400,
2193
+ color: m ? y : a.colorSchemes.light.textColor,
2194
+ fontFamily: s.secondary,
2195
+ whiteSpace: "nowrap",
2196
+ lineHeight: 1,
2197
+ textAlign: "center"
2198
+ },
2199
+ children: [
2200
+ "(",
2201
+ B.toFixed(1),
2202
+ "%)"
2203
+ ]
2204
+ }
2205
+ )
2206
+ ]
2207
+ }
2208
+ ),
2209
+ /* @__PURE__ */ n.jsx(
2210
+ l,
2211
+ {
2212
+ sx: {
2213
+ display: "flex",
2214
+ alignItems: "center",
2215
+ flex: 1,
2216
+ minWidth: 0,
2217
+ gap: c.xs
2218
+ },
2219
+ children: /* @__PURE__ */ n.jsx(
2220
+ K,
2221
+ {
2222
+ level: "body-md",
2223
+ sx: {
2224
+ fontFamily: s.primary,
2225
+ fontWeight: 500,
2226
+ fontSize: "0.935em",
2227
+ lineHeight: "16px",
2228
+ letterSpacing: "0.46px",
2229
+ color: d,
2230
+ flex: 1,
2231
+ minWidth: 0,
2232
+ wordBreak: "break-word",
2233
+ hyphens: "auto",
2234
+ textAlign: "center"
2235
+ },
2236
+ children: o.option.title
2237
+ }
2238
+ )
2239
+ }
2240
+ )
2241
+ ]
2242
+ }
2243
+ );
2244
+ return /* @__PURE__ */ n.jsxs(
2245
+ l,
2246
+ {
2247
+ sx: {
2248
+ borderRadius: t,
2249
+ flex: 1,
2250
+ p: c.xs,
2251
+ bgcolor: m ? x : "#FFFFFF",
2252
+ display: "flex",
2253
+ flexDirection: "column",
2254
+ position: "relative",
2255
+ overflow: "hidden",
2256
+ justifyContent: "center"
2257
+ },
2258
+ children: [
2259
+ /* @__PURE__ */ n.jsx(
2260
+ l,
2261
+ {
2262
+ sx: {
2263
+ position: "absolute",
2264
+ top: 0,
2265
+ left: 0,
2266
+ height: "100%",
2267
+ width: `${i}%`,
2268
+ bgcolor: m ? r.palette.primary.primaryContainer : a.mode === "light" ? "rgba(0, 0, 0, 0.1)" : "rgba(0, 0, 0, 0.2)",
2269
+ transition: "width 0.8s ease-out",
2270
+ zIndex: 0
2271
+ }
2272
+ }
2273
+ ),
2274
+ f()
2275
+ ]
2276
+ },
2277
+ o.option.id
2278
+ );
2279
+ }, No = (o) => {
2280
+ const { t: A } = G(), i = L(), e = j(), a = Z(), r = Do().size, t = o.options.reduce(
2281
+ (s, p) => s + (p.votes || 0),
2282
+ 0
2283
+ );
2284
+ if (o.optionsLayout === "twoByTwo") {
2285
+ const s = [];
2286
+ for (let p = 0; p < o.options.length; p += 2) {
2287
+ const c = o.options.slice(p, p + 2);
2288
+ s.push(c);
2289
+ }
2290
+ return /* @__PURE__ */ n.jsxs(
2291
+ l,
2292
+ {
2293
+ sx: { display: "flex", flexDirection: "column", gap: i.md },
2294
+ children: [
2295
+ /* @__PURE__ */ n.jsx(l, { sx: { py: 2, display: "flex", flexDirection: "column", gap: 2 }, children: s.map((p, c) => /* @__PURE__ */ n.jsx(
2296
+ l,
2297
+ {
2298
+ sx: {
2299
+ display: "flex",
2300
+ flexDirection: {
2301
+ xs: "column",
2302
+ md: "row"
2303
+ },
2304
+ gap: 2
2305
+ },
2306
+ children: p.map((U) => /* @__PURE__ */ n.jsx(
2307
+ Jo,
2308
+ {
2309
+ option: U,
2310
+ optionsImages: o.optionsImages,
2311
+ selectedOptions: o.selectedOptions,
2312
+ brandingColors: o.brandingColors,
2313
+ totalVotes: t
2314
+ },
2315
+ U.id
2316
+ ))
2317
+ },
2318
+ `row-${c}`
2319
+ )) }),
2320
+ /* @__PURE__ */ n.jsxs(
2321
+ l,
2322
+ {
2323
+ sx: {
2324
+ display: "flex",
2325
+ alignItems: "center",
2326
+ justifyContent: "center",
2327
+ gap: i.xs,
2328
+ pt: i.md,
2329
+ borderTop: `${r} solid`,
2330
+ borderColor: j().outlineEnabledBorder
2331
+ },
2332
+ children: [
2333
+ /* @__PURE__ */ n.jsx(
2334
+ zo,
2335
+ {
2336
+ sx: {
2337
+ fontSize: 18,
2338
+ color: e.textColor
2339
+ }
2340
+ }
2341
+ ),
2342
+ /* @__PURE__ */ n.jsxs(
2343
+ K,
2344
+ {
2345
+ level: "body-sm",
2346
+ sx: {
2347
+ color: e.textColor,
2348
+ fontWeight: 500,
2349
+ fontFamily: a.secondary
2350
+ },
2351
+ children: [
2352
+ t.toLocaleString(),
2353
+ " ",
2354
+ A("poll.totalVotes")
2355
+ ]
2356
+ }
2357
+ )
2358
+ ]
2359
+ }
2360
+ )
2361
+ ]
2362
+ }
2363
+ );
2364
+ }
2365
+ return o.optionsLayout === "column" ? /* @__PURE__ */ n.jsxs(
2366
+ l,
2367
+ {
2368
+ sx: { display: "flex", flexDirection: "column", gap: i.md },
2369
+ children: [
2370
+ /* @__PURE__ */ n.jsx(l, { sx: { py: 2, display: "flex", flexDirection: "column", gap: 2 }, children: o.options.map((s) => /* @__PURE__ */ n.jsx(
2371
+ Jo,
2372
+ {
2373
+ option: s,
2374
+ selectedOptions: o.selectedOptions,
2375
+ optionsImages: o.optionsImages,
2376
+ brandingColors: o.brandingColors,
2377
+ totalVotes: t
2378
+ },
2379
+ s.id
2380
+ )) }),
2381
+ /* @__PURE__ */ n.jsxs(
2382
+ l,
2383
+ {
2384
+ sx: {
2385
+ display: "flex",
2386
+ alignItems: "center",
2387
+ justifyContent: "center",
2388
+ gap: i.xs,
2389
+ pt: i.md,
2390
+ borderTop: `${r} solid`,
2391
+ borderColor: j().outlineEnabledBorder
2392
+ },
2393
+ children: [
2394
+ /* @__PURE__ */ n.jsx(
2395
+ zo,
2396
+ {
2397
+ sx: {
2398
+ fontSize: 18,
2399
+ color: e.textColor
2400
+ }
2401
+ }
2402
+ ),
2403
+ /* @__PURE__ */ n.jsxs(
2404
+ K,
2405
+ {
2406
+ level: "body-sm",
2407
+ sx: {
2408
+ color: e.textColor,
2409
+ fontWeight: 500,
2410
+ fontFamily: a.secondary
2411
+ },
2412
+ children: [
2413
+ t.toLocaleString(),
2414
+ " ",
2415
+ A("poll.totalVotes")
2416
+ ]
2417
+ }
2418
+ )
2419
+ ]
2420
+ }
2421
+ )
2422
+ ]
2423
+ }
2424
+ ) : /* @__PURE__ */ n.jsxs(
2425
+ l,
2426
+ {
2427
+ sx: { display: "flex", flexDirection: "column", gap: i.md },
2428
+ children: [
2429
+ /* @__PURE__ */ n.jsx(
2430
+ l,
2431
+ {
2432
+ sx: {
2433
+ py: 2,
2434
+ display: "flex",
2435
+ flexWrap: "wrap",
2436
+ flexDirection: { xs: "column", md: "row" },
2437
+ gap: 2
2438
+ },
2439
+ children: o.options.map((s) => /* @__PURE__ */ n.jsx(
2440
+ Jo,
2441
+ {
2442
+ option: s,
2443
+ selectedOptions: o.selectedOptions,
2444
+ optionsImages: o.optionsImages,
2445
+ brandingColors: o.brandingColors,
2446
+ totalVotes: t
2447
+ },
2448
+ s.id
2449
+ ))
2450
+ }
2451
+ ),
2452
+ /* @__PURE__ */ n.jsxs(
2453
+ l,
2454
+ {
2455
+ sx: {
2456
+ display: "flex",
2457
+ alignItems: "center",
2458
+ justifyContent: "center",
2459
+ gap: i.xs,
2460
+ pt: i.md,
2461
+ borderTop: `${r} solid`,
2462
+ borderColor: j().outlineEnabledBorder
2463
+ },
2464
+ children: [
2465
+ /* @__PURE__ */ n.jsx(
2466
+ zo,
2467
+ {
2468
+ sx: {
2469
+ fontSize: 18,
2470
+ color: e.textColor
2471
+ }
2472
+ }
2473
+ ),
2474
+ /* @__PURE__ */ n.jsxs(
2475
+ K,
2476
+ {
2477
+ level: "body-sm",
2478
+ sx: {
2479
+ color: e.textColor,
2480
+ fontWeight: 500,
2481
+ fontFamily: a.secondary
2482
+ },
2483
+ children: [
2484
+ t.toLocaleString(),
2485
+ " ",
2486
+ A("poll.totalVotes")
2487
+ ]
2488
+ }
2489
+ )
2490
+ ]
2491
+ }
2492
+ )
2493
+ ]
2494
+ }
2495
+ );
2496
+ }, oA = (o) => {
2497
+ var A, i, e, a;
2498
+ const r = eo(
2499
+ {
2500
+ images: o.poll.images,
2501
+ imagePlaceholder: o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : ""
2502
+ },
2503
+ I.STANDARD
2504
+ ), { optionsLayout: t } = mo(Po), { t: s } = G(), p = ((A = o.poll.branding) == null ? void 0 : A.colors) || null, c = J() ? ((i = o.poll.branding) == null ? void 0 : i.images.mobileLogo) || ((e = o.poll.branding) == null ? void 0 : e.images.mainLogo) || "" : ((a = o.poll.branding) == null ? void 0 : a.images.mainLogo) || "", U = o.imagePosition || "left", m = uo(o.poll.options), x = (p == null ? void 0 : p.contentColor) || j().textColor, y = L(), d = Ln({
2505
+ spacingScale: y,
2506
+ textColor: x
2507
+ }), g = () => {
2508
+ var B, f, P, T, h;
2509
+ return /* @__PURE__ */ n.jsx(n.Fragment, { children: o.isUnauthorized ? /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
2510
+ /* @__PURE__ */ n.jsx(
2511
+ Eo,
2512
+ {
2513
+ variant: "error",
2514
+ title: s("common.authentication.accessRequired"),
2515
+ message: s("common.authentication.invalidOrMissingAuth")
2516
+ }
2517
+ ),
2518
+ c ? /* @__PURE__ */ n.jsx(
2519
+ w,
2520
+ {
2521
+ brandingLogo: c,
2522
+ textColor: x,
2523
+ label: ((h = o.poll.labels) == null ? void 0 : h.sponsor) || null
2524
+ }
2525
+ ) : /* @__PURE__ */ n.jsx(n.Fragment, {})
2526
+ ] }) : /* @__PURE__ */ n.jsxs(n.Fragment, { children: [
2527
+ /* @__PURE__ */ n.jsx(l, { sx: d.questionArea, children: /* @__PURE__ */ n.jsx(l, { sx: d.questionContainer, children: /* @__PURE__ */ n.jsxs(l, { sx: d.questionContentContainer, children: [
2528
+ o.poll.alternativeTitle ? /* @__PURE__ */ n.jsx(l, { sx: d.alternativeTitleSection, children: /* @__PURE__ */ n.jsx(
2529
+ K,
2530
+ {
2531
+ level: "body-lg",
2532
+ sx: d.alternativeTitleText,
2533
+ children: o.poll.alternativeTitle
2534
+ }
2535
+ ) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
2536
+ /* @__PURE__ */ n.jsx(
2537
+ No,
2538
+ {
2539
+ options: o.poll.options,
2540
+ selectedOptions: ((B = o.userVote) == null ? void 0 : B.optionIds) || [],
2541
+ optionsLayout: t ?? "twoByTwo",
2542
+ optionsImages: m,
2543
+ brandingColors: ((f = o.poll.branding) == null ? void 0 : f.colors) || null
2544
+ }
2545
+ )
2546
+ ] }) }) }),
2547
+ /* @__PURE__ */ n.jsx(l, { sx: d.questionArea, children: /* @__PURE__ */ n.jsxs(l, { sx: d.questionContainer, children: [
2548
+ /* @__PURE__ */ n.jsxs(
2549
+ l,
2550
+ {
2551
+ sx: c ? d.footerContainer : d.footerContainerNoLogo,
2552
+ children: [
2553
+ c ? /* @__PURE__ */ n.jsx(l, { sx: d.presentedByDesktop, children: /* @__PURE__ */ n.jsx(
2554
+ w,
2555
+ {
2556
+ brandingLogo: c,
2557
+ textColor: x,
2558
+ label: ((P = o.poll.labels) == null ? void 0 : P.sponsor) || null
2559
+ }
2560
+ ) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
2561
+ /* @__PURE__ */ n.jsxs(
2562
+ l,
2563
+ {
2564
+ sx: {
2565
+ display: "flex",
2566
+ gap: "16px"
2567
+ },
2568
+ children: [
2569
+ /* @__PURE__ */ n.jsx(
2570
+ Zo,
2571
+ {
2572
+ additionalCTA: o.additionalCTA,
2573
+ buttonStyle: d.additionalCTAButton,
2574
+ buttonContentStyle: d.additionalCTAButtonContent,
2575
+ textStyle: d.additionalCTAText
2576
+ }
2577
+ ),
2578
+ o.maxAttemptsReached ? /* @__PURE__ */ n.jsx(n.Fragment, {}) : /* @__PURE__ */ n.jsx(
2579
+ W,
2580
+ {
2581
+ sx: d.voteAgainButton,
2582
+ onClick: o.voteAgain,
2583
+ children: /* @__PURE__ */ n.jsxs(l, { sx: d.playAgainButtonContent, children: [
2584
+ /* @__PURE__ */ n.jsx(Go, { sx: d.playAgainIcon }),
2585
+ /* @__PURE__ */ n.jsx(K, { sx: d.playAgainText, children: s("poll.buttons.voteAgain") })
2586
+ ] })
2587
+ }
2588
+ )
2589
+ ]
2590
+ }
2591
+ )
2592
+ ]
2593
+ }
2594
+ ),
2595
+ c ? /* @__PURE__ */ n.jsx(l, { sx: d.presentedByMobile, children: /* @__PURE__ */ n.jsx(
2596
+ w,
2597
+ {
2598
+ brandingLogo: c,
2599
+ textColor: x,
2600
+ label: ((T = o.poll.labels) == null ? void 0 : T.sponsor) || null
2601
+ }
2602
+ ) }) : /* @__PURE__ */ n.jsx(n.Fragment, {})
2603
+ ] }) })
2604
+ ] }) });
2605
+ };
2606
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (p == null ? void 0 : p.borderColor) || null, children: /* @__PURE__ */ n.jsx(
2607
+ wn,
2608
+ {
2609
+ entity: o.poll,
2610
+ headline: s("poll.headline"),
2611
+ finalImage: r,
2612
+ imagePosition: U,
2613
+ rulesDisplay: o.rulesDisplay,
2614
+ children: g()
2615
+ }
2616
+ ) });
2617
+ }, nA = (o) => ({
2618
+ // Question area content wrapper
2619
+ questionAreaContent: {
2620
+ p: o.spacingScale.lg,
2621
+ display: "flex",
2622
+ flexDirection: "column",
2623
+ justifyContent: "center",
2624
+ gap: o.spacingScale.lg,
2625
+ flex: 1,
2626
+ height: "100%"
2627
+ },
2628
+ // Alternative title section
2629
+ alternativeTitleSection: {
2630
+ gap: "8px",
2631
+ display: "flex",
2632
+ justifyContent: "center"
2633
+ },
2634
+ // Alternative title text
2635
+ alternativeTitleText: {
2636
+ fontFamily: o.fontFamilyPrimary,
2637
+ lineHeight: "150%",
2638
+ letterSpacing: "0.15px",
2639
+ fontWeight: 500,
2640
+ fontSize: "1.25em",
2641
+ textAlign: "center",
2642
+ color: o.textColor
2643
+ },
2644
+ // CTA container
2645
+ ctaContainer: {
2646
+ display: "flex",
2647
+ flexDirection: "column",
2648
+ alignItems: "center"
2649
+ },
2650
+ // CTA content wrapper
2651
+ ctaContentWrapper: {
2652
+ display: "flex",
2653
+ flexDirection: "column",
2654
+ justifyContent: "center",
2655
+ alignItems: "center",
2656
+ gap: o.spacingScale.lg
2657
+ },
2658
+ // Thanks for playing text
2659
+ thanksText: {
2660
+ color: o.textPrimary,
2661
+ textAlign: "center",
2662
+ fontFamily: o.fontFamilyPrimary,
2663
+ fontSize: "1.25em",
2664
+ fontStyle: "normal",
2665
+ fontWeight: 500,
2666
+ lineHeight: "120%",
2667
+ letterSpacing: "0.15px"
2668
+ },
2669
+ // Buttons container
2670
+ buttonsContainer: {
2671
+ display: "flex",
2672
+ flexDirection: "column",
2673
+ gap: "16px"
2674
+ },
2675
+ // Play again button
2676
+ playAgainButton: {
2677
+ display: "flex",
2678
+ py: o.spacingScale.xs,
2679
+ px: "16px",
2680
+ flexDirection: "column",
2681
+ justifyContent: "center",
2682
+ alignItems: "center",
2683
+ gap: "8px",
2684
+ borderRadius: o.borderRadius.xl,
2685
+ color: o.textPrimary,
2686
+ bgcolor: o.surfaceColor,
2687
+ "&:hover": {
2688
+ bgcolor: o.onSurfaceColor
2689
+ },
2690
+ fontSize: "0.9375em"
2691
+ },
2692
+ // Play again button content
2693
+ playAgainButtonContent: {
2694
+ display: "flex",
2695
+ justifyContent: "center",
2696
+ alignItems: "center",
2697
+ gap: "8px",
2698
+ alignSelf: "stretch"
2699
+ },
2700
+ // Play again icon
2701
+ playAgainIcon: {
2702
+ display: "flex",
2703
+ width: "16px",
2704
+ height: "16px",
2705
+ justifyContent: "flex-end",
2706
+ alignItems: "center",
2707
+ color: o.textPrimary
2708
+ },
2709
+ // Play again text
2710
+ playAgainText: {
2711
+ color: o.textPrimary,
2712
+ textAlign: "center",
2713
+ fontFamily: o.fontFamilyPrimary,
2714
+ fontSize: "0.9375em",
2715
+ fontStyle: "normal",
2716
+ fontWeight: 500,
2717
+ lineHeight: "22px",
2718
+ letterSpacing: "0.46px",
2719
+ textTransform: "uppercase"
2720
+ },
2721
+ // Additional CTA button (secondary style)
2722
+ additionalCTAButton: {
2723
+ display: "flex",
2724
+ py: o.spacingScale.xs,
2725
+ px: o.spacingScale.md,
2726
+ flexDirection: "column",
2727
+ justifyContent: "center",
2728
+ alignItems: "center",
2729
+ gap: "8px",
2730
+ borderRadius: o.borderRadius.xl,
2731
+ bgcolor: o.secondaryContainer,
2732
+ "&:hover": {
2733
+ bgcolor: o.secondaryContainer,
2734
+ opacity: 0.9
2735
+ },
2736
+ fontSize: "0.9375em"
2737
+ },
2738
+ // Additional CTA button content
2739
+ additionalCTAButtonContent: {
2740
+ display: "flex",
2741
+ justifyContent: "center",
2742
+ alignItems: "center",
2743
+ gap: "8px"
2744
+ },
2745
+ // Additional CTA text
2746
+ additionalCTAText: {
2747
+ color: o.secondaryColor,
2748
+ textAlign: "center",
2749
+ fontFamily: o.fontFamilyPrimary,
2750
+ fontSize: "0.9375em",
2751
+ fontStyle: "normal",
2752
+ fontWeight: 500,
2753
+ lineHeight: "22px",
2754
+ letterSpacing: "0.46px",
2755
+ textTransform: "uppercase"
2756
+ },
2757
+ alertMessageArea: {
2758
+ flex: o.isLarge ? "1" : "0 0 50%",
2759
+ width: o.isLarge ? "100%" : "50%",
2760
+ minWidth: o.isLarge ? "100%" : "50%",
2761
+ maxWidth: o.isLarge ? "100%" : "50%",
2762
+ display: "flex",
2763
+ flexDirection: "column",
2764
+ justifyContent: "center"
2765
+ },
2766
+ alertMessageWrapper: {
2767
+ p: o.spacingScale.lg
2768
+ }
2769
+ }), AA = (o) => {
2770
+ var A, i, e, a;
2771
+ const r = X(), t = J(), s = fn(), p = bo(), c = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : t ? to : io, U = eo(
2772
+ {
2773
+ images: o.poll.images,
2774
+ imagePlaceholder: c
2775
+ },
2776
+ I.SPLIT
2777
+ ), m = uo(o.poll.options), { t: x } = G(), { optionsLayout: y } = mo(Po), d = ((A = o.poll.branding) == null ? void 0 : A.colors) || null, g = j().textPrimary, B = (d == null ? void 0 : d.secondaryColor) || j().textSecondary, f = j().secondaryContainer, P = Z().primary, T = (d == null ? void 0 : d.backgroundColor) || j().surfaceVariant, h = j().surface, C = j().onSurface, k = Y(), S = j().textColor, z = L(), H = t ? ((i = o.poll.branding) == null ? void 0 : i.images.mobileLogo) || ((e = o.poll.branding) == null ? void 0 : e.images.mainLogo) || "" : ((a = o.poll.branding) == null ? void 0 : a.images.mainLogo) || "", u = nA({
2778
+ spacingScale: z,
2779
+ borderRadius: k,
2780
+ fontFamilyPrimary: P,
2781
+ textPrimary: g,
2782
+ secondaryColor: B,
2783
+ secondaryContainer: f,
2784
+ bgcolor: go(T || ""),
2785
+ surfaceColor: h,
2786
+ onSurfaceColor: C,
2787
+ textColor: S,
2788
+ darkTextColor: r.colorSchemes.dark.textColor,
2789
+ isLarge: p
2790
+ }), D = () => {
2791
+ var V, v, O, R;
2792
+ const b = s ? /* @__PURE__ */ n.jsx(
2793
+ w,
2794
+ {
2795
+ brandingLogo: H,
2796
+ textColor: (d == null ? void 0 : d.contentColor) || r.colorSchemes.dark.textColor,
2797
+ label: ((V = o.poll.labels) == null ? void 0 : V.sponsor) || null
2798
+ }
2799
+ ) : null;
2800
+ return /* @__PURE__ */ n.jsx(
2801
+ kn,
2802
+ {
2803
+ entity: o.poll,
2804
+ headline: x("poll.headline"),
2805
+ finalImage: U,
2806
+ brandingContent: b,
2807
+ isTabulated: !1,
2808
+ alwaysShowImage: !0,
2809
+ rulesDisplay: o.rulesDisplay,
2810
+ children: o.isUnauthorized ? /* @__PURE__ */ n.jsx(l, { sx: u.alertMessageArea, children: /* @__PURE__ */ n.jsx(l, { sx: u.alertMessageWrapper, children: /* @__PURE__ */ n.jsx(
2811
+ Eo,
2812
+ {
2813
+ variant: "error",
2814
+ title: x("common.authentication.accessRequired"),
2815
+ message: x("common.authentication.invalidOrMissingAuth")
2816
+ }
2817
+ ) }) }) : /* @__PURE__ */ n.jsxs(l, { sx: u.questionAreaContent, children: [
2818
+ /* @__PURE__ */ n.jsxs(
2819
+ l,
2820
+ {
2821
+ sx: {
2822
+ p: z.lg,
2823
+ gap: z.lg,
2824
+ display: "flex",
2825
+ flexDirection: "column",
2826
+ backdropFilter: "blur(4px)",
2827
+ bgcolor: `rgba(${T ? go(T || "").replace(/[^\d,]/g, "") : ""}, 0.5)`,
2828
+ borderRadius: k.sm
2829
+ },
2830
+ children: [
2831
+ o.poll.alternativeTitle ? /* @__PURE__ */ n.jsx(l, { sx: u.alternativeTitleSection, children: /* @__PURE__ */ n.jsx(K, { level: "body-lg", sx: u.alternativeTitleText, children: o.poll.alternativeTitle }) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
2832
+ /* @__PURE__ */ n.jsx(
2833
+ No,
2834
+ {
2835
+ options: o.poll.options,
2836
+ selectedOptions: ((v = o.userVote) == null ? void 0 : v.optionIds) || [],
2837
+ optionsLayout: y ?? "twoByTwo",
2838
+ optionsImages: m,
2839
+ brandingColors: ((O = o.poll.branding) == null ? void 0 : O.colors) || null
2840
+ }
2841
+ )
2842
+ ]
2843
+ }
2844
+ ),
2845
+ !o.maxAttemptsReached || o.additionalCTA !== void 0 ? /* @__PURE__ */ n.jsx(
2846
+ l,
2847
+ {
2848
+ id: "poll-desktop-thanks",
2849
+ sx: {
2850
+ p: z.lg,
2851
+ gap: z.lg,
2852
+ display: "flex",
2853
+ flexDirection: "column",
2854
+ backdropFilter: "blur(4px)",
2855
+ bgcolor: `rgba(${T ? go(T || "").replace(/[^\d,]/g, "") : ""}, 0.5)`,
2856
+ borderRadius: k.sm
2857
+ },
2858
+ children: /* @__PURE__ */ n.jsx(l, { sx: u.ctaContainer, children: /* @__PURE__ */ n.jsx(l, { sx: u.ctaContentWrapper, children: /* @__PURE__ */ n.jsxs(l, { sx: u.buttonsContainer, children: [
2859
+ !o.maxAttemptsReached && /* @__PURE__ */ n.jsx(
2860
+ W,
2861
+ {
2862
+ sx: u.playAgainButton,
2863
+ onClick: o.voteAgain,
2864
+ children: /* @__PURE__ */ n.jsxs(l, { sx: u.playAgainButtonContent, children: [
2865
+ /* @__PURE__ */ n.jsx(Go, { sx: u.playAgainIcon }),
2866
+ /* @__PURE__ */ n.jsx(K, { sx: u.playAgainText, children: x("poll.buttons.voteAgain") })
2867
+ ] })
2868
+ }
2869
+ ),
2870
+ /* @__PURE__ */ n.jsx(
2871
+ Zo,
2872
+ {
2873
+ additionalCTA: o.additionalCTA,
2874
+ buttonStyle: u.additionalCTAButton,
2875
+ buttonContentStyle: u.additionalCTAButtonContent,
2876
+ textStyle: u.additionalCTAText
2877
+ }
2878
+ )
2879
+ ] }) }) })
2880
+ }
2881
+ ) : null,
2882
+ p && H && /* @__PURE__ */ n.jsx(
2883
+ w,
2884
+ {
2885
+ brandingLogo: H,
2886
+ textColor: (d == null ? void 0 : d.contentColor) || S,
2887
+ label: ((R = o.poll.labels) == null ? void 0 : R.sponsor) || null,
2888
+ isCentered: !0
2889
+ }
2890
+ )
2891
+ ] })
2892
+ }
2893
+ );
2894
+ };
2895
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (d == null ? void 0 : d.borderColor) || null, children: D() });
2896
+ }, lA = (o) => ({
2897
+ // Main content wrapper
2898
+ mainContentWrapper: {
2899
+ display: "flex",
2900
+ flexDirection: "column",
2901
+ gap: "24px",
2902
+ zIndex: 10
2903
+ },
2904
+ resultsContainer: {
2905
+ borderRadius: o.mdBorderRadius,
2906
+ p: o.spacingScale.md,
2907
+ display: "flex",
2908
+ flexDirection: "column",
2909
+ alignItems: "center",
2910
+ alignSelf: "stretch",
2911
+ gap: o.spacingScale.md,
2912
+ backdropFilter: "blur(4px)",
2913
+ position: "relative",
2914
+ "&::before": {
2915
+ content: '""',
2916
+ position: "absolute",
2917
+ top: 0,
2918
+ left: 0,
2919
+ right: 0,
2920
+ bottom: 0,
2921
+ backgroundColor: o.contentBgColor,
2922
+ opacity: 0.25,
2923
+ borderRadius: "inherit",
2924
+ zIndex: 0,
2925
+ backdropFilter: "blur(4px)"
2926
+ },
2927
+ "& > *": {
2928
+ position: "relative",
2929
+ zIndex: 1
2930
+ }
2931
+ },
2932
+ resultsWrapper: {
2933
+ display: "flex",
2934
+ flexDirection: "column",
2935
+ justifyContent: "center",
2936
+ alignItems: "center",
2937
+ alignSelf: "stretch"
2938
+ },
2939
+ alternativeTitleSection: {
2940
+ display: "flex",
2941
+ gap: "8px",
2942
+ alignItems: "flex-start",
2943
+ justifyContent: "center"
2944
+ },
2945
+ alternativeTitleText: {
2946
+ fontFamily: o.fontFamilyPrimary,
2947
+ lineHeight: "150%",
2948
+ letterSpacing: "0.15px",
2949
+ fontWeight: 500,
2950
+ fontSize: "1.25em",
2951
+ textAlign: "center",
2952
+ color: o.darkTextColor
2953
+ },
2954
+ ctaSection: {
2955
+ borderRadius: o.mdBorderRadius,
2956
+ py: o.spacingScale.md,
2957
+ display: "flex",
2958
+ flexDirection: "column",
2959
+ alignItems: "center",
2960
+ alignSelf: "stretch",
2961
+ gap: o.spacingScale.md,
2962
+ backdropFilter: "blur(4px)",
2963
+ position: "relative",
2964
+ "&::before": {
2965
+ content: '""',
2966
+ position: "absolute",
2967
+ top: 0,
2968
+ left: 0,
2969
+ right: 0,
2970
+ bottom: 0,
2971
+ backgroundColor: o.contentBgColor,
2972
+ opacity: 0.25,
2973
+ borderRadius: "inherit",
2974
+ zIndex: 0,
2975
+ backdropFilter: "blur(4px)"
2976
+ },
2977
+ "& > *": {
2978
+ position: "relative",
2979
+ zIndex: 1
2980
+ }
2981
+ },
2982
+ // Buttons container
2983
+ buttonsContainer: {
2984
+ display: "flex",
2985
+ flexDirection: "column",
2986
+ gap: o.spacingScale.md
2987
+ },
2988
+ // Play again button
2989
+ playAgainButton: {
2990
+ display: "flex",
2991
+ minHeight: "48px",
2992
+ py: "12px",
2993
+ pr: "24px",
2994
+ pl: "16px",
2995
+ flexDirection: "column",
2996
+ justifyContent: "center",
2997
+ alignItems: "center",
2998
+ gap: "8px",
2999
+ borderRadius: o.xlBorderRadius,
3000
+ bgcolor: o.onSurfaceColor,
3001
+ "&:hover": {
3002
+ bgcolor: o.surfaceVariantColor
3003
+ },
3004
+ fontSize: "0.9375em"
3005
+ },
3006
+ // Play again button content
3007
+ playAgainButtonContent: {
3008
+ display: "flex",
3009
+ justifyContent: "center",
3010
+ alignItems: "center",
3011
+ gap: "8px",
3012
+ alignSelf: "stretch"
3013
+ },
3014
+ // Play again icon
3015
+ playAgainIcon: {
3016
+ display: "flex",
3017
+ width: "24px",
3018
+ height: "24px",
3019
+ justifyContent: "center",
3020
+ alignItems: "center",
3021
+ color: o.textPrimary
3022
+ },
3023
+ // Play again text
3024
+ playAgainText: {
3025
+ color: o.textPrimary,
3026
+ textAlign: "center",
3027
+ fontFamily: o.fontFamilyPrimary,
3028
+ fontSize: "0.9375em",
3029
+ fontStyle: "normal",
3030
+ fontWeight: 500,
3031
+ lineHeight: "24px",
3032
+ letterSpacing: "0.46px",
3033
+ textTransform: "uppercase"
3034
+ },
3035
+ // Additional CTA button (secondary style)
3036
+ additionalCTAButton: {
3037
+ display: "flex",
3038
+ py: o.spacingScale.sm,
3039
+ px: o.spacingScale.md,
3040
+ flexDirection: "column",
3041
+ justifyContent: "center",
3042
+ alignItems: "center",
3043
+ gap: "8px",
3044
+ borderRadius: o.xlBorderRadius,
3045
+ bgcolor: o.secondaryContainer,
3046
+ "&:hover": {
3047
+ bgcolor: o.secondaryContainer,
3048
+ opacity: 0.9
3049
+ },
3050
+ fontSize: "0.9375em"
3051
+ },
3052
+ // Additional CTA button content
3053
+ additionalCTAButtonContent: {
3054
+ display: "flex",
3055
+ justifyContent: "center",
3056
+ alignItems: "center",
3057
+ gap: "8px"
3058
+ },
3059
+ // Additional CTA text
3060
+ additionalCTAText: {
3061
+ color: o.secondaryColor,
3062
+ fontFamily: o.fontFamilyPrimary,
3063
+ fontSize: "0.9375em",
3064
+ fontStyle: "normal",
3065
+ fontWeight: 500,
3066
+ lineHeight: "24px",
3067
+ letterSpacing: "0.46px",
3068
+ textTransform: "uppercase"
3069
+ }
3070
+ }), eA = (o) => {
3071
+ const A = X(), i = L(), { t: e } = G(), a = bo(), r = Ho(
3072
+ I.OVERLAY
3073
+ ), { optionsLayout: t } = mo(Po), { brandingImage: s, brandingColors: p, brandingLogo: c } = Io(o.poll.branding), U = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : J() ? to : io, m = s || eo(
3074
+ {
3075
+ images: o.poll.images,
3076
+ imagePlaceholder: U
3077
+ },
3078
+ I.OVERLAY
3079
+ ), x = $o(m), y = uo(o.poll.options), d = (p == null ? void 0 : p.secondaryColor) || A.colorSchemes.dark.textSecondary, g = A.colorSchemes.dark.secondaryContainer, B = A.colorSchemes.dark.textPrimary, f = A.customFontFamily.light.primary, P = A.customRadius.light.md, T = A.customRadius.light.xl, h = (p == null ? void 0 : p.backgroundColor) || A.colorSchemes.dark.surfaceVariant, C = lA({
3080
+ spacingScale: i,
3081
+ secondaryColor: d,
3082
+ secondaryContainer: g,
3083
+ textPrimary: B,
3084
+ fontFamilyPrimary: f,
3085
+ mdBorderRadius: P,
3086
+ xlBorderRadius: T,
3087
+ contentBgColor: h,
3088
+ onSurfaceColor: A.colorSchemes.dark.onSurface,
3089
+ surfaceVariantColor: A.colorSchemes.dark.surfaceVariant,
3090
+ darkTextColor: A.colorSchemes.dark.textColor
3091
+ }), k = () => {
3092
+ var S, z, H;
3093
+ return /* @__PURE__ */ n.jsxs(l, { sx: C.mainContentWrapper, children: [
3094
+ o.isUnauthorized ? /* @__PURE__ */ n.jsx(n.Fragment, { children: /* @__PURE__ */ n.jsx(
3095
+ Eo,
3096
+ {
3097
+ variant: "error",
3098
+ title: e("common.authentication.accessRequired"),
3099
+ message: e("common.authentication.invalidOrMissingAuth")
3100
+ }
3101
+ ) }) : /* @__PURE__ */ n.jsx(l, { sx: C.resultsContainer, children: /* @__PURE__ */ n.jsxs(l, { sx: C.resultsWrapper, children: [
3102
+ o.poll.alternativeTitle ? /* @__PURE__ */ n.jsx(l, { sx: C.alternativeTitleSection, children: /* @__PURE__ */ n.jsx(K, { level: "body-lg", sx: C.alternativeTitleText, children: o.poll.alternativeTitle }) }) : /* @__PURE__ */ n.jsx(n.Fragment, {}),
3103
+ /* @__PURE__ */ n.jsx(l, { sx: { width: "100%" }, children: /* @__PURE__ */ n.jsx(
3104
+ No,
3105
+ {
3106
+ options: o.poll.options,
3107
+ selectedOptions: ((S = o.userVote) == null ? void 0 : S.optionIds) || [],
3108
+ optionsLayout: a ? "column" : t ?? "row",
3109
+ optionsImages: y,
3110
+ brandingColors: ((z = o.poll.branding) == null ? void 0 : z.colors) || null
3111
+ }
3112
+ ) })
3113
+ ] }) }),
3114
+ (!o.maxAttemptsReached || o.additionalCTA !== void 0) && /* @__PURE__ */ n.jsx(l, { sx: C.ctaSection, children: /* @__PURE__ */ n.jsxs(l, { sx: C.buttonsContainer, children: [
3115
+ !o.maxAttemptsReached && /* @__PURE__ */ n.jsx(W, { sx: C.playAgainButton, onClick: o.voteAgain, children: /* @__PURE__ */ n.jsxs(l, { sx: C.playAgainButtonContent, children: [
3116
+ /* @__PURE__ */ n.jsx(Go, { sx: C.playAgainIcon }),
3117
+ /* @__PURE__ */ n.jsx(K, { sx: C.playAgainText, children: e("poll.buttons.voteAgain") })
3118
+ ] }) }),
3119
+ /* @__PURE__ */ n.jsx(
3120
+ Zo,
3121
+ {
3122
+ additionalCTA: o.additionalCTA,
3123
+ buttonStyle: C.additionalCTAButton,
3124
+ buttonContentStyle: C.additionalCTAButtonContent,
3125
+ textStyle: C.additionalCTAText
3126
+ }
3127
+ )
3128
+ ] }) }),
3129
+ /* @__PURE__ */ n.jsx(
3130
+ w,
3131
+ {
3132
+ brandingLogo: c,
3133
+ textColor: A.colorSchemes.dark.textColor,
3134
+ label: ((H = o.poll.labels) == null ? void 0 : H.sponsor) || null
3135
+ }
3136
+ )
3137
+ ] });
3138
+ };
3139
+ return /* @__PURE__ */ n.jsx(
3140
+ Hn,
3141
+ {
3142
+ entity: o.poll,
3143
+ headline: e("poll.headline"),
3144
+ backgroundImage: x,
3145
+ imageBackgroundGradient: r,
3146
+ rulesDisplay: o.rulesDisplay,
3147
+ children: k()
3148
+ }
3149
+ );
3150
+ }, iA = () => {
3151
+ const { t: o } = G();
3152
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: null, children: /* @__PURE__ */ n.jsx(
3153
+ Fn,
3154
+ {
3155
+ notFoundTitle: o("poll.pollNotFound"),
3156
+ notFoundMessage: o("poll.pollNotFoundDescription")
3157
+ }
3158
+ ) });
3159
+ }, tA = (o) => {
3160
+ var A, i, e, a;
3161
+ const r = ((A = o.poll.branding) == null ? void 0 : A.colors) || null, t = J() ? ((i = o.poll.branding) == null ? void 0 : i.images.mobileLogo) || ((e = o.poll.branding) == null ? void 0 : e.images.mainLogo) || "" : ((a = o.poll.branding) == null ? void 0 : a.images.mainLogo) || "", { t: s } = G();
3162
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (r == null ? void 0 : r.borderColor) || null, children: /* @__PURE__ */ n.jsx(
3163
+ Sn,
3164
+ {
3165
+ entity: o.poll,
3166
+ headline: s("poll.headline"),
3167
+ tryAgainButtonText: s("poll.buttons.tryAgain"),
3168
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3169
+ imagePosition: o.imagePosition || "left",
3170
+ isApiError: o.isApiError,
3171
+ toggleTryAgain: o.toggleTryAgain,
3172
+ rulesDisplay: o.rulesDisplay,
3173
+ renderPresentedBy: (p) => {
3174
+ var c;
3175
+ return /* @__PURE__ */ n.jsx(
3176
+ w,
3177
+ {
3178
+ brandingLogo: t,
3179
+ textColor: p,
3180
+ label: ((c = o.poll.labels) == null ? void 0 : c.sponsor) || null
3181
+ }
3182
+ );
3183
+ }
3184
+ }
3185
+ ) });
3186
+ }, aA = (o) => {
3187
+ var A, i, e, a;
3188
+ const r = J(), { t } = G(), s = ((A = o.poll.branding) == null ? void 0 : A.colors) || null, p = r ? ((i = o.poll.branding) == null ? void 0 : i.images.mobileLogo) || ((e = o.poll.branding) == null ? void 0 : e.images.mainLogo) || "" : ((a = o.poll.branding) == null ? void 0 : a.images.mainLogo) || "";
3189
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (s == null ? void 0 : s.borderColor) || null, children: /* @__PURE__ */ n.jsx(
3190
+ jn,
3191
+ {
3192
+ entity: o.poll,
3193
+ headline: t("poll.headline"),
3194
+ tryAgainButtonText: t("poll.buttons.tryAgain"),
3195
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3196
+ isApiError: o.isApiError,
3197
+ toggleTryAgain: o.toggleTryAgain,
3198
+ rulesDisplay: o.rulesDisplay,
3199
+ renderPresentedBy: (c) => {
3200
+ var U;
3201
+ return /* @__PURE__ */ n.jsx(
3202
+ w,
3203
+ {
3204
+ brandingLogo: p,
3205
+ textColor: c,
3206
+ label: ((U = o.poll.labels) == null ? void 0 : U.sponsor) || null
3207
+ }
3208
+ );
3209
+ }
3210
+ }
3211
+ ) });
3212
+ }, rA = (o) => {
3213
+ const { t: A } = G(), i = J(), e = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : i ? to : io, { brandingLogo: a } = Io(
3214
+ o.poll.branding || null
3215
+ );
3216
+ return /* @__PURE__ */ n.jsx(
3217
+ Bn,
3218
+ {
3219
+ entity: o.poll,
3220
+ headline: A("poll.headline"),
3221
+ tryAgainButtonText: A("poll.buttons.tryAgain"),
3222
+ defaultImagePlaceholderUrl: e,
3223
+ isApiError: o.isApiError,
3224
+ toggleTryAgain: o.toggleTryAgain,
3225
+ rulesDisplay: o.rulesDisplay,
3226
+ renderPresentedBy: (r) => {
3227
+ var t;
3228
+ return /* @__PURE__ */ n.jsx(
3229
+ w,
3230
+ {
3231
+ brandingLogo: a,
3232
+ textColor: r,
3233
+ label: ((t = o.poll.labels) == null ? void 0 : t.sponsor) || null
3234
+ }
3235
+ );
3236
+ }
3237
+ }
3238
+ );
3239
+ }, sA = (o) => {
3240
+ var A, i, e;
3241
+ return {
3242
+ // Pulse animation for buttons
3243
+ pulseAnimation: {
3244
+ "@keyframes pulse": {
3245
+ "0%": { transform: "scale(1)" },
3246
+ "50%": { transform: "scale(1.05)" },
3247
+ "100%": { transform: "scale(1)" }
3248
+ }
3249
+ },
3250
+ // Sign in button
3251
+ signInButton: {
3252
+ borderRadius: o.buttonRadius,
3253
+ py: "10px",
3254
+ px: "16px",
3255
+ bgcolor: o.primaryColor,
3256
+ color: o.onPrimaryColor,
3257
+ transition: "all 300ms cubic-bezier(0.2, 0, 0, 1)",
3258
+ transform: "scale(1)",
3259
+ alignSelf: "center",
3260
+ "&:hover": {
3261
+ bgcolor: o.primaryColor,
3262
+ transform: "scale(1.02)"
3263
+ },
3264
+ "&:active": {
3265
+ color: o.onPrimaryColor,
3266
+ transform: "scale(0.98)"
3267
+ },
3268
+ "&:disabled": {
3269
+ bgcolor: o.primaryColor,
3270
+ color: o.onPrimaryColor,
3271
+ opacity: "12%"
3272
+ },
3273
+ animation: "pulse 1s infinite",
3274
+ fontSize: "0.9375em"
3275
+ },
3276
+ // Sign in button text
3277
+ signInButtonText: {
3278
+ fontFamily: o.fontFamilyPrimary,
3279
+ fontWeight: 500,
3280
+ fontSize: "0.9375em",
3281
+ lineHeight: "24px",
3282
+ letterSpacing: "0.46px",
3283
+ textTransform: "uppercase",
3284
+ color: o.onPrimaryColor,
3285
+ gap: "8px",
3286
+ display: "flex",
3287
+ alignItems: "center"
3288
+ },
3289
+ // Mobile headline with image background
3290
+ mobileHeadlineWithImage: {
3291
+ display: { xs: "flex", md: "none" },
3292
+ flexDirection: "column",
3293
+ justifyContent: "space-between",
3294
+ gap: "10px",
3295
+ backgroundImage: `url(${o.finalImage})`,
3296
+ backgroundSize: "cover",
3297
+ backgroundPosition: "center",
3298
+ borderTopLeftRadius: "5px",
3299
+ borderTopRightRadius: "5px",
3300
+ position: "relative",
3301
+ minHeight: "210px",
3302
+ overflow: "hidden",
3303
+ height: "auto",
3304
+ "&::before": {
3305
+ content: '""',
3306
+ position: "absolute",
3307
+ width: "100%",
3308
+ height: "100%",
3309
+ background: o.imageBackgroundGradient,
3310
+ borderTopLeftRadius: "5px",
3311
+ borderTopRightRadius: "5px"
3312
+ }
3313
+ },
3314
+ // Content inside mobile headline with image
3315
+ mobileHeadlineContent: {
3316
+ zIndex: 1,
3317
+ height: "100%",
3318
+ p: o.spacingScale.xl,
3319
+ gap: o.spacingScale["2xl"],
3320
+ display: "flex",
3321
+ flexDirection: "column",
3322
+ justifyContent: "space-between"
3323
+ },
3324
+ // Mobile headline without image
3325
+ mobileHeadlineWithoutImage: {
3326
+ display: { xs: "flex", md: "none" },
3327
+ flex: "0.5",
3328
+ flexDirection: "column",
3329
+ justifyContent: "space-between",
3330
+ p: o.spacingScale.lg,
3331
+ gap: o.spacingScale["2xl"]
3332
+ },
3333
+ // Headline typography (mobile with image)
3334
+ headlineTypographyMobileImage: {
3335
+ fontWeight: 500,
3336
+ lineHeight: "166%",
3337
+ letterSpacing: "1px",
3338
+ fontSize: "0.75em",
3339
+ color: ((A = o.brandingColors) == null ? void 0 : A.secondaryColor) || o.darkTextColor,
3340
+ opacity: "70%",
3341
+ textTransform: "uppercase",
3342
+ fontFamily: o.fontFamilySecondary,
3343
+ textAlign: "center"
3344
+ },
3345
+ // Headline typography (mobile without image & desktop)
3346
+ headlineTypography: {
3347
+ fontWeight: 500,
3348
+ lineHeight: "166%",
3349
+ letterSpacing: "1px",
3350
+ textTransform: "uppercase",
3351
+ fontSize: "0.75em",
3352
+ color: o.secondaryColor,
3353
+ opacity: o.opacity,
3354
+ fontFamily: o.fontFamilySecondary,
3355
+ textAlign: "center"
3356
+ },
3357
+ // Title typography (mobile with image)
3358
+ titleTypographyMobileImage: {
3359
+ fontWeight: 700,
3360
+ lineHeight: "133%",
3361
+ fontSize: "1.5em",
3362
+ letterSpacing: "0.15px",
3363
+ color: ((i = o.brandingColors) == null ? void 0 : i.contentColor) || o.darkTextColor,
3364
+ fontFamily: o.fontFamilyPrimary,
3365
+ textAlign: "center"
3366
+ },
3367
+ // Title typography (mobile without image & desktop)
3368
+ titleTypography: {
3369
+ fontWeight: 700,
3370
+ lineHeight: "133%",
3371
+ letterSpacing: "0px",
3372
+ fontSize: "1.5em",
3373
+ color: o.textColor,
3374
+ fontFamily: o.fontFamilyPrimary,
3375
+ textAlign: { xs: "center", md: "left" }
3376
+ },
3377
+ // Description typography (mobile with image)
3378
+ descriptionTypographyMobileImage: {
3379
+ fontWeight: 400,
3380
+ lineHeight: "140%",
3381
+ fontSize: "1.25em",
3382
+ letterSpacing: "0.15px",
3383
+ color: ((e = o.brandingColors) == null ? void 0 : e.secondaryColor) || o.darkTextColor,
3384
+ opacity: "70%",
3385
+ fontFamily: o.fontFamilyPrimary,
3386
+ textAlign: "center"
3387
+ },
3388
+ // Description typography (mobile without image & desktop)
3389
+ descriptionTypography: {
3390
+ fontWeight: 400,
3391
+ lineHeight: "140%",
3392
+ letterSpacing: "0.15px",
3393
+ fontSize: "1.25em",
3394
+ color: o.secondaryColor,
3395
+ opacity: o.opacity,
3396
+ fontFamily: o.fontFamilyPrimary,
3397
+ textAlign: { xs: "center", md: "left" }
3398
+ },
3399
+ // Desktop title typography (centered)
3400
+ titleTypographyDesktop: {
3401
+ fontWeight: 700,
3402
+ lineHeight: "133%",
3403
+ letterSpacing: "0px",
3404
+ fontSize: "1.5em",
3405
+ color: o.textColor,
3406
+ fontFamily: o.fontFamilyPrimary
3407
+ },
3408
+ // Desktop description typography (centered)
3409
+ descriptionTypographyDesktop: {
3410
+ fontWeight: 400,
3411
+ lineHeight: "140%",
3412
+ letterSpacing: "0.15px",
3413
+ fontSize: "1.25em",
3414
+ color: o.secondaryColor,
3415
+ opacity: o.opacity,
3416
+ fontFamily: o.fontFamilyPrimary
3417
+ },
3418
+ // Image container (left position)
3419
+ imageContainerLeft: {
3420
+ display: { xs: "none", md: "block" },
3421
+ flex: "0.3",
3422
+ borderTopLeftRadius: o.borderRadius.md,
3423
+ borderBottomLeftRadius: o.borderRadius.md,
3424
+ overflow: "hidden",
3425
+ height: "auto",
3426
+ position: "relative"
3427
+ },
3428
+ // Image container (right position)
3429
+ imageContainerRight: {
3430
+ display: { xs: "none", md: "block" },
3431
+ flex: "0.3",
3432
+ borderTopRightRadius: "5px",
3433
+ borderBottomRightRadius: "5px",
3434
+ overflow: "hidden",
3435
+ height: "auto",
3436
+ position: "relative"
3437
+ },
3438
+ // Main content area
3439
+ mainContentArea: {
3440
+ flex: { xs: "1", md: o.finalImage ? "0.7" : "1" },
3441
+ display: {
3442
+ md: "flex",
3443
+ xs: "none"
3444
+ },
3445
+ flexDirection: "column",
3446
+ p: o.spacingScale.md,
3447
+ gap: o.spacingScale["2xl"]
3448
+ },
3449
+ // Desktop headline container
3450
+ desktopHeadlineContainer: {
3451
+ display: { xs: "none", md: "flex" },
3452
+ flexDirection: "column",
3453
+ justifyContent: "space-between",
3454
+ gap: o.spacingScale["2xl"],
3455
+ textAlign: "center"
3456
+ },
3457
+ // Content container
3458
+ contentContainer: {
3459
+ display: "flex",
3460
+ flexDirection: "column",
3461
+ gap: o.spacingScale["3xs"]
3462
+ },
3463
+ // Question area
3464
+ questionArea: {
3465
+ display: "flex",
3466
+ flexDirection: "column"
3467
+ },
3468
+ // Start button container
3469
+ signInButtonContainer: {
3470
+ display: "flex",
3471
+ flexDirection: "column",
3472
+ justifyContent: "space-between",
3473
+ alignItems: "center",
3474
+ gap: o.spacingScale["2xl"]
3475
+ },
3476
+ // Quiz image
3477
+ pollImage: {
3478
+ width: "100%",
3479
+ height: "100%",
3480
+ objectFit: "cover"
3481
+ }
3482
+ };
3483
+ }, pA = (o) => {
3484
+ var A, i, e, a, r;
3485
+ const t = ((A = o.poll.branding) == null ? void 0 : A.colors) || null, s = J(), p = X(), c = eo(
3486
+ {
3487
+ images: o.poll.images,
3488
+ imagePlaceholder: o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : ""
3489
+ },
3490
+ I.STANDARD
3491
+ ), U = L(), m = Z().primary, x = Z().secondary, y = Y(), d = Y().xl, g = (t == null ? void 0 : t.primaryColor) || j().palette.primary.plainColor, B = j().palette.primary.onPrimary, f = (t == null ? void 0 : t.contentColor) || j().textColor, P = (t == null ? void 0 : t.secondaryColor) || j().textColor, T = Ho(
3492
+ I.STANDARD
3493
+ ), h = s ? ((i = o.poll.branding) == null ? void 0 : i.images.mobileLogo) || ((e = o.poll.branding) == null ? void 0 : e.images.mainLogo) || "" : ((a = o.poll.branding) == null ? void 0 : a.images.mainLogo) || "", { t: C } = G(), k = o.imagePosition || "left", S = sA({
3494
+ finalImage: c,
3495
+ spacingScale: U,
3496
+ borderRadius: y,
3497
+ fontFamilyPrimary: m,
3498
+ fontFamilySecondary: x,
3499
+ textColor: f,
3500
+ secondaryColor: P,
3501
+ brandingColors: t,
3502
+ darkTextColor: p.colorSchemes.dark.textColor,
3503
+ opacity: "60%",
3504
+ imageBackgroundGradient: T,
3505
+ buttonRadius: d,
3506
+ primaryColor: g,
3507
+ onPrimaryColor: B
3508
+ }), z = () => {
3509
+ var H, u, D, V;
3510
+ return o.signInCTA ? (H = o.signInCTA) != null && H.component ? o.signInCTA.component : (u = o.signInCTA) != null && u.onClick ? /* @__PURE__ */ n.jsx(
3511
+ W,
3512
+ {
3513
+ variant: "soft",
3514
+ sx: {
3515
+ ...S.signInButton,
3516
+ ...S.pulseAnimation
3517
+ },
3518
+ onClick: o.signInCTA.onClick,
3519
+ children: /* @__PURE__ */ n.jsx(K, { sx: S.signInButtonText, children: o.signInCTA.defaultLabel || C("common.signIn") })
3520
+ }
3521
+ ) : (D = o.signInCTA) != null && D.url ? typeof window > "u" ? /* @__PURE__ */ n.jsx(
3522
+ l,
3523
+ {
3524
+ component: "a",
3525
+ href: o.signInCTA.url,
3526
+ target: ((V = o.signInCTA) == null ? void 0 : V.target) || "_self",
3527
+ sx: {
3528
+ ...S.signInButton,
3529
+ ...S.pulseAnimation,
3530
+ textDecoration: "none",
3531
+ display: "inline-flex",
3532
+ alignItems: "center",
3533
+ justifyContent: "center"
3534
+ },
3535
+ children: /* @__PURE__ */ n.jsx(K, { sx: S.signInButtonText, children: o.signInCTA.defaultLabel || C("common.signIn") })
3536
+ }
3537
+ ) : /* @__PURE__ */ n.jsx(
3538
+ W,
3539
+ {
3540
+ variant: "soft",
3541
+ sx: {
3542
+ ...S.signInButton,
3543
+ ...S.pulseAnimation
3544
+ },
3545
+ onClick: () => {
3546
+ var v, O, R;
3547
+ ((v = o.signInCTA) == null ? void 0 : v.target) === "_blank" ? window.open((O = o.signInCTA) == null ? void 0 : O.url, "_blank") : window.location.href = (R = o.signInCTA) == null ? void 0 : R.url;
3548
+ },
3549
+ children: /* @__PURE__ */ n.jsx(K, { sx: S.signInButtonText, children: o.signInCTA.defaultLabel || C("common.signIn") })
3550
+ }
3551
+ ) : /* @__PURE__ */ n.jsx(
3552
+ W,
3553
+ {
3554
+ variant: "soft",
3555
+ sx: {
3556
+ ...S.signInButton
3557
+ },
3558
+ disabled: !0,
3559
+ children: /* @__PURE__ */ n.jsx(K, { sx: S.signInButtonText, children: o.signInCTA.defaultLabel || C("common.signIn") })
3560
+ }
3561
+ ) : /* @__PURE__ */ n.jsx(
3562
+ W,
3563
+ {
3564
+ variant: "soft",
3565
+ sx: {
3566
+ ...S.signInButton
3567
+ },
3568
+ disabled: !0,
3569
+ children: /* @__PURE__ */ n.jsx(K, { sx: S.signInButtonText, children: C("common.signIn") })
3570
+ }
3571
+ );
3572
+ };
3573
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (t == null ? void 0 : t.borderColor) || null, children: /* @__PURE__ */ n.jsx(
3574
+ bn,
3575
+ {
3576
+ entity: o.poll,
3577
+ headline: C("poll.headline"),
3578
+ finalImage: c,
3579
+ imagePosition: k,
3580
+ signInContent: z(),
3581
+ rulesDisplay: o.rulesDisplay,
3582
+ brandingContent: /* @__PURE__ */ n.jsx(
3583
+ w,
3584
+ {
3585
+ brandingLogo: h,
3586
+ textColor: s && c ? (t == null ? void 0 : t.contentColor) || p.colorSchemes.dark.textColor : f,
3587
+ label: ((r = o.poll.labels) == null ? void 0 : r.sponsor) || null,
3588
+ isCentered: !0
3589
+ }
3590
+ )
3591
+ }
3592
+ ) });
3593
+ }, cA = (o) => ({
3594
+ // Pulse animation for buttons
3595
+ pulseAnimation: {
3596
+ "@keyframes pulse": {
3597
+ "0%": { transform: "scale(1)" },
3598
+ "50%": { transform: "scale(1.05)" },
3599
+ "100%": { transform: "scale(1)" }
3600
+ }
3601
+ },
3602
+ // Sign in button
3603
+ signInButton: {
3604
+ borderRadius: o.buttonRadius,
3605
+ py: "10px",
3606
+ px: "16px",
3607
+ bgcolor: o.primaryColor,
3608
+ color: o.onPrimaryColor,
3609
+ transition: "all 300ms cubic-bezier(0.2, 0, 0, 1)",
3610
+ transform: "scale(1)",
3611
+ alignSelf: "center",
3612
+ "&:hover": {
3613
+ bgcolor: o.primaryColor,
3614
+ transform: "scale(1.02)"
3615
+ },
3616
+ "&:active": {
3617
+ color: o.onPrimaryColor,
3618
+ transform: "scale(0.98)"
3619
+ },
3620
+ "&:disabled": {
3621
+ bgcolor: o.primaryColor,
3622
+ color: o.onPrimaryColor,
3623
+ opacity: "12%"
3624
+ },
3625
+ animation: "pulse 1s infinite",
3626
+ fontSize: "0.9375em"
3627
+ },
3628
+ // Sign in button text
3629
+ signInButtonText: {
3630
+ fontFamily: o.fontFamilyPrimary,
3631
+ fontWeight: 500,
3632
+ fontSize: "0.9375em",
3633
+ lineHeight: "24px",
3634
+ letterSpacing: "0.46px",
3635
+ textTransform: "uppercase",
3636
+ color: o.onPrimaryColor,
3637
+ gap: "8px",
3638
+ display: "flex",
3639
+ alignItems: "center"
3640
+ }
3641
+ }), gA = (o) => {
3642
+ var A, i, e, a, r;
3643
+ const t = X(), s = J(), p = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : s ? to : io, c = eo(
3644
+ {
3645
+ images: o.poll.images,
3646
+ imagePlaceholder: p
3647
+ },
3648
+ I.SPLIT
3649
+ ), { t: U } = G(), m = ((A = o.poll.branding) == null ? void 0 : A.colors) || null, x = s ? ((i = o.poll.branding) == null ? void 0 : i.images.mobileLogo) || ((e = o.poll.branding) == null ? void 0 : e.images.mainLogo) || "" : ((a = o.poll.branding) == null ? void 0 : a.images.mainLogo) || "", y = Z().primary, d = Y().xl, g = (m == null ? void 0 : m.primaryColor) || j().palette.primary.plainColor, B = j().palette.primary.onPrimary, f = cA({
3650
+ fontFamilyPrimary: y,
3651
+ buttonRadius: d,
3652
+ primaryColor: g,
3653
+ onPrimaryColor: B
3654
+ }), P = () => {
3655
+ var T, h, C, k;
3656
+ return o.signInCTA ? (T = o.signInCTA) != null && T.component ? o.signInCTA.component : (h = o.signInCTA) != null && h.onClick ? /* @__PURE__ */ n.jsx(
3657
+ W,
3658
+ {
3659
+ variant: "soft",
3660
+ sx: {
3661
+ ...f.signInButton,
3662
+ ...f.pulseAnimation
3663
+ },
3664
+ onClick: o.signInCTA.onClick,
3665
+ children: /* @__PURE__ */ n.jsx(K, { sx: f.signInButtonText, children: o.signInCTA.defaultLabel || U("common.signIn") })
3666
+ }
3667
+ ) : (C = o.signInCTA) != null && C.url ? typeof window > "u" ? /* @__PURE__ */ n.jsx(
3668
+ l,
3669
+ {
3670
+ component: "a",
3671
+ href: o.signInCTA.url,
3672
+ target: ((k = o.signInCTA) == null ? void 0 : k.target) || "_self",
3673
+ sx: {
3674
+ ...f.signInButton,
3675
+ ...f.pulseAnimation,
3676
+ textDecoration: "none",
3677
+ display: "inline-flex",
3678
+ alignItems: "center",
3679
+ justifyContent: "center"
3680
+ },
3681
+ children: /* @__PURE__ */ n.jsx(K, { sx: f.signInButtonText, children: o.signInCTA.defaultLabel || U("common.signIn") })
3682
+ }
3683
+ ) : /* @__PURE__ */ n.jsx(
3684
+ W,
3685
+ {
3686
+ variant: "soft",
3687
+ sx: {
3688
+ ...f.signInButton,
3689
+ ...f.pulseAnimation
3690
+ },
3691
+ onClick: () => {
3692
+ var S, z, H;
3693
+ ((S = o.signInCTA) == null ? void 0 : S.target) === "_blank" ? window.open((z = o.signInCTA) == null ? void 0 : z.url, "_blank") : window.location.href = (H = o.signInCTA) == null ? void 0 : H.url;
3694
+ },
3695
+ children: /* @__PURE__ */ n.jsx(K, { sx: f.signInButtonText, children: o.signInCTA.defaultLabel || U("common.signIn") })
3696
+ }
3697
+ ) : /* @__PURE__ */ n.jsx(
3698
+ W,
3699
+ {
3700
+ variant: "soft",
3701
+ sx: {
3702
+ ...f.signInButton
3703
+ },
3704
+ disabled: !0,
3705
+ children: /* @__PURE__ */ n.jsx(K, { sx: f.signInButtonText, children: o.signInCTA.defaultLabel || U("common.signIn") })
3706
+ }
3707
+ ) : /* @__PURE__ */ n.jsx(
3708
+ W,
3709
+ {
3710
+ variant: "soft",
3711
+ sx: {
3712
+ ...f.signInButton
3713
+ },
3714
+ disabled: !0,
3715
+ children: /* @__PURE__ */ n.jsx(K, { sx: f.signInButtonText, children: U("common.signIn") })
3716
+ }
3717
+ );
3718
+ };
3719
+ return /* @__PURE__ */ n.jsx($, { brandingBorderColor: (m == null ? void 0 : m.borderColor) || null, children: /* @__PURE__ */ n.jsx(
3720
+ qn,
3721
+ {
3722
+ entity: o.poll,
3723
+ headline: U("poll.headline"),
3724
+ finalImage: c,
3725
+ signInContent: P(),
3726
+ rulesDisplay: o.rulesDisplay,
3727
+ brandingContent: /* @__PURE__ */ n.jsx(
3728
+ w,
3729
+ {
3730
+ brandingLogo: x,
3731
+ textColor: (m == null ? void 0 : m.contentColor) || t.colorSchemes.dark.textColor,
3732
+ label: ((r = o.poll.labels) == null ? void 0 : r.sponsor) || null
3733
+ }
3734
+ )
3735
+ }
3736
+ ) });
3737
+ }, dA = (o) => ({
3738
+ // Pulse animation for buttons
3739
+ pulseAnimation: {
3740
+ "@keyframes pulse": {
3741
+ "0%": { transform: "scale(1)" },
3742
+ "50%": { transform: "scale(1.05)" },
3743
+ "100%": { transform: "scale(1)" }
3744
+ }
3745
+ },
3746
+ // Sign In button
3747
+ signInButton: {
3748
+ borderRadius: o.buttonRadius,
3749
+ bgcolor: o.primaryColor,
3750
+ color: "#FFFFFF",
3751
+ py: "10px",
3752
+ px: "16px",
3753
+ "&:hover": {
3754
+ bgcolor: o.primaryColor
3755
+ },
3756
+ "&:active": {
3757
+ color: o.onPrimaryColor
3758
+ },
3759
+ animation: "pulse 1s infinite",
3760
+ fontSize: "0.9375em"
3761
+ },
3762
+ // Start button text
3763
+ signInButtonText: {
3764
+ fontFamily: o.fontFamilyPrimary,
3765
+ fontWeight: 500,
3766
+ fontSize: "0.9375em",
3767
+ lineHeight: "24px",
3768
+ letterSpacing: "0.46px",
3769
+ textTransform: "uppercase",
3770
+ color: o.onPrimaryColor,
3771
+ gap: "8px",
3772
+ display: "flex",
3773
+ alignItems: "center"
3774
+ }
3775
+ }), fA = (o) => {
3776
+ var A, i, e, a, r, t, s, p, c, U, m;
3777
+ const x = X(), { t: y } = G(), d = J(), g = Ho(
3778
+ I.OVERLAY
3779
+ ), { brandingImage: B, brandingColors: f, brandingLogo: P } = Io(o.poll.branding || null), T = o.defaultImagePlaceholderUrl ? o.defaultImagePlaceholderUrl : d ? to : io, h = B || eo(
3780
+ {
3781
+ images: o.poll.images,
3782
+ imagePlaceholder: T
3783
+ },
3784
+ I.OVERLAY
3785
+ ), C = $o(h), k = (i = (A = x.customRadius) == null ? void 0 : A.light) == null ? void 0 : i.xl, S = (f == null ? void 0 : f.primaryColor) || ((t = (r = (a = (e = x.colorSchemes) == null ? void 0 : e.light) == null ? void 0 : a.palette) == null ? void 0 : r.primary) == null ? void 0 : t.plainColor), z = (U = (c = (p = (s = x.colorSchemes) == null ? void 0 : s.light) == null ? void 0 : p.palette) == null ? void 0 : c.primary) == null ? void 0 : U.onPrimary, H = x.customFontFamily.dark.primary, u = dA({
3786
+ buttonRadius: k,
3787
+ primaryColor: S,
3788
+ onPrimaryColor: z,
3789
+ fontFamilyPrimary: H
3790
+ }), D = () => {
3791
+ var V, v, O, R;
3792
+ return o.signInCTA ? (V = o.signInCTA) != null && V.component ? o.signInCTA.component : (v = o.signInCTA) != null && v.onClick ? /* @__PURE__ */ n.jsx(
3793
+ W,
3794
+ {
3795
+ variant: "soft",
3796
+ sx: {
3797
+ ...u.signInButton,
3798
+ ...u.pulseAnimation
3799
+ },
3800
+ onClick: o.signInCTA.onClick,
3801
+ children: /* @__PURE__ */ n.jsx(K, { sx: u.signInButtonText, children: o.signInCTA.defaultLabel || y("common.signIn") })
3802
+ }
3803
+ ) : (O = o.signInCTA) != null && O.url ? typeof window > "u" ? /* @__PURE__ */ n.jsx(
3804
+ l,
3805
+ {
3806
+ component: "a",
3807
+ href: o.signInCTA.url,
3808
+ target: ((R = o.signInCTA) == null ? void 0 : R.target) || "_self",
3809
+ sx: {
3810
+ ...u.signInButton,
3811
+ ...u.pulseAnimation,
3812
+ textDecoration: "none",
3813
+ display: "inline-flex",
3814
+ alignItems: "center",
3815
+ justifyContent: "center"
3816
+ },
3817
+ children: /* @__PURE__ */ n.jsx(K, { sx: u.signInButtonText, children: o.signInCTA.defaultLabel || y("common.signIn") })
3818
+ }
3819
+ ) : /* @__PURE__ */ n.jsx(
3820
+ W,
3821
+ {
3822
+ variant: "soft",
3823
+ sx: {
3824
+ ...u.signInButton,
3825
+ ...u.pulseAnimation
3826
+ },
3827
+ onClick: () => {
3828
+ var b, F, q;
3829
+ ((b = o.signInCTA) == null ? void 0 : b.target) === "_blank" ? window.open((F = o.signInCTA) == null ? void 0 : F.url, "_blank") : window.location.href = (q = o.signInCTA) == null ? void 0 : q.url;
3830
+ },
3831
+ children: /* @__PURE__ */ n.jsx(K, { sx: u.signInButtonText, children: o.signInCTA.defaultLabel || y("common.signIn") })
3832
+ }
3833
+ ) : /* @__PURE__ */ n.jsx(
3834
+ W,
3835
+ {
3836
+ variant: "soft",
3837
+ sx: {
3838
+ ...u.signInButton
3839
+ },
3840
+ disabled: !0,
3841
+ children: /* @__PURE__ */ n.jsx(K, { sx: u.signInButtonText, children: o.signInCTA.defaultLabel || y("common.signIn") })
3842
+ }
3843
+ ) : /* @__PURE__ */ n.jsx(
3844
+ W,
3845
+ {
3846
+ variant: "soft",
3847
+ sx: {
3848
+ ...u.signInButton
3849
+ },
3850
+ disabled: !0,
3851
+ children: /* @__PURE__ */ n.jsx(K, { sx: u.signInButtonText, children: y("common.signIn") })
3852
+ }
3853
+ );
3854
+ };
3855
+ return /* @__PURE__ */ n.jsx(
3856
+ Vn,
3857
+ {
3858
+ entity: o.poll,
3859
+ headline: y("poll.headline"),
3860
+ backgroundImage: C,
3861
+ imageBackgroundGradient: g,
3862
+ signInContent: D(),
3863
+ rulesDisplay: o.rulesDisplay,
3864
+ brandingContent: /* @__PURE__ */ n.jsx(
3865
+ w,
3866
+ {
3867
+ brandingLogo: P,
3868
+ textColor: x.colorSchemes.dark.textColor,
3869
+ label: ((m = o.poll.labels) == null ? void 0 : m.sponsor) || null
3870
+ }
3871
+ )
3872
+ }
3873
+ );
3874
+ }, xA = (o) => {
3875
+ const { t: A } = G();
3876
+ return /* @__PURE__ */ n.jsx(
3877
+ In,
3878
+ {
3879
+ entity: o.poll,
3880
+ headline: A("poll.headline"),
3881
+ sdk: o.sdk,
3882
+ leads: o.leads,
3883
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3884
+ imagePosition: o.imagePosition,
3885
+ onLeadSubmitted: o.onLeadSubmitted,
3886
+ isSubmitting: o.isSubmitting,
3887
+ MainCard: $,
3888
+ PresentedBy: w,
3889
+ CollectLeadWrapper: yo
3890
+ }
3891
+ );
3892
+ }, UA = (o) => {
3893
+ const { t: A } = G();
3894
+ return /* @__PURE__ */ n.jsx(
3895
+ Dn,
3896
+ {
3897
+ entity: o.poll,
3898
+ headline: A("poll.headline"),
3899
+ sdk: o.sdk,
3900
+ leads: o.leads,
3901
+ defaultImagePlaceholder: io,
3902
+ mobileImagePlaceholder: to,
3903
+ onLeadSubmitted: o.onLeadSubmitted,
3904
+ isSubmitting: o.isSubmitting,
3905
+ MainCard: $,
3906
+ PresentedBy: w,
3907
+ CollectLeadWrapper: yo
3908
+ }
3909
+ );
3910
+ }, KA = (o) => {
3911
+ const { t: A } = G();
3912
+ return /* @__PURE__ */ n.jsx(
3913
+ Qn,
3914
+ {
3915
+ entity: o.poll,
3916
+ headline: A("poll.headline"),
3917
+ sdk: o.sdk,
3918
+ leads: o.leads,
3919
+ defaultImagePlaceholder: io,
3920
+ mobileImagePlaceholder: to,
3921
+ onLeadSubmitted: o.onLeadSubmitted,
3922
+ isSubmitting: o.isSubmitting,
3923
+ PresentedBy: w,
3924
+ CollectLeadWrapper: yo
3925
+ }
3926
+ );
3927
+ };
3928
+ function ko(o) {
3929
+ return o.template === I.STANDARD;
3930
+ }
3931
+ const mA = (o) => {
3932
+ const [A, i] = M.useState([]), [e, a] = M.useState(!1), [r, t] = M.useState(!1), [s, p] = M.useState(!1), [c, U] = M.useState(!1), [m, x] = M.useState(!1), [y, d] = M.useState(!1), { poll: g, setPoll: B } = Jn(o.entityId, o.sdk), {
3933
+ myVote: f,
3934
+ setMyVote: P,
3935
+ isUnauthorized: T,
3936
+ isApiError: h,
3937
+ setIsApiError: C,
3938
+ setIsUnauthorized: k
3939
+ } = Wn(o.entityId, o.sdk, s), S = M.useMemo(() => !g || !f || !(f != null && f.id) || g.maxAttempts === -1 || g.maxAttempts === null || f.attempts === null ? !1 : (g == null ? void 0 : g.maxAttempts) <= (f == null ? void 0 : f.attempts), [g, f]);
3940
+ if (M.useEffect(() => {
3941
+ dn(o.language || "en");
3942
+ }, [o.language]), !g || !f)
3943
+ return /* @__PURE__ */ n.jsx(Cn, { my: 20 });
3944
+ if (!g.id)
3945
+ return /* @__PURE__ */ n.jsx(iA, {});
3946
+ if (g.authRequirement === "REGISTERED" && !o.userIsLoggedIn)
3947
+ return ko(o) ? /* @__PURE__ */ n.jsx(
3948
+ pA,
3949
+ {
3950
+ poll: g,
3951
+ imagePosition: o.imagePosition,
3952
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3953
+ signInCTA: o.signInCTA,
3954
+ rulesDisplay: o.rulesDisplay
3955
+ }
3956
+ ) : o.template === I.OVERLAY ? /* @__PURE__ */ n.jsx(
3957
+ fA,
3958
+ {
3959
+ poll: g,
3960
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3961
+ signInCTA: o.signInCTA,
3962
+ rulesDisplay: o.rulesDisplay
3963
+ }
3964
+ ) : /* @__PURE__ */ n.jsx(
3965
+ gA,
3966
+ {
3967
+ poll: g,
3968
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3969
+ signInCTA: o.signInCTA,
3970
+ rulesDisplay: o.rulesDisplay
3971
+ }
3972
+ );
3973
+ const z = () => {
3974
+ C(!1), k(!1), p(!s);
3975
+ };
3976
+ if (T || h)
3977
+ return ko(o) ? /* @__PURE__ */ n.jsx(
3978
+ tA,
3979
+ {
3980
+ poll: g,
3981
+ imagePosition: o.imagePosition,
3982
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3983
+ isApiError: h,
3984
+ toggleTryAgain: z,
3985
+ rulesDisplay: o.rulesDisplay
3986
+ }
3987
+ ) : o.template === I.OVERLAY ? /* @__PURE__ */ n.jsx(
3988
+ rA,
3989
+ {
3990
+ poll: g,
3991
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
3992
+ isApiError: h,
3993
+ toggleTryAgain: z,
3994
+ rulesDisplay: o.rulesDisplay
3995
+ }
3996
+ ) : /* @__PURE__ */ n.jsx(
3997
+ aA,
3998
+ {
3999
+ poll: g,
4000
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4001
+ isApiError: h,
4002
+ toggleTryAgain: z,
4003
+ rulesDisplay: o.rulesDisplay
4004
+ }
4005
+ );
4006
+ const H = g.multipleChoice && g.maxMultipleChoiceOptions || 1, u = (b) => {
4007
+ if (H === 1)
4008
+ i(b);
4009
+ else {
4010
+ const F = b[0];
4011
+ i((q) => q.includes(F) ? q.filter((ro) => ro !== F) : q.length < H ? [...q, F] : q);
4012
+ }
4013
+ }, D = async () => {
4014
+ var b;
4015
+ if (((b = o.leads) == null ? void 0 : b.position) === "after" && g.authRequirement === "LEAD" && !m) {
4016
+ d(!0);
4017
+ return;
4018
+ }
4019
+ await V();
4020
+ }, V = async () => {
4021
+ t(!0);
4022
+ try {
4023
+ const b = await o.sdk.voting.voteForPoll(
4024
+ o.entityId,
4025
+ A
4026
+ ), F = { ...g };
4027
+ F.options = g.options.map((q) => A.includes(q.id) ? {
4028
+ ...q,
4029
+ votes: q.votes + 1
4030
+ } : q), F.totalVotes = (g.totalVotes || 0) + A.length, B(F), P(b), a(!0);
4031
+ } catch (b) {
4032
+ if (o.sdk.helpers.getSDKConfiguration().errorHandlingMode === "standard") {
4033
+ const F = b;
4034
+ F.error.code === 401 || F.error.code === 403 ? k(!0) : C(!0);
4035
+ } else {
4036
+ const F = b;
4037
+ F.data.error.code === 401 || F.data.error.code === 403 ? k(!0) : C(!0);
4038
+ }
4039
+ } finally {
4040
+ t(!1);
4041
+ }
4042
+ }, v = async () => {
4043
+ x(!0), U(!0), await V(), U(!1), d(!1);
4044
+ }, O = () => {
4045
+ a(!1), i([]), U(!1), x(!1), d(!1);
4046
+ };
4047
+ return y ? o.template === I.OVERLAY ? /* @__PURE__ */ n.jsx(
4048
+ KA,
4049
+ {
4050
+ poll: g,
4051
+ sdk: o.sdk,
4052
+ leads: o.leads,
4053
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4054
+ onLeadSubmitted: v,
4055
+ isSubmitting: c
4056
+ }
4057
+ ) : ko(o) ? /* @__PURE__ */ n.jsx(
4058
+ xA,
4059
+ {
4060
+ poll: g,
4061
+ sdk: o.sdk,
4062
+ leads: o.leads,
4063
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4064
+ imagePosition: o.imagePosition,
4065
+ onLeadSubmitted: v,
4066
+ isSubmitting: c
4067
+ }
4068
+ ) : /* @__PURE__ */ n.jsx(
4069
+ UA,
4070
+ {
4071
+ poll: g,
4072
+ sdk: o.sdk,
4073
+ leads: o.leads,
4074
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4075
+ onLeadSubmitted: v,
4076
+ isSubmitting: c
4077
+ }
4078
+ ) : e || S ? o.template === I.OVERLAY ? /* @__PURE__ */ n.jsx(
4079
+ eA,
4080
+ {
4081
+ userVote: f,
4082
+ poll: g,
4083
+ maxAttemptsReached: S,
4084
+ voteAgain: O,
4085
+ sdk: o.sdk,
4086
+ leads: o.leads,
4087
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4088
+ isUnauthorized: T,
4089
+ additionalCTA: o.additionalCTA,
4090
+ rulesDisplay: o.rulesDisplay
4091
+ }
4092
+ ) : ko(o) ? /* @__PURE__ */ n.jsx(
4093
+ oA,
4094
+ {
4095
+ imagePosition: o.imagePosition || "left",
4096
+ userVote: f,
4097
+ poll: g,
4098
+ maxAttemptsReached: S,
4099
+ voteAgain: O,
4100
+ sdk: o.sdk,
4101
+ leads: o.leads,
4102
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4103
+ isUnauthorized: T,
4104
+ additionalCTA: o.additionalCTA,
4105
+ rulesDisplay: o.rulesDisplay
4106
+ }
4107
+ ) : /* @__PURE__ */ n.jsx(
4108
+ AA,
4109
+ {
4110
+ userVote: f,
4111
+ poll: g,
4112
+ maxAttemptsReached: S,
4113
+ voteAgain: O,
4114
+ sdk: o.sdk,
4115
+ leads: o.leads,
4116
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4117
+ isUnauthorized: T,
4118
+ additionalCTA: o.additionalCTA,
4119
+ rulesDisplay: o.rulesDisplay
4120
+ }
4121
+ ) : o.template === I.OVERLAY ? /* @__PURE__ */ n.jsx(
4122
+ Zn,
4123
+ {
4124
+ sdk: o.sdk,
4125
+ leads: o.leads,
4126
+ poll: g,
4127
+ options: g.options,
4128
+ selectedOptions: A,
4129
+ answerPoll: u,
4130
+ voteForPoll: D,
4131
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4132
+ optionChoices: H,
4133
+ isVoting: r,
4134
+ rulesDisplay: o.rulesDisplay
4135
+ }
4136
+ ) : ko(o) ? /* @__PURE__ */ n.jsx(
4137
+ En,
4138
+ {
4139
+ sdk: o.sdk,
4140
+ leads: o.leads,
4141
+ poll: g,
4142
+ options: g.options,
4143
+ selectedOptions: A,
4144
+ answerPoll: u,
4145
+ voteForPoll: D,
4146
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4147
+ imagePosition: o.imagePosition,
4148
+ optionChoices: H,
4149
+ isVoting: r,
4150
+ rulesDisplay: o.rulesDisplay
4151
+ }
4152
+ ) : /* @__PURE__ */ n.jsx(
4153
+ Xn,
4154
+ {
4155
+ sdk: o.sdk,
4156
+ leads: o.leads,
4157
+ poll: g,
4158
+ options: g.options,
4159
+ selectedOptions: A,
4160
+ answerPoll: u,
4161
+ voteForPoll: D,
4162
+ defaultImagePlaceholderUrl: o.defaultImagePlaceholderUrl,
4163
+ optionChoices: H,
4164
+ isVoting: r,
4165
+ rulesDisplay: o.rulesDisplay
4166
+ }
4167
+ );
4168
+ }, PA = (o) => /* @__PURE__ */ n.jsx(gn, { packageName: "poll-vote", ...o, children: /* @__PURE__ */ n.jsx(mA, { ...o }) }), yA = PA, HA = ({ pollId: o, layoutTemplate: A }) => {
4169
+ const i = nn(), { language: e } = An(), { isAuthenticated: a } = ln(), { imagePosition: r, optionsLayout: t } = en(), s = tn(), p = an(), { defaultImagePlaceholderUrl: c } = rn(), U = sn(), m = pn(), x = cn();
4170
+ let y = {
4171
+ entityId: o,
4172
+ sdk: i,
4173
+ language: e,
4174
+ leads: s,
4175
+ themeOptions: p,
4176
+ userIsLoggedIn: a,
4177
+ template: ho.STANDARD,
4178
+ imagePosition: void 0,
4179
+ signInCTA: U,
4180
+ additionalCTA: m,
4181
+ rulesDisplay: x,
4182
+ optionsLayout: t
4183
+ };
4184
+ switch (A == null ? void 0 : A.toLowerCase()) {
4185
+ case ho.OVERLAY.toLowerCase():
4186
+ y = { ...y, template: ho.OVERLAY, defaultImagePlaceholderUrl: c };
4187
+ break;
4188
+ case ho.SPLIT.toLowerCase():
4189
+ y = { ...y, template: ho.SPLIT, defaultImagePlaceholderUrl: c };
4190
+ break;
4191
+ default:
4192
+ y = { ...y, imagePosition: r };
4193
+ }
4194
+ return /* @__PURE__ */ n.jsx(yA, { ...y });
4195
+ };
4196
+ export {
4197
+ HA as default
4198
+ };