@coorpacademy/components 10.19.12 → 10.19.13-alpha.8

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 (70) hide show
  1. package/es/organism/review-skills/index.js +2 -0
  2. package/es/organism/review-skills/index.js.map +1 -1
  3. package/es/template/app-review/index.js +35 -0
  4. package/es/template/app-review/index.js.map +1 -0
  5. package/es/template/app-review/{root-view/root-view.native.js → index.native.js} +2 -3
  6. package/es/template/app-review/index.native.js.map +1 -0
  7. package/es/template/app-review/onboarding/index.js +3 -0
  8. package/es/template/app-review/onboarding/index.js.map +1 -0
  9. package/es/template/app-review/onboarding/index.native.js +84 -0
  10. package/es/template/app-review/onboarding/index.native.js.map +1 -0
  11. package/es/template/app-review/{root-view/prop-types.js → prop-types.js} +11 -7
  12. package/es/template/app-review/prop-types.js.map +1 -0
  13. package/es/template/app-review/skills/index.js +3 -0
  14. package/es/template/app-review/skills/index.js.map +1 -0
  15. package/es/template/app-review/skills/index.native.js +179 -0
  16. package/es/template/app-review/skills/index.native.js.map +1 -0
  17. package/es/template/app-review/skills/stories.js +15 -0
  18. package/es/template/app-review/skills/stories.js.map +1 -0
  19. package/es/template/app-review/slides/index.js +338 -0
  20. package/es/template/app-review/slides/index.js.map +1 -0
  21. package/es/template/app-review/slides/index.native.js +212 -0
  22. package/es/template/app-review/slides/index.native.js.map +1 -0
  23. package/es/template/app-review/slides/prop-types.js +67 -0
  24. package/es/template/app-review/slides/prop-types.js.map +1 -0
  25. package/es/template/app-review/{slides-review → slides}/style.css +0 -0
  26. package/lib/organism/review-skills/index.js +5 -1
  27. package/lib/organism/review-skills/index.js.map +1 -1
  28. package/lib/template/app-review/index.js +52 -0
  29. package/lib/template/app-review/index.js.map +1 -0
  30. package/lib/template/app-review/{root-view/root-view.native.js → index.native.js} +5 -9
  31. package/lib/template/app-review/index.native.js.map +1 -0
  32. package/lib/template/app-review/onboarding/index.js +12 -0
  33. package/lib/template/app-review/onboarding/index.js.map +1 -0
  34. package/lib/template/app-review/onboarding/index.native.js +100 -0
  35. package/lib/template/app-review/onboarding/index.native.js.map +1 -0
  36. package/lib/template/app-review/prop-types.js +33 -0
  37. package/lib/template/app-review/prop-types.js.map +1 -0
  38. package/lib/template/app-review/skills/index.js +12 -0
  39. package/lib/template/app-review/skills/index.js.map +1 -0
  40. package/lib/template/app-review/skills/index.native.js +197 -0
  41. package/lib/template/app-review/skills/index.native.js.map +1 -0
  42. package/lib/template/app-review/skills/stories.js +16 -0
  43. package/lib/template/app-review/skills/stories.js.map +1 -0
  44. package/lib/template/app-review/slides/index.js +367 -0
  45. package/lib/template/app-review/slides/index.js.map +1 -0
  46. package/lib/template/app-review/slides/index.native.js +229 -0
  47. package/lib/template/app-review/slides/index.native.js.map +1 -0
  48. package/lib/template/app-review/slides/prop-types.js +84 -0
  49. package/lib/template/app-review/slides/prop-types.js.map +1 -0
  50. package/lib/template/app-review/{slides-review → slides}/style.css +0 -0
  51. package/package.json +2 -2
  52. package/es/template/app-review/root-view/common.js +0 -6
  53. package/es/template/app-review/root-view/common.js.map +0 -1
  54. package/es/template/app-review/root-view/prop-types.js.map +0 -1
  55. package/es/template/app-review/root-view/root-view.js +0 -14
  56. package/es/template/app-review/root-view/root-view.js.map +0 -1
  57. package/es/template/app-review/root-view/root-view.modules.css +0 -8
  58. package/es/template/app-review/root-view/root-view.native.js.map +0 -1
  59. package/es/template/app-review/slides-review/index.js +0 -427
  60. package/es/template/app-review/slides-review/index.js.map +0 -1
  61. package/lib/template/app-review/root-view/common.js +0 -11
  62. package/lib/template/app-review/root-view/common.js.map +0 -1
  63. package/lib/template/app-review/root-view/prop-types.js +0 -28
  64. package/lib/template/app-review/root-view/prop-types.js.map +0 -1
  65. package/lib/template/app-review/root-view/root-view.js +0 -25
  66. package/lib/template/app-review/root-view/root-view.js.map +0 -1
  67. package/lib/template/app-review/root-view/root-view.modules.css +0 -8
  68. package/lib/template/app-review/root-view/root-view.native.js.map +0 -1
  69. package/lib/template/app-review/slides-review/index.js +0 -453
  70. package/lib/template/app-review/slides-review/index.js.map +0 -1
@@ -1,427 +0,0 @@
1
- function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
2
-
3
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
4
-
5
- import React, { useState, useReducer, useMemo } from 'react';
6
- import PropTypes from 'prop-types';
7
- import classnames from 'classnames';
8
- import getOr from 'lodash/fp/getOr';
9
- import omit from 'lodash/fp/omit';
10
- import isNil from 'lodash/fp/isNil';
11
- import ReviewBackground from '../../../atom/review-background';
12
- import { ICON_VALUES } from '../../../atom/review-header-step-item';
13
- import ReviewCongrats from '../../../organism/review-congrats';
14
- import ReviewHeader from '../../../organism/review-header';
15
- import ReviewCorrectionPopin from '../../../molecule/review-correction-popin';
16
- import Answer from '../../../molecule/answer';
17
- import ButtonLink from '../../../atom/button-link';
18
- import style from './style.css';
19
- const stylesByPosition = {
20
- 0: style.position0,
21
- 1: style.position1,
22
- 2: style.position2,
23
- 3: style.position3,
24
- 4: style.position4
25
- };
26
- const TOTAL_SLIDES_STACK = 5;
27
- const HIGHEST_INDEX = TOTAL_SLIDES_STACK - 1;
28
-
29
- const getSlideAnimation = (action, position, hidden) => {
30
- switch (action) {
31
- case 'unstack':
32
- return style.slideOutHideAndIn;
33
-
34
- case 'restack':
35
- return style.slideOutAndIn;
36
-
37
- default:
38
- return hidden ? style.hiddenSlide : stylesByPosition[position];
39
- }
40
- };
41
-
42
- const buildSlide = (slideNumber, slidesState, updateSlides, primarySkinColor, validate, correctionPopinProps, updateStepItems, finishedSlides, updateFinishedSlides, updateReviewState, updateShouldMountSlides) => {
43
- const {
44
- hidden,
45
- endReview,
46
- position,
47
- action,
48
- validationResult,
49
- question,
50
- answer
51
- } = slidesState.get(slideNumber);
52
- const {
53
- onClick: onValidateClick,
54
- label: validateLabel
55
- } = validate;
56
- const validateButtonProps = {
57
- customStyle: {
58
- backgroundColor: primarySkinColor
59
- },
60
-
61
- /*
62
- slide validation action, this will trigger the correction popin but will not trigger any
63
- animations unless the endReview signal is received (all slides will disappear),
64
- if there is a nextSlide content, it will be loaded here
65
- if it is the last slide and the content needs to be different, then that update will
66
- be handled on the next slide logic but the content will be carried from here.
67
- */
68
- onClick: async () => {
69
- const {
70
- validationResult: result,
71
- nextSlide,
72
- endReview: _endReview
73
- } = await onValidateClick();
74
- updateSlides([slideNumber, {
75
- hidden,
76
- position,
77
- validationResult: result,
78
- answer,
79
- question,
80
- nextSlide,
81
- numberOfFinishedSlides: finishedSlides.size,
82
- endReview: _endReview
83
- }]); // on endReview, this gives some time for the slides to slide out && then launch
84
- // the 'finished' logic as it would happen when normally finishing the review
85
-
86
- if (_endReview) {
87
- updateReviewState('finished');
88
- setTimeout(() => updateShouldMountSlides(false), 2000);
89
- }
90
-
91
- updateStepItems([slideNumber, {
92
- icon: result === 'success' ? ICON_VALUES.right : ICON_VALUES.wrong,
93
- finishedSlides
94
- }]); // only stores successful slides
95
-
96
- if (result === 'success') updateFinishedSlides([slideNumber, true]);
97
- },
98
- 'aria-label': validateLabel,
99
- label: validateLabel,
100
- 'data-name': `slide-validate-button-${slideNumber}`,
101
- className: style.validateButton,
102
- disabled: !isNil(validationResult)
103
- };
104
- const {
105
- klf,
106
- information,
107
- next,
108
- successLabel,
109
- failureLabel
110
- } = correctionPopinProps;
111
- const _correctionPopinProps = {
112
- next: {
113
- /*
114
- next slide action, this will trigger the slides animations
115
- if it is the last slide AND the content needs to be different, then that update
116
- of the content will be handled here (and in the validate as it happens normally )
117
- from the content carried from the validate action.
118
- */
119
- onClick: () => {
120
- updateSlides([slideNumber, {
121
- hidden: validationResult === 'success',
122
- position: HIGHEST_INDEX - finishedSlides.size,
123
- action: validationResult === 'success' ? 'unstack' : 'restack',
124
- answer,
125
- question,
126
- validationResult,
127
- numberOfFinishedSlides: finishedSlides.size,
128
- endReview
129
- }]);
130
- updateStepItems([slideNumber, {
131
- setNext: true,
132
- finishedSlides,
133
- current: finishedSlides.size === HIGHEST_INDEX && validationResult !== 'success'
134
- }]); // if slides are successfully reviewed, then trigger the 'finished' state
135
-
136
- if (finishedSlides.size === TOTAL_SLIDES_STACK) {
137
- updateReviewState('finished');
138
- setTimeout(() => updateShouldMountSlides(false), 2000);
139
- }
140
- },
141
- label: next.label,
142
- 'data-name': `next-question-button-${slideNumber}`,
143
- 'aria-label': next['aria-label']
144
- },
145
- klf,
146
- information,
147
- type: validationResult === 'success' ? 'right' : 'wrong',
148
- resultLabel: validationResult === 'success' ? successLabel : failureLabel
149
- };
150
- const questionOrigin = 'From "Master Design Thinking to become more agile" course';
151
- return /*#__PURE__*/React.createElement("div", {
152
- key: `slide-${slideNumber}`,
153
- "data-name": `slide-${slideNumber}`,
154
- className: classnames(style.slideBase, getSlideAnimation(action, position, hidden), endReview ? style.endReview : null)
155
- }, answer && question ? /*#__PURE__*/React.createElement("div", {
156
- key: "content-container",
157
- className: style.slideContentContainer
158
- }, /*#__PURE__*/React.createElement("div", {
159
- key: "from-course",
160
- className: style.questionOrigin
161
- }, questionOrigin), /*#__PURE__*/React.createElement("div", {
162
- key: "title",
163
- className: style.question
164
- }, question), /*#__PURE__*/React.createElement("div", {
165
- key: "help",
166
- className: style.help
167
- }, answer.help), /*#__PURE__*/React.createElement("div", {
168
- key: "answer-container",
169
- className: style.answerContainer
170
- }, /*#__PURE__*/React.createElement(Answer, _extends({}, answer, {
171
- key: "answer"
172
- })))) : null, /*#__PURE__*/React.createElement("div", {
173
- key: "button-wrapper",
174
- className: style.validateButtonWrapper
175
- }, /*#__PURE__*/React.createElement(ButtonLink, validateButtonProps)), /*#__PURE__*/React.createElement("div", {
176
- className: validationResult ? style.correctionPopinWrapper : style.hiddenCorrectionPopinWrapper,
177
- style: _extends({}, finishedSlides.size !== HIGHEST_INDEX && !validationResult && {
178
- display: 'none'
179
- })
180
- }, /*#__PURE__*/React.createElement(ReviewCorrectionPopin, _correctionPopinProps)));
181
- }; // ||-------> Handles the updates of a given slide (using the 'id' in the action),
182
- // & then updates de remaining slides if this given change should impact their content
183
-
184
-
185
- const slidesStateReducer = (state, action) => {
186
- const [id, value] = action;
187
-
188
- const _state = new Map();
189
-
190
- const {
191
- nextSlide,
192
- numberOfFinishedSlides
193
- } = value,
194
- newValue = _objectWithoutPropertiesLoose(value, ["nextSlide", "numberOfFinishedSlides"]); // eslint-disable-next-line fp/no-loops
195
-
196
-
197
- for (const [index, previousValue] of state) {
198
- if (index === id) {
199
- // update the given slide
200
- if (nextSlide && numberOfFinishedSlides === HIGHEST_INDEX) {
201
- _state.set(index, _extends(_extends({}, previousValue), {}, {
202
- nextSlide,
203
- position: newValue.position,
204
- validationResult: newValue.validationResult
205
- }));
206
- } else if (numberOfFinishedSlides === HIGHEST_INDEX && previousValue.nextSlide) {
207
- _state.set(index, _extends(_extends({}, previousValue.nextSlide), {}, {
208
- position: previousValue.position
209
- }));
210
- } else _state.set(id, newValue);
211
- } else {
212
- // updates the rest of the slides here
213
- const {
214
- hidden,
215
- position,
216
- answer,
217
- question
218
- } = previousValue;
219
-
220
- if (nextSlide) {
221
- _state.set(index, _extends(_extends({}, nextSlide), {}, {
222
- endReview: newValue.endReview,
223
- hidden,
224
- position
225
- }));
226
- } else {
227
- _state.set(index, {
228
- hidden,
229
- position: position - 1,
230
- answer,
231
- question,
232
- endReview: newValue.endReview
233
- });
234
- }
235
- }
236
- }
237
-
238
- return _state;
239
- }; // ||-------> aux function, finds the consecutive index to loop from 0 to HIGHEST_INDEX (4) & again to 0
240
-
241
-
242
- const getNextIndex = currentIndex => currentIndex === HIGHEST_INDEX ? 0 : currentIndex + 1; // ||-------> calculates which should be the next step to visit (as there can be already answered slides &&
243
- // they have to be skipped)
244
-
245
-
246
- const calculateNextStepIndex = (currentSlideIndex, finishedSlides, lastVisitedIndex = null) => {
247
- // only one slide remaining
248
- if (lastVisitedIndex === currentSlideIndex) {
249
- return currentSlideIndex;
250
- }
251
-
252
- const indexToVisit = getNextIndex(isNil(lastVisitedIndex) ? currentSlideIndex : lastVisitedIndex);
253
- return finishedSlides.has(indexToVisit) ? calculateNextStepIndex(currentSlideIndex, finishedSlides, indexToVisit) : indexToVisit;
254
- }; // ||-------> Handles the updates of a given step item (using the 'id' in the action),
255
- // & then updates de remaining step items if this given change should impact their content
256
-
257
-
258
- const stepItemsReducer = (state, action) => {
259
- const [id, value] = action;
260
-
261
- const {
262
- setNext,
263
- finishedSlides
264
- } = value,
265
- rest = _objectWithoutPropertiesLoose(value, ["setNext", "finishedSlides"]);
266
-
267
- const _state = new Map();
268
-
269
- const nextIndex = !rest.current && setNext ? calculateNextStepIndex(id, finishedSlides) : null; // eslint-disable-next-line fp/no-loops
270
-
271
- for (const [index, previousValue] of state) {
272
- if (id === index) _state.set(id, _extends(_extends({}, previousValue), rest));else if (setNext && nextIndex === index) {
273
- _state.set(index, _extends(_extends({}, previousValue), {}, {
274
- current: true
275
- }));
276
- } else _state.set(index, previousValue);
277
- }
278
-
279
- return _state;
280
- }; // ||-------> Stores the correctly answered (finished) slides, the initial state is an empty Map
281
-
282
-
283
- const finishedSlidesReducer = (state, action) => {
284
- const [id, value] = action;
285
-
286
- const _state = new Map(); // eslint-disable-next-line fp/no-loops
287
-
288
-
289
- for (const [index, previousValue] of state) {
290
- _state.set(index, previousValue);
291
- }
292
-
293
- _state.set(id, value);
294
-
295
- return _state;
296
- };
297
-
298
- const SlidesReview = ({
299
- headerProps,
300
- reviewBackgroundAriaLabel,
301
- validate,
302
- correctionPopinProps,
303
- firstSlide,
304
- congratsProps
305
- }, context) => {
306
- const {
307
- skin
308
- } = context;
309
- const primarySkinColor = useMemo(() => getOr('#00B0FF', 'common.primary', skin), [skin]); // ||-------> States init: build initial states && memoize them + reducers creation
310
-
311
- const slidesInitialState = useMemo(() => {
312
- const states = new Map();
313
- const {
314
- answer,
315
- question
316
- } = firstSlide; // eslint-disable-next-line fp/no-loops
317
-
318
- for (let index = 0; index < TOTAL_SLIDES_STACK; index++) {
319
- const content = index === 0 ? {
320
- answer,
321
- question
322
- } : {};
323
- states.set(index, _extends(_extends({}, content), {}, {
324
- hidden: false,
325
- position: index
326
- }));
327
- }
328
-
329
- return states;
330
- }, [firstSlide]);
331
- const stepItemsInitialState = useMemo(() => {
332
- const states = new Map(); // eslint-disable-next-line fp/no-loops
333
-
334
- for (let index = 0; index < TOTAL_SLIDES_STACK; index++) {
335
- const current = index === 0;
336
- states.set(index, {
337
- current,
338
- value: `${index + 1}`,
339
- icon: null
340
- });
341
- }
342
-
343
- return states;
344
- }, []);
345
- const [finishedSlides, updateFinishedSlides] = useReducer(finishedSlidesReducer, new Map());
346
- const [slidesState, updateSlides] = useReducer(slidesStateReducer, slidesInitialState);
347
- const [stepItemsState, updateStepItems] = useReducer(stepItemsReducer, stepItemsInitialState);
348
- const [reviewState, updateReviewState] = useState('ongoing');
349
- /*
350
- ||-------> the slides have an slightly longer lifespan than the "ongoing" review State,
351
- after reviewState changes to "finished" the slides don't have to unmount until the last
352
- slide-out animation is finished, the slides have to be unmounted to be RGAA complaint
353
- (if they are only invisible but still mounted, then they will be found the assisting tools & clutter it)
354
- */
355
-
356
- const [shouldMountSlides, updateShouldMountSlides] = useState(true); // ||-------> build each slide, passing down the reducers that will act on validation & next clicks
357
-
358
- const builtStackedSlides = useMemo(() => {
359
- const StackedSlides = []; // eslint-disable-next-line fp/no-loops
360
-
361
- for (let slideNumber = 0; slideNumber < TOTAL_SLIDES_STACK; slideNumber++) {
362
- StackedSlides.push(buildSlide(slideNumber, slidesState, updateSlides, primarySkinColor, validate, correctionPopinProps, updateStepItems, finishedSlides, updateFinishedSlides, updateReviewState, updateShouldMountSlides));
363
- }
364
-
365
- return StackedSlides;
366
- }, [slidesState, primarySkinColor, validate, correctionPopinProps, finishedSlides]); // ||-------> transform the step items state (Map structure) to an Array
367
-
368
- const stepItemsArray = useMemo(() => {
369
- // eslint-disable-next-line unicorn/prefer-spread
370
- return Array.from(stepItemsState.values());
371
- }, [stepItemsState]);
372
-
373
- const _headerProps = _extends(_extends({}, headerProps), {}, {
374
- steps: stepItemsArray,
375
- key: 'review-header',
376
- hiddenSteps: reviewState !== 'ongoing'
377
- });
378
-
379
- return /*#__PURE__*/React.createElement("div", {
380
- key: "slides-revision-container",
381
- "data-name": "slides-revision-container",
382
- className: style.slidesRevisionContainer
383
- }, /*#__PURE__*/React.createElement("div", {
384
- key: "player-background-container",
385
- className: style.playerBackground
386
- }, /*#__PURE__*/React.createElement(ReviewBackground, {
387
- "aria-label": reviewBackgroundAriaLabel
388
- })), /*#__PURE__*/React.createElement("div", {
389
- key: "review-header-wrapper",
390
- className: style.reviewHeaderContainer
391
- }, /*#__PURE__*/React.createElement(ReviewHeader, _headerProps)), shouldMountSlides ? /*#__PURE__*/React.createElement("div", {
392
- key: "stacked-slides-container-y-overflow",
393
- className: style.stackedSlidesYAxisOverflowContainer
394
- }, /*#__PURE__*/React.createElement("div", {
395
- key: "stacked-slides-container",
396
- "data-name": "stacked-slides-container",
397
- className: style.stackedSlidesContainer
398
- }, builtStackedSlides)) : null, reviewState === 'finished' ? /*#__PURE__*/React.createElement("div", {
399
- className: style.congrats
400
- }, /*#__PURE__*/React.createElement(ReviewCongrats, congratsProps)) : null);
401
- };
402
-
403
- SlidesReview.propTypes = process.env.NODE_ENV !== "production" ? {
404
- headerProps: PropTypes.shape(omit(['steps', ''], ReviewHeader.propTypes)),
405
- reviewBackgroundAriaLabel: ReviewBackground.propTypes['aria-label'],
406
- validate: PropTypes.shape({
407
- label: PropTypes.string,
408
- onClick: PropTypes.func
409
- }),
410
- firstSlide: PropTypes.shape({
411
- question: PropTypes.string,
412
- answer: PropTypes.shape(Answer.propTypes)
413
- }),
414
- correctionPopinProps: PropTypes.shape({
415
- klf: ReviewCorrectionPopin.propTypes.klf,
416
- information: ReviewCorrectionPopin.propTypes.information,
417
- next: PropTypes.shape({
418
- label: PropTypes.string,
419
- 'aria-label': PropTypes.string
420
- }),
421
- successLabel: ReviewCorrectionPopin.propTypes.resultLabel,
422
- failureLabel: ReviewCorrectionPopin.propTypes.resultLabel
423
- }),
424
- congratsProps: PropTypes.shape(ReviewCongrats.propTypes)
425
- } : {};
426
- export default SlidesReview;
427
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/template/app-review/slides-review/index.js"],"names":["React","useState","useReducer","useMemo","PropTypes","classnames","getOr","omit","isNil","ReviewBackground","ICON_VALUES","ReviewCongrats","ReviewHeader","ReviewCorrectionPopin","Answer","ButtonLink","style","stylesByPosition","position0","position1","position2","position3","position4","TOTAL_SLIDES_STACK","HIGHEST_INDEX","getSlideAnimation","action","position","hidden","slideOutHideAndIn","slideOutAndIn","hiddenSlide","buildSlide","slideNumber","slidesState","updateSlides","primarySkinColor","validate","correctionPopinProps","updateStepItems","finishedSlides","updateFinishedSlides","updateReviewState","updateShouldMountSlides","endReview","validationResult","question","answer","get","onClick","onValidateClick","label","validateLabel","validateButtonProps","customStyle","backgroundColor","result","nextSlide","_endReview","numberOfFinishedSlides","size","setTimeout","icon","right","wrong","className","validateButton","disabled","klf","information","next","successLabel","failureLabel","_correctionPopinProps","setNext","current","type","resultLabel","questionOrigin","slideBase","slideContentContainer","help","answerContainer","validateButtonWrapper","correctionPopinWrapper","hiddenCorrectionPopinWrapper","display","slidesStateReducer","state","id","value","_state","Map","newValue","index","previousValue","set","getNextIndex","currentIndex","calculateNextStepIndex","currentSlideIndex","lastVisitedIndex","indexToVisit","has","stepItemsReducer","rest","nextIndex","finishedSlidesReducer","SlidesReview","headerProps","reviewBackgroundAriaLabel","firstSlide","congratsProps","context","skin","slidesInitialState","states","content","stepItemsInitialState","stepItemsState","reviewState","shouldMountSlides","builtStackedSlides","StackedSlides","push","stepItemsArray","Array","from","values","_headerProps","steps","key","hiddenSteps","slidesRevisionContainer","playerBackground","reviewHeaderContainer","stackedSlidesYAxisOverflowContainer","stackedSlidesContainer","congrats","propTypes","shape","string","func"],"mappings":";;;;AAAA,OAAOA,KAAP,IAAeC,QAAf,EAAyBC,UAAzB,EAAqCC,OAArC,QAAmD,OAAnD;AACA,OAAOC,SAAP,MAAsB,YAAtB;AACA,OAAOC,UAAP,MAAuB,YAAvB;AACA,OAAOC,KAAP,MAAkB,iBAAlB;AACA,OAAOC,IAAP,MAAiB,gBAAjB;AACA,OAAOC,KAAP,MAAkB,iBAAlB;AACA,OAAOC,gBAAP,MAA6B,iCAA7B;AACA,SAAQC,WAAR,QAA0B,uCAA1B;AACA,OAAOC,cAAP,MAA2B,mCAA3B;AACA,OAAOC,YAAP,MAAyB,iCAAzB;AACA,OAAOC,qBAAP,MAAkC,2CAAlC;AACA,OAAOC,MAAP,MAAmB,0BAAnB;AACA,OAAOC,UAAP,MAAuB,2BAAvB;AACA,OAAOC,KAAP,MAAkB,aAAlB;AAEA,MAAMC,gBAAgB,GAAG;AACvB,KAAGD,KAAK,CAACE,SADc;AAEvB,KAAGF,KAAK,CAACG,SAFc;AAGvB,KAAGH,KAAK,CAACI,SAHc;AAIvB,KAAGJ,KAAK,CAACK,SAJc;AAKvB,KAAGL,KAAK,CAACM;AALc,CAAzB;AAQA,MAAMC,kBAAkB,GAAG,CAA3B;AACA,MAAMC,aAAa,GAAGD,kBAAkB,GAAG,CAA3C;;AAEA,MAAME,iBAAiB,GAAG,CAACC,MAAD,EAASC,QAAT,EAAmBC,MAAnB,KAA8B;AACtD,UAAQF,MAAR;AACE,SAAK,SAAL;AACE,aAAOV,KAAK,CAACa,iBAAb;;AACF,SAAK,SAAL;AACE,aAAOb,KAAK,CAACc,aAAb;;AACF;AACE,aAAOF,MAAM,GAAGZ,KAAK,CAACe,WAAT,GAAuBd,gBAAgB,CAACU,QAAD,CAApD;AANJ;AAQD,CATD;;AAWA,MAAMK,UAAU,GAAG,CACjBC,WADiB,EAEjBC,WAFiB,EAGjBC,YAHiB,EAIjBC,gBAJiB,EAKjBC,QALiB,EAMjBC,oBANiB,EAOjBC,eAPiB,EAQjBC,cARiB,EASjBC,oBATiB,EAUjBC,iBAViB,EAWjBC,uBAXiB,KAYd;AACH,QAAM;AAACf,IAAAA,MAAD;AAASgB,IAAAA,SAAT;AAAoBjB,IAAAA,QAApB;AAA8BD,IAAAA,MAA9B;AAAsCmB,IAAAA,gBAAtC;AAAwDC,IAAAA,QAAxD;AAAkEC,IAAAA;AAAlE,MAA4Eb,WAAW,CAACc,GAAZ,CAChFf,WADgF,CAAlF;AAGA,QAAM;AAACgB,IAAAA,OAAO,EAAEC,eAAV;AAA2BC,IAAAA,KAAK,EAAEC;AAAlC,MAAmDf,QAAzD;AAEA,QAAMgB,mBAAmB,GAAG;AAC1BC,IAAAA,WAAW,EAAE;AACXC,MAAAA,eAAe,EAAEnB;AADN,KADa;;AAI1B;;;;;;;AAOAa,IAAAA,OAAO,EAAE,YAAY;AACnB,YAAM;AAACJ,QAAAA,gBAAgB,EAAEW,MAAnB;AAA2BC,QAAAA,SAA3B;AAAsCb,QAAAA,SAAS,EAAEc;AAAjD,UAA+D,MAAMR,eAAe,EAA1F;AACAf,MAAAA,YAAY,CAAC,CACXF,WADW,EAEX;AACEL,QAAAA,MADF;AAEED,QAAAA,QAFF;AAGEkB,QAAAA,gBAAgB,EAAEW,MAHpB;AAIET,QAAAA,MAJF;AAKED,QAAAA,QALF;AAMEW,QAAAA,SANF;AAOEE,QAAAA,sBAAsB,EAAEnB,cAAc,CAACoB,IAPzC;AAQEhB,QAAAA,SAAS,EAAEc;AARb,OAFW,CAAD,CAAZ,CAFmB,CAenB;AACA;;AACA,UAAIA,UAAJ,EAAgB;AACdhB,QAAAA,iBAAiB,CAAC,UAAD,CAAjB;AACAmB,QAAAA,UAAU,CAAC,MAAMlB,uBAAuB,CAAC,KAAD,CAA9B,EAAuC,IAAvC,CAAV;AACD;;AACDJ,MAAAA,eAAe,CAAC,CACdN,WADc,EAEd;AACE6B,QAAAA,IAAI,EAAEN,MAAM,KAAK,SAAX,GAAuB9C,WAAW,CAACqD,KAAnC,GAA2CrD,WAAW,CAACsD,KAD/D;AAEExB,QAAAA;AAFF,OAFc,CAAD,CAAf,CArBmB,CA4BnB;;AACA,UAAIgB,MAAM,KAAK,SAAf,EAA0Bf,oBAAoB,CAAC,CAACR,WAAD,EAAc,IAAd,CAAD,CAApB;AAC3B,KAzCyB;AA0C1B,kBAAcmB,aA1CY;AA2C1BD,IAAAA,KAAK,EAAEC,aA3CmB;AA4C1B,iBAAc,yBAAwBnB,WAAY,EA5CxB;AA6C1BgC,IAAAA,SAAS,EAAEjD,KAAK,CAACkD,cA7CS;AA8C1BC,IAAAA,QAAQ,EAAE,CAAC3D,KAAK,CAACqC,gBAAD;AA9CU,GAA5B;AAiDA,QAAM;AAACuB,IAAAA,GAAD;AAAMC,IAAAA,WAAN;AAAmBC,IAAAA,IAAnB;AAAyBC,IAAAA,YAAzB;AAAuCC,IAAAA;AAAvC,MAAuDlC,oBAA7D;AAEA,QAAMmC,qBAAqB,GAAG;AAC5BH,IAAAA,IAAI,EAAE;AACJ;;;;;;AAMArB,MAAAA,OAAO,EAAE,MAAM;AACbd,QAAAA,YAAY,CAAC,CACXF,WADW,EAEX;AACEL,UAAAA,MAAM,EAAEiB,gBAAgB,KAAK,SAD/B;AAEElB,UAAAA,QAAQ,EAAEH,aAAa,GAAGgB,cAAc,CAACoB,IAF3C;AAGElC,UAAAA,MAAM,EAAEmB,gBAAgB,KAAK,SAArB,GAAiC,SAAjC,GAA6C,SAHvD;AAIEE,UAAAA,MAJF;AAKED,UAAAA,QALF;AAMED,UAAAA,gBANF;AAOEc,UAAAA,sBAAsB,EAAEnB,cAAc,CAACoB,IAPzC;AAQEhB,UAAAA;AARF,SAFW,CAAD,CAAZ;AAaAL,QAAAA,eAAe,CAAC,CACdN,WADc,EAEd;AACEyC,UAAAA,OAAO,EAAE,IADX;AAEElC,UAAAA,cAFF;AAGEmC,UAAAA,OAAO,EAAEnC,cAAc,CAACoB,IAAf,KAAwBpC,aAAxB,IAAyCqB,gBAAgB,KAAK;AAHzE,SAFc,CAAD,CAAf,CAda,CAsBb;;AACA,YAAIL,cAAc,CAACoB,IAAf,KAAwBrC,kBAA5B,EAAgD;AAC9CmB,UAAAA,iBAAiB,CAAC,UAAD,CAAjB;AACAmB,UAAAA,UAAU,CAAC,MAAMlB,uBAAuB,CAAC,KAAD,CAA9B,EAAuC,IAAvC,CAAV;AACD;AACF,OAlCG;AAmCJQ,MAAAA,KAAK,EAAEmB,IAAI,CAACnB,KAnCR;AAoCJ,mBAAc,wBAAuBlB,WAAY,EApC7C;AAqCJ,oBAAcqC,IAAI,CAAC,YAAD;AArCd,KADsB;AAwC5BF,IAAAA,GAxC4B;AAyC5BC,IAAAA,WAzC4B;AA0C5BO,IAAAA,IAAI,EAAE/B,gBAAgB,KAAK,SAArB,GAAiC,OAAjC,GAA2C,OA1CrB;AA2C5BgC,IAAAA,WAAW,EAAEhC,gBAAgB,KAAK,SAArB,GAAiC0B,YAAjC,GAAgDC;AA3CjC,GAA9B;AA8CA,QAAMM,cAAc,GAAG,2DAAvB;AAEA,sBACE;AACE,IAAA,GAAG,EAAG,SAAQ7C,WAAY,EAD5B;AAEE,iBAAY,SAAQA,WAAY,EAFlC;AAGE,IAAA,SAAS,EAAE5B,UAAU,CACnBW,KAAK,CAAC+D,SADa,EAEnBtD,iBAAiB,CAACC,MAAD,EAASC,QAAT,EAAmBC,MAAnB,CAFE,EAGnBgB,SAAS,GAAG5B,KAAK,CAAC4B,SAAT,GAAqB,IAHX;AAHvB,KASGG,MAAM,IAAID,QAAV,gBACC;AAAK,IAAA,GAAG,EAAC,mBAAT;AAA6B,IAAA,SAAS,EAAE9B,KAAK,CAACgE;AAA9C,kBACE;AAAK,IAAA,GAAG,EAAC,aAAT;AAAuB,IAAA,SAAS,EAAEhE,KAAK,CAAC8D;AAAxC,KACGA,cADH,CADF,eAIE;AAAK,IAAA,GAAG,EAAC,OAAT;AAAiB,IAAA,SAAS,EAAE9D,KAAK,CAAC8B;AAAlC,KACGA,QADH,CAJF,eAOE;AAAK,IAAA,GAAG,EAAC,MAAT;AAAgB,IAAA,SAAS,EAAE9B,KAAK,CAACiE;AAAjC,KACGlC,MAAM,CAACkC,IADV,CAPF,eAUE;AAAK,IAAA,GAAG,EAAC,kBAAT;AAA4B,IAAA,SAAS,EAAEjE,KAAK,CAACkE;AAA7C,kBACE,oBAAC,MAAD,eAAYnC,MAAZ;AAAoB,IAAA,GAAG,EAAC;AAAxB,KADF,CAVF,CADD,GAeG,IAxBN,eA0BE;AAAK,IAAA,GAAG,EAAC,gBAAT;AAA0B,IAAA,SAAS,EAAE/B,KAAK,CAACmE;AAA3C,kBACE,oBAAC,UAAD,EAAgB9B,mBAAhB,CADF,CA1BF,eA6BE;AACE,IAAA,SAAS,EACPR,gBAAgB,GAAG7B,KAAK,CAACoE,sBAAT,GAAkCpE,KAAK,CAACqE,4BAF5D;AAIE,IAAA,KAAK,eACC7C,cAAc,CAACoB,IAAf,KAAwBpC,aAAxB,IACF,CAACqB,gBADC,IACmB;AACnByC,MAAAA,OAAO,EAAE;AADU,KAFpB;AAJP,kBAWE,oBAAC,qBAAD,EAA2Bb,qBAA3B,CAXF,CA7BF,CADF;AA6CD,CAlKD,C,CAoKA;AACA;;;AACA,MAAMc,kBAAkB,GAAG,CAACC,KAAD,EAAQ9D,MAAR,KAAmB;AAC5C,QAAM,CAAC+D,EAAD,EAAKC,KAAL,IAAchE,MAApB;;AACA,QAAMiE,MAAM,GAAG,IAAIC,GAAJ,EAAf;;AAEA,QAAM;AAACnC,IAAAA,SAAD;AAAYE,IAAAA;AAAZ,MAAmD+B,KAAzD;AAAA,QAA6CG,QAA7C,iCAAyDH,KAAzD,2CAJ4C,CAM5C;;;AACA,OAAK,MAAM,CAACI,KAAD,EAAQC,aAAR,CAAX,IAAqCP,KAArC,EAA4C;AAC1C,QAAIM,KAAK,KAAKL,EAAd,EAAkB;AAChB;AACA,UAAIhC,SAAS,IAAIE,sBAAsB,KAAKnC,aAA5C,EAA2D;AACzDmE,QAAAA,MAAM,CAACK,GAAP,CAAWF,KAAX,wBACKC,aADL;AAEEtC,UAAAA,SAFF;AAGE9B,UAAAA,QAAQ,EAAEkE,QAAQ,CAAClE,QAHrB;AAIEkB,UAAAA,gBAAgB,EAAEgD,QAAQ,CAAChD;AAJ7B;AAMD,OAPD,MAOO,IAAIc,sBAAsB,KAAKnC,aAA3B,IAA4CuE,aAAa,CAACtC,SAA9D,EAAyE;AAC9EkC,QAAAA,MAAM,CAACK,GAAP,CAAWF,KAAX,wBAAsBC,aAAa,CAACtC,SAApC;AAA+C9B,UAAAA,QAAQ,EAAEoE,aAAa,CAACpE;AAAvE;AACD,OAFM,MAEAgE,MAAM,CAACK,GAAP,CAAWP,EAAX,EAAeI,QAAf;AACR,KAZD,MAYO;AACL;AACA,YAAM;AAACjE,QAAAA,MAAD;AAASD,QAAAA,QAAT;AAAmBoB,QAAAA,MAAnB;AAA2BD,QAAAA;AAA3B,UAAuCiD,aAA7C;;AACA,UAAItC,SAAJ,EAAe;AACbkC,QAAAA,MAAM,CAACK,GAAP,CAAWF,KAAX,wBAAsBrC,SAAtB;AAAiCb,UAAAA,SAAS,EAAEiD,QAAQ,CAACjD,SAArD;AAAgEhB,UAAAA,MAAhE;AAAwED,UAAAA;AAAxE;AACD,OAFD,MAEO;AACLgE,QAAAA,MAAM,CAACK,GAAP,CAAWF,KAAX,EAAkB;AAChBlE,UAAAA,MADgB;AAEhBD,UAAAA,QAAQ,EAAEA,QAAQ,GAAG,CAFL;AAGhBoB,UAAAA,MAHgB;AAIhBD,UAAAA,QAJgB;AAKhBF,UAAAA,SAAS,EAAEiD,QAAQ,CAACjD;AALJ,SAAlB;AAOD;AACF;AACF;;AAED,SAAO+C,MAAP;AACD,CAtCD,C,CAwCA;;;AACA,MAAMM,YAAY,GAAGC,YAAY,IAAKA,YAAY,KAAK1E,aAAjB,GAAiC,CAAjC,GAAqC0E,YAAY,GAAG,CAA1F,C,CAEA;AACA;;;AACA,MAAMC,sBAAsB,GAAG,CAACC,iBAAD,EAAoB5D,cAApB,EAAoC6D,gBAAgB,GAAG,IAAvD,KAAgE;AAC7F;AACA,MAAIA,gBAAgB,KAAKD,iBAAzB,EAA4C;AAC1C,WAAOA,iBAAP;AACD;;AAED,QAAME,YAAY,GAAGL,YAAY,CAACzF,KAAK,CAAC6F,gBAAD,CAAL,GAA0BD,iBAA1B,GAA8CC,gBAA/C,CAAjC;AAEA,SAAO7D,cAAc,CAAC+D,GAAf,CAAmBD,YAAnB,IACHH,sBAAsB,CAACC,iBAAD,EAAoB5D,cAApB,EAAoC8D,YAApC,CADnB,GAEHA,YAFJ;AAGD,CAXD,C,CAaA;AACA;;;AACA,MAAME,gBAAgB,GAAG,CAAChB,KAAD,EAAQ9D,MAAR,KAAmB;AAC1C,QAAM,CAAC+D,EAAD,EAAKC,KAAL,IAAchE,MAApB;;AACA,QAAM;AAACgD,IAAAA,OAAD;AAAUlC,IAAAA;AAAV,MAAqCkD,KAA3C;AAAA,QAAmCe,IAAnC,iCAA2Cf,KAA3C;;AACA,QAAMC,MAAM,GAAG,IAAIC,GAAJ,EAAf;;AACA,QAAMc,SAAS,GAAG,CAACD,IAAI,CAAC9B,OAAN,IAAiBD,OAAjB,GAA2ByB,sBAAsB,CAACV,EAAD,EAAKjD,cAAL,CAAjD,GAAwE,IAA1F,CAJ0C,CAM1C;;AACA,OAAK,MAAM,CAACsD,KAAD,EAAQC,aAAR,CAAX,IAAqCP,KAArC,EAA4C;AAC1C,QAAIC,EAAE,KAAKK,KAAX,EACEH,MAAM,CAACK,GAAP,CAAWP,EAAX,wBACKM,aADL,GAEKU,IAFL,GADF,KAKK,IAAI/B,OAAO,IAAIgC,SAAS,KAAKZ,KAA7B,EAAoC;AACvCH,MAAAA,MAAM,CAACK,GAAP,CAAWF,KAAX,wBAAsBC,aAAtB;AAAqCpB,QAAAA,OAAO,EAAE;AAA9C;AACD,KAFI,MAEEgB,MAAM,CAACK,GAAP,CAAWF,KAAX,EAAkBC,aAAlB;AACR;;AAED,SAAOJ,MAAP;AACD,CAnBD,C,CAqBA;;;AACA,MAAMgB,qBAAqB,GAAG,CAACnB,KAAD,EAAQ9D,MAAR,KAAmB;AAC/C,QAAM,CAAC+D,EAAD,EAAKC,KAAL,IAAchE,MAApB;;AACA,QAAMiE,MAAM,GAAG,IAAIC,GAAJ,EAAf,CAF+C,CAI/C;;;AACA,OAAK,MAAM,CAACE,KAAD,EAAQC,aAAR,CAAX,IAAqCP,KAArC,EAA4C;AAC1CG,IAAAA,MAAM,CAACK,GAAP,CAAWF,KAAX,EAAkBC,aAAlB;AACD;;AAEDJ,EAAAA,MAAM,CAACK,GAAP,CAAWP,EAAX,EAAeC,KAAf;;AAEA,SAAOC,MAAP;AACD,CAZD;;AAcA,MAAMiB,YAAY,GAAG,CACnB;AACEC,EAAAA,WADF;AAEEC,EAAAA,yBAFF;AAGEzE,EAAAA,QAHF;AAIEC,EAAAA,oBAJF;AAKEyE,EAAAA,UALF;AAMEC,EAAAA;AANF,CADmB,EASnBC,OATmB,KAUhB;AACH,QAAM;AAACC,IAAAA;AAAD,MAASD,OAAf;AACA,QAAM7E,gBAAgB,GAAGjC,OAAO,CAAC,MAAMG,KAAK,CAAC,SAAD,EAAY,gBAAZ,EAA8B4G,IAA9B,CAAZ,EAAiD,CAACA,IAAD,CAAjD,CAAhC,CAFG,CAIH;;AACA,QAAMC,kBAAkB,GAAGhH,OAAO,CAAC,MAAM;AACvC,UAAMiH,MAAM,GAAG,IAAIxB,GAAJ,EAAf;AACA,UAAM;AAAC7C,MAAAA,MAAD;AAASD,MAAAA;AAAT,QAAqBiE,UAA3B,CAFuC,CAGvC;;AACA,SAAK,IAAIjB,KAAK,GAAG,CAAjB,EAAoBA,KAAK,GAAGvE,kBAA5B,EAAgDuE,KAAK,EAArD,EAAyD;AACvD,YAAMuB,OAAO,GAAGvB,KAAK,KAAK,CAAV,GAAc;AAAC/C,QAAAA,MAAD;AAASD,QAAAA;AAAT,OAAd,GAAmC,EAAnD;AACAsE,MAAAA,MAAM,CAACpB,GAAP,CAAWF,KAAX,wBAAsBuB,OAAtB;AAA+BzF,QAAAA,MAAM,EAAE,KAAvC;AAA8CD,QAAAA,QAAQ,EAAEmE;AAAxD;AACD;;AACD,WAAOsB,MAAP;AACD,GATiC,EAS/B,CAACL,UAAD,CAT+B,CAAlC;AAWA,QAAMO,qBAAqB,GAAGnH,OAAO,CAAC,MAAM;AAC1C,UAAMiH,MAAM,GAAG,IAAIxB,GAAJ,EAAf,CAD0C,CAE1C;;AACA,SAAK,IAAIE,KAAK,GAAG,CAAjB,EAAoBA,KAAK,GAAGvE,kBAA5B,EAAgDuE,KAAK,EAArD,EAAyD;AACvD,YAAMnB,OAAO,GAAGmB,KAAK,KAAK,CAA1B;AACAsB,MAAAA,MAAM,CAACpB,GAAP,CAAWF,KAAX,EAAkB;AAACnB,QAAAA,OAAD;AAAUe,QAAAA,KAAK,EAAG,GAAEI,KAAK,GAAG,CAAE,EAA9B;AAAiChC,QAAAA,IAAI,EAAE;AAAvC,OAAlB;AACD;;AACD,WAAOsD,MAAP;AACD,GARoC,EAQlC,EARkC,CAArC;AAUA,QAAM,CAAC5E,cAAD,EAAiBC,oBAAjB,IAAyCvC,UAAU,CAACyG,qBAAD,EAAwB,IAAIf,GAAJ,EAAxB,CAAzD;AAEA,QAAM,CAAC1D,WAAD,EAAcC,YAAd,IAA8BjC,UAAU,CAACqF,kBAAD,EAAqB4B,kBAArB,CAA9C;AAEA,QAAM,CAACI,cAAD,EAAiBhF,eAAjB,IAAoCrC,UAAU,CAACsG,gBAAD,EAAmBc,qBAAnB,CAApD;AAEA,QAAM,CAACE,WAAD,EAAc9E,iBAAd,IAAmCzC,QAAQ,CAAC,SAAD,CAAjD;AAEA;;;;;;;AAMA,QAAM,CAACwH,iBAAD,EAAoB9E,uBAApB,IAA+C1C,QAAQ,CAAC,IAAD,CAA7D,CAxCG,CA0CH;;AACA,QAAMyH,kBAAkB,GAAGvH,OAAO,CAAC,MAAM;AACvC,UAAMwH,aAAa,GAAG,EAAtB,CADuC,CAEvC;;AACA,SAAK,IAAI1F,WAAW,GAAG,CAAvB,EAA0BA,WAAW,GAAGV,kBAAxC,EAA4DU,WAAW,EAAvE,EAA2E;AACzE0F,MAAAA,aAAa,CAACC,IAAd,CACE5F,UAAU,CACRC,WADQ,EAERC,WAFQ,EAGRC,YAHQ,EAIRC,gBAJQ,EAKRC,QALQ,EAMRC,oBANQ,EAORC,eAPQ,EAQRC,cARQ,EASRC,oBATQ,EAURC,iBAVQ,EAWRC,uBAXQ,CADZ;AAeD;;AAED,WAAOgF,aAAP;AACD,GAtBiC,EAsB/B,CAACzF,WAAD,EAAcE,gBAAd,EAAgCC,QAAhC,EAA0CC,oBAA1C,EAAgEE,cAAhE,CAtB+B,CAAlC,CA3CG,CAmEH;;AACA,QAAMqF,cAAc,GAAG1H,OAAO,CAAC,MAAM;AACnC;AACA,WAAO2H,KAAK,CAACC,IAAN,CAAWR,cAAc,CAACS,MAAf,EAAX,CAAP;AACD,GAH6B,EAG3B,CAACT,cAAD,CAH2B,CAA9B;;AAKA,QAAMU,YAAY,yBACbpB,WADa;AAEhBqB,IAAAA,KAAK,EAAEL,cAFS;AAGhBM,IAAAA,GAAG,EAAE,eAHW;AAIhBC,IAAAA,WAAW,EAAEZ,WAAW,KAAK;AAJb,IAAlB;;AAOA,sBACE;AACE,IAAA,GAAG,EAAC,2BADN;AAEE,iBAAU,2BAFZ;AAGE,IAAA,SAAS,EAAExG,KAAK,CAACqH;AAHnB,kBAKE;AAAK,IAAA,GAAG,EAAC,6BAAT;AAAuC,IAAA,SAAS,EAAErH,KAAK,CAACsH;AAAxD,kBACE,oBAAC,gBAAD;AAAkB,kBAAYxB;AAA9B,IADF,CALF,eASE;AAAK,IAAA,GAAG,EAAC,uBAAT;AAAiC,IAAA,SAAS,EAAE9F,KAAK,CAACuH;AAAlD,kBACE,oBAAC,YAAD,EAAkBN,YAAlB,CADF,CATF,EAaGR,iBAAiB,gBAChB;AACE,IAAA,GAAG,EAAC,qCADN;AAEE,IAAA,SAAS,EAAEzG,KAAK,CAACwH;AAFnB,kBAIE;AACE,IAAA,GAAG,EAAC,0BADN;AAEE,iBAAU,0BAFZ;AAGE,IAAA,SAAS,EAAExH,KAAK,CAACyH;AAHnB,KAKGf,kBALH,CAJF,CADgB,GAad,IA1BN,EA4BGF,WAAW,KAAK,UAAhB,gBACC;AAAK,IAAA,SAAS,EAAExG,KAAK,CAAC0H;AAAtB,kBACE,oBAAC,cAAD,EAAoB1B,aAApB,CADF,CADD,GAIG,IAhCN,CADF;AAoCD,CA9HD;;AAgIAJ,YAAY,CAAC+B,SAAb,2CAAyB;AACvB9B,EAAAA,WAAW,EAAEzG,SAAS,CAACwI,KAAV,CAAgBrI,IAAI,CAAC,CAAC,OAAD,EAAU,EAAV,CAAD,EAAgBK,YAAY,CAAC+H,SAA7B,CAApB,CADU;AAEvB7B,EAAAA,yBAAyB,EAAErG,gBAAgB,CAACkI,SAAjB,CAA2B,YAA3B,CAFJ;AAGvBtG,EAAAA,QAAQ,EAAEjC,SAAS,CAACwI,KAAV,CAAgB;AACxBzF,IAAAA,KAAK,EAAE/C,SAAS,CAACyI,MADO;AAExB5F,IAAAA,OAAO,EAAE7C,SAAS,CAAC0I;AAFK,GAAhB,CAHa;AAOvB/B,EAAAA,UAAU,EAAE3G,SAAS,CAACwI,KAAV,CAAgB;AAC1B9F,IAAAA,QAAQ,EAAE1C,SAAS,CAACyI,MADM;AAE1B9F,IAAAA,MAAM,EAAE3C,SAAS,CAACwI,KAAV,CAAgB9H,MAAM,CAAC6H,SAAvB;AAFkB,GAAhB,CAPW;AAWvBrG,EAAAA,oBAAoB,EAAElC,SAAS,CAACwI,KAAV,CAAgB;AACpCxE,IAAAA,GAAG,EAAEvD,qBAAqB,CAAC8H,SAAtB,CAAgCvE,GADD;AAEpCC,IAAAA,WAAW,EAAExD,qBAAqB,CAAC8H,SAAtB,CAAgCtE,WAFT;AAGpCC,IAAAA,IAAI,EAAElE,SAAS,CAACwI,KAAV,CAAgB;AACpBzF,MAAAA,KAAK,EAAE/C,SAAS,CAACyI,MADG;AAEpB,oBAAczI,SAAS,CAACyI;AAFJ,KAAhB,CAH8B;AAOpCtE,IAAAA,YAAY,EAAE1D,qBAAqB,CAAC8H,SAAtB,CAAgC9D,WAPV;AAQpCL,IAAAA,YAAY,EAAE3D,qBAAqB,CAAC8H,SAAtB,CAAgC9D;AARV,GAAhB,CAXC;AAqBvBmC,EAAAA,aAAa,EAAE5G,SAAS,CAACwI,KAAV,CAAgBjI,cAAc,CAACgI,SAA/B;AArBQ,CAAzB;AAwBA,eAAe/B,YAAf","sourcesContent":["import React, {useState, useReducer, useMemo} from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport getOr from 'lodash/fp/getOr';\nimport omit from 'lodash/fp/omit';\nimport isNil from 'lodash/fp/isNil';\nimport ReviewBackground from '../../../atom/review-background';\nimport {ICON_VALUES} from '../../../atom/review-header-step-item';\nimport ReviewCongrats from '../../../organism/review-congrats';\nimport ReviewHeader from '../../../organism/review-header';\nimport ReviewCorrectionPopin from '../../../molecule/review-correction-popin';\nimport Answer from '../../../molecule/answer';\nimport ButtonLink from '../../../atom/button-link';\nimport style from './style.css';\n\nconst stylesByPosition = {\n 0: style.position0,\n 1: style.position1,\n 2: style.position2,\n 3: style.position3,\n 4: style.position4\n};\n\nconst TOTAL_SLIDES_STACK = 5;\nconst HIGHEST_INDEX = TOTAL_SLIDES_STACK - 1;\n\nconst getSlideAnimation = (action, position, hidden) => {\n switch (action) {\n case 'unstack':\n return style.slideOutHideAndIn;\n case 'restack':\n return style.slideOutAndIn;\n default:\n return hidden ? style.hiddenSlide : stylesByPosition[position];\n }\n};\n\nconst buildSlide = (\n slideNumber,\n slidesState,\n updateSlides,\n primarySkinColor,\n validate,\n correctionPopinProps,\n updateStepItems,\n finishedSlides,\n updateFinishedSlides,\n updateReviewState,\n updateShouldMountSlides\n) => {\n const {hidden, endReview, position, action, validationResult, question, answer} = slidesState.get(\n slideNumber\n );\n const {onClick: onValidateClick, label: validateLabel} = validate;\n\n const validateButtonProps = {\n customStyle: {\n backgroundColor: primarySkinColor\n },\n /* \n slide validation action, this will trigger the correction popin but will not trigger any\n animations unless the endReview signal is received (all slides will disappear),\n if there is a nextSlide content, it will be loaded here\n if it is the last slide and the content needs to be different, then that update will\n be handled on the next slide logic but the content will be carried from here.\n */\n onClick: async () => {\n const {validationResult: result, nextSlide, endReview: _endReview} = await onValidateClick();\n updateSlides([\n slideNumber,\n {\n hidden,\n position,\n validationResult: result,\n answer,\n question,\n nextSlide,\n numberOfFinishedSlides: finishedSlides.size,\n endReview: _endReview\n }\n ]);\n // on endReview, this gives some time for the slides to slide out && then launch\n // the 'finished' logic as it would happen when normally finishing the review\n if (_endReview) {\n updateReviewState('finished');\n setTimeout(() => updateShouldMountSlides(false), 2000);\n }\n updateStepItems([\n slideNumber,\n {\n icon: result === 'success' ? ICON_VALUES.right : ICON_VALUES.wrong,\n finishedSlides\n }\n ]);\n // only stores successful slides\n if (result === 'success') updateFinishedSlides([slideNumber, true]);\n },\n 'aria-label': validateLabel,\n label: validateLabel,\n 'data-name': `slide-validate-button-${slideNumber}`,\n className: style.validateButton,\n disabled: !isNil(validationResult)\n };\n\n const {klf, information, next, successLabel, failureLabel} = correctionPopinProps;\n\n const _correctionPopinProps = {\n next: {\n /* \n next slide action, this will trigger the slides animations\n if it is the last slide AND the content needs to be different, then that update\n of the content will be handled here (and in the validate as it happens normally )\n from the content carried from the validate action.\n */\n onClick: () => {\n updateSlides([\n slideNumber,\n {\n hidden: validationResult === 'success',\n position: HIGHEST_INDEX - finishedSlides.size,\n action: validationResult === 'success' ? 'unstack' : 'restack',\n answer,\n question,\n validationResult,\n numberOfFinishedSlides: finishedSlides.size,\n endReview\n }\n ]);\n updateStepItems([\n slideNumber,\n {\n setNext: true,\n finishedSlides,\n current: finishedSlides.size === HIGHEST_INDEX && validationResult !== 'success'\n }\n ]);\n // if slides are successfully reviewed, then trigger the 'finished' state\n if (finishedSlides.size === TOTAL_SLIDES_STACK) {\n updateReviewState('finished');\n setTimeout(() => updateShouldMountSlides(false), 2000);\n }\n },\n label: next.label,\n 'data-name': `next-question-button-${slideNumber}`,\n 'aria-label': next['aria-label']\n },\n klf,\n information,\n type: validationResult === 'success' ? 'right' : 'wrong',\n resultLabel: validationResult === 'success' ? successLabel : failureLabel\n };\n\n const questionOrigin = 'From \"Master Design Thinking to become more agile\" course';\n\n return (\n <div\n key={`slide-${slideNumber}`}\n data-name={`slide-${slideNumber}`}\n className={classnames(\n style.slideBase,\n getSlideAnimation(action, position, hidden),\n endReview ? style.endReview : null\n )}\n >\n {answer && question ? (\n <div key=\"content-container\" className={style.slideContentContainer}>\n <div key=\"from-course\" className={style.questionOrigin}>\n {questionOrigin}\n </div>\n <div key=\"title\" className={style.question}>\n {question}\n </div>\n <div key=\"help\" className={style.help}>\n {answer.help}\n </div>\n <div key=\"answer-container\" className={style.answerContainer}>\n <Answer {...answer} key=\"answer\" />\n </div>\n </div>\n ) : null}\n\n <div key=\"button-wrapper\" className={style.validateButtonWrapper}>\n <ButtonLink {...validateButtonProps} />\n </div>\n <div\n className={\n validationResult ? style.correctionPopinWrapper : style.hiddenCorrectionPopinWrapper\n }\n style={{\n ...(finishedSlides.size !== HIGHEST_INDEX &&\n !validationResult && {\n display: 'none'\n })\n }}\n >\n <ReviewCorrectionPopin {..._correctionPopinProps} />\n </div>\n </div>\n );\n};\n\n// ||-------> Handles the updates of a given slide (using the 'id' in the action),\n// & then updates de remaining slides if this given change should impact their content\nconst slidesStateReducer = (state, action) => {\n const [id, value] = action;\n const _state = new Map();\n\n const {nextSlide, numberOfFinishedSlides, ...newValue} = value;\n\n // eslint-disable-next-line fp/no-loops\n for (const [index, previousValue] of state) {\n if (index === id) {\n // update the given slide\n if (nextSlide && numberOfFinishedSlides === HIGHEST_INDEX) {\n _state.set(index, {\n ...previousValue,\n nextSlide,\n position: newValue.position,\n validationResult: newValue.validationResult\n });\n } else if (numberOfFinishedSlides === HIGHEST_INDEX && previousValue.nextSlide) {\n _state.set(index, {...previousValue.nextSlide, position: previousValue.position});\n } else _state.set(id, newValue);\n } else {\n // updates the rest of the slides here\n const {hidden, position, answer, question} = previousValue;\n if (nextSlide) {\n _state.set(index, {...nextSlide, endReview: newValue.endReview, hidden, position});\n } else {\n _state.set(index, {\n hidden,\n position: position - 1,\n answer,\n question,\n endReview: newValue.endReview\n });\n }\n }\n }\n\n return _state;\n};\n\n// ||-------> aux function, finds the consecutive index to loop from 0 to HIGHEST_INDEX (4) & again to 0\nconst getNextIndex = currentIndex => (currentIndex === HIGHEST_INDEX ? 0 : currentIndex + 1);\n\n// ||-------> calculates which should be the next step to visit (as there can be already answered slides &&\n// they have to be skipped)\nconst calculateNextStepIndex = (currentSlideIndex, finishedSlides, lastVisitedIndex = null) => {\n // only one slide remaining\n if (lastVisitedIndex === currentSlideIndex) {\n return currentSlideIndex;\n }\n\n const indexToVisit = getNextIndex(isNil(lastVisitedIndex) ? currentSlideIndex : lastVisitedIndex);\n\n return finishedSlides.has(indexToVisit)\n ? calculateNextStepIndex(currentSlideIndex, finishedSlides, indexToVisit)\n : indexToVisit;\n};\n\n// ||-------> Handles the updates of a given step item (using the 'id' in the action),\n// & then updates de remaining step items if this given change should impact their content\nconst stepItemsReducer = (state, action) => {\n const [id, value] = action;\n const {setNext, finishedSlides, ...rest} = value;\n const _state = new Map();\n const nextIndex = !rest.current && setNext ? calculateNextStepIndex(id, finishedSlides) : null;\n\n // eslint-disable-next-line fp/no-loops\n for (const [index, previousValue] of state) {\n if (id === index)\n _state.set(id, {\n ...previousValue,\n ...rest\n });\n else if (setNext && nextIndex === index) {\n _state.set(index, {...previousValue, current: true});\n } else _state.set(index, previousValue);\n }\n\n return _state;\n};\n\n// ||-------> Stores the correctly answered (finished) slides, the initial state is an empty Map\nconst finishedSlidesReducer = (state, action) => {\n const [id, value] = action;\n const _state = new Map();\n\n // eslint-disable-next-line fp/no-loops\n for (const [index, previousValue] of state) {\n _state.set(index, previousValue);\n }\n\n _state.set(id, value);\n\n return _state;\n};\n\nconst SlidesReview = (\n {\n headerProps,\n reviewBackgroundAriaLabel,\n validate,\n correctionPopinProps,\n firstSlide,\n congratsProps\n },\n context\n) => {\n const {skin} = context;\n const primarySkinColor = useMemo(() => getOr('#00B0FF', 'common.primary', skin), [skin]);\n\n // ||-------> States init: build initial states && memoize them + reducers creation\n const slidesInitialState = useMemo(() => {\n const states = new Map();\n const {answer, question} = firstSlide;\n // eslint-disable-next-line fp/no-loops\n for (let index = 0; index < TOTAL_SLIDES_STACK; index++) {\n const content = index === 0 ? {answer, question} : {};\n states.set(index, {...content, hidden: false, position: index});\n }\n return states;\n }, [firstSlide]);\n\n const stepItemsInitialState = useMemo(() => {\n const states = new Map();\n // eslint-disable-next-line fp/no-loops\n for (let index = 0; index < TOTAL_SLIDES_STACK; index++) {\n const current = index === 0;\n states.set(index, {current, value: `${index + 1}`, icon: null});\n }\n return states;\n }, []);\n\n const [finishedSlides, updateFinishedSlides] = useReducer(finishedSlidesReducer, new Map());\n\n const [slidesState, updateSlides] = useReducer(slidesStateReducer, slidesInitialState);\n\n const [stepItemsState, updateStepItems] = useReducer(stepItemsReducer, stepItemsInitialState);\n\n const [reviewState, updateReviewState] = useState('ongoing');\n\n /*\n ||-------> the slides have an slightly longer lifespan than the \"ongoing\" review State,\n after reviewState changes to \"finished\" the slides don't have to unmount until the last\n slide-out animation is finished, the slides have to be unmounted to be RGAA complaint \n (if they are only invisible but still mounted, then they will be found the assisting tools & clutter it)\n */\n const [shouldMountSlides, updateShouldMountSlides] = useState(true);\n\n // ||-------> build each slide, passing down the reducers that will act on validation & next clicks\n const builtStackedSlides = useMemo(() => {\n const StackedSlides = [];\n // eslint-disable-next-line fp/no-loops\n for (let slideNumber = 0; slideNumber < TOTAL_SLIDES_STACK; slideNumber++) {\n StackedSlides.push(\n buildSlide(\n slideNumber,\n slidesState,\n updateSlides,\n primarySkinColor,\n validate,\n correctionPopinProps,\n updateStepItems,\n finishedSlides,\n updateFinishedSlides,\n updateReviewState,\n updateShouldMountSlides\n )\n );\n }\n\n return StackedSlides;\n }, [slidesState, primarySkinColor, validate, correctionPopinProps, finishedSlides]);\n\n // ||-------> transform the step items state (Map structure) to an Array\n const stepItemsArray = useMemo(() => {\n // eslint-disable-next-line unicorn/prefer-spread\n return Array.from(stepItemsState.values());\n }, [stepItemsState]);\n\n const _headerProps = {\n ...headerProps,\n steps: stepItemsArray,\n key: 'review-header',\n hiddenSteps: reviewState !== 'ongoing'\n };\n\n return (\n <div\n key=\"slides-revision-container\"\n data-name=\"slides-revision-container\"\n className={style.slidesRevisionContainer}\n >\n <div key=\"player-background-container\" className={style.playerBackground}>\n <ReviewBackground aria-label={reviewBackgroundAriaLabel} />\n </div>\n\n <div key=\"review-header-wrapper\" className={style.reviewHeaderContainer}>\n <ReviewHeader {..._headerProps} />\n </div>\n\n {shouldMountSlides ? (\n <div\n key=\"stacked-slides-container-y-overflow\"\n className={style.stackedSlidesYAxisOverflowContainer}\n >\n <div\n key=\"stacked-slides-container\"\n data-name=\"stacked-slides-container\"\n className={style.stackedSlidesContainer}\n >\n {builtStackedSlides}\n </div>\n </div>\n ) : null}\n\n {reviewState === 'finished' ? (\n <div className={style.congrats}>\n <ReviewCongrats {...congratsProps} />\n </div>\n ) : null}\n </div>\n );\n};\n\nSlidesReview.propTypes = {\n headerProps: PropTypes.shape(omit(['steps', ''], ReviewHeader.propTypes)),\n reviewBackgroundAriaLabel: ReviewBackground.propTypes['aria-label'],\n validate: PropTypes.shape({\n label: PropTypes.string,\n onClick: PropTypes.func\n }),\n firstSlide: PropTypes.shape({\n question: PropTypes.string,\n answer: PropTypes.shape(Answer.propTypes)\n }),\n correctionPopinProps: PropTypes.shape({\n klf: ReviewCorrectionPopin.propTypes.klf,\n information: ReviewCorrectionPopin.propTypes.information,\n next: PropTypes.shape({\n label: PropTypes.string,\n 'aria-label': PropTypes.string\n }),\n successLabel: ReviewCorrectionPopin.propTypes.resultLabel,\n failureLabel: ReviewCorrectionPopin.propTypes.resultLabel\n }),\n congratsProps: PropTypes.shape(ReviewCongrats.propTypes)\n};\n\nexport default SlidesReview;\n"],"file":"index.js"}
@@ -1,11 +0,0 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- exports.ViewNames = void 0;
5
- const ViewNames = {
6
- home: 'home',
7
- onboarding: 'onboarding',
8
- slides: 'slides'
9
- };
10
- exports.ViewNames = ViewNames;
11
- //# sourceMappingURL=common.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/template/app-review/root-view/common.js"],"names":["ViewNames","home","onboarding","slides"],"mappings":";;;;AAAO,MAAMA,SAAS,GAAG;AACvBC,EAAAA,IAAI,EAAE,MADiB;AAEvBC,EAAAA,UAAU,EAAE,YAFW;AAGvBC,EAAAA,MAAM,EAAE;AAHe,CAAlB","sourcesContent":["export const ViewNames = {\n home: 'home',\n onboarding: 'onboarding',\n slides: 'slides'\n};\n"],"file":"common.js"}
@@ -1,28 +0,0 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- exports.default = void 0;
5
-
6
- var _propTypes = _interopRequireDefault(require("prop-types"));
7
-
8
- var _keys = _interopRequireDefault(require("lodash/fp/keys"));
9
-
10
- var _reviewDashboardSkills = _interopRequireDefault(require("../../review-dashboard-skills"));
11
-
12
- var _slidesReview = _interopRequireDefault(require("../slides-review"));
13
-
14
- var _common = require("./common");
15
-
16
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
-
18
- function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
19
-
20
- var _default = {
21
- viewName: _propTypes.default.oneOf((0, _keys.default)(_common.ViewNames)),
22
- navigateBack: _propTypes.default.func,
23
- navigateTo: _propTypes.default.func,
24
- onboarding: _propTypes.default.shape(_extends({}, _reviewDashboardSkills.default.propTypes)),
25
- slidesReview: _propTypes.default.shape(_extends({}, _slidesReview.default.propTypes))
26
- };
27
- exports.default = _default;
28
- //# sourceMappingURL=prop-types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/template/app-review/root-view/prop-types.js"],"names":["viewName","PropTypes","oneOf","ViewNames","navigateBack","func","navigateTo","onboarding","shape","ReviewDashboardSkills","propTypes","slidesReview","SlidesReview"],"mappings":";;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;eAEe;AACbA,EAAAA,QAAQ,EAAEC,mBAAUC,KAAV,CAAgB,mBAAKC,iBAAL,CAAhB,CADG;AAEbC,EAAAA,YAAY,EAAEH,mBAAUI,IAFX;AAGbC,EAAAA,UAAU,EAAEL,mBAAUI,IAHT;AAIbE,EAAAA,UAAU,EAAEN,mBAAUO,KAAV,cAAoBC,+BAAsBC,SAA1C,EAJC;AAKbC,EAAAA,YAAY,EAAEV,mBAAUO,KAAV,cAAoBI,sBAAaF,SAAjC;AALD,C","sourcesContent":["import PropTypes from 'prop-types';\nimport keys from 'lodash/fp/keys';\nimport ReviewDashboardSkills from '../../review-dashboard-skills';\nimport SlidesReview from '../slides-review';\nimport {ViewNames} from './common';\n\nexport default {\n viewName: PropTypes.oneOf(keys(ViewNames)),\n navigateBack: PropTypes.func,\n navigateTo: PropTypes.func,\n onboarding: PropTypes.shape({...ReviewDashboardSkills.propTypes}),\n slidesReview: PropTypes.shape({...SlidesReview.propTypes})\n};\n"],"file":"prop-types.js"}
@@ -1,25 +0,0 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- exports.default = void 0;
5
-
6
- var _react = _interopRequireDefault(require("react"));
7
-
8
- var _slidesReview = _interopRequireDefault(require("../slides-review"));
9
-
10
- var _propTypes = _interopRequireDefault(require("./prop-types"));
11
-
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
-
14
- // -----------------------------------------------------------------------------
15
- const RootView = ({
16
- slidesReview
17
- }) => {
18
- return /*#__PURE__*/_react.default.createElement(_slidesReview.default, slidesReview);
19
- };
20
-
21
- RootView.propTypes = process.env.NODE_ENV !== "production" ? _propTypes.default : {}; // -----------------------------------------------------------------------------
22
-
23
- var _default = RootView;
24
- exports.default = _default;
25
- //# sourceMappingURL=root-view.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/template/app-review/root-view/root-view.js"],"names":["RootView","slidesReview","propTypes"],"mappings":";;;;;AAAA;;AACA;;AACA;;;;AAEA;AAEA,MAAMA,QAAQ,GAAG,CAAC;AAACC,EAAAA;AAAD,CAAD,KAAoB;AACnC,sBAAO,6BAAC,qBAAD,EAAkBA,YAAlB,CAAP;AACD,CAFD;;AAIAD,QAAQ,CAACE,SAAT,2CAAqBA,kBAArB,M,CAEA;;eAEeF,Q","sourcesContent":["import React from 'react';\nimport SlidesReview from '../slides-review';\nimport propTypes from './prop-types';\n\n// -----------------------------------------------------------------------------\n\nconst RootView = ({slidesReview}) => {\n return <SlidesReview {...slidesReview} />;\n};\n\nRootView.propTypes = propTypes;\n\n// -----------------------------------------------------------------------------\n\nexport default RootView;\n"],"file":"root-view.js"}
@@ -1,8 +0,0 @@
1
- .textButton {
2
- background-color: aquamarine;
3
- padding: 20px;
4
- border-radius: 10px;
5
- user-select: none;
6
- cursor: pointer;
7
- font-size: 25px;
8
- }
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/template/app-review/root-view/root-view.native.js"],"names":["styles","StyleSheet","create","rootView","flex","alignItems","justifyContent","NavText","viewName","navigateTo","handlePress","v","ViewNames","home","onboarding","slides","RootView","navigateBack","backAction","backHandler","BackHandler","addEventListener","remove","propTypes"],"mappings":";;;;;AAAA;;AACA;;AACA;;AACA;;;;;;;;AAEA;AAEA,MAAMA,MAAM,GAAGC,wBAAWC,MAAX,CAAkB;AAC/BC,EAAAA,QAAQ,EAAE;AACRC,IAAAA,IAAI,EAAE,CADE;AAERC,IAAAA,UAAU,EAAE,QAFJ;AAGRC,IAAAA,cAAc,EAAE;AAHR;AADqB,CAAlB,CAAf,C,CAQA;;;AAEA,MAAMC,OAAO,GAAG,CAAC;AAACC,EAAAA,QAAD;AAAWC,EAAAA;AAAX,CAAD,KAA4B;AAC1C,QAAMC,WAAW,GAAGC,CAAC,IAAI,MAAMF,UAAU,CAACE,CAAD,CAAzC;;AAEA,UAAQH,QAAR;AACE,SAAKI,kBAAUC,IAAf;AACE,0BACE,6BAAC,sBAAD;AAAW,QAAA,OAAO,EAAEH,WAAW,CAAC,YAAD;AAA/B,sBACE,6BAAC,iBAAD,oBADF,CADF;;AAKF,SAAKE,kBAAUE,UAAf;AACE,0BACE,6BAAC,sBAAD;AAAW,QAAA,OAAO,EAAEJ,WAAW,CAAC,SAAD;AAA/B,sBACE,6BAAC,iBAAD,0BADF,CADF;;AAKF,SAAKE,kBAAUG,MAAf;AACE,0BACE,6BAAC,sBAAD;AAAW,QAAA,OAAO,EAAEL,WAAW,CAAC,MAAD;AAA/B,sBACE,6BAAC,iBAAD,uBADF,CADF;;AAKF;AACE,0BAAO,6BAAC,iBAAD,+BAAP;AApBJ;AAsBD,CAzBD,C,CA2BA;;;AAEA,MAAMM,QAAQ,GAAG,CAAC;AAACR,EAAAA,QAAD;AAAWS,EAAAA,YAAX;AAAyBR,EAAAA;AAAzB,CAAD,KAA0C;AACzD,wBAAU,MAAM;AACd,UAAMS,UAAU,GAAG,MAAM;AACvBD,MAAAA,YAAY;AACZ,aAAO,IAAP;AACD,KAHD,CADc,CAMd;;;AACA,UAAME,WAAW,GAAGC,yBAAYC,gBAAZ,CAA6B,mBAA7B,EAAkDH,UAAlD,CAApB;;AAEA,WAAO,MAAMC,WAAW,CAACG,MAAZ,EAAb;AACD,GAVD,EAUG,CAACL,YAAD,CAVH;AAYA,sBACE,6BAAC,iBAAD;AAAM,IAAA,KAAK,EAAEjB,MAAM,CAACG;AAApB,kBACE,6BAAC,OAAD;AAAS,IAAA,QAAQ,EAAEK,QAAnB;AAA6B,IAAA,UAAU,EAAEC;AAAzC,IADF,CADF;AAKD,CAlBD,C,CAoBA;;;AAEAO,QAAQ,CAACO,SAAT,2CAAqBA,kBAArB;AACAhB,OAAO,CAACgB,SAAR,2CAAoBP,QAAQ,CAACO,SAA7B,M,CAEA;;eAEeP,Q","sourcesContent":["import React, {useEffect} from 'react';\nimport {Text, StyleSheet, Pressable, View, BackHandler} from 'react-native';\nimport propTypes from './prop-types';\nimport {ViewNames} from './common';\n\n// -----------------------------------------------------------------------------\n\nconst styles = StyleSheet.create({\n rootView: {\n flex: 1,\n alignItems: 'center',\n justifyContent: 'center'\n }\n});\n\n// -----------------------------------------------------------------------------\n\nconst NavText = ({viewName, navigateTo}) => {\n const handlePress = v => () => navigateTo(v);\n\n switch (viewName) {\n case ViewNames.home:\n return (\n <Pressable onPress={handlePress('onboarding')}>\n <Text>view home</Text>\n </Pressable>\n );\n case ViewNames.onboarding:\n return (\n <Pressable onPress={handlePress('quizzer')}>\n <Text>view onboarding</Text>\n </Pressable>\n );\n case ViewNames.slides:\n return (\n <Pressable onPress={handlePress('home')}>\n <Text>view quizzer</Text>\n </Pressable>\n );\n default:\n return <Text>view (none selected)</Text>;\n }\n};\n\n// -----------------------------------------------------------------------------\n\nconst RootView = ({viewName, navigateBack, navigateTo}) => {\n useEffect(() => {\n const backAction = () => {\n navigateBack();\n return true;\n };\n\n // https://reactnative.dev/docs/backhandler\n const backHandler = BackHandler.addEventListener('hardwareBackPress', backAction);\n\n return () => backHandler.remove();\n }, [navigateBack]);\n\n return (\n <View style={styles.rootView}>\n <NavText viewName={viewName} navigateTo={navigateTo} />\n </View>\n );\n};\n\n// -----------------------------------------------------------------------------\n\nRootView.propTypes = propTypes;\nNavText.propTypes = RootView.propTypes;\n\n// -----------------------------------------------------------------------------\n\nexport default RootView;\n"],"file":"root-view.native.js"}