@cuemath/leap 2.8.36-tables-hg9 → 2.8.36-tables-beta-hg1
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.
- package/dist/assets/lottie/lottie.js +2 -0
- package/dist/assets/lottie/lottie.js.map +1 -1
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode/table-mode-styled.js +3 -3
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode/table-mode-styled.js.map +1 -1
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode/table-mode.js +29 -35
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode/table-mode.js.map +1 -1
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode-star/table-mode-star-styled.js +25 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode-star/table-mode-star-styled.js.map +1 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode-star/table-mode-star.js +57 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-mode-star/table-mode-star.js.map +1 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-segment-star/table-segment-star-styled.js +27 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-segment-star/table-segment-star-styled.js.map +1 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-segment-star/table-segment-star.js +37 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-segment-star/table-segment-star.js.map +1 -0
- package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card-styled.js +35 -42
- package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card-styled.js.map +1 -1
- package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card.js +223 -212
- package/dist/features/circle-games/game-launcher/comps/tables-card/tables-card.js.map +1 -1
- package/dist/features/circle-games/game-launcher/game-launcher-analytics-events.js +8 -7
- package/dist/features/circle-games/game-launcher/game-launcher-analytics-events.js.map +1 -1
- package/dist/features/circle-games/game-launcher/game-launcher.js +25 -24
- package/dist/features/circle-games/game-launcher/game-launcher.js.map +1 -1
- package/dist/features/post-game-stats/digital-meter/digital-meter-styled.js +24 -24
- package/dist/features/post-game-stats/digital-meter/digital-meter-styled.js.map +1 -1
- package/dist/features/post-game-stats/digital-meter/digital-meter.js +119 -88
- package/dist/features/post-game-stats/digital-meter/digital-meter.js.map +1 -1
- package/dist/index.d.ts +16 -2
- package/dist/static/table-mode-star.b8a1d762.json +1 -0
- package/dist/static/table-segment-star.78e851d6.json +1 -0
- package/package.json +1 -1
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-star/table-star-styled.js +0 -11
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-star/table-star-styled.js.map +0 -1
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-star/table-star.js +0 -16
- package/dist/features/circle-games/game-launcher/comps/tables-card/table-star/table-star.js.map +0 -1
@@ -1,29 +1,29 @@
|
|
1
1
|
import { jsx as i } from "react/jsx-runtime";
|
2
|
-
import { memo as D, useState as
|
2
|
+
import { memo as D, useState as I, useCallback as n, useMemo as h, useEffect as B } from "react";
|
3
3
|
import { LOTTIE as K } from "../../../assets/lottie/lottie.js";
|
4
|
-
import { CircularLoader as
|
5
|
-
import
|
6
|
-
import { useCircleSounds as
|
4
|
+
import { CircularLoader as O } from "../../ui/loader/circular-loader/circular-loader.js";
|
5
|
+
import U from "../../ui/lottie-animation/lottie-animation.js";
|
6
|
+
import { useCircleSounds as Y } from "../hooks/use-circle-sounds/use-circle-sounds.js";
|
7
7
|
import { CircleSoundKey as t } from "../hooks/use-circle-sounds/use-circle-sounds-enums.js";
|
8
|
-
import { GAME_LAUNCHER_SIZE as
|
8
|
+
import { GAME_LAUNCHER_SIZE as H } from "./comps/card-container/constants.js";
|
9
9
|
import { Carousel as z } from "./comps/carousel/carousel.js";
|
10
|
-
import { GAME_LAUNCHER_ASSET_PADDING as
|
10
|
+
import { GAME_LAUNCHER_ASSET_PADDING as J } from "./comps/segmented-game-card/constants.js";
|
11
11
|
import { SegmentedGameCard as f } from "./comps/segmented-game-card/segmented-game-card.js";
|
12
12
|
import { TablesCard as Z } from "./comps/tables-card/tables-card.js";
|
13
13
|
import { GAME_LAUNCHER_ANALYTICS_EVENTS as x } from "./game-launcher-analytics-events.js";
|
14
14
|
import { useGameLauncherJourney as w } from "./use-game-launcher-journey/use-game-launcher-journey.js";
|
15
15
|
import { ProjectType as m } from "../games/web-view/enums/project-type-enum.js";
|
16
|
-
const G =
|
16
|
+
const G = H + J, ne = D(
|
17
17
|
({ onSegmentClick: r, onJourneyComplete: V, journeyId: u, data: e, isLoading: g, defaultIndex: N = 0 }) => {
|
18
|
-
const [R,
|
18
|
+
const [R, M] = I(N), [p] = I(!0), { playSwipSound: c, play: o } = Y(), {
|
19
19
|
gameRefs: a,
|
20
20
|
lessonRefs: C,
|
21
21
|
puzzleRefs: L,
|
22
22
|
startJourney: E,
|
23
|
-
carouselNextBtnRef:
|
24
|
-
isJourneyInProgress:
|
23
|
+
carouselNextBtnRef: b,
|
24
|
+
isJourneyInProgress: A
|
25
25
|
} = w({
|
26
|
-
setCarouselIndex:
|
26
|
+
setCarouselIndex: M,
|
27
27
|
onSegmentClick: r,
|
28
28
|
onJourneyComplete: V
|
29
29
|
}), _ = n(
|
@@ -36,17 +36,17 @@ const G = J + O, ne = D(
|
|
36
36
|
l.status !== "completed" && (o(t.GAME_CARD_CLICK), r(l, m.LESSON));
|
37
37
|
},
|
38
38
|
[r, o]
|
39
|
-
),
|
39
|
+
), T = n(
|
40
40
|
(l) => {
|
41
41
|
o(t.GAME_CARD_CLICK), r(l, m.GAME);
|
42
42
|
},
|
43
43
|
[r, o]
|
44
|
-
),
|
44
|
+
), y = n(
|
45
45
|
(l) => {
|
46
46
|
o(t.GAME_CARD_CLICK), r(l, m.PUZZLE);
|
47
47
|
},
|
48
48
|
[r, o]
|
49
|
-
),
|
49
|
+
), S = h(() => {
|
50
50
|
let l = [];
|
51
51
|
return e && (e.lessons && (l = [
|
52
52
|
...l,
|
@@ -80,7 +80,7 @@ const G = J + O, ne = D(
|
|
80
80
|
card: s.cardLottie,
|
81
81
|
name: s.name,
|
82
82
|
isCompleted: !1,
|
83
|
-
onPress: () =>
|
83
|
+
onPress: () => T(s)
|
84
84
|
}))
|
85
85
|
}
|
86
86
|
),
|
@@ -96,7 +96,7 @@ const G = J + O, ne = D(
|
|
96
96
|
card: s.cardLottie,
|
97
97
|
name: s.name,
|
98
98
|
isCompleted: s.solved,
|
99
|
-
onPress: () =>
|
99
|
+
onPress: () => y(s)
|
100
100
|
}))
|
101
101
|
}
|
102
102
|
)
|
@@ -107,7 +107,8 @@ const G = J + O, ne = D(
|
|
107
107
|
{
|
108
108
|
label: e.tables.label,
|
109
109
|
data: e.tables.data,
|
110
|
-
onPress: _
|
110
|
+
onPress: _,
|
111
|
+
openModesOfTable: e.tables.openModesOfTable
|
111
112
|
}
|
112
113
|
)
|
113
114
|
])), l;
|
@@ -118,13 +119,13 @@ const G = J + O, ne = D(
|
|
118
119
|
L,
|
119
120
|
P,
|
120
121
|
_,
|
121
|
-
I,
|
122
122
|
y,
|
123
|
+
T,
|
123
124
|
p
|
124
125
|
]), v = h(
|
125
126
|
() => [
|
126
127
|
/* @__PURE__ */ i(
|
127
|
-
|
128
|
+
U,
|
128
129
|
{
|
129
130
|
src: K.SLEEPY_BOI,
|
130
131
|
width: G,
|
@@ -135,12 +136,12 @@ const G = J + O, ne = D(
|
|
135
136
|
[]
|
136
137
|
);
|
137
138
|
return B(() => {
|
138
|
-
e != null && e.puzzles && u &&
|
139
|
-
}, [e == null ? void 0 : e.lessons, e == null ? void 0 : e.puzzles,
|
139
|
+
e != null && e.puzzles && u && A && E(e == null ? void 0 : e.puzzles, !!(e != null && e.lessons), u);
|
140
|
+
}, [e == null ? void 0 : e.lessons, e == null ? void 0 : e.puzzles, A, u, E]), g ? /* @__PURE__ */ i(O, {}) : e ? /* @__PURE__ */ i(
|
140
141
|
z,
|
141
142
|
{
|
142
|
-
ref:
|
143
|
-
items:
|
143
|
+
ref: b,
|
144
|
+
items: S,
|
144
145
|
defaultIndex: R,
|
145
146
|
onNext: c,
|
146
147
|
onPrev: c,
|
@@ -154,7 +155,7 @@ const G = J + O, ne = D(
|
|
154
155
|
) : /* @__PURE__ */ i(
|
155
156
|
z,
|
156
157
|
{
|
157
|
-
ref:
|
158
|
+
ref: b,
|
158
159
|
items: v,
|
159
160
|
analyticsNext: {
|
160
161
|
analyticsLabel: ""
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"game-launcher.js","sources":["../../../../src/features/circle-games/game-launcher/game-launcher.tsx"],"sourcesContent":["import type { ITableDetails } from './comps/tables-card/tables-card-types';\nimport type {\n Game,\n Lesson,\n Puzzle,\n} from './dal/use-get-circle-home-details-dal/use-get-circle-home-dal-types';\nimport type { IGameLauncherProps } from './game-launcher-types';\nimport type { FC, ReactNode } from 'react';\n\nimport { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { LOTTIE } from '../../../assets/lottie/lottie';\nimport { CircularLoader } from '../../ui/loader/circular-loader/circular-loader';\nimport LottieAnimation from '../../ui/lottie-animation/lottie-animation';\nimport { ProjectType } from '../games/web-view/enums';\nimport { useCircleSounds } from '../hooks/use-circle-sounds/use-circle-sounds';\nimport { CircleSoundKey } from '../hooks/use-circle-sounds/use-circle-sounds-enums';\nimport { GAME_LAUNCHER_SIZE } from './comps/card-container/constants';\nimport { Carousel } from './comps/carousel/carousel';\nimport { GAME_LAUNCHER_ASSET_PADDING } from './comps/segmented-game-card/constants';\nimport { SegmentedGameCard } from './comps/segmented-game-card/segmented-game-card';\nimport { TablesCard } from './comps/tables-card/tables-card';\nimport { GAME_LAUNCHER_ANALYTICS_EVENTS } from './game-launcher-analytics-events';\nimport { useGameLauncherJourney } from './use-game-launcher-journey/use-game-launcher-journey';\n\nconst sleepyBoiDimension = GAME_LAUNCHER_SIZE + GAME_LAUNCHER_ASSET_PADDING;\n\nexport const GameLauncher: FC<IGameLauncherProps> = memo(\n ({ onSegmentClick, onJourneyComplete, journeyId, data, isLoading, defaultIndex = 0 }) => {\n const [currentIndex, setCurrentIndex] = useState(defaultIndex);\n const [enableTables] = useState(true);\n\n const { playSwipSound, play } = useCircleSounds();\n const {\n gameRefs,\n lessonRefs,\n puzzleRefs,\n startJourney,\n carouselNextBtnRef,\n isJourneyInProgress,\n } = useGameLauncherJourney({\n setCarouselIndex: setCurrentIndex,\n onSegmentClick,\n onJourneyComplete,\n });\n\n const onTableSegmentClick = useCallback(\n (table: ITableDetails) => {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(table, ProjectType.TABLE);\n },\n [onSegmentClick, play],\n );\n\n const handleLessonSegmentClick = useCallback(\n (lesson: Lesson) => {\n if (lesson.status !== 'completed') {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(lesson, ProjectType.LESSON);\n }\n },\n [onSegmentClick, play],\n );\n\n const handleGameSegmentClick = useCallback(\n (game: Game) => {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(game, ProjectType.GAME);\n },\n [onSegmentClick, play],\n );\n\n const handlePuzzleSegmentClick = useCallback(\n (puzzle: Puzzle) => {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(puzzle, ProjectType.PUZZLE);\n },\n [onSegmentClick, play],\n );\n\n const items = useMemo(() => {\n let itemTypes: ReactNode[] = [];\n\n if (data) {\n if (data.lessons) {\n itemTypes = [\n ...itemTypes,\n <SegmentedGameCard\n ref={lessonRefs}\n label={data.lessons.label}\n value={data.lessons.data.filter(lesson => lesson.status === 'completed').length}\n maxValue={data.lessons.data.length}\n initialValue={data.lessons.initialProgressValue}\n data={data?.lessons.data.map(lesson => ({\n card: lesson.cardLottie,\n name: lesson.name,\n isCompleted: lesson.status === 'completed',\n onPress: () => handleLessonSegmentClick(lesson),\n }))}\n />,\n ];\n }\n\n itemTypes = [\n ...itemTypes,\n <SegmentedGameCard\n ref={gameRefs}\n label={data.games.label}\n value={data.games.data.filter(game => game.isPlayed).length}\n maxValue={data.games.data.length}\n initialValue={data.games.initialProgressValue}\n data={data.games.data.map(game => ({\n card: game.cardLottie,\n name: game.name,\n isCompleted: false,\n onPress: () => handleGameSegmentClick(game),\n }))}\n />,\n <SegmentedGameCard\n ref={puzzleRefs}\n label={data.puzzles.label}\n value={data.puzzles.data.filter(puzzle => puzzle.solved).length}\n maxValue={data.puzzles.data.length}\n initialValue={data.puzzles.initialProgressValue}\n data={data.puzzles.data.map(puzzle => ({\n card: puzzle.cardLottie,\n name: puzzle.name,\n isCompleted: puzzle.solved,\n onPress: () => handlePuzzleSegmentClick(puzzle),\n }))}\n />,\n ];\n\n if (data.tables && enableTables) {\n itemTypes = [\n ...itemTypes,\n <TablesCard\n label={data.tables.label}\n data={data.tables.data}\n onPress={onTableSegmentClick}\n />,\n ];\n }\n }\n\n return itemTypes;\n }, [\n data,\n gameRefs,\n lessonRefs,\n puzzleRefs,\n handleLessonSegmentClick,\n onTableSegmentClick,\n handlePuzzleSegmentClick,\n handleGameSegmentClick,\n enableTables,\n ]);\n\n const sleepyBoiItem = useMemo(\n () => [\n <LottieAnimation\n src={LOTTIE.SLEEPY_BOI}\n width={sleepyBoiDimension}\n height={sleepyBoiDimension}\n />,\n ],\n [],\n );\n\n // Start game launcher journey when the data for puzzles is available\n useEffect(() => {\n if (data?.puzzles && journeyId && isJourneyInProgress) {\n startJourney(data?.puzzles, !!data?.lessons, journeyId);\n }\n }, [data?.lessons, data?.puzzles, isJourneyInProgress, journeyId, startJourney]);\n\n if (isLoading) {\n return <CircularLoader />;\n }\n\n if (!data) {\n return (\n <Carousel\n ref={carouselNextBtnRef}\n items={sleepyBoiItem}\n analyticsNext={{\n analyticsLabel: '',\n }}\n analyticsPrev={{\n analyticsLabel: '',\n }}\n />\n );\n }\n\n return (\n <Carousel\n ref={carouselNextBtnRef}\n items={items}\n defaultIndex={currentIndex}\n onNext={playSwipSound}\n onPrev={playSwipSound}\n analyticsNext={{\n analyticsLabel: GAME_LAUNCHER_ANALYTICS_EVENTS.NEXT_ACTIVITY,\n }}\n analyticsPrev={{\n analyticsLabel: GAME_LAUNCHER_ANALYTICS_EVENTS.PREV_ACTIVITY,\n }}\n />\n );\n },\n);\n"],"names":["sleepyBoiDimension","GAME_LAUNCHER_SIZE","GAME_LAUNCHER_ASSET_PADDING","GameLauncher","memo","onSegmentClick","onJourneyComplete","journeyId","data","isLoading","defaultIndex","currentIndex","setCurrentIndex","useState","enableTables","playSwipSound","play","useCircleSounds","gameRefs","lessonRefs","puzzleRefs","startJourney","carouselNextBtnRef","isJourneyInProgress","useGameLauncherJourney","onTableSegmentClick","useCallback","table","CircleSoundKey","ProjectType","handleLessonSegmentClick","lesson","handleGameSegmentClick","game","handlePuzzleSegmentClick","puzzle","items","useMemo","itemTypes","jsx","SegmentedGameCard","TablesCard","sleepyBoiItem","LottieAnimation","LOTTIE","useEffect","CircularLoader","Carousel","GAME_LAUNCHER_ANALYTICS_EVENTS"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"game-launcher.js","sources":["../../../../src/features/circle-games/game-launcher/game-launcher.tsx"],"sourcesContent":["import type { ITableDetails } from './comps/tables-card/tables-card-types';\nimport type {\n Game,\n Lesson,\n Puzzle,\n} from './dal/use-get-circle-home-details-dal/use-get-circle-home-dal-types';\nimport type { IGameLauncherProps } from './game-launcher-types';\nimport type { FC, ReactNode } from 'react';\n\nimport { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { LOTTIE } from '../../../assets/lottie/lottie';\nimport { CircularLoader } from '../../ui/loader/circular-loader/circular-loader';\nimport LottieAnimation from '../../ui/lottie-animation/lottie-animation';\nimport { ProjectType } from '../games/web-view/enums';\nimport { useCircleSounds } from '../hooks/use-circle-sounds/use-circle-sounds';\nimport { CircleSoundKey } from '../hooks/use-circle-sounds/use-circle-sounds-enums';\nimport { GAME_LAUNCHER_SIZE } from './comps/card-container/constants';\nimport { Carousel } from './comps/carousel/carousel';\nimport { GAME_LAUNCHER_ASSET_PADDING } from './comps/segmented-game-card/constants';\nimport { SegmentedGameCard } from './comps/segmented-game-card/segmented-game-card';\nimport { TablesCard } from './comps/tables-card/tables-card';\nimport { GAME_LAUNCHER_ANALYTICS_EVENTS } from './game-launcher-analytics-events';\nimport { useGameLauncherJourney } from './use-game-launcher-journey/use-game-launcher-journey';\n\nconst sleepyBoiDimension = GAME_LAUNCHER_SIZE + GAME_LAUNCHER_ASSET_PADDING;\n\nexport const GameLauncher: FC<IGameLauncherProps> = memo(\n ({ onSegmentClick, onJourneyComplete, journeyId, data, isLoading, defaultIndex = 0 }) => {\n const [currentIndex, setCurrentIndex] = useState(defaultIndex);\n const [enableTables] = useState(true);\n\n const { playSwipSound, play } = useCircleSounds();\n const {\n gameRefs,\n lessonRefs,\n puzzleRefs,\n startJourney,\n carouselNextBtnRef,\n isJourneyInProgress,\n } = useGameLauncherJourney({\n setCarouselIndex: setCurrentIndex,\n onSegmentClick,\n onJourneyComplete,\n });\n\n const onTableSegmentClick = useCallback(\n (table: ITableDetails) => {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(table, ProjectType.TABLE);\n },\n [onSegmentClick, play],\n );\n\n const handleLessonSegmentClick = useCallback(\n (lesson: Lesson) => {\n if (lesson.status !== 'completed') {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(lesson, ProjectType.LESSON);\n }\n },\n [onSegmentClick, play],\n );\n\n const handleGameSegmentClick = useCallback(\n (game: Game) => {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(game, ProjectType.GAME);\n },\n [onSegmentClick, play],\n );\n\n const handlePuzzleSegmentClick = useCallback(\n (puzzle: Puzzle) => {\n play(CircleSoundKey.GAME_CARD_CLICK);\n onSegmentClick(puzzle, ProjectType.PUZZLE);\n },\n [onSegmentClick, play],\n );\n\n const items = useMemo(() => {\n let itemTypes: ReactNode[] = [];\n\n if (data) {\n if (data.lessons) {\n itemTypes = [\n ...itemTypes,\n <SegmentedGameCard\n ref={lessonRefs}\n label={data.lessons.label}\n value={data.lessons.data.filter(lesson => lesson.status === 'completed').length}\n maxValue={data.lessons.data.length}\n initialValue={data.lessons.initialProgressValue}\n data={data?.lessons.data.map(lesson => ({\n card: lesson.cardLottie,\n name: lesson.name,\n isCompleted: lesson.status === 'completed',\n onPress: () => handleLessonSegmentClick(lesson),\n }))}\n />,\n ];\n }\n\n itemTypes = [\n ...itemTypes,\n <SegmentedGameCard\n ref={gameRefs}\n label={data.games.label}\n value={data.games.data.filter(game => game.isPlayed).length}\n maxValue={data.games.data.length}\n initialValue={data.games.initialProgressValue}\n data={data.games.data.map(game => ({\n card: game.cardLottie,\n name: game.name,\n isCompleted: false,\n onPress: () => handleGameSegmentClick(game),\n }))}\n />,\n <SegmentedGameCard\n ref={puzzleRefs}\n label={data.puzzles.label}\n value={data.puzzles.data.filter(puzzle => puzzle.solved).length}\n maxValue={data.puzzles.data.length}\n initialValue={data.puzzles.initialProgressValue}\n data={data.puzzles.data.map(puzzle => ({\n card: puzzle.cardLottie,\n name: puzzle.name,\n isCompleted: puzzle.solved,\n onPress: () => handlePuzzleSegmentClick(puzzle),\n }))}\n />,\n ];\n\n if (data.tables && enableTables) {\n itemTypes = [\n ...itemTypes,\n <TablesCard\n label={data.tables.label}\n data={data.tables.data}\n onPress={onTableSegmentClick}\n openModesOfTable={data.tables.openModesOfTable}\n />,\n ];\n }\n }\n\n return itemTypes;\n }, [\n data,\n gameRefs,\n lessonRefs,\n puzzleRefs,\n handleLessonSegmentClick,\n onTableSegmentClick,\n handlePuzzleSegmentClick,\n handleGameSegmentClick,\n enableTables,\n ]);\n\n const sleepyBoiItem = useMemo(\n () => [\n <LottieAnimation\n src={LOTTIE.SLEEPY_BOI}\n width={sleepyBoiDimension}\n height={sleepyBoiDimension}\n />,\n ],\n [],\n );\n\n // Start game launcher journey when the data for puzzles is available\n useEffect(() => {\n if (data?.puzzles && journeyId && isJourneyInProgress) {\n startJourney(data?.puzzles, !!data?.lessons, journeyId);\n }\n }, [data?.lessons, data?.puzzles, isJourneyInProgress, journeyId, startJourney]);\n\n if (isLoading) {\n return <CircularLoader />;\n }\n\n if (!data) {\n return (\n <Carousel\n ref={carouselNextBtnRef}\n items={sleepyBoiItem}\n analyticsNext={{\n analyticsLabel: '',\n }}\n analyticsPrev={{\n analyticsLabel: '',\n }}\n />\n );\n }\n\n return (\n <Carousel\n ref={carouselNextBtnRef}\n items={items}\n defaultIndex={currentIndex}\n onNext={playSwipSound}\n onPrev={playSwipSound}\n analyticsNext={{\n analyticsLabel: GAME_LAUNCHER_ANALYTICS_EVENTS.NEXT_ACTIVITY,\n }}\n analyticsPrev={{\n analyticsLabel: GAME_LAUNCHER_ANALYTICS_EVENTS.PREV_ACTIVITY,\n }}\n />\n );\n },\n);\n"],"names":["sleepyBoiDimension","GAME_LAUNCHER_SIZE","GAME_LAUNCHER_ASSET_PADDING","GameLauncher","memo","onSegmentClick","onJourneyComplete","journeyId","data","isLoading","defaultIndex","currentIndex","setCurrentIndex","useState","enableTables","playSwipSound","play","useCircleSounds","gameRefs","lessonRefs","puzzleRefs","startJourney","carouselNextBtnRef","isJourneyInProgress","useGameLauncherJourney","onTableSegmentClick","useCallback","table","CircleSoundKey","ProjectType","handleLessonSegmentClick","lesson","handleGameSegmentClick","game","handlePuzzleSegmentClick","puzzle","items","useMemo","itemTypes","jsx","SegmentedGameCard","TablesCard","sleepyBoiItem","LottieAnimation","LOTTIE","useEffect","CircularLoader","Carousel","GAME_LAUNCHER_ANALYTICS_EVENTS"],"mappings":"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"}
|
@@ -1,9 +1,9 @@
|
|
1
1
|
import o, { keyframes as e } from "styled-components";
|
2
|
-
import { GAME_LAUNCHER_SIZE as r } from "../../circle-games/game-launcher/comps/card-container/constants.js";
|
2
|
+
import { GAME_LAUNCHER_SIZE as r, GAME_LAUNCHER_SIZE_LARGE as s } from "../../circle-games/game-launcher/comps/card-container/constants.js";
|
3
3
|
import i from "../../ui/text/text.js";
|
4
4
|
import { ADJUSTED_START_ANGLE as n } from "./comp/animated-arc/constants.js";
|
5
|
-
import { CONTENT_CONTAINER_Z_INDEX as
|
6
|
-
import { rainbowColorAnimation as
|
5
|
+
import { CONTENT_CONTAINER_Z_INDEX as l, LINE_MARKING_Z_INDEX as d, NUMBER_MARKING_Z_INDEX as m, TARGET_HELPER_TEXT_APPEAR_DELAY as a, RAINBOW_COLOR_ANIMATION_DURATION as p } from "./constants.js";
|
6
|
+
import { rainbowColorAnimation as f } from "./helper.js";
|
7
7
|
const g = o.div`
|
8
8
|
height: ${r}px;
|
9
9
|
width: ${r}px;
|
@@ -16,12 +16,12 @@ const g = o.div`
|
|
16
16
|
border: 1px solid ${({ theme: t }) => t.colors.WHITE};
|
17
17
|
animation: ${({ $isTargetAchieved: t }) => t ? e`100%{transform: scale(1.02)}` : "unset"}
|
18
18
|
0.133s ease alternate;
|
19
|
-
`,
|
19
|
+
`, N = o.div`
|
20
20
|
display: flex;
|
21
21
|
justify-content: center;
|
22
22
|
align-items: center;
|
23
23
|
position: absolute;
|
24
|
-
z-index: ${
|
24
|
+
z-index: ${l};
|
25
25
|
height: 92%;
|
26
26
|
width: 92%;
|
27
27
|
border-radius: 100%;
|
@@ -29,7 +29,7 @@ const g = o.div`
|
|
29
29
|
`, b = o.div`
|
30
30
|
position: relative;
|
31
31
|
flex-grow: 1;
|
32
|
-
bottom: -
|
32
|
+
bottom: ${r === s ? -8 : -6}px;
|
33
33
|
`;
|
34
34
|
o.div`
|
35
35
|
position: absolute;
|
@@ -45,22 +45,22 @@ const u = o.div`
|
|
45
45
|
transform: rotate(${({ $angle: t }) => -240 + t}deg);
|
46
46
|
left: ${r / 2}px;
|
47
47
|
top: ${r / 2}px;
|
48
|
-
z-index: ${l};
|
49
|
-
`, N = o.div`
|
50
|
-
position: absolute;
|
51
|
-
height: ${r - 32}px;
|
52
|
-
transform: rotate(${({ $angle: t }) => -n + t}deg);
|
53
48
|
z-index: ${d};
|
54
49
|
`, T = o.div`
|
55
|
-
|
50
|
+
position: absolute;
|
51
|
+
height: ${r - r * 0.0625 - 10}px;
|
52
|
+
transform: rotate(${({ $angle: t }) => -n + t}deg);
|
53
|
+
z-index: ${m};
|
56
54
|
`, h = o.div`
|
55
|
+
transform: rotate(${({ $angle: t }) => n - t}deg);
|
56
|
+
`, C = o.div`
|
57
57
|
position: absolute;
|
58
58
|
top: 0;
|
59
59
|
transform: ${({ top: t }) => `translateY(${t}px)`};
|
60
|
-
`,
|
60
|
+
`, R = o(i)`
|
61
61
|
animation: ${e`from{transform: translateY(-6px)} to{transform: translateY(0)}`} 0.133s
|
62
62
|
ease-in-out ${a}s forwards;
|
63
|
-
`,
|
63
|
+
`, I = o(i)`
|
64
64
|
animation: ${e`from{transform: translateY(-6px)} to{transform: translateY(0)}`} 0.133s
|
65
65
|
ease ${a}s forwards;
|
66
66
|
`;
|
@@ -68,20 +68,20 @@ o.div`
|
|
68
68
|
height: 100%;
|
69
69
|
width: 100%;
|
70
70
|
`;
|
71
|
-
const
|
72
|
-
animation: ${({ $isTargetAchieved: t }) => t ?
|
73
|
-
${
|
71
|
+
const v = o(i)`
|
72
|
+
animation: ${({ $isTargetAchieved: t }) => t ? f : "unset"}
|
73
|
+
${p}s ease infinite forwards;
|
74
74
|
`;
|
75
75
|
export {
|
76
|
-
|
77
|
-
|
76
|
+
C as BottomAbsoluteView,
|
77
|
+
N as ContentContainer,
|
78
78
|
g as DigitalMeter,
|
79
|
-
|
80
|
-
|
79
|
+
R as HelperTextPrimary,
|
80
|
+
I as HelperTextSecondary,
|
81
81
|
u as LineMarking,
|
82
|
-
|
83
|
-
|
82
|
+
T as MarkingContainer,
|
83
|
+
h as MarkingText,
|
84
84
|
b as NumberCountContainer,
|
85
|
-
|
85
|
+
v as RainboxColorText
|
86
86
|
};
|
87
87
|
//# sourceMappingURL=digital-meter-styled.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"digital-meter-styled.js","sources":["../../../../src/features/post-game-stats/digital-meter/digital-meter-styled.tsx"],"sourcesContent":["import styled, { keyframes } from 'styled-components';\n\nimport {
|
1
|
+
{"version":3,"file":"digital-meter-styled.js","sources":["../../../../src/features/post-game-stats/digital-meter/digital-meter-styled.tsx"],"sourcesContent":["import styled, { keyframes } from 'styled-components';\n\nimport {\n GAME_LAUNCHER_SIZE,\n GAME_LAUNCHER_SIZE_LARGE,\n} from '../../circle-games/game-launcher/comps/card-container/constants';\nimport Text from '../../ui/text/text';\nimport { ADJUSTED_START_ANGLE } from './comp/animated-arc/constants';\nimport {\n CONTENT_CONTAINER_Z_INDEX,\n LINE_MARKING_Z_INDEX,\n NUMBER_MARKING_Z_INDEX,\n RAINBOW_COLOR_ANIMATION_DURATION,\n TARGET_HELPER_TEXT_APPEAR_DELAY,\n} from './constants';\nimport { rainbowColorAnimation } from './helper';\n\nexport const DigitalMeter = styled.div<{ $isTargetAchieved: boolean }>`\n height: ${GAME_LAUNCHER_SIZE}px;\n width: ${GAME_LAUNCHER_SIZE}px;\n background-color: ${({ theme }) => theme.colors.BLACK_2};\n display: flex;\n align-items: center;\n justify-content: center;\n position: relative;\n border-radius: 100%;\n border: 1px solid ${({ theme }) => theme.colors.WHITE};\n animation: ${({ $isTargetAchieved }) =>\n $isTargetAchieved ? keyframes`100%{transform: scale(1.02)}` : 'unset'}\n 0.133s ease alternate;\n`;\n\nexport const ContentContainer = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n position: absolute;\n z-index: ${CONTENT_CONTAINER_Z_INDEX};\n height: 92%;\n width: 92%;\n border-radius: 100%;\n background-color: ${({ theme }) => theme.colors.BLACK_2};\n`;\n\nexport const NumberCountContainer = styled.div`\n position: relative;\n flex-grow: 1;\n bottom: ${GAME_LAUNCHER_SIZE === GAME_LAUNCHER_SIZE_LARGE ? -8 : -6}px;\n`;\n\nexport const AbsoluteView = styled.div`\n position: absolute;\n`;\n\nexport const LineMarking = styled.div<{\n $angle: number;\n}>`\n width: ${GAME_LAUNCHER_SIZE / 2}px;\n height: 2px;\n position: absolute;\n background-color: ${({ theme }) => theme.colors.BLACK_2};\n transform-style: preserve-3d;\n backface-visibility: hidden;\n transform-origin: left;\n transform: rotate(${({ $angle }) => -240 + $angle}deg);\n left: ${GAME_LAUNCHER_SIZE / 2}px;\n top: ${GAME_LAUNCHER_SIZE / 2}px;\n z-index: ${LINE_MARKING_Z_INDEX};\n`;\n\nexport const MarkingContainer = styled.div<{ $angle: number }>`\n position: absolute;\n height: ${GAME_LAUNCHER_SIZE - GAME_LAUNCHER_SIZE * 0.0625 - 10}px;\n transform: rotate(${({ $angle }) => -ADJUSTED_START_ANGLE + $angle}deg);\n z-index: ${NUMBER_MARKING_Z_INDEX};\n`;\n\nexport const MarkingText = styled.div<{ $angle: number }>`\n transform: rotate(${({ $angle }) => ADJUSTED_START_ANGLE - $angle}deg);\n`;\n\nexport const BottomAbsoluteView = styled.div<{ top: number }>`\n position: absolute;\n top: 0;\n transform: ${({ top }) => `translateY(${top}px)`};\n`;\n\nexport const HelperTextPrimary = styled(Text)`\n animation: ${keyframes`from{transform: translateY(-6px)} to{transform: translateY(0)}`} 0.133s\n ease-in-out ${TARGET_HELPER_TEXT_APPEAR_DELAY}s forwards;\n`;\n\nexport const HelperTextSecondary = styled(Text)`\n animation: ${keyframes`from{transform: translateY(-6px)} to{transform: translateY(0)}`} 0.133s\n ease ${TARGET_HELPER_TEXT_APPEAR_DELAY}s forwards;\n`;\n\nexport const TargetAchievedTextLottie = styled.div`\n height: 100%;\n width: 100%;\n`;\n\nexport const RainboxColorText = styled(Text)<{ $isTargetAchieved: boolean }>`\n animation: ${({ $isTargetAchieved }) => ($isTargetAchieved ? rainbowColorAnimation : 'unset')}\n ${RAINBOW_COLOR_ANIMATION_DURATION}s ease infinite forwards;\n`;\n"],"names":["DigitalMeter","styled","GAME_LAUNCHER_SIZE","theme","$isTargetAchieved","keyframes","ContentContainer","CONTENT_CONTAINER_Z_INDEX","NumberCountContainer","GAME_LAUNCHER_SIZE_LARGE","LineMarking","$angle","LINE_MARKING_Z_INDEX","MarkingContainer","ADJUSTED_START_ANGLE","NUMBER_MARKING_Z_INDEX","MarkingText","BottomAbsoluteView","top","HelperTextPrimary","Text","TARGET_HELPER_TEXT_APPEAR_DELAY","HelperTextSecondary","RainboxColorText","rainbowColorAnimation","RAINBOW_COLOR_ANIMATION_DURATION"],"mappings":";;;;;;AAiBO,MAAMA,IAAeC,EAAO;AAAA,YACvBC,CAAkB;AAAA,WACnBA,CAAkB;AAAA,sBACP,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAMnC,CAAC,EAAE,OAAAA,EAAA,MAAYA,EAAM,OAAO,KAAK;AAAA,eACxC,CAAC,EAAE,mBAAAC,QACZA,IAAoBC,kCAA0C,OAAO;AAAA;AAAA,GAI9DC,IAAmBL,EAAO;AAAA;AAAA;AAAA;AAAA;AAAA,aAK1BM,CAAyB;AAAA;AAAA;AAAA;AAAA,sBAIhB,CAAC,EAAE,OAAAJ,EAAA,MAAYA,EAAM,OAAO,OAAO;AAAA,GAG5CK,IAAuBP,EAAO;AAAA;AAAA;AAAA,YAG/BC,MAAuBO,IAA2B,KAAK,EAAE;AAAA;AAGzCR,EAAO;AAAA;AAAA;AAI5B,MAAMS,IAAcT,EAAO;AAAA,WAGvBC,IAAqB,CAAC;AAAA;AAAA;AAAA,sBAGX,CAAC,EAAE,OAAAC,EAAA,MAAYA,EAAM,OAAO,OAAO;AAAA;AAAA;AAAA;AAAA,sBAInC,CAAC,EAAE,QAAAQ,EAAO,MAAM,OAAOA,CAAM;AAAA,UACzCT,IAAqB,CAAC;AAAA,SACvBA,IAAqB,CAAC;AAAA,aAClBU,CAAoB;AAAA,GAGpBC,IAAmBZ,EAAO;AAAA;AAAA,YAE3BC,IAAqBA,IAAqB,SAAS,EAAE;AAAA,sBAC3C,CAAC,EAAE,QAAAS,EAAA,MAAa,CAACG,IAAuBH,CAAM;AAAA,aACvDI,CAAsB;AAAA,GAGtBC,IAAcf,EAAO;AAAA,sBACZ,CAAC,EAAE,QAAAU,QAAaG,IAAuBH,CAAM;AAAA,GAGtDM,IAAqBhB,EAAO;AAAA;AAAA;AAAA,eAG1B,CAAC,EAAE,KAAAiB,EAAU,MAAA,cAAcA,CAAG,KAAK;AAAA,GAGrCC,IAAoBlB,EAAOmB,CAAI;AAAA,eAC7Bf,iEAAyE;AAAA,kBACtEgB,CAA+B;AAAA,GAGpCC,IAAsBrB,EAAOmB,CAAI;AAAA,eAC/Bf,iEAAyE;AAAA,WAC7EgB,CAA+B;AAAA;AAGFpB,EAAO;AAAA;AAAA;AAAA;AAKlC,MAAAsB,IAAmBtB,EAAOmB,CAAI;AAAA,eAC5B,CAAC,EAAE,mBAAAhB,EAAA,MAAyBA,IAAoBoB,IAAwB,OAAQ;AAAA,MACzFC,CAAgC;AAAA;"}
|
@@ -1,135 +1,149 @@
|
|
1
1
|
import { jsxs as c, jsx as r, Fragment as E } from "react/jsx-runtime";
|
2
|
-
import { memo as
|
3
|
-
import { LOTTIE as
|
4
|
-
import { GAME_LAUNCHER_SIZE as
|
5
|
-
import
|
6
|
-
import
|
7
|
-
import
|
8
|
-
import
|
9
|
-
import { NumberCountAnimation as
|
10
|
-
import { AnimatedArc as
|
11
|
-
import { TARGET_ACHIEVED_DELAY as
|
12
|
-
import { DigitalMeter as u, ContentContainer as P, NumberCountContainer as
|
13
|
-
const
|
2
|
+
import { memo as M, useState as O, useEffect as W } from "react";
|
3
|
+
import { LOTTIE as y } from "../../../assets/lottie/lottie.js";
|
4
|
+
import { GAME_LAUNCHER_SIZE as i, GAME_LAUNCHER_SIZE_LARGE as l } from "../../circle-games/game-launcher/comps/card-container/constants.js";
|
5
|
+
import _ from "../../ui/layout/flex-view.js";
|
6
|
+
import w from "../../ui/lottie-animation/lottie-animation.js";
|
7
|
+
import $ from "../../ui/separator/separator.js";
|
8
|
+
import L from "../../ui/text/text.js";
|
9
|
+
import { NumberCountAnimation as B } from "../number-count-animation/number-count-animation.js";
|
10
|
+
import { AnimatedArc as f } from "./comp/animated-arc/animated-arc.js";
|
11
|
+
import { TARGET_ACHIEVED_DELAY as b, TOTAL_ARC_AVAILABLE as m, BORDER_OFFSET as g, PROGRESS_FILL_DURATION as s, PROGRESS_FILL_DELAY as I, TOTAL_ANIMATION_DURATION as U } from "./constants.js";
|
12
|
+
import { DigitalMeter as u, ContentContainer as P, NumberCountContainer as j, RainboxColorText as R, LineMarking as k, MarkingContainer as C, MarkingText as D, BottomAbsoluteView as N, HelperTextPrimary as Y, HelperTextSecondary as Z } from "./digital-meter-styled.js";
|
13
|
+
const tr = M(
|
14
14
|
({
|
15
15
|
show: T,
|
16
|
-
value:
|
16
|
+
value: a,
|
17
17
|
maxValue: n,
|
18
|
-
targetValue:
|
19
|
-
displayText:
|
20
|
-
progressType:
|
21
|
-
helperTextPrimary:
|
18
|
+
targetValue: o = 0,
|
19
|
+
displayText: S,
|
20
|
+
progressType: d,
|
21
|
+
helperTextPrimary: G,
|
22
22
|
helperTextSecondary: H,
|
23
|
-
onComplete:
|
23
|
+
onComplete: p
|
24
24
|
}) => {
|
25
|
-
const [
|
26
|
-
return
|
27
|
-
let
|
28
|
-
const
|
29
|
-
return T && (
|
25
|
+
const [h, F] = O(!1);
|
26
|
+
return W(() => {
|
27
|
+
let t, e;
|
28
|
+
const A = !!(o && a >= o);
|
29
|
+
return T && (A && (t = setTimeout(() => {
|
30
30
|
F(!0);
|
31
|
-
},
|
32
|
-
|
33
|
-
}, (
|
34
|
-
|
31
|
+
}, b * 1e3)), e = setTimeout(() => {
|
32
|
+
p();
|
33
|
+
}, (A ? U : b) * 1e3)), () => {
|
34
|
+
t && clearTimeout(t), e && clearTimeout(e);
|
35
35
|
};
|
36
|
-
}, [T,
|
36
|
+
}, [T, a, o, p]), T ? /* @__PURE__ */ c(u, { $isTargetAchieved: h, children: [
|
37
37
|
/* @__PURE__ */ r(
|
38
|
-
|
38
|
+
f,
|
39
39
|
{
|
40
|
-
targetAngle:
|
41
|
-
strokeWidth: 16,
|
40
|
+
targetAngle: m,
|
41
|
+
strokeWidth: i === l ? 16 : 12,
|
42
42
|
color: "BLACK_5",
|
43
|
-
radius: (
|
43
|
+
radius: (i - g) / 2,
|
44
44
|
duration: 0
|
45
45
|
}
|
46
46
|
),
|
47
|
-
/* @__PURE__ */ r(P, { children: /* @__PURE__ */ c(
|
48
|
-
/* @__PURE__ */ c(
|
49
|
-
/* @__PURE__ */ r(
|
50
|
-
|
47
|
+
/* @__PURE__ */ r(P, { children: /* @__PURE__ */ c(_, { $flexDirection: "column", $alignItems: "center", children: [
|
48
|
+
/* @__PURE__ */ c(_, { $flexDirection: "row", $alignItems: "flex-end", children: [
|
49
|
+
/* @__PURE__ */ r(j, { children: /* @__PURE__ */ r(
|
50
|
+
R,
|
51
51
|
{
|
52
|
-
$renderAs: "ah1",
|
52
|
+
$renderAs: i === l ? "ah1" : "ah2",
|
53
53
|
$color: "GREEN_4",
|
54
|
-
$isTargetAchieved:
|
54
|
+
$isTargetAchieved: h,
|
55
55
|
children: /* @__PURE__ */ r(
|
56
|
-
|
56
|
+
B,
|
57
57
|
{
|
58
58
|
initialValue: 0,
|
59
|
-
targetValue: Math.floor(
|
59
|
+
targetValue: Math.floor(a),
|
60
60
|
durationInSec: s,
|
61
|
-
delayInSec:
|
61
|
+
delayInSec: I
|
62
62
|
}
|
63
63
|
)
|
64
64
|
}
|
65
65
|
) }),
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
66
|
+
d === "stepper" && /* @__PURE__ */ c(
|
67
|
+
L,
|
68
|
+
{
|
69
|
+
$renderAs: i === l ? "ah4" : "ab1",
|
70
|
+
$color: "WHITE",
|
71
|
+
children: [
|
72
|
+
"/",
|
73
|
+
n
|
74
|
+
]
|
75
|
+
}
|
76
|
+
)
|
70
77
|
] }),
|
71
|
-
/* @__PURE__ */ r(
|
72
|
-
/* @__PURE__ */ r(
|
78
|
+
/* @__PURE__ */ r($, { height: 8 }),
|
79
|
+
/* @__PURE__ */ r(
|
80
|
+
L,
|
81
|
+
{
|
82
|
+
$renderAs: i === l ? "ac3-black" : "ac4-black",
|
83
|
+
$color: "WHITE_T_60",
|
84
|
+
children: S
|
85
|
+
}
|
86
|
+
)
|
73
87
|
] }) }),
|
74
|
-
|
75
|
-
const
|
88
|
+
d === "stepper" && Array.from({ length: a }, (t, e) => {
|
89
|
+
const A = m / n;
|
76
90
|
return /* @__PURE__ */ r(
|
77
|
-
|
91
|
+
f,
|
78
92
|
{
|
79
|
-
startAngle:
|
80
|
-
targetAngle:
|
81
|
-
strokeWidth: 12,
|
93
|
+
startAngle: A * e,
|
94
|
+
targetAngle: A,
|
95
|
+
strokeWidth: i === l ? 16 : 12,
|
82
96
|
color: "GREEN_4",
|
83
|
-
radius: (
|
97
|
+
radius: (i - g) / 2,
|
84
98
|
mode: "fade",
|
85
99
|
duration: s / n,
|
86
|
-
delay:
|
87
|
-
playRainbowColors:
|
100
|
+
delay: I + s / n * e,
|
101
|
+
playRainbowColors: h
|
88
102
|
},
|
89
103
|
e
|
90
104
|
);
|
91
105
|
}),
|
92
|
-
|
93
|
-
const
|
106
|
+
d === "stepper" && Array.from({ length: n + 1 }, (t, e) => {
|
107
|
+
const A = m / n;
|
94
108
|
return /* @__PURE__ */ c(E, { children: [
|
95
|
-
/* @__PURE__ */ r(
|
96
|
-
/* @__PURE__ */ r(
|
97
|
-
|
109
|
+
/* @__PURE__ */ r(k, { $angle: A * e }, e + "linemarking"),
|
110
|
+
/* @__PURE__ */ r(C, { $angle: A * e, children: /* @__PURE__ */ r(D, { $angle: A * e, children: /* @__PURE__ */ r(
|
111
|
+
R,
|
98
112
|
{
|
99
|
-
$renderAs: "ac4-black",
|
100
|
-
$isTargetAchieved: e ===
|
101
|
-
$color:
|
113
|
+
$renderAs: i === l ? "ac3-black" : "ac4-black",
|
114
|
+
$isTargetAchieved: e === o && h,
|
115
|
+
$color: o && e === o ? "GREEN_4" : "WHITE_T_60",
|
102
116
|
children: e
|
103
117
|
}
|
104
118
|
) }) }, e)
|
105
119
|
] });
|
106
120
|
}),
|
107
|
-
|
121
|
+
d === "linear" && /* @__PURE__ */ c(E, { children: [
|
108
122
|
/* @__PURE__ */ r(
|
109
|
-
|
123
|
+
f,
|
110
124
|
{
|
111
|
-
targetAngle:
|
112
|
-
strokeWidth: 12,
|
125
|
+
targetAngle: a * m / n,
|
126
|
+
strokeWidth: i === l ? 16 : 12,
|
113
127
|
color: "GREEN_4",
|
114
|
-
radius: (
|
128
|
+
radius: (i - g) / 2,
|
115
129
|
duration: s,
|
116
|
-
delay:
|
117
|
-
playRainbowColors:
|
130
|
+
delay: I,
|
131
|
+
playRainbowColors: h
|
118
132
|
}
|
119
133
|
),
|
120
134
|
/* @__PURE__ */ c(E, { children: [
|
121
|
-
|
122
|
-
Array.from(/* @__PURE__ */ new Set([0,
|
123
|
-
|
135
|
+
o && /* @__PURE__ */ r(k, { $angle: o * m / n }),
|
136
|
+
Array.from(/* @__PURE__ */ new Set([0, o, n])).map((t, e) => /* @__PURE__ */ r(
|
137
|
+
C,
|
124
138
|
{
|
125
|
-
$angle:
|
126
|
-
children: /* @__PURE__ */ r(
|
127
|
-
|
139
|
+
$angle: t * m / n,
|
140
|
+
children: /* @__PURE__ */ r(D, { $angle: t * m / n, children: /* @__PURE__ */ r(
|
141
|
+
R,
|
128
142
|
{
|
129
|
-
$renderAs: "ac4-black",
|
130
|
-
$color:
|
131
|
-
$isTargetAchieved:
|
132
|
-
children:
|
143
|
+
$renderAs: i === l ? "ac3-black" : "ac4-black",
|
144
|
+
$color: o && t === o ? "GREEN_4" : "WHITE_T_60",
|
145
|
+
$isTargetAchieved: a >= t && h && t === o,
|
146
|
+
children: t
|
133
147
|
}
|
134
148
|
) })
|
135
149
|
},
|
@@ -137,18 +151,35 @@ const or = G(
|
|
137
151
|
))
|
138
152
|
] })
|
139
153
|
] }),
|
140
|
-
|
141
|
-
!
|
142
|
-
/* @__PURE__ */ r(
|
143
|
-
/* @__PURE__ */ c(
|
144
|
-
/* @__PURE__ */
|
145
|
-
|
154
|
+
h && /* @__PURE__ */ r(N, { top: i, children: /* @__PURE__ */ r(w, { src: y.TARGET_ACHIEVED_TEXT }) }),
|
155
|
+
!h && /* @__PURE__ */ c(N, { top: i, children: [
|
156
|
+
/* @__PURE__ */ r($, { height: 25 }),
|
157
|
+
/* @__PURE__ */ c(_, { $flexDirection: "column", $alignItems: "center", children: [
|
158
|
+
/* @__PURE__ */ c(
|
159
|
+
Y,
|
160
|
+
{
|
161
|
+
$renderAs: i === l ? "ac3-black" : "ac4-black",
|
162
|
+
$color: "WHITE_T_60",
|
163
|
+
children: [
|
164
|
+
G,
|
165
|
+
/* @__PURE__ */ r($, { height: i * 0.03 })
|
166
|
+
]
|
167
|
+
}
|
168
|
+
),
|
169
|
+
/* @__PURE__ */ r(
|
170
|
+
Z,
|
171
|
+
{
|
172
|
+
$renderAs: i === l ? "ah4" : "ab1",
|
173
|
+
$color: "WHITE",
|
174
|
+
children: H
|
175
|
+
}
|
176
|
+
)
|
146
177
|
] })
|
147
178
|
] })
|
148
179
|
] }) : null;
|
149
180
|
}
|
150
181
|
);
|
151
182
|
export {
|
152
|
-
|
183
|
+
tr as DigitalMeter
|
153
184
|
};
|
154
185
|
//# sourceMappingURL=digital-meter.js.map
|