@pie-lib/rubric 1.0.0-beta.5 → 1.1.0-next.0

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/lib/authoring.js CHANGED
@@ -8,38 +8,37 @@ exports["default"] = exports.RubricType = exports.RawAuthoring = exports.PointCo
8
8
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
9
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
10
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
11
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
12
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
13
11
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
14
12
  var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
13
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
15
14
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
15
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
16
  var _react = _interopRequireDefault(require("react"));
18
17
  var _propTypes = _interopRequireDefault(require("prop-types"));
19
- var _styles = require("@material-ui/core/styles");
20
- var _classnames = _interopRequireDefault(require("classnames"));
21
- var _OutlinedInput = _interopRequireDefault(require("@material-ui/core/OutlinedInput"));
22
- var _InputLabel = _interopRequireDefault(require("@material-ui/core/InputLabel"));
23
- var _Select = _interopRequireDefault(require("@material-ui/core/Select"));
24
- var _FormControl = _interopRequireDefault(require("@material-ui/core/FormControl"));
25
- var _MenuItem = _interopRequireDefault(require("@material-ui/core/MenuItem"));
18
+ var _styles = require("@mui/material/styles");
19
+ var _InputLabel = _interopRequireDefault(require("@mui/material/InputLabel"));
20
+ var _OutlinedInput = _interopRequireDefault(require("@mui/material/OutlinedInput"));
21
+ var _Select = _interopRequireDefault(require("@mui/material/Select"));
22
+ var _FormControl = _interopRequireDefault(require("@mui/material/FormControl"));
23
+ var _MenuItem = _interopRequireDefault(require("@mui/material/MenuItem"));
26
24
  var _times = _interopRequireDefault(require("lodash/times"));
27
- var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
28
- var _FormGroup = _interopRequireDefault(require("@material-ui/core/FormGroup"));
29
- var _FormControlLabel = _interopRequireDefault(require("@material-ui/core/FormControlLabel"));
30
- var _grey = _interopRequireDefault(require("@material-ui/core/colors/grey"));
31
- var _Typography = _interopRequireDefault(require("@material-ui/core/Typography"));
32
- var _DragIndicator = _interopRequireDefault(require("@material-ui/icons/DragIndicator"));
33
- var _editableHtml = _interopRequireDefault(require("@pie-lib/editable-html"));
34
- var _reactBeautifulDnd = require("react-beautiful-dnd");
25
+ var _Checkbox = _interopRequireDefault(require("@mui/material/Checkbox"));
26
+ var _FormGroup = _interopRequireDefault(require("@mui/material/FormGroup"));
27
+ var _FormControlLabel = _interopRequireDefault(require("@mui/material/FormControlLabel"));
28
+ var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
29
+ var _DragIndicator = _interopRequireDefault(require("@mui/icons-material/DragIndicator"));
30
+ var _dnd = require("@hello-pangea/dnd");
35
31
  var _debug = _interopRequireDefault(require("debug"));
36
32
  var _takeRight = _interopRequireDefault(require("lodash/takeRight"));
37
33
  var _pointMenu = _interopRequireDefault(require("./point-menu"));
38
34
  var _range = _interopRequireDefault(require("lodash/range"));
39
- 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; }
40
- 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; }
41
- 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); }; }
42
- 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; } }
35
+ var _editableHtmlTipTap = _interopRequireDefault(require("@pie-lib/editable-html-tip-tap"));
36
+ var _configUi = require("@pie-lib/config-ui");
37
+ var _colors = require("@mui/material/colors");
38
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
39
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
40
+ function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
41
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
43
42
  var log = (0, _debug["default"])('pie-lib:rubric:authoring');
44
43
  var reorder = function reorder(list, startIndex, endIndex) {
45
44
  var result = Array.from(list);
@@ -49,134 +48,187 @@ var reorder = function reorder(list, startIndex, endIndex) {
49
48
  result.splice(endIndex, 0, removed);
50
49
  return result;
51
50
  };
52
- var RubricType = _propTypes["default"].shape({
51
+ var RubricType = exports.RubricType = _propTypes["default"].shape({
53
52
  excludeZero: _propTypes["default"].bool,
54
53
  points: _propTypes["default"].arrayOf(_propTypes["default"].string),
55
54
  sampleAnswers: _propTypes["default"].arrayOf(_propTypes["default"].string),
56
- maxPoints: _propTypes["default"].number
55
+ maxPoints: _propTypes["default"].number,
56
+ rubriclessInstruction: _propTypes["default"].string
57
57
  });
58
- exports.RubricType = RubricType;
59
- var MaxPoints = (0, _styles.withStyles)(function (theme) {
60
- return {
61
- formControl: {
62
- minWidth: '120px',
63
- margin: theme.spacing.unit
64
- }
65
- };
66
- })(function (props) {
58
+ var MaxPoints = function MaxPoints(props) {
67
59
  var value = props.value,
68
60
  _onChange = props.onChange,
69
- max = props.max,
70
- classes = props.classes;
61
+ max = props.max;
62
+ var labelId = 'max-points-label';
71
63
  return /*#__PURE__*/_react["default"].createElement(_FormControl["default"], {
72
- className: classes.formControl,
64
+ sx: {
65
+ minWidth: 120,
66
+ m: 1
67
+ },
73
68
  variant: "outlined"
74
69
  }, /*#__PURE__*/_react["default"].createElement(_InputLabel["default"], {
75
- width: 100,
76
- htmlFor: "..."
70
+ id: labelId
77
71
  }, "Max Points"), /*#__PURE__*/_react["default"].createElement(_Select["default"], {
72
+ labelId: labelId,
73
+ label: "Max Points",
78
74
  value: value,
79
75
  onChange: function onChange(e) {
80
76
  return _onChange(e.target.value);
81
77
  },
82
78
  input: /*#__PURE__*/_react["default"].createElement(_OutlinedInput["default"], {
83
- labelWidth: 80
84
- })
85
- }, (0, _range["default"])(1, max).map(function (v) {
79
+ label: "Max Points"
80
+ }),
81
+ MenuProps: {
82
+ transitionDuration: {
83
+ enter: 225,
84
+ exit: 195
85
+ }
86
+ }
87
+ }, (0, _range["default"])(1, max + 1).map(function (v) {
86
88
  return /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
87
89
  key: "".concat(v),
88
90
  value: v
89
91
  }, v);
90
92
  })));
91
- });
93
+ };
92
94
 
93
95
  // if the value is null or 'null', the Sample Answer input field for that point will not be dispalyed
94
96
  // if the value is '', the Sample Answer input field will be empty
95
97
  var checkSampleAnswer = function checkSampleAnswer(sampleAnswer) {
96
98
  return sampleAnswer === null || sampleAnswer === 'null';
97
99
  };
98
- var PointConfig = (0, _styles.withStyles)(function (theme) {
100
+ var Row = (0, _styles.styled)('div')(function () {
99
101
  return {
100
- pointConfig: {},
101
- row: {
102
- display: 'flex',
103
- width: '100%',
104
- position: 'relative'
105
- },
106
- editor: {
107
- width: '100%',
108
- backgroundColor: "".concat(theme.palette.common.white, " !important")
109
- },
110
- dragIndicator: {
111
- paddingTop: theme.spacing.unit,
112
- color: _grey["default"][500]
113
- },
114
- pointsLabel: {
115
- color: _grey["default"][500],
116
- paddingBottom: theme.spacing.unit,
117
- textTransform: 'uppercase'
118
- },
119
- sampleAnswersEditor: {
120
- paddingLeft: theme.spacing.unit * 3
121
- },
122
- pointMenu: {
123
- position: 'absolute',
124
- right: 0
125
- }
102
+ display: 'flex',
103
+ width: '100%',
104
+ position: 'relative'
105
+ };
106
+ });
107
+ var EditorDiv = (0, _styles.styled)('div')(function (_ref) {
108
+ var theme = _ref.theme;
109
+ return {
110
+ width: '100%',
111
+ backgroundColor: "".concat(theme.palette.common.white)
112
+ };
113
+ });
114
+ var DragIndicatorStyled = (0, _styles.styled)(_DragIndicator["default"])(function (_ref2) {
115
+ var theme = _ref2.theme;
116
+ return {
117
+ paddingTop: theme.spacing(1),
118
+ color: _colors.grey[500]
119
+ };
120
+ });
121
+ var PointsLabel = (0, _styles.styled)(_Typography["default"])(function (_ref3) {
122
+ var theme = _ref3.theme;
123
+ return {
124
+ color: _colors.grey[500],
125
+ paddingBottom: theme.spacing(1),
126
+ textTransform: 'uppercase'
127
+ };
128
+ });
129
+ var SampleAnswersEditor = (0, _styles.styled)('div')(function (_ref4) {
130
+ var theme = _ref4.theme;
131
+ return {
132
+ paddingLeft: theme.spacing(3)
133
+ };
134
+ });
135
+ var ErrorText = (0, _styles.styled)('div')(function (_ref5) {
136
+ var theme = _ref5.theme;
137
+ return {
138
+ fontSize: theme.typography.fontSize - 2,
139
+ color: theme.palette.error.main,
140
+ paddingLeft: theme.spacing(3),
141
+ paddingTop: theme.spacing(1)
126
142
  };
127
- })(function (props) {
143
+ });
144
+ var PointMenuWrapper = (0, _styles.styled)('div')(function () {
145
+ return {
146
+ position: 'absolute',
147
+ right: 0
148
+ };
149
+ });
150
+ var PointConfig = exports.PointConfig = function PointConfig(props) {
128
151
  var points = props.points,
129
152
  content = props.content,
130
- classes = props.classes,
131
153
  sampleAnswer = props.sampleAnswer,
132
154
  _props$mathMlOptions = props.mathMlOptions,
133
- mathMlOptions = _props$mathMlOptions === void 0 ? {} : _props$mathMlOptions;
155
+ mathMlOptions = _props$mathMlOptions === void 0 ? {} : _props$mathMlOptions,
156
+ error = props.error,
157
+ _props$pluginOpts = props.pluginOpts,
158
+ pluginOpts = _props$pluginOpts === void 0 ? {} : _props$pluginOpts;
134
159
  var pointsLabel = "".concat(points, " ").concat(points <= 1 ? 'pt' : 'pts');
135
160
  var showSampleAnswer = checkSampleAnswer(sampleAnswer);
136
- return /*#__PURE__*/_react["default"].createElement("div", {
137
- className: classes.pointConfig
138
- }, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
139
- variant: "overline",
140
- className: classes.pointsLabel
141
- }, pointsLabel), /*#__PURE__*/_react["default"].createElement("div", {
142
- className: classes.row
143
- }, /*#__PURE__*/_react["default"].createElement(_DragIndicator["default"], {
144
- className: classes.dragIndicator
145
- }), /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
146
- className: classes.editor,
161
+ return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(PointsLabel, {
162
+ variant: "overline"
163
+ }, pointsLabel), /*#__PURE__*/_react["default"].createElement(Row, null, /*#__PURE__*/_react["default"].createElement(DragIndicatorStyled, null), /*#__PURE__*/_react["default"].createElement(EditorDiv, null, /*#__PURE__*/_react["default"].createElement(_editableHtmlTipTap["default"], {
164
+ error: error,
165
+ pluginProps: pluginOpts,
147
166
  markup: content,
148
167
  onChange: props.onChange,
149
168
  mathMlOptions: mathMlOptions
150
- }), /*#__PURE__*/_react["default"].createElement(_pointMenu["default"], {
151
- classes: {
152
- icon: classes.pointMenu
153
- },
169
+ })), /*#__PURE__*/_react["default"].createElement(PointMenuWrapper, null, /*#__PURE__*/_react["default"].createElement(_pointMenu["default"], {
154
170
  showSampleAnswer: showSampleAnswer,
155
171
  onChange: props.onMenuChange
156
- })), !showSampleAnswer && /*#__PURE__*/_react["default"].createElement("div", {
157
- className: classes.sampleAnswersEditor
158
- }, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
159
- variant: "overline",
160
- className: classes.dragIndicator
161
- }, "Sample Response"), /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
162
- className: classes.editor,
172
+ }))), error && /*#__PURE__*/_react["default"].createElement(ErrorText, null, error), !showSampleAnswer && /*#__PURE__*/_react["default"].createElement(SampleAnswersEditor, null, /*#__PURE__*/_react["default"].createElement(DragIndicatorStyled, {
173
+ as: _Typography["default"],
174
+ variant: "overline"
175
+ }, "Sample Response"), /*#__PURE__*/_react["default"].createElement(EditorDiv, null, /*#__PURE__*/_react["default"].createElement(_editableHtmlTipTap["default"], {
163
176
  markup: sampleAnswer,
177
+ pluginProps: pluginOpts,
164
178
  onChange: props.onSampleChange,
165
179
  mathMlOptions: mathMlOptions
166
- })));
180
+ }))));
181
+ };
182
+ var Container = (0, _styles.styled)('div')(function (_ref6) {
183
+ var theme = _ref6.theme;
184
+ return {
185
+ backgroundColor: _colors.grey[200],
186
+ borderWidth: 1,
187
+ borderStyle: 'solid',
188
+ borderColor: _colors.grey[300],
189
+ padding: theme.spacing(2),
190
+ margin: theme.spacing(1)
191
+ };
167
192
  });
168
- exports.PointConfig = PointConfig;
169
- var RawAuthoring = /*#__PURE__*/function (_React$Component) {
170
- (0, _inherits2["default"])(RawAuthoring, _React$Component);
171
- var _super = _createSuper(RawAuthoring);
193
+ var InputContainerWrapper = (0, _styles.styled)('div')(function (_ref7) {
194
+ var theme = _ref7.theme;
195
+ return {
196
+ width: '100%',
197
+ paddingTop: theme.spacing(2),
198
+ marginBottom: theme.spacing(2),
199
+ '& MuiFormControl-root': {
200
+ width: '100%'
201
+ }
202
+ };
203
+ });
204
+ var Rubricless = (0, _styles.styled)('div')(function () {
205
+ return {
206
+ display: 'none'
207
+ };
208
+ });
209
+ var ConfigHolder = (0, _styles.styled)('div')(function (_ref8) {
210
+ var theme = _ref8.theme;
211
+ return {
212
+ paddingTop: theme.spacing(1),
213
+ paddingBottom: theme.spacing(1)
214
+ };
215
+ });
216
+ var RubricTitle = (0, _styles.styled)(_Typography["default"])(function (_ref9) {
217
+ var theme = _ref9.theme;
218
+ return {
219
+ paddingLeft: theme.spacing(1),
220
+ margin: theme.spacing(1)
221
+ };
222
+ });
223
+ var RawAuthoring = exports.RawAuthoring = /*#__PURE__*/function (_React$Component) {
172
224
  function RawAuthoring() {
173
225
  var _this;
174
226
  (0, _classCallCheck2["default"])(this, RawAuthoring);
175
227
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
176
228
  args[_key] = arguments[_key];
177
229
  }
178
- _this = _super.call.apply(_super, [this].concat(args));
179
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "dragEnd", function (result) {
230
+ _this = _callSuper(this, RawAuthoring, [].concat(args));
231
+ (0, _defineProperty2["default"])(_this, "dragEnd", function (result) {
180
232
  if (!result.destination) {
181
233
  return;
182
234
  }
@@ -190,10 +242,19 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
190
242
  sampleAnswers: sampleAnswers
191
243
  }));
192
244
  });
193
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeMaxPoints", function (maxPoints) {
245
+ (0, _defineProperty2["default"])(_this, "changeRubriclessInstruction", function (input) {
194
246
  var _this$props2 = _this.props,
195
247
  value = _this$props2.value,
196
248
  onChange = _this$props2.onChange;
249
+ onChange(_objectSpread(_objectSpread({}, value), {}, {
250
+ rubriclessInstruction: input
251
+ }));
252
+ });
253
+ (0, _defineProperty2["default"])(_this, "changeMaxPoints", function (maxPoints) {
254
+ var _this$props3 = _this.props,
255
+ value = _this$props3.value,
256
+ onChange = _this$props3.onChange,
257
+ rubricless = _this$props3.rubricless;
197
258
  var currentMax = value.points.length - 1;
198
259
  log('current', currentMax, 'new: ', maxPoints);
199
260
  var points, sampleAnswers;
@@ -210,36 +271,41 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
210
271
  points = (0, _takeRight["default"])(value.points, maxPoints + 1);
211
272
  sampleAnswers = (0, _takeRight["default"])(value.sampleAnswers, maxPoints + 1);
212
273
  }
213
- if (points) {
274
+ if (points && !rubricless) {
214
275
  onChange(_objectSpread(_objectSpread({}, value), {}, {
215
276
  points: points,
216
- sampleAnswers: sampleAnswers
277
+ sampleAnswers: sampleAnswers,
278
+ maxPoints: maxPoints
279
+ }));
280
+ } else {
281
+ onChange(_objectSpread(_objectSpread({}, value), {}, {
282
+ maxPoints: maxPoints
217
283
  }));
218
284
  }
219
285
  });
220
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeContent", function (index, content, type) {
286
+ (0, _defineProperty2["default"])(_this, "changeContent", function (index, content, type) {
221
287
  // type could be 'points' or 'sampleAnswers'
222
288
  log("changeModel[".concat(type, "]:"), index, content);
223
289
  if (type !== 'points' && type !== 'sampleAnswers') {
224
290
  return;
225
291
  }
226
- var _this$props3 = _this.props,
227
- value = _this$props3.value,
228
- onChange = _this$props3.onChange;
292
+ var _this$props4 = _this.props,
293
+ value = _this$props4.value,
294
+ onChange = _this$props4.onChange;
229
295
  var items = value[type] && Array.from(value[type]);
230
296
  items.splice(index, 1, content);
231
297
  log("changeModel[".concat(type, "]:"), items);
232
298
  onChange(_objectSpread(_objectSpread({}, value), {}, (0, _defineProperty2["default"])({}, type, items)));
233
299
  });
234
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "excludeZeros", function () {
235
- var _this$props4 = _this.props,
236
- value = _this$props4.value,
237
- onChange = _this$props4.onChange;
300
+ (0, _defineProperty2["default"])(_this, "excludeZeros", function () {
301
+ var _this$props5 = _this.props,
302
+ value = _this$props5.value,
303
+ onChange = _this$props5.onChange;
238
304
  onChange(_objectSpread(_objectSpread({}, value), {}, {
239
305
  excludeZero: !value.excludeZero
240
306
  }));
241
307
  });
242
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "shouldRenderPoint", function (index, value) {
308
+ (0, _defineProperty2["default"])(_this, "shouldRenderPoint", function (index, value) {
243
309
  if (!value.excludeZero) {
244
310
  return true;
245
311
  } else {
@@ -251,7 +317,7 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
251
317
  return true;
252
318
  }
253
319
  });
254
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onPointMenuChange", function (index, clickedItem) {
320
+ (0, _defineProperty2["default"])(_this, "onPointMenuChange", function (index, clickedItem) {
255
321
  if (clickedItem === 'sample') {
256
322
  var value = _this.props.value;
257
323
  var sampleAnswers = Array.from(value.sampleAnswers || []);
@@ -266,63 +332,95 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
266
332
  });
267
333
  return _this;
268
334
  }
269
- (0, _createClass2["default"])(RawAuthoring, [{
335
+ (0, _inherits2["default"])(RawAuthoring, _React$Component);
336
+ return (0, _createClass2["default"])(RawAuthoring, [{
270
337
  key: "render",
271
338
  value: function render() {
272
339
  var _this2 = this;
273
- var _this$props5 = this.props,
274
- classes = _this$props5.classes,
275
- className = _this$props5.className,
276
- value = _this$props5.value,
277
- _this$props5$mathMlOp = _this$props5.mathMlOptions,
278
- mathMlOptions = _this$props5$mathMlOp === void 0 ? {} : _this$props5$mathMlOp;
279
- var _ref = value || {},
280
- _ref$excludeZeroEnabl = _ref.excludeZeroEnabled,
281
- excludeZeroEnabled = _ref$excludeZeroEnabl === void 0 ? true : _ref$excludeZeroEnabl,
282
- _ref$maxPointsEnabled = _ref.maxPointsEnabled,
283
- maxPointsEnabled = _ref$maxPointsEnabled === void 0 ? true : _ref$maxPointsEnabled;
340
+ var _this$props6 = this.props,
341
+ value = _this$props6.value,
342
+ _this$props6$mathMlOp = _this$props6.mathMlOptions,
343
+ mathMlOptions = _this$props6$mathMlOp === void 0 ? {} : _this$props6$mathMlOp,
344
+ _this$props6$config = _this$props6.config,
345
+ config = _this$props6$config === void 0 ? {} : _this$props6$config,
346
+ _this$props6$rubricle = _this$props6.rubricless,
347
+ rubricless = _this$props6$rubricle === void 0 ? false : _this$props6$rubricle,
348
+ _this$props6$pluginOp = _this$props6.pluginOpts,
349
+ pluginOpts = _this$props6$pluginOp === void 0 ? {} : _this$props6$pluginOp;
350
+ var _ref0 = value || {},
351
+ _ref0$excludeZeroEnab = _ref0.excludeZeroEnabled,
352
+ excludeZeroEnabled = _ref0$excludeZeroEnab === void 0 ? true : _ref0$excludeZeroEnab,
353
+ _ref0$maxPointsEnable = _ref0.maxPointsEnabled,
354
+ maxPointsEnabled = _ref0$maxPointsEnable === void 0 ? true : _ref0$maxPointsEnable,
355
+ _ref0$errors = _ref0.errors,
356
+ errors = _ref0$errors === void 0 ? {} : _ref0$errors,
357
+ _ref0$rubriclessInstr = _ref0.rubriclessInstructionEnabled,
358
+ rubriclessInstructionEnabled = _ref0$rubriclessInstr === void 0 ? false : _ref0$rubriclessInstr,
359
+ _ref0$maxPoints = _ref0.maxPoints,
360
+ maxPoints = _ref0$maxPoints === void 0 ? 10 : _ref0$maxPoints;
361
+ // rubric will contain a max value for maxPoints
362
+ var _ref1 = config || {},
363
+ _ref1$rubriclessInstr = _ref1.rubriclessInstruction,
364
+ rubriclessInstruction = _ref1$rubriclessInstr === void 0 ? {} : _ref1$rubriclessInstr,
365
+ _ref1$maxMaxPoints = _ref1.maxMaxPoints,
366
+ maxMaxPoints = _ref1$maxMaxPoints === void 0 ? 10 : _ref1$maxMaxPoints;
367
+ var _ref10 = errors || {},
368
+ pointsDescriptorsErrors = _ref10.pointsDescriptorsErrors;
284
369
  if (value && Number.isFinite(value.maxPoints)) {
285
370
  // eslint-disable-next-line no-console
286
371
  console.warn('maxPoints is deprecated - remove from model');
287
372
  }
288
- return /*#__PURE__*/_react["default"].createElement("div", {
289
- className: (0, _classnames["default"])(classes["class"], className)
290
- }, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
291
- variant: "h5",
292
- className: classes.rubricTitle
373
+
374
+ // for rubric value is computed based on points
375
+ var maxPointsValue = !rubricless ? value.points.length - 1 : maxPoints;
376
+ return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(RubricTitle, {
377
+ variant: "h5"
293
378
  }, "Rubric"), /*#__PURE__*/_react["default"].createElement(_FormGroup["default"], {
294
379
  row: true
295
380
  }, maxPointsEnabled && /*#__PURE__*/_react["default"].createElement(MaxPoints, {
296
- max: 10,
297
- value: value.points.length - 1,
298
- onChange: this.changeMaxPoints
381
+ max: maxMaxPoints < 100 ? maxMaxPoints : 100,
382
+ value: maxPointsValue,
383
+ onChange: this.changeMaxPoints,
384
+ pluginOpts: pluginOpts
299
385
  }), excludeZeroEnabled && /*#__PURE__*/_react["default"].createElement(_FormControlLabel["default"], {
300
386
  label: "Exclude zeros",
301
387
  control: /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
302
388
  checked: value.excludeZero,
303
389
  onChange: this.excludeZeros
304
390
  })
305
- })), /*#__PURE__*/_react["default"].createElement("div", {
306
- className: classes.container
307
- }, /*#__PURE__*/_react["default"].createElement(_reactBeautifulDnd.DragDropContext, {
391
+ })), rubriclessInstructionEnabled && rubricless && /*#__PURE__*/_react["default"].createElement(InputContainerWrapper, null, /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
392
+ label: rubriclessInstruction.label
393
+ }, /*#__PURE__*/_react["default"].createElement(_editableHtmlTipTap["default"], {
394
+ markup: value.rubriclessInstruction || '',
395
+ onChange: this.changeRubriclessInstruction,
396
+ pluginProps: pluginOpts,
397
+ nonEmpty: false,
398
+ disableUnderline: true,
399
+ languageCharactersProps: [{
400
+ language: 'spanish'
401
+ }, {
402
+ language: 'special'
403
+ }],
404
+ mathMlOptions: mathMlOptions
405
+ }))), /*#__PURE__*/_react["default"].createElement("div", null, rubricless ? /*#__PURE__*/_react["default"].createElement(Rubricless, null) : /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(_dnd.DragDropContext, {
308
406
  onDragEnd: this.dragEnd
309
- }, /*#__PURE__*/_react["default"].createElement(_reactBeautifulDnd.Droppable, {
407
+ }, /*#__PURE__*/_react["default"].createElement(_dnd.Droppable, {
310
408
  droppableId: "droppable"
311
409
  }, function (provided) {
312
410
  return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({}, provided.droppableProps, {
313
411
  ref: provided.innerRef
314
412
  }), value.points.map(function (p, index) {
315
- return _this2.shouldRenderPoint(index, value) && /*#__PURE__*/_react["default"].createElement(_reactBeautifulDnd.Draggable, {
413
+ return _this2.shouldRenderPoint(index, value) && /*#__PURE__*/_react["default"].createElement(_dnd.Draggable, {
316
414
  key: "".concat(p.points, "-").concat(index),
317
415
  index: index,
318
416
  draggableId: index.toString()
319
417
  }, function (provided) {
320
- return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
321
- className: classes.configHolder,
418
+ return /*#__PURE__*/_react["default"].createElement(ConfigHolder, (0, _extends2["default"])({
322
419
  ref: provided.innerRef
323
420
  }, provided.draggableProps, provided.dragHandleProps), /*#__PURE__*/_react["default"].createElement(PointConfig, {
324
421
  points: value.points.length - 1 - index,
325
422
  content: p,
423
+ error: pointsDescriptorsErrors && pointsDescriptorsErrors[value.points.length - 1 - index],
326
424
  sampleAnswer: value.sampleAnswers && value.sampleAnswers[index],
327
425
  onChange: function onChange(content) {
328
426
  return _this2.changeContent(index, content, 'points');
@@ -333,45 +431,31 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
333
431
  onMenuChange: function onMenuChange(clickedItem) {
334
432
  return _this2.onPointMenuChange(index, clickedItem);
335
433
  },
336
- mathMlOptions: mathMlOptions
434
+ mathMlOptions: mathMlOptions,
435
+ pluginOpts: pluginOpts
337
436
  }));
338
437
  });
339
438
  }), provided.placeholder);
340
- }))));
439
+ })))));
341
440
  }
342
441
  }]);
343
- return RawAuthoring;
344
- }(_react["default"].Component);
345
- exports.RawAuthoring = RawAuthoring;
442
+ }(_react["default"].Component); // styles migrated to styled-components above
346
443
  (0, _defineProperty2["default"])(RawAuthoring, "propTypes", {
347
- classes: _propTypes["default"].object.isRequired,
348
- className: _propTypes["default"].string,
349
444
  value: RubricType,
445
+ config: _propTypes["default"].object,
446
+ pluginOpts: _propTypes["default"].object,
447
+ rubricless: _propTypes["default"].bool,
350
448
  onChange: _propTypes["default"].func
351
449
  });
352
450
  (0, _defineProperty2["default"])(RawAuthoring, "defaultProps", {});
353
- var styles = function styles(theme) {
354
- return {
355
- container: {
356
- backgroundColor: _grey["default"][200],
357
- borderWidth: 1,
358
- borderStyle: 'solid',
359
- borderColor: _grey["default"][300],
360
- padding: theme.spacing.unit * 2,
361
- margin: theme.spacing.unit
362
- },
363
- configHolder: {
364
- paddingTop: theme.spacing.unit,
365
- paddingBottom: theme.spacing.unit
366
- },
367
- rubricTitle: {
368
- paddingLeft: theme.spacing.unit,
369
- margin: theme.spacing.unit
370
- }
371
- };
372
- };
373
- var StyledRawAuthoring = (0, _styles.withStyles)(styles)(RawAuthoring);
374
451
  var Reverse = function Reverse(props) {
452
+ var _ref11 = props || {},
453
+ _ref11$rubricless = _ref11.rubricless,
454
+ rubricless = _ref11$rubricless === void 0 ? false : _ref11$rubricless,
455
+ _ref11$config = _ref11.config,
456
+ config = _ref11$config === void 0 ? {} : _ref11$config,
457
+ _ref11$pluginOpts = _ref11.pluginOpts,
458
+ pluginOpts = _ref11$pluginOpts === void 0 ? {} : _ref11$pluginOpts;
375
459
  var points = Array.from(props.value.points || []).reverse();
376
460
  var sampleAnswers = Array.from(props.value.sampleAnswers || []).reverse();
377
461
  if (points.length > sampleAnswers.length) {
@@ -389,16 +473,21 @@ var Reverse = function Reverse(props) {
389
473
  sampleAnswers: Array.from(value.sampleAnswers || []).reverse()
390
474
  }));
391
475
  };
392
- return /*#__PURE__*/_react["default"].createElement(StyledRawAuthoring, {
476
+ return /*#__PURE__*/_react["default"].createElement(RawAuthoring, {
393
477
  value: value,
394
- onChange: onChange
478
+ config: config,
479
+ onChange: onChange,
480
+ rubricless: rubricless,
481
+ pluginOpts: pluginOpts
395
482
  });
396
483
  };
397
484
  Reverse.propTypes = {
398
485
  value: RubricType,
486
+ config: _propTypes["default"].object,
487
+ pluginOpts: _propTypes["default"].object,
488
+ rubricless: _propTypes["default"].bool,
399
489
  getIndex: _propTypes["default"].func,
400
490
  onChange: _propTypes["default"].func
401
491
  };
402
- var _default = Reverse;
403
- exports["default"] = _default;
404
- //# sourceMappingURL=authoring.js.map
492
+ var _default = exports["default"] = Reverse;
493
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_styles","_InputLabel","_OutlinedInput","_Select","_FormControl","_MenuItem","_times","_Checkbox","_FormGroup","_FormControlLabel","_Typography","_DragIndicator","_dnd","_debug","_takeRight","_pointMenu","_range","_editableHtmlTipTap","_configUi","_colors","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","log","debug","reorder","list","startIndex","endIndex","result","Array","from","_result$splice","splice","_result$splice2","_slicedToArray2","removed","RubricType","exports","PropTypes","shape","excludeZero","bool","points","arrayOf","string","sampleAnswers","maxPoints","number","rubriclessInstruction","MaxPoints","props","value","onChange","max","labelId","createElement","sx","minWidth","m","variant","id","label","target","input","MenuProps","transitionDuration","enter","exit","range","map","v","key","concat","checkSampleAnswer","sampleAnswer","Row","styled","display","width","position","EditorDiv","_ref","theme","backgroundColor","palette","common","white","DragIndicatorStyled","DragIndicator","_ref2","paddingTop","spacing","color","grey","PointsLabel","Typography","_ref3","paddingBottom","textTransform","SampleAnswersEditor","_ref4","paddingLeft","ErrorText","_ref5","fontSize","typography","error","main","PointMenuWrapper","right","PointConfig","content","_props$mathMlOptions","mathMlOptions","_props$pluginOpts","pluginOpts","pointsLabel","showSampleAnswer","pluginProps","markup","onMenuChange","as","onSampleChange","Container","_ref6","borderWidth","borderStyle","borderColor","padding","margin","InputContainerWrapper","_ref7","marginBottom","Rubricless","ConfigHolder","_ref8","RubricTitle","_ref9","RawAuthoring","_React$Component","_this","_classCallCheck2","_len","args","_key","destination","_this$props","source","index","_this$props2","_this$props3","rubricless","currentMax","times","takeRight","type","_this$props4","items","_this$props5","clickedItem","changeContent","_inherits2","_createClass2","render","_this2","_this$props6","_this$props6$mathMlOp","_this$props6$config","config","_this$props6$rubricle","_this$props6$pluginOp","_ref0","_ref0$excludeZeroEnab","excludeZeroEnabled","_ref0$maxPointsEnable","maxPointsEnabled","_ref0$errors","errors","_ref0$rubriclessInstr","rubriclessInstructionEnabled","_ref0$maxPoints","_ref1","_ref1$rubriclessInstr","_ref1$maxMaxPoints","maxMaxPoints","_ref10","pointsDescriptorsErrors","Number","isFinite","console","warn","maxPointsValue","row","changeMaxPoints","control","checked","excludeZeros","InputContainer","changeRubriclessInstruction","nonEmpty","disableUnderline","languageCharactersProps","language","DragDropContext","onDragEnd","dragEnd","Droppable","droppableId","provided","_extends2","droppableProps","ref","innerRef","p","shouldRenderPoint","Draggable","draggableId","toString","draggableProps","dragHandleProps","onPointMenuChange","placeholder","React","Component","object","func","Reverse","_ref11","_ref11$rubricless","_ref11$config","_ref11$pluginOpts","reverse","propTypes","getIndex","_default"],"sources":["../src/authoring.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\n\nimport InputLabel from '@mui/material/InputLabel';\nimport OutlinedInput from '@mui/material/OutlinedInput';\nimport Select from '@mui/material/Select';\nimport FormControl from '@mui/material/FormControl';\nimport MenuItem from '@mui/material/MenuItem';\nimport times from 'lodash/times';\nimport Checkbox from '@mui/material/Checkbox';\nimport FormGroup from '@mui/material/FormGroup';\nimport FormControlLabel from '@mui/material/FormControlLabel';\nimport Typography from '@mui/material/Typography';\nimport DragIndicator from '@mui/icons-material/DragIndicator';\nimport { DragDropContext, Droppable, Draggable } from '@hello-pangea/dnd';\nimport debug from 'debug';\nimport takeRight from 'lodash/takeRight';\nimport PointMenu from './point-menu';\nimport range from 'lodash/range';\nimport EditableHtml from '@pie-lib/editable-html-tip-tap';\nimport { InputContainer } from '@pie-lib/config-ui';\nimport { grey } from '@mui/material/colors';\n\nconst log = debug('pie-lib:rubric:authoring');\n\nconst reorder = (list, startIndex, endIndex) => {\n  const result = Array.from(list);\n  const [removed] = result.splice(startIndex, 1);\n\n  result.splice(endIndex, 0, removed);\n\n  return result;\n};\n\nexport const RubricType = PropTypes.shape({\n  excludeZero: PropTypes.bool,\n  points: PropTypes.arrayOf(PropTypes.string),\n  sampleAnswers: PropTypes.arrayOf(PropTypes.string),\n  maxPoints: PropTypes.number,\n  rubriclessInstruction: PropTypes.string,\n});\n\nconst MaxPoints = (props) => {\n  const { value, onChange, max } = props;\n  const labelId = 'max-points-label';\n\n  return (\n    <FormControl sx={{ minWidth: 120, m: 1 }} variant=\"outlined\">\n      <InputLabel id={labelId}>Max Points</InputLabel>\n      <Select\n        labelId={labelId}\n        label=\"Max Points\"\n        value={value}\n        onChange={(e) => onChange(e.target.value)}\n        input={<OutlinedInput label=\"Max Points\" />}\n        MenuProps={{ transitionDuration: { enter: 225, exit: 195 } }}\n      >\n        {range(1, max + 1).map((v) => (\n          <MenuItem key={`${v}`} value={v}>\n            {v}\n          </MenuItem>\n        ))}\n      </Select>\n    </FormControl>\n  );\n};\n\n// if the value is null or 'null', the Sample Answer input field for that point will not be dispalyed\n// if the value is '', the Sample Answer input field will be empty\nconst checkSampleAnswer = (sampleAnswer) => sampleAnswer === null || sampleAnswer === 'null';\n\nconst Row = styled('div')(() => ({ display: 'flex', width: '100%', position: 'relative' }));\n\nconst EditorDiv = styled('div')(({ theme }) => ({ width: '100%', backgroundColor: `${theme.palette.common.white}` }));\n\nconst DragIndicatorStyled = styled(DragIndicator)(({ theme }) => ({ paddingTop: theme.spacing(1), color: grey[500] }));\n\nconst PointsLabel = styled(Typography)(({ theme }) => ({\n  color: grey[500],\n  paddingBottom: theme.spacing(1),\n  textTransform: 'uppercase',\n}));\n\nconst SampleAnswersEditor = styled('div')(({ theme }) => ({ paddingLeft: theme.spacing(3) }));\n\nconst ErrorText = styled('div')(({ theme }) => ({\n  fontSize: theme.typography.fontSize - 2,\n  color: theme.palette.error.main,\n  paddingLeft: theme.spacing(3),\n  paddingTop: theme.spacing(1),\n}));\n\nconst PointMenuWrapper = styled('div')(() => ({ position: 'absolute', right: 0 }));\n\nexport const PointConfig = (props) => {\n  const { points, content, sampleAnswer, mathMlOptions = {}, error, pluginOpts = {} } = props;\n  const pointsLabel = `${points} ${points <= 1 ? 'pt' : 'pts'}`;\n  const showSampleAnswer = checkSampleAnswer(sampleAnswer);\n\n  return (\n    <div>\n      <PointsLabel variant=\"overline\">{pointsLabel}</PointsLabel>\n      <Row>\n        <DragIndicatorStyled />\n        <EditorDiv>\n          <EditableHtml\n            error={error}\n            pluginProps={pluginOpts}\n            markup={content}\n            onChange={props.onChange}\n            mathMlOptions={mathMlOptions}\n          />\n        </EditorDiv>\n        <PointMenuWrapper>\n          <PointMenu showSampleAnswer={showSampleAnswer} onChange={props.onMenuChange} />\n        </PointMenuWrapper>\n      </Row>\n      {error && <ErrorText>{error}</ErrorText>}\n      {!showSampleAnswer && (\n        <SampleAnswersEditor>\n          <DragIndicatorStyled as={Typography} variant=\"overline\">\n            Sample Response\n          </DragIndicatorStyled>\n          <EditorDiv>\n            <EditableHtml\n              markup={sampleAnswer}\n              pluginProps={pluginOpts}\n              onChange={props.onSampleChange}\n              mathMlOptions={mathMlOptions}\n            />\n          </EditorDiv>\n        </SampleAnswersEditor>\n      )}\n    </div>\n  );\n};\n\nconst Container = styled('div')(({ theme }) => ({\n  backgroundColor: grey[200],\n  borderWidth: 1,\n  borderStyle: 'solid',\n  borderColor: grey[300],\n  padding: theme.spacing(2),\n  margin: theme.spacing(1),\n}));\nconst InputContainerWrapper = styled('div')(({ theme }) => ({\n  width: '100%',\n  paddingTop: theme.spacing(2),\n  marginBottom: theme.spacing(2),\n  '& MuiFormControl-root': { width: '100%' },\n}));\nconst Rubricless = styled('div')(() => ({ display: 'none' }));\nconst ConfigHolder = styled('div')(({ theme }) => ({ paddingTop: theme.spacing(1), paddingBottom: theme.spacing(1) }));\nconst RubricTitle = styled(Typography)(({ theme }) => ({ paddingLeft: theme.spacing(1), margin: theme.spacing(1) }));\n\nexport class RawAuthoring extends React.Component {\n  static propTypes = {\n    value: RubricType,\n    config: PropTypes.object,\n    pluginOpts: PropTypes.object,\n    rubricless: PropTypes.bool,\n    onChange: PropTypes.func,\n  };\n\n  static defaultProps = {};\n\n  dragEnd = (result) => {\n    if (!result.destination) {\n      return;\n    }\n\n    const { value, onChange } = this.props;\n\n    const points = reorder(value.points, result.source.index, result.destination.index);\n    const sampleAnswers = reorder(value.sampleAnswers, result.source.index, result.destination.index);\n\n    onChange({ ...value, points, sampleAnswers });\n  };\n\n  changeRubriclessInstruction = (input) => {\n    const { value, onChange } = this.props;\n    onChange({ ...value, rubriclessInstruction: input });\n  };\n\n  changeMaxPoints = (maxPoints) => {\n    const { value, onChange, rubricless } = this.props;\n    const currentMax = value.points.length - 1;\n\n    log('current', currentMax, 'new: ', maxPoints);\n\n    let points, sampleAnswers;\n    if (maxPoints > currentMax) {\n      points = times(maxPoints - currentMax)\n        .map(() => '')\n        .concat(value.points);\n      sampleAnswers = times(maxPoints - currentMax)\n        .map(() => null)\n        .concat(value.sampleAnswers);\n    }\n\n    if (maxPoints < currentMax) {\n      log('less than');\n      points = takeRight(value.points, maxPoints + 1);\n      sampleAnswers = takeRight(value.sampleAnswers, maxPoints + 1);\n    }\n\n    if (points && !rubricless) {\n      onChange({ ...value, points, sampleAnswers, maxPoints });\n    } else {\n      onChange({ ...value, maxPoints });\n    }\n  };\n\n  changeContent = (index, content, type) => {\n    // type could be 'points' or 'sampleAnswers'\n    log(`changeModel[${type}]:`, index, content);\n\n    if (type !== 'points' && type !== 'sampleAnswers') {\n      return;\n    }\n\n    const { value, onChange } = this.props;\n    const items = value[type] && Array.from(value[type]);\n\n    items.splice(index, 1, content);\n    log(`changeModel[${type}]:`, items);\n\n    onChange({ ...value, [type]: items });\n  };\n\n  excludeZeros = () => {\n    const { value, onChange } = this.props;\n\n    onChange({ ...value, excludeZero: !value.excludeZero });\n  };\n\n  shouldRenderPoint = (index, value) => {\n    if (!value.excludeZero) {\n      return true;\n    } else {\n      if (index < value.points.length - 1) {\n        return true;\n      } else if (index === value.points.length - 1) {\n        return false;\n      }\n\n      return true;\n    }\n  };\n\n  onPointMenuChange = (index, clickedItem) => {\n    if (clickedItem === 'sample') {\n      const { value } = this.props;\n      const sampleAnswers = Array.from(value.sampleAnswers || []);\n\n      if (checkSampleAnswer(sampleAnswers[index])) {\n        // an empty string will display an empty Sample Answer input field\n        this.changeContent(index, '', 'sampleAnswers');\n      } else {\n        // when the content is null or 'null', the Sample Answer input field will not be displayed\n        this.changeContent(index, null, 'sampleAnswers');\n      }\n    }\n  };\n\n  render() {\n    const { value, mathMlOptions = {}, config = {}, rubricless = false, pluginOpts = {} } = this.props;\n    let {\n      excludeZeroEnabled = true,\n      maxPointsEnabled = true,\n      errors = {},\n      rubriclessInstructionEnabled = false,\n      maxPoints = 10,\n    } = value || {};\n    // rubric will contain a max value for maxPoints\n    const { rubriclessInstruction = {}, maxMaxPoints = 10 } = config || {};\n    const { pointsDescriptorsErrors } = errors || {};\n    if (value && Number.isFinite(value.maxPoints)) {\n      // eslint-disable-next-line no-console\n      console.warn('maxPoints is deprecated - remove from model');\n    }\n\n    // for rubric value is computed based on points\n    const maxPointsValue = !rubricless ? value.points.length - 1 : maxPoints;\n\n    return (\n      <div>\n        <RubricTitle variant=\"h5\">Rubric</RubricTitle>\n        <FormGroup row>\n          {maxPointsEnabled && (\n            <MaxPoints\n              max={maxMaxPoints < 100 ? maxMaxPoints : 100}\n              value={maxPointsValue}\n              onChange={this.changeMaxPoints}\n              pluginOpts={pluginOpts}\n            />\n          )}\n          {excludeZeroEnabled && (\n            <FormControlLabel\n              label=\"Exclude zeros\"\n              control={<Checkbox checked={value.excludeZero} onChange={this.excludeZeros} />}\n            />\n          )}\n        </FormGroup>\n\n        {rubriclessInstructionEnabled && rubricless && (\n          <InputContainerWrapper>\n            <InputContainer label={rubriclessInstruction.label}>\n              <EditableHtml\n                markup={value.rubriclessInstruction || ''}\n                onChange={this.changeRubriclessInstruction}\n                pluginProps={pluginOpts}\n                nonEmpty={false}\n                disableUnderline\n                languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n                mathMlOptions={mathMlOptions}\n              />\n            </InputContainer>\n          </InputContainerWrapper>\n        )}\n\n        <div>\n          {rubricless ? (\n            <Rubricless />\n          ) : (\n            <Container>\n              <DragDropContext onDragEnd={this.dragEnd}>\n                <Droppable droppableId=\"droppable\">\n                  {(provided) => (\n                    <div {...provided.droppableProps} ref={provided.innerRef}>\n                      {value.points.map(\n                        (p, index) =>\n                          this.shouldRenderPoint(index, value) && (\n                            <Draggable key={`${p.points}-${index}`} index={index} draggableId={index.toString()}>\n                              {(provided) => (\n                                <ConfigHolder\n                                  ref={provided.innerRef}\n                                  {...provided.draggableProps}\n                                  {...provided.dragHandleProps}\n                                >\n                                  <PointConfig\n                                    points={value.points.length - 1 - index}\n                                    content={p}\n                                    error={\n                                      pointsDescriptorsErrors &&\n                                      pointsDescriptorsErrors[value.points.length - 1 - index]\n                                    }\n                                    sampleAnswer={value.sampleAnswers && value.sampleAnswers[index]}\n                                    onChange={(content) => this.changeContent(index, content, 'points')}\n                                    onSampleChange={(content) => this.changeContent(index, content, 'sampleAnswers')}\n                                    onMenuChange={(clickedItem) => this.onPointMenuChange(index, clickedItem)}\n                                    mathMlOptions={mathMlOptions}\n                                    pluginOpts={pluginOpts}\n                                  />\n                                </ConfigHolder>\n                              )}\n                            </Draggable>\n                          ),\n                      )}\n                      {provided.placeholder}\n                    </div>\n                  )}\n                </Droppable>\n              </DragDropContext>\n            </Container>\n          )}\n        </div>\n      </div>\n    );\n  }\n}\n\n// styles migrated to styled-components above\n\nconst Reverse = (props) => {\n  const { rubricless = false, config = {}, pluginOpts = {} } = props || {};\n  const points = Array.from(props.value.points || []).reverse();\n  let sampleAnswers = Array.from(props.value.sampleAnswers || []).reverse();\n\n  if (points.length > sampleAnswers.length) {\n    sampleAnswers = times(points.length - sampleAnswers.length)\n      .map(() => null)\n      .concat(sampleAnswers);\n  }\n\n  const value = { ...props.value, points, sampleAnswers };\n\n  const onChange = (value) => {\n    props.onChange({\n      ...value,\n      points: Array.from(value.points || []).reverse(),\n      sampleAnswers: Array.from(value.sampleAnswers || []).reverse(),\n    });\n  };\n\n  return (\n    <RawAuthoring value={value} config={config} onChange={onChange} rubricless={rubricless} pluginOpts={pluginOpts} />\n  );\n};\n\nReverse.propTypes = {\n  value: RubricType,\n  config: PropTypes.object,\n  pluginOpts: PropTypes.object,\n  rubricless: PropTypes.bool,\n  getIndex: PropTypes.func,\n  onChange: PropTypes.func,\n};\n\nexport default Reverse;\n"],"mappings":";;;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AAEA,IAAAG,WAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,cAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,OAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,YAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,SAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,MAAA,GAAAT,sBAAA,CAAAC,OAAA;AACA,IAAAS,SAAA,GAAAV,sBAAA,CAAAC,OAAA;AACA,IAAAU,UAAA,GAAAX,sBAAA,CAAAC,OAAA;AACA,IAAAW,iBAAA,GAAAZ,sBAAA,CAAAC,OAAA;AACA,IAAAY,WAAA,GAAAb,sBAAA,CAAAC,OAAA;AACA,IAAAa,cAAA,GAAAd,sBAAA,CAAAC,OAAA;AACA,IAAAc,IAAA,GAAAd,OAAA;AACA,IAAAe,MAAA,GAAAhB,sBAAA,CAAAC,OAAA;AACA,IAAAgB,UAAA,GAAAjB,sBAAA,CAAAC,OAAA;AACA,IAAAiB,UAAA,GAAAlB,sBAAA,CAAAC,OAAA;AACA,IAAAkB,MAAA,GAAAnB,sBAAA,CAAAC,OAAA;AACA,IAAAmB,mBAAA,GAAApB,sBAAA,CAAAC,OAAA;AACA,IAAAoB,SAAA,GAAApB,OAAA;AACA,IAAAqB,OAAA,GAAArB,OAAA;AAA4C,SAAAsB,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA;AAAA,SAAAoB,WAAAlB,CAAA,EAAAI,CAAA,EAAAN,CAAA,WAAAM,CAAA,OAAAe,gBAAA,aAAAf,CAAA,OAAAgB,2BAAA,aAAApB,CAAA,EAAAqB,yBAAA,KAAAC,OAAA,CAAAC,SAAA,CAAAnB,CAAA,EAAAN,CAAA,YAAAqB,gBAAA,aAAAnB,CAAA,EAAAwB,WAAA,IAAApB,CAAA,CAAAK,KAAA,CAAAT,CAAA,EAAAF,CAAA;AAAA,SAAAuB,0BAAA,cAAArB,CAAA,IAAAyB,OAAA,CAAAC,SAAA,CAAAC,OAAA,CAAAC,IAAA,CAAAN,OAAA,CAAAC,SAAA,CAAAE,OAAA,iCAAAzB,CAAA,aAAAqB,yBAAA,YAAAA,0BAAA,aAAArB,CAAA;AAE5C,IAAM6B,GAAG,GAAG,IAAAC,iBAAK,EAAC,0BAA0B,CAAC;AAE7C,IAAMC,OAAO,GAAG,SAAVA,OAAOA,CAAIC,IAAI,EAAEC,UAAU,EAAEC,QAAQ,EAAK;EAC9C,IAAMC,MAAM,GAAGC,KAAK,CAACC,IAAI,CAACL,IAAI,CAAC;EAC/B,IAAAM,cAAA,GAAkBH,MAAM,CAACI,MAAM,CAACN,UAAU,EAAE,CAAC,CAAC;IAAAO,eAAA,OAAAC,eAAA,aAAAH,cAAA;IAAvCI,OAAO,GAAAF,eAAA;EAEdL,MAAM,CAACI,MAAM,CAACL,QAAQ,EAAE,CAAC,EAAEQ,OAAO,CAAC;EAEnC,OAAOP,MAAM;AACf,CAAC;AAEM,IAAMQ,UAAU,GAAAC,OAAA,CAAAD,UAAA,GAAGE,qBAAS,CAACC,KAAK,CAAC;EACxCC,WAAW,EAAEF,qBAAS,CAACG,IAAI;EAC3BC,MAAM,EAAEJ,qBAAS,CAACK,OAAO,CAACL,qBAAS,CAACM,MAAM,CAAC;EAC3CC,aAAa,EAAEP,qBAAS,CAACK,OAAO,CAACL,qBAAS,CAACM,MAAM,CAAC;EAClDE,SAAS,EAAER,qBAAS,CAACS,MAAM;EAC3BC,qBAAqB,EAAEV,qBAAS,CAACM;AACnC,CAAC,CAAC;AAEF,IAAMK,SAAS,GAAG,SAAZA,SAASA,CAAIC,KAAK,EAAK;EAC3B,IAAQC,KAAK,GAAoBD,KAAK,CAA9BC,KAAK;IAAEC,SAAQ,GAAUF,KAAK,CAAvBE,QAAQ;IAAEC,GAAG,GAAKH,KAAK,CAAbG,GAAG;EAC5B,IAAMC,OAAO,GAAG,kBAAkB;EAElC,oBACExF,MAAA,YAAAyF,aAAA,CAACjF,YAAA,WAAW;IAACkF,EAAE,EAAE;MAAEC,QAAQ,EAAE,GAAG;MAAEC,CAAC,EAAE;IAAE,CAAE;IAACC,OAAO,EAAC;EAAU,gBAC1D7F,MAAA,YAAAyF,aAAA,CAACpF,WAAA,WAAU;IAACyF,EAAE,EAAEN;EAAQ,GAAC,YAAsB,CAAC,eAChDxF,MAAA,YAAAyF,aAAA,CAAClF,OAAA,WAAM;IACLiF,OAAO,EAAEA,OAAQ;IACjBO,KAAK,EAAC,YAAY;IAClBV,KAAK,EAAEA,KAAM;IACbC,QAAQ,EAAE,SAAVA,QAAQA,CAAG7D,CAAC;MAAA,OAAK6D,SAAQ,CAAC7D,CAAC,CAACuE,MAAM,CAACX,KAAK,CAAC;IAAA,CAAC;IAC1CY,KAAK,eAAEjG,MAAA,YAAAyF,aAAA,CAACnF,cAAA,WAAa;MAACyF,KAAK,EAAC;IAAY,CAAE,CAAE;IAC5CG,SAAS,EAAE;MAAEC,kBAAkB,EAAE;QAAEC,KAAK,EAAE,GAAG;QAAEC,IAAI,EAAE;MAAI;IAAE;EAAE,GAE5D,IAAAC,iBAAK,EAAC,CAAC,EAAEf,GAAG,GAAG,CAAC,CAAC,CAACgB,GAAG,CAAC,UAACC,CAAC;IAAA,oBACvBxG,MAAA,YAAAyF,aAAA,CAAChF,SAAA,WAAQ;MAACgG,GAAG,KAAAC,MAAA,CAAKF,CAAC,CAAG;MAACnB,KAAK,EAAEmB;IAAE,GAC7BA,CACO,CAAC;EAAA,CACZ,CACK,CACG,CAAC;AAElB,CAAC;;AAED;AACA;AACA,IAAMG,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIC,YAAY;EAAA,OAAKA,YAAY,KAAK,IAAI,IAAIA,YAAY,KAAK,MAAM;AAAA;AAE5F,IAAMC,GAAG,GAAG,IAAAC,cAAM,EAAC,KAAK,CAAC,CAAC;EAAA,OAAO;IAAEC,OAAO,EAAE,MAAM;IAAEC,KAAK,EAAE,MAAM;IAAEC,QAAQ,EAAE;EAAW,CAAC;AAAA,CAAC,CAAC;AAE3F,IAAMC,SAAS,GAAG,IAAAJ,cAAM,EAAC,KAAK,CAAC,CAAC,UAAAK,IAAA;EAAA,IAAGC,KAAK,GAAAD,IAAA,CAALC,KAAK;EAAA,OAAQ;IAAEJ,KAAK,EAAE,MAAM;IAAEK,eAAe,KAAAX,MAAA,CAAKU,KAAK,CAACE,OAAO,CAACC,MAAM,CAACC,KAAK;EAAG,CAAC;AAAA,CAAC,CAAC;AAErH,IAAMC,mBAAmB,GAAG,IAAAX,cAAM,EAACY,yBAAa,CAAC,CAAC,UAAAC,KAAA;EAAA,IAAGP,KAAK,GAAAO,KAAA,CAALP,KAAK;EAAA,OAAQ;IAAEQ,UAAU,EAAER,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAAEC,KAAK,EAAEC,YAAI,CAAC,GAAG;EAAE,CAAC;AAAA,CAAC,CAAC;AAEtH,IAAMC,WAAW,GAAG,IAAAlB,cAAM,EAACmB,sBAAU,CAAC,CAAC,UAAAC,KAAA;EAAA,IAAGd,KAAK,GAAAc,KAAA,CAALd,KAAK;EAAA,OAAQ;IACrDU,KAAK,EAAEC,YAAI,CAAC,GAAG,CAAC;IAChBI,aAAa,EAAEf,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAC/BO,aAAa,EAAE;EACjB,CAAC;AAAA,CAAC,CAAC;AAEH,IAAMC,mBAAmB,GAAG,IAAAvB,cAAM,EAAC,KAAK,CAAC,CAAC,UAAAwB,KAAA;EAAA,IAAGlB,KAAK,GAAAkB,KAAA,CAALlB,KAAK;EAAA,OAAQ;IAAEmB,WAAW,EAAEnB,KAAK,CAACS,OAAO,CAAC,CAAC;EAAE,CAAC;AAAA,CAAC,CAAC;AAE7F,IAAMW,SAAS,GAAG,IAAA1B,cAAM,EAAC,KAAK,CAAC,CAAC,UAAA2B,KAAA;EAAA,IAAGrB,KAAK,GAAAqB,KAAA,CAALrB,KAAK;EAAA,OAAQ;IAC9CsB,QAAQ,EAAEtB,KAAK,CAACuB,UAAU,CAACD,QAAQ,GAAG,CAAC;IACvCZ,KAAK,EAAEV,KAAK,CAACE,OAAO,CAACsB,KAAK,CAACC,IAAI;IAC/BN,WAAW,EAAEnB,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAC7BD,UAAU,EAAER,KAAK,CAACS,OAAO,CAAC,CAAC;EAC7B,CAAC;AAAA,CAAC,CAAC;AAEH,IAAMiB,gBAAgB,GAAG,IAAAhC,cAAM,EAAC,KAAK,CAAC,CAAC;EAAA,OAAO;IAAEG,QAAQ,EAAE,UAAU;IAAE8B,KAAK,EAAE;EAAE,CAAC;AAAA,CAAC,CAAC;AAE3E,IAAMC,WAAW,GAAAzE,OAAA,CAAAyE,WAAA,GAAG,SAAdA,WAAWA,CAAI5D,KAAK,EAAK;EACpC,IAAQR,MAAM,GAAwEQ,KAAK,CAAnFR,MAAM;IAAEqE,OAAO,GAA+D7D,KAAK,CAA3E6D,OAAO;IAAErC,YAAY,GAAiDxB,KAAK,CAAlEwB,YAAY;IAAAsC,oBAAA,GAAiD9D,KAAK,CAApD+D,aAAa;IAAbA,aAAa,GAAAD,oBAAA,cAAG,CAAC,CAAC,GAAAA,oBAAA;IAAEN,KAAK,GAAsBxD,KAAK,CAAhCwD,KAAK;IAAAQ,iBAAA,GAAsBhE,KAAK,CAAzBiE,UAAU;IAAVA,UAAU,GAAAD,iBAAA,cAAG,CAAC,CAAC,GAAAA,iBAAA;EACjF,IAAME,WAAW,MAAA5C,MAAA,CAAM9B,MAAM,OAAA8B,MAAA,CAAI9B,MAAM,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,CAAE;EAC7D,IAAM2E,gBAAgB,GAAG5C,iBAAiB,CAACC,YAAY,CAAC;EAExD,oBACE5G,MAAA,YAAAyF,aAAA,2BACEzF,MAAA,YAAAyF,aAAA,CAACuC,WAAW;IAACnC,OAAO,EAAC;EAAU,GAAEyD,WAAyB,CAAC,eAC3DtJ,MAAA,YAAAyF,aAAA,CAACoB,GAAG,qBACF7G,MAAA,YAAAyF,aAAA,CAACgC,mBAAmB,MAAE,CAAC,eACvBzH,MAAA,YAAAyF,aAAA,CAACyB,SAAS,qBACRlH,MAAA,YAAAyF,aAAA,CAACpE,mBAAA,WAAY;IACXuH,KAAK,EAAEA,KAAM;IACbY,WAAW,EAAEH,UAAW;IACxBI,MAAM,EAAER,OAAQ;IAChB3D,QAAQ,EAAEF,KAAK,CAACE,QAAS;IACzB6D,aAAa,EAAEA;EAAc,CAC9B,CACQ,CAAC,eACZnJ,MAAA,YAAAyF,aAAA,CAACqD,gBAAgB,qBACf9I,MAAA,YAAAyF,aAAA,CAACtE,UAAA,WAAS;IAACoI,gBAAgB,EAAEA,gBAAiB;IAACjE,QAAQ,EAAEF,KAAK,CAACsE;EAAa,CAAE,CAC9D,CACf,CAAC,EACLd,KAAK,iBAAI5I,MAAA,YAAAyF,aAAA,CAAC+C,SAAS,QAAEI,KAAiB,CAAC,EACvC,CAACW,gBAAgB,iBAChBvJ,MAAA,YAAAyF,aAAA,CAAC4C,mBAAmB,qBAClBrI,MAAA,YAAAyF,aAAA,CAACgC,mBAAmB;IAACkC,EAAE,EAAE1B,sBAAW;IAACpC,OAAO,EAAC;EAAU,GAAC,iBAEnC,CAAC,eACtB7F,MAAA,YAAAyF,aAAA,CAACyB,SAAS,qBACRlH,MAAA,YAAAyF,aAAA,CAACpE,mBAAA,WAAY;IACXoI,MAAM,EAAE7C,YAAa;IACrB4C,WAAW,EAAEH,UAAW;IACxB/D,QAAQ,EAAEF,KAAK,CAACwE,cAAe;IAC/BT,aAAa,EAAEA;EAAc,CAC9B,CACQ,CACQ,CAEpB,CAAC;AAEV,CAAC;AAED,IAAMU,SAAS,GAAG,IAAA/C,cAAM,EAAC,KAAK,CAAC,CAAC,UAAAgD,KAAA;EAAA,IAAG1C,KAAK,GAAA0C,KAAA,CAAL1C,KAAK;EAAA,OAAQ;IAC9CC,eAAe,EAAEU,YAAI,CAAC,GAAG,CAAC;IAC1BgC,WAAW,EAAE,CAAC;IACdC,WAAW,EAAE,OAAO;IACpBC,WAAW,EAAElC,YAAI,CAAC,GAAG,CAAC;IACtBmC,OAAO,EAAE9C,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IACzBsC,MAAM,EAAE/C,KAAK,CAACS,OAAO,CAAC,CAAC;EACzB,CAAC;AAAA,CAAC,CAAC;AACH,IAAMuC,qBAAqB,GAAG,IAAAtD,cAAM,EAAC,KAAK,CAAC,CAAC,UAAAuD,KAAA;EAAA,IAAGjD,KAAK,GAAAiD,KAAA,CAALjD,KAAK;EAAA,OAAQ;IAC1DJ,KAAK,EAAE,MAAM;IACbY,UAAU,EAAER,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAC5ByC,YAAY,EAAElD,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAC9B,uBAAuB,EAAE;MAAEb,KAAK,EAAE;IAAO;EAC3C,CAAC;AAAA,CAAC,CAAC;AACH,IAAMuD,UAAU,GAAG,IAAAzD,cAAM,EAAC,KAAK,CAAC,CAAC;EAAA,OAAO;IAAEC,OAAO,EAAE;EAAO,CAAC;AAAA,CAAC,CAAC;AAC7D,IAAMyD,YAAY,GAAG,IAAA1D,cAAM,EAAC,KAAK,CAAC,CAAC,UAAA2D,KAAA;EAAA,IAAGrD,KAAK,GAAAqD,KAAA,CAALrD,KAAK;EAAA,OAAQ;IAAEQ,UAAU,EAAER,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAAEM,aAAa,EAAEf,KAAK,CAACS,OAAO,CAAC,CAAC;EAAE,CAAC;AAAA,CAAC,CAAC;AACtH,IAAM6C,WAAW,GAAG,IAAA5D,cAAM,EAACmB,sBAAU,CAAC,CAAC,UAAA0C,KAAA;EAAA,IAAGvD,KAAK,GAAAuD,KAAA,CAALvD,KAAK;EAAA,OAAQ;IAAEmB,WAAW,EAAEnB,KAAK,CAACS,OAAO,CAAC,CAAC,CAAC;IAAEsC,MAAM,EAAE/C,KAAK,CAACS,OAAO,CAAC,CAAC;EAAE,CAAC;AAAA,CAAC,CAAC;AAAC,IAExG+C,YAAY,GAAArG,OAAA,CAAAqG,YAAA,0BAAAC,gBAAA;EAAA,SAAAD,aAAA;IAAA,IAAAE,KAAA;IAAA,IAAAC,gBAAA,mBAAAH,YAAA;IAAA,SAAAI,IAAA,GAAA1I,SAAA,CAAAC,MAAA,EAAA0I,IAAA,OAAAlH,KAAA,CAAAiH,IAAA,GAAAE,IAAA,MAAAA,IAAA,GAAAF,IAAA,EAAAE,IAAA;MAAAD,IAAA,CAAAC,IAAA,IAAA5I,SAAA,CAAA4I,IAAA;IAAA;IAAAJ,KAAA,GAAAjI,UAAA,OAAA+H,YAAA,KAAAlE,MAAA,CAAAuE,IAAA;IAAA,IAAAxI,gBAAA,aAAAqI,KAAA,aAWb,UAAChH,MAAM,EAAK;MACpB,IAAI,CAACA,MAAM,CAACqH,WAAW,EAAE;QACvB;MACF;MAEA,IAAAC,WAAA,GAA4BN,KAAA,CAAK1F,KAAK;QAA9BC,KAAK,GAAA+F,WAAA,CAAL/F,KAAK;QAAEC,QAAQ,GAAA8F,WAAA,CAAR9F,QAAQ;MAEvB,IAAMV,MAAM,GAAGlB,OAAO,CAAC2B,KAAK,CAACT,MAAM,EAAEd,MAAM,CAACuH,MAAM,CAACC,KAAK,EAAExH,MAAM,CAACqH,WAAW,CAACG,KAAK,CAAC;MACnF,IAAMvG,aAAa,GAAGrB,OAAO,CAAC2B,KAAK,CAACN,aAAa,EAAEjB,MAAM,CAACuH,MAAM,CAACC,KAAK,EAAExH,MAAM,CAACqH,WAAW,CAACG,KAAK,CAAC;MAEjGhG,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KAAMgD,KAAK;QAAET,MAAM,EAANA,MAAM;QAAEG,aAAa,EAAbA;MAAa,EAAE,CAAC;IAC/C,CAAC;IAAA,IAAAtC,gBAAA,aAAAqI,KAAA,iCAE6B,UAAC7E,KAAK,EAAK;MACvC,IAAAsF,YAAA,GAA4BT,KAAA,CAAK1F,KAAK;QAA9BC,KAAK,GAAAkG,YAAA,CAALlG,KAAK;QAAEC,QAAQ,GAAAiG,YAAA,CAARjG,QAAQ;MACvBA,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KAAMgD,KAAK;QAAEH,qBAAqB,EAAEe;MAAK,EAAE,CAAC;IACtD,CAAC;IAAA,IAAAxD,gBAAA,aAAAqI,KAAA,qBAEiB,UAAC9F,SAAS,EAAK;MAC/B,IAAAwG,YAAA,GAAwCV,KAAA,CAAK1F,KAAK;QAA1CC,KAAK,GAAAmG,YAAA,CAALnG,KAAK;QAAEC,QAAQ,GAAAkG,YAAA,CAARlG,QAAQ;QAAEmG,UAAU,GAAAD,YAAA,CAAVC,UAAU;MACnC,IAAMC,UAAU,GAAGrG,KAAK,CAACT,MAAM,CAACrC,MAAM,GAAG,CAAC;MAE1CiB,GAAG,CAAC,SAAS,EAAEkI,UAAU,EAAE,OAAO,EAAE1G,SAAS,CAAC;MAE9C,IAAIJ,MAAM,EAAEG,aAAa;MACzB,IAAIC,SAAS,GAAG0G,UAAU,EAAE;QAC1B9G,MAAM,GAAG,IAAA+G,iBAAK,EAAC3G,SAAS,GAAG0G,UAAU,CAAC,CACnCnF,GAAG,CAAC;UAAA,OAAM,EAAE;QAAA,EAAC,CACbG,MAAM,CAACrB,KAAK,CAACT,MAAM,CAAC;QACvBG,aAAa,GAAG,IAAA4G,iBAAK,EAAC3G,SAAS,GAAG0G,UAAU,CAAC,CAC1CnF,GAAG,CAAC;UAAA,OAAM,IAAI;QAAA,EAAC,CACfG,MAAM,CAACrB,KAAK,CAACN,aAAa,CAAC;MAChC;MAEA,IAAIC,SAAS,GAAG0G,UAAU,EAAE;QAC1BlI,GAAG,CAAC,WAAW,CAAC;QAChBoB,MAAM,GAAG,IAAAgH,qBAAS,EAACvG,KAAK,CAACT,MAAM,EAAEI,SAAS,GAAG,CAAC,CAAC;QAC/CD,aAAa,GAAG,IAAA6G,qBAAS,EAACvG,KAAK,CAACN,aAAa,EAAEC,SAAS,GAAG,CAAC,CAAC;MAC/D;MAEA,IAAIJ,MAAM,IAAI,CAAC6G,UAAU,EAAE;QACzBnG,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KAAMgD,KAAK;UAAET,MAAM,EAANA,MAAM;UAAEG,aAAa,EAAbA,aAAa;UAAEC,SAAS,EAATA;QAAS,EAAE,CAAC;MAC1D,CAAC,MAAM;QACLM,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KAAMgD,KAAK;UAAEL,SAAS,EAATA;QAAS,EAAE,CAAC;MACnC;IACF,CAAC;IAAA,IAAAvC,gBAAA,aAAAqI,KAAA,mBAEe,UAACQ,KAAK,EAAErC,OAAO,EAAE4C,IAAI,EAAK;MACxC;MACArI,GAAG,gBAAAkD,MAAA,CAAgBmF,IAAI,SAAMP,KAAK,EAAErC,OAAO,CAAC;MAE5C,IAAI4C,IAAI,KAAK,QAAQ,IAAIA,IAAI,KAAK,eAAe,EAAE;QACjD;MACF;MAEA,IAAAC,YAAA,GAA4BhB,KAAA,CAAK1F,KAAK;QAA9BC,KAAK,GAAAyG,YAAA,CAALzG,KAAK;QAAEC,QAAQ,GAAAwG,YAAA,CAARxG,QAAQ;MACvB,IAAMyG,KAAK,GAAG1G,KAAK,CAACwG,IAAI,CAAC,IAAI9H,KAAK,CAACC,IAAI,CAACqB,KAAK,CAACwG,IAAI,CAAC,CAAC;MAEpDE,KAAK,CAAC7H,MAAM,CAACoH,KAAK,EAAE,CAAC,EAAErC,OAAO,CAAC;MAC/BzF,GAAG,gBAAAkD,MAAA,CAAgBmF,IAAI,SAAME,KAAK,CAAC;MAEnCzG,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KAAMgD,KAAK,WAAA5C,gBAAA,iBAAGoJ,IAAI,EAAGE,KAAK,EAAE,CAAC;IACvC,CAAC;IAAA,IAAAtJ,gBAAA,aAAAqI,KAAA,kBAEc,YAAM;MACnB,IAAAkB,YAAA,GAA4BlB,KAAA,CAAK1F,KAAK;QAA9BC,KAAK,GAAA2G,YAAA,CAAL3G,KAAK;QAAEC,QAAQ,GAAA0G,YAAA,CAAR1G,QAAQ;MAEvBA,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KAAMgD,KAAK;QAAEX,WAAW,EAAE,CAACW,KAAK,CAACX;MAAW,EAAE,CAAC;IACzD,CAAC;IAAA,IAAAjC,gBAAA,aAAAqI,KAAA,uBAEmB,UAACQ,KAAK,EAAEjG,KAAK,EAAK;MACpC,IAAI,CAACA,KAAK,CAACX,WAAW,EAAE;QACtB,OAAO,IAAI;MACb,CAAC,MAAM;QACL,IAAI4G,KAAK,GAAGjG,KAAK,CAACT,MAAM,CAACrC,MAAM,GAAG,CAAC,EAAE;UACnC,OAAO,IAAI;QACb,CAAC,MAAM,IAAI+I,KAAK,KAAKjG,KAAK,CAACT,MAAM,CAACrC,MAAM,GAAG,CAAC,EAAE;UAC5C,OAAO,KAAK;QACd;QAEA,OAAO,IAAI;MACb;IACF,CAAC;IAAA,IAAAE,gBAAA,aAAAqI,KAAA,uBAEmB,UAACQ,KAAK,EAAEW,WAAW,EAAK;MAC1C,IAAIA,WAAW,KAAK,QAAQ,EAAE;QAC5B,IAAQ5G,KAAK,GAAKyF,KAAA,CAAK1F,KAAK,CAApBC,KAAK;QACb,IAAMN,aAAa,GAAGhB,KAAK,CAACC,IAAI,CAACqB,KAAK,CAACN,aAAa,IAAI,EAAE,CAAC;QAE3D,IAAI4B,iBAAiB,CAAC5B,aAAa,CAACuG,KAAK,CAAC,CAAC,EAAE;UAC3C;UACAR,KAAA,CAAKoB,aAAa,CAACZ,KAAK,EAAE,EAAE,EAAE,eAAe,CAAC;QAChD,CAAC,MAAM;UACL;UACAR,KAAA,CAAKoB,aAAa,CAACZ,KAAK,EAAE,IAAI,EAAE,eAAe,CAAC;QAClD;MACF;IACF,CAAC;IAAA,OAAAR,KAAA;EAAA;EAAA,IAAAqB,UAAA,aAAAvB,YAAA,EAAAC,gBAAA;EAAA,WAAAuB,aAAA,aAAAxB,YAAA;IAAAnE,GAAA;IAAApB,KAAA,EAED,SAAAgH,MAAMA,CAAA,EAAG;MAAA,IAAAC,MAAA;MACP,IAAAC,YAAA,GAAwF,IAAI,CAACnH,KAAK;QAA1FC,KAAK,GAAAkH,YAAA,CAALlH,KAAK;QAAAmH,qBAAA,GAAAD,YAAA,CAAEpD,aAAa;QAAbA,aAAa,GAAAqD,qBAAA,cAAG,CAAC,CAAC,GAAAA,qBAAA;QAAAC,mBAAA,GAAAF,YAAA,CAAEG,MAAM;QAANA,MAAM,GAAAD,mBAAA,cAAG,CAAC,CAAC,GAAAA,mBAAA;QAAAE,qBAAA,GAAAJ,YAAA,CAAEd,UAAU;QAAVA,UAAU,GAAAkB,qBAAA,cAAG,KAAK,GAAAA,qBAAA;QAAAC,qBAAA,GAAAL,YAAA,CAAElD,UAAU;QAAVA,UAAU,GAAAuD,qBAAA,cAAG,CAAC,CAAC,GAAAA,qBAAA;MACnF,IAAAC,KAAA,GAMIxH,KAAK,IAAI,CAAC,CAAC;QAAAyH,qBAAA,GAAAD,KAAA,CALbE,kBAAkB;QAAlBA,kBAAkB,GAAAD,qBAAA,cAAG,IAAI,GAAAA,qBAAA;QAAAE,qBAAA,GAAAH,KAAA,CACzBI,gBAAgB;QAAhBA,gBAAgB,GAAAD,qBAAA,cAAG,IAAI,GAAAA,qBAAA;QAAAE,YAAA,GAAAL,KAAA,CACvBM,MAAM;QAANA,MAAM,GAAAD,YAAA,cAAG,CAAC,CAAC,GAAAA,YAAA;QAAAE,qBAAA,GAAAP,KAAA,CACXQ,4BAA4B;QAA5BA,4BAA4B,GAAAD,qBAAA,cAAG,KAAK,GAAAA,qBAAA;QAAAE,eAAA,GAAAT,KAAA,CACpC7H,SAAS;QAATA,SAAS,GAAAsI,eAAA,cAAG,EAAE,GAAAA,eAAA;MAEhB;MACA,IAAAC,KAAA,GAA0Db,MAAM,IAAI,CAAC,CAAC;QAAAc,qBAAA,GAAAD,KAAA,CAA9DrI,qBAAqB;QAArBA,qBAAqB,GAAAsI,qBAAA,cAAG,CAAC,CAAC,GAAAA,qBAAA;QAAAC,kBAAA,GAAAF,KAAA,CAAEG,YAAY;QAAZA,YAAY,GAAAD,kBAAA,cAAG,EAAE,GAAAA,kBAAA;MACrD,IAAAE,MAAA,GAAoCR,MAAM,IAAI,CAAC,CAAC;QAAxCS,uBAAuB,GAAAD,MAAA,CAAvBC,uBAAuB;MAC/B,IAAIvI,KAAK,IAAIwI,MAAM,CAACC,QAAQ,CAACzI,KAAK,CAACL,SAAS,CAAC,EAAE;QAC7C;QACA+I,OAAO,CAACC,IAAI,CAAC,6CAA6C,CAAC;MAC7D;;MAEA;MACA,IAAMC,cAAc,GAAG,CAACxC,UAAU,GAAGpG,KAAK,CAACT,MAAM,CAACrC,MAAM,GAAG,CAAC,GAAGyC,SAAS;MAExE,oBACEhF,MAAA,YAAAyF,aAAA,2BACEzF,MAAA,YAAAyF,aAAA,CAACiF,WAAW;QAAC7E,OAAO,EAAC;MAAI,GAAC,QAAmB,CAAC,eAC9C7F,MAAA,YAAAyF,aAAA,CAAC7E,UAAA,WAAS;QAACsN,GAAG;MAAA,GACXjB,gBAAgB,iBACfjN,MAAA,YAAAyF,aAAA,CAACN,SAAS;QACRI,GAAG,EAAEmI,YAAY,GAAG,GAAG,GAAGA,YAAY,GAAG,GAAI;QAC7CrI,KAAK,EAAE4I,cAAe;QACtB3I,QAAQ,EAAE,IAAI,CAAC6I,eAAgB;QAC/B9E,UAAU,EAAEA;MAAW,CACxB,CACF,EACA0D,kBAAkB,iBACjB/M,MAAA,YAAAyF,aAAA,CAAC5E,iBAAA,WAAgB;QACfkF,KAAK,EAAC,eAAe;QACrBqI,OAAO,eAAEpO,MAAA,YAAAyF,aAAA,CAAC9E,SAAA,WAAQ;UAAC0N,OAAO,EAAEhJ,KAAK,CAACX,WAAY;UAACY,QAAQ,EAAE,IAAI,CAACgJ;QAAa,CAAE;MAAE,CAChF,CAEM,CAAC,EAEXjB,4BAA4B,IAAI5B,UAAU,iBACzCzL,MAAA,YAAAyF,aAAA,CAAC2E,qBAAqB,qBACpBpK,MAAA,YAAAyF,aAAA,CAACnE,SAAA,CAAAiN,cAAc;QAACxI,KAAK,EAAEb,qBAAqB,CAACa;MAAM,gBACjD/F,MAAA,YAAAyF,aAAA,CAACpE,mBAAA,WAAY;QACXoI,MAAM,EAAEpE,KAAK,CAACH,qBAAqB,IAAI,EAAG;QAC1CI,QAAQ,EAAE,IAAI,CAACkJ,2BAA4B;QAC3ChF,WAAW,EAAEH,UAAW;QACxBoF,QAAQ,EAAE,KAAM;QAChBC,gBAAgB;QAChBC,uBAAuB,EAAE,CAAC;UAAEC,QAAQ,EAAE;QAAU,CAAC,EAAE;UAAEA,QAAQ,EAAE;QAAU,CAAC,CAAE;QAC5EzF,aAAa,EAAEA;MAAc,CAC9B,CACa,CACK,CACxB,eAEDnJ,MAAA,YAAAyF,aAAA,cACGgG,UAAU,gBACTzL,MAAA,YAAAyF,aAAA,CAAC8E,UAAU,MAAE,CAAC,gBAEdvK,MAAA,YAAAyF,aAAA,CAACoE,SAAS,qBACR7J,MAAA,YAAAyF,aAAA,CAACzE,IAAA,CAAA6N,eAAe;QAACC,SAAS,EAAE,IAAI,CAACC;MAAQ,gBACvC/O,MAAA,YAAAyF,aAAA,CAACzE,IAAA,CAAAgO,SAAS;QAACC,WAAW,EAAC;MAAW,GAC/B,UAACC,QAAQ;QAAA,oBACRlP,MAAA,YAAAyF,aAAA,YAAA0J,SAAA,iBAASD,QAAQ,CAACE,cAAc;UAAEC,GAAG,EAAEH,QAAQ,CAACI;QAAS,IACtDjK,KAAK,CAACT,MAAM,CAAC2B,GAAG,CACf,UAACgJ,CAAC,EAAEjE,KAAK;UAAA,OACPgB,MAAI,CAACkD,iBAAiB,CAAClE,KAAK,EAAEjG,KAAK,CAAC,iBAClCrF,MAAA,YAAAyF,aAAA,CAACzE,IAAA,CAAAyO,SAAS;YAAChJ,GAAG,KAAAC,MAAA,CAAK6I,CAAC,CAAC3K,MAAM,OAAA8B,MAAA,CAAI4E,KAAK,CAAG;YAACA,KAAK,EAAEA,KAAM;YAACoE,WAAW,EAAEpE,KAAK,CAACqE,QAAQ,CAAC;UAAE,GACjF,UAACT,QAAQ;YAAA,oBACRlP,MAAA,YAAAyF,aAAA,CAAC+E,YAAY,MAAA2E,SAAA;cACXE,GAAG,EAAEH,QAAQ,CAACI;YAAS,GACnBJ,QAAQ,CAACU,cAAc,EACvBV,QAAQ,CAACW,eAAe,gBAE5B7P,MAAA,YAAAyF,aAAA,CAACuD,WAAW;cACVpE,MAAM,EAAES,KAAK,CAACT,MAAM,CAACrC,MAAM,GAAG,CAAC,GAAG+I,KAAM;cACxCrC,OAAO,EAAEsG,CAAE;cACX3G,KAAK,EACHgF,uBAAuB,IACvBA,uBAAuB,CAACvI,KAAK,CAACT,MAAM,CAACrC,MAAM,GAAG,CAAC,GAAG+I,KAAK,CACxD;cACD1E,YAAY,EAAEvB,KAAK,CAACN,aAAa,IAAIM,KAAK,CAACN,aAAa,CAACuG,KAAK,CAAE;cAChEhG,QAAQ,EAAE,SAAVA,QAAQA,CAAG2D,OAAO;gBAAA,OAAKqD,MAAI,CAACJ,aAAa,CAACZ,KAAK,EAAErC,OAAO,EAAE,QAAQ,CAAC;cAAA,CAAC;cACpEW,cAAc,EAAE,SAAhBA,cAAcA,CAAGX,OAAO;gBAAA,OAAKqD,MAAI,CAACJ,aAAa,CAACZ,KAAK,EAAErC,OAAO,EAAE,eAAe,CAAC;cAAA,CAAC;cACjFS,YAAY,EAAE,SAAdA,YAAYA,CAAGuC,WAAW;gBAAA,OAAKK,MAAI,CAACwD,iBAAiB,CAACxE,KAAK,EAAEW,WAAW,CAAC;cAAA,CAAC;cAC1E9C,aAAa,EAAEA,aAAc;cAC7BE,UAAU,EAAEA;YAAW,CACxB,CACW,CAAC;UAAA,CAER,CACZ;QAAA,CACL,CAAC,EACA6F,QAAQ,CAACa,WACP,CAAC;MAAA,CAEC,CACI,CACR,CAEV,CACF,CAAC;IAEV;EAAC;AAAA,EAtN+BC,iBAAK,CAACC,SAAS,GAyNjD;AAAA,IAAAxN,gBAAA,aAzNamI,YAAY,eACJ;EACjBvF,KAAK,EAAEf,UAAU;EACjBoI,MAAM,EAAElI,qBAAS,CAAC0L,MAAM;EACxB7G,UAAU,EAAE7E,qBAAS,CAAC0L,MAAM;EAC5BzE,UAAU,EAAEjH,qBAAS,CAACG,IAAI;EAC1BW,QAAQ,EAAEd,qBAAS,CAAC2L;AACtB,CAAC;AAAA,IAAA1N,gBAAA,aAPUmI,YAAY,kBASD,CAAC,CAAC;AAkN1B,IAAMwF,OAAO,GAAG,SAAVA,OAAOA,CAAIhL,KAAK,EAAK;EACzB,IAAAiL,MAAA,GAA6DjL,KAAK,IAAI,CAAC,CAAC;IAAAkL,iBAAA,GAAAD,MAAA,CAAhE5E,UAAU;IAAVA,UAAU,GAAA6E,iBAAA,cAAG,KAAK,GAAAA,iBAAA;IAAAC,aAAA,GAAAF,MAAA,CAAE3D,MAAM;IAANA,MAAM,GAAA6D,aAAA,cAAG,CAAC,CAAC,GAAAA,aAAA;IAAAC,iBAAA,GAAAH,MAAA,CAAEhH,UAAU;IAAVA,UAAU,GAAAmH,iBAAA,cAAG,CAAC,CAAC,GAAAA,iBAAA;EACxD,IAAM5L,MAAM,GAAGb,KAAK,CAACC,IAAI,CAACoB,KAAK,CAACC,KAAK,CAACT,MAAM,IAAI,EAAE,CAAC,CAAC6L,OAAO,CAAC,CAAC;EAC7D,IAAI1L,aAAa,GAAGhB,KAAK,CAACC,IAAI,CAACoB,KAAK,CAACC,KAAK,CAACN,aAAa,IAAI,EAAE,CAAC,CAAC0L,OAAO,CAAC,CAAC;EAEzE,IAAI7L,MAAM,CAACrC,MAAM,GAAGwC,aAAa,CAACxC,MAAM,EAAE;IACxCwC,aAAa,GAAG,IAAA4G,iBAAK,EAAC/G,MAAM,CAACrC,MAAM,GAAGwC,aAAa,CAACxC,MAAM,CAAC,CACxDgE,GAAG,CAAC;MAAA,OAAM,IAAI;IAAA,EAAC,CACfG,MAAM,CAAC3B,aAAa,CAAC;EAC1B;EAEA,IAAMM,KAAK,GAAAhD,aAAA,CAAAA,aAAA,KAAQ+C,KAAK,CAACC,KAAK;IAAET,MAAM,EAANA,MAAM;IAAEG,aAAa,EAAbA;EAAa,EAAE;EAEvD,IAAMO,QAAQ,GAAG,SAAXA,QAAQA,CAAID,KAAK,EAAK;IAC1BD,KAAK,CAACE,QAAQ,CAAAjD,aAAA,CAAAA,aAAA,KACTgD,KAAK;MACRT,MAAM,EAAEb,KAAK,CAACC,IAAI,CAACqB,KAAK,CAACT,MAAM,IAAI,EAAE,CAAC,CAAC6L,OAAO,CAAC,CAAC;MAChD1L,aAAa,EAAEhB,KAAK,CAACC,IAAI,CAACqB,KAAK,CAACN,aAAa,IAAI,EAAE,CAAC,CAAC0L,OAAO,CAAC;IAAC,EAC/D,CAAC;EACJ,CAAC;EAED,oBACEzQ,MAAA,YAAAyF,aAAA,CAACmF,YAAY;IAACvF,KAAK,EAAEA,KAAM;IAACqH,MAAM,EAAEA,MAAO;IAACpH,QAAQ,EAAEA,QAAS;IAACmG,UAAU,EAAEA,UAAW;IAACpC,UAAU,EAAEA;EAAW,CAAE,CAAC;AAEtH,CAAC;AAED+G,OAAO,CAACM,SAAS,GAAG;EAClBrL,KAAK,EAAEf,UAAU;EACjBoI,MAAM,EAAElI,qBAAS,CAAC0L,MAAM;EACxB7G,UAAU,EAAE7E,qBAAS,CAAC0L,MAAM;EAC5BzE,UAAU,EAAEjH,qBAAS,CAACG,IAAI;EAC1BgM,QAAQ,EAAEnM,qBAAS,CAAC2L,IAAI;EACxB7K,QAAQ,EAAEd,qBAAS,CAAC2L;AACtB,CAAC;AAAC,IAAAS,QAAA,GAAArM,OAAA,cAEa6L,OAAO","ignoreList":[]}