@pie-element/multiple-choice 11.1.0 → 11.2.0-mui-update.1

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 (46) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/configure/CHANGELOG.md +11 -0
  3. package/configure/lib/__tests__/root.test.js +248 -0
  4. package/configure/lib/defaults.js +3 -5
  5. package/configure/lib/defaults.js.map +1 -1
  6. package/configure/lib/index.js +128 -204
  7. package/configure/lib/index.js.map +1 -1
  8. package/configure/lib/main.js +325 -445
  9. package/configure/lib/main.js.map +1 -1
  10. package/configure/lib/utils.js +9 -9
  11. package/configure/lib/utils.js.map +1 -1
  12. package/configure/package.json +10 -8
  13. package/controller/CHANGELOG.md +11 -0
  14. package/controller/lib/__tests__/index.test.js +520 -0
  15. package/controller/lib/__tests__/utils.test.js +8 -0
  16. package/controller/lib/defaults.js +3 -4
  17. package/controller/lib/defaults.js.map +1 -1
  18. package/controller/lib/index.js +145 -240
  19. package/controller/lib/index.js.map +1 -1
  20. package/controller/lib/utils.js +5 -17
  21. package/controller/lib/utils.js.map +1 -1
  22. package/controller/package.json +2 -2
  23. package/docs/demo/pie.manifest.json +11 -0
  24. package/lib/__tests__/choice-input-test.js +117 -0
  25. package/lib/__tests__/index-test.js +151 -0
  26. package/lib/__tests__/key-events-test.js +95 -0
  27. package/lib/__tests__/multiple-choice-test.js +223 -0
  28. package/lib/__tests__/session-updater-test.js +70 -0
  29. package/lib/choice-input.js +312 -369
  30. package/lib/choice-input.js.map +1 -1
  31. package/lib/choice.js +164 -219
  32. package/lib/choice.js.map +1 -1
  33. package/lib/feedback-tick.js +71 -115
  34. package/lib/feedback-tick.js.map +1 -1
  35. package/lib/index.js +233 -329
  36. package/lib/index.js.map +1 -1
  37. package/lib/main.js +36 -90
  38. package/lib/main.js.map +1 -1
  39. package/lib/multiple-choice.js +305 -388
  40. package/lib/multiple-choice.js.map +1 -1
  41. package/lib/print.js +41 -78
  42. package/lib/print.js.map +1 -1
  43. package/lib/session-updater.js +5 -16
  44. package/lib/session-updater.js.map +1 -1
  45. package/package.json +13 -10
  46. package/LICENSE.md +0 -5
@@ -1,427 +1,370 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports["default"] = exports.StyledRadio = exports.StyledFormControlLabel = exports.StyledCheckbox = exports.ChoiceInput = void 0;
9
-
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
22
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
23
-
7
+ exports.default = exports.StyledRadio = exports.StyledFormControlLabel = exports.StyledCheckbox = exports.ChoiceInput = void 0;
24
8
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
-
26
- var _FormControlLabel = _interopRequireDefault(require("@material-ui/core/FormControlLabel"));
27
-
9
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
+ var _FormControlLabel = _interopRequireDefault(require("@mui/material/FormControlLabel"));
28
11
  var _react = _interopRequireDefault(require("react"));
29
-
30
12
  var _propTypes = _interopRequireDefault(require("prop-types"));
31
-
32
- var _styles = require("@material-ui/core/styles");
33
-
34
- var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
35
-
13
+ var _styles = require("@mui/material/styles");
14
+ var _Box = _interopRequireDefault(require("@mui/material/Box"));
15
+ var _Checkbox = _interopRequireDefault(require("@mui/material/Checkbox"));
36
16
  var _renderUi = require("@pie-lib/render-ui");
37
-
38
- var _Radio = _interopRequireDefault(require("@material-ui/core/Radio"));
39
-
17
+ var _Radio = _interopRequireDefault(require("@mui/material/Radio"));
40
18
  var _classnames = _interopRequireDefault(require("classnames"));
41
-
42
19
  var _feedbackTick = _interopRequireDefault(require("./feedback-tick"));
43
-
44
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
45
-
46
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
47
-
48
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
49
-
50
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
51
-
52
- var CLASS_NAME = 'multiple-choice-component';
53
-
54
- var styleSheet = function styleSheet(theme) {
20
+ const CLASS_NAME = 'multiple-choice-component';
21
+ const Row = (0, _styles.styled)(_Box.default)({
22
+ display: 'flex',
23
+ alignItems: 'center',
24
+ backgroundColor: _renderUi.color.background()
25
+ });
26
+ const CheckboxHolder = (0, _styles.styled)(_Box.default)({
27
+ display: 'flex',
28
+ alignItems: 'center',
29
+ backgroundColor: _renderUi.color.background(),
30
+ flex: 1,
31
+ '& label': {
32
+ color: _renderUi.color.text(),
33
+ '& > span': {
34
+ fontSize: 'inherit'
35
+ }
36
+ }
37
+ });
38
+ const BelowSelectionComponent = (0, _styles.styled)('span')(({
39
+ theme
40
+ }) => ({
41
+ display: 'flex',
42
+ alignItems: 'center',
43
+ '& > span': {
44
+ // visually reduce right padding, but maintain accessibility padding for checkbox indicators to be circles
45
+ marginLeft: `-${theme.spacing(1)}px`
46
+ }
47
+ }));
48
+ const SrOnly = (0, _styles.styled)('span')({
49
+ position: 'absolute',
50
+ left: '-10000px',
51
+ top: 'auto',
52
+ width: '1px',
53
+ height: '1px',
54
+ overflow: 'hidden'
55
+ });
56
+ const StyledFormControlLabel = exports.StyledFormControlLabel = (0, _styles.styled)(_FormControlLabel.default)({
57
+ '& .MuiFormControlLabel-label': {
58
+ color: `${_renderUi.color.text()} !important`,
59
+ backgroundColor: _renderUi.color.background(),
60
+ letterSpacing: 'normal'
61
+ },
62
+ '&.Mui-disabled *': {
63
+ cursor: 'not-allowed !important'
64
+ }
65
+ });
66
+ const colorStyle = (varName, fallback) => ({
67
+ [`&.${CLASS_NAME}`]: {
68
+ color: `var(--choice-input-${varName}, ${fallback}) !important`
69
+ }
70
+ });
71
+ const getInputStyles = correctness => {
72
+ const key = k => correctness ? `${correctness}-${k}` : k;
55
73
  return {
56
- row: {
57
- display: 'flex',
58
- alignItems: 'center',
59
- backgroundColor: _renderUi.color.background()
60
- },
61
- checkboxHolder: {
62
- display: 'flex',
63
- alignItems: 'center',
64
- backgroundColor: _renderUi.color.background(),
65
- flex: 1,
66
- '& label': {
67
- color: _renderUi.color.text(),
68
- '& > span': {
69
- fontSize: 'inherit'
74
+ [key('root')]: {
75
+ ...colorStyle('color', _renderUi.color.text()),
76
+ ...(correctness ? {} : {
77
+ '&:hover': {
78
+ color: `${_renderUi.color.primaryLight()} !important`
70
79
  }
71
- }
80
+ }),
81
+ ...(correctness === 'correct' ? colorStyle('correct-color', _renderUi.color.text()) : {}),
82
+ ...(correctness === 'incorrect' ? colorStyle('incorrect-color', _renderUi.color.incorrect()) : {})
72
83
  },
73
- horizontalLayout: (0, _defineProperty2["default"])({}, "& .".concat(CLASS_NAME), {
74
- // visually reduce right padding, but maintain accessibility padding for checkbox indicators to be circles
75
- // add margin to the top, left and bottom of the checkbox to keep the same spacing as before
76
- padding: theme.spacing.unit,
77
- margin: "".concat(theme.spacing.unit / 2, "px 0 ").concat(theme.spacing.unit / 2, "px ").concat(theme.spacing.unit / 2, "px")
78
- }),
79
- belowLayout: {
80
- '& > label': {
81
- alignItems: 'flex-start'
82
- }
84
+ [key('checked')]: {
85
+ ...(correctness === 'correct' ? colorStyle('correct-selected-color', _renderUi.color.correct()) : {}),
86
+ ...(correctness === 'incorrect' ? colorStyle('incorrect-checked', _renderUi.color.incorrect()) : {}),
87
+ ...(!correctness ? colorStyle('selected-color', _renderUi.color.primary()) : {})
83
88
  },
84
- belowLayoutCenter: {
85
- justifyContent: 'center',
86
- '& > label': {
87
- alignItems: 'center'
88
- }
89
+ [key('disabled')]: {
90
+ ...colorStyle('disabled-color', _renderUi.color.text()),
91
+ ...(correctness === 'correct' ? colorStyle('correct-disabled-color', _renderUi.color.disabled()) : {}),
92
+ ...(correctness === 'incorrect' ? colorStyle('incorrect-disabled-color', _renderUi.color.disabled()) : {}),
93
+ opacity: 0.6,
94
+ cursor: 'not-allowed !important',
95
+ pointerEvents: 'initial !important'
89
96
  },
90
- belowSelectionComponent: {
91
- display: 'flex',
92
- alignItems: 'center',
93
- '& > span': {
94
- // visually reduce right padding, but maintain accessibility padding for checkbox indicators to be circles
95
- marginLeft: "-".concat(theme.spacing.unit, "px")
96
- }
97
+ focusVisibleUnchecked: {
98
+ outline: `2px solid ${_renderUi.color.focusUncheckedBorder()}`,
99
+ backgroundColor: _renderUi.color.focusUnchecked()
97
100
  },
98
- srOnly: {
99
- position: 'absolute',
100
- left: '-10000px',
101
- top: 'auto',
102
- width: '1px',
103
- height: '1px',
104
- overflow: 'hidden'
101
+ focusVisibleChecked: {
102
+ outline: `2px solid ${_renderUi.color.focusCheckedBorder()}`,
103
+ backgroundColor: _renderUi.color.focusChecked()
105
104
  }
106
105
  };
107
106
  };
108
-
109
- var formStyleSheet = {
110
- label: {
111
- color: "".concat(_renderUi.color.text(), " !important"),
112
- //'var(--choice-input-color, black)'
113
- backgroundColor: _renderUi.color.background(),
114
- letterSpacing: 'normal'
115
- },
116
- disabled: {
117
- // apply to all children
118
- '& *': {
119
- cursor: 'not-allowed !important'
120
- }
121
- }
122
- };
123
- var StyledFormControlLabel = (0, _styles.withStyles)(formStyleSheet, {
124
- name: 'FormControlLabel'
125
- })(function (props) {
126
- return /*#__PURE__*/_react["default"].createElement(_FormControlLabel["default"], (0, _extends2["default"])({}, props, {
127
- classes: {
128
- label: props.classes.label,
129
- disabled: props.classes.disabled
130
- }
131
- }));
132
- });
133
- exports.StyledFormControlLabel = StyledFormControlLabel;
134
-
135
- var colorStyle = function colorStyle(varName, fallback) {
136
- return (0, _defineProperty2["default"])({}, "&.".concat(CLASS_NAME), {
137
- color: "var(--choice-input-".concat(varName, ", ").concat(fallback, ") !important")
138
- });
139
- };
140
-
141
- var inputStyles = {
142
- 'correct-root': colorStyle('correct-color', _renderUi.color.text()),
143
- 'correct-checked': colorStyle('correct-selected-color', _renderUi.color.correct()),
144
- //green[500]),
145
- 'correct-disabled': colorStyle('correct-disabled-color', _renderUi.color.disabled()),
146
- //'grey'),
147
- 'incorrect-root': colorStyle('incorrect-color', _renderUi.color.incorrect()),
148
- 'incorrect-checked': colorStyle('incorrect-checked', _renderUi.color.incorrect()),
149
- //orange[500]),
150
- 'incorrect-disabled': colorStyle('incorrect-disabled-color', _renderUi.color.disabled()),
151
- root: _objectSpread(_objectSpread({}, colorStyle('color', _renderUi.color.text())), {}, {
152
- '&:hover': {
153
- color: "".concat(_renderUi.color.primaryLight(), " !important")
107
+ const StyledCheckboxBase = (0, _styles.styled)(_Checkbox.default, {
108
+ shouldForwardProp: prop => prop !== 'correctness'
109
+ })(({
110
+ correctness
111
+ }) => {
112
+ const styles = getInputStyles(correctness);
113
+ const key = k => correctness ? `${correctness}-${k}` : k;
114
+ return {
115
+ [`&.${CLASS_NAME}`]: {
116
+ ...styles[key('root')],
117
+ '&.Mui-checked': styles[key('checked')],
118
+ '&.Mui-disabled': correctness ? {} : styles[key('disabled')]
119
+ },
120
+ '&.Mui-focusVisible': {
121
+ '&:not(.Mui-checked)': styles.focusVisibleUnchecked,
122
+ '&.Mui-checked': styles.focusVisibleChecked
154
123
  }
155
- }),
156
- checked: colorStyle('selected-color', _renderUi.color.primary()),
157
- disabled: _objectSpread(_objectSpread({}, colorStyle('disabled-color', _renderUi.color.text())), {}, {
158
- opacity: 0.6,
159
- cursor: 'not-allowed !important',
160
- pointerEvents: 'initial !important'
161
- }),
162
- focusVisibleUnchecked: {
163
- outline: "2px solid ".concat(_renderUi.color.focusUncheckedBorder()),
164
- backgroundColor: _renderUi.color.focusUnchecked()
165
- },
166
- focusVisibleChecked: {
167
- outline: "2px solid ".concat(_renderUi.color.focusCheckedBorder()),
168
- backgroundColor: _renderUi.color.focusChecked()
169
- }
170
- };
171
- var StyledCheckbox = (0, _styles.withStyles)(inputStyles)(function (props) {
172
- var correctness = props.correctness,
173
- classes = props.classes,
174
- checked = props.checked,
175
- onChange = props.onChange,
176
- disabled = props.disabled,
177
- value = props.value,
178
- id = props.id,
179
- onKeyDown = props.onKeyDown,
180
- inputRef = props.inputRef;
181
-
182
- var key = function key(k) {
183
- return correctness ? "".concat(correctness, "-").concat(k) : k;
184
- };
185
-
186
- var resolved = {
187
- root: classes[key('root')],
188
- checked: classes[key('checked')],
189
- disabled: classes[key('disabled')]
190
124
  };
191
- var miniProps = {
192
- checked: checked,
193
- onChange: onChange,
194
- disabled: disabled,
195
- value: value
125
+ });
126
+ const StyledCheckbox = props => {
127
+ const {
128
+ correctness,
129
+ checked,
130
+ onChange,
131
+ disabled,
132
+ value,
133
+ id,
134
+ onKeyDown,
135
+ inputRef
136
+ } = props;
137
+ const miniProps = {
138
+ checked,
139
+ onChange,
140
+ disabled,
141
+ value
196
142
  };
197
- return /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], (0, _extends2["default"])({
143
+ return /*#__PURE__*/_react.default.createElement(StyledCheckboxBase, (0, _extends2.default)({
198
144
  id: id,
199
- inputRef: inputRef,
145
+ slotProps: {
146
+ input: {
147
+ ref: inputRef
148
+ }
149
+ },
200
150
  "aria-checked": checked,
201
151
  onKeyDown: onKeyDown,
202
- focusVisibleClassName: checked ? classes.focusVisibleChecked : classes.focusVisibleUnchecked,
203
152
  disableRipple: true
204
153
  }, miniProps, {
205
- className: CLASS_NAME,
206
- classes: {
207
- root: resolved.root,
208
- checked: resolved.checked,
209
- disabled: "".concat(correctness ? '' : resolved.disabled)
210
- }
154
+ correctness: correctness,
155
+ className: CLASS_NAME
211
156
  }));
212
- });
157
+ };
213
158
  exports.StyledCheckbox = StyledCheckbox;
214
- var StyledRadio = (0, _styles.withStyles)(inputStyles)(function (props) {
215
- var correctness = props.correctness,
216
- classes = props.classes,
217
- checked = props.checked,
218
- onChange = props.onChange,
219
- disabled = props.disabled,
220
- value = props.value,
221
- id = props.id,
222
- tagName = props.tagName,
223
- inputRef = props.inputRef;
224
-
225
- var key = function key(k) {
226
- return correctness ? "".concat(correctness, "-").concat(k) : k;
227
- };
228
-
229
- var resolved = {
230
- root: classes[key('root')],
231
- checked: classes[key('checked')],
232
- disabled: classes[key('disabled')]
159
+ const StyledRadioBase = (0, _styles.styled)(_Radio.default, {
160
+ shouldForwardProp: prop => prop !== 'correctness'
161
+ })(({
162
+ correctness
163
+ }) => {
164
+ const styles = getInputStyles(correctness);
165
+ const key = k => correctness ? `${correctness}-${k}` : k;
166
+ return {
167
+ [`&.${CLASS_NAME}`]: {
168
+ ...styles[key('root')],
169
+ '&.Mui-checked': styles[key('checked')],
170
+ '&.Mui-disabled': correctness ? {} : styles[key('disabled')]
171
+ },
172
+ '&.Mui-focusVisible': {
173
+ '&:not(.Mui-checked)': styles.focusVisibleUnchecked,
174
+ '&.Mui-checked': styles.focusVisibleChecked
175
+ }
233
176
  };
234
- var miniProps = {
235
- checked: checked,
236
- onChange: onChange,
237
- disabled: disabled,
238
- value: value
177
+ });
178
+ const StyledRadio = props => {
179
+ const {
180
+ correctness,
181
+ checked,
182
+ onChange,
183
+ disabled,
184
+ value,
185
+ id,
186
+ tagName,
187
+ inputRef
188
+ } = props;
189
+ const miniProps = {
190
+ checked,
191
+ onChange,
192
+ disabled,
193
+ value
239
194
  };
240
- return /*#__PURE__*/_react["default"].createElement(_Radio["default"], (0, _extends2["default"])({
195
+ return /*#__PURE__*/_react.default.createElement(StyledRadioBase, (0, _extends2.default)({
241
196
  id: id,
242
- inputRef: inputRef,
197
+ slotProps: {
198
+ input: {
199
+ ref: inputRef
200
+ }
201
+ },
243
202
  "aria-checked": checked,
244
- focusVisibleClassName: checked ? classes.focusVisibleChecked : classes.focusVisibleUnchecked,
245
203
  disableRipple: true
246
204
  }, miniProps, {
205
+ correctness: correctness,
247
206
  className: CLASS_NAME,
248
- name: tagName,
249
- classes: {
250
- root: resolved.root,
251
- checked: resolved.checked,
252
- disabled: "".concat(correctness ? '' : resolved.disabled)
253
- }
207
+ name: tagName
254
208
  }));
255
- });
209
+ };
256
210
  exports.StyledRadio = StyledRadio;
257
-
258
- var ChoiceInput = /*#__PURE__*/function (_React$Component) {
259
- (0, _inherits2["default"])(ChoiceInput, _React$Component);
260
-
261
- var _super = _createSuper(ChoiceInput);
262
-
263
- function ChoiceInput(props) {
264
- var _this;
265
-
266
- (0, _classCallCheck2["default"])(this, ChoiceInput);
267
- _this = _super.call(this, props);
268
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleKeyDown", function (event) {
269
- var choiceMode = _this.props.choiceMode;
211
+ class ChoiceInput extends _react.default.Component {
212
+ constructor(props) {
213
+ super(props);
214
+ (0, _defineProperty2.default)(this, "handleKeyDown", event => {
215
+ const {
216
+ choiceMode
217
+ } = this.props;
270
218
  if (choiceMode !== 'checkbox') return;
271
- var isArrowDown = event.key === 'ArrowDown';
272
- var isArrowUp = event.key === 'ArrowUp';
219
+ const isArrowDown = event.key === 'ArrowDown';
220
+ const isArrowUp = event.key === 'ArrowUp';
273
221
  if (!isArrowDown && !isArrowUp) return;
274
222
  event.preventDefault();
275
- var currentEl = document.getElementById(_this.choiceId);
223
+ const currentEl = document.getElementById(this.choiceId);
276
224
  if (!currentEl) return;
277
- var fieldset = currentEl.closest('fieldset');
225
+ const fieldset = currentEl.closest('fieldset');
278
226
  if (!fieldset) return;
279
- var groupCheckboxes = Array.from(fieldset.querySelectorAll('input[type="checkbox"]'));
280
- var currentIndex = groupCheckboxes.findIndex(function (el) {
281
- return el === currentEl;
282
- });
227
+ const groupCheckboxes = Array.from(fieldset.querySelectorAll('input[type="checkbox"]'));
228
+ const currentIndex = groupCheckboxes.findIndex(el => el === currentEl);
283
229
  if (currentIndex === -1) return;
284
- var nextIndex = isArrowDown ? currentIndex + 1 : currentIndex - 1;
285
- var nextEl = groupCheckboxes[nextIndex];
286
-
230
+ const nextIndex = isArrowDown ? currentIndex + 1 : currentIndex - 1;
231
+ const nextEl = groupCheckboxes[nextIndex];
287
232
  if (nextEl) {
288
233
  nextEl.focus();
289
234
  }
290
235
  });
291
- _this.onToggleChoice = _this.onToggleChoice.bind((0, _assertThisInitialized2["default"])(_this));
292
- _this.choiceId = _this.generateChoiceId();
293
- _this.descId = "".concat(_this.choiceId, "-desc");
294
- return _this;
236
+ this.onToggleChoice = this.onToggleChoice.bind(this);
237
+ this.choiceId = this.generateChoiceId();
238
+ this.descId = `${this.choiceId}-desc`;
295
239
  }
296
-
297
- (0, _createClass2["default"])(ChoiceInput, [{
298
- key: "onToggleChoice",
299
- value: function onToggleChoice(event) {
300
- this.props.onChange(event);
301
- }
302
- }, {
303
- key: "generateChoiceId",
304
- value: function generateChoiceId() {
305
- return 'choice-' + (Math.random() * 10000).toFixed();
306
- }
307
- }, {
308
- key: "render",
309
- value: function render() {
310
- var _classNames;
311
-
312
- var _this$props = this.props,
313
- choiceMode = _this$props.choiceMode,
314
- disabled = _this$props.disabled,
315
- displayKey = _this$props.displayKey,
316
- feedback = _this$props.feedback,
317
- label = _this$props.label,
318
- correctness = _this$props.correctness,
319
- classes = _this$props.classes,
320
- className = _this$props.className,
321
- rationale = _this$props.rationale,
322
- hideTick = _this$props.hideTick,
323
- isEvaluateMode = _this$props.isEvaluateMode,
324
- choicesLayout = _this$props.choicesLayout,
325
- value = _this$props.value,
326
- checked = _this$props.checked,
327
- tagName = _this$props.tagName,
328
- isSelectionButtonBelow = _this$props.isSelectionButtonBelow;
329
- var Tag = choiceMode === 'checkbox' ? StyledCheckbox : StyledRadio;
330
- var classSuffix = choiceMode === 'checkbox' ? 'checkbox' : 'radio-button';
331
- var holderClassNames = (0, _classnames["default"])(classes.checkboxHolder, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.horizontalLayout, choicesLayout === 'horizontal'), (0, _defineProperty2["default"])(_classNames, classes.belowLayout, isSelectionButtonBelow && choicesLayout !== 'grid'), (0, _defineProperty2["default"])(_classNames, classes.belowLayoutCenter, isSelectionButtonBelow && choicesLayout === 'grid'), _classNames));
332
-
333
- var choicelabel = /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, displayKey && !isSelectionButtonBelow ? /*#__PURE__*/_react["default"].createElement("span", {
334
- className: classes.row
335
- }, displayKey, ".", "\xA0", /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
336
- className: "label",
337
- prompt: label,
338
- tagName: "span"
339
- })) : /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
340
- className: "label",
341
- prompt: label,
342
- tagName: "span"
343
- }));
344
-
345
- var screenReaderLabel = /*#__PURE__*/_react["default"].createElement("span", {
346
- id: this.descId,
347
- className: classes.srOnly
348
- }, choiceMode === 'checkbox' ? 'Checkbox to select the answer below' : 'Radio button to select the answer below');
349
-
350
- var tagProps = {
351
- disabled: disabled,
352
- checked: checked,
353
- correctness: correctness,
354
- tagName: tagName,
355
- value: value,
356
- id: this.choiceId,
357
- onChange: this.onToggleChoice,
358
- onKeyDown: this.handleKeyDown,
359
- 'aria-describedby': this.descId
360
- };
361
- var hasMathOrImage = typeof label === 'string' && (label.includes('<math') || label.includes('\\(') || label.includes('\\[') || label.includes('<img') || label.includes('data-latex') || label.includes('data-raw') || label.includes('<mjx-container'));
362
- var control = isSelectionButtonBelow ? /*#__PURE__*/_react["default"].createElement("span", {
363
- className: classes.belowSelectionComponent
364
- }, hasMathOrImage && screenReaderLabel, /*#__PURE__*/_react["default"].createElement(Tag, (0, _extends2["default"])({}, tagProps, {
365
- style: {
366
- padding: 0
240
+ onToggleChoice(event) {
241
+ this.props.onChange(event);
242
+ }
243
+ generateChoiceId() {
244
+ return 'choice-' + (Math.random() * 10000).toFixed();
245
+ }
246
+ render() {
247
+ const {
248
+ choiceMode,
249
+ disabled,
250
+ displayKey,
251
+ feedback,
252
+ label,
253
+ correctness,
254
+ className,
255
+ rationale,
256
+ hideTick,
257
+ isEvaluateMode,
258
+ choicesLayout,
259
+ value,
260
+ checked,
261
+ tagName,
262
+ isSelectionButtonBelow
263
+ } = this.props;
264
+ const Tag = choiceMode === 'checkbox' ? StyledCheckbox : StyledRadio;
265
+ const classSuffix = choiceMode === 'checkbox' ? 'checkbox' : 'radio-button';
266
+ const holderSx = {
267
+ ...(choicesLayout === 'horizontal' && {
268
+ [`& .${CLASS_NAME}`]: {
269
+ padding: '8px',
270
+ margin: '4px 0 4px 4px'
367
271
  }
368
- })), displayKey ? "".concat(displayKey, ".") : '') : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, hasMathOrImage && screenReaderLabel, /*#__PURE__*/_react["default"].createElement(Tag, (0, _extends2["default"])({}, tagProps, {
369
- inputRef: this.props.autoFocusRef
370
- })));
371
- return /*#__PURE__*/_react["default"].createElement("div", {
372
- className: (0, _classnames["default"])(className, 'corespring-' + classSuffix, 'choice-input')
373
- }, /*#__PURE__*/_react["default"].createElement("div", {
374
- className: classes.row
375
- }, !hideTick && isEvaluateMode && /*#__PURE__*/_react["default"].createElement(_feedbackTick["default"], {
376
- correctness: correctness
377
- }), /*#__PURE__*/_react["default"].createElement("div", {
378
- className: (0, _classnames["default"])(holderClassNames, 'checkbox-holder')
379
- }, /*#__PURE__*/_react["default"].createElement(StyledFormControlLabel, {
380
- label: choicelabel,
381
- value: value,
382
- htmlFor: this.choiceId,
383
- labelPlacement: isSelectionButtonBelow ? 'top' : undefined,
384
- control: control
385
- }))), rationale && /*#__PURE__*/_react["default"].createElement(_renderUi.PreviewPrompt, {
386
- className: "rationale",
387
- defaultClassName: "rationale",
388
- prompt: rationale
389
- }), /*#__PURE__*/_react["default"].createElement(_renderUi.Feedback, {
390
- feedback: feedback,
391
- correctness: correctness
392
- }));
393
- }
394
- }]);
395
- return ChoiceInput;
396
- }(_react["default"].Component);
397
-
272
+ }),
273
+ ...(isSelectionButtonBelow && choicesLayout !== 'grid' && {
274
+ '& > label': {
275
+ alignItems: 'flex-start'
276
+ }
277
+ }),
278
+ ...(isSelectionButtonBelow && choicesLayout === 'grid' && {
279
+ justifyContent: 'center',
280
+ '& > label': {
281
+ alignItems: 'center'
282
+ }
283
+ })
284
+ };
285
+ const choicelabel = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, displayKey && !isSelectionButtonBelow ? /*#__PURE__*/_react.default.createElement(Row, {
286
+ component: "span"
287
+ }, displayKey, ".", '\u00A0', /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
288
+ className: "label",
289
+ prompt: label,
290
+ tagName: "span"
291
+ })) : /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
292
+ className: "label",
293
+ prompt: label,
294
+ tagName: "span"
295
+ }));
296
+ const screenReaderLabel = /*#__PURE__*/_react.default.createElement(SrOnly, {
297
+ id: this.descId
298
+ }, choiceMode === 'checkbox' ? 'Checkbox to select the answer below' : 'Radio button to select the answer below');
299
+ const tagProps = {
300
+ disabled,
301
+ checked,
302
+ correctness,
303
+ tagName,
304
+ value,
305
+ id: this.choiceId,
306
+ onChange: this.onToggleChoice,
307
+ onKeyDown: this.handleKeyDown,
308
+ 'aria-describedby': this.descId
309
+ };
310
+ const hasMathOrImage = typeof label === 'string' && (label.includes('<math') || label.includes('\\(') || label.includes('\\[') || label.includes('<img') || label.includes('data-latex') || label.includes('data-raw') || label.includes('<mjx-container'));
311
+ const control = isSelectionButtonBelow ? /*#__PURE__*/_react.default.createElement(BelowSelectionComponent, null, hasMathOrImage && screenReaderLabel, /*#__PURE__*/_react.default.createElement(Tag, (0, _extends2.default)({}, tagProps, {
312
+ style: {
313
+ padding: 0
314
+ }
315
+ })), displayKey ? `${displayKey}.` : '') : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, hasMathOrImage && screenReaderLabel, /*#__PURE__*/_react.default.createElement(Tag, (0, _extends2.default)({}, tagProps, {
316
+ slotProps: {
317
+ input: {
318
+ ref: this.props.autoFocusRef
319
+ }
320
+ }
321
+ })));
322
+ return /*#__PURE__*/_react.default.createElement("div", {
323
+ className: (0, _classnames.default)(className, 'corespring-' + classSuffix, 'choice-input')
324
+ }, /*#__PURE__*/_react.default.createElement(Row, null, !hideTick && isEvaluateMode && /*#__PURE__*/_react.default.createElement(_feedbackTick.default, {
325
+ correctness: correctness
326
+ }), /*#__PURE__*/_react.default.createElement(CheckboxHolder, {
327
+ className: "checkbox-holder",
328
+ sx: holderSx
329
+ }, /*#__PURE__*/_react.default.createElement(StyledFormControlLabel, {
330
+ label: choicelabel,
331
+ value: value,
332
+ htmlFor: this.choiceId,
333
+ labelPlacement: isSelectionButtonBelow ? 'top' : undefined,
334
+ control: control
335
+ }))), rationale && /*#__PURE__*/_react.default.createElement(_renderUi.PreviewPrompt, {
336
+ className: "rationale",
337
+ defaultClassName: "rationale",
338
+ prompt: rationale
339
+ }), /*#__PURE__*/_react.default.createElement(_renderUi.Feedback, {
340
+ feedback: feedback,
341
+ correctness: correctness
342
+ }));
343
+ }
344
+ }
398
345
  exports.ChoiceInput = ChoiceInput;
399
- (0, _defineProperty2["default"])(ChoiceInput, "propTypes", {
400
- choiceMode: _propTypes["default"].oneOf(['radio', 'checkbox']),
401
- displayKey: _propTypes["default"].string,
402
- checked: _propTypes["default"].bool.isRequired,
403
- correctness: _propTypes["default"].string,
404
- disabled: _propTypes["default"].bool.isRequired,
405
- feedback: _propTypes["default"].string,
406
- label: _propTypes["default"].string.isRequired,
407
- rationale: _propTypes["default"].string,
408
- onChange: _propTypes["default"].func.isRequired,
409
- value: _propTypes["default"].string.isRequired,
410
- classes: _propTypes["default"].object,
411
- className: _propTypes["default"].string,
412
- tagName: _propTypes["default"].string,
413
- hideTick: _propTypes["default"].bool,
414
- isEvaluateMode: _propTypes["default"].bool,
415
- choicesLayout: _propTypes["default"].oneOf(['vertical', 'grid', 'horizontal']),
416
- isSelectionButtonBelow: _propTypes["default"].bool
346
+ (0, _defineProperty2.default)(ChoiceInput, "propTypes", {
347
+ choiceMode: _propTypes.default.oneOf(['radio', 'checkbox']),
348
+ displayKey: _propTypes.default.string,
349
+ checked: _propTypes.default.bool.isRequired,
350
+ correctness: _propTypes.default.string,
351
+ disabled: _propTypes.default.bool.isRequired,
352
+ feedback: _propTypes.default.string,
353
+ label: _propTypes.default.string.isRequired,
354
+ rationale: _propTypes.default.string,
355
+ onChange: _propTypes.default.func.isRequired,
356
+ value: _propTypes.default.string.isRequired,
357
+ className: _propTypes.default.string,
358
+ tagName: _propTypes.default.string,
359
+ hideTick: _propTypes.default.bool,
360
+ isEvaluateMode: _propTypes.default.bool,
361
+ choicesLayout: _propTypes.default.oneOf(['vertical', 'grid', 'horizontal']),
362
+ isSelectionButtonBelow: _propTypes.default.bool
417
363
  });
418
- (0, _defineProperty2["default"])(ChoiceInput, "defaultProps", {
364
+ (0, _defineProperty2.default)(ChoiceInput, "defaultProps", {
419
365
  rationale: null,
420
366
  checked: false,
421
367
  isEvaluateMode: false
422
368
  });
423
-
424
- var _default = (0, _styles.withStyles)(styleSheet)(ChoiceInput);
425
-
426
- exports["default"] = _default;
427
- //# sourceMappingURL=choice-input.js.map
369
+ var _default = exports.default = ChoiceInput;
370
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfRm9ybUNvbnRyb2xMYWJlbCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX3JlYWN0IiwiX3Byb3BUeXBlcyIsIl9zdHlsZXMiLCJfQm94IiwiX0NoZWNrYm94IiwiX3JlbmRlclVpIiwiX1JhZGlvIiwiX2NsYXNzbmFtZXMiLCJfZmVlZGJhY2tUaWNrIiwiQ0xBU1NfTkFNRSIsIlJvdyIsInN0eWxlZCIsIkJveCIsImRpc3BsYXkiLCJhbGlnbkl0ZW1zIiwiYmFja2dyb3VuZENvbG9yIiwiY29sb3IiLCJiYWNrZ3JvdW5kIiwiQ2hlY2tib3hIb2xkZXIiLCJmbGV4IiwidGV4dCIsImZvbnRTaXplIiwiQmVsb3dTZWxlY3Rpb25Db21wb25lbnQiLCJ0aGVtZSIsIm1hcmdpbkxlZnQiLCJzcGFjaW5nIiwiU3JPbmx5IiwicG9zaXRpb24iLCJsZWZ0IiwidG9wIiwid2lkdGgiLCJoZWlnaHQiLCJvdmVyZmxvdyIsIlN0eWxlZEZvcm1Db250cm9sTGFiZWwiLCJleHBvcnRzIiwiRm9ybUNvbnRyb2xMYWJlbCIsImxldHRlclNwYWNpbmciLCJjdXJzb3IiLCJjb2xvclN0eWxlIiwidmFyTmFtZSIsImZhbGxiYWNrIiwiZ2V0SW5wdXRTdHlsZXMiLCJjb3JyZWN0bmVzcyIsImtleSIsImsiLCJwcmltYXJ5TGlnaHQiLCJpbmNvcnJlY3QiLCJjb3JyZWN0IiwicHJpbWFyeSIsImRpc2FibGVkIiwib3BhY2l0eSIsInBvaW50ZXJFdmVudHMiLCJmb2N1c1Zpc2libGVVbmNoZWNrZWQiLCJvdXRsaW5lIiwiZm9jdXNVbmNoZWNrZWRCb3JkZXIiLCJmb2N1c1VuY2hlY2tlZCIsImZvY3VzVmlzaWJsZUNoZWNrZWQiLCJmb2N1c0NoZWNrZWRCb3JkZXIiLCJmb2N1c0NoZWNrZWQiLCJTdHlsZWRDaGVja2JveEJhc2UiLCJDaGVja2JveCIsInNob3VsZEZvcndhcmRQcm9wIiwicHJvcCIsInN0eWxlcyIsIlN0eWxlZENoZWNrYm94IiwicHJvcHMiLCJjaGVja2VkIiwib25DaGFuZ2UiLCJ2YWx1ZSIsImlkIiwib25LZXlEb3duIiwiaW5wdXRSZWYiLCJtaW5pUHJvcHMiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsIl9leHRlbmRzMiIsInNsb3RQcm9wcyIsImlucHV0IiwicmVmIiwiZGlzYWJsZVJpcHBsZSIsImNsYXNzTmFtZSIsIlN0eWxlZFJhZGlvQmFzZSIsIlJhZGlvIiwiU3R5bGVkUmFkaW8iLCJ0YWdOYW1lIiwibmFtZSIsIkNob2ljZUlucHV0IiwiUmVhY3QiLCJDb21wb25lbnQiLCJjb25zdHJ1Y3RvciIsIl9kZWZpbmVQcm9wZXJ0eTIiLCJldmVudCIsImNob2ljZU1vZGUiLCJpc0Fycm93RG93biIsImlzQXJyb3dVcCIsInByZXZlbnREZWZhdWx0IiwiY3VycmVudEVsIiwiZG9jdW1lbnQiLCJnZXRFbGVtZW50QnlJZCIsImNob2ljZUlkIiwiZmllbGRzZXQiLCJjbG9zZXN0IiwiZ3JvdXBDaGVja2JveGVzIiwiQXJyYXkiLCJmcm9tIiwicXVlcnlTZWxlY3RvckFsbCIsImN1cnJlbnRJbmRleCIsImZpbmRJbmRleCIsImVsIiwibmV4dEluZGV4IiwibmV4dEVsIiwiZm9jdXMiLCJvblRvZ2dsZUNob2ljZSIsImJpbmQiLCJnZW5lcmF0ZUNob2ljZUlkIiwiZGVzY0lkIiwiTWF0aCIsInJhbmRvbSIsInRvRml4ZWQiLCJyZW5kZXIiLCJkaXNwbGF5S2V5IiwiZmVlZGJhY2siLCJsYWJlbCIsInJhdGlvbmFsZSIsImhpZGVUaWNrIiwiaXNFdmFsdWF0ZU1vZGUiLCJjaG9pY2VzTGF5b3V0IiwiaXNTZWxlY3Rpb25CdXR0b25CZWxvdyIsIlRhZyIsImNsYXNzU3VmZml4IiwiaG9sZGVyU3giLCJwYWRkaW5nIiwibWFyZ2luIiwianVzdGlmeUNvbnRlbnQiLCJjaG9pY2VsYWJlbCIsIkZyYWdtZW50IiwiY29tcG9uZW50IiwiUHJldmlld1Byb21wdCIsInByb21wdCIsInNjcmVlblJlYWRlckxhYmVsIiwidGFnUHJvcHMiLCJoYW5kbGVLZXlEb3duIiwiaGFzTWF0aE9ySW1hZ2UiLCJpbmNsdWRlcyIsImNvbnRyb2wiLCJzdHlsZSIsImF1dG9Gb2N1c1JlZiIsImNsYXNzTmFtZXMiLCJzeCIsImh0bWxGb3IiLCJsYWJlbFBsYWNlbWVudCIsInVuZGVmaW5lZCIsImRlZmF1bHRDbGFzc05hbWUiLCJGZWVkYmFjayIsIlByb3BUeXBlcyIsIm9uZU9mIiwic3RyaW5nIiwiYm9vbCIsImlzUmVxdWlyZWQiLCJmdW5jIiwiX2RlZmF1bHQiXSwic291cmNlcyI6WyIuLi9zcmMvY2hvaWNlLWlucHV0LmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgRm9ybUNvbnRyb2xMYWJlbCBmcm9tICdAbXVpL21hdGVyaWFsL0Zvcm1Db250cm9sTGFiZWwnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBzdHlsZWQgfSBmcm9tICdAbXVpL21hdGVyaWFsL3N0eWxlcyc7XG5pbXBvcnQgQm94IGZyb20gJ0BtdWkvbWF0ZXJpYWwvQm94JztcbmltcG9ydCBDaGVja2JveCBmcm9tICdAbXVpL21hdGVyaWFsL0NoZWNrYm94JztcbmltcG9ydCB7IEZlZWRiYWNrLCBjb2xvciwgUHJldmlld1Byb21wdCB9IGZyb20gJ0BwaWUtbGliL3JlbmRlci11aSc7XG5pbXBvcnQgUmFkaW8gZnJvbSAnQG11aS9tYXRlcmlhbC9SYWRpbyc7XG5pbXBvcnQgY2xhc3NOYW1lcyBmcm9tICdjbGFzc25hbWVzJztcblxuaW1wb3J0IEZlZWRiYWNrVGljayBmcm9tICcuL2ZlZWRiYWNrLXRpY2snO1xuXG5jb25zdCBDTEFTU19OQU1FID0gJ211bHRpcGxlLWNob2ljZS1jb21wb25lbnQnO1xuXG5jb25zdCBSb3cgPSBzdHlsZWQoQm94KSh7XG4gIGRpc3BsYXk6ICdmbGV4JyxcbiAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gIGJhY2tncm91bmRDb2xvcjogY29sb3IuYmFja2dyb3VuZCgpLFxufSk7XG5cbmNvbnN0IENoZWNrYm94SG9sZGVyID0gc3R5bGVkKEJveCkoe1xuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBiYWNrZ3JvdW5kQ29sb3I6IGNvbG9yLmJhY2tncm91bmQoKSxcbiAgZmxleDogMSxcbiAgJyYgbGFiZWwnOiB7XG4gICAgY29sb3I6IGNvbG9yLnRleHQoKSxcbiAgICAnJiA+IHNwYW4nOiB7XG4gICAgICBmb250U2l6ZTogJ2luaGVyaXQnLFxuICAgIH0sXG4gIH0sXG59KTtcblxuY29uc3QgQmVsb3dTZWxlY3Rpb25Db21wb25lbnQgPSBzdHlsZWQoJ3NwYW4nKSgoeyB0aGVtZSB9KSA9PiAoe1xuICBkaXNwbGF5OiAnZmxleCcsXG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAnJiA+IHNwYW4nOiB7XG4gICAgLy8gdmlzdWFsbHkgcmVkdWNlIHJpZ2h0IHBhZGRpbmcsIGJ1dCBtYWludGFpbiBhY2Nlc3NpYmlsaXR5IHBhZGRpbmcgZm9yIGNoZWNrYm94IGluZGljYXRvcnMgdG8gYmUgY2lyY2xlc1xuICAgIG1hcmdpbkxlZnQ6IGAtJHt0aGVtZS5zcGFjaW5nKDEpfXB4YCxcbiAgfSxcbn0pKTtcblxuY29uc3QgU3JPbmx5ID0gc3R5bGVkKCdzcGFuJykoe1xuICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgbGVmdDogJy0xMDAwMHB4JyxcbiAgdG9wOiAnYXV0bycsXG4gIHdpZHRoOiAnMXB4JyxcbiAgaGVpZ2h0OiAnMXB4JyxcbiAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxufSk7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRGb3JtQ29udHJvbExhYmVsID0gc3R5bGVkKEZvcm1Db250cm9sTGFiZWwpKHtcbiAgJyYgLk11aUZvcm1Db250cm9sTGFiZWwtbGFiZWwnOiB7XG4gICAgY29sb3I6IGAke2NvbG9yLnRleHQoKX0gIWltcG9ydGFudGAsXG4gICAgYmFja2dyb3VuZENvbG9yOiBjb2xvci5iYWNrZ3JvdW5kKCksXG4gICAgbGV0dGVyU3BhY2luZzogJ25vcm1hbCcsXG4gIH0sXG4gICcmLk11aS1kaXNhYmxlZCAqJzoge1xuICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkICFpbXBvcnRhbnQnLFxuICB9LFxufSk7XG5cbmNvbnN0IGNvbG9yU3R5bGUgPSAodmFyTmFtZSwgZmFsbGJhY2spID0+ICh7XG4gIFtgJi4ke0NMQVNTX05BTUV9YF06IHtcbiAgICBjb2xvcjogYHZhcigtLWNob2ljZS1pbnB1dC0ke3Zhck5hbWV9LCAke2ZhbGxiYWNrfSkgIWltcG9ydGFudGAsXG4gIH0sXG59KTtcblxuY29uc3QgZ2V0SW5wdXRTdHlsZXMgPSAoY29ycmVjdG5lc3MpID0+IHtcbiAgY29uc3Qga2V5ID0gKGspID0+IChjb3JyZWN0bmVzcyA/IGAke2NvcnJlY3RuZXNzfS0ke2t9YCA6IGspO1xuICBcbiAgcmV0dXJuIHtcbiAgICBba2V5KCdyb290JyldOiB7XG4gICAgICAuLi5jb2xvclN0eWxlKCdjb2xvcicsIGNvbG9yLnRleHQoKSksXG4gICAgICAuLi4oY29ycmVjdG5lc3MgPyB7fSA6IHtcbiAgICAgICAgJyY6aG92ZXInOiB7IGNvbG9yOiBgJHtjb2xvci5wcmltYXJ5TGlnaHQoKX0gIWltcG9ydGFudGAgfSxcbiAgICAgIH0pLFxuICAgICAgLi4uKGNvcnJlY3RuZXNzID09PSAnY29ycmVjdCcgPyBjb2xvclN0eWxlKCdjb3JyZWN0LWNvbG9yJywgY29sb3IudGV4dCgpKSA6IHt9KSxcbiAgICAgIC4uLihjb3JyZWN0bmVzcyA9PT0gJ2luY29ycmVjdCcgPyBjb2xvclN0eWxlKCdpbmNvcnJlY3QtY29sb3InLCBjb2xvci5pbmNvcnJlY3QoKSkgOiB7fSksXG4gICAgfSxcbiAgICBba2V5KCdjaGVja2VkJyldOiB7XG4gICAgICAuLi4oY29ycmVjdG5lc3MgPT09ICdjb3JyZWN0JyA/IGNvbG9yU3R5bGUoJ2NvcnJlY3Qtc2VsZWN0ZWQtY29sb3InLCBjb2xvci5jb3JyZWN0KCkpIDoge30pLFxuICAgICAgLi4uKGNvcnJlY3RuZXNzID09PSAnaW5jb3JyZWN0JyA/IGNvbG9yU3R5bGUoJ2luY29ycmVjdC1jaGVja2VkJywgY29sb3IuaW5jb3JyZWN0KCkpIDoge30pLFxuICAgICAgLi4uKCFjb3JyZWN0bmVzcyA/IGNvbG9yU3R5bGUoJ3NlbGVjdGVkLWNvbG9yJywgY29sb3IucHJpbWFyeSgpKSA6IHt9KSxcbiAgICB9LFxuICAgIFtrZXkoJ2Rpc2FibGVkJyldOiB7XG4gICAgICAuLi5jb2xvclN0eWxlKCdkaXNhYmxlZC1jb2xvcicsIGNvbG9yLnRleHQoKSksXG4gICAgICAuLi4oY29ycmVjdG5lc3MgPT09ICdjb3JyZWN0JyA/IGNvbG9yU3R5bGUoJ2NvcnJlY3QtZGlzYWJsZWQtY29sb3InLCBjb2xvci5kaXNhYmxlZCgpKSA6IHt9KSxcbiAgICAgIC4uLihjb3JyZWN0bmVzcyA9PT0gJ2luY29ycmVjdCcgPyBjb2xvclN0eWxlKCdpbmNvcnJlY3QtZGlzYWJsZWQtY29sb3InLCBjb2xvci5kaXNhYmxlZCgpKSA6IHt9KSxcbiAgICAgIG9wYWNpdHk6IDAuNixcbiAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkICFpbXBvcnRhbnQnLFxuICAgICAgcG9pbnRlckV2ZW50czogJ2luaXRpYWwgIWltcG9ydGFudCcsXG4gICAgfSxcbiAgICBmb2N1c1Zpc2libGVVbmNoZWNrZWQ6IHtcbiAgICAgIG91dGxpbmU6IGAycHggc29saWQgJHtjb2xvci5mb2N1c1VuY2hlY2tlZEJvcmRlcigpfWAsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IGNvbG9yLmZvY3VzVW5jaGVja2VkKCksXG4gICAgfSxcbiAgICBmb2N1c1Zpc2libGVDaGVja2VkOiB7XG4gICAgICBvdXRsaW5lOiBgMnB4IHNvbGlkICR7Y29sb3IuZm9jdXNDaGVja2VkQm9yZGVyKCl9YCxcbiAgICAgIGJhY2tncm91bmRDb2xvcjogY29sb3IuZm9jdXNDaGVja2VkKCksXG4gICAgfSxcbiAgfTtcbn07XG5cbmNvbnN0IFN0eWxlZENoZWNrYm94QmFzZSA9IHN0eWxlZChDaGVja2JveCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogKHByb3ApID0+IHByb3AgIT09ICdjb3JyZWN0bmVzcycsXG59KSgoeyBjb3JyZWN0bmVzcyB9KSA9PiB7XG4gIGNvbnN0IHN0eWxlcyA9IGdldElucHV0U3R5bGVzKGNvcnJlY3RuZXNzKTtcbiAgY29uc3Qga2V5ID0gKGspID0+IChjb3JyZWN0bmVzcyA/IGAke2NvcnJlY3RuZXNzfS0ke2t9YCA6IGspO1xuICBcbiAgcmV0dXJuIHtcbiAgICBbYCYuJHtDTEFTU19OQU1FfWBdOiB7XG4gICAgICAuLi5zdHlsZXNba2V5KCdyb290JyldLFxuICAgICAgJyYuTXVpLWNoZWNrZWQnOiBzdHlsZXNba2V5KCdjaGVja2VkJyldLFxuICAgICAgJyYuTXVpLWRpc2FibGVkJzogY29ycmVjdG5lc3MgPyB7fSA6IHN0eWxlc1trZXkoJ2Rpc2FibGVkJyldLFxuICAgIH0sXG4gICAgJyYuTXVpLWZvY3VzVmlzaWJsZSc6IHtcbiAgICAgICcmOm5vdCguTXVpLWNoZWNrZWQpJzogc3R5bGVzLmZvY3VzVmlzaWJsZVVuY2hlY2tlZCxcbiAgICAgICcmLk11aS1jaGVja2VkJzogc3R5bGVzLmZvY3VzVmlzaWJsZUNoZWNrZWQsXG4gICAgfSxcbiAgfTtcbn0pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hlY2tib3ggPSAocHJvcHMpID0+IHtcbiAgY29uc3QgeyBjb3JyZWN0bmVzcywgY2hlY2tlZCwgb25DaGFuZ2UsIGRpc2FibGVkLCB2YWx1ZSwgaWQsIG9uS2V5RG93biwgaW5wdXRSZWYgfSA9IHByb3BzO1xuXG4gIGNvbnN0IG1pbmlQcm9wcyA9IHsgY2hlY2tlZCwgb25DaGFuZ2UsIGRpc2FibGVkLCB2YWx1ZSB9O1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENoZWNrYm94QmFzZVxuICAgICAgaWQ9e2lkfVxuICAgICAgc2xvdFByb3BzPXt7IGlucHV0OiB7IHJlZjogaW5wdXRSZWYgfSB9fVxuICAgICAgYXJpYS1jaGVja2VkPXtjaGVja2VkfVxuICAgICAgb25LZXlEb3duPXtvbktleURvd259XG4gICAgICBkaXNhYmxlUmlwcGxlXG4gICAgICB7Li4ubWluaVByb3BzfVxuICAgICAgY29ycmVjdG5lc3M9e2NvcnJlY3RuZXNzfVxuICAgICAgY2xhc3NOYW1lPXtDTEFTU19OQU1FfVxuICAgIC8+XG4gICk7XG59O1xuXG5jb25zdCBTdHlsZWRSYWRpb0Jhc2UgPSBzdHlsZWQoUmFkaW8sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IChwcm9wKSA9PiBwcm9wICE9PSAnY29ycmVjdG5lc3MnLFxufSkoKHsgY29ycmVjdG5lc3MgfSkgPT4ge1xuICBjb25zdCBzdHlsZXMgPSBnZXRJbnB1dFN0eWxlcyhjb3JyZWN0bmVzcyk7XG4gIGNvbnN0IGtleSA9IChrKSA9PiAoY29ycmVjdG5lc3MgPyBgJHtjb3JyZWN0bmVzc30tJHtrfWAgOiBrKTtcbiAgXG4gIHJldHVybiB7XG4gICAgW2AmLiR7Q0xBU1NfTkFNRX1gXToge1xuICAgICAgLi4uc3R5bGVzW2tleSgncm9vdCcpXSxcbiAgICAgICcmLk11aS1jaGVja2VkJzogc3R5bGVzW2tleSgnY2hlY2tlZCcpXSxcbiAgICAgICcmLk11aS1kaXNhYmxlZCc6IGNvcnJlY3RuZXNzID8ge30gOiBzdHlsZXNba2V5KCdkaXNhYmxlZCcpXSxcbiAgICB9LFxuICAgICcmLk11aS1mb2N1c1Zpc2libGUnOiB7XG4gICAgICAnJjpub3QoLk11aS1jaGVja2VkKSc6IHN0eWxlcy5mb2N1c1Zpc2libGVVbmNoZWNrZWQsXG4gICAgICAnJi5NdWktY2hlY2tlZCc6IHN0eWxlcy5mb2N1c1Zpc2libGVDaGVja2VkLFxuICAgIH0sXG4gIH07XG59KTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFJhZGlvID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IHsgY29ycmVjdG5lc3MsIGNoZWNrZWQsIG9uQ2hhbmdlLCBkaXNhYmxlZCwgdmFsdWUsIGlkLCB0YWdOYW1lLCBpbnB1dFJlZiB9ID0gcHJvcHM7XG5cbiAgY29uc3QgbWluaVByb3BzID0geyBjaGVja2VkLCBvbkNoYW5nZSwgZGlzYWJsZWQsIHZhbHVlIH07XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkUmFkaW9CYXNlXG4gICAgICBpZD17aWR9XG4gICAgICBzbG90UHJvcHM9e3sgaW5wdXQ6IHsgcmVmOiBpbnB1dFJlZiB9IH19XG4gICAgICBhcmlhLWNoZWNrZWQ9e2NoZWNrZWR9XG4gICAgICBkaXNhYmxlUmlwcGxlXG4gICAgICB7Li4ubWluaVByb3BzfVxuICAgICAgY29ycmVjdG5lc3M9e2NvcnJlY3RuZXNzfVxuICAgICAgY2xhc3NOYW1lPXtDTEFTU19OQU1FfVxuICAgICAgbmFtZT17dGFnTmFtZX1cbiAgICAvPlxuICApO1xufTtcblxuZXhwb3J0IGNsYXNzIENob2ljZUlucHV0IGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBjaG9pY2VNb2RlOiBQcm9wVHlwZXMub25lT2YoWydyYWRpbycsICdjaGVja2JveCddKSxcbiAgICBkaXNwbGF5S2V5OiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGNoZWNrZWQ6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gICAgY29ycmVjdG5lc3M6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gICAgZmVlZGJhY2s6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgbGFiZWw6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICByYXRpb25hbGU6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgdmFsdWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgICBjbGFzc05hbWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgdGFnTmFtZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBoaWRlVGljazogUHJvcFR5cGVzLmJvb2wsXG4gICAgaXNFdmFsdWF0ZU1vZGU6IFByb3BUeXBlcy5ib29sLFxuICAgIGNob2ljZXNMYXlvdXQ6IFByb3BUeXBlcy5vbmVPZihbJ3ZlcnRpY2FsJywgJ2dyaWQnLCAnaG9yaXpvbnRhbCddKSxcbiAgICBpc1NlbGVjdGlvbkJ1dHRvbkJlbG93OiBQcm9wVHlwZXMuYm9vbCxcbiAgfTtcblxuICBzdGF0aWMgZGVmYXVsdFByb3BzID0ge1xuICAgIHJhdGlvbmFsZTogbnVsbCxcbiAgICBjaGVja2VkOiBmYWxzZSxcbiAgICBpc0V2YWx1YXRlTW9kZTogZmFsc2UsXG4gIH07XG5cbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gICAgdGhpcy5vblRvZ2dsZUNob2ljZSA9IHRoaXMub25Ub2dnbGVDaG9pY2UuYmluZCh0aGlzKTtcbiAgICB0aGlzLmNob2ljZUlkID0gdGhpcy5nZW5lcmF0ZUNob2ljZUlkKCk7XG4gICAgdGhpcy5kZXNjSWQgPSBgJHt0aGlzLmNob2ljZUlkfS1kZXNjYDtcbiAgfVxuXG4gIG9uVG9nZ2xlQ2hvaWNlKGV2ZW50KSB7XG4gICAgdGhpcy5wcm9wcy5vbkNoYW5nZShldmVudCk7XG4gIH1cblxuICBnZW5lcmF0ZUNob2ljZUlkKCkge1xuICAgIHJldHVybiAnY2hvaWNlLScgKyAoTWF0aC5yYW5kb20oKSAqIDEwMDAwKS50b0ZpeGVkKCk7XG4gIH1cblxuICBoYW5kbGVLZXlEb3duID0gKGV2ZW50KSA9PiB7XG4gICAgY29uc3QgeyBjaG9pY2VNb2RlIH0gPSB0aGlzLnByb3BzO1xuXG4gICAgaWYgKGNob2ljZU1vZGUgIT09ICdjaGVja2JveCcpIHJldHVybjtcblxuICAgIGNvbnN0IGlzQXJyb3dEb3duID0gZXZlbnQua2V5ID09PSAnQXJyb3dEb3duJztcbiAgICBjb25zdCBpc0Fycm93VXAgPSBldmVudC5rZXkgPT09ICdBcnJvd1VwJztcblxuICAgIGlmICghaXNBcnJvd0Rvd24gJiYgIWlzQXJyb3dVcCkgcmV0dXJuO1xuXG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcblxuICAgIGNvbnN0IGN1cnJlbnRFbCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKHRoaXMuY2hvaWNlSWQpO1xuICAgIGlmICghY3VycmVudEVsKSByZXR1cm47XG5cbiAgICBjb25zdCBmaWVsZHNldCA9IGN1cnJlbnRFbC5jbG9zZXN0KCdmaWVsZHNldCcpO1xuICAgIGlmICghZmllbGRzZXQpIHJldHVybjtcblxuICAgIGNvbnN0IGdyb3VwQ2hlY2tib3hlcyA9IEFycmF5LmZyb20oZmllbGRzZXQucXVlcnlTZWxlY3RvckFsbCgnaW5wdXRbdHlwZT1cImNoZWNrYm94XCJdJykpO1xuXG4gICAgY29uc3QgY3VycmVudEluZGV4ID0gZ3JvdXBDaGVja2JveGVzLmZpbmRJbmRleCgoZWwpID0+IGVsID09PSBjdXJyZW50RWwpO1xuICAgIGlmIChjdXJyZW50SW5kZXggPT09IC0xKSByZXR1cm47XG5cbiAgICBjb25zdCBuZXh0SW5kZXggPSBpc0Fycm93RG93biA/IGN1cnJlbnRJbmRleCArIDEgOiBjdXJyZW50SW5kZXggLSAxO1xuICAgIGNvbnN0IG5leHRFbCA9IGdyb3VwQ2hlY2tib3hlc1tuZXh0SW5kZXhdO1xuXG4gICAgaWYgKG5leHRFbCkge1xuICAgICAgbmV4dEVsLmZvY3VzKCk7XG4gICAgfVxuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7XG4gICAgICBjaG9pY2VNb2RlLFxuICAgICAgZGlzYWJsZWQsXG4gICAgICBkaXNwbGF5S2V5LFxuICAgICAgZmVlZGJhY2ssXG4gICAgICBsYWJlbCxcbiAgICAgIGNvcnJlY3RuZXNzLFxuICAgICAgY2xhc3NOYW1lLFxuICAgICAgcmF0aW9uYWxlLFxuICAgICAgaGlkZVRpY2ssXG4gICAgICBpc0V2YWx1YXRlTW9kZSxcbiAgICAgIGNob2ljZXNMYXlvdXQsXG4gICAgICB2YWx1ZSxcbiAgICAgIGNoZWNrZWQsXG4gICAgICB0YWdOYW1lLFxuICAgICAgaXNTZWxlY3Rpb25CdXR0b25CZWxvdyxcbiAgICB9ID0gdGhpcy5wcm9wcztcblxuICAgIGNvbnN0IFRhZyA9IGNob2ljZU1vZGUgPT09ICdjaGVja2JveCcgPyBTdHlsZWRDaGVja2JveCA6IFN0eWxlZFJhZGlvO1xuICAgIGNvbnN0IGNsYXNzU3VmZml4ID0gY2hvaWNlTW9kZSA9PT0gJ2NoZWNrYm94JyA/ICdjaGVja2JveCcgOiAncmFkaW8tYnV0dG9uJztcblxuICAgIGNvbnN0IGhvbGRlclN4ID0ge1xuICAgICAgLi4uKGNob2ljZXNMYXlvdXQgPT09ICdob3Jpem9udGFsJyAmJiB7XG4gICAgICAgIFtgJiAuJHtDTEFTU19OQU1FfWBdOiB7XG4gICAgICAgICAgcGFkZGluZzogJzhweCcsXG4gICAgICAgICAgbWFyZ2luOiAnNHB4IDAgNHB4IDRweCcsXG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICAgIC4uLihpc1NlbGVjdGlvbkJ1dHRvbkJlbG93ICYmIGNob2ljZXNMYXlvdXQgIT09ICdncmlkJyAmJiB7XG4gICAgICAgICcmID4gbGFiZWwnOiB7XG4gICAgICAgICAgYWxpZ25JdGVtczogJ2ZsZXgtc3RhcnQnLFxuICAgICAgICB9LFxuICAgICAgfSksXG4gICAgICAuLi4oaXNTZWxlY3Rpb25CdXR0b25CZWxvdyAmJiBjaG9pY2VzTGF5b3V0ID09PSAnZ3JpZCcgJiYge1xuICAgICAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgICAgICcmID4gbGFiZWwnOiB7XG4gICAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgY2hvaWNlbGFiZWwgPSAoXG4gICAgICA8PlxuICAgICAgICB7ZGlzcGxheUtleSAmJiAhaXNTZWxlY3Rpb25CdXR0b25CZWxvdyA/IChcbiAgICAgICAgICA8Um93IGNvbXBvbmVudD1cInNwYW5cIj5cbiAgICAgICAgICAgIHtkaXNwbGF5S2V5fS57J1xcdTAwQTAnfVxuICAgICAgICAgICAgPFByZXZpZXdQcm9tcHQgY2xhc3NOYW1lPVwibGFiZWxcIiBwcm9tcHQ9e2xhYmVsfSB0YWdOYW1lPVwic3BhblwiIC8+XG4gICAgICAgICAgPC9Sb3c+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFByZXZpZXdQcm9tcHQgY2xhc3NOYW1lPVwibGFiZWxcIiBwcm9tcHQ9e2xhYmVsfSB0YWdOYW1lPVwic3BhblwiIC8+XG4gICAgICAgICl9XG4gICAgICA8Lz5cbiAgICApO1xuXG4gICAgY29uc3Qgc2NyZWVuUmVhZGVyTGFiZWwgPSAoXG4gICAgICA8U3JPbmx5IGlkPXt0aGlzLmRlc2NJZH0+XG4gICAgICAgIHtjaG9pY2VNb2RlID09PSAnY2hlY2tib3gnID8gJ0NoZWNrYm94IHRvIHNlbGVjdCB0aGUgYW5zd2VyIGJlbG93JyA6ICdSYWRpbyBidXR0b24gdG8gc2VsZWN0IHRoZSBhbnN3ZXIgYmVsb3cnfVxuICAgICAgPC9Tck9ubHk+XG4gICAgKTtcblxuICAgIGNvbnN0IHRhZ1Byb3BzID0ge1xuICAgICAgZGlzYWJsZWQsXG4gICAgICBjaGVja2VkLFxuICAgICAgY29ycmVjdG5lc3MsXG4gICAgICB0YWdOYW1lLFxuICAgICAgdmFsdWUsXG4gICAgICBpZDogdGhpcy5jaG9pY2VJZCxcbiAgICAgIG9uQ2hhbmdlOiB0aGlzLm9uVG9nZ2xlQ2hvaWNlLFxuICAgICAgb25LZXlEb3duOiB0aGlzLmhhbmRsZUtleURvd24sXG4gICAgICAnYXJpYS1kZXNjcmliZWRieSc6IHRoaXMuZGVzY0lkLFxuICAgIH07XG5cbiAgICBjb25zdCBoYXNNYXRoT3JJbWFnZSA9XG4gICAgICB0eXBlb2YgbGFiZWwgPT09ICdzdHJpbmcnICYmXG4gICAgICAobGFiZWwuaW5jbHVkZXMoJzxtYXRoJykgfHxcbiAgICAgICAgbGFiZWwuaW5jbHVkZXMoJ1xcXFwoJykgfHxcbiAgICAgICAgbGFiZWwuaW5jbHVkZXMoJ1xcXFxbJykgfHxcbiAgICAgICAgbGFiZWwuaW5jbHVkZXMoJzxpbWcnKSB8fFxuICAgICAgICBsYWJlbC5pbmNsdWRlcygnZGF0YS1sYXRleCcpIHx8XG4gICAgICAgIGxhYmVsLmluY2x1ZGVzKCdkYXRhLXJhdycpIHx8XG4gICAgICAgIGxhYmVsLmluY2x1ZGVzKCc8bWp4LWNvbnRhaW5lcicpKTtcblxuICAgIGNvbnN0IGNvbnRyb2wgPSBpc1NlbGVjdGlvbkJ1dHRvbkJlbG93ID8gKFxuICAgICAgPEJlbG93U2VsZWN0aW9uQ29tcG9uZW50PlxuICAgICAgICB7aGFzTWF0aE9ySW1hZ2UgJiYgc2NyZWVuUmVhZGVyTGFiZWx9XG4gICAgICAgIDxUYWcgey4uLnRhZ1Byb3BzfSBzdHlsZT17eyBwYWRkaW5nOiAwIH19IC8+XG4gICAgICAgIHtkaXNwbGF5S2V5ID8gYCR7ZGlzcGxheUtleX0uYCA6ICcnfVxuICAgICAgPC9CZWxvd1NlbGVjdGlvbkNvbXBvbmVudD5cbiAgICApIDogKFxuICAgICAgPD5cbiAgICAgICAge2hhc01hdGhPckltYWdlICYmIHNjcmVlblJlYWRlckxhYmVsfVxuICAgICAgICA8VGFnIHsuLi50YWdQcm9wc30gc2xvdFByb3BzPXt7IGlucHV0OiB7IHJlZjogdGhpcy5wcm9wcy5hdXRvRm9jdXNSZWYgfSB9fSAvPlxuICAgICAgPC8+XG4gICAgKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3NOYW1lcyhjbGFzc05hbWUsICdjb3Jlc3ByaW5nLScgKyBjbGFzc1N1ZmZpeCwgJ2Nob2ljZS1pbnB1dCcpfT5cbiAgICAgICAgPFJvdz5cbiAgICAgICAgICB7IWhpZGVUaWNrICYmIGlzRXZhbHVhdGVNb2RlICYmIDxGZWVkYmFja1RpY2sgY29ycmVjdG5lc3M9e2NvcnJlY3RuZXNzfSAvPn1cbiAgICAgICAgICA8Q2hlY2tib3hIb2xkZXIgY2xhc3NOYW1lPVwiY2hlY2tib3gtaG9sZGVyXCIgc3g9e2hvbGRlclN4fT5cbiAgICAgICAgICAgIDxTdHlsZWRGb3JtQ29udHJvbExhYmVsXG4gICAgICAgICAgICAgIGxhYmVsPXtjaG9pY2VsYWJlbH1cbiAgICAgICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgICAgICBodG1sRm9yPXt0aGlzLmNob2ljZUlkfVxuICAgICAgICAgICAgICBsYWJlbFBsYWNlbWVudD17aXNTZWxlY3Rpb25CdXR0b25CZWxvdyA/ICd0b3AnIDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgICBjb250cm9sPXtjb250cm9sfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L0NoZWNrYm94SG9sZGVyPlxuICAgICAgICA8L1Jvdz5cbiAgICAgICAge3JhdGlvbmFsZSAmJiA8UHJldmlld1Byb21wdCBjbGFzc05hbWU9XCJyYXRpb25hbGVcIiBkZWZhdWx0Q2xhc3NOYW1lPVwicmF0aW9uYWxlXCIgcHJvbXB0PXtyYXRpb25hbGV9IC8+fVxuICAgICAgICA8RmVlZGJhY2sgZmVlZGJhY2s9e2ZlZWRiYWNrfSBjb3JyZWN0bmVzcz17Y29ycmVjdG5lc3N9IC8+XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IENob2ljZUlucHV0O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSxJQUFBQSxpQkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsTUFBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUUsVUFBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUcsT0FBQSxHQUFBSCxPQUFBO0FBQ0EsSUFBQUksSUFBQSxHQUFBTCxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUssU0FBQSxHQUFBTixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQU0sU0FBQSxHQUFBTixPQUFBO0FBQ0EsSUFBQU8sTUFBQSxHQUFBUixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQVEsV0FBQSxHQUFBVCxzQkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQVMsYUFBQSxHQUFBVixzQkFBQSxDQUFBQyxPQUFB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M0gsTUFBQSxDQUFBeUUsT0FBQSxDQUFBQyxhQUFBLENBQUNyRSxTQUFBLENBQUFvSixRQUFRO01BQUNoQyxRQUFRLEVBQUVBLFFBQVM7TUFBQy9FLFdBQVcsRUFBRUE7SUFBWSxDQUFFLENBQ3RELENBQUM7RUFFVjtBQUNGO0FBQUNSLE9BQUEsQ0FBQW9ELFdBQUEsR0FBQUEsV0FBQTtBQUFBLElBQUFJLGdCQUFBLENBQUFqQixPQUFBLEVBM0xZYSxXQUFXLGVBQ0g7RUFDakJNLFVBQVUsRUFBRThELGtCQUFTLENBQUNDLEtBQUssQ0FBQyxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQztFQUNsRG5DLFVBQVUsRUFBRWtDLGtCQUFTLENBQUNFLE1BQU07RUFDNUIxRixPQUFPLEVBQUV3RixrQkFBUyxDQUFDRyxJQUFJLENBQUNDLFVBQVU7RUFDbENwSCxXQUFXLEVBQUVnSCxrQkFBUyxDQUFDRSxNQUFNO0VBQzdCM0csUUFBUSxFQUFFeUcsa0JBQVMsQ0FBQ0csSUFBSSxDQUFDQyxVQUFVO0VBQ25DckMsUUFBUSxFQUFFaUMsa0JBQVMsQ0FBQ0UsTUFBTTtFQUMxQmxDLEtBQUssRUFBRWdDLGtCQUFTLENBQUNFLE1BQU0sQ0FBQ0UsVUFBVTtFQUNsQ25DLFNBQVMsRUFBRStCLGtCQUFTLENBQUNFLE1BQU07RUFDM0J6RixRQUFRLEVBQUV1RixrQkFBUyxDQUFDSyxJQUFJLENBQUNELFVBQVU7RUFDbkMxRixLQUFLLEVBQUVzRixrQkFBUyxDQUFDRSxNQUFNLENBQUNFLFVBQVU7RUFDbEM5RSxTQUFTLEVBQUUwRSxrQkFBUyxDQUFDRSxNQUFNO0VBQzNCeEUsT0FBTyxFQUFFc0Usa0JBQVMsQ0FBQ0UsTUFBTTtFQUN6QmhDLFFBQVEsRUFBRThCLGtCQUFTLENBQUNHLElBQUk7RUFDeEJoQyxjQUFjLEVBQUU2QixrQkFBUyxDQUFDRyxJQUFJO0VBQzlCL0IsYUFBYSxFQUFFNEIsa0JBQVMsQ0FBQ0MsS0FBSyxDQUFDLENBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRSxZQUFZLENBQUMsQ0FBQztFQUNsRTVCLHNCQUFzQixFQUFFMkIsa0JBQVMsQ0FBQ0c7QUFDcEMsQ0FBQztBQUFBLElBQUFuRSxnQkFBQSxDQUFBakIsT0FBQSxFQWxCVWEsV0FBVyxrQkFvQkE7RUFDcEJxQyxTQUFTLEVBQUUsSUFBSTtFQUNmekQsT0FBTyxFQUFFLEtBQUs7RUFDZDJELGNBQWMsRUFBRTtBQUNsQixDQUFDO0FBQUEsSUFBQW1DLFFBQUEsR0FBQTlILE9BQUEsQ0FBQXVDLE9BQUEsR0FxS1lhLFdBQVciLCJpZ25vcmVMaXN0IjpbXX0=