@pie-lib/config-ui 11.30.3-next.2 → 11.30.4-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.
Files changed (145) hide show
  1. package/CHANGELOG.md +7 -78
  2. package/lib/__tests__/alert-dialog.test.js +262 -0
  3. package/lib/__tests__/checkbox.test.js +227 -0
  4. package/lib/__tests__/choice-utils.test.js +14 -0
  5. package/lib/__tests__/form-section.test.js +252 -0
  6. package/lib/__tests__/help.test.js +270 -0
  7. package/lib/__tests__/input.test.js +268 -0
  8. package/lib/__tests__/langs.test.js +541 -0
  9. package/lib/__tests__/number-text-field-custom.test.js +362 -0
  10. package/lib/__tests__/number-text-field.test.js +421 -0
  11. package/lib/__tests__/radio-with-label.test.js +233 -0
  12. package/lib/__tests__/settings-panel.test.js +184 -0
  13. package/lib/__tests__/settings.test.js +653 -0
  14. package/lib/__tests__/tabs.test.js +211 -0
  15. package/lib/__tests__/two-choice.test.js +124 -0
  16. package/lib/__tests__/with-stateful-model.test.js +221 -0
  17. package/lib/alert-dialog.js +36 -43
  18. package/lib/alert-dialog.js.map +1 -1
  19. package/lib/checkbox.js +57 -72
  20. package/lib/checkbox.js.map +1 -1
  21. package/lib/choice-configuration/__tests__/feedback-menu.test.js +287 -0
  22. package/lib/choice-configuration/__tests__/index.test.js +253 -0
  23. package/lib/choice-configuration/feedback-menu.js +30 -65
  24. package/lib/choice-configuration/feedback-menu.js.map +1 -1
  25. package/lib/choice-configuration/index.js +203 -263
  26. package/lib/choice-configuration/index.js.map +1 -1
  27. package/lib/choice-utils.js +7 -19
  28. package/lib/choice-utils.js.map +1 -1
  29. package/lib/feedback-config/__tests__/feedback-config.test.js +201 -0
  30. package/lib/feedback-config/__tests__/feedback-selector.test.js +177 -0
  31. package/lib/feedback-config/feedback-selector.js +80 -116
  32. package/lib/feedback-config/feedback-selector.js.map +1 -1
  33. package/lib/feedback-config/group.js +27 -41
  34. package/lib/feedback-config/group.js.map +1 -1
  35. package/lib/feedback-config/index.js +48 -91
  36. package/lib/feedback-config/index.js.map +1 -1
  37. package/lib/form-section.js +32 -34
  38. package/lib/form-section.js.map +1 -1
  39. package/lib/help.js +40 -81
  40. package/lib/help.js.map +1 -1
  41. package/lib/index.js +2 -32
  42. package/lib/index.js.map +1 -1
  43. package/lib/input.js +22 -55
  44. package/lib/input.js.map +1 -1
  45. package/lib/inputs.js +62 -96
  46. package/lib/inputs.js.map +1 -1
  47. package/lib/langs.js +59 -102
  48. package/lib/langs.js.map +1 -1
  49. package/lib/layout/__tests__/config.layout.test.js +70 -0
  50. package/lib/layout/__tests__/layout-content.test.js +6 -0
  51. package/lib/layout/config-layout.js +41 -71
  52. package/lib/layout/config-layout.js.map +1 -1
  53. package/lib/layout/index.js +1 -4
  54. package/lib/layout/index.js.map +1 -1
  55. package/lib/layout/layout-contents.js +73 -104
  56. package/lib/layout/layout-contents.js.map +1 -1
  57. package/lib/layout/settings-box.js +28 -57
  58. package/lib/layout/settings-box.js.map +1 -1
  59. package/lib/mui-box/index.js +42 -58
  60. package/lib/mui-box/index.js.map +1 -1
  61. package/lib/number-text-field-custom.js +80 -162
  62. package/lib/number-text-field-custom.js.map +1 -1
  63. package/lib/number-text-field.js +81 -115
  64. package/lib/number-text-field.js.map +1 -1
  65. package/lib/radio-with-label.js +31 -32
  66. package/lib/radio-with-label.js.map +1 -1
  67. package/lib/settings/display-size.js +17 -33
  68. package/lib/settings/display-size.js.map +1 -1
  69. package/lib/settings/index.js +15 -48
  70. package/lib/settings/index.js.map +1 -1
  71. package/lib/settings/panel.js +160 -230
  72. package/lib/settings/panel.js.map +1 -1
  73. package/lib/settings/settings-radio-label.js +29 -31
  74. package/lib/settings/settings-radio-label.js.map +1 -1
  75. package/lib/settings/toggle.js +36 -47
  76. package/lib/settings/toggle.js.map +1 -1
  77. package/lib/tabs/index.js +23 -58
  78. package/lib/tabs/index.js.map +1 -1
  79. package/lib/tags-input/__tests__/index.test.js +183 -0
  80. package/lib/tags-input/index.js +51 -100
  81. package/lib/tags-input/index.js.map +1 -1
  82. package/lib/two-choice.js +47 -91
  83. package/lib/two-choice.js.map +1 -1
  84. package/lib/with-stateful-model.js +9 -32
  85. package/lib/with-stateful-model.js.map +1 -1
  86. package/package.json +12 -20
  87. package/src/__tests__/alert-dialog.test.jsx +283 -0
  88. package/src/__tests__/checkbox.test.jsx +249 -0
  89. package/src/__tests__/form-section.test.jsx +334 -0
  90. package/src/__tests__/help.test.jsx +184 -0
  91. package/src/__tests__/input.test.jsx +192 -0
  92. package/src/__tests__/langs.test.jsx +435 -15
  93. package/src/__tests__/number-text-field-custom.test.jsx +438 -0
  94. package/src/__tests__/number-text-field.test.jsx +295 -102
  95. package/src/__tests__/radio-with-label.test.jsx +259 -0
  96. package/src/__tests__/settings-panel.test.js +66 -83
  97. package/src/__tests__/settings.test.jsx +515 -0
  98. package/src/__tests__/tabs.test.jsx +193 -0
  99. package/src/__tests__/two-choice.test.js +104 -18
  100. package/src/__tests__/with-stateful-model.test.jsx +145 -0
  101. package/src/alert-dialog.jsx +21 -19
  102. package/src/checkbox.jsx +42 -46
  103. package/src/choice-configuration/__tests__/feedback-menu.test.jsx +157 -4
  104. package/src/choice-configuration/__tests__/index.test.jsx +198 -56
  105. package/src/choice-configuration/feedback-menu.jsx +6 -6
  106. package/src/choice-configuration/index.jsx +201 -196
  107. package/src/feedback-config/__tests__/feedback-config.test.jsx +130 -60
  108. package/src/feedback-config/__tests__/feedback-selector.test.jsx +87 -40
  109. package/src/feedback-config/feedback-selector.jsx +52 -53
  110. package/src/feedback-config/group.jsx +21 -22
  111. package/src/feedback-config/index.jsx +27 -29
  112. package/src/form-section.jsx +26 -18
  113. package/src/help.jsx +20 -28
  114. package/src/input.jsx +1 -1
  115. package/src/inputs.jsx +34 -50
  116. package/src/langs.jsx +41 -46
  117. package/src/layout/__tests__/config.layout.test.jsx +55 -38
  118. package/src/layout/config-layout.jsx +38 -32
  119. package/src/layout/layout-contents.jsx +38 -39
  120. package/src/layout/settings-box.jsx +16 -19
  121. package/src/mui-box/index.jsx +35 -43
  122. package/src/number-text-field-custom.jsx +30 -36
  123. package/src/number-text-field.jsx +45 -29
  124. package/src/radio-with-label.jsx +25 -13
  125. package/src/settings/display-size.jsx +12 -11
  126. package/src/settings/panel.jsx +97 -91
  127. package/src/settings/settings-radio-label.jsx +25 -13
  128. package/src/settings/toggle.jsx +30 -29
  129. package/src/tabs/index.jsx +8 -8
  130. package/src/tags-input/__tests__/index.test.jsx +88 -37
  131. package/src/tags-input/index.jsx +35 -38
  132. package/src/two-choice.jsx +15 -19
  133. package/esm/index.css +0 -847
  134. package/esm/index.js +0 -213950
  135. package/esm/index.js.map +0 -1
  136. package/esm/package.json +0 -3
  137. package/src/__tests__/__snapshots__/langs.test.jsx.snap +0 -32
  138. package/src/__tests__/__snapshots__/settings-panel.test.js.snap +0 -115
  139. package/src/__tests__/__snapshots__/two-choice.test.js.snap +0 -171
  140. package/src/choice-configuration/__tests__/__snapshots__/feedback-menu.test.jsx.snap +0 -51
  141. package/src/choice-configuration/__tests__/__snapshots__/index.test.jsx.snap +0 -519
  142. package/src/feedback-config/__tests__/__snapshots__/feedback-config.test.jsx.snap +0 -27
  143. package/src/feedback-config/__tests__/__snapshots__/feedback-selector.test.jsx.snap +0 -38
  144. package/src/layout/__tests__/__snapshots__/config.layout.test.jsx.snap +0 -59
  145. package/src/tags-input/__tests__/__snapshots__/index.test.jsx.snap +0 -170
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = require("@testing-library/react");
7
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
8
+ var _react2 = _interopRequireDefault(require("react"));
9
+ var _feedbackSelector = require("../feedback-selector");
10
+ // Mock the editable-html component to avoid window dependencies in tests
11
+ jest.mock('@pie-lib/editable-html', function () {
12
+ return {
13
+ __esModule: true,
14
+ "default": function _default(_ref) {
15
+ var markup = _ref.markup,
16
+ _onChange = _ref.onChange;
17
+ return /*#__PURE__*/_react2["default"].createElement("textarea", {
18
+ "data-testid": "editable-html",
19
+ defaultValue: markup || '',
20
+ onChange: function onChange(e) {
21
+ return _onChange(e.target.value);
22
+ }
23
+ });
24
+ }
25
+ };
26
+ });
27
+ describe('feedback-selector', function () {
28
+ var onChange;
29
+ var renderComponent = function renderComponent() {
30
+ var feedback = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
31
+ type: 'default',
32
+ "default": 'hi'
33
+ };
34
+ return (0, _react.render)(/*#__PURE__*/_react2["default"].createElement(_feedbackSelector.FeedbackSelector, {
35
+ label: 'Feedback',
36
+ onChange: onChange,
37
+ feedback: feedback
38
+ }));
39
+ };
40
+ beforeEach(function () {
41
+ onChange = jest.fn();
42
+ });
43
+ describe('rendering', function () {
44
+ it('renders feedback type selector', function () {
45
+ renderComponent();
46
+ expect(_react.screen.getByText('Simple Feedback')).toBeInTheDocument();
47
+ expect(_react.screen.getByText('No Feedback')).toBeInTheDocument();
48
+ expect(_react.screen.getByText('Customized Feedback')).toBeInTheDocument();
49
+ });
50
+ it('shows default feedback text when type is default', function () {
51
+ renderComponent({
52
+ type: 'default',
53
+ "default": 'hi'
54
+ });
55
+ expect(_react.screen.getByText('hi')).toBeInTheDocument();
56
+ });
57
+ it('shows editable html when type is custom', function () {
58
+ renderComponent({
59
+ type: 'custom',
60
+ "default": 'hi',
61
+ custom: 'custom text'
62
+ });
63
+ expect(_react.screen.getByTestId('editable-html')).toBeInTheDocument();
64
+ expect(_react.screen.getByTestId('editable-html')).toHaveValue('custom text');
65
+ });
66
+ it('does not show default feedback when type is none', function () {
67
+ renderComponent({
68
+ type: 'none',
69
+ "default": 'hi'
70
+ });
71
+ expect(_react.screen.queryByText('hi')).not.toBeInTheDocument();
72
+ });
73
+ });
74
+ describe('user interactions', function () {
75
+ it('calls onChange when switching to default feedback', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
76
+ var user;
77
+ return _regenerator["default"].wrap(function (_context) {
78
+ while (1) switch (_context.prev = _context.next) {
79
+ case 0:
80
+ user = _userEvent["default"].setup();
81
+ renderComponent({
82
+ type: 'custom',
83
+ "default": 'hi'
84
+ });
85
+ _context.next = 1;
86
+ return user.click(_react.screen.getByLabelText('Simple Feedback'));
87
+ case 1:
88
+ expect(onChange).toHaveBeenCalledWith({
89
+ type: 'default',
90
+ "default": 'hi'
91
+ });
92
+ case 2:
93
+ case "end":
94
+ return _context.stop();
95
+ }
96
+ }, _callee);
97
+ })));
98
+ it('calls onChange when switching to custom feedback', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
99
+ var user;
100
+ return _regenerator["default"].wrap(function (_context2) {
101
+ while (1) switch (_context2.prev = _context2.next) {
102
+ case 0:
103
+ user = _userEvent["default"].setup();
104
+ renderComponent({
105
+ type: 'default',
106
+ "default": 'hi'
107
+ });
108
+ _context2.next = 1;
109
+ return user.click(_react.screen.getByLabelText('Customized Feedback'));
110
+ case 1:
111
+ expect(onChange).toHaveBeenCalledWith({
112
+ type: 'custom',
113
+ "default": 'hi'
114
+ });
115
+ case 2:
116
+ case "end":
117
+ return _context2.stop();
118
+ }
119
+ }, _callee2);
120
+ })));
121
+ it('calls onChange when switching to no feedback', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
122
+ var user;
123
+ return _regenerator["default"].wrap(function (_context3) {
124
+ while (1) switch (_context3.prev = _context3.next) {
125
+ case 0:
126
+ user = _userEvent["default"].setup();
127
+ renderComponent({
128
+ type: 'default',
129
+ "default": 'hi'
130
+ });
131
+ _context3.next = 1;
132
+ return user.click(_react.screen.getByLabelText('No Feedback'));
133
+ case 1:
134
+ expect(onChange).toHaveBeenCalledWith({
135
+ type: 'none',
136
+ "default": 'hi'
137
+ });
138
+ case 2:
139
+ case "end":
140
+ return _context3.stop();
141
+ }
142
+ }, _callee3);
143
+ })));
144
+ it('calls onChange with custom text when editing custom feedback', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4() {
145
+ var user, editor, lastCall;
146
+ return _regenerator["default"].wrap(function (_context4) {
147
+ while (1) switch (_context4.prev = _context4.next) {
148
+ case 0:
149
+ user = _userEvent["default"].setup();
150
+ renderComponent({
151
+ type: 'custom',
152
+ "default": 'hi',
153
+ custom: ''
154
+ });
155
+ editor = _react.screen.getByTestId('editable-html');
156
+ _context4.next = 1;
157
+ return user.clear(editor);
158
+ case 1:
159
+ _context4.next = 2;
160
+ return user.type(editor, 'text');
161
+ case 2:
162
+ // user.type triggers onChange for each character, so check that onChange was called
163
+ // and that the last call has 'text' in custom field
164
+ expect(onChange).toHaveBeenCalled();
165
+ lastCall = onChange.mock.calls[onChange.mock.calls.length - 1][0];
166
+ expect(lastCall.type).toBe('custom');
167
+ expect(lastCall.custom).toBe('text');
168
+ expect(lastCall["default"]).toBe('hi');
169
+ case 3:
170
+ case "end":
171
+ return _context4.stop();
172
+ }
173
+ }, _callee4);
174
+ })));
175
+ });
176
+ });
177
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_userEvent","_interopRequireDefault","_react2","_feedbackSelector","jest","mock","__esModule","default","_ref","markup","onChange","createElement","defaultValue","e","target","value","describe","renderComponent","feedback","arguments","length","undefined","type","render","FeedbackSelector","label","beforeEach","fn","it","expect","screen","getByText","toBeInTheDocument","custom","getByTestId","toHaveValue","queryByText","not","_asyncToGenerator2","_regenerator","mark","_callee","user","wrap","_context","prev","next","userEvent","setup","click","getByLabelText","toHaveBeenCalledWith","stop","_callee2","_context2","_callee3","_context3","_callee4","editor","lastCall","_context4","clear","toHaveBeenCalled","calls","toBe"],"sources":["../../../src/feedback-config/__tests__/feedback-selector.test.jsx"],"sourcesContent":["import { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport React from 'react';\nimport { FeedbackSelector } from '../feedback-selector';\n\n// Mock the editable-html component to avoid window dependencies in tests\njest.mock('@pie-lib/editable-html', () => {\n  return {\n    __esModule: true,\n    default: ({ markup, onChange }) => (\n      <textarea\n        data-testid=\"editable-html\"\n        defaultValue={markup || ''}\n        onChange={(e) => onChange(e.target.value)}\n      />\n    ),\n  };\n});\n\ndescribe('feedback-selector', () => {\n  let onChange;\n\n  const renderComponent = (feedback = { type: 'default', default: 'hi' }) => {\n    return render(\n      <FeedbackSelector\n        label={'Feedback'}\n        onChange={onChange}\n        feedback={feedback}\n      />\n    );\n  };\n\n  beforeEach(() => {\n    onChange = jest.fn();\n  });\n\n  describe('rendering', () => {\n    it('renders feedback type selector', () => {\n      renderComponent();\n      expect(screen.getByText('Simple Feedback')).toBeInTheDocument();\n      expect(screen.getByText('No Feedback')).toBeInTheDocument();\n      expect(screen.getByText('Customized Feedback')).toBeInTheDocument();\n    });\n\n    it('shows default feedback text when type is default', () => {\n      renderComponent({ type: 'default', default: 'hi' });\n      expect(screen.getByText('hi')).toBeInTheDocument();\n    });\n\n    it('shows editable html when type is custom', () => {\n      renderComponent({ type: 'custom', default: 'hi', custom: 'custom text' });\n      expect(screen.getByTestId('editable-html')).toBeInTheDocument();\n      expect(screen.getByTestId('editable-html')).toHaveValue('custom text');\n    });\n\n    it('does not show default feedback when type is none', () => {\n      renderComponent({ type: 'none', default: 'hi' });\n      expect(screen.queryByText('hi')).not.toBeInTheDocument();\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange when switching to default feedback', async () => {\n      const user = userEvent.setup();\n      renderComponent({ type: 'custom', default: 'hi' });\n\n      await user.click(screen.getByLabelText('Simple Feedback'));\n\n      expect(onChange).toHaveBeenCalledWith({ type: 'default', default: 'hi' });\n    });\n\n    it('calls onChange when switching to custom feedback', async () => {\n      const user = userEvent.setup();\n      renderComponent({ type: 'default', default: 'hi' });\n\n      await user.click(screen.getByLabelText('Customized Feedback'));\n\n      expect(onChange).toHaveBeenCalledWith({ type: 'custom', default: 'hi' });\n    });\n\n    it('calls onChange when switching to no feedback', async () => {\n      const user = userEvent.setup();\n      renderComponent({ type: 'default', default: 'hi' });\n\n      await user.click(screen.getByLabelText('No Feedback'));\n\n      expect(onChange).toHaveBeenCalledWith({ type: 'none', default: 'hi' });\n    });\n\n    it('calls onChange with custom text when editing custom feedback', async () => {\n      const user = userEvent.setup();\n      renderComponent({ type: 'custom', default: 'hi', custom: '' });\n\n      const editor = screen.getByTestId('editable-html');\n      await user.clear(editor);\n      await user.type(editor, 'text');\n\n      // user.type triggers onChange for each character, so check that onChange was called\n      // and that the last call has 'text' in custom field\n      expect(onChange).toHaveBeenCalled();\n      const lastCall = onChange.mock.calls[onChange.mock.calls.length - 1][0];\n      expect(lastCall.type).toBe('custom');\n      expect(lastCall.custom).toBe('text');\n      expect(lastCall.default).toBe('hi');\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
@@ -1,128 +1,106 @@
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.FeedbackType = exports.FeedbackSelector = void 0;
9
-
10
8
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
9
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
10
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
11
  var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
12
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
22
13
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
23
-
24
- var _editableHtml = _interopRequireDefault(require("@pie-lib/editable-html"));
25
-
26
14
  var _renderUi = require("@pie-lib/render-ui");
27
-
28
15
  var _propTypes = _interopRequireDefault(require("prop-types"));
29
-
30
16
  var _react = _interopRequireDefault(require("react"));
31
-
32
- var _styles = require("@material-ui/core/styles");
33
-
17
+ var _styles = require("@mui/material/styles");
34
18
  var _group = _interopRequireDefault(require("./group"));
35
-
36
- 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); }; }
37
-
38
- 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; } }
39
-
40
- 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; }
41
-
42
- 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; }
43
-
19
+ 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; }
20
+ 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; }
21
+ 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)); }
22
+ 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';
23
+ // - mathquill error window not defined
24
+ var EditableHtml;
25
+ var StyledEditableHTML;
26
+ if (typeof window !== 'undefined') {
27
+ EditableHtml = require('@pie-lib/editable-html')['default'];
28
+ StyledEditableHTML = (0, _styles.styled)(EditableHtml)(function (_ref) {
29
+ var theme = _ref.theme;
30
+ return {
31
+ fontFamily: theme.typography.fontFamily
32
+ };
33
+ });
34
+ }
44
35
  var feedbackLabels = {
45
36
  "default": 'Simple Feedback',
46
37
  none: 'No Feedback',
47
38
  custom: 'Customized Feedback'
48
39
  };
49
-
50
- var holder = function holder(theme, extras) {
51
- return _objectSpread({
40
+ var StyledFeedbackSelector = (0, _styles.styled)('div')(function (_ref2) {
41
+ var theme = _ref2.theme;
42
+ return {
43
+ marginBottom: theme.spacing(1)
44
+ };
45
+ });
46
+ var StyledInputContainer = (0, _styles.styled)(_renderUi.InputContainer)(function () {
47
+ return {
48
+ paddingBottom: 0
49
+ };
50
+ });
51
+ var StyledCustomHolder = (0, _styles.styled)('div')(function (_ref3) {
52
+ var theme = _ref3.theme;
53
+ return {
52
54
  marginTop: '0px',
53
55
  background: theme.palette.grey[300],
54
- padding: theme.spacing.unit,
55
- marginBottom: theme.spacing.unit * 2,
56
+ padding: 0,
57
+ marginBottom: theme.spacing(2),
56
58
  borderRadius: '4px'
57
- }, extras);
58
- };
59
-
60
- var style = function style(theme) {
59
+ };
60
+ });
61
+ var StyledDefaultHolder = (0, _styles.styled)('div')(function (_ref4) {
62
+ var theme = _ref4.theme;
61
63
  return {
62
- feedbackSelector: {
63
- marginBottom: theme.spacing.unit
64
- },
65
- label: {
66
- cursor: 'pointer'
67
- },
68
- inputContainerLabel: {
69
- transform: 'translateY(-20%)'
70
- },
71
- feedbackInputContainer: {
72
- paddingBottom: 0
73
- },
74
- customHolder: holder(theme, {
75
- background: theme.palette.grey[300],
76
- padding: 0
77
- }),
78
- defaultHolder: holder(theme, {
79
- fontFamily: theme.typography.fontFamily,
80
- padding: theme.spacing.unit * 2,
81
- cursor: 'default'
82
- }),
83
- editor: {
84
- fontFamily: theme.typography.fontFamily
85
- },
86
- group: {
87
- paddingTop: theme.spacing.unit
88
- }
64
+ marginTop: '0px',
65
+ background: theme.palette.grey[300],
66
+ padding: theme.spacing(2),
67
+ marginBottom: theme.spacing(2),
68
+ borderRadius: '4px',
69
+ fontFamily: theme.typography.fontFamily,
70
+ cursor: 'default'
89
71
  };
90
- };
91
-
92
- var FeedbackType = {
72
+ });
73
+ var StyledGroup = (0, _styles.styled)(_group["default"])(function (_ref5) {
74
+ var theme = _ref5.theme;
75
+ return {
76
+ paddingTop: theme.spacing(1)
77
+ };
78
+ });
79
+ var FeedbackType = exports.FeedbackType = {
93
80
  type: _propTypes["default"].oneOf(['default', 'custom', 'none']),
94
81
  "default": _propTypes["default"].string,
95
82
  custom: _propTypes["default"].string
96
83
  };
97
- exports.FeedbackType = FeedbackType;
98
-
99
- var FeedbackSelector = /*#__PURE__*/function (_React$Component) {
100
- (0, _inherits2["default"])(FeedbackSelector, _React$Component);
101
-
102
- var _super = _createSuper(FeedbackSelector);
103
-
84
+ var FeedbackSelector = exports.FeedbackSelector = /*#__PURE__*/function (_React$Component) {
104
85
  function FeedbackSelector() {
105
86
  var _this;
106
-
107
87
  (0, _classCallCheck2["default"])(this, FeedbackSelector);
108
-
109
88
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
110
89
  args[_key] = arguments[_key];
111
90
  }
112
-
113
- _this = _super.call.apply(_super, [this].concat(args));
114
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeType", function (type) {
91
+ _this = _callSuper(this, FeedbackSelector, [].concat(args));
92
+ (0, _defineProperty2["default"])(_this, "changeType", function (type) {
115
93
  var _this$props = _this.props,
116
- onChange = _this$props.onChange,
117
- feedback = _this$props.feedback;
94
+ onChange = _this$props.onChange,
95
+ feedback = _this$props.feedback;
118
96
  onChange(_objectSpread(_objectSpread({}, feedback), {}, {
119
97
  type: type
120
98
  }));
121
99
  });
122
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeCustom", function (custom) {
100
+ (0, _defineProperty2["default"])(_this, "changeCustom", function (custom) {
123
101
  var _this$props2 = _this.props,
124
- onChange = _this$props2.onChange,
125
- feedback = _this$props2.feedback;
102
+ onChange = _this$props2.onChange,
103
+ feedback = _this$props2.feedback;
126
104
  onChange(_objectSpread(_objectSpread({}, feedback), {}, {
127
105
  type: 'custom',
128
106
  custom: custom
@@ -130,38 +108,32 @@ var FeedbackSelector = /*#__PURE__*/function (_React$Component) {
130
108
  });
131
109
  return _this;
132
110
  }
133
-
134
- (0, _createClass2["default"])(FeedbackSelector, [{
111
+ (0, _inherits2["default"])(FeedbackSelector, _React$Component);
112
+ return (0, _createClass2["default"])(FeedbackSelector, [{
135
113
  key: "render",
136
114
  value: function render() {
137
115
  var _this$props3 = this.props,
138
- keys = _this$props3.keys,
139
- classes = _this$props3.classes,
140
- label = _this$props3.label,
141
- feedback = _this$props3.feedback,
142
- toolbarOpts = _this$props3.toolbarOpts,
143
- _this$props3$mathMlOp = _this$props3.mathMlOptions,
144
- mathMlOptions = _this$props3$mathMlOp === void 0 ? {} : _this$props3$mathMlOp;
116
+ keys = _this$props3.keys,
117
+ label = _this$props3.label,
118
+ feedback = _this$props3.feedback,
119
+ toolbarOpts = _this$props3.toolbarOpts,
120
+ _this$props3$mathMlOp = _this$props3.mathMlOptions,
121
+ mathMlOptions = _this$props3$mathMlOp === void 0 ? {} : _this$props3$mathMlOp;
145
122
  var feedbackKeys = keys || Object.keys(feedbackLabels);
146
- return /*#__PURE__*/_react["default"].createElement("div", {
147
- className: classes.feedbackSelector
148
- }, /*#__PURE__*/_react["default"].createElement(_renderUi.InputContainer, {
123
+ return /*#__PURE__*/_react["default"].createElement(StyledFeedbackSelector, null, /*#__PURE__*/_react["default"].createElement(StyledInputContainer, {
149
124
  label: label,
150
- className: classes.feedbackInputContainer,
151
125
  extraClasses: {
152
- label: classes.inputContainerLabel
126
+ label: {
127
+ transform: 'translateY(-20%)'
128
+ }
153
129
  }
154
- }, /*#__PURE__*/_react["default"].createElement(_group["default"], {
155
- className: classes.group,
130
+ }, /*#__PURE__*/_react["default"].createElement(StyledGroup, {
156
131
  keys: feedbackKeys,
157
132
  label: label,
158
133
  value: feedback.type,
159
134
  onChange: this.changeType,
160
135
  feedbackLabels: feedbackLabels
161
- })), feedback.type === 'custom' && /*#__PURE__*/_react["default"].createElement("div", {
162
- className: classes.customHolder
163
- }, /*#__PURE__*/_react["default"].createElement(_editableHtml["default"], {
164
- className: classes.editor,
136
+ })), feedback.type === 'custom' && /*#__PURE__*/_react["default"].createElement(StyledCustomHolder, null, /*#__PURE__*/_react["default"].createElement(StyledEditableHTML, {
165
137
  onChange: this.changeCustom,
166
138
  markup: feedback.custom || '',
167
139
  toolbarOpts: toolbarOpts,
@@ -171,25 +143,17 @@ var FeedbackSelector = /*#__PURE__*/function (_React$Component) {
171
143
  language: 'special'
172
144
  }],
173
145
  mathMlOptions: mathMlOptions
174
- })), feedback.type === 'default' && /*#__PURE__*/_react["default"].createElement("div", {
175
- className: classes.defaultHolder
176
- }, " ", feedback["default"]));
146
+ })), feedback.type === 'default' && /*#__PURE__*/_react["default"].createElement(StyledDefaultHolder, null, " ", feedback["default"]));
177
147
  }
178
148
  }]);
179
- return FeedbackSelector;
180
149
  }(_react["default"].Component);
181
-
182
- exports.FeedbackSelector = FeedbackSelector;
183
150
  (0, _defineProperty2["default"])(FeedbackSelector, "propTypes", {
184
151
  keys: _propTypes["default"].arrayOf(_propTypes["default"].string),
185
- classes: _propTypes["default"].object.isRequired,
186
152
  label: _propTypes["default"].string.isRequired,
187
153
  feedback: _propTypes["default"].shape(FeedbackType).isRequired,
188
154
  onChange: _propTypes["default"].func.isRequired,
189
- toolbarOpts: _propTypes["default"].object
155
+ toolbarOpts: _propTypes["default"].object,
156
+ mathMlOptions: _propTypes["default"].object
190
157
  });
191
-
192
- var _default = (0, _styles.withStyles)(style)(FeedbackSelector);
193
-
194
- exports["default"] = _default;
195
- //# sourceMappingURL=feedback-selector.js.map
158
+ var _default = exports["default"] = FeedbackSelector;
159
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_renderUi","require","_propTypes","_interopRequireDefault","_react","_styles","_group","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","EditableHtml","StyledEditableHTML","window","styled","_ref","theme","fontFamily","typography","feedbackLabels","none","custom","StyledFeedbackSelector","_ref2","marginBottom","spacing","StyledInputContainer","InputContainer","paddingBottom","StyledCustomHolder","_ref3","marginTop","background","palette","grey","padding","borderRadius","StyledDefaultHolder","_ref4","cursor","StyledGroup","Group","_ref5","paddingTop","FeedbackType","exports","type","PropTypes","oneOf","string","FeedbackSelector","_React$Component","_this","_classCallCheck2","_len","args","Array","_key","concat","_this$props","props","onChange","feedback","_this$props2","_inherits2","_createClass2","key","value","render","_this$props3","label","toolbarOpts","_this$props3$mathMlOp","mathMlOptions","feedbackKeys","createElement","extraClasses","transform","changeType","changeCustom","markup","languageCharactersProps","language","React","Component","arrayOf","isRequired","shape","func","object","_default"],"sources":["../../src/feedback-config/feedback-selector.jsx"],"sourcesContent":["//import EditableHTML from '@pie-lib/editable-html';\nimport { InputContainer } from '@pie-lib/render-ui';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { styled } from '@mui/material/styles';\nimport Group from './group';\n\n\n// - mathquill error window not defined\nlet EditableHtml;\nlet StyledEditableHTML;\nif (typeof window !== 'undefined') {\n  EditableHtml = require('@pie-lib/editable-html')['default'];\n  StyledEditableHTML = styled(EditableHtml)(({ theme }) => ({\n    fontFamily: theme.typography.fontFamily,\n  }));\n}\n\nconst feedbackLabels = {\n  default: 'Simple Feedback',\n  none: 'No Feedback',\n  custom: 'Customized Feedback',\n};\n\nconst StyledFeedbackSelector = styled('div')(({ theme }) => ({\n  marginBottom: theme.spacing(1),\n}));\n\nconst StyledInputContainer = styled(InputContainer)(() => ({\n  paddingBottom: 0,\n}));\n\nconst StyledCustomHolder = styled('div')(({ theme }) => ({\n  marginTop: '0px',\n  background: theme.palette.grey[300],\n  padding: 0,\n  marginBottom: theme.spacing(2),\n  borderRadius: '4px',\n}));\n\nconst StyledDefaultHolder = styled('div')(({ theme }) => ({\n  marginTop: '0px',\n  background: theme.palette.grey[300],\n  padding: theme.spacing(2),\n  marginBottom: theme.spacing(2),\n  borderRadius: '4px',\n  fontFamily: theme.typography.fontFamily,\n  cursor: 'default',\n}));\n\nconst StyledGroup = styled(Group)(({ theme }) => ({\n  paddingTop: theme.spacing(1),\n}));\n\nexport const FeedbackType = {\n  type: PropTypes.oneOf(['default', 'custom', 'none']),\n  default: PropTypes.string,\n  custom: PropTypes.string,\n};\n\nexport class FeedbackSelector extends React.Component {\n  static propTypes = {\n    keys: PropTypes.arrayOf(PropTypes.string),\n    label: PropTypes.string.isRequired,\n    feedback: PropTypes.shape(FeedbackType).isRequired,\n    onChange: PropTypes.func.isRequired,\n    toolbarOpts: PropTypes.object,\n    mathMlOptions: PropTypes.object,\n  };\n\n  changeType = (type) => {\n    const { onChange, feedback } = this.props;\n\n    onChange({ ...feedback, type });\n  };\n\n  changeCustom = (custom) => {\n    const { onChange, feedback } = this.props;\n\n    onChange({ ...feedback, type: 'custom', custom });\n  };\n\n  render() {\n    const { keys, label, feedback, toolbarOpts, mathMlOptions = {} } = this.props;\n\n    const feedbackKeys = keys || Object.keys(feedbackLabels);\n\n    return (\n      <StyledFeedbackSelector>\n        <StyledInputContainer\n          label={label}\n          extraClasses={{ label: { transform: 'translateY(-20%)' } }}\n        >\n          <StyledGroup\n            keys={feedbackKeys}\n            label={label}\n            value={feedback.type}\n            onChange={this.changeType}\n            feedbackLabels={feedbackLabels}\n          />\n        </StyledInputContainer>\n\n        {feedback.type === 'custom' && (\n          <StyledCustomHolder>\n            <StyledEditableHTML\n              onChange={this.changeCustom}\n              markup={feedback.custom || ''}\n              toolbarOpts={toolbarOpts}\n              languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n              mathMlOptions={mathMlOptions}\n            />\n          </StyledCustomHolder>\n        )}\n\n        {feedback.type === 'default' && <StyledDefaultHolder> {feedback.default}</StyledDefaultHolder>}\n      </StyledFeedbackSelector>\n    );\n  }\n}\n\nexport default FeedbackSelector;\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/feedback-config/feedback-selector.jsx"],"names":["feedbackLabels","none","custom","holder","theme","extras","marginTop","background","palette","grey","padding","spacing","unit","marginBottom","borderRadius","style","feedbackSelector","label","cursor","inputContainerLabel","transform","feedbackInputContainer","paddingBottom","customHolder","defaultHolder","fontFamily","typography","editor","group","paddingTop","FeedbackType","type","PropTypes","oneOf","string","FeedbackSelector","props","onChange","feedback","keys","classes","toolbarOpts","mathMlOptions","feedbackKeys","Object","changeType","changeCustom","language","React","Component","arrayOf","object","isRequired","shape","func"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAEA,IAAMA,cAAc,GAAG;AACrB,aAAS,iBADY;AAErBC,EAAAA,IAAI,EAAE,aAFe;AAGrBC,EAAAA,MAAM,EAAE;AAHa,CAAvB;;AAMA,IAAMC,MAAM,GAAG,SAATA,MAAS,CAACC,KAAD,EAAQC,MAAR;AAAA;AACbC,IAAAA,SAAS,EAAE,KADE;AAEbC,IAAAA,UAAU,EAAEH,KAAK,CAACI,OAAN,CAAcC,IAAd,CAAmB,GAAnB,CAFC;AAGbC,IAAAA,OAAO,EAAEN,KAAK,CAACO,OAAN,CAAcC,IAHV;AAIbC,IAAAA,YAAY,EAAET,KAAK,CAACO,OAAN,CAAcC,IAAd,GAAqB,CAJtB;AAKbE,IAAAA,YAAY,EAAE;AALD,KAMVT,MANU;AAAA,CAAf;;AASA,IAAMU,KAAK,GAAG,SAARA,KAAQ,CAACX,KAAD;AAAA,SAAY;AACxBY,IAAAA,gBAAgB,EAAE;AAChBH,MAAAA,YAAY,EAAET,KAAK,CAACO,OAAN,CAAcC;AADZ,KADM;AAIxBK,IAAAA,KAAK,EAAE;AACLC,MAAAA,MAAM,EAAE;AADH,KAJiB;AAOxBC,IAAAA,mBAAmB,EAAE;AACnBC,MAAAA,SAAS,EAAE;AADQ,KAPG;AAUxBC,IAAAA,sBAAsB,EAAE;AACtBC,MAAAA,aAAa,EAAE;AADO,KAVA;AAaxBC,IAAAA,YAAY,EAAEpB,MAAM,CAACC,KAAD,EAAQ;AAC1BG,MAAAA,UAAU,EAAEH,KAAK,CAACI,OAAN,CAAcC,IAAd,CAAmB,GAAnB,CADc;AAE1BC,MAAAA,OAAO,EAAE;AAFiB,KAAR,CAbI;AAiBxBc,IAAAA,aAAa,EAAErB,MAAM,CAACC,KAAD,EAAQ;AAC3BqB,MAAAA,UAAU,EAAErB,KAAK,CAACsB,UAAN,CAAiBD,UADF;AAE3Bf,MAAAA,OAAO,EAAEN,KAAK,CAACO,OAAN,CAAcC,IAAd,GAAqB,CAFH;AAG3BM,MAAAA,MAAM,EAAE;AAHmB,KAAR,CAjBG;AAsBxBS,IAAAA,MAAM,EAAE;AACNF,MAAAA,UAAU,EAAErB,KAAK,CAACsB,UAAN,CAAiBD;AADvB,KAtBgB;AAyBxBG,IAAAA,KAAK,EAAE;AACLC,MAAAA,UAAU,EAAEzB,KAAK,CAACO,OAAN,CAAcC;AADrB;AAzBiB,GAAZ;AAAA,CAAd;;AA8BO,IAAMkB,YAAY,GAAG;AAC1BC,EAAAA,IAAI,EAAEC,sBAAUC,KAAV,CAAgB,CAAC,SAAD,EAAY,QAAZ,EAAsB,MAAtB,CAAhB,CADoB;AAE1B,aAASD,sBAAUE,MAFO;AAG1BhC,EAAAA,MAAM,EAAE8B,sBAAUE;AAHQ,CAArB;;;IAMMC,gB;;;;;;;;;;;;;;;mGAUE,UAACJ,IAAD,EAAU;AACrB,wBAA+B,MAAKK,KAApC;AAAA,UAAQC,QAAR,eAAQA,QAAR;AAAA,UAAkBC,QAAlB,eAAkBA,QAAlB;AAEAD,MAAAA,QAAQ,iCAAMC,QAAN;AAAgBP,QAAAA,IAAI,EAAJA;AAAhB,SAAR;AACD,K;qGAEc,UAAC7B,MAAD,EAAY;AACzB,yBAA+B,MAAKkC,KAApC;AAAA,UAAQC,QAAR,gBAAQA,QAAR;AAAA,UAAkBC,QAAlB,gBAAkBA,QAAlB;AAEAD,MAAAA,QAAQ,iCAAMC,QAAN;AAAgBP,QAAAA,IAAI,EAAE,QAAtB;AAAgC7B,QAAAA,MAAM,EAANA;AAAhC,SAAR;AACD,K;;;;;;WAED,kBAAS;AACP,yBAA4E,KAAKkC,KAAjF;AAAA,UAAQG,IAAR,gBAAQA,IAAR;AAAA,UAAcC,OAAd,gBAAcA,OAAd;AAAA,UAAuBvB,KAAvB,gBAAuBA,KAAvB;AAAA,UAA8BqB,QAA9B,gBAA8BA,QAA9B;AAAA,UAAwCG,WAAxC,gBAAwCA,WAAxC;AAAA,+CAAqDC,aAArD;AAAA,UAAqDA,aAArD,sCAAqE,EAArE;AAEA,UAAMC,YAAY,GAAGJ,IAAI,IAAIK,MAAM,CAACL,IAAP,CAAYvC,cAAZ,CAA7B;AAEA,0BACE;AAAK,QAAA,SAAS,EAAEwC,OAAO,CAACxB;AAAxB,sBACE,gCAAC,wBAAD;AACE,QAAA,KAAK,EAAEC,KADT;AAEE,QAAA,SAAS,EAAEuB,OAAO,CAACnB,sBAFrB;AAGE,QAAA,YAAY,EAAE;AAAEJ,UAAAA,KAAK,EAAEuB,OAAO,CAACrB;AAAjB;AAHhB,sBAKE,gCAAC,iBAAD;AACE,QAAA,SAAS,EAAEqB,OAAO,CAACZ,KADrB;AAEE,QAAA,IAAI,EAAEe,YAFR;AAGE,QAAA,KAAK,EAAE1B,KAHT;AAIE,QAAA,KAAK,EAAEqB,QAAQ,CAACP,IAJlB;AAKE,QAAA,QAAQ,EAAE,KAAKc,UALjB;AAME,QAAA,cAAc,EAAE7C;AANlB,QALF,CADF,EAgBGsC,QAAQ,CAACP,IAAT,KAAkB,QAAlB,iBACC;AAAK,QAAA,SAAS,EAAES,OAAO,CAACjB;AAAxB,sBACE,gCAAC,wBAAD;AACE,QAAA,SAAS,EAAEiB,OAAO,CAACb,MADrB;AAEE,QAAA,QAAQ,EAAE,KAAKmB,YAFjB;AAGE,QAAA,MAAM,EAAER,QAAQ,CAACpC,MAAT,IAAmB,EAH7B;AAIE,QAAA,WAAW,EAAEuC,WAJf;AAKE,QAAA,uBAAuB,EAAE,CAAC;AAAEM,UAAAA,QAAQ,EAAE;AAAZ,SAAD,EAA0B;AAAEA,UAAAA,QAAQ,EAAE;AAAZ,SAA1B,CAL3B;AAME,QAAA,aAAa,EAAEL;AANjB,QADF,CAjBJ,EA6BGJ,QAAQ,CAACP,IAAT,KAAkB,SAAlB,iBAA+B;AAAK,QAAA,SAAS,EAAES,OAAO,CAAChB;AAAxB,cAAyCc,QAAQ,WAAjD,CA7BlC,CADF;AAiCD;;;EA5DmCU,kBAAMC,S;;;iCAA/Bd,gB,eACQ;AACjBI,EAAAA,IAAI,EAAEP,sBAAUkB,OAAV,CAAkBlB,sBAAUE,MAA5B,CADW;AAEjBM,EAAAA,OAAO,EAAER,sBAAUmB,MAAV,CAAiBC,UAFT;AAGjBnC,EAAAA,KAAK,EAAEe,sBAAUE,MAAV,CAAiBkB,UAHP;AAIjBd,EAAAA,QAAQ,EAAEN,sBAAUqB,KAAV,CAAgBvB,YAAhB,EAA8BsB,UAJvB;AAKjBf,EAAAA,QAAQ,EAAEL,sBAAUsB,IAAV,CAAeF,UALR;AAMjBX,EAAAA,WAAW,EAAET,sBAAUmB;AANN,C;;eA8DN,wBAAWpC,KAAX,EAAkBoB,gBAAlB,C","sourcesContent":["import EditableHTML from '@pie-lib/editable-html';\nimport { InputContainer } from '@pie-lib/render-ui';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { withStyles } from '@material-ui/core/styles';\nimport Group from './group';\n\nconst feedbackLabels = {\n default: 'Simple Feedback',\n none: 'No Feedback',\n custom: 'Customized Feedback',\n};\n\nconst holder = (theme, extras) => ({\n marginTop: '0px',\n background: theme.palette.grey[300],\n padding: theme.spacing.unit,\n marginBottom: theme.spacing.unit * 2,\n borderRadius: '4px',\n ...extras,\n});\n\nconst style = (theme) => ({\n feedbackSelector: {\n marginBottom: theme.spacing.unit,\n },\n label: {\n cursor: 'pointer',\n },\n inputContainerLabel: {\n transform: 'translateY(-20%)',\n },\n feedbackInputContainer: {\n paddingBottom: 0,\n },\n customHolder: holder(theme, {\n background: theme.palette.grey[300],\n padding: 0,\n }),\n defaultHolder: holder(theme, {\n fontFamily: theme.typography.fontFamily,\n padding: theme.spacing.unit * 2,\n cursor: 'default',\n }),\n editor: {\n fontFamily: theme.typography.fontFamily,\n },\n group: {\n paddingTop: theme.spacing.unit,\n },\n});\n\nexport const FeedbackType = {\n type: PropTypes.oneOf(['default', 'custom', 'none']),\n default: PropTypes.string,\n custom: PropTypes.string,\n};\n\nexport class FeedbackSelector extends React.Component {\n static propTypes = {\n keys: PropTypes.arrayOf(PropTypes.string),\n classes: PropTypes.object.isRequired,\n label: PropTypes.string.isRequired,\n feedback: PropTypes.shape(FeedbackType).isRequired,\n onChange: PropTypes.func.isRequired,\n toolbarOpts: PropTypes.object,\n };\n\n changeType = (type) => {\n const { onChange, feedback } = this.props;\n\n onChange({ ...feedback, type });\n };\n\n changeCustom = (custom) => {\n const { onChange, feedback } = this.props;\n\n onChange({ ...feedback, type: 'custom', custom });\n };\n\n render() {\n const { keys, classes, label, feedback, toolbarOpts, mathMlOptions = {} } = this.props;\n\n const feedbackKeys = keys || Object.keys(feedbackLabels);\n\n return (\n <div className={classes.feedbackSelector}>\n <InputContainer\n label={label}\n className={classes.feedbackInputContainer}\n extraClasses={{ label: classes.inputContainerLabel }}\n >\n <Group\n className={classes.group}\n keys={feedbackKeys}\n label={label}\n value={feedback.type}\n onChange={this.changeType}\n feedbackLabels={feedbackLabels}\n />\n </InputContainer>\n\n {feedback.type === 'custom' && (\n <div className={classes.customHolder}>\n <EditableHTML\n className={classes.editor}\n onChange={this.changeCustom}\n markup={feedback.custom || ''}\n toolbarOpts={toolbarOpts}\n languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n mathMlOptions={mathMlOptions}\n />\n </div>\n )}\n\n {feedback.type === 'default' && <div className={classes.defaultHolder}> {feedback.default}</div>}\n </div>\n );\n }\n}\n\nexport default withStyles(style)(FeedbackSelector);\n"],"file":"feedback-selector.js"}
1
+ {"version":3,"file":"feedback-selector.js","names":["_renderUi","require","_propTypes","_interopRequireDefault","_react","_styles","_group","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","EditableHtml","StyledEditableHTML","window","styled","_ref","theme","fontFamily","typography","feedbackLabels","none","custom","StyledFeedbackSelector","_ref2","marginBottom","spacing","StyledInputContainer","InputContainer","paddingBottom","StyledCustomHolder","_ref3","marginTop","background","palette","grey","padding","borderRadius","StyledDefaultHolder","_ref4","cursor","StyledGroup","Group","_ref5","paddingTop","FeedbackType","exports","type","PropTypes","oneOf","string","FeedbackSelector","_React$Component","_this","_classCallCheck2","_len","args","Array","_key","concat","_this$props","props","onChange","feedback","_this$props2","_inherits2","_createClass2","key","value","render","_this$props3","label","toolbarOpts","_this$props3$mathMlOp","mathMlOptions","feedbackKeys","createElement","extraClasses","transform","changeType","changeCustom","markup","languageCharactersProps","language","React","Component","arrayOf","isRequired","shape","func","object","_default"],"sources":["../../src/feedback-config/feedback-selector.jsx"],"sourcesContent":["//import EditableHTML from '@pie-lib/editable-html';\nimport { InputContainer } from '@pie-lib/render-ui';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { styled } from '@mui/material/styles';\nimport Group from './group';\n\n\n// - mathquill error window not defined\nlet EditableHtml;\nlet StyledEditableHTML;\nif (typeof window !== 'undefined') {\n EditableHtml = require('@pie-lib/editable-html')['default'];\n StyledEditableHTML = styled(EditableHtml)(({ theme }) => ({\n fontFamily: theme.typography.fontFamily,\n }));\n}\n\nconst feedbackLabels = {\n default: 'Simple Feedback',\n none: 'No Feedback',\n custom: 'Customized Feedback',\n};\n\nconst StyledFeedbackSelector = styled('div')(({ theme }) => ({\n marginBottom: theme.spacing(1),\n}));\n\nconst StyledInputContainer = styled(InputContainer)(() => ({\n paddingBottom: 0,\n}));\n\nconst StyledCustomHolder = styled('div')(({ theme }) => ({\n marginTop: '0px',\n background: theme.palette.grey[300],\n padding: 0,\n marginBottom: theme.spacing(2),\n borderRadius: '4px',\n}));\n\nconst StyledDefaultHolder = styled('div')(({ theme }) => ({\n marginTop: '0px',\n background: theme.palette.grey[300],\n padding: theme.spacing(2),\n marginBottom: theme.spacing(2),\n borderRadius: '4px',\n fontFamily: theme.typography.fontFamily,\n cursor: 'default',\n}));\n\nconst StyledGroup = styled(Group)(({ theme }) => ({\n paddingTop: theme.spacing(1),\n}));\n\nexport const FeedbackType = {\n type: PropTypes.oneOf(['default', 'custom', 'none']),\n default: PropTypes.string,\n custom: PropTypes.string,\n};\n\nexport class FeedbackSelector extends React.Component {\n static propTypes = {\n keys: PropTypes.arrayOf(PropTypes.string),\n label: PropTypes.string.isRequired,\n feedback: PropTypes.shape(FeedbackType).isRequired,\n onChange: PropTypes.func.isRequired,\n toolbarOpts: PropTypes.object,\n mathMlOptions: PropTypes.object,\n };\n\n changeType = (type) => {\n const { onChange, feedback } = this.props;\n\n onChange({ ...feedback, type });\n };\n\n changeCustom = (custom) => {\n const { onChange, feedback } = this.props;\n\n onChange({ ...feedback, type: 'custom', custom });\n };\n\n render() {\n const { keys, label, feedback, toolbarOpts, mathMlOptions = {} } = this.props;\n\n const feedbackKeys = keys || Object.keys(feedbackLabels);\n\n return (\n <StyledFeedbackSelector>\n <StyledInputContainer\n label={label}\n extraClasses={{ label: { transform: 'translateY(-20%)' } }}\n >\n <StyledGroup\n keys={feedbackKeys}\n label={label}\n value={feedback.type}\n onChange={this.changeType}\n feedbackLabels={feedbackLabels}\n />\n </StyledInputContainer>\n\n {feedback.type === 'custom' && (\n <StyledCustomHolder>\n <StyledEditableHTML\n onChange={this.changeCustom}\n markup={feedback.custom || ''}\n toolbarOpts={toolbarOpts}\n languageCharactersProps={[{ language: 'spanish' }, { language: 'special' }]}\n mathMlOptions={mathMlOptions}\n />\n </StyledCustomHolder>\n )}\n\n {feedback.type === 'default' && <StyledDefaultHolder> {feedback.default}</StyledDefaultHolder>}\n </StyledFeedbackSelector>\n );\n }\n}\n\nexport default FeedbackSelector;\n"],"mappings":"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","ignoreList":[]}