@pie-lib/config-ui 12.0.0-beta.4 → 12.0.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.json +8 -1653
- package/CHANGELOG.md +540 -58
- package/LICENSE.md +5 -0
- package/NEXT.CHANGELOG.json +1 -0
- package/lib/alert-dialog.js +44 -20
- package/lib/alert-dialog.js.map +1 -1
- package/lib/checkbox.js +59 -61
- package/lib/checkbox.js.map +1 -1
- package/lib/choice-configuration/feedback-menu.js +30 -65
- package/lib/choice-configuration/feedback-menu.js.map +1 -1
- package/lib/choice-configuration/index.js +231 -244
- package/lib/choice-configuration/index.js.map +1 -1
- package/lib/choice-utils.js +7 -19
- package/lib/choice-utils.js.map +1 -1
- package/lib/feedback-config/feedback-selector.js +89 -115
- package/lib/feedback-config/feedback-selector.js.map +1 -1
- package/lib/feedback-config/group.js +28 -42
- package/lib/feedback-config/group.js.map +1 -1
- package/lib/feedback-config/index.js +55 -87
- package/lib/feedback-config/index.js.map +1 -1
- package/lib/form-section.js +32 -34
- package/lib/form-section.js.map +1 -1
- package/lib/help.js +41 -80
- package/lib/help.js.map +1 -1
- package/lib/index.js +2 -32
- package/lib/index.js.map +1 -1
- package/lib/input.js +24 -57
- package/lib/input.js.map +1 -1
- package/lib/inputs.js +62 -88
- package/lib/inputs.js.map +1 -1
- package/lib/langs.js +59 -102
- package/lib/langs.js.map +1 -1
- package/lib/layout/config-layout.js +95 -67
- package/lib/layout/config-layout.js.map +1 -1
- package/lib/layout/index.js +1 -4
- package/lib/layout/index.js.map +1 -1
- package/lib/layout/layout-contents.js +130 -75
- package/lib/layout/layout-contents.js.map +1 -1
- package/lib/layout/settings-box.js +28 -58
- package/lib/layout/settings-box.js.map +1 -1
- package/lib/mui-box/index.js +42 -58
- package/lib/mui-box/index.js.map +1 -1
- package/lib/number-text-field-custom.js +164 -152
- package/lib/number-text-field-custom.js.map +1 -1
- package/lib/number-text-field.js +87 -119
- package/lib/number-text-field.js.map +1 -1
- package/lib/radio-with-label.js +33 -26
- package/lib/radio-with-label.js.map +1 -1
- package/lib/settings/display-size.js +17 -33
- package/lib/settings/display-size.js.map +1 -1
- package/lib/settings/index.js +26 -46
- package/lib/settings/index.js.map +1 -1
- package/lib/settings/panel.js +202 -221
- package/lib/settings/panel.js.map +1 -1
- package/lib/settings/settings-radio-label.js +37 -29
- package/lib/settings/settings-radio-label.js.map +1 -1
- package/lib/settings/toggle.js +40 -33
- package/lib/settings/toggle.js.map +1 -1
- package/lib/tabs/index.js +26 -57
- package/lib/tabs/index.js.map +1 -1
- package/lib/tags-input/index.js +51 -100
- package/lib/tags-input/index.js.map +1 -1
- package/lib/two-choice.js +47 -91
- package/lib/two-choice.js.map +1 -1
- package/lib/with-stateful-model.js +11 -34
- package/lib/with-stateful-model.js.map +1 -1
- package/package.json +22 -11
- package/src/__tests__/alert-dialog.test.jsx +283 -0
- package/src/__tests__/checkbox.test.jsx +249 -0
- package/src/__tests__/choice-utils.test.js +12 -0
- package/src/__tests__/form-section.test.jsx +334 -0
- package/src/__tests__/help.test.jsx +184 -0
- package/src/__tests__/input.test.jsx +192 -0
- package/src/__tests__/langs.test.jsx +457 -0
- package/src/__tests__/number-text-field-custom.test.jsx +438 -0
- package/src/__tests__/number-text-field.test.jsx +341 -0
- package/src/__tests__/radio-with-label.test.jsx +259 -0
- package/src/__tests__/settings-panel.test.js +187 -0
- package/src/__tests__/settings.test.jsx +515 -0
- package/src/__tests__/tabs.test.jsx +193 -0
- package/src/__tests__/two-choice.test.js +110 -0
- package/src/__tests__/with-stateful-model.test.jsx +145 -0
- package/src/alert-dialog.jsx +31 -16
- package/src/checkbox.jsx +45 -39
- package/src/choice-configuration/__tests__/feedback-menu.test.jsx +163 -0
- package/src/choice-configuration/__tests__/index.test.jsx +234 -0
- package/src/choice-configuration/feedback-menu.jsx +15 -28
- package/src/choice-configuration/index.jsx +233 -182
- package/src/choice-utils.js +1 -1
- package/src/feedback-config/__tests__/feedback-config.test.jsx +141 -0
- package/src/feedback-config/__tests__/feedback-selector.test.jsx +107 -0
- package/src/feedback-config/feedback-selector.jsx +65 -60
- package/src/feedback-config/group.jsx +26 -29
- package/src/feedback-config/index.jsx +59 -47
- package/src/form-section.jsx +26 -18
- package/src/help.jsx +27 -36
- package/src/index.js +2 -5
- package/src/input.jsx +9 -9
- package/src/inputs.jsx +36 -50
- package/src/langs.jsx +57 -73
- package/src/layout/__tests__/config.layout.test.jsx +59 -0
- package/src/layout/__tests__/layout-content.test.jsx +3 -0
- package/src/layout/config-layout.jsx +70 -37
- package/src/layout/layout-contents.jsx +96 -39
- package/src/layout/settings-box.jsx +22 -21
- package/src/mui-box/index.jsx +37 -45
- package/src/number-text-field-custom.jsx +136 -81
- package/src/number-text-field.jsx +59 -37
- package/src/radio-with-label.jsx +28 -12
- package/src/settings/display-size.jsx +14 -13
- package/src/settings/index.js +20 -12
- package/src/settings/panel.jsx +147 -110
- package/src/settings/settings-radio-label.jsx +29 -13
- package/src/settings/toggle.jsx +39 -20
- package/src/tabs/index.jsx +15 -19
- package/src/tags-input/__tests__/index.test.jsx +113 -0
- package/src/tags-input/index.jsx +42 -47
- package/src/two-choice.jsx +19 -23
- package/src/with-stateful-model.jsx +5 -5
- package/README.md +0 -12
|
@@ -1,312 +1,348 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = exports.ChoiceConfiguration = void 0;
|
|
9
|
-
|
|
10
8
|
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
11
|
-
|
|
12
9
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
13
|
-
|
|
14
10
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
15
|
-
|
|
16
|
-
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
17
|
-
|
|
18
|
-
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
19
|
-
|
|
20
11
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
21
|
-
|
|
22
12
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
23
|
-
|
|
13
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
24
14
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
25
|
-
|
|
26
15
|
var _react = _interopRequireDefault(require("react"));
|
|
27
|
-
|
|
28
16
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
29
|
-
|
|
30
|
-
var
|
|
31
|
-
|
|
32
|
-
var
|
|
33
|
-
|
|
34
|
-
var _classnames = _interopRequireDefault(require("classnames"));
|
|
35
|
-
|
|
17
|
+
var _styles = require("@mui/material/styles");
|
|
18
|
+
var _TextField = _interopRequireDefault(require("@mui/material/TextField"));
|
|
19
|
+
var _Delete = _interopRequireDefault(require("@mui/icons-material/Delete"));
|
|
20
|
+
var _SubdirectoryArrowRight = _interopRequireDefault(require("@mui/icons-material/SubdirectoryArrowRight"));
|
|
21
|
+
var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
|
|
36
22
|
var _renderUi = require("@pie-lib/render-ui");
|
|
37
|
-
|
|
38
|
-
var _editableHtml = _interopRequireDefault(require("@pie-lib/editable-html"));
|
|
39
|
-
|
|
40
23
|
var _inputs = require("../inputs");
|
|
41
|
-
|
|
42
24
|
var _feedbackMenu = _interopRequireDefault(require("./feedback-menu"));
|
|
43
|
-
|
|
44
|
-
var
|
|
45
|
-
|
|
46
|
-
var
|
|
47
|
-
|
|
48
|
-
var
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
55
|
-
|
|
56
|
-
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
57
|
-
|
|
58
|
-
var EditableHtmlContainer = (0, _styles.withStyles)(function (theme) {
|
|
25
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
26
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
27
|
+
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
|
|
28
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } // import EditableHtml from '@pie-lib/editable-html';
|
|
29
|
+
// - mathquill error window not defined
|
|
30
|
+
var EditableHtml;
|
|
31
|
+
if (typeof window !== 'undefined') {
|
|
32
|
+
EditableHtml = require('@pie-lib/editable-html')['default'];
|
|
33
|
+
}
|
|
34
|
+
var StyledEditorHolder = (0, _styles.styled)('div')(function (_ref) {
|
|
35
|
+
var theme = _ref.theme;
|
|
59
36
|
return {
|
|
60
|
-
|
|
61
|
-
editorHolder: {
|
|
62
|
-
marginTop: theme.spacing.unit * 2
|
|
63
|
-
}
|
|
37
|
+
marginTop: theme.spacing(2)
|
|
64
38
|
};
|
|
65
|
-
})
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
39
|
+
});
|
|
40
|
+
var EditableHtmlContainer = function EditableHtmlContainer(_ref2) {
|
|
41
|
+
var label = _ref2.label,
|
|
42
|
+
onChange = _ref2.onChange,
|
|
43
|
+
value = _ref2.value,
|
|
44
|
+
className = _ref2.className,
|
|
45
|
+
imageSupport = _ref2.imageSupport,
|
|
46
|
+
disableImageAlignmentButtons = _ref2.disableImageAlignmentButtons,
|
|
47
|
+
disabled = _ref2.disabled,
|
|
48
|
+
spellCheck = _ref2.spellCheck,
|
|
49
|
+
nonEmpty = _ref2.nonEmpty,
|
|
50
|
+
pluginOpts = _ref2.pluginOpts,
|
|
51
|
+
toolbarOpts = _ref2.toolbarOpts,
|
|
52
|
+
error = _ref2.error,
|
|
53
|
+
maxImageWidth = _ref2.maxImageWidth,
|
|
54
|
+
maxImageHeight = _ref2.maxImageHeight,
|
|
55
|
+
uploadSoundSupport = _ref2.uploadSoundSupport,
|
|
56
|
+
_ref2$mathMlOptions = _ref2.mathMlOptions,
|
|
57
|
+
mathMlOptions = _ref2$mathMlOptions === void 0 ? {} : _ref2$mathMlOptions;
|
|
80
58
|
return /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
|
|
81
59
|
label: label,
|
|
82
|
-
className:
|
|
83
|
-
}, /*#__PURE__*/_react["default"].createElement("
|
|
84
|
-
className: classes.editorHolder
|
|
85
|
-
}, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
|
|
60
|
+
className: className
|
|
61
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledEditorHolder, null, /*#__PURE__*/_react["default"].createElement(EditableHtml, {
|
|
86
62
|
markup: value || '',
|
|
87
63
|
disabled: disabled,
|
|
88
64
|
spellCheck: spellCheck,
|
|
89
65
|
nonEmpty: nonEmpty,
|
|
90
66
|
onChange: onChange,
|
|
91
67
|
imageSupport: imageSupport,
|
|
92
|
-
|
|
68
|
+
disableImageAlignmentButtons: disableImageAlignmentButtons,
|
|
69
|
+
pluginProps: pluginOpts || {},
|
|
93
70
|
toolbarOpts: toolbarOpts,
|
|
94
71
|
error: error,
|
|
95
72
|
maxImageWidth: maxImageWidth,
|
|
96
|
-
maxImageHeight: maxImageHeight
|
|
73
|
+
maxImageHeight: maxImageHeight,
|
|
74
|
+
uploadSoundSupport: uploadSoundSupport,
|
|
75
|
+
languageCharactersProps: [{
|
|
76
|
+
language: 'spanish'
|
|
77
|
+
}, {
|
|
78
|
+
language: 'special'
|
|
79
|
+
}],
|
|
80
|
+
mathMlOptions: mathMlOptions
|
|
97
81
|
})));
|
|
82
|
+
};
|
|
83
|
+
var StyledFeedbackContainer = (0, _styles.styled)('div')(function () {
|
|
84
|
+
return {
|
|
85
|
+
position: 'relative'
|
|
86
|
+
};
|
|
98
87
|
});
|
|
99
|
-
var
|
|
88
|
+
var StyledArrowIcon = (0, _styles.styled)(_SubdirectoryArrowRight["default"])(function (_ref3) {
|
|
89
|
+
var theme = _ref3.theme;
|
|
100
90
|
return {
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
position: 'relative'
|
|
106
|
-
},
|
|
107
|
-
arrowIcon: {
|
|
108
|
-
fill: '#ccc',
|
|
109
|
-
left: -56,
|
|
110
|
-
position: 'absolute',
|
|
111
|
-
top: 20
|
|
112
|
-
}
|
|
91
|
+
fill: theme.palette.grey[400],
|
|
92
|
+
left: -56,
|
|
93
|
+
position: 'absolute',
|
|
94
|
+
top: 40
|
|
113
95
|
};
|
|
114
|
-
})
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
96
|
+
});
|
|
97
|
+
var StyledTextField = (0, _styles.styled)(_TextField["default"])(function (_ref4) {
|
|
98
|
+
var theme = _ref4.theme;
|
|
99
|
+
return {
|
|
100
|
+
width: '100%',
|
|
101
|
+
marginTop: theme.spacing(2)
|
|
102
|
+
};
|
|
103
|
+
});
|
|
104
|
+
var StyledEditableHtmlContainer = (0, _styles.styled)(EditableHtmlContainer)(function (_ref5) {
|
|
105
|
+
var theme = _ref5.theme;
|
|
106
|
+
return {
|
|
107
|
+
width: '100%',
|
|
108
|
+
marginTop: theme.spacing(2)
|
|
109
|
+
};
|
|
110
|
+
});
|
|
111
|
+
var Feedback = function Feedback(_ref6) {
|
|
112
|
+
var value = _ref6.value,
|
|
113
|
+
onChange = _ref6.onChange,
|
|
114
|
+
type = _ref6.type,
|
|
115
|
+
correct = _ref6.correct,
|
|
116
|
+
defaults = _ref6.defaults,
|
|
117
|
+
toolbarOpts = _ref6.toolbarOpts,
|
|
118
|
+
_ref6$mathMlOptions = _ref6.mathMlOptions,
|
|
119
|
+
mathMlOptions = _ref6$mathMlOptions === void 0 ? {} : _ref6$mathMlOptions;
|
|
123
120
|
if (!type || type === 'none') {
|
|
124
121
|
return null;
|
|
125
122
|
} else if (type === 'default') {
|
|
126
|
-
return /*#__PURE__*/_react["default"].createElement("
|
|
127
|
-
className: classes.feedbackContainer
|
|
128
|
-
}, /*#__PURE__*/_react["default"].createElement(_SubdirectoryArrowRight["default"], {
|
|
129
|
-
className: classes.arrowIcon
|
|
130
|
-
}), /*#__PURE__*/_react["default"].createElement(_TextField["default"], {
|
|
131
|
-
className: classes.text,
|
|
123
|
+
return /*#__PURE__*/_react["default"].createElement(StyledFeedbackContainer, null, /*#__PURE__*/_react["default"].createElement(StyledArrowIcon, null), /*#__PURE__*/_react["default"].createElement(StyledTextField, {
|
|
132
124
|
label: "Feedback Text",
|
|
133
|
-
value: correct ? defaults.correct : defaults.incorrect
|
|
125
|
+
value: correct ? defaults.correct : defaults.incorrect,
|
|
126
|
+
variant: "standard"
|
|
134
127
|
}));
|
|
135
128
|
} else {
|
|
136
|
-
return /*#__PURE__*/_react["default"].createElement("
|
|
137
|
-
className: classes.feedbackContainer
|
|
138
|
-
}, /*#__PURE__*/_react["default"].createElement(_SubdirectoryArrowRight["default"], {
|
|
139
|
-
className: classes.arrowIcon
|
|
140
|
-
}), /*#__PURE__*/_react["default"].createElement(EditableHtmlContainer, {
|
|
141
|
-
className: classes.text,
|
|
129
|
+
return /*#__PURE__*/_react["default"].createElement(StyledFeedbackContainer, null, /*#__PURE__*/_react["default"].createElement(StyledArrowIcon, null), /*#__PURE__*/_react["default"].createElement(StyledEditableHtmlContainer, {
|
|
142
130
|
label: "Feedback Text",
|
|
143
131
|
value: value,
|
|
144
132
|
onChange: onChange,
|
|
145
|
-
toolbarOpts: toolbarOpts
|
|
133
|
+
toolbarOpts: toolbarOpts,
|
|
134
|
+
mathMlOptions: mathMlOptions
|
|
146
135
|
}));
|
|
147
136
|
}
|
|
137
|
+
};
|
|
138
|
+
var StyledIndex = (0, _styles.styled)('span')(function (_ref7) {
|
|
139
|
+
var theme = _ref7.theme;
|
|
140
|
+
return {
|
|
141
|
+
paddingRight: theme.spacing(1),
|
|
142
|
+
paddingTop: theme.spacing(3)
|
|
143
|
+
};
|
|
148
144
|
});
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
145
|
+
var StyledTopRow = (0, _styles.styled)('div')(function () {
|
|
146
|
+
return {
|
|
147
|
+
display: 'flex',
|
|
148
|
+
alignItems: 'center'
|
|
149
|
+
};
|
|
150
|
+
});
|
|
151
|
+
var StyledToggle = (0, _styles.styled)('div')(function (_ref8) {
|
|
152
|
+
var theme = _ref8.theme;
|
|
153
|
+
return {
|
|
154
|
+
flex: '0 1 auto',
|
|
155
|
+
paddingTop: theme.spacing(0.5),
|
|
156
|
+
paddingBottom: 0,
|
|
157
|
+
marginRight: 0,
|
|
158
|
+
marginLeft: theme.spacing(1)
|
|
159
|
+
};
|
|
160
|
+
});
|
|
161
|
+
var StyledFeedback = (0, _styles.styled)('div')(function (_ref9) {
|
|
162
|
+
var theme = _ref9.theme;
|
|
163
|
+
return {
|
|
164
|
+
flex: '0 1 auto',
|
|
165
|
+
paddingTop: theme.spacing(2),
|
|
166
|
+
paddingLeft: 0,
|
|
167
|
+
marginLeft: 0,
|
|
168
|
+
marginRight: theme.spacing(1)
|
|
169
|
+
};
|
|
170
|
+
});
|
|
171
|
+
var StyledFeedbackIcon = (0, _styles.styled)('div')(function () {
|
|
172
|
+
return {
|
|
173
|
+
margin: 0,
|
|
174
|
+
width: 'inherit'
|
|
175
|
+
};
|
|
176
|
+
});
|
|
177
|
+
var StyledDeleteIcon = (0, _styles.styled)('div')(function () {
|
|
178
|
+
return {
|
|
179
|
+
margin: 0,
|
|
180
|
+
width: 'inherit'
|
|
181
|
+
};
|
|
182
|
+
});
|
|
183
|
+
var StyledDelete = (0, _styles.styled)('div')(function (_ref0) {
|
|
184
|
+
var theme = _ref0.theme;
|
|
185
|
+
return {
|
|
186
|
+
flex: '0 1 auto',
|
|
187
|
+
paddingTop: theme.spacing(2),
|
|
188
|
+
paddingLeft: 0,
|
|
189
|
+
marginLeft: 0
|
|
190
|
+
};
|
|
191
|
+
});
|
|
192
|
+
var StyledMiddleColumn = (0, _styles.styled)('div')(function (_ref1) {
|
|
193
|
+
var theme = _ref1.theme;
|
|
194
|
+
return {
|
|
195
|
+
display: 'flex',
|
|
196
|
+
flex: 1,
|
|
197
|
+
flexDirection: 'column',
|
|
198
|
+
marginRight: theme.spacing(1)
|
|
199
|
+
};
|
|
200
|
+
});
|
|
201
|
+
var StyledErrorText = (0, _styles.styled)('div')(function (_ref10) {
|
|
202
|
+
var theme = _ref10.theme;
|
|
203
|
+
return {
|
|
204
|
+
fontSize: theme.typography.fontSize - 2,
|
|
205
|
+
color: theme.palette.error.main
|
|
206
|
+
};
|
|
207
|
+
});
|
|
208
|
+
var ChoiceConfiguration = exports.ChoiceConfiguration = /*#__PURE__*/function (_React$Component) {
|
|
155
209
|
function ChoiceConfiguration() {
|
|
156
210
|
var _this;
|
|
157
|
-
|
|
158
211
|
(0, _classCallCheck2["default"])(this, ChoiceConfiguration);
|
|
159
|
-
|
|
160
212
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
161
213
|
args[_key] = arguments[_key];
|
|
162
214
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_changeFn", function (key) {
|
|
215
|
+
_this = _callSuper(this, ChoiceConfiguration, [].concat(args));
|
|
216
|
+
(0, _defineProperty2["default"])(_this, "_changeFn", function (key) {
|
|
166
217
|
return function (update) {
|
|
167
218
|
var _this$props = _this.props,
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
219
|
+
data = _this$props.data,
|
|
220
|
+
onChange = _this$props.onChange;
|
|
171
221
|
if (onChange) {
|
|
172
222
|
onChange(_objectSpread(_objectSpread({}, data), {}, (0, _defineProperty2["default"])({}, key, update)));
|
|
173
223
|
}
|
|
174
224
|
};
|
|
175
225
|
});
|
|
176
|
-
(0, _defineProperty2["default"])(
|
|
177
|
-
(0, _defineProperty2["default"])(
|
|
226
|
+
(0, _defineProperty2["default"])(_this, "onLabelChange", _this._changeFn('label'));
|
|
227
|
+
(0, _defineProperty2["default"])(_this, "onCheckedChange", function (event) {
|
|
178
228
|
var correct = event.target.checked;
|
|
179
229
|
var _this$props2 = _this.props,
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
230
|
+
data = _this$props2.data,
|
|
231
|
+
onChange = _this$props2.onChange;
|
|
183
232
|
if (onChange) {
|
|
184
233
|
onChange(_objectSpread(_objectSpread({}, data), {}, {
|
|
185
234
|
correct: correct
|
|
186
235
|
}));
|
|
187
236
|
}
|
|
188
237
|
});
|
|
189
|
-
(0, _defineProperty2["default"])(
|
|
238
|
+
(0, _defineProperty2["default"])(_this, "onFeedbackValueChange", function (v) {
|
|
190
239
|
var _this$props3 = _this.props,
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
240
|
+
data = _this$props3.data,
|
|
241
|
+
onChange = _this$props3.onChange;
|
|
194
242
|
if (data.feedback.type !== 'custom') {
|
|
195
243
|
return;
|
|
196
244
|
}
|
|
197
|
-
|
|
198
245
|
var fb = _objectSpread(_objectSpread({}, data.feedback), {}, {
|
|
199
246
|
value: v
|
|
200
247
|
});
|
|
201
|
-
|
|
202
248
|
if (onChange) onChange(_objectSpread(_objectSpread({}, data), {}, {
|
|
203
249
|
feedback: fb
|
|
204
250
|
}));
|
|
205
251
|
});
|
|
206
|
-
(0, _defineProperty2["default"])(
|
|
252
|
+
(0, _defineProperty2["default"])(_this, "onFeedbackTypeChange", function (t) {
|
|
207
253
|
var _this$props4 = _this.props,
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
254
|
+
data = _this$props4.data,
|
|
255
|
+
onChange = _this$props4.onChange;
|
|
211
256
|
var fb = _objectSpread(_objectSpread({}, data.feedback), {}, {
|
|
212
257
|
type: t
|
|
213
258
|
});
|
|
214
|
-
|
|
215
259
|
if (fb.type !== 'custom') {
|
|
216
260
|
fb.value = undefined;
|
|
217
261
|
}
|
|
218
|
-
|
|
219
262
|
if (onChange) onChange(_objectSpread(_objectSpread({}, data), {}, {
|
|
220
263
|
feedback: fb
|
|
221
264
|
}));
|
|
222
265
|
});
|
|
223
266
|
return _this;
|
|
224
267
|
}
|
|
225
|
-
|
|
226
|
-
(0, _createClass2["default"])(ChoiceConfiguration, [{
|
|
268
|
+
(0, _inherits2["default"])(ChoiceConfiguration, _React$Component);
|
|
269
|
+
return (0, _createClass2["default"])(ChoiceConfiguration, [{
|
|
227
270
|
key: "render",
|
|
228
271
|
value: function render() {
|
|
229
272
|
var _this$props5 = this.props,
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
273
|
+
data = _this$props5.data,
|
|
274
|
+
mode = _this$props5.mode,
|
|
275
|
+
onDelete = _this$props5.onDelete,
|
|
276
|
+
defaultFeedback = _this$props5.defaultFeedback,
|
|
277
|
+
index = _this$props5.index,
|
|
278
|
+
className = _this$props5.className,
|
|
279
|
+
noLabels = _this$props5.noLabels,
|
|
280
|
+
useLetterOrdering = _this$props5.useLetterOrdering,
|
|
281
|
+
imageSupport = _this$props5.imageSupport,
|
|
282
|
+
disableImageAlignmentButtons = _this$props5.disableImageAlignmentButtons,
|
|
283
|
+
disabled = _this$props5.disabled,
|
|
284
|
+
spellCheck = _this$props5.spellCheck,
|
|
285
|
+
nonEmpty = _this$props5.nonEmpty,
|
|
286
|
+
allowFeedBack = _this$props5.allowFeedBack,
|
|
287
|
+
allowDelete = _this$props5.allowDelete,
|
|
288
|
+
pluginOpts = _this$props5.pluginOpts,
|
|
289
|
+
toolbarOpts = _this$props5.toolbarOpts,
|
|
290
|
+
error = _this$props5.error,
|
|
291
|
+
noCorrectAnswerError = _this$props5.noCorrectAnswerError,
|
|
292
|
+
uploadSoundSupport = _this$props5.uploadSoundSupport,
|
|
293
|
+
maxImageWidth = _this$props5.maxImageWidth,
|
|
294
|
+
maxImageHeight = _this$props5.maxImageHeight,
|
|
295
|
+
_this$props5$mathMlOp = _this$props5.mathMlOptions,
|
|
296
|
+
mathMlOptions = _this$props5$mathMlOp === void 0 ? {} : _this$props5$mathMlOp;
|
|
248
297
|
var InputToggle = mode === 'checkbox' ? _inputs.InputCheckbox : _inputs.InputRadio;
|
|
249
|
-
|
|
250
|
-
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
251
|
-
className: names
|
|
252
|
-
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
253
|
-
className: classes.topRow
|
|
254
|
-
}, index > 0 && /*#__PURE__*/_react["default"].createElement("span", {
|
|
255
|
-
className: classes.index,
|
|
298
|
+
return /*#__PURE__*/_react["default"].createElement(StyledTopRow, null, index > 0 && /*#__PURE__*/_react["default"].createElement(StyledIndex, {
|
|
256
299
|
type: "title"
|
|
257
|
-
}, useLetterOrdering ? String.fromCharCode(96 + index).toUpperCase() : index), /*#__PURE__*/_react["default"].createElement(InputToggle, {
|
|
258
|
-
className: classes.toggle,
|
|
300
|
+
}, useLetterOrdering ? String.fromCharCode(96 + index).toUpperCase() : index), /*#__PURE__*/_react["default"].createElement(StyledToggle, null, /*#__PURE__*/_react["default"].createElement(InputToggle, {
|
|
259
301
|
onChange: this.onCheckedChange,
|
|
260
302
|
label: !noLabels ? 'Correct' : '',
|
|
261
303
|
checked: !!data.correct,
|
|
262
304
|
error: noCorrectAnswerError
|
|
263
|
-
}), /*#__PURE__*/_react["default"].createElement("
|
|
264
|
-
className: classes.middleColumn
|
|
265
|
-
}, /*#__PURE__*/_react["default"].createElement(EditableHtmlContainer, {
|
|
305
|
+
})), /*#__PURE__*/_react["default"].createElement(StyledMiddleColumn, null, /*#__PURE__*/_react["default"].createElement(EditableHtmlContainer, {
|
|
266
306
|
label: !noLabels ? 'Label' : '',
|
|
267
307
|
value: data.label,
|
|
268
308
|
onChange: this.onLabelChange,
|
|
269
309
|
imageSupport: imageSupport,
|
|
310
|
+
disableImageAlignmentButtons: disableImageAlignmentButtons,
|
|
270
311
|
disabled: disabled,
|
|
271
312
|
spellCheck: spellCheck,
|
|
272
313
|
nonEmpty: nonEmpty,
|
|
314
|
+
pluginOpts: pluginOpts,
|
|
273
315
|
toolbarOpts: toolbarOpts,
|
|
274
|
-
error: error
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
316
|
+
error: error,
|
|
317
|
+
uploadSoundSupport: uploadSoundSupport,
|
|
318
|
+
mathMlOptions: mathMlOptions,
|
|
319
|
+
maxImageWidth: maxImageWidth,
|
|
320
|
+
maxImageHeight: maxImageHeight
|
|
321
|
+
}), error && /*#__PURE__*/_react["default"].createElement(StyledErrorText, null, error), allowFeedBack && /*#__PURE__*/_react["default"].createElement(Feedback, (0, _extends2["default"])({}, data.feedback, {
|
|
278
322
|
correct: data.correct,
|
|
279
323
|
defaults: defaultFeedback,
|
|
280
324
|
onChange: this.onFeedbackValueChange,
|
|
281
325
|
toolbarOpts: toolbarOpts
|
|
282
|
-
}))), allowFeedBack && /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
|
|
283
|
-
className: classes.feedback,
|
|
326
|
+
}))), allowFeedBack && /*#__PURE__*/_react["default"].createElement(StyledFeedback, null, /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
|
|
284
327
|
label: !noLabels ? 'Feedback' : ''
|
|
285
|
-
}, /*#__PURE__*/_react["default"].createElement(_feedbackMenu["default"], {
|
|
328
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledFeedbackIcon, null, /*#__PURE__*/_react["default"].createElement(_feedbackMenu["default"], {
|
|
286
329
|
onChange: this.onFeedbackTypeChange,
|
|
287
|
-
value: data.feedback
|
|
288
|
-
|
|
289
|
-
icon: classes.feedbackIcon
|
|
290
|
-
}
|
|
291
|
-
})), allowDelete && /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
|
|
292
|
-
className: classes["delete"],
|
|
330
|
+
value: data.feedback
|
|
331
|
+
})))), allowDelete && /*#__PURE__*/_react["default"].createElement(StyledDelete, null, /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
|
|
293
332
|
label: !noLabels ? 'Delete' : ''
|
|
294
|
-
}, /*#__PURE__*/_react["default"].createElement(_IconButton["default"], {
|
|
333
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledDeleteIcon, null, /*#__PURE__*/_react["default"].createElement(_IconButton["default"], {
|
|
295
334
|
"aria-label": "delete",
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
}, /*#__PURE__*/_react["default"].createElement(_Delete["default"], null)))));
|
|
335
|
+
onClick: onDelete,
|
|
336
|
+
size: "large"
|
|
337
|
+
}, /*#__PURE__*/_react["default"].createElement(_Delete["default"], null))))));
|
|
299
338
|
}
|
|
300
339
|
}]);
|
|
301
|
-
return ChoiceConfiguration;
|
|
302
340
|
}(_react["default"].Component);
|
|
303
|
-
|
|
304
|
-
exports.ChoiceConfiguration = ChoiceConfiguration;
|
|
305
341
|
(0, _defineProperty2["default"])(ChoiceConfiguration, "propTypes", {
|
|
306
|
-
classes: _propTypes["default"].object.isRequired,
|
|
307
342
|
noLabels: _propTypes["default"].bool,
|
|
308
343
|
useLetterOrdering: _propTypes["default"].bool,
|
|
309
344
|
className: _propTypes["default"].string,
|
|
345
|
+
error: _propTypes["default"].string,
|
|
310
346
|
mode: _propTypes["default"].oneOf(['checkbox', 'radio']),
|
|
311
347
|
defaultFeedback: _propTypes["default"].object.isRequired,
|
|
312
348
|
disabled: _propTypes["default"].bool,
|
|
@@ -327,9 +363,16 @@ exports.ChoiceConfiguration = ChoiceConfiguration;
|
|
|
327
363
|
add: _propTypes["default"].func.isRequired,
|
|
328
364
|
"delete": _propTypes["default"].func.isRequired
|
|
329
365
|
}),
|
|
366
|
+
disableImageAlignmentButtons: _propTypes["default"].bool,
|
|
330
367
|
allowFeedBack: _propTypes["default"].bool,
|
|
331
368
|
allowDelete: _propTypes["default"].bool,
|
|
332
|
-
|
|
369
|
+
noCorrectAnswerError: _propTypes["default"].string,
|
|
370
|
+
spellCheck: _propTypes["default"].bool,
|
|
371
|
+
pluginOpts: _propTypes["default"].object,
|
|
372
|
+
toolbarOpts: _propTypes["default"].object,
|
|
373
|
+
uploadSoundSupport: _propTypes["default"].object,
|
|
374
|
+
maxImageWidth: _propTypes["default"].number,
|
|
375
|
+
maxImageHeight: _propTypes["default"].number
|
|
333
376
|
});
|
|
334
377
|
(0, _defineProperty2["default"])(ChoiceConfiguration, "defaultProps", {
|
|
335
378
|
index: -1,
|
|
@@ -338,61 +381,5 @@ exports.ChoiceConfiguration = ChoiceConfiguration;
|
|
|
338
381
|
allowFeedBack: true,
|
|
339
382
|
allowDelete: true
|
|
340
383
|
});
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
return {
|
|
344
|
-
index: {
|
|
345
|
-
padding: '24px 10px 0 0'
|
|
346
|
-
},
|
|
347
|
-
choiceConfiguration: {},
|
|
348
|
-
topRow: {
|
|
349
|
-
display: 'flex'
|
|
350
|
-
},
|
|
351
|
-
value: {
|
|
352
|
-
flex: '0.5',
|
|
353
|
-
paddingRight: theme.spacing.unit
|
|
354
|
-
},
|
|
355
|
-
editorHolder: {
|
|
356
|
-
marginTop: theme.spacing.unit * 2
|
|
357
|
-
},
|
|
358
|
-
toggle: {
|
|
359
|
-
flex: '0 1 auto'
|
|
360
|
-
},
|
|
361
|
-
feedback: {
|
|
362
|
-
flex: '0 1 auto',
|
|
363
|
-
paddingTop: theme.spacing.unit,
|
|
364
|
-
paddingLeft: 0,
|
|
365
|
-
marginLeft: 0,
|
|
366
|
-
paddingRight: theme.spacing.unit * 3
|
|
367
|
-
},
|
|
368
|
-
feedbackIcon: {
|
|
369
|
-
margin: 0,
|
|
370
|
-
paddingLeft: 0,
|
|
371
|
-
width: 'inherit'
|
|
372
|
-
},
|
|
373
|
-
deleteIcon: {
|
|
374
|
-
margin: 0,
|
|
375
|
-
width: 'inherit'
|
|
376
|
-
},
|
|
377
|
-
"delete": {
|
|
378
|
-
flex: '0 1 auto',
|
|
379
|
-
paddingTop: theme.spacing.unit,
|
|
380
|
-
paddingLeft: 0,
|
|
381
|
-
marginLeft: 0
|
|
382
|
-
},
|
|
383
|
-
middleColumn: {
|
|
384
|
-
display: 'flex',
|
|
385
|
-
flex: 1,
|
|
386
|
-
flexDirection: 'column'
|
|
387
|
-
},
|
|
388
|
-
errorText: {
|
|
389
|
-
fontSize: '12px',
|
|
390
|
-
color: 'red'
|
|
391
|
-
}
|
|
392
|
-
};
|
|
393
|
-
};
|
|
394
|
-
|
|
395
|
-
var _default = (0, _styles.withStyles)(styles)(ChoiceConfiguration);
|
|
396
|
-
|
|
397
|
-
exports["default"] = _default;
|
|
398
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EditableHtmlContainer","withStyles","theme","labelContainer","editorHolder","marginTop","spacing","unit","label","classes","onChange","value","className","imageSupport","disabled","spellCheck","nonEmpty","toolbarOpts","error","maxImageWidth","maxImageHeight","names","classNames","editor","Feedback","text","width","feedbackContainer","position","arrowIcon","fill","left","top","type","correct","defaults","incorrect","ChoiceConfiguration","key","update","props","data","_changeFn","event","target","checked","v","feedback","fb","t","undefined","mode","onDelete","defaultFeedback","index","noLabels","useLetterOrdering","allowFeedBack","allowDelete","noCorrectAnswerError","InputToggle","InputCheckbox","InputRadio","choiceConfiguration","topRow","String","fromCharCode","toUpperCase","toggle","onCheckedChange","middleColumn","onLabelChange","errorText","onFeedbackValueChange","onFeedbackTypeChange","icon","feedbackIcon","deleteIcon","React","Component","PropTypes","object","isRequired","bool","string","oneOf","shape","func","number","add","styles","padding","display","flex","paddingRight","paddingTop","paddingLeft","marginLeft","margin","flexDirection","fontSize","color"],"sources":["../../src/choice-configuration/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport TextField from '@material-ui/core/TextField';\nimport classNames from 'classnames';\nimport { InputContainer } from '@pie-lib/render-ui';\nimport EditableHtml from '@pie-lib/editable-html';\nimport { InputCheckbox, InputRadio } from '../inputs';\nimport FeedbackMenu from './feedback-menu';\nimport ActionDelete from '@material-ui/icons/Delete';\nimport ArrowRight from '@material-ui/icons/SubdirectoryArrowRight';\nimport IconButton from '@material-ui/core/IconButton';\n\nconst EditableHtmlContainer = withStyles(theme => ({\n  labelContainer: {},\n  editorHolder: {\n    marginTop: theme.spacing.unit * 2\n  }\n}))(\n  ({\n     label,\n     classes,\n     onChange,\n     value,\n     className,\n     imageSupport,\n     disabled,\n     spellCheck,\n     nonEmpty,\n     toolbarOpts,\n     error,\n     maxImageWidth,\n     maxImageHeight\n   }) => {\n    const names = classNames(classes.labelContainer, className);\n\n    return (\n      <InputContainer label={label} className={names}>\n        <div className={classes.editorHolder}>\n          <EditableHtml\n            markup={value || ''}\n            disabled={disabled}\n            spellCheck={spellCheck}\n            nonEmpty={nonEmpty}\n            onChange={onChange}\n            imageSupport={imageSupport}\n            className={classes.editor}\n            toolbarOpts={toolbarOpts}\n            error={error}\n            maxImageWidth={maxImageWidth}\n            maxImageHeight={maxImageHeight}\n          />\n        </div>\n      </InputContainer>\n    );\n  }\n);\n\nconst Feedback = withStyles(() => ({\n  text: {\n    width: '100%'\n  },\n  feedbackContainer: {\n    position: 'relative'\n  },\n  arrowIcon: {\n    fill: '#ccc',\n    left: -56,\n    position: 'absolute',\n    top: 20\n  }\n}))(({ value, onChange, type, correct, classes, defaults, toolbarOpts }) => {\n  if (!type || type === 'none') {\n    return null;\n  } else if (type === 'default') {\n    return (\n      <div className={classes.feedbackContainer}>\n        <ArrowRight className={classes.arrowIcon} />\n        <TextField\n          className={classes.text}\n          label=\"Feedback Text\"\n          value={correct ? defaults.correct : defaults.incorrect}\n        />\n      </div>\n    );\n  } else {\n    return (\n      <div className={classes.feedbackContainer}>\n        <ArrowRight className={classes.arrowIcon} />\n        <EditableHtmlContainer\n          className={classes.text}\n          label=\"Feedback Text\"\n          value={value}\n          onChange={onChange}\n          toolbarOpts={toolbarOpts}\n        />\n      </div>\n    );\n  }\n});\n\nexport class ChoiceConfiguration extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object.isRequired,\n    noLabels: PropTypes.bool,\n    useLetterOrdering: PropTypes.bool,\n    className: PropTypes.string,\n    mode: PropTypes.oneOf(['checkbox', 'radio']),\n    defaultFeedback: PropTypes.object.isRequired,\n    disabled: PropTypes.bool,\n    nonEmpty: PropTypes.bool,\n    data: PropTypes.shape({\n      label: PropTypes.string.isRequired,\n      value: PropTypes.string.isRequired,\n      correct: PropTypes.bool,\n      feedback: PropTypes.shape({\n        type: PropTypes.string,\n        value: PropTypes.string\n      })\n    }),\n    onDelete: PropTypes.func,\n    onChange: PropTypes.func,\n    index: PropTypes.number,\n    imageSupport: PropTypes.shape({\n      add: PropTypes.func.isRequired,\n      delete: PropTypes.func.isRequired\n    }),\n    allowFeedBack: PropTypes.bool,\n    allowDelete: PropTypes.bool,\n    toolbarOpts: PropTypes.object\n  };\n\n  static defaultProps = {\n    index: -1,\n    noLabels: false,\n    useLetterOrdering: false,\n    allowFeedBack: true,\n    allowDelete: true\n  };\n\n  _changeFn = key => update => {\n    const { data, onChange } = this.props;\n    if (onChange) {\n      onChange({ ...data, [key]: update });\n    }\n  };\n\n  onLabelChange = this._changeFn('label');\n\n  onCheckedChange = event => {\n    const correct = event.target.checked;\n    const { data, onChange } = this.props;\n\n    if (onChange) {\n      onChange({ ...data, correct });\n    }\n  };\n\n  onFeedbackValueChange = v => {\n    const { data, onChange } = this.props;\n\n    if (data.feedback.type !== 'custom') {\n      return;\n    }\n\n    const fb = { ...data.feedback, value: v };\n\n    if (onChange) onChange({ ...data, feedback: fb });\n  };\n\n  onFeedbackTypeChange = t => {\n    const { data, onChange } = this.props;\n    const fb = { ...data.feedback, type: t };\n    if (fb.type !== 'custom') {\n      fb.value = undefined;\n    }\n\n    if (onChange) onChange({ ...data, feedback: fb });\n  };\n\n  render() {\n    const {\n      data,\n      classes,\n      mode,\n      onDelete,\n      defaultFeedback,\n      index,\n      className,\n      noLabels,\n      useLetterOrdering,\n      imageSupport,\n      disabled,\n      spellCheck,\n      nonEmpty,\n      allowFeedBack,\n      allowDelete,\n      toolbarOpts,\n      error,\n      noCorrectAnswerError\n    } = this.props;\n\n    const InputToggle = mode === 'checkbox' ? InputCheckbox : InputRadio;\n    const names = classNames(classes.choiceConfiguration, className);\n    return (\n      <div className={names}>\n        <div className={classes.topRow}>\n          {index > 0 && (\n            <span className={classes.index} type=\"title\">\n              {useLetterOrdering ? String.fromCharCode(96 + index).toUpperCase() : index}\n            </span>\n          )}\n          <InputToggle\n            className={classes.toggle}\n            onChange={this.onCheckedChange}\n            label={!noLabels ? 'Correct' : ''}\n            checked={!!data.correct}\n            error={noCorrectAnswerError}\n          />\n          <div className={classes.middleColumn}>\n            <EditableHtmlContainer\n              label={!noLabels ? 'Label' : ''}\n              value={data.label}\n              onChange={this.onLabelChange}\n              imageSupport={imageSupport}\n              disabled={disabled}\n              spellCheck={spellCheck}\n              nonEmpty={nonEmpty}\n              toolbarOpts={toolbarOpts}\n              error={error}\n            />\n            {error && <div className={classes.errorText}>{error}</div>}\n\n            {allowFeedBack && (\n              <Feedback\n                {...data.feedback}\n                correct={data.correct}\n                defaults={defaultFeedback}\n                onChange={this.onFeedbackValueChange}\n                toolbarOpts={toolbarOpts}\n              />\n            )}\n          </div>\n          {allowFeedBack && (\n            <InputContainer className={classes.feedback} label={!noLabels ? 'Feedback' : ''}>\n              <FeedbackMenu\n                onChange={this.onFeedbackTypeChange}\n                value={data.feedback}\n                classes={{\n                  icon: classes.feedbackIcon\n                }}\n              />\n            </InputContainer>\n          )}\n          {allowDelete && (\n            <InputContainer className={classes.delete} label={!noLabels ? 'Delete' : ''}>\n              <IconButton aria-label=\"delete\" className={classes.deleteIcon} onClick={onDelete}>\n                <ActionDelete />\n              </IconButton>\n            </InputContainer>\n          )}\n        </div>\n      </div>\n    );\n  }\n}\n\nconst styles = theme => ({\n  index: {\n    padding: '24px 10px 0 0'\n  },\n  choiceConfiguration: {},\n  topRow: {\n    display: 'flex'\n  },\n  value: {\n    flex: '0.5',\n    paddingRight: theme.spacing.unit\n  },\n  editorHolder: {\n    marginTop: theme.spacing.unit * 2\n  },\n  toggle: {\n    flex: '0 1 auto'\n  },\n  feedback: {\n    flex: '0 1 auto',\n    paddingTop: theme.spacing.unit,\n    paddingLeft: 0,\n    marginLeft: 0,\n    paddingRight: theme.spacing.unit * 3\n  },\n  feedbackIcon: {\n    margin: 0,\n    paddingLeft: 0,\n    width: 'inherit'\n  },\n  deleteIcon: {\n    margin: 0,\n    width: 'inherit'\n  },\n  delete: {\n    flex: '0 1 auto',\n    paddingTop: theme.spacing.unit,\n    paddingLeft: 0,\n    marginLeft: 0\n  },\n  middleColumn: {\n    display: 'flex',\n    flex: 1,\n    flexDirection: 'column'\n  },\n  errorText: {\n    fontSize: '12px',\n    color: 'red'\n  }\n});\n\nexport default withStyles(styles)(ChoiceConfiguration);\n"],"mappings":"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"}
|
|
384
|
+
var _default = exports["default"] = ChoiceConfiguration;
|
|
385
|
+
//# sourceMappingURL=index.js.map
|