@pie-lib/rubric 0.8.32-next.0 → 0.10.0-beta.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/CHANGELOG.md +9 -1
- package/NEXT.CHANGELOG.json +1 -0
- package/lib/__tests__/rubric.test.js +116 -0
- package/lib/authoring.js +127 -28
- package/lib/index.js +3 -2
- package/lib/point-menu.js +1 -1
- package/package.json +3 -3
- package/src/__tests__/__snapshots__/rubric.test.jsx.snap +48 -0
- package/src/__tests__/rubric.test.jsx +91 -0
- package/src/authoring.jsx +99 -12
- package/src/index.js +1 -0
- package/lib/authoring.js.map +0 -1
- package/lib/index.js.map +0 -1
- package/lib/point-menu.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,7 +3,15 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
-
|
|
6
|
+
# [0.10.0-beta.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/rubric@0.8.31...@pie-lib/rubric@0.10.0-beta.0) (2025-07-15)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @pie-lib/rubric
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# [0.9.0-beta.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/rubric@0.8.31...@pie-lib/rubric@0.9.0-beta.0) (2025-07-15)
|
|
7
15
|
|
|
8
16
|
**Note:** Version bump only for package @pie-lib/rubric
|
|
9
17
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
[]
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
6
|
+
|
|
7
|
+
var _enzyme = require("enzyme");
|
|
8
|
+
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
|
|
11
|
+
var _authoring = require("../authoring");
|
|
12
|
+
|
|
13
|
+
var _reactBeautifulDnd = require("react-beautiful-dnd");
|
|
14
|
+
|
|
15
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
16
|
+
|
|
17
|
+
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; }
|
|
18
|
+
|
|
19
|
+
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; }
|
|
20
|
+
|
|
21
|
+
jest.mock('@pie-lib/editable-html', function () {
|
|
22
|
+
return function () {
|
|
23
|
+
return /*#__PURE__*/_react["default"].createElement("div", null);
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
describe('Rubric', function () {
|
|
27
|
+
var w;
|
|
28
|
+
var points = ['nothing right', 'a teeny bit right', 'mostly right', 'bingo'];
|
|
29
|
+
var sampleAnswers = [null, 'just right', 'not left', null];
|
|
30
|
+
|
|
31
|
+
var wrapper = function wrapper(value, opts) {
|
|
32
|
+
var props = {
|
|
33
|
+
classes: {},
|
|
34
|
+
onChange: jest.fn(),
|
|
35
|
+
className: 'className',
|
|
36
|
+
value: _objectSpread({
|
|
37
|
+
excludeZero: false,
|
|
38
|
+
points: points,
|
|
39
|
+
sampleAnswers: sampleAnswers
|
|
40
|
+
}, value)
|
|
41
|
+
};
|
|
42
|
+
var fn = opts && opts.mount ? _enzyme.mount : _enzyme.shallow;
|
|
43
|
+
return fn( /*#__PURE__*/_react["default"].createElement(_authoring.RawAuthoring, props), opts);
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
describe('render', function () {
|
|
47
|
+
it('snapshot', function () {
|
|
48
|
+
w = wrapper();
|
|
49
|
+
expect(w).toMatchSnapshot();
|
|
50
|
+
});
|
|
51
|
+
describe('draggable', function () {
|
|
52
|
+
it('renders correctly for excluded zeroes', function () {
|
|
53
|
+
var w = wrapper({
|
|
54
|
+
excludeZero: true
|
|
55
|
+
}, {
|
|
56
|
+
mount: true
|
|
57
|
+
});
|
|
58
|
+
expect(w.find(_reactBeautifulDnd.Draggable).length).toEqual(3);
|
|
59
|
+
});
|
|
60
|
+
it('renders correctly for excluded zeroes', function () {
|
|
61
|
+
var w = wrapper({
|
|
62
|
+
excludeZero: false
|
|
63
|
+
}, {
|
|
64
|
+
mount: true
|
|
65
|
+
});
|
|
66
|
+
expect(w.find(_reactBeautifulDnd.Draggable).length).toEqual(4);
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
describe('logic', function () {
|
|
71
|
+
describe('rendering', function () {});
|
|
72
|
+
describe('changeMaxPoints', function () {
|
|
73
|
+
var assertChangeMax = function assertChangeMax(points, excludeZero, expectedPoints, expectedSampleAnswers) {
|
|
74
|
+
it("".concat(points, " calls onChange with: ").concat(expectedPoints, " and ").concat(expectedSampleAnswers), function () {
|
|
75
|
+
var w = wrapper({
|
|
76
|
+
excludeZero: excludeZero
|
|
77
|
+
});
|
|
78
|
+
w.instance().changeMaxPoints(points);
|
|
79
|
+
expect(w.instance().props.onChange).toHaveBeenCalledWith({
|
|
80
|
+
excludeZero: excludeZero,
|
|
81
|
+
points: expectedPoints,
|
|
82
|
+
sampleAnswers: expectedSampleAnswers,
|
|
83
|
+
maxPoints: expectedPoints.length - 1
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
assertChangeMax(1, false, _lodash["default"].takeRight(points, 2), _lodash["default"].takeRight(sampleAnswers, 2));
|
|
89
|
+
assertChangeMax(1, true, _lodash["default"].takeRight(points, 2), _lodash["default"].takeRight(sampleAnswers, 2));
|
|
90
|
+
assertChangeMax(2, true, _lodash["default"].takeRight(points, 3), _lodash["default"].takeRight(sampleAnswers, 3));
|
|
91
|
+
assertChangeMax(2, false, _lodash["default"].takeRight(points, 3), _lodash["default"].takeRight(sampleAnswers, 3));
|
|
92
|
+
assertChangeMax(5, false, ['', ''].concat(points), [null, null].concat(sampleAnswers));
|
|
93
|
+
});
|
|
94
|
+
describe('changeSampleResponse', function () {
|
|
95
|
+
var assertChangeSample = function assertChangeSample(index, clickedItem, excludeZero, expectedPoints, expectedSampleAnswers) {
|
|
96
|
+
it("Point ".concat(index, " calls onChange with: ").concat(expectedPoints, " and ").concat(expectedSampleAnswers), function () {
|
|
97
|
+
var w = wrapper({
|
|
98
|
+
excludeZero: excludeZero
|
|
99
|
+
});
|
|
100
|
+
w.instance().onPointMenuChange(index, clickedItem);
|
|
101
|
+
expect(w.instance().props.onChange).toHaveBeenCalledWith({
|
|
102
|
+
excludeZero: excludeZero,
|
|
103
|
+
points: expectedPoints,
|
|
104
|
+
sampleAnswers: expectedSampleAnswers
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
assertChangeSample(0, 'sample', false, points, ['', 'just right', 'not left', null]);
|
|
110
|
+
assertChangeSample(3, 'sample', false, points, [null, 'just right', 'not left', '']);
|
|
111
|
+
assertChangeSample(1, 'sample', true, points, [null, null, 'not left', null]);
|
|
112
|
+
assertChangeSample(3, 'sample', true, points, [null, 'just right', 'not left', '']);
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/rubric.test.jsx"],"names":["jest","mock","describe","w","points","sampleAnswers","wrapper","value","opts","props","classes","onChange","fn","className","excludeZero","mount","shallow","it","expect","toMatchSnapshot","find","Draggable","length","toEqual","assertChangeMax","expectedPoints","expectedSampleAnswers","instance","changeMaxPoints","toHaveBeenCalledWith","maxPoints","_","takeRight","concat","assertChangeSample","index","clickedItem","onPointMenuChange"],"mappings":"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","sourcesContent":["import { shallow, mount } from 'enzyme';\nimport React from 'react';\nimport { RawAuthoring } from '../authoring';\nimport { Draggable } from 'react-beautiful-dnd';\nimport _ from 'lodash';\n\njest.mock('@pie-lib/editable-html', () => () => <div />);\n\ndescribe('Rubric', () => {\n  let w;\n\n  const points = ['nothing right', 'a teeny bit right', 'mostly right', 'bingo'];\n  const sampleAnswers = [null, 'just right', 'not left', null];\n  const wrapper = (value, opts) => {\n    const props = {\n      classes: {},\n      onChange: jest.fn(),\n      className: 'className',\n      value: {\n        excludeZero: false,\n        points,\n        sampleAnswers,\n        ...value,\n      },\n    };\n    const fn = opts && opts.mount ? mount : shallow;\n    return fn(<RawAuthoring {...props} />, opts);\n  };\n\n  describe('render', () => {\n    it('snapshot', () => {\n      w = wrapper();\n      expect(w).toMatchSnapshot();\n    });\n\n    describe('draggable', () => {\n      it('renders correctly for excluded zeroes', () => {\n        let w = wrapper({ excludeZero: true }, { mount: true });\n        expect(w.find(Draggable).length).toEqual(3);\n      });\n      it('renders correctly for excluded zeroes', () => {\n        let w = wrapper({ excludeZero: false }, { mount: true });\n        expect(w.find(Draggable).length).toEqual(4);\n      });\n    });\n  });\n\n  describe('logic', () => {\n    describe('rendering', () => {});\n\n    describe('changeMaxPoints', () => {\n      const assertChangeMax = (points, excludeZero, expectedPoints, expectedSampleAnswers) => {\n        it(`${points} calls onChange with: ${expectedPoints} and ${expectedSampleAnswers}`, () => {\n          let w = wrapper({ excludeZero });\n          w.instance().changeMaxPoints(points);\n          expect(w.instance().props.onChange).toHaveBeenCalledWith({\n            excludeZero,\n            points: expectedPoints,\n            sampleAnswers: expectedSampleAnswers,\n            maxPoints: expectedPoints.length - 1,\n          });\n        });\n      };\n\n      assertChangeMax(1, false, _.takeRight(points, 2), _.takeRight(sampleAnswers, 2));\n      assertChangeMax(1, true, _.takeRight(points, 2), _.takeRight(sampleAnswers, 2));\n      assertChangeMax(2, true, _.takeRight(points, 3), _.takeRight(sampleAnswers, 3));\n      assertChangeMax(2, false, _.takeRight(points, 3), _.takeRight(sampleAnswers, 3));\n      assertChangeMax(5, false, ['', ''].concat(points), [null, null].concat(sampleAnswers));\n    });\n\n    describe('changeSampleResponse', () => {\n      const assertChangeSample = (index, clickedItem, excludeZero, expectedPoints, expectedSampleAnswers) => {\n        it(`Point ${index} calls onChange with: ${expectedPoints} and ${expectedSampleAnswers}`, () => {\n          let w = wrapper({ excludeZero });\n          w.instance().onPointMenuChange(index, clickedItem);\n          expect(w.instance().props.onChange).toHaveBeenCalledWith({\n            excludeZero,\n            points: expectedPoints,\n            sampleAnswers: expectedSampleAnswers,\n          });\n        });\n      };\n\n      assertChangeSample(0, 'sample', false, points, ['', 'just right', 'not left', null]);\n      assertChangeSample(3, 'sample', false, points, [null, 'just right', 'not left', '']);\n      assertChangeSample(1, 'sample', true, points, [null, null, 'not left', null]);\n      assertChangeSample(3, 'sample', true, points, [null, 'just right', 'not left', '']);\n    });\n  });\n});\n"]}
|
package/lib/authoring.js
CHANGED
|
@@ -69,6 +69,8 @@ var _pointMenu = _interopRequireDefault(require("./point-menu"));
|
|
|
69
69
|
|
|
70
70
|
var _range = _interopRequireDefault(require("lodash/range"));
|
|
71
71
|
|
|
72
|
+
var _configUi = require("@pie-lib/config-ui");
|
|
73
|
+
|
|
72
74
|
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; }
|
|
73
75
|
|
|
74
76
|
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; }
|
|
@@ -94,7 +96,8 @@ var RubricType = _propTypes["default"].shape({
|
|
|
94
96
|
excludeZero: _propTypes["default"].bool,
|
|
95
97
|
points: _propTypes["default"].arrayOf(_propTypes["default"].string),
|
|
96
98
|
sampleAnswers: _propTypes["default"].arrayOf(_propTypes["default"].string),
|
|
97
|
-
maxPoints: _propTypes["default"].number
|
|
99
|
+
maxPoints: _propTypes["default"].number,
|
|
100
|
+
rubriclessInstruction: _propTypes["default"].string
|
|
98
101
|
});
|
|
99
102
|
|
|
100
103
|
exports.RubricType = RubricType;
|
|
@@ -124,7 +127,7 @@ var MaxPoints = (0, _styles.withStyles)(function (theme) {
|
|
|
124
127
|
input: /*#__PURE__*/_react["default"].createElement(_OutlinedInput["default"], {
|
|
125
128
|
labelWidth: 80
|
|
126
129
|
})
|
|
127
|
-
}, (0, _range["default"])(1, max).map(function (v) {
|
|
130
|
+
}, (0, _range["default"])(1, max + 1).map(function (v) {
|
|
128
131
|
return /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
|
|
129
132
|
key: "".concat(v),
|
|
130
133
|
value: v
|
|
@@ -164,6 +167,12 @@ var PointConfig = (0, _styles.withStyles)(function (theme) {
|
|
|
164
167
|
pointMenu: {
|
|
165
168
|
position: 'absolute',
|
|
166
169
|
right: 0
|
|
170
|
+
},
|
|
171
|
+
errorText: {
|
|
172
|
+
fontSize: theme.typography.fontSize - 2,
|
|
173
|
+
color: theme.palette.error.main,
|
|
174
|
+
paddingLeft: theme.spacing.unit * 3,
|
|
175
|
+
paddingTop: theme.spacing.unit
|
|
167
176
|
}
|
|
168
177
|
};
|
|
169
178
|
})(function (props) {
|
|
@@ -172,7 +181,10 @@ var PointConfig = (0, _styles.withStyles)(function (theme) {
|
|
|
172
181
|
classes = props.classes,
|
|
173
182
|
sampleAnswer = props.sampleAnswer,
|
|
174
183
|
_props$mathMlOptions = props.mathMlOptions,
|
|
175
|
-
mathMlOptions = _props$mathMlOptions === void 0 ? {} : _props$mathMlOptions
|
|
184
|
+
mathMlOptions = _props$mathMlOptions === void 0 ? {} : _props$mathMlOptions,
|
|
185
|
+
error = props.error,
|
|
186
|
+
_props$pluginOpts = props.pluginOpts,
|
|
187
|
+
pluginOpts = _props$pluginOpts === void 0 ? {} : _props$pluginOpts;
|
|
176
188
|
var pointsLabel = "".concat(points, " ").concat(points <= 1 ? 'pt' : 'pts');
|
|
177
189
|
var showSampleAnswer = checkSampleAnswer(sampleAnswer);
|
|
178
190
|
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
@@ -186,6 +198,8 @@ var PointConfig = (0, _styles.withStyles)(function (theme) {
|
|
|
186
198
|
className: classes.dragIndicator
|
|
187
199
|
}), /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
|
|
188
200
|
className: classes.editor,
|
|
201
|
+
error: error,
|
|
202
|
+
pluginProps: pluginOpts,
|
|
189
203
|
markup: content,
|
|
190
204
|
onChange: props.onChange,
|
|
191
205
|
mathMlOptions: mathMlOptions
|
|
@@ -195,7 +209,9 @@ var PointConfig = (0, _styles.withStyles)(function (theme) {
|
|
|
195
209
|
},
|
|
196
210
|
showSampleAnswer: showSampleAnswer,
|
|
197
211
|
onChange: props.onMenuChange
|
|
198
|
-
})),
|
|
212
|
+
})), error && /*#__PURE__*/_react["default"].createElement("div", {
|
|
213
|
+
className: classes.errorText
|
|
214
|
+
}, error), !showSampleAnswer && /*#__PURE__*/_react["default"].createElement("div", {
|
|
199
215
|
className: classes.sampleAnswersEditor
|
|
200
216
|
}, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
|
|
201
217
|
variant: "overline",
|
|
@@ -203,6 +219,7 @@ var PointConfig = (0, _styles.withStyles)(function (theme) {
|
|
|
203
219
|
}, "Sample Response"), /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
|
|
204
220
|
className: classes.editor,
|
|
205
221
|
markup: sampleAnswer,
|
|
222
|
+
pluginProps: pluginOpts,
|
|
206
223
|
onChange: props.onSampleChange,
|
|
207
224
|
mathMlOptions: mathMlOptions
|
|
208
225
|
})));
|
|
@@ -239,10 +256,19 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
239
256
|
sampleAnswers: sampleAnswers
|
|
240
257
|
}));
|
|
241
258
|
});
|
|
242
|
-
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "
|
|
259
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeRubriclessInstruction", function (input) {
|
|
243
260
|
var _this$props2 = _this.props,
|
|
244
261
|
value = _this$props2.value,
|
|
245
262
|
onChange = _this$props2.onChange;
|
|
263
|
+
onChange(_objectSpread(_objectSpread({}, value), {}, {
|
|
264
|
+
rubriclessInstruction: input
|
|
265
|
+
}));
|
|
266
|
+
});
|
|
267
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeMaxPoints", function (maxPoints) {
|
|
268
|
+
var _this$props3 = _this.props,
|
|
269
|
+
value = _this$props3.value,
|
|
270
|
+
onChange = _this$props3.onChange,
|
|
271
|
+
rubricless = _this$props3.rubricless;
|
|
246
272
|
var currentMax = value.points.length - 1;
|
|
247
273
|
log('current', currentMax, 'new: ', maxPoints);
|
|
248
274
|
var points, sampleAnswers;
|
|
@@ -262,10 +288,15 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
262
288
|
sampleAnswers = (0, _takeRight["default"])(value.sampleAnswers, maxPoints + 1);
|
|
263
289
|
}
|
|
264
290
|
|
|
265
|
-
if (points) {
|
|
291
|
+
if (points && !rubricless) {
|
|
266
292
|
onChange(_objectSpread(_objectSpread({}, value), {}, {
|
|
267
293
|
points: points,
|
|
268
|
-
sampleAnswers: sampleAnswers
|
|
294
|
+
sampleAnswers: sampleAnswers,
|
|
295
|
+
maxPoints: maxPoints
|
|
296
|
+
}));
|
|
297
|
+
} else {
|
|
298
|
+
onChange(_objectSpread(_objectSpread({}, value), {}, {
|
|
299
|
+
maxPoints: maxPoints
|
|
269
300
|
}));
|
|
270
301
|
}
|
|
271
302
|
});
|
|
@@ -277,18 +308,18 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
277
308
|
return;
|
|
278
309
|
}
|
|
279
310
|
|
|
280
|
-
var _this$
|
|
281
|
-
value = _this$
|
|
282
|
-
onChange = _this$
|
|
311
|
+
var _this$props4 = _this.props,
|
|
312
|
+
value = _this$props4.value,
|
|
313
|
+
onChange = _this$props4.onChange;
|
|
283
314
|
var items = value[type] && Array.from(value[type]);
|
|
284
315
|
items.splice(index, 1, content);
|
|
285
316
|
log("changeModel[".concat(type, "]:"), items);
|
|
286
317
|
onChange(_objectSpread(_objectSpread({}, value), {}, (0, _defineProperty2["default"])({}, type, items)));
|
|
287
318
|
});
|
|
288
319
|
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "excludeZeros", function () {
|
|
289
|
-
var _this$
|
|
290
|
-
value = _this$
|
|
291
|
-
onChange = _this$
|
|
320
|
+
var _this$props5 = _this.props,
|
|
321
|
+
value = _this$props5.value,
|
|
322
|
+
onChange = _this$props5.onChange;
|
|
292
323
|
onChange(_objectSpread(_objectSpread({}, value), {}, {
|
|
293
324
|
excludeZero: !value.excludeZero
|
|
294
325
|
}));
|
|
@@ -328,24 +359,48 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
328
359
|
value: function render() {
|
|
329
360
|
var _this2 = this;
|
|
330
361
|
|
|
331
|
-
var _this$
|
|
332
|
-
classes = _this$
|
|
333
|
-
className = _this$
|
|
334
|
-
value = _this$
|
|
335
|
-
_this$
|
|
336
|
-
mathMlOptions = _this$
|
|
362
|
+
var _this$props6 = this.props,
|
|
363
|
+
classes = _this$props6.classes,
|
|
364
|
+
className = _this$props6.className,
|
|
365
|
+
value = _this$props6.value,
|
|
366
|
+
_this$props6$mathMlOp = _this$props6.mathMlOptions,
|
|
367
|
+
mathMlOptions = _this$props6$mathMlOp === void 0 ? {} : _this$props6$mathMlOp,
|
|
368
|
+
_this$props6$config = _this$props6.config,
|
|
369
|
+
config = _this$props6$config === void 0 ? {} : _this$props6$config,
|
|
370
|
+
_this$props6$rubricle = _this$props6.rubricless,
|
|
371
|
+
rubricless = _this$props6$rubricle === void 0 ? false : _this$props6$rubricle,
|
|
372
|
+
_this$props6$pluginOp = _this$props6.pluginOpts,
|
|
373
|
+
pluginOpts = _this$props6$pluginOp === void 0 ? {} : _this$props6$pluginOp;
|
|
337
374
|
|
|
338
375
|
var _ref = value || {},
|
|
339
376
|
_ref$excludeZeroEnabl = _ref.excludeZeroEnabled,
|
|
340
377
|
excludeZeroEnabled = _ref$excludeZeroEnabl === void 0 ? true : _ref$excludeZeroEnabl,
|
|
341
378
|
_ref$maxPointsEnabled = _ref.maxPointsEnabled,
|
|
342
|
-
maxPointsEnabled = _ref$maxPointsEnabled === void 0 ? true : _ref$maxPointsEnabled
|
|
379
|
+
maxPointsEnabled = _ref$maxPointsEnabled === void 0 ? true : _ref$maxPointsEnabled,
|
|
380
|
+
_ref$errors = _ref.errors,
|
|
381
|
+
errors = _ref$errors === void 0 ? {} : _ref$errors,
|
|
382
|
+
_ref$rubriclessInstru = _ref.rubriclessInstructionEnabled,
|
|
383
|
+
rubriclessInstructionEnabled = _ref$rubriclessInstru === void 0 ? false : _ref$rubriclessInstru,
|
|
384
|
+
_ref$maxPoints = _ref.maxPoints,
|
|
385
|
+
maxPoints = _ref$maxPoints === void 0 ? 10 : _ref$maxPoints; // rubric will contain a max value for maxPoints
|
|
386
|
+
|
|
387
|
+
|
|
388
|
+
var _ref2 = config || {},
|
|
389
|
+
_ref2$rubriclessInstr = _ref2.rubriclessInstruction,
|
|
390
|
+
rubriclessInstruction = _ref2$rubriclessInstr === void 0 ? {} : _ref2$rubriclessInstr,
|
|
391
|
+
_ref2$maxMaxPoints = _ref2.maxMaxPoints,
|
|
392
|
+
maxMaxPoints = _ref2$maxMaxPoints === void 0 ? 10 : _ref2$maxMaxPoints;
|
|
393
|
+
|
|
394
|
+
var _ref3 = errors || {},
|
|
395
|
+
pointsDescriptorsErrors = _ref3.pointsDescriptorsErrors;
|
|
343
396
|
|
|
344
397
|
if (value && Number.isFinite(value.maxPoints)) {
|
|
345
398
|
// eslint-disable-next-line no-console
|
|
346
399
|
console.warn('maxPoints is deprecated - remove from model');
|
|
347
|
-
}
|
|
400
|
+
} // for rubric value is computed based on points
|
|
348
401
|
|
|
402
|
+
|
|
403
|
+
var maxPointsValue = !rubricless ? value.points.length - 1 : maxPoints;
|
|
349
404
|
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
350
405
|
className: (0, _classnames["default"])(classes["class"], className)
|
|
351
406
|
}, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
|
|
@@ -354,17 +409,34 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
354
409
|
}, "Rubric"), /*#__PURE__*/_react["default"].createElement(_FormGroup["default"], {
|
|
355
410
|
row: true
|
|
356
411
|
}, maxPointsEnabled && /*#__PURE__*/_react["default"].createElement(MaxPoints, {
|
|
357
|
-
max:
|
|
358
|
-
value:
|
|
359
|
-
onChange: this.changeMaxPoints
|
|
412
|
+
max: maxMaxPoints < 100 ? maxMaxPoints : 100,
|
|
413
|
+
value: maxPointsValue,
|
|
414
|
+
onChange: this.changeMaxPoints,
|
|
415
|
+
pluginOpts: pluginOpts
|
|
360
416
|
}), excludeZeroEnabled && /*#__PURE__*/_react["default"].createElement(_FormControlLabel["default"], {
|
|
361
417
|
label: "Exclude zeros",
|
|
362
418
|
control: /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
363
419
|
checked: value.excludeZero,
|
|
364
420
|
onChange: this.excludeZeros
|
|
365
421
|
})
|
|
422
|
+
})), rubriclessInstructionEnabled && rubricless && /*#__PURE__*/_react["default"].createElement(_configUi.InputContainer, {
|
|
423
|
+
label: rubriclessInstruction.label,
|
|
424
|
+
className: classes.inputContainer
|
|
425
|
+
}, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
|
|
426
|
+
className: classes.input,
|
|
427
|
+
markup: value.rubriclessInstruction || '',
|
|
428
|
+
onChange: this.changeRubriclessInstruction,
|
|
429
|
+
pluginProps: pluginOpts,
|
|
430
|
+
nonEmpty: false,
|
|
431
|
+
disableUnderline: true,
|
|
432
|
+
languageCharactersProps: [{
|
|
433
|
+
language: 'spanish'
|
|
434
|
+
}, {
|
|
435
|
+
language: 'special'
|
|
436
|
+
}],
|
|
437
|
+
mathMlOptions: mathMlOptions
|
|
366
438
|
})), /*#__PURE__*/_react["default"].createElement("div", {
|
|
367
|
-
className: classes.container
|
|
439
|
+
className: rubricless ? classes.rubricless : classes.container
|
|
368
440
|
}, /*#__PURE__*/_react["default"].createElement(_reactBeautifulDnd.DragDropContext, {
|
|
369
441
|
onDragEnd: this.dragEnd
|
|
370
442
|
}, /*#__PURE__*/_react["default"].createElement(_reactBeautifulDnd.Droppable, {
|
|
@@ -384,6 +456,7 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
384
456
|
}, provided.draggableProps, provided.dragHandleProps), /*#__PURE__*/_react["default"].createElement(PointConfig, {
|
|
385
457
|
points: value.points.length - 1 - index,
|
|
386
458
|
content: p,
|
|
459
|
+
error: pointsDescriptorsErrors && pointsDescriptorsErrors[value.points.length - 1 - index],
|
|
387
460
|
sampleAnswer: value.sampleAnswers && value.sampleAnswers[index],
|
|
388
461
|
onChange: function onChange(content) {
|
|
389
462
|
return _this2.changeContent(index, content, 'points');
|
|
@@ -394,7 +467,8 @@ var RawAuthoring = /*#__PURE__*/function (_React$Component) {
|
|
|
394
467
|
onMenuChange: function onMenuChange(clickedItem) {
|
|
395
468
|
return _this2.onPointMenuChange(index, clickedItem);
|
|
396
469
|
},
|
|
397
|
-
mathMlOptions: mathMlOptions
|
|
470
|
+
mathMlOptions: mathMlOptions,
|
|
471
|
+
pluginOpts: pluginOpts
|
|
398
472
|
}));
|
|
399
473
|
});
|
|
400
474
|
}), provided.placeholder);
|
|
@@ -409,6 +483,9 @@ exports.RawAuthoring = RawAuthoring;
|
|
|
409
483
|
classes: _propTypes["default"].object.isRequired,
|
|
410
484
|
className: _propTypes["default"].string,
|
|
411
485
|
value: RubricType,
|
|
486
|
+
config: _propTypes["default"].object,
|
|
487
|
+
pluginOpts: _propTypes["default"].object,
|
|
488
|
+
rubricless: _propTypes["default"].bool,
|
|
412
489
|
onChange: _propTypes["default"].func
|
|
413
490
|
});
|
|
414
491
|
(0, _defineProperty2["default"])(RawAuthoring, "defaultProps", {});
|
|
@@ -423,6 +500,14 @@ var styles = function styles(theme) {
|
|
|
423
500
|
padding: theme.spacing.unit * 2,
|
|
424
501
|
margin: theme.spacing.unit
|
|
425
502
|
},
|
|
503
|
+
inputContainer: {
|
|
504
|
+
width: '100%',
|
|
505
|
+
paddingTop: theme.spacing.unit * 2,
|
|
506
|
+
marginBottom: theme.spacing.unit * 2
|
|
507
|
+
},
|
|
508
|
+
rubricless: {
|
|
509
|
+
display: 'none'
|
|
510
|
+
},
|
|
426
511
|
configHolder: {
|
|
427
512
|
paddingTop: theme.spacing.unit,
|
|
428
513
|
paddingBottom: theme.spacing.unit
|
|
@@ -437,6 +522,14 @@ var styles = function styles(theme) {
|
|
|
437
522
|
var StyledRawAuthoring = (0, _styles.withStyles)(styles)(RawAuthoring);
|
|
438
523
|
|
|
439
524
|
var Reverse = function Reverse(props) {
|
|
525
|
+
var _ref4 = props || {},
|
|
526
|
+
_ref4$rubricless = _ref4.rubricless,
|
|
527
|
+
rubricless = _ref4$rubricless === void 0 ? false : _ref4$rubricless,
|
|
528
|
+
_ref4$config = _ref4.config,
|
|
529
|
+
config = _ref4$config === void 0 ? {} : _ref4$config,
|
|
530
|
+
_ref4$pluginOpts = _ref4.pluginOpts,
|
|
531
|
+
pluginOpts = _ref4$pluginOpts === void 0 ? {} : _ref4$pluginOpts;
|
|
532
|
+
|
|
440
533
|
var points = Array.from(props.value.points || []).reverse();
|
|
441
534
|
var sampleAnswers = Array.from(props.value.sampleAnswers || []).reverse();
|
|
442
535
|
|
|
@@ -460,15 +553,21 @@ var Reverse = function Reverse(props) {
|
|
|
460
553
|
|
|
461
554
|
return /*#__PURE__*/_react["default"].createElement(StyledRawAuthoring, {
|
|
462
555
|
value: value,
|
|
463
|
-
|
|
556
|
+
config: config,
|
|
557
|
+
onChange: onChange,
|
|
558
|
+
rubricless: rubricless,
|
|
559
|
+
pluginOpts: pluginOpts
|
|
464
560
|
});
|
|
465
561
|
};
|
|
466
562
|
|
|
467
563
|
Reverse.propTypes = {
|
|
468
564
|
value: RubricType,
|
|
565
|
+
config: _propTypes["default"].object,
|
|
566
|
+
pluginOpts: _propTypes["default"].object,
|
|
567
|
+
rubricless: _propTypes["default"].bool,
|
|
469
568
|
getIndex: _propTypes["default"].func,
|
|
470
569
|
onChange: _propTypes["default"].func
|
|
471
570
|
};
|
|
472
571
|
var _default = Reverse;
|
|
473
572
|
exports["default"] = _default;
|
|
474
|
-
//# sourceMappingURL=authoring.js.map
|
|
573
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/authoring.jsx"],"names":["log","reorder","list","startIndex","endIndex","result","Array","from","splice","removed","RubricType","PropTypes","shape","excludeZero","bool","points","arrayOf","string","sampleAnswers","maxPoints","number","rubriclessInstruction","MaxPoints","theme","formControl","minWidth","margin","spacing","unit","props","value","onChange","max","classes","e","target","map","v","checkSampleAnswer","sampleAnswer","PointConfig","pointConfig","row","display","width","position","editor","backgroundColor","palette","common","white","dragIndicator","paddingTop","color","grey","pointsLabel","paddingBottom","textTransform","sampleAnswersEditor","paddingLeft","pointMenu","right","errorText","fontSize","typography","error","main","content","mathMlOptions","pluginOpts","showSampleAnswer","icon","onMenuChange","onSampleChange","RawAuthoring","destination","source","index","input","rubricless","currentMax","length","concat","type","items","clickedItem","changeContent","className","config","excludeZeroEnabled","maxPointsEnabled","errors","rubriclessInstructionEnabled","maxMaxPoints","pointsDescriptorsErrors","Number","isFinite","console","warn","maxPointsValue","rubricTitle","changeMaxPoints","excludeZeros","label","inputContainer","changeRubriclessInstruction","language","container","dragEnd","provided","droppableProps","innerRef","p","shouldRenderPoint","toString","configHolder","draggableProps","dragHandleProps","onPointMenuChange","placeholder","React","Component","object","isRequired","func","styles","borderWidth","borderStyle","borderColor","padding","marginBottom","StyledRawAuthoring","Reverse","reverse","propTypes","getIndex"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;;;;;;;;;AAEA,IAAMA,GAAG,GAAG,uBAAM,0BAAN,CAAZ;;AAEA,IAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,IAAD,EAAOC,UAAP,EAAmBC,QAAnB,EAAgC;AAC9C,MAAMC,MAAM,GAAGC,KAAK,CAACC,IAAN,CAAWL,IAAX,CAAf;;AACA,uBAAkBG,MAAM,CAACG,MAAP,CAAcL,UAAd,EAA0B,CAA1B,CAAlB;AAAA;AAAA,MAAOM,OAAP;;AAEAJ,EAAAA,MAAM,CAACG,MAAP,CAAcJ,QAAd,EAAwB,CAAxB,EAA2BK,OAA3B;AAEA,SAAOJ,MAAP;AACD,CAPD;;AASO,IAAMK,UAAU,GAAGC,sBAAUC,KAAV,CAAgB;AACxCC,EAAAA,WAAW,EAAEF,sBAAUG,IADiB;AAExCC,EAAAA,MAAM,EAAEJ,sBAAUK,OAAV,CAAkBL,sBAAUM,MAA5B,CAFgC;AAGxCC,EAAAA,aAAa,EAAEP,sBAAUK,OAAV,CAAkBL,sBAAUM,MAA5B,CAHyB;AAIxCE,EAAAA,SAAS,EAAER,sBAAUS,MAJmB;AAKxCC,EAAAA,qBAAqB,EAAEV,sBAAUM;AALO,CAAhB,CAAnB;;;AAQP,IAAMK,SAAS,GAAG,wBAAW,UAACC,KAAD;AAAA,SAAY;AACvCC,IAAAA,WAAW,EAAE;AACXC,MAAAA,QAAQ,EAAE,OADC;AAEXC,MAAAA,MAAM,EAAEH,KAAK,CAACI,OAAN,CAAcC;AAFX;AAD0B,GAAZ;AAAA,CAAX,EAKd,UAACC,KAAD,EAAW;AACb,MAAQC,KAAR,GAA0CD,KAA1C,CAAQC,KAAR;AAAA,MAAeC,SAAf,GAA0CF,KAA1C,CAAeE,QAAf;AAAA,MAAyBC,GAAzB,GAA0CH,KAA1C,CAAyBG,GAAzB;AAAA,MAA8BC,OAA9B,GAA0CJ,KAA1C,CAA8BI,OAA9B;AAEA,sBACE,gCAAC,uBAAD;AAAa,IAAA,SAAS,EAAEA,OAAO,CAACT,WAAhC;AAA6C,IAAA,OAAO,EAAC;AAArD,kBACE,gCAAC,sBAAD;AAAY,IAAA,KAAK,EAAE,GAAnB;AAAwB,IAAA,OAAO,EAAC;AAAhC,kBADF,eAIE,gCAAC,kBAAD;AAAQ,IAAA,KAAK,EAAEM,KAAf;AAAsB,IAAA,QAAQ,EAAE,kBAACI,CAAD;AAAA,aAAOH,SAAQ,CAACG,CAAC,CAACC,MAAF,CAASL,KAAV,CAAf;AAAA,KAAhC;AAAiE,IAAA,KAAK,eAAE,gCAAC,yBAAD;AAAe,MAAA,UAAU,EAAE;AAA3B;AAAxE,KACG,uBAAM,CAAN,EAASE,GAAG,GAAG,CAAf,EAAkBI,GAAlB,CAAsB,UAACC,CAAD;AAAA,wBACrB,gCAAC,oBAAD;AAAU,MAAA,GAAG,YAAKA,CAAL,CAAb;AAAuB,MAAA,KAAK,EAAEA;AAA9B,OACGA,CADH,CADqB;AAAA,GAAtB,CADH,CAJF,CADF;AAcD,CAtBiB,CAAlB,C,CAwBA;AACA;;AACA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACC,YAAD;AAAA,SAAkBA,YAAY,KAAK,IAAjB,IAAyBA,YAAY,KAAK,MAA5D;AAAA,CAA1B;;AAEO,IAAMC,WAAW,GAAG,wBAAW,UAACjB,KAAD;AAAA,SAAY;AAChDkB,IAAAA,WAAW,EAAE,EADmC;AAEhDC,IAAAA,GAAG,EAAE;AACHC,MAAAA,OAAO,EAAE,MADN;AAEHC,MAAAA,KAAK,EAAE,MAFJ;AAGHC,MAAAA,QAAQ,EAAE;AAHP,KAF2C;AAOhDC,IAAAA,MAAM,EAAE;AACNF,MAAAA,KAAK,EAAE,MADD;AAENG,MAAAA,eAAe,YAAKxB,KAAK,CAACyB,OAAN,CAAcC,MAAd,CAAqBC,KAA1B;AAFT,KAPwC;AAWhDC,IAAAA,aAAa,EAAE;AACbC,MAAAA,UAAU,EAAE7B,KAAK,CAACI,OAAN,CAAcC,IADb;AAEbyB,MAAAA,KAAK,EAAEC,iBAAK,GAAL;AAFM,KAXiC;AAehDC,IAAAA,WAAW,EAAE;AACXF,MAAAA,KAAK,EAAEC,iBAAK,GAAL,CADI;AAEXE,MAAAA,aAAa,EAAEjC,KAAK,CAACI,OAAN,CAAcC,IAFlB;AAGX6B,MAAAA,aAAa,EAAE;AAHJ,KAfmC;AAoBhDC,IAAAA,mBAAmB,EAAE;AACnBC,MAAAA,WAAW,EAAEpC,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB;AADf,KApB2B;AAuBhDgC,IAAAA,SAAS,EAAE;AACTf,MAAAA,QAAQ,EAAE,UADD;AAETgB,MAAAA,KAAK,EAAE;AAFE,KAvBqC;AA2BhDC,IAAAA,SAAS,EAAE;AACTC,MAAAA,QAAQ,EAAExC,KAAK,CAACyC,UAAN,CAAiBD,QAAjB,GAA4B,CAD7B;AAETV,MAAAA,KAAK,EAAE9B,KAAK,CAACyB,OAAN,CAAciB,KAAd,CAAoBC,IAFlB;AAGTP,MAAAA,WAAW,EAAEpC,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB,CAHzB;AAITwB,MAAAA,UAAU,EAAE7B,KAAK,CAACI,OAAN,CAAcC;AAJjB;AA3BqC,GAAZ;AAAA,CAAX,EAiCvB,UAACC,KAAD,EAAW;AACb,MAAQd,MAAR,GAA+Fc,KAA/F,CAAQd,MAAR;AAAA,MAAgBoD,OAAhB,GAA+FtC,KAA/F,CAAgBsC,OAAhB;AAAA,MAAyBlC,OAAzB,GAA+FJ,KAA/F,CAAyBI,OAAzB;AAAA,MAAkCM,YAAlC,GAA+FV,KAA/F,CAAkCU,YAAlC;AAAA,6BAA+FV,KAA/F,CAAgDuC,aAAhD;AAAA,MAAgDA,aAAhD,qCAAgE,EAAhE;AAAA,MAAoEH,KAApE,GAA+FpC,KAA/F,CAAoEoC,KAApE;AAAA,0BAA+FpC,KAA/F,CAA2EwC,UAA3E;AAAA,MAA2EA,UAA3E,kCAAwF,EAAxF;AACA,MAAMd,WAAW,aAAMxC,MAAN,cAAgBA,MAAM,IAAI,CAAV,GAAc,IAAd,GAAqB,KAArC,CAAjB;AACA,MAAMuD,gBAAgB,GAAGhC,iBAAiB,CAACC,YAAD,CAA1C;AAEA,sBACE;AAAK,IAAA,SAAS,EAAEN,OAAO,CAACQ;AAAxB,kBACE,gCAAC,sBAAD;AAAY,IAAA,OAAO,EAAC,UAApB;AAA+B,IAAA,SAAS,EAAER,OAAO,CAACsB;AAAlD,KACGA,WADH,CADF,eAKE;AAAK,IAAA,SAAS,EAAEtB,OAAO,CAACS;AAAxB,kBACE,gCAAC,yBAAD;AAAe,IAAA,SAAS,EAAET,OAAO,CAACkB;AAAlC,IADF,eAEE,gCAAC,wBAAD;AACE,IAAA,SAAS,EAAElB,OAAO,CAACa,MADrB;AAEE,IAAA,KAAK,EAAEmB,KAFT;AAGE,IAAA,WAAW,EAAEI,UAHf;AAIE,IAAA,MAAM,EAAEF,OAJV;AAKE,IAAA,QAAQ,EAAEtC,KAAK,CAACE,QALlB;AAME,IAAA,aAAa,EAAEqC;AANjB,IAFF,eAUE,gCAAC,qBAAD;AACE,IAAA,OAAO,EAAE;AACPG,MAAAA,IAAI,EAAEtC,OAAO,CAAC2B;AADP,KADX;AAIE,IAAA,gBAAgB,EAAEU,gBAJpB;AAKE,IAAA,QAAQ,EAAEzC,KAAK,CAAC2C;AALlB,IAVF,CALF,EAuBGP,KAAK,iBAAI;AAAK,IAAA,SAAS,EAAEhC,OAAO,CAAC6B;AAAxB,KAAoCG,KAApC,CAvBZ,EAwBG,CAACK,gBAAD,iBACC;AAAK,IAAA,SAAS,EAAErC,OAAO,CAACyB;AAAxB,kBACE,gCAAC,sBAAD;AAAY,IAAA,OAAO,EAAC,UAApB;AAA+B,IAAA,SAAS,EAAEzB,OAAO,CAACkB;AAAlD,uBADF,eAIE,gCAAC,wBAAD;AACE,IAAA,SAAS,EAAElB,OAAO,CAACa,MADrB;AAEE,IAAA,MAAM,EAAEP,YAFV;AAGE,IAAA,WAAW,EAAE8B,UAHf;AAIE,IAAA,QAAQ,EAAExC,KAAK,CAAC4C,cAJlB;AAKE,IAAA,aAAa,EAAEL;AALjB,IAJF,CAzBJ,CADF;AAyCD,CA/E0B,CAApB;;;IAiFMM,Y;;;;;;;;;;;;;;;gGAaD,UAACrE,MAAD,EAAY;AACpB,UAAI,CAACA,MAAM,CAACsE,WAAZ,EAAyB;AACvB;AACD;;AAED,wBAA4B,MAAK9C,KAAjC;AAAA,UAAQC,KAAR,eAAQA,KAAR;AAAA,UAAeC,QAAf,eAAeA,QAAf;AAEA,UAAMhB,MAAM,GAAGd,OAAO,CAAC6B,KAAK,CAACf,MAAP,EAAeV,MAAM,CAACuE,MAAP,CAAcC,KAA7B,EAAoCxE,MAAM,CAACsE,WAAP,CAAmBE,KAAvD,CAAtB;AACA,UAAM3D,aAAa,GAAGjB,OAAO,CAAC6B,KAAK,CAACZ,aAAP,EAAsBb,MAAM,CAACuE,MAAP,CAAcC,KAApC,EAA2CxE,MAAM,CAACsE,WAAP,CAAmBE,KAA9D,CAA7B;AAEA9C,MAAAA,QAAQ,iCAAMD,KAAN;AAAaf,QAAAA,MAAM,EAANA,MAAb;AAAqBG,QAAAA,aAAa,EAAbA;AAArB,SAAR;AACD,K;oHAE6B,UAAC4D,KAAD,EAAW;AACvC,yBAA4B,MAAKjD,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AACAA,MAAAA,QAAQ,iCAAMD,KAAN;AAAaT,QAAAA,qBAAqB,EAAEyD;AAApC,SAAR;AACD,K;wGAEiB,UAAC3D,SAAD,EAAe;AAC/B,yBAAwC,MAAKU,KAA7C;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AAAA,UAAyBgD,UAAzB,gBAAyBA,UAAzB;AACA,UAAMC,UAAU,GAAGlD,KAAK,CAACf,MAAN,CAAakE,MAAb,GAAsB,CAAzC;AAEAjF,MAAAA,GAAG,CAAC,SAAD,EAAYgF,UAAZ,EAAwB,OAAxB,EAAiC7D,SAAjC,CAAH;AAEA,UAAIJ,MAAJ,EAAYG,aAAZ;;AACA,UAAIC,SAAS,GAAG6D,UAAhB,EAA4B;AAC1BjE,QAAAA,MAAM,GAAG,uBAAMI,SAAS,GAAG6D,UAAlB,EACN5C,GADM,CACF;AAAA,iBAAM,EAAN;AAAA,SADE,EAEN8C,MAFM,CAECpD,KAAK,CAACf,MAFP,CAAT;AAGAG,QAAAA,aAAa,GAAG,uBAAMC,SAAS,GAAG6D,UAAlB,EACb5C,GADa,CACT;AAAA,iBAAM,IAAN;AAAA,SADS,EAEb8C,MAFa,CAENpD,KAAK,CAACZ,aAFA,CAAhB;AAGD;;AAED,UAAIC,SAAS,GAAG6D,UAAhB,EAA4B;AAC1BhF,QAAAA,GAAG,CAAC,WAAD,CAAH;AACAe,QAAAA,MAAM,GAAG,2BAAUe,KAAK,CAACf,MAAhB,EAAwBI,SAAS,GAAG,CAApC,CAAT;AACAD,QAAAA,aAAa,GAAG,2BAAUY,KAAK,CAACZ,aAAhB,EAA+BC,SAAS,GAAG,CAA3C,CAAhB;AACD;;AAED,UAAIJ,MAAM,IAAI,CAACgE,UAAf,EAA2B;AACzBhD,QAAAA,QAAQ,iCAAMD,KAAN;AAAaf,UAAAA,MAAM,EAANA,MAAb;AAAqBG,UAAAA,aAAa,EAAbA,aAArB;AAAoCC,UAAAA,SAAS,EAATA;AAApC,WAAR;AACD,OAFD,MAEO;AACLY,QAAAA,QAAQ,iCAAMD,KAAN;AAAaX,UAAAA,SAAS,EAATA;AAAb,WAAR;AACD;AACF,K;sGAEe,UAAC0D,KAAD,EAAQV,OAAR,EAAiBgB,IAAjB,EAA0B;AACxC;AACAnF,MAAAA,GAAG,uBAAgBmF,IAAhB,SAA0BN,KAA1B,EAAiCV,OAAjC,CAAH;;AAEA,UAAIgB,IAAI,KAAK,QAAT,IAAqBA,IAAI,KAAK,eAAlC,EAAmD;AACjD;AACD;;AAED,yBAA4B,MAAKtD,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AACA,UAAMqD,KAAK,GAAGtD,KAAK,CAACqD,IAAD,CAAL,IAAe7E,KAAK,CAACC,IAAN,CAAWuB,KAAK,CAACqD,IAAD,CAAhB,CAA7B;AAEAC,MAAAA,KAAK,CAAC5E,MAAN,CAAaqE,KAAb,EAAoB,CAApB,EAAuBV,OAAvB;AACAnE,MAAAA,GAAG,uBAAgBmF,IAAhB,SAA0BC,KAA1B,CAAH;AAEArD,MAAAA,QAAQ,iCAAMD,KAAN,4CAAcqD,IAAd,EAAqBC,KAArB,GAAR;AACD,K;qGAEc,YAAM;AACnB,yBAA4B,MAAKvD,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AAEAA,MAAAA,QAAQ,iCAAMD,KAAN;AAAajB,QAAAA,WAAW,EAAE,CAACiB,KAAK,CAACjB;AAAjC,SAAR;AACD,K;0GAEmB,UAACgE,KAAD,EAAQ/C,KAAR,EAAkB;AACpC,UAAI,CAACA,KAAK,CAACjB,WAAX,EAAwB;AACtB,eAAO,IAAP;AACD,OAFD,MAEO;AACL,YAAIgE,KAAK,GAAG/C,KAAK,CAACf,MAAN,CAAakE,MAAb,GAAsB,CAAlC,EAAqC;AACnC,iBAAO,IAAP;AACD,SAFD,MAEO,IAAIJ,KAAK,KAAK/C,KAAK,CAACf,MAAN,CAAakE,MAAb,GAAsB,CAApC,EAAuC;AAC5C,iBAAO,KAAP;AACD;;AAED,eAAO,IAAP;AACD;AACF,K;0GAEmB,UAACJ,KAAD,EAAQQ,WAAR,EAAwB;AAC1C,UAAIA,WAAW,KAAK,QAApB,EAA8B;AAC5B,YAAQvD,KAAR,GAAkB,MAAKD,KAAvB,CAAQC,KAAR;AACA,YAAMZ,aAAa,GAAGZ,KAAK,CAACC,IAAN,CAAWuB,KAAK,CAACZ,aAAN,IAAuB,EAAlC,CAAtB;;AAEA,YAAIoB,iBAAiB,CAACpB,aAAa,CAAC2D,KAAD,CAAd,CAArB,EAA6C;AAC3C;AACA,gBAAKS,aAAL,CAAmBT,KAAnB,EAA0B,EAA1B,EAA8B,eAA9B;AACD,SAHD,MAGO;AACL;AACA,gBAAKS,aAAL,CAAmBT,KAAnB,EAA0B,IAA1B,EAAgC,eAAhC;AACD;AACF;AACF,K;;;;;;WAED,kBAAS;AAAA;;AACP,yBAQI,KAAKhD,KART;AAAA,UACEI,OADF,gBACEA,OADF;AAAA,UAEEsD,SAFF,gBAEEA,SAFF;AAAA,UAGEzD,KAHF,gBAGEA,KAHF;AAAA,+CAIEsC,aAJF;AAAA,UAIEA,aAJF,sCAIkB,EAJlB;AAAA,6CAKEoB,MALF;AAAA,UAKEA,MALF,oCAKW,EALX;AAAA,+CAMET,UANF;AAAA,UAMEA,UANF,sCAMe,KANf;AAAA,+CAOEV,UAPF;AAAA,UAOEA,UAPF,sCAOe,EAPf;;AASA,iBAMIvC,KAAK,IAAI,EANb;AAAA,uCACE2D,kBADF;AAAA,UACEA,kBADF,sCACuB,IADvB;AAAA,uCAEEC,gBAFF;AAAA,UAEEA,gBAFF,sCAEqB,IAFrB;AAAA,6BAGEC,MAHF;AAAA,UAGEA,MAHF,4BAGW,EAHX;AAAA,uCAIEC,4BAJF;AAAA,UAIEA,4BAJF,sCAIiC,KAJjC;AAAA,gCAKEzE,SALF;AAAA,UAKEA,SALF,+BAKc,EALd,kBAVO,CAiBP;;;AACA,kBAA0DqE,MAAM,IAAI,EAApE;AAAA,wCAAQnE,qBAAR;AAAA,UAAQA,qBAAR,sCAAgC,EAAhC;AAAA,qCAAoCwE,YAApC;AAAA,UAAoCA,YAApC,mCAAmD,EAAnD;;AACA,kBAAoCF,MAAM,IAAI,EAA9C;AAAA,UAAQG,uBAAR,SAAQA,uBAAR;;AACA,UAAIhE,KAAK,IAAIiE,MAAM,CAACC,QAAP,CAAgBlE,KAAK,CAACX,SAAtB,CAAb,EAA+C;AAC7C;AACA8E,QAAAA,OAAO,CAACC,IAAR,CAAa,6CAAb;AACD,OAvBM,CAyBP;;;AACA,UAAMC,cAAc,GAAG,CAACpB,UAAD,GAAcjD,KAAK,CAACf,MAAN,CAAakE,MAAb,GAAsB,CAApC,GAAwC9D,SAA/D;AAEA,0BACE;AAAK,QAAA,SAAS,EAAE,4BAAWc,OAAO,SAAlB,EAA0BsD,SAA1B;AAAhB,sBACE,gCAAC,sBAAD;AAAY,QAAA,OAAO,EAAC,IAApB;AAAyB,QAAA,SAAS,EAAEtD,OAAO,CAACmE;AAA5C,kBADF,eAIE,gCAAC,qBAAD;AAAW,QAAA,GAAG;AAAd,SACGV,gBAAgB,iBACf,gCAAC,SAAD;AACE,QAAA,GAAG,EAAEG,YAAY,GAAG,GAAf,GAAqBA,YAArB,GAAoC,GAD3C;AAEE,QAAA,KAAK,EAAEM,cAFT;AAGE,QAAA,QAAQ,EAAE,KAAKE,eAHjB;AAIE,QAAA,UAAU,EAAEhC;AAJd,QAFJ,EASGoB,kBAAkB,iBACjB,gCAAC,4BAAD;AACE,QAAA,KAAK,EAAC,eADR;AAEE,QAAA,OAAO,eAAE,gCAAC,oBAAD;AAAU,UAAA,OAAO,EAAE3D,KAAK,CAACjB,WAAzB;AAAsC,UAAA,QAAQ,EAAE,KAAKyF;AAArD;AAFX,QAVJ,CAJF,EAqBGV,4BAA4B,IAAIb,UAAhC,iBACC,gCAAC,wBAAD;AAAgB,QAAA,KAAK,EAAE1D,qBAAqB,CAACkF,KAA7C;AAAoD,QAAA,SAAS,EAAEtE,OAAO,CAACuE;AAAvE,sBACE,gCAAC,wBAAD;AACE,QAAA,SAAS,EAAEvE,OAAO,CAAC6C,KADrB;AAEE,QAAA,MAAM,EAAEhD,KAAK,CAACT,qBAAN,IAA+B,EAFzC;AAGE,QAAA,QAAQ,EAAE,KAAKoF,2BAHjB;AAIE,QAAA,WAAW,EAAEpC,UAJf;AAKE,QAAA,QAAQ,EAAE,KALZ;AAME,QAAA,gBAAgB,MANlB;AAOE,QAAA,uBAAuB,EAAE,CAAC;AAAEqC,UAAAA,QAAQ,EAAE;AAAZ,SAAD,EAA0B;AAAEA,UAAAA,QAAQ,EAAE;AAAZ,SAA1B,CAP3B;AAQE,QAAA,aAAa,EAAEtC;AARjB,QADF,CAtBJ,eAoCE;AAAK,QAAA,SAAS,EAAEW,UAAU,GAAG9C,OAAO,CAAC8C,UAAX,GAAwB9C,OAAO,CAAC0E;AAA1D,sBACE,gCAAC,kCAAD;AAAiB,QAAA,SAAS,EAAE,KAAKC;AAAjC,sBACE,gCAAC,4BAAD;AAAW,QAAA,WAAW,EAAC;AAAvB,SACG,UAACC,QAAD;AAAA,4BACC,qEAASA,QAAQ,CAACC,cAAlB;AAAkC,UAAA,GAAG,EAAED,QAAQ,CAACE;AAAhD,YACGjF,KAAK,CAACf,MAAN,CAAaqB,GAAb,CACC,UAAC4E,CAAD,EAAInC,KAAJ;AAAA,iBACE,MAAI,CAACoC,iBAAL,CAAuBpC,KAAvB,EAA8B/C,KAA9B,kBACE,gCAAC,4BAAD;AAAW,YAAA,GAAG,YAAKkF,CAAC,CAACjG,MAAP,cAAiB8D,KAAjB,CAAd;AAAwC,YAAA,KAAK,EAAEA,KAA/C;AAAsD,YAAA,WAAW,EAAEA,KAAK,CAACqC,QAAN;AAAnE,aACG,UAACL,QAAD;AAAA,gCACC;AACE,cAAA,SAAS,EAAE5E,OAAO,CAACkF,YADrB;AAEE,cAAA,GAAG,EAAEN,QAAQ,CAACE;AAFhB,eAGMF,QAAQ,CAACO,cAHf,EAIMP,QAAQ,CAACQ,eAJf,gBAME,gCAAC,WAAD;AACE,cAAA,MAAM,EAAEvF,KAAK,CAACf,MAAN,CAAakE,MAAb,GAAsB,CAAtB,GAA0BJ,KADpC;AAEE,cAAA,OAAO,EAAEmC,CAFX;AAGE,cAAA,KAAK,EACHlB,uBAAuB,IAAIA,uBAAuB,CAAChE,KAAK,CAACf,MAAN,CAAakE,MAAb,GAAsB,CAAtB,GAA0BJ,KAA3B,CAJtD;AAME,cAAA,YAAY,EAAE/C,KAAK,CAACZ,aAAN,IAAuBY,KAAK,CAACZ,aAAN,CAAoB2D,KAApB,CANvC;AAOE,cAAA,QAAQ,EAAE,kBAACV,OAAD;AAAA,uBAAa,MAAI,CAACmB,aAAL,CAAmBT,KAAnB,EAA0BV,OAA1B,EAAmC,QAAnC,CAAb;AAAA,eAPZ;AAQE,cAAA,cAAc,EAAE,wBAACA,OAAD;AAAA,uBAAa,MAAI,CAACmB,aAAL,CAAmBT,KAAnB,EAA0BV,OAA1B,EAAmC,eAAnC,CAAb;AAAA,eARlB;AASE,cAAA,YAAY,EAAE,sBAACkB,WAAD;AAAA,uBAAiB,MAAI,CAACiC,iBAAL,CAAuBzC,KAAvB,EAA8BQ,WAA9B,CAAjB;AAAA,eAThB;AAUE,cAAA,aAAa,EAAEjB,aAVjB;AAWE,cAAA,UAAU,EAAEC;AAXd,cANF,CADD;AAAA,WADH,CAFJ;AAAA,SADD,CADH,EA8BGwC,QAAQ,CAACU,WA9BZ,CADD;AAAA,OADH,CADF,CADF,CApCF,CADF;AA+ED;;;EA3N+BC,kBAAMC,S;;;iCAA3B/C,Y,eACQ;AACjBzC,EAAAA,OAAO,EAAEtB,sBAAU+G,MAAV,CAAiBC,UADT;AAEjBpC,EAAAA,SAAS,EAAE5E,sBAAUM,MAFJ;AAGjBa,EAAAA,KAAK,EAAEpB,UAHU;AAIjB8E,EAAAA,MAAM,EAAE7E,sBAAU+G,MAJD;AAKjBrD,EAAAA,UAAU,EAAE1D,sBAAU+G,MALL;AAMjB3C,EAAAA,UAAU,EAAEpE,sBAAUG,IANL;AAOjBiB,EAAAA,QAAQ,EAAEpB,sBAAUiH;AAPH,C;iCADRlD,Y,kBAWW,E;;AAmNxB,IAAMmD,MAAM,GAAG,SAATA,MAAS,CAACtG,KAAD;AAAA,SAAY;AACzBoF,IAAAA,SAAS,EAAE;AACT5D,MAAAA,eAAe,EAAEO,iBAAK,GAAL,CADR;AAETwE,MAAAA,WAAW,EAAE,CAFJ;AAGTC,MAAAA,WAAW,EAAE,OAHJ;AAITC,MAAAA,WAAW,EAAE1E,iBAAK,GAAL,CAJJ;AAKT2E,MAAAA,OAAO,EAAE1G,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB,CALrB;AAMTF,MAAAA,MAAM,EAAEH,KAAK,CAACI,OAAN,CAAcC;AANb,KADc;AASzB4E,IAAAA,cAAc,EAAE;AACd5D,MAAAA,KAAK,EAAE,MADO;AAEdQ,MAAAA,UAAU,EAAE7B,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB,CAFnB;AAGdsG,MAAAA,YAAY,EAAE3G,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB;AAHrB,KATS;AAczBmD,IAAAA,UAAU,EAAE;AACVpC,MAAAA,OAAO,EAAE;AADC,KAda;AAiBzBwE,IAAAA,YAAY,EAAE;AACZ/D,MAAAA,UAAU,EAAE7B,KAAK,CAACI,OAAN,CAAcC,IADd;AAEZ4B,MAAAA,aAAa,EAAEjC,KAAK,CAACI,OAAN,CAAcC;AAFjB,KAjBW;AAqBzBwE,IAAAA,WAAW,EAAE;AACXzC,MAAAA,WAAW,EAAEpC,KAAK,CAACI,OAAN,CAAcC,IADhB;AAEXF,MAAAA,MAAM,EAAEH,KAAK,CAACI,OAAN,CAAcC;AAFX;AArBY,GAAZ;AAAA,CAAf;;AA2BA,IAAMuG,kBAAkB,GAAG,wBAAWN,MAAX,EAAmBnD,YAAnB,CAA3B;;AAEA,IAAM0D,OAAO,GAAG,SAAVA,OAAU,CAACvG,KAAD,EAAW;AACzB,cAA6DA,KAAK,IAAI,EAAtE;AAAA,+BAAQkD,UAAR;AAAA,MAAQA,UAAR,iCAAqB,KAArB;AAAA,2BAA4BS,MAA5B;AAAA,MAA4BA,MAA5B,6BAAqC,EAArC;AAAA,+BAAyCnB,UAAzC;AAAA,MAAyCA,UAAzC,iCAAsD,EAAtD;;AACA,MAAMtD,MAAM,GAAGT,KAAK,CAACC,IAAN,CAAWsB,KAAK,CAACC,KAAN,CAAYf,MAAZ,IAAsB,EAAjC,EAAqCsH,OAArC,EAAf;AACA,MAAInH,aAAa,GAAGZ,KAAK,CAACC,IAAN,CAAWsB,KAAK,CAACC,KAAN,CAAYZ,aAAZ,IAA6B,EAAxC,EAA4CmH,OAA5C,EAApB;;AAEA,MAAItH,MAAM,CAACkE,MAAP,GAAgB/D,aAAa,CAAC+D,MAAlC,EAA0C;AACxC/D,IAAAA,aAAa,GAAG,uBAAMH,MAAM,CAACkE,MAAP,GAAgB/D,aAAa,CAAC+D,MAApC,EACb7C,GADa,CACT;AAAA,aAAM,IAAN;AAAA,KADS,EAEb8C,MAFa,CAENhE,aAFM,CAAhB;AAGD;;AAED,MAAMY,KAAK,mCAAQD,KAAK,CAACC,KAAd;AAAqBf,IAAAA,MAAM,EAANA,MAArB;AAA6BG,IAAAA,aAAa,EAAbA;AAA7B,IAAX;;AAEA,MAAMa,QAAQ,GAAG,SAAXA,QAAW,CAACD,KAAD,EAAW;AAC1BD,IAAAA,KAAK,CAACE,QAAN,iCACKD,KADL;AAEEf,MAAAA,MAAM,EAAET,KAAK,CAACC,IAAN,CAAWuB,KAAK,CAACf,MAAN,IAAgB,EAA3B,EAA+BsH,OAA/B,EAFV;AAGEnH,MAAAA,aAAa,EAAEZ,KAAK,CAACC,IAAN,CAAWuB,KAAK,CAACZ,aAAN,IAAuB,EAAlC,EAAsCmH,OAAtC;AAHjB;AAKD,GAND;;AAQA,sBACE,gCAAC,kBAAD;AACE,IAAA,KAAK,EAAEvG,KADT;AAEE,IAAA,MAAM,EAAE0D,MAFV;AAGE,IAAA,QAAQ,EAAEzD,QAHZ;AAIE,IAAA,UAAU,EAAEgD,UAJd;AAKE,IAAA,UAAU,EAAEV;AALd,IADF;AASD,CA9BD;;AAgCA+D,OAAO,CAACE,SAAR,GAAoB;AAClBxG,EAAAA,KAAK,EAAEpB,UADW;AAElB8E,EAAAA,MAAM,EAAE7E,sBAAU+G,MAFA;AAGlBrD,EAAAA,UAAU,EAAE1D,sBAAU+G,MAHJ;AAIlB3C,EAAAA,UAAU,EAAEpE,sBAAUG,IAJJ;AAKlByH,EAAAA,QAAQ,EAAE5H,sBAAUiH,IALF;AAMlB7F,EAAAA,QAAQ,EAAEpB,sBAAUiH;AANF,CAApB;eASeQ,O","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport OutlinedInput from '@material-ui/core/OutlinedInput';\nimport InputLabel from '@material-ui/core/InputLabel';\nimport Select from '@material-ui/core/Select';\nimport FormControl from '@material-ui/core/FormControl';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport times from 'lodash/times';\nimport Checkbox from '@material-ui/core/Checkbox';\nimport FormGroup from '@material-ui/core/FormGroup';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport grey from '@material-ui/core/colors/grey';\nimport Typography from '@material-ui/core/Typography';\nimport DragIndicator from '@material-ui/icons/DragIndicator';\nimport EditableHtml from '@pie-lib/editable-html';\nimport { DragDropContext, Droppable, Draggable } from 'react-beautiful-dnd';\nimport debug from 'debug';\nimport takeRight from 'lodash/takeRight';\nimport PointMenu from './point-menu';\n\nimport range from 'lodash/range';\nimport { InputContainer } from '@pie-lib/config-ui';\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 = withStyles((theme) => ({\n  formControl: {\n    minWidth: '120px',\n    margin: theme.spacing.unit,\n  },\n}))((props) => {\n  const { value, onChange, max, classes } = props;\n\n  return (\n    <FormControl className={classes.formControl} variant=\"outlined\">\n      <InputLabel width={100} htmlFor=\"...\">\n        Max Points\n      </InputLabel>\n      <Select value={value} onChange={(e) => onChange(e.target.value)} input={<OutlinedInput labelWidth={80} />}>\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\nexport const PointConfig = withStyles((theme) => ({\n  pointConfig: {},\n  row: {\n    display: 'flex',\n    width: '100%',\n    position: 'relative',\n  },\n  editor: {\n    width: '100%',\n    backgroundColor: `${theme.palette.common.white} !important`,\n  },\n  dragIndicator: {\n    paddingTop: theme.spacing.unit,\n    color: grey[500],\n  },\n  pointsLabel: {\n    color: grey[500],\n    paddingBottom: theme.spacing.unit,\n    textTransform: 'uppercase',\n  },\n  sampleAnswersEditor: {\n    paddingLeft: theme.spacing.unit * 3,\n  },\n  pointMenu: {\n    position: 'absolute',\n    right: 0,\n  },\n  errorText: {\n    fontSize: theme.typography.fontSize - 2,\n    color: theme.palette.error.main,\n    paddingLeft: theme.spacing.unit * 3,\n    paddingTop: theme.spacing.unit,\n  },\n}))((props) => {\n  const { points, content, classes, sampleAnswer, mathMlOptions = {}, error, pluginOpts = {} } = props;\n  const pointsLabel = `${points} ${points <= 1 ? 'pt' : 'pts'}`;\n  const showSampleAnswer = checkSampleAnswer(sampleAnswer);\n\n  return (\n    <div className={classes.pointConfig}>\n      <Typography variant=\"overline\" className={classes.pointsLabel}>\n        {pointsLabel}\n      </Typography>\n\n      <div className={classes.row}>\n        <DragIndicator className={classes.dragIndicator} />\n        <EditableHtml\n          className={classes.editor}\n          error={error}\n          pluginProps={pluginOpts}\n          markup={content}\n          onChange={props.onChange}\n          mathMlOptions={mathMlOptions}\n        />\n        <PointMenu\n          classes={{\n            icon: classes.pointMenu,\n          }}\n          showSampleAnswer={showSampleAnswer}\n          onChange={props.onMenuChange}\n        />\n      </div>\n      {error && <div className={classes.errorText}>{error}</div>}\n      {!showSampleAnswer && (\n        <div className={classes.sampleAnswersEditor}>\n          <Typography variant=\"overline\" className={classes.dragIndicator}>\n            Sample Response\n          </Typography>\n          <EditableHtml\n            className={classes.editor}\n            markup={sampleAnswer}\n            pluginProps={pluginOpts}\n            onChange={props.onSampleChange}\n            mathMlOptions={mathMlOptions}\n          />\n        </div>\n      )}\n    </div>\n  );\n});\n\nexport class RawAuthoring extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object.isRequired,\n    className: PropTypes.string,\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 {\n      classes,\n      className,\n      value,\n      mathMlOptions = {},\n      config = {},\n      rubricless = false,\n      pluginOpts = {},\n    } = 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 className={classNames(classes.class, className)}>\n        <Typography variant=\"h5\" className={classes.rubricTitle}>\n          Rubric\n        </Typography>\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          <InputContainer label={rubriclessInstruction.label} className={classes.inputContainer}>\n            <EditableHtml\n              className={classes.input}\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        )}\n\n        <div className={rubricless ? classes.rubricless : classes.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                            <div\n                              className={classes.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 && 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                            </div>\n                          )}\n                        </Draggable>\n                      ),\n                  )}\n                  {provided.placeholder}\n                </div>\n              )}\n            </Droppable>\n          </DragDropContext>\n        </div>\n      </div>\n    );\n  }\n}\n\nconst styles = (theme) => ({\n  container: {\n    backgroundColor: grey[200],\n    borderWidth: 1,\n    borderStyle: 'solid',\n    borderColor: grey[300],\n    padding: theme.spacing.unit * 2,\n    margin: theme.spacing.unit,\n  },\n  inputContainer: {\n    width: '100%',\n    paddingTop: theme.spacing.unit * 2,\n    marginBottom: theme.spacing.unit * 2,\n  },\n  rubricless: {\n    display: 'none',\n  },\n  configHolder: {\n    paddingTop: theme.spacing.unit,\n    paddingBottom: theme.spacing.unit,\n  },\n  rubricTitle: {\n    paddingLeft: theme.spacing.unit,\n    margin: theme.spacing.unit,\n  },\n});\n\nconst StyledRawAuthoring = withStyles(styles)(RawAuthoring);\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    <StyledRawAuthoring\n      value={value}\n      config={config}\n      onChange={onChange}\n      rubricless={rubricless}\n      pluginOpts={pluginOpts}\n    />\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"]}
|
package/lib/index.js
CHANGED
|
@@ -17,7 +17,8 @@ var _authoring = _interopRequireDefault(require("./authoring"));
|
|
|
17
17
|
|
|
18
18
|
var RUBRIC_TYPES = {
|
|
19
19
|
SIMPLE_RUBRIC: 'simpleRubric',
|
|
20
|
-
MULTI_TRAIT_RUBRIC: 'multiTraitRubric'
|
|
20
|
+
MULTI_TRAIT_RUBRIC: 'multiTraitRubric',
|
|
21
|
+
RUBRICLESS: 'rubricless'
|
|
21
22
|
};
|
|
22
23
|
exports.RUBRIC_TYPES = RUBRIC_TYPES;
|
|
23
|
-
//# sourceMappingURL=
|
|
24
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJSVUJSSUNfVFlQRVMiLCJTSU1QTEVfUlVCUklDIiwiTVVMVElfVFJBSVRfUlVCUklDIiwiUlVCUklDTEVTUyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBRUEsSUFBTUEsWUFBWSxHQUFHO0FBQ25CQyxFQUFBQSxhQUFhLEVBQUUsY0FESTtBQUVuQkMsRUFBQUEsa0JBQWtCLEVBQUUsa0JBRkQ7QUFHbkJDLEVBQUFBLFVBQVUsRUFBRTtBQUhPLENBQXJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEF1dGhvcmluZyBmcm9tICcuL2F1dGhvcmluZyc7XG5cbmNvbnN0IFJVQlJJQ19UWVBFUyA9IHtcbiAgU0lNUExFX1JVQlJJQzogJ3NpbXBsZVJ1YnJpYycsXG4gIE1VTFRJX1RSQUlUX1JVQlJJQzogJ211bHRpVHJhaXRSdWJyaWMnLFxuICBSVUJSSUNMRVNTOiAncnVicmljbGVzcycsXG59O1xuXG5leHBvcnQgeyBBdXRob3JpbmcsIFJVQlJJQ19UWVBFUyB9O1xuIl19
|
package/lib/point-menu.js
CHANGED
|
@@ -169,4 +169,4 @@ exports["default"] = PointMenu;
|
|
|
169
169
|
(0, _defineProperty2["default"])(PointMenu, "defaultProps", {
|
|
170
170
|
classes: {}
|
|
171
171
|
});
|
|
172
|
-
//# sourceMappingURL=
|
|
172
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wb2ludC1tZW51LmpzeCJdLCJuYW1lcyI6WyJJY29uTWVudSIsInByb3BzIiwiZXZlbnQiLCJzZXRTdGF0ZSIsIm9wZW4iLCJhbmNob3JFbCIsImN1cnJlbnRUYXJnZXQiLCJzdGF0ZSIsInVuZGVmaW5lZCIsIm9wdHMiLCJvbkNsaWNrIiwiY2xhc3NlcyIsImtleXMiLCJPYmplY3QiLCJoYW5kbGVNZW51Q2xpY2siLCJrZXkiLCJoYW5kbGVSZXF1ZXN0Q2xvc2UiLCJpY29uQ29sb3IiLCJoYW5kbGVDbGljayIsImljb24iLCJ0cmFuc2Zvcm0iLCJ2ZXJ0aWNhbCIsImhvcml6b250YWwiLCJtYXAiLCJrIiwiaW5kZXgiLCJSZWFjdCIsIkNvbXBvbmVudCIsIlByb3BUeXBlcyIsIm9iamVjdCIsImZ1bmMiLCJpc1JlcXVpcmVkIiwiUG9pbnRNZW51Iiwib25DaGFuZ2UiLCJzaG93U2FtcGxlQW5zd2VyIiwic2FtcGxlVGV4dCIsInNhbXBsZSIsImJvb2wiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7OztJQUVhQSxROzs7OztBQU9YLG9CQUFZQyxLQUFaLEVBQW1CO0FBQUE7O0FBQUE7QUFDakIsOEJBQU1BLEtBQU47QUFEaUIsb0dBUUwsVUFBQ0MsS0FBRDtBQUFBLGFBQVcsTUFBS0MsUUFBTCxDQUFjO0FBQUVDLFFBQUFBLElBQUksRUFBRSxJQUFSO0FBQWNDLFFBQUFBLFFBQVEsRUFBRUgsS0FBSyxDQUFDSTtBQUE5QixPQUFkLENBQVg7QUFBQSxLQVJLO0FBQUEsMkdBVUU7QUFBQSxhQUFNLE1BQUtILFFBQUwsQ0FBYztBQUFFQyxRQUFBQSxJQUFJLEVBQUU7QUFBUixPQUFkLENBQU47QUFBQSxLQVZGO0FBRWpCLFVBQUtHLEtBQUwsR0FBYTtBQUNYRixNQUFBQSxRQUFRLEVBQUVHLFNBREM7QUFFWEosTUFBQUEsSUFBSSxFQUFFO0FBRkss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RUFBRUwsc0JBQVVFLElBQVYsQ0FBZUMsVUFEUjtBQUVqQnBCLEVBQUFBLE9BQU8sRUFBRWlCLHNCQUFVQyxNQUFWLENBQWlCRSxVQUZUO0FBR2pCRyxFQUFBQSxnQkFBZ0IsRUFBRU4sc0JBQVVTLElBQVYsQ0FBZU47QUFIaEIsQztpQ0FEQUMsUyxrQkFPRztBQUNwQnJCLEVBQUFBLE9BQU8sRUFBRTtBQURXLEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTWVudSBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9NZW51JztcbmltcG9ydCBNZW51SXRlbSBmcm9tICdAbWF0ZXJpYWwtdWkvY29yZS9NZW51SXRlbSc7XG5pbXBvcnQgTW9yZVZlcnRJY29uIGZyb20gJ0BtYXRlcmlhbC11aS9pY29ucy9Nb3JlVmVydCc7XG5pbXBvcnQgTW9yZUhvcml6SWNvbiBmcm9tICdAbWF0ZXJpYWwtdWkvaWNvbnMvTW9yZUhvcml6JztcbmltcG9ydCBJY29uQnV0dG9uIGZyb20gJ0BtYXRlcmlhbC11aS9jb3JlL0ljb25CdXR0b24nO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCBjbGFzcyBJY29uTWVudSBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgb3B0czogUHJvcFR5cGVzLm9iamVjdCxcbiAgICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgfTtcblxuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnN0YXRlID0ge1xuICAgICAgYW5jaG9yRWw6IHVuZGVmaW5lZCxcbiAgICAgIG9wZW46IGZhbHNlLFxuICAgIH07XG4gIH1cblxuICBoYW5kbGVDbGljayA9IChldmVudCkgPT4gdGhpcy5zZXRTdGF0ZSh7IG9wZW46IHRydWUsIGFuY2hvckVsOiBldmVudC5jdXJyZW50VGFyZ2V0IH0pO1xuXG4gIGhhbmRsZVJlcXVlc3RDbG9zZSA9ICgpID0+IHRoaXMuc2V0U3RhdGUoeyBvcGVuOiBmYWxzZSB9KTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBvcHRzLCBvbkNsaWNrLCBjbGFzc2VzIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IHsgb3BlbiwgYW5jaG9yRWwgfSA9IHRoaXMuc3RhdGU7XG4gICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKG9wdHMpIHx8IFtdO1xuXG4gICAgY29uc3QgaGFuZGxlTWVudUNsaWNrID0gKGtleSkgPT4gKCkgPT4ge1xuICAgICAgb25DbGljayhrZXkpO1xuICAgICAgdGhpcy5oYW5kbGVSZXF1ZXN0Q2xvc2UoKTtcbiAgICB9O1xuXG4gICAgY29uc3QgaWNvbkNvbG9yID0gb3BlbiA/ICdpbmhlcml0JyA6ICdkaXNhYmxlZCc7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdj5cbiAgICAgICAgPGRpdiBvbkNsaWNrPXt0aGlzLmhhbmRsZUNsaWNrfT5cbiAgICAgICAgICA8SWNvbkJ1dHRvbiBjbGFzc05hbWU9e2NsYXNzZXMuaWNvbn0+XG4gICAgICAgICAgICB7b3BlbiA/IDxNb3JlVmVydEljb24gY29sb3I9e2ljb25Db2xvcn0gLz4gOiA8TW9yZUhvcml6SWNvbiBjb2xvcj17aWNvbkNvbG9yfSAvPn1cbiAgICAgICAgICA8L0ljb25CdXR0b24+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8TWVudVxuICAgICAgICAgIGlkPVwicG9pbnQtbWVudVwiXG4gICAgICAgICAgYW5jaG9yRWw9e2FuY2hvckVsfVxuICAgICAgICAgIG9wZW49e29wZW59XG4gICAgICAgICAgb25DbG9zZT17dGhpcy5oYW5kbGVSZXF1ZXN0Q2xvc2V9XG4gICAgICAgICAgc3R5bGU9e3sgdHJhbnNmb3JtOiAndHJhbnNsYXRlKC0xNXB4LCAtMTVweCknIH19XG4gICAgICAgICAgdHJhbnNmb3JtT3JpZ2luPXt7XG4gICAgICAgICAgICB2ZXJ0aWNhbDogJ2NlbnRlcicsXG4gICAgICAgICAgICBob3Jpem9udGFsOiAncmlnaHQnLFxuICAgICAgICAgIH19XG4gICAgICAgID5cbiAgICAgICAgICB7a2V5cy5tYXAoKGssIGluZGV4KSA9PiAoXG4gICAgICAgICAgICA8TWVudUl0ZW0ga2V5PXtpbmRleH0gb25DbGljaz17aGFuZGxlTWVudUNsaWNrKGspfT5cbiAgICAgICAgICAgICAge29wdHNba119XG4gICAgICAgICAgICA8L01lbnVJdGVtPlxuICAgICAgICAgICkpfVxuICAgICAgICA8L01lbnU+XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFBvaW50TWVudSBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gICAgY2xhc3NlczogUHJvcFR5cGVzLm9iamVjdC5pc1JlcXVpcmVkLFxuICAgIHNob3dTYW1wbGVBbnN3ZXI6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBjbGFzc2VzOiB7fSxcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBvbkNoYW5nZSwgY2xhc3Nlcywgc2hvd1NhbXBsZUFuc3dlciB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBzYW1wbGVUZXh0ID0gc2hvd1NhbXBsZUFuc3dlciA/ICdQcm92aWRlIFNhbXBsZSBSZXNwb25zZScgOiAnUmVtb3ZlIFNhbXBsZSBSZXNwb25zZSc7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPEljb25NZW51XG4gICAgICAgIG9uQ2xpY2s9eyhrZXkpID0+IG9uQ2hhbmdlKGtleSl9XG4gICAgICAgIG9wdHM9e3tcbiAgICAgICAgICBzYW1wbGU6IHNhbXBsZVRleHQsXG4gICAgICAgIH19XG4gICAgICAgIGNsYXNzZXM9e2NsYXNzZXN9XG4gICAgICAvPlxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pie-lib/rubric",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.10.0-beta.0",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"dependencies": {
|
|
10
10
|
"@material-ui/core": "^3.9.3",
|
|
11
11
|
"@material-ui/icons": "^3.0.2",
|
|
12
|
-
"@pie-lib/editable-html": "^11.
|
|
12
|
+
"@pie-lib/editable-html": "^11.3.0-beta.0",
|
|
13
13
|
"debug": "^4.1.1",
|
|
14
14
|
"editable-html": "npm:@pie-lib/editable-html@^7.21.0",
|
|
15
15
|
"lodash": "^4.17.11",
|
|
@@ -18,5 +18,5 @@
|
|
|
18
18
|
"react-beautiful-dnd": "^11.0.2",
|
|
19
19
|
"react-dom": "^16.9.0"
|
|
20
20
|
},
|
|
21
|
-
"gitHead": "
|
|
21
|
+
"gitHead": "3818c24530f62b5bb9be7a2c6aa5428f13a17e0a"
|
|
22
22
|
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
+
|
|
3
|
+
exports[`Rubric render snapshot 1`] = `
|
|
4
|
+
<div
|
|
5
|
+
className="className"
|
|
6
|
+
>
|
|
7
|
+
<WithStyles(Typography)
|
|
8
|
+
variant="h5"
|
|
9
|
+
>
|
|
10
|
+
Rubric
|
|
11
|
+
</WithStyles(Typography)>
|
|
12
|
+
<WithStyles(FormGroup)
|
|
13
|
+
row={true}
|
|
14
|
+
>
|
|
15
|
+
<WithStyles(Component)
|
|
16
|
+
max={10}
|
|
17
|
+
onChange={[Function]}
|
|
18
|
+
pluginOpts={Object {}}
|
|
19
|
+
value={3}
|
|
20
|
+
/>
|
|
21
|
+
<WithStyles(WithFormControlContext(FormControlLabel))
|
|
22
|
+
control={
|
|
23
|
+
<WithStyles(Checkbox)
|
|
24
|
+
checked={false}
|
|
25
|
+
onChange={[Function]}
|
|
26
|
+
/>
|
|
27
|
+
}
|
|
28
|
+
label="Exclude zeros"
|
|
29
|
+
/>
|
|
30
|
+
</WithStyles(FormGroup)>
|
|
31
|
+
<div>
|
|
32
|
+
<DragDropContext
|
|
33
|
+
onDragEnd={[Function]}
|
|
34
|
+
>
|
|
35
|
+
<Connect(Droppable)
|
|
36
|
+
direction="vertical"
|
|
37
|
+
droppableId="droppable"
|
|
38
|
+
ignoreContainerClipping={false}
|
|
39
|
+
isCombineEnabled={false}
|
|
40
|
+
isDropDisabled={false}
|
|
41
|
+
type="DEFAULT"
|
|
42
|
+
>
|
|
43
|
+
<Component />
|
|
44
|
+
</Connect(Droppable)>
|
|
45
|
+
</DragDropContext>
|
|
46
|
+
</div>
|
|
47
|
+
</div>
|
|
48
|
+
`;
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { shallow, mount } from 'enzyme';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { RawAuthoring } from '../authoring';
|
|
4
|
+
import { Draggable } from 'react-beautiful-dnd';
|
|
5
|
+
import _ from 'lodash';
|
|
6
|
+
|
|
7
|
+
jest.mock('@pie-lib/editable-html', () => () => <div />);
|
|
8
|
+
|
|
9
|
+
describe('Rubric', () => {
|
|
10
|
+
let w;
|
|
11
|
+
|
|
12
|
+
const points = ['nothing right', 'a teeny bit right', 'mostly right', 'bingo'];
|
|
13
|
+
const sampleAnswers = [null, 'just right', 'not left', null];
|
|
14
|
+
const wrapper = (value, opts) => {
|
|
15
|
+
const props = {
|
|
16
|
+
classes: {},
|
|
17
|
+
onChange: jest.fn(),
|
|
18
|
+
className: 'className',
|
|
19
|
+
value: {
|
|
20
|
+
excludeZero: false,
|
|
21
|
+
points,
|
|
22
|
+
sampleAnswers,
|
|
23
|
+
...value,
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
const fn = opts && opts.mount ? mount : shallow;
|
|
27
|
+
return fn(<RawAuthoring {...props} />, opts);
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
describe('render', () => {
|
|
31
|
+
it('snapshot', () => {
|
|
32
|
+
w = wrapper();
|
|
33
|
+
expect(w).toMatchSnapshot();
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
describe('draggable', () => {
|
|
37
|
+
it('renders correctly for excluded zeroes', () => {
|
|
38
|
+
let w = wrapper({ excludeZero: true }, { mount: true });
|
|
39
|
+
expect(w.find(Draggable).length).toEqual(3);
|
|
40
|
+
});
|
|
41
|
+
it('renders correctly for excluded zeroes', () => {
|
|
42
|
+
let w = wrapper({ excludeZero: false }, { mount: true });
|
|
43
|
+
expect(w.find(Draggable).length).toEqual(4);
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe('logic', () => {
|
|
49
|
+
describe('rendering', () => {});
|
|
50
|
+
|
|
51
|
+
describe('changeMaxPoints', () => {
|
|
52
|
+
const assertChangeMax = (points, excludeZero, expectedPoints, expectedSampleAnswers) => {
|
|
53
|
+
it(`${points} calls onChange with: ${expectedPoints} and ${expectedSampleAnswers}`, () => {
|
|
54
|
+
let w = wrapper({ excludeZero });
|
|
55
|
+
w.instance().changeMaxPoints(points);
|
|
56
|
+
expect(w.instance().props.onChange).toHaveBeenCalledWith({
|
|
57
|
+
excludeZero,
|
|
58
|
+
points: expectedPoints,
|
|
59
|
+
sampleAnswers: expectedSampleAnswers,
|
|
60
|
+
maxPoints: expectedPoints.length - 1,
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
assertChangeMax(1, false, _.takeRight(points, 2), _.takeRight(sampleAnswers, 2));
|
|
66
|
+
assertChangeMax(1, true, _.takeRight(points, 2), _.takeRight(sampleAnswers, 2));
|
|
67
|
+
assertChangeMax(2, true, _.takeRight(points, 3), _.takeRight(sampleAnswers, 3));
|
|
68
|
+
assertChangeMax(2, false, _.takeRight(points, 3), _.takeRight(sampleAnswers, 3));
|
|
69
|
+
assertChangeMax(5, false, ['', ''].concat(points), [null, null].concat(sampleAnswers));
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
describe('changeSampleResponse', () => {
|
|
73
|
+
const assertChangeSample = (index, clickedItem, excludeZero, expectedPoints, expectedSampleAnswers) => {
|
|
74
|
+
it(`Point ${index} calls onChange with: ${expectedPoints} and ${expectedSampleAnswers}`, () => {
|
|
75
|
+
let w = wrapper({ excludeZero });
|
|
76
|
+
w.instance().onPointMenuChange(index, clickedItem);
|
|
77
|
+
expect(w.instance().props.onChange).toHaveBeenCalledWith({
|
|
78
|
+
excludeZero,
|
|
79
|
+
points: expectedPoints,
|
|
80
|
+
sampleAnswers: expectedSampleAnswers,
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
assertChangeSample(0, 'sample', false, points, ['', 'just right', 'not left', null]);
|
|
86
|
+
assertChangeSample(3, 'sample', false, points, [null, 'just right', 'not left', '']);
|
|
87
|
+
assertChangeSample(1, 'sample', true, points, [null, null, 'not left', null]);
|
|
88
|
+
assertChangeSample(3, 'sample', true, points, [null, 'just right', 'not left', '']);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
});
|
package/src/authoring.jsx
CHANGED
|
@@ -21,6 +21,8 @@ import takeRight from 'lodash/takeRight';
|
|
|
21
21
|
import PointMenu from './point-menu';
|
|
22
22
|
|
|
23
23
|
import range from 'lodash/range';
|
|
24
|
+
import { InputContainer } from '@pie-lib/config-ui';
|
|
25
|
+
|
|
24
26
|
const log = debug('pie-lib:rubric:authoring');
|
|
25
27
|
|
|
26
28
|
const reorder = (list, startIndex, endIndex) => {
|
|
@@ -37,6 +39,7 @@ export const RubricType = PropTypes.shape({
|
|
|
37
39
|
points: PropTypes.arrayOf(PropTypes.string),
|
|
38
40
|
sampleAnswers: PropTypes.arrayOf(PropTypes.string),
|
|
39
41
|
maxPoints: PropTypes.number,
|
|
42
|
+
rubriclessInstruction: PropTypes.string,
|
|
40
43
|
});
|
|
41
44
|
|
|
42
45
|
const MaxPoints = withStyles((theme) => ({
|
|
@@ -53,7 +56,7 @@ const MaxPoints = withStyles((theme) => ({
|
|
|
53
56
|
Max Points
|
|
54
57
|
</InputLabel>
|
|
55
58
|
<Select value={value} onChange={(e) => onChange(e.target.value)} input={<OutlinedInput labelWidth={80} />}>
|
|
56
|
-
{range(1, max).map((v) => (
|
|
59
|
+
{range(1, max + 1).map((v) => (
|
|
57
60
|
<MenuItem key={`${v}`} value={v}>
|
|
58
61
|
{v}
|
|
59
62
|
</MenuItem>
|
|
@@ -94,8 +97,14 @@ export const PointConfig = withStyles((theme) => ({
|
|
|
94
97
|
position: 'absolute',
|
|
95
98
|
right: 0,
|
|
96
99
|
},
|
|
100
|
+
errorText: {
|
|
101
|
+
fontSize: theme.typography.fontSize - 2,
|
|
102
|
+
color: theme.palette.error.main,
|
|
103
|
+
paddingLeft: theme.spacing.unit * 3,
|
|
104
|
+
paddingTop: theme.spacing.unit,
|
|
105
|
+
},
|
|
97
106
|
}))((props) => {
|
|
98
|
-
const { points, content, classes, sampleAnswer, mathMlOptions = {} } = props;
|
|
107
|
+
const { points, content, classes, sampleAnswer, mathMlOptions = {}, error, pluginOpts = {} } = props;
|
|
99
108
|
const pointsLabel = `${points} ${points <= 1 ? 'pt' : 'pts'}`;
|
|
100
109
|
const showSampleAnswer = checkSampleAnswer(sampleAnswer);
|
|
101
110
|
|
|
@@ -109,6 +118,8 @@ export const PointConfig = withStyles((theme) => ({
|
|
|
109
118
|
<DragIndicator className={classes.dragIndicator} />
|
|
110
119
|
<EditableHtml
|
|
111
120
|
className={classes.editor}
|
|
121
|
+
error={error}
|
|
122
|
+
pluginProps={pluginOpts}
|
|
112
123
|
markup={content}
|
|
113
124
|
onChange={props.onChange}
|
|
114
125
|
mathMlOptions={mathMlOptions}
|
|
@@ -121,7 +132,7 @@ export const PointConfig = withStyles((theme) => ({
|
|
|
121
132
|
onChange={props.onMenuChange}
|
|
122
133
|
/>
|
|
123
134
|
</div>
|
|
124
|
-
|
|
135
|
+
{error && <div className={classes.errorText}>{error}</div>}
|
|
125
136
|
{!showSampleAnswer && (
|
|
126
137
|
<div className={classes.sampleAnswersEditor}>
|
|
127
138
|
<Typography variant="overline" className={classes.dragIndicator}>
|
|
@@ -130,6 +141,7 @@ export const PointConfig = withStyles((theme) => ({
|
|
|
130
141
|
<EditableHtml
|
|
131
142
|
className={classes.editor}
|
|
132
143
|
markup={sampleAnswer}
|
|
144
|
+
pluginProps={pluginOpts}
|
|
133
145
|
onChange={props.onSampleChange}
|
|
134
146
|
mathMlOptions={mathMlOptions}
|
|
135
147
|
/>
|
|
@@ -144,6 +156,9 @@ export class RawAuthoring extends React.Component {
|
|
|
144
156
|
classes: PropTypes.object.isRequired,
|
|
145
157
|
className: PropTypes.string,
|
|
146
158
|
value: RubricType,
|
|
159
|
+
config: PropTypes.object,
|
|
160
|
+
pluginOpts: PropTypes.object,
|
|
161
|
+
rubricless: PropTypes.bool,
|
|
147
162
|
onChange: PropTypes.func,
|
|
148
163
|
};
|
|
149
164
|
|
|
@@ -162,8 +177,13 @@ export class RawAuthoring extends React.Component {
|
|
|
162
177
|
onChange({ ...value, points, sampleAnswers });
|
|
163
178
|
};
|
|
164
179
|
|
|
165
|
-
|
|
180
|
+
changeRubriclessInstruction = (input) => {
|
|
166
181
|
const { value, onChange } = this.props;
|
|
182
|
+
onChange({ ...value, rubriclessInstruction: input });
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
changeMaxPoints = (maxPoints) => {
|
|
186
|
+
const { value, onChange, rubricless } = this.props;
|
|
167
187
|
const currentMax = value.points.length - 1;
|
|
168
188
|
|
|
169
189
|
log('current', currentMax, 'new: ', maxPoints);
|
|
@@ -184,8 +204,10 @@ export class RawAuthoring extends React.Component {
|
|
|
184
204
|
sampleAnswers = takeRight(value.sampleAnswers, maxPoints + 1);
|
|
185
205
|
}
|
|
186
206
|
|
|
187
|
-
if (points) {
|
|
188
|
-
onChange({ ...value, points, sampleAnswers });
|
|
207
|
+
if (points && !rubricless) {
|
|
208
|
+
onChange({ ...value, points, sampleAnswers, maxPoints });
|
|
209
|
+
} else {
|
|
210
|
+
onChange({ ...value, maxPoints });
|
|
189
211
|
}
|
|
190
212
|
};
|
|
191
213
|
|
|
@@ -242,21 +264,47 @@ export class RawAuthoring extends React.Component {
|
|
|
242
264
|
};
|
|
243
265
|
|
|
244
266
|
render() {
|
|
245
|
-
const {
|
|
246
|
-
|
|
247
|
-
|
|
267
|
+
const {
|
|
268
|
+
classes,
|
|
269
|
+
className,
|
|
270
|
+
value,
|
|
271
|
+
mathMlOptions = {},
|
|
272
|
+
config = {},
|
|
273
|
+
rubricless = false,
|
|
274
|
+
pluginOpts = {},
|
|
275
|
+
} = this.props;
|
|
276
|
+
let {
|
|
277
|
+
excludeZeroEnabled = true,
|
|
278
|
+
maxPointsEnabled = true,
|
|
279
|
+
errors = {},
|
|
280
|
+
rubriclessInstructionEnabled = false,
|
|
281
|
+
maxPoints = 10,
|
|
282
|
+
} = value || {};
|
|
283
|
+
// rubric will contain a max value for maxPoints
|
|
284
|
+
const { rubriclessInstruction = {}, maxMaxPoints = 10 } = config || {};
|
|
285
|
+
const { pointsDescriptorsErrors } = errors || {};
|
|
248
286
|
if (value && Number.isFinite(value.maxPoints)) {
|
|
249
287
|
// eslint-disable-next-line no-console
|
|
250
288
|
console.warn('maxPoints is deprecated - remove from model');
|
|
251
289
|
}
|
|
252
290
|
|
|
291
|
+
// for rubric value is computed based on points
|
|
292
|
+
const maxPointsValue = !rubricless ? value.points.length - 1 : maxPoints;
|
|
293
|
+
|
|
253
294
|
return (
|
|
254
295
|
<div className={classNames(classes.class, className)}>
|
|
255
296
|
<Typography variant="h5" className={classes.rubricTitle}>
|
|
256
297
|
Rubric
|
|
257
298
|
</Typography>
|
|
258
299
|
<FormGroup row>
|
|
259
|
-
{maxPointsEnabled &&
|
|
300
|
+
{maxPointsEnabled && (
|
|
301
|
+
<MaxPoints
|
|
302
|
+
max={maxMaxPoints < 100 ? maxMaxPoints : 100}
|
|
303
|
+
value={maxPointsValue}
|
|
304
|
+
onChange={this.changeMaxPoints}
|
|
305
|
+
pluginOpts={pluginOpts}
|
|
306
|
+
/>
|
|
307
|
+
)}
|
|
260
308
|
{excludeZeroEnabled && (
|
|
261
309
|
<FormControlLabel
|
|
262
310
|
label="Exclude zeros"
|
|
@@ -265,7 +313,22 @@ export class RawAuthoring extends React.Component {
|
|
|
265
313
|
)}
|
|
266
314
|
</FormGroup>
|
|
267
315
|
|
|
268
|
-
|
|
316
|
+
{rubriclessInstructionEnabled && rubricless && (
|
|
317
|
+
<InputContainer label={rubriclessInstruction.label} className={classes.inputContainer}>
|
|
318
|
+
<EditableHtml
|
|
319
|
+
className={classes.input}
|
|
320
|
+
markup={value.rubriclessInstruction || ''}
|
|
321
|
+
onChange={this.changeRubriclessInstruction}
|
|
322
|
+
pluginProps={pluginOpts}
|
|
323
|
+
nonEmpty={false}
|
|
324
|
+
disableUnderline
|
|
325
|
+
languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}
|
|
326
|
+
mathMlOptions={mathMlOptions}
|
|
327
|
+
/>
|
|
328
|
+
</InputContainer>
|
|
329
|
+
)}
|
|
330
|
+
|
|
331
|
+
<div className={rubricless ? classes.rubricless : classes.container}>
|
|
269
332
|
<DragDropContext onDragEnd={this.dragEnd}>
|
|
270
333
|
<Droppable droppableId="droppable">
|
|
271
334
|
{(provided) => (
|
|
@@ -284,11 +347,15 @@ export class RawAuthoring extends React.Component {
|
|
|
284
347
|
<PointConfig
|
|
285
348
|
points={value.points.length - 1 - index}
|
|
286
349
|
content={p}
|
|
350
|
+
error={
|
|
351
|
+
pointsDescriptorsErrors && pointsDescriptorsErrors[value.points.length - 1 - index]
|
|
352
|
+
}
|
|
287
353
|
sampleAnswer={value.sampleAnswers && value.sampleAnswers[index]}
|
|
288
354
|
onChange={(content) => this.changeContent(index, content, 'points')}
|
|
289
355
|
onSampleChange={(content) => this.changeContent(index, content, 'sampleAnswers')}
|
|
290
356
|
onMenuChange={(clickedItem) => this.onPointMenuChange(index, clickedItem)}
|
|
291
357
|
mathMlOptions={mathMlOptions}
|
|
358
|
+
pluginOpts={pluginOpts}
|
|
292
359
|
/>
|
|
293
360
|
</div>
|
|
294
361
|
)}
|
|
@@ -315,6 +382,14 @@ const styles = (theme) => ({
|
|
|
315
382
|
padding: theme.spacing.unit * 2,
|
|
316
383
|
margin: theme.spacing.unit,
|
|
317
384
|
},
|
|
385
|
+
inputContainer: {
|
|
386
|
+
width: '100%',
|
|
387
|
+
paddingTop: theme.spacing.unit * 2,
|
|
388
|
+
marginBottom: theme.spacing.unit * 2,
|
|
389
|
+
},
|
|
390
|
+
rubricless: {
|
|
391
|
+
display: 'none',
|
|
392
|
+
},
|
|
318
393
|
configHolder: {
|
|
319
394
|
paddingTop: theme.spacing.unit,
|
|
320
395
|
paddingBottom: theme.spacing.unit,
|
|
@@ -328,6 +403,7 @@ const styles = (theme) => ({
|
|
|
328
403
|
const StyledRawAuthoring = withStyles(styles)(RawAuthoring);
|
|
329
404
|
|
|
330
405
|
const Reverse = (props) => {
|
|
406
|
+
const { rubricless = false, config = {}, pluginOpts = {} } = props || {};
|
|
331
407
|
const points = Array.from(props.value.points || []).reverse();
|
|
332
408
|
let sampleAnswers = Array.from(props.value.sampleAnswers || []).reverse();
|
|
333
409
|
|
|
@@ -347,11 +423,22 @@ const Reverse = (props) => {
|
|
|
347
423
|
});
|
|
348
424
|
};
|
|
349
425
|
|
|
350
|
-
return
|
|
426
|
+
return (
|
|
427
|
+
<StyledRawAuthoring
|
|
428
|
+
value={value}
|
|
429
|
+
config={config}
|
|
430
|
+
onChange={onChange}
|
|
431
|
+
rubricless={rubricless}
|
|
432
|
+
pluginOpts={pluginOpts}
|
|
433
|
+
/>
|
|
434
|
+
);
|
|
351
435
|
};
|
|
352
436
|
|
|
353
437
|
Reverse.propTypes = {
|
|
354
438
|
value: RubricType,
|
|
439
|
+
config: PropTypes.object,
|
|
440
|
+
pluginOpts: PropTypes.object,
|
|
441
|
+
rubricless: PropTypes.bool,
|
|
355
442
|
getIndex: PropTypes.func,
|
|
356
443
|
onChange: PropTypes.func,
|
|
357
444
|
};
|
package/src/index.js
CHANGED
package/lib/authoring.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/authoring.jsx"],"names":["log","reorder","list","startIndex","endIndex","result","Array","from","splice","removed","RubricType","PropTypes","shape","excludeZero","bool","points","arrayOf","string","sampleAnswers","maxPoints","number","MaxPoints","theme","formControl","minWidth","margin","spacing","unit","props","value","onChange","max","classes","e","target","map","v","checkSampleAnswer","sampleAnswer","PointConfig","pointConfig","row","display","width","position","editor","backgroundColor","palette","common","white","dragIndicator","paddingTop","color","grey","pointsLabel","paddingBottom","textTransform","sampleAnswersEditor","paddingLeft","pointMenu","right","content","mathMlOptions","showSampleAnswer","icon","onMenuChange","onSampleChange","RawAuthoring","destination","source","index","currentMax","length","concat","type","items","clickedItem","changeContent","className","excludeZeroEnabled","maxPointsEnabled","Number","isFinite","console","warn","rubricTitle","changeMaxPoints","excludeZeros","container","dragEnd","provided","droppableProps","innerRef","p","shouldRenderPoint","toString","configHolder","draggableProps","dragHandleProps","onPointMenuChange","placeholder","React","Component","object","isRequired","func","styles","borderWidth","borderStyle","borderColor","padding","StyledRawAuthoring","Reverse","reverse","propTypes","getIndex"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;;;AACA,IAAMA,GAAG,GAAG,uBAAM,0BAAN,CAAZ;;AAEA,IAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,IAAD,EAAOC,UAAP,EAAmBC,QAAnB,EAAgC;AAC9C,MAAMC,MAAM,GAAGC,KAAK,CAACC,IAAN,CAAWL,IAAX,CAAf;;AACA,uBAAkBG,MAAM,CAACG,MAAP,CAAcL,UAAd,EAA0B,CAA1B,CAAlB;AAAA;AAAA,MAAOM,OAAP;;AAEAJ,EAAAA,MAAM,CAACG,MAAP,CAAcJ,QAAd,EAAwB,CAAxB,EAA2BK,OAA3B;AAEA,SAAOJ,MAAP;AACD,CAPD;;AASO,IAAMK,UAAU,GAAGC,sBAAUC,KAAV,CAAgB;AACxCC,EAAAA,WAAW,EAAEF,sBAAUG,IADiB;AAExCC,EAAAA,MAAM,EAAEJ,sBAAUK,OAAV,CAAkBL,sBAAUM,MAA5B,CAFgC;AAGxCC,EAAAA,aAAa,EAAEP,sBAAUK,OAAV,CAAkBL,sBAAUM,MAA5B,CAHyB;AAIxCE,EAAAA,SAAS,EAAER,sBAAUS;AAJmB,CAAhB,CAAnB;;;AAOP,IAAMC,SAAS,GAAG,wBAAW,UAACC,KAAD;AAAA,SAAY;AACvCC,IAAAA,WAAW,EAAE;AACXC,MAAAA,QAAQ,EAAE,OADC;AAEXC,MAAAA,MAAM,EAAEH,KAAK,CAACI,OAAN,CAAcC;AAFX;AAD0B,GAAZ;AAAA,CAAX,EAKd,UAACC,KAAD,EAAW;AACb,MAAQC,KAAR,GAA0CD,KAA1C,CAAQC,KAAR;AAAA,MAAeC,SAAf,GAA0CF,KAA1C,CAAeE,QAAf;AAAA,MAAyBC,GAAzB,GAA0CH,KAA1C,CAAyBG,GAAzB;AAAA,MAA8BC,OAA9B,GAA0CJ,KAA1C,CAA8BI,OAA9B;AAEA,sBACE,gCAAC,uBAAD;AAAa,IAAA,SAAS,EAAEA,OAAO,CAACT,WAAhC;AAA6C,IAAA,OAAO,EAAC;AAArD,kBACE,gCAAC,sBAAD;AAAY,IAAA,KAAK,EAAE,GAAnB;AAAwB,IAAA,OAAO,EAAC;AAAhC,kBADF,eAIE,gCAAC,kBAAD;AAAQ,IAAA,KAAK,EAAEM,KAAf;AAAsB,IAAA,QAAQ,EAAE,kBAACI,CAAD;AAAA,aAAOH,SAAQ,CAACG,CAAC,CAACC,MAAF,CAASL,KAAV,CAAf;AAAA,KAAhC;AAAiE,IAAA,KAAK,eAAE,gCAAC,yBAAD;AAAe,MAAA,UAAU,EAAE;AAA3B;AAAxE,KACG,uBAAM,CAAN,EAASE,GAAT,EAAcI,GAAd,CAAkB,UAACC,CAAD;AAAA,wBACjB,gCAAC,oBAAD;AAAU,MAAA,GAAG,YAAKA,CAAL,CAAb;AAAuB,MAAA,KAAK,EAAEA;AAA9B,OACGA,CADH,CADiB;AAAA,GAAlB,CADH,CAJF,CADF;AAcD,CAtBiB,CAAlB,C,CAwBA;AACA;;AACA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACC,YAAD;AAAA,SAAkBA,YAAY,KAAK,IAAjB,IAAyBA,YAAY,KAAK,MAA5D;AAAA,CAA1B;;AAEO,IAAMC,WAAW,GAAG,wBAAW,UAACjB,KAAD;AAAA,SAAY;AAChDkB,IAAAA,WAAW,EAAE,EADmC;AAEhDC,IAAAA,GAAG,EAAE;AACHC,MAAAA,OAAO,EAAE,MADN;AAEHC,MAAAA,KAAK,EAAE,MAFJ;AAGHC,MAAAA,QAAQ,EAAE;AAHP,KAF2C;AAOhDC,IAAAA,MAAM,EAAE;AACNF,MAAAA,KAAK,EAAE,MADD;AAENG,MAAAA,eAAe,YAAKxB,KAAK,CAACyB,OAAN,CAAcC,MAAd,CAAqBC,KAA1B;AAFT,KAPwC;AAWhDC,IAAAA,aAAa,EAAE;AACbC,MAAAA,UAAU,EAAE7B,KAAK,CAACI,OAAN,CAAcC,IADb;AAEbyB,MAAAA,KAAK,EAAEC,iBAAK,GAAL;AAFM,KAXiC;AAehDC,IAAAA,WAAW,EAAE;AACXF,MAAAA,KAAK,EAAEC,iBAAK,GAAL,CADI;AAEXE,MAAAA,aAAa,EAAEjC,KAAK,CAACI,OAAN,CAAcC,IAFlB;AAGX6B,MAAAA,aAAa,EAAE;AAHJ,KAfmC;AAoBhDC,IAAAA,mBAAmB,EAAE;AACnBC,MAAAA,WAAW,EAAEpC,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB;AADf,KApB2B;AAuBhDgC,IAAAA,SAAS,EAAE;AACTf,MAAAA,QAAQ,EAAE,UADD;AAETgB,MAAAA,KAAK,EAAE;AAFE;AAvBqC,GAAZ;AAAA,CAAX,EA2BvB,UAAChC,KAAD,EAAW;AACb,MAAQb,MAAR,GAAuEa,KAAvE,CAAQb,MAAR;AAAA,MAAgB8C,OAAhB,GAAuEjC,KAAvE,CAAgBiC,OAAhB;AAAA,MAAyB7B,OAAzB,GAAuEJ,KAAvE,CAAyBI,OAAzB;AAAA,MAAkCM,YAAlC,GAAuEV,KAAvE,CAAkCU,YAAlC;AAAA,6BAAuEV,KAAvE,CAAgDkC,aAAhD;AAAA,MAAgDA,aAAhD,qCAAgE,EAAhE;AACA,MAAMR,WAAW,aAAMvC,MAAN,cAAgBA,MAAM,IAAI,CAAV,GAAc,IAAd,GAAqB,KAArC,CAAjB;AACA,MAAMgD,gBAAgB,GAAG1B,iBAAiB,CAACC,YAAD,CAA1C;AAEA,sBACE;AAAK,IAAA,SAAS,EAAEN,OAAO,CAACQ;AAAxB,kBACE,gCAAC,sBAAD;AAAY,IAAA,OAAO,EAAC,UAApB;AAA+B,IAAA,SAAS,EAAER,OAAO,CAACsB;AAAlD,KACGA,WADH,CADF,eAKE;AAAK,IAAA,SAAS,EAAEtB,OAAO,CAACS;AAAxB,kBACE,gCAAC,yBAAD;AAAe,IAAA,SAAS,EAAET,OAAO,CAACkB;AAAlC,IADF,eAEE,gCAAC,wBAAD;AACE,IAAA,SAAS,EAAElB,OAAO,CAACa,MADrB;AAEE,IAAA,MAAM,EAAEgB,OAFV;AAGE,IAAA,QAAQ,EAAEjC,KAAK,CAACE,QAHlB;AAIE,IAAA,aAAa,EAAEgC;AAJjB,IAFF,eAQE,gCAAC,qBAAD;AACE,IAAA,OAAO,EAAE;AACPE,MAAAA,IAAI,EAAEhC,OAAO,CAAC2B;AADP,KADX;AAIE,IAAA,gBAAgB,EAAEI,gBAJpB;AAKE,IAAA,QAAQ,EAAEnC,KAAK,CAACqC;AALlB,IARF,CALF,EAsBG,CAACF,gBAAD,iBACC;AAAK,IAAA,SAAS,EAAE/B,OAAO,CAACyB;AAAxB,kBACE,gCAAC,sBAAD;AAAY,IAAA,OAAO,EAAC,UAApB;AAA+B,IAAA,SAAS,EAAEzB,OAAO,CAACkB;AAAlD,uBADF,eAIE,gCAAC,wBAAD;AACE,IAAA,SAAS,EAAElB,OAAO,CAACa,MADrB;AAEE,IAAA,MAAM,EAAEP,YAFV;AAGE,IAAA,QAAQ,EAAEV,KAAK,CAACsC,cAHlB;AAIE,IAAA,aAAa,EAAEJ;AAJjB,IAJF,CAvBJ,CADF;AAsCD,CAtE0B,CAApB;;;IAwEMK,Y;;;;;;;;;;;;;;;gGAUD,UAAC9D,MAAD,EAAY;AACpB,UAAI,CAACA,MAAM,CAAC+D,WAAZ,EAAyB;AACvB;AACD;;AAED,wBAA4B,MAAKxC,KAAjC;AAAA,UAAQC,KAAR,eAAQA,KAAR;AAAA,UAAeC,QAAf,eAAeA,QAAf;AAEA,UAAMf,MAAM,GAAGd,OAAO,CAAC4B,KAAK,CAACd,MAAP,EAAeV,MAAM,CAACgE,MAAP,CAAcC,KAA7B,EAAoCjE,MAAM,CAAC+D,WAAP,CAAmBE,KAAvD,CAAtB;AACA,UAAMpD,aAAa,GAAGjB,OAAO,CAAC4B,KAAK,CAACX,aAAP,EAAsBb,MAAM,CAACgE,MAAP,CAAcC,KAApC,EAA2CjE,MAAM,CAAC+D,WAAP,CAAmBE,KAA9D,CAA7B;AAEAxC,MAAAA,QAAQ,iCAAMD,KAAN;AAAad,QAAAA,MAAM,EAANA,MAAb;AAAqBG,QAAAA,aAAa,EAAbA;AAArB,SAAR;AACD,K;wGAEiB,UAACC,SAAD,EAAe;AAC/B,yBAA4B,MAAKS,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AACA,UAAMyC,UAAU,GAAG1C,KAAK,CAACd,MAAN,CAAayD,MAAb,GAAsB,CAAzC;AAEAxE,MAAAA,GAAG,CAAC,SAAD,EAAYuE,UAAZ,EAAwB,OAAxB,EAAiCpD,SAAjC,CAAH;AAEA,UAAIJ,MAAJ,EAAYG,aAAZ;;AACA,UAAIC,SAAS,GAAGoD,UAAhB,EAA4B;AAC1BxD,QAAAA,MAAM,GAAG,uBAAMI,SAAS,GAAGoD,UAAlB,EACNpC,GADM,CACF;AAAA,iBAAM,EAAN;AAAA,SADE,EAENsC,MAFM,CAEC5C,KAAK,CAACd,MAFP,CAAT;AAGAG,QAAAA,aAAa,GAAG,uBAAMC,SAAS,GAAGoD,UAAlB,EACbpC,GADa,CACT;AAAA,iBAAM,IAAN;AAAA,SADS,EAEbsC,MAFa,CAEN5C,KAAK,CAACX,aAFA,CAAhB;AAGD;;AAED,UAAIC,SAAS,GAAGoD,UAAhB,EAA4B;AAC1BvE,QAAAA,GAAG,CAAC,WAAD,CAAH;AACAe,QAAAA,MAAM,GAAG,2BAAUc,KAAK,CAACd,MAAhB,EAAwBI,SAAS,GAAG,CAApC,CAAT;AACAD,QAAAA,aAAa,GAAG,2BAAUW,KAAK,CAACX,aAAhB,EAA+BC,SAAS,GAAG,CAA3C,CAAhB;AACD;;AAED,UAAIJ,MAAJ,EAAY;AACVe,QAAAA,QAAQ,iCAAMD,KAAN;AAAad,UAAAA,MAAM,EAANA,MAAb;AAAqBG,UAAAA,aAAa,EAAbA;AAArB,WAAR;AACD;AACF,K;sGAEe,UAACoD,KAAD,EAAQT,OAAR,EAAiBa,IAAjB,EAA0B;AACxC;AACA1E,MAAAA,GAAG,uBAAgB0E,IAAhB,SAA0BJ,KAA1B,EAAiCT,OAAjC,CAAH;;AAEA,UAAIa,IAAI,KAAK,QAAT,IAAqBA,IAAI,KAAK,eAAlC,EAAmD;AACjD;AACD;;AAED,yBAA4B,MAAK9C,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AACA,UAAM6C,KAAK,GAAG9C,KAAK,CAAC6C,IAAD,CAAL,IAAepE,KAAK,CAACC,IAAN,CAAWsB,KAAK,CAAC6C,IAAD,CAAhB,CAA7B;AAEAC,MAAAA,KAAK,CAACnE,MAAN,CAAa8D,KAAb,EAAoB,CAApB,EAAuBT,OAAvB;AACA7D,MAAAA,GAAG,uBAAgB0E,IAAhB,SAA0BC,KAA1B,CAAH;AAEA7C,MAAAA,QAAQ,iCAAMD,KAAN,4CAAc6C,IAAd,EAAqBC,KAArB,GAAR;AACD,K;qGAEc,YAAM;AACnB,yBAA4B,MAAK/C,KAAjC;AAAA,UAAQC,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AAEAA,MAAAA,QAAQ,iCAAMD,KAAN;AAAahB,QAAAA,WAAW,EAAE,CAACgB,KAAK,CAAChB;AAAjC,SAAR;AACD,K;0GAEmB,UAACyD,KAAD,EAAQzC,KAAR,EAAkB;AACpC,UAAI,CAACA,KAAK,CAAChB,WAAX,EAAwB;AACtB,eAAO,IAAP;AACD,OAFD,MAEO;AACL,YAAIyD,KAAK,GAAGzC,KAAK,CAACd,MAAN,CAAayD,MAAb,GAAsB,CAAlC,EAAqC;AACnC,iBAAO,IAAP;AACD,SAFD,MAEO,IAAIF,KAAK,KAAKzC,KAAK,CAACd,MAAN,CAAayD,MAAb,GAAsB,CAApC,EAAuC;AAC5C,iBAAO,KAAP;AACD;;AAED,eAAO,IAAP;AACD;AACF,K;0GAEmB,UAACF,KAAD,EAAQM,WAAR,EAAwB;AAC1C,UAAIA,WAAW,KAAK,QAApB,EAA8B;AAC5B,YAAQ/C,KAAR,GAAkB,MAAKD,KAAvB,CAAQC,KAAR;AACA,YAAMX,aAAa,GAAGZ,KAAK,CAACC,IAAN,CAAWsB,KAAK,CAACX,aAAN,IAAuB,EAAlC,CAAtB;;AAEA,YAAImB,iBAAiB,CAACnB,aAAa,CAACoD,KAAD,CAAd,CAArB,EAA6C;AAC3C;AACA,gBAAKO,aAAL,CAAmBP,KAAnB,EAA0B,EAA1B,EAA8B,eAA9B;AACD,SAHD,MAGO;AACL;AACA,gBAAKO,aAAL,CAAmBP,KAAnB,EAA0B,IAA1B,EAAgC,eAAhC;AACD;AACF;AACF,K;;;;;;WAED,kBAAS;AAAA;;AACP,yBAA0D,KAAK1C,KAA/D;AAAA,UAAQI,OAAR,gBAAQA,OAAR;AAAA,UAAiB8C,SAAjB,gBAAiBA,SAAjB;AAAA,UAA4BjD,KAA5B,gBAA4BA,KAA5B;AAAA,+CAAmCiC,aAAnC;AAAA,UAAmCA,aAAnC,sCAAmD,EAAnD;;AACA,iBAA6DjC,KAAK,IAAI,EAAtE;AAAA,uCAAMkD,kBAAN;AAAA,UAAMA,kBAAN,sCAA2B,IAA3B;AAAA,uCAAiCC,gBAAjC;AAAA,UAAiCA,gBAAjC,sCAAoD,IAApD;;AAEA,UAAInD,KAAK,IAAIoD,MAAM,CAACC,QAAP,CAAgBrD,KAAK,CAACV,SAAtB,CAAb,EAA+C;AAC7C;AACAgE,QAAAA,OAAO,CAACC,IAAR,CAAa,6CAAb;AACD;;AAED,0BACE;AAAK,QAAA,SAAS,EAAE,4BAAWpD,OAAO,SAAlB,EAA0B8C,SAA1B;AAAhB,sBACE,gCAAC,sBAAD;AAAY,QAAA,OAAO,EAAC,IAApB;AAAyB,QAAA,SAAS,EAAE9C,OAAO,CAACqD;AAA5C,kBADF,eAIE,gCAAC,qBAAD;AAAW,QAAA,GAAG;AAAd,SACGL,gBAAgB,iBAAI,gCAAC,SAAD;AAAW,QAAA,GAAG,EAAE,EAAhB;AAAoB,QAAA,KAAK,EAAEnD,KAAK,CAACd,MAAN,CAAayD,MAAb,GAAsB,CAAjD;AAAoD,QAAA,QAAQ,EAAE,KAAKc;AAAnE,QADvB,EAEGP,kBAAkB,iBACjB,gCAAC,4BAAD;AACE,QAAA,KAAK,EAAC,eADR;AAEE,QAAA,OAAO,eAAE,gCAAC,oBAAD;AAAU,UAAA,OAAO,EAAElD,KAAK,CAAChB,WAAzB;AAAsC,UAAA,QAAQ,EAAE,KAAK0E;AAArD;AAFX,QAHJ,CAJF,eAcE;AAAK,QAAA,SAAS,EAAEvD,OAAO,CAACwD;AAAxB,sBACE,gCAAC,kCAAD;AAAiB,QAAA,SAAS,EAAE,KAAKC;AAAjC,sBACE,gCAAC,4BAAD;AAAW,QAAA,WAAW,EAAC;AAAvB,SACG,UAACC,QAAD;AAAA,4BACC,qEAASA,QAAQ,CAACC,cAAlB;AAAkC,UAAA,GAAG,EAAED,QAAQ,CAACE;AAAhD,YACG/D,KAAK,CAACd,MAAN,CAAaoB,GAAb,CACC,UAAC0D,CAAD,EAAIvB,KAAJ;AAAA,iBACE,MAAI,CAACwB,iBAAL,CAAuBxB,KAAvB,EAA8BzC,KAA9B,kBACE,gCAAC,4BAAD;AAAW,YAAA,GAAG,YAAKgE,CAAC,CAAC9E,MAAP,cAAiBuD,KAAjB,CAAd;AAAwC,YAAA,KAAK,EAAEA,KAA/C;AAAsD,YAAA,WAAW,EAAEA,KAAK,CAACyB,QAAN;AAAnE,aACG,UAACL,QAAD;AAAA,gCACC;AACE,cAAA,SAAS,EAAE1D,OAAO,CAACgE,YADrB;AAEE,cAAA,GAAG,EAAEN,QAAQ,CAACE;AAFhB,eAGMF,QAAQ,CAACO,cAHf,EAIMP,QAAQ,CAACQ,eAJf,gBAME,gCAAC,WAAD;AACE,cAAA,MAAM,EAAErE,KAAK,CAACd,MAAN,CAAayD,MAAb,GAAsB,CAAtB,GAA0BF,KADpC;AAEE,cAAA,OAAO,EAAEuB,CAFX;AAGE,cAAA,YAAY,EAAEhE,KAAK,CAACX,aAAN,IAAuBW,KAAK,CAACX,aAAN,CAAoBoD,KAApB,CAHvC;AAIE,cAAA,QAAQ,EAAE,kBAACT,OAAD;AAAA,uBAAa,MAAI,CAACgB,aAAL,CAAmBP,KAAnB,EAA0BT,OAA1B,EAAmC,QAAnC,CAAb;AAAA,eAJZ;AAKE,cAAA,cAAc,EAAE,wBAACA,OAAD;AAAA,uBAAa,MAAI,CAACgB,aAAL,CAAmBP,KAAnB,EAA0BT,OAA1B,EAAmC,eAAnC,CAAb;AAAA,eALlB;AAME,cAAA,YAAY,EAAE,sBAACe,WAAD;AAAA,uBAAiB,MAAI,CAACuB,iBAAL,CAAuB7B,KAAvB,EAA8BM,WAA9B,CAAjB;AAAA,eANhB;AAOE,cAAA,aAAa,EAAEd;AAPjB,cANF,CADD;AAAA,WADH,CAFJ;AAAA,SADD,CADH,EA0BG4B,QAAQ,CAACU,WA1BZ,CADD;AAAA,OADH,CADF,CADF,CAdF,CADF;AAqDD;;;EApK+BC,kBAAMC,S;;;iCAA3BnC,Y,eACQ;AACjBnC,EAAAA,OAAO,EAAErB,sBAAU4F,MAAV,CAAiBC,UADT;AAEjB1B,EAAAA,SAAS,EAAEnE,sBAAUM,MAFJ;AAGjBY,EAAAA,KAAK,EAAEnB,UAHU;AAIjBoB,EAAAA,QAAQ,EAAEnB,sBAAU8F;AAJH,C;iCADRtC,Y,kBAQW,E;;AA+JxB,IAAMuC,MAAM,GAAG,SAATA,MAAS,CAACpF,KAAD;AAAA,SAAY;AACzBkE,IAAAA,SAAS,EAAE;AACT1C,MAAAA,eAAe,EAAEO,iBAAK,GAAL,CADR;AAETsD,MAAAA,WAAW,EAAE,CAFJ;AAGTC,MAAAA,WAAW,EAAE,OAHJ;AAITC,MAAAA,WAAW,EAAExD,iBAAK,GAAL,CAJJ;AAKTyD,MAAAA,OAAO,EAAExF,KAAK,CAACI,OAAN,CAAcC,IAAd,GAAqB,CALrB;AAMTF,MAAAA,MAAM,EAAEH,KAAK,CAACI,OAAN,CAAcC;AANb,KADc;AASzBqE,IAAAA,YAAY,EAAE;AACZ7C,MAAAA,UAAU,EAAE7B,KAAK,CAACI,OAAN,CAAcC,IADd;AAEZ4B,MAAAA,aAAa,EAAEjC,KAAK,CAACI,OAAN,CAAcC;AAFjB,KATW;AAazB0D,IAAAA,WAAW,EAAE;AACX3B,MAAAA,WAAW,EAAEpC,KAAK,CAACI,OAAN,CAAcC,IADhB;AAEXF,MAAAA,MAAM,EAAEH,KAAK,CAACI,OAAN,CAAcC;AAFX;AAbY,GAAZ;AAAA,CAAf;;AAmBA,IAAMoF,kBAAkB,GAAG,wBAAWL,MAAX,EAAmBvC,YAAnB,CAA3B;;AAEA,IAAM6C,OAAO,GAAG,SAAVA,OAAU,CAACpF,KAAD,EAAW;AACzB,MAAMb,MAAM,GAAGT,KAAK,CAACC,IAAN,CAAWqB,KAAK,CAACC,KAAN,CAAYd,MAAZ,IAAsB,EAAjC,EAAqCkG,OAArC,EAAf;AACA,MAAI/F,aAAa,GAAGZ,KAAK,CAACC,IAAN,CAAWqB,KAAK,CAACC,KAAN,CAAYX,aAAZ,IAA6B,EAAxC,EAA4C+F,OAA5C,EAApB;;AAEA,MAAIlG,MAAM,CAACyD,MAAP,GAAgBtD,aAAa,CAACsD,MAAlC,EAA0C;AACxCtD,IAAAA,aAAa,GAAG,uBAAMH,MAAM,CAACyD,MAAP,GAAgBtD,aAAa,CAACsD,MAApC,EACbrC,GADa,CACT;AAAA,aAAM,IAAN;AAAA,KADS,EAEbsC,MAFa,CAENvD,aAFM,CAAhB;AAGD;;AAED,MAAMW,KAAK,mCAAQD,KAAK,CAACC,KAAd;AAAqBd,IAAAA,MAAM,EAANA,MAArB;AAA6BG,IAAAA,aAAa,EAAbA;AAA7B,IAAX;;AAEA,MAAMY,QAAQ,GAAG,SAAXA,QAAW,CAACD,KAAD,EAAW;AAC1BD,IAAAA,KAAK,CAACE,QAAN,iCACKD,KADL;AAEEd,MAAAA,MAAM,EAAET,KAAK,CAACC,IAAN,CAAWsB,KAAK,CAACd,MAAN,IAAgB,EAA3B,EAA+BkG,OAA/B,EAFV;AAGE/F,MAAAA,aAAa,EAAEZ,KAAK,CAACC,IAAN,CAAWsB,KAAK,CAACX,aAAN,IAAuB,EAAlC,EAAsC+F,OAAtC;AAHjB;AAKD,GAND;;AAQA,sBAAO,gCAAC,kBAAD;AAAoB,IAAA,KAAK,EAAEpF,KAA3B;AAAkC,IAAA,QAAQ,EAAEC;AAA5C,IAAP;AACD,CArBD;;AAuBAkF,OAAO,CAACE,SAAR,GAAoB;AAClBrF,EAAAA,KAAK,EAAEnB,UADW;AAElByG,EAAAA,QAAQ,EAAExG,sBAAU8F,IAFF;AAGlB3E,EAAAA,QAAQ,EAAEnB,sBAAU8F;AAHF,CAApB;eAMeO,O","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport OutlinedInput from '@material-ui/core/OutlinedInput';\nimport InputLabel from '@material-ui/core/InputLabel';\nimport Select from '@material-ui/core/Select';\nimport FormControl from '@material-ui/core/FormControl';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport times from 'lodash/times';\nimport Checkbox from '@material-ui/core/Checkbox';\nimport FormGroup from '@material-ui/core/FormGroup';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport grey from '@material-ui/core/colors/grey';\nimport Typography from '@material-ui/core/Typography';\nimport DragIndicator from '@material-ui/icons/DragIndicator';\nimport EditableHtml from '@pie-lib/editable-html';\nimport { DragDropContext, Droppable, Draggable } from 'react-beautiful-dnd';\nimport debug from 'debug';\nimport takeRight from 'lodash/takeRight';\nimport PointMenu from './point-menu';\n\nimport range from 'lodash/range';\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});\n\nconst MaxPoints = withStyles((theme) => ({\n formControl: {\n minWidth: '120px',\n margin: theme.spacing.unit,\n },\n}))((props) => {\n const { value, onChange, max, classes } = props;\n\n return (\n <FormControl className={classes.formControl} variant=\"outlined\">\n <InputLabel width={100} htmlFor=\"...\">\n Max Points\n </InputLabel>\n <Select value={value} onChange={(e) => onChange(e.target.value)} input={<OutlinedInput labelWidth={80} />}>\n {range(1, max).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\nexport const PointConfig = withStyles((theme) => ({\n pointConfig: {},\n row: {\n display: 'flex',\n width: '100%',\n position: 'relative',\n },\n editor: {\n width: '100%',\n backgroundColor: `${theme.palette.common.white} !important`,\n },\n dragIndicator: {\n paddingTop: theme.spacing.unit,\n color: grey[500],\n },\n pointsLabel: {\n color: grey[500],\n paddingBottom: theme.spacing.unit,\n textTransform: 'uppercase',\n },\n sampleAnswersEditor: {\n paddingLeft: theme.spacing.unit * 3,\n },\n pointMenu: {\n position: 'absolute',\n right: 0,\n },\n}))((props) => {\n const { points, content, classes, sampleAnswer, mathMlOptions = {} } = props;\n const pointsLabel = `${points} ${points <= 1 ? 'pt' : 'pts'}`;\n const showSampleAnswer = checkSampleAnswer(sampleAnswer);\n\n return (\n <div className={classes.pointConfig}>\n <Typography variant=\"overline\" className={classes.pointsLabel}>\n {pointsLabel}\n </Typography>\n\n <div className={classes.row}>\n <DragIndicator className={classes.dragIndicator} />\n <EditableHtml\n className={classes.editor}\n markup={content}\n onChange={props.onChange}\n mathMlOptions={mathMlOptions}\n />\n <PointMenu\n classes={{\n icon: classes.pointMenu,\n }}\n showSampleAnswer={showSampleAnswer}\n onChange={props.onMenuChange}\n />\n </div>\n\n {!showSampleAnswer && (\n <div className={classes.sampleAnswersEditor}>\n <Typography variant=\"overline\" className={classes.dragIndicator}>\n Sample Response\n </Typography>\n <EditableHtml\n className={classes.editor}\n markup={sampleAnswer}\n onChange={props.onSampleChange}\n mathMlOptions={mathMlOptions}\n />\n </div>\n )}\n </div>\n );\n});\n\nexport class RawAuthoring extends React.Component {\n static propTypes = {\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n value: RubricType,\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 changeMaxPoints = (maxPoints) => {\n const { value, onChange } = 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) {\n onChange({ ...value, points, sampleAnswers });\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 { classes, className, value, mathMlOptions = {} } = this.props;\n let { excludeZeroEnabled = true, maxPointsEnabled = true } = value || {};\n\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 return (\n <div className={classNames(classes.class, className)}>\n <Typography variant=\"h5\" className={classes.rubricTitle}>\n Rubric\n </Typography>\n <FormGroup row>\n {maxPointsEnabled && <MaxPoints max={10} value={value.points.length - 1} onChange={this.changeMaxPoints} />}\n {excludeZeroEnabled && (\n <FormControlLabel\n label=\"Exclude zeros\"\n control={<Checkbox checked={value.excludeZero} onChange={this.excludeZeros} />}\n />\n )}\n </FormGroup>\n\n <div className={classes.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 <div\n className={classes.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 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 />\n </div>\n )}\n </Draggable>\n ),\n )}\n {provided.placeholder}\n </div>\n )}\n </Droppable>\n </DragDropContext>\n </div>\n </div>\n );\n }\n}\n\nconst styles = (theme) => ({\n container: {\n backgroundColor: grey[200],\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: grey[300],\n padding: theme.spacing.unit * 2,\n margin: theme.spacing.unit,\n },\n configHolder: {\n paddingTop: theme.spacing.unit,\n paddingBottom: theme.spacing.unit,\n },\n rubricTitle: {\n paddingLeft: theme.spacing.unit,\n margin: theme.spacing.unit,\n },\n});\n\nconst StyledRawAuthoring = withStyles(styles)(RawAuthoring);\n\nconst Reverse = (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 <StyledRawAuthoring value={value} onChange={onChange} />;\n};\n\nReverse.propTypes = {\n value: RubricType,\n getIndex: PropTypes.func,\n onChange: PropTypes.func,\n};\n\nexport default Reverse;\n"],"file":"authoring.js"}
|
package/lib/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.js"],"names":["RUBRIC_TYPES","SIMPLE_RUBRIC","MULTI_TRAIT_RUBRIC"],"mappings":";;;;;;;;;;;;;;;AAAA;;AAEA,IAAMA,YAAY,GAAG;AACnBC,EAAAA,aAAa,EAAE,cADI;AAEnBC,EAAAA,kBAAkB,EAAE;AAFD,CAArB","sourcesContent":["import Authoring from './authoring';\n\nconst RUBRIC_TYPES = {\n SIMPLE_RUBRIC: 'simpleRubric',\n MULTI_TRAIT_RUBRIC: 'multiTraitRubric',\n};\n\nexport { Authoring, RUBRIC_TYPES };\n"],"file":"index.js"}
|
package/lib/point-menu.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/point-menu.jsx"],"names":["IconMenu","props","event","setState","open","anchorEl","currentTarget","state","undefined","opts","onClick","classes","keys","Object","handleMenuClick","key","handleRequestClose","iconColor","handleClick","icon","transform","vertical","horizontal","map","k","index","React","Component","PropTypes","object","func","isRequired","PointMenu","onChange","showSampleAnswer","sampleText","sample","bool"],"mappings":"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","sourcesContent":["import Menu from '@material-ui/core/Menu';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MoreVertIcon from '@material-ui/icons/MoreVert';\nimport MoreHorizIcon from '@material-ui/icons/MoreHoriz';\nimport IconButton from '@material-ui/core/IconButton';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nexport class IconMenu extends React.Component {\n static propTypes = {\n opts: PropTypes.object,\n onClick: PropTypes.func.isRequired,\n classes: PropTypes.object.isRequired,\n };\n\n constructor(props) {\n super(props);\n this.state = {\n anchorEl: undefined,\n open: false,\n };\n }\n\n handleClick = (event) => this.setState({ open: true, anchorEl: event.currentTarget });\n\n handleRequestClose = () => this.setState({ open: false });\n\n render() {\n const { opts, onClick, classes } = this.props;\n const { open, anchorEl } = this.state;\n const keys = Object.keys(opts) || [];\n\n const handleMenuClick = (key) => () => {\n onClick(key);\n this.handleRequestClose();\n };\n\n const iconColor = open ? 'inherit' : 'disabled';\n\n return (\n <div>\n <div onClick={this.handleClick}>\n <IconButton className={classes.icon}>\n {open ? <MoreVertIcon color={iconColor} /> : <MoreHorizIcon color={iconColor} />}\n </IconButton>\n </div>\n <Menu\n id=\"point-menu\"\n anchorEl={anchorEl}\n open={open}\n onClose={this.handleRequestClose}\n style={{ transform: 'translate(-15px, -15px)' }}\n transformOrigin={{\n vertical: 'center',\n horizontal: 'right',\n }}\n >\n {keys.map((k, index) => (\n <MenuItem key={index} onClick={handleMenuClick(k)}>\n {opts[k]}\n </MenuItem>\n ))}\n </Menu>\n </div>\n );\n }\n}\n\nexport default class PointMenu extends React.Component {\n static propTypes = {\n onChange: PropTypes.func.isRequired,\n classes: PropTypes.object.isRequired,\n showSampleAnswer: PropTypes.bool.isRequired,\n };\n\n static defaultProps = {\n classes: {},\n };\n\n render() {\n const { onChange, classes, showSampleAnswer } = this.props;\n const sampleText = showSampleAnswer ? 'Provide Sample Response' : 'Remove Sample Response';\n\n return (\n <IconMenu\n onClick={(key) => onChange(key)}\n opts={{\n sample: sampleText,\n }}\n classes={classes}\n />\n );\n }\n}\n"],"file":"point-menu.js"}
|