@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.
- package/es/organism/review-skills/index.js +2 -0
- package/es/organism/review-skills/index.js.map +1 -1
- package/es/template/app-review/index.js +35 -0
- package/es/template/app-review/index.js.map +1 -0
- package/es/template/app-review/{root-view/root-view.native.js → index.native.js} +2 -3
- package/es/template/app-review/index.native.js.map +1 -0
- package/es/template/app-review/onboarding/index.js +3 -0
- package/es/template/app-review/onboarding/index.js.map +1 -0
- package/es/template/app-review/onboarding/index.native.js +84 -0
- package/es/template/app-review/onboarding/index.native.js.map +1 -0
- package/es/template/app-review/{root-view/prop-types.js → prop-types.js} +11 -7
- package/es/template/app-review/prop-types.js.map +1 -0
- package/es/template/app-review/skills/index.js +3 -0
- package/es/template/app-review/skills/index.js.map +1 -0
- package/es/template/app-review/skills/index.native.js +179 -0
- package/es/template/app-review/skills/index.native.js.map +1 -0
- package/es/template/app-review/skills/stories.js +15 -0
- package/es/template/app-review/skills/stories.js.map +1 -0
- package/es/template/app-review/slides/index.js +338 -0
- package/es/template/app-review/slides/index.js.map +1 -0
- package/es/template/app-review/slides/index.native.js +212 -0
- package/es/template/app-review/slides/index.native.js.map +1 -0
- package/es/template/app-review/slides/prop-types.js +67 -0
- package/es/template/app-review/slides/prop-types.js.map +1 -0
- package/es/template/app-review/{slides-review → slides}/style.css +0 -0
- package/lib/organism/review-skills/index.js +5 -1
- package/lib/organism/review-skills/index.js.map +1 -1
- package/lib/template/app-review/index.js +52 -0
- package/lib/template/app-review/index.js.map +1 -0
- package/lib/template/app-review/{root-view/root-view.native.js → index.native.js} +5 -9
- package/lib/template/app-review/index.native.js.map +1 -0
- package/lib/template/app-review/onboarding/index.js +12 -0
- package/lib/template/app-review/onboarding/index.js.map +1 -0
- package/lib/template/app-review/onboarding/index.native.js +100 -0
- package/lib/template/app-review/onboarding/index.native.js.map +1 -0
- package/lib/template/app-review/prop-types.js +33 -0
- package/lib/template/app-review/prop-types.js.map +1 -0
- package/lib/template/app-review/skills/index.js +12 -0
- package/lib/template/app-review/skills/index.js.map +1 -0
- package/lib/template/app-review/skills/index.native.js +197 -0
- package/lib/template/app-review/skills/index.native.js.map +1 -0
- package/lib/template/app-review/skills/stories.js +16 -0
- package/lib/template/app-review/skills/stories.js.map +1 -0
- package/lib/template/app-review/slides/index.js +367 -0
- package/lib/template/app-review/slides/index.js.map +1 -0
- package/lib/template/app-review/slides/index.native.js +229 -0
- package/lib/template/app-review/slides/index.native.js.map +1 -0
- package/lib/template/app-review/slides/prop-types.js +84 -0
- package/lib/template/app-review/slides/prop-types.js.map +1 -0
- package/lib/template/app-review/{slides-review → slides}/style.css +0 -0
- package/package.json +2 -2
- package/es/template/app-review/root-view/common.js +0 -6
- package/es/template/app-review/root-view/common.js.map +0 -1
- package/es/template/app-review/root-view/prop-types.js.map +0 -1
- package/es/template/app-review/root-view/root-view.js +0 -14
- package/es/template/app-review/root-view/root-view.js.map +0 -1
- package/es/template/app-review/root-view/root-view.modules.css +0 -8
- package/es/template/app-review/root-view/root-view.native.js.map +0 -1
- package/es/template/app-review/slides-review/index.js +0 -427
- package/es/template/app-review/slides-review/index.js.map +0 -1
- package/lib/template/app-review/root-view/common.js +0 -11
- package/lib/template/app-review/root-view/common.js.map +0 -1
- package/lib/template/app-review/root-view/prop-types.js +0 -28
- package/lib/template/app-review/root-view/prop-types.js.map +0 -1
- package/lib/template/app-review/root-view/root-view.js +0 -25
- package/lib/template/app-review/root-view/root-view.js.map +0 -1
- package/lib/template/app-review/root-view/root-view.modules.css +0 -8
- package/lib/template/app-review/root-view/root-view.native.js.map +0 -1
- package/lib/template/app-review/slides-review/index.js +0 -453
- 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":"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","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 +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 +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"}
|