@pie-lib/mask-markup 2.2.0-next.0 → 2.2.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/__tests__/drag-in-the-blank.test.js +129 -0
- package/lib/__tests__/index.test.js +39 -0
- package/lib/__tests__/mask.test.js +163 -0
- package/lib/__tests__/serialization.test.js +44 -0
- package/lib/__tests__/utils.js +14 -0
- package/lib/__tests__/with-mask.test.js +110 -0
- package/lib/choices/__tests__/index.test.js +101 -0
- package/lib/choices/choice.js +1 -1
- package/lib/choices/index.js +1 -1
- package/lib/componentize.js +1 -1
- package/lib/components/__tests__/blank.test.js +188 -0
- package/lib/components/__tests__/correct-input.test.js +132 -0
- package/lib/components/__tests__/dropdown.test.js +134 -0
- package/lib/components/__tests__/input.test.js +129 -0
- package/lib/components/blank.js +1 -1
- package/lib/components/correct-input.js +1 -1
- package/lib/components/dropdown.js +1 -1
- package/lib/components/input.js +1 -1
- package/lib/constructed-response.js +1 -1
- package/lib/customizable.js +1 -1
- package/lib/drag-in-the-blank.js +1 -1
- package/lib/index.js +1 -1
- package/lib/inline-dropdown.js +1 -1
- package/lib/mask.js +1 -1
- package/lib/serialization.js +1 -1
- package/lib/with-mask.js +1 -1
- package/package.json +7 -10
- package/LICENSE.md +0 -5
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
6
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
7
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
8
|
+
var React = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
11
|
+
var _utils = require("../../__tests__/utils");
|
|
12
|
+
var _dropdown = _interopRequireDefault(require("../dropdown"));
|
|
13
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
14
|
+
describe('Dropdown', function () {
|
|
15
|
+
var onChange = jest.fn();
|
|
16
|
+
var defaultProps = {
|
|
17
|
+
onChange: onChange,
|
|
18
|
+
id: '1',
|
|
19
|
+
correct: false,
|
|
20
|
+
disabled: false,
|
|
21
|
+
value: 'Jumped',
|
|
22
|
+
choices: [(0, _utils.choice)('Jumped'), (0, _utils.choice)('Laughed'), (0, _utils.choice)('Smiled')]
|
|
23
|
+
};
|
|
24
|
+
beforeEach(function () {
|
|
25
|
+
onChange.mockClear();
|
|
26
|
+
});
|
|
27
|
+
describe('rendering', function () {
|
|
28
|
+
it('renders dropdown with default props', function () {
|
|
29
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
30
|
+
var button = _react2.screen.getByRole('combobox');
|
|
31
|
+
expect(button).toBeInTheDocument();
|
|
32
|
+
// Button displays the selected value
|
|
33
|
+
expect(button).toHaveTextContent('Jumped');
|
|
34
|
+
});
|
|
35
|
+
it('renders with all choices as options when opened', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
36
|
+
var user, button, options;
|
|
37
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
38
|
+
while (1) switch (_context.prev = _context.next) {
|
|
39
|
+
case 0:
|
|
40
|
+
user = _userEvent["default"].setup();
|
|
41
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
42
|
+
button = _react2.screen.getByRole('combobox');
|
|
43
|
+
_context.next = 1;
|
|
44
|
+
return user.click(button);
|
|
45
|
+
case 1:
|
|
46
|
+
// Options should now be visible - find them by role
|
|
47
|
+
options = _react2.screen.getAllByRole('option');
|
|
48
|
+
expect(options).toHaveLength(3);
|
|
49
|
+
// Verify the text content of options using specific elements
|
|
50
|
+
expect(options[0]).toHaveTextContent('Jumped');
|
|
51
|
+
expect(options[1]).toHaveTextContent('Laughed');
|
|
52
|
+
expect(options[2]).toHaveTextContent('Smiled');
|
|
53
|
+
case 2:
|
|
54
|
+
case "end":
|
|
55
|
+
return _context.stop();
|
|
56
|
+
}
|
|
57
|
+
}, _callee);
|
|
58
|
+
})));
|
|
59
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
60
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
61
|
+
disabled: true
|
|
62
|
+
})));
|
|
63
|
+
var button = _react2.screen.getByRole('combobox');
|
|
64
|
+
expect(button).toBeDisabled();
|
|
65
|
+
});
|
|
66
|
+
it('shows correct state when correct is true', function () {
|
|
67
|
+
var _render = (0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
68
|
+
correct: true
|
|
69
|
+
}))),
|
|
70
|
+
container = _render.container;
|
|
71
|
+
var button = _react2.screen.getByRole('combobox');
|
|
72
|
+
expect(button).toBeInTheDocument();
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
describe('user interactions', function () {
|
|
76
|
+
it('calls onChange when user selects a different option', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
77
|
+
var user, button, options, laughedOption;
|
|
78
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
79
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
80
|
+
case 0:
|
|
81
|
+
user = _userEvent["default"].setup();
|
|
82
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
83
|
+
|
|
84
|
+
// Click button to open menu
|
|
85
|
+
button = _react2.screen.getByRole('combobox');
|
|
86
|
+
_context2.next = 1;
|
|
87
|
+
return user.click(button);
|
|
88
|
+
case 1:
|
|
89
|
+
// Find the option by getting all options and selecting the one with "Laughed" text
|
|
90
|
+
options = _react2.screen.getAllByRole('option');
|
|
91
|
+
laughedOption = options.find(function (opt) {
|
|
92
|
+
return opt.textContent.includes('Laughed');
|
|
93
|
+
});
|
|
94
|
+
_context2.next = 2;
|
|
95
|
+
return user.click(laughedOption);
|
|
96
|
+
case 2:
|
|
97
|
+
expect(onChange).toHaveBeenCalledWith('1', 'Laughed');
|
|
98
|
+
case 3:
|
|
99
|
+
case "end":
|
|
100
|
+
return _context2.stop();
|
|
101
|
+
}
|
|
102
|
+
}, _callee2);
|
|
103
|
+
})));
|
|
104
|
+
it('calls onChange with correct value', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
105
|
+
var user, button, options, smiledOption;
|
|
106
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
107
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
108
|
+
case 0:
|
|
109
|
+
user = _userEvent["default"].setup();
|
|
110
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
111
|
+
|
|
112
|
+
// Click button to open menu
|
|
113
|
+
button = _react2.screen.getByRole('combobox');
|
|
114
|
+
_context3.next = 1;
|
|
115
|
+
return user.click(button);
|
|
116
|
+
case 1:
|
|
117
|
+
// Find the option by getting all options and selecting the one with "Smiled" text
|
|
118
|
+
options = _react2.screen.getAllByRole('option');
|
|
119
|
+
smiledOption = options.find(function (opt) {
|
|
120
|
+
return opt.textContent.includes('Smiled');
|
|
121
|
+
});
|
|
122
|
+
_context3.next = 2;
|
|
123
|
+
return user.click(smiledOption);
|
|
124
|
+
case 2:
|
|
125
|
+
expect(onChange).toHaveBeenCalledWith('1', 'Smiled');
|
|
126
|
+
case 3:
|
|
127
|
+
case "end":
|
|
128
|
+
return _context3.stop();
|
|
129
|
+
}
|
|
130
|
+
}, _callee3);
|
|
131
|
+
})));
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_utils","_dropdown","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","describe","onChange","jest","fn","defaultProps","id","correct","disabled","value","choices","choice","beforeEach","mockClear","it","render","createElement","button","screen","getByRole","expect","toBeInTheDocument","toHaveTextContent","_asyncToGenerator2","_regenerator","mark","_callee","user","options","wrap","_context","prev","next","userEvent","setup","click","getAllByRole","toHaveLength","stop","_extends2","toBeDisabled","_render","container","_callee2","laughedOption","_context2","find","opt","textContent","includes","toHaveBeenCalledWith","_callee3","smiledOption","_context3"],"sources":["../../../src/components/__tests__/dropdown.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { choice } from '../../__tests__/utils';\nimport Dropdown from '../dropdown';\n\ndescribe('Dropdown', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    onChange,\n    id: '1',\n    correct: false,\n    disabled: false,\n    value: 'Jumped',\n    choices: [choice('Jumped'), choice('Laughed'), choice('Smiled')],\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders dropdown with default props', () => {\n      render(<Dropdown {...defaultProps} />);\n      const button = screen.getByRole('combobox');\n      expect(button).toBeInTheDocument();\n      // Button displays the selected value\n      expect(button).toHaveTextContent('Jumped');\n    });\n\n    it('renders with all choices as options when opened', async () => {\n      const user = userEvent.setup();\n      render(<Dropdown {...defaultProps} />);\n\n      const button = screen.getByRole('combobox');\n      await user.click(button);\n\n      // Options should now be visible - find them by role\n      const options = screen.getAllByRole('option');\n      expect(options).toHaveLength(3);\n      // Verify the text content of options using specific elements\n      expect(options[0]).toHaveTextContent('Jumped');\n      expect(options[1]).toHaveTextContent('Laughed');\n      expect(options[2]).toHaveTextContent('Smiled');\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<Dropdown {...defaultProps} disabled={true} />);\n      const button = screen.getByRole('combobox');\n      expect(button).toBeDisabled();\n    });\n\n    it('shows correct state when correct is true', () => {\n      const { container } = render(<Dropdown {...defaultProps} correct={true} />);\n      const button = screen.getByRole('combobox');\n      expect(button).toBeInTheDocument();\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange when user selects a different option', async () => {\n      const user = userEvent.setup();\n      render(<Dropdown {...defaultProps} />);\n\n      // Click button to open menu\n      const button = screen.getByRole('combobox');\n      await user.click(button);\n\n      // Find the option by getting all options and selecting the one with \"Laughed\" text\n      const options = screen.getAllByRole('option');\n      const laughedOption = options.find((opt) => opt.textContent.includes('Laughed'));\n      await user.click(laughedOption);\n\n      expect(onChange).toHaveBeenCalledWith('1', 'Laughed');\n    });\n\n    it('calls onChange with correct value', async () => {\n      const user = userEvent.setup();\n      render(<Dropdown {...defaultProps} />);\n\n      // Click button to open menu\n      const button = screen.getByRole('combobox');\n      await user.click(button);\n\n      // Find the option by getting all options and selecting the one with \"Smiled\" text\n      const options = screen.getAllByRole('option');\n      const smiledOption = options.find((opt) => opt.textContent.includes('Smiled'));\n      await user.click(smiledOption);\n\n      expect(onChange).toHaveBeenCalledWith('1', 'Smiled');\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
6
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
7
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
8
|
+
var React = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
11
|
+
var _input = _interopRequireDefault(require("../input"));
|
|
12
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
13
|
+
// Mock CorrectInput to simplify testing
|
|
14
|
+
jest.mock('../correct-input', function () {
|
|
15
|
+
return function CorrectInput(_ref) {
|
|
16
|
+
var value = _ref.value,
|
|
17
|
+
onChange = _ref.onChange,
|
|
18
|
+
disabled = _ref.disabled,
|
|
19
|
+
correct = _ref.correct,
|
|
20
|
+
variant = _ref.variant;
|
|
21
|
+
return /*#__PURE__*/React.createElement("input", {
|
|
22
|
+
"data-testid": "correct-input",
|
|
23
|
+
value: value || '',
|
|
24
|
+
onChange: onChange,
|
|
25
|
+
disabled: disabled,
|
|
26
|
+
"data-correct": correct,
|
|
27
|
+
"data-variant": variant
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
});
|
|
31
|
+
describe('Input', function () {
|
|
32
|
+
var onChange = jest.fn();
|
|
33
|
+
var defaultProps = {
|
|
34
|
+
disabled: false,
|
|
35
|
+
correct: false,
|
|
36
|
+
value: 'Cow',
|
|
37
|
+
id: '1',
|
|
38
|
+
onChange: onChange
|
|
39
|
+
};
|
|
40
|
+
beforeEach(function () {
|
|
41
|
+
onChange.mockClear();
|
|
42
|
+
});
|
|
43
|
+
describe('rendering', function () {
|
|
44
|
+
it('renders with default props', function () {
|
|
45
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], defaultProps));
|
|
46
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
47
|
+
expect(input).toBeInTheDocument();
|
|
48
|
+
expect(input).toHaveValue('Cow');
|
|
49
|
+
expect(input).not.toBeDisabled();
|
|
50
|
+
expect(input).toHaveAttribute('data-correct', 'false');
|
|
51
|
+
});
|
|
52
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
53
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
54
|
+
disabled: true
|
|
55
|
+
})));
|
|
56
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
57
|
+
expect(input).toBeDisabled();
|
|
58
|
+
});
|
|
59
|
+
it('renders with correct state', function () {
|
|
60
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
61
|
+
correct: true
|
|
62
|
+
})));
|
|
63
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
64
|
+
expect(input).toHaveAttribute('data-correct', 'true');
|
|
65
|
+
});
|
|
66
|
+
it('shows correct answer when showCorrectAnswer is true', function () {
|
|
67
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
68
|
+
showCorrectAnswer: true
|
|
69
|
+
})));
|
|
70
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
71
|
+
expect(input).toHaveAttribute('data-correct', 'true');
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
describe('user interactions', function () {
|
|
75
|
+
it('calls onChange with id and value when user types', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
76
|
+
var user, input;
|
|
77
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
78
|
+
while (1) switch (_context.prev = _context.next) {
|
|
79
|
+
case 0:
|
|
80
|
+
user = _userEvent["default"].setup();
|
|
81
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
82
|
+
value: ""
|
|
83
|
+
})));
|
|
84
|
+
input = _react2.screen.getByTestId('correct-input');
|
|
85
|
+
_context.next = 1;
|
|
86
|
+
return user.type(input, '20');
|
|
87
|
+
case 1:
|
|
88
|
+
// userEvent.type types character by character, so onChange is called for each character
|
|
89
|
+
expect(onChange).toHaveBeenCalled();
|
|
90
|
+
expect(onChange).toHaveBeenCalledTimes(2);
|
|
91
|
+
// Check the last call has both characters
|
|
92
|
+
expect(onChange).toHaveBeenLastCalledWith('1', '0');
|
|
93
|
+
case 2:
|
|
94
|
+
case "end":
|
|
95
|
+
return _context.stop();
|
|
96
|
+
}
|
|
97
|
+
}, _callee);
|
|
98
|
+
})));
|
|
99
|
+
it('calls onChange with updated value', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
100
|
+
var user, input;
|
|
101
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
102
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
103
|
+
case 0:
|
|
104
|
+
user = _userEvent["default"].setup();
|
|
105
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], defaultProps));
|
|
106
|
+
input = _react2.screen.getByTestId('correct-input');
|
|
107
|
+
_context2.next = 1;
|
|
108
|
+
return user.clear(input);
|
|
109
|
+
case 1:
|
|
110
|
+
_context2.next = 2;
|
|
111
|
+
return user.type(input, 'New Value');
|
|
112
|
+
case 2:
|
|
113
|
+
// userEvent.type types character by character
|
|
114
|
+
// After clear, we start with empty string, and each character is typed
|
|
115
|
+
// The last call should have the full accumulated value up to the last character
|
|
116
|
+
expect(onChange).toHaveBeenCalled();
|
|
117
|
+
// With clear + "New Value", onChange is called for clearing ("") and each typed character
|
|
118
|
+
// The value accumulated in the input element after typing will be "CowNew Value"
|
|
119
|
+
// because the component starts with value="Cow" and we clear then type
|
|
120
|
+
expect(onChange.mock.calls.length).toBeGreaterThan(0);
|
|
121
|
+
case 3:
|
|
122
|
+
case "end":
|
|
123
|
+
return _context2.stop();
|
|
124
|
+
}
|
|
125
|
+
}, _callee2);
|
|
126
|
+
})));
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_input","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","jest","mock","CorrectInput","_ref","value","onChange","disabled","correct","variant","createElement","describe","fn","defaultProps","id","beforeEach","mockClear","it","render","input","screen","getByTestId","expect","toBeInTheDocument","toHaveValue","not","toBeDisabled","toHaveAttribute","_extends2","showCorrectAnswer","_asyncToGenerator2","_regenerator","mark","_callee","user","wrap","_context","prev","next","userEvent","setup","type","toHaveBeenCalled","toHaveBeenCalledTimes","toHaveBeenLastCalledWith","stop","_callee2","_context2","clear","calls","length","toBeGreaterThan"],"sources":["../../../src/components/__tests__/input.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport Input from '../input';\n\n// Mock CorrectInput to simplify testing\njest.mock('../correct-input', () => {\n  return function CorrectInput({ value, onChange, disabled, correct, variant }) {\n    return (\n      <input\n        data-testid=\"correct-input\"\n        value={value || ''}\n        onChange={onChange}\n        disabled={disabled}\n        data-correct={correct}\n        data-variant={variant}\n      />\n    );\n  };\n});\n\ndescribe('Input', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    disabled: false,\n    correct: false,\n    value: 'Cow',\n    id: '1',\n    onChange,\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders with default props', () => {\n      render(<Input {...defaultProps} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toBeInTheDocument();\n      expect(input).toHaveValue('Cow');\n      expect(input).not.toBeDisabled();\n      expect(input).toHaveAttribute('data-correct', 'false');\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<Input {...defaultProps} disabled={true} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toBeDisabled();\n    });\n\n    it('renders with correct state', () => {\n      render(<Input {...defaultProps} correct={true} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toHaveAttribute('data-correct', 'true');\n    });\n\n    it('shows correct answer when showCorrectAnswer is true', () => {\n      render(<Input {...defaultProps} showCorrectAnswer={true} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toHaveAttribute('data-correct', 'true');\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange with id and value when user types', async () => {\n      const user = userEvent.setup();\n      render(<Input {...defaultProps} value=\"\" />);\n\n      const input = screen.getByTestId('correct-input');\n      await user.type(input, '20');\n\n      // userEvent.type types character by character, so onChange is called for each character\n      expect(onChange).toHaveBeenCalled();\n      expect(onChange).toHaveBeenCalledTimes(2);\n      // Check the last call has both characters\n      expect(onChange).toHaveBeenLastCalledWith('1', '0');\n    });\n\n    it('calls onChange with updated value', async () => {\n      const user = userEvent.setup();\n      render(<Input {...defaultProps} />);\n\n      const input = screen.getByTestId('correct-input');\n      await user.clear(input);\n      await user.type(input, 'New Value');\n\n      // userEvent.type types character by character\n      // After clear, we start with empty string, and each character is typed\n      // The last call should have the full accumulated value up to the last character\n      expect(onChange).toHaveBeenCalled();\n      // With clear + \"New Value\", onChange is called for clearing (\"\") and each typed character\n      // The value accumulated in the input element after typing will be \"CowNew Value\"\n      // because the component starts with value=\"Cow\" and we clear then type\n      expect(onChange.mock.calls.length).toBeGreaterThan(0);\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
package/lib/components/blank.js
CHANGED
|
@@ -356,4 +356,4 @@ DragDropBlank.propTypes = {
|
|
|
356
356
|
instanceId: _propTypes["default"].string
|
|
357
357
|
};
|
|
358
358
|
var _default = exports["default"] = DragDropBlank;
|
|
359
|
-
//# sourceMappingURL=blank.js.map
|
|
359
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_mathRendering","_debug","_core","_utilities","_styles","_Chip","_classnames","_renderUi","_colors","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","log","debug","StyledContent","styled","_ref","dragged","over","border","concat","color","primary","minWidth","touchAction","overflow","whiteSpace","opacity","StyledChip","Chip","backgroundColor","background","text","fontSize","maxWidth","position","borderRadius","grey","correct","incorrect","StyledChipLabel","pointerEvents","display","padding","marginTop","marginBottom","left","top","transform","BlankContent","_ref2","_dragItem$choice","_frozenRef$current","_frozenRef$current2","disabled","choice","isOver","isDragging","dragItem","emptyResponseAreaWidth","emptyResponseAreaHeight","rootRef","useRef","spanRef","frozenRef","_useState","useState","height","width","_useState2","_slicedToArray2","dimensions","setDimensions","handleImageLoad","updateDimensions","handleElements","_spanRef$current","imageElement","current","querySelector","onload","setTimeout","style","offsetWidth","offsetHeight","widthWithPadding","heightWithPadding","responseAreaWidth","parseFloat","responseAreaHeight","adjustedWidth","adjustedHeight","prevState","getRootDimensions","isNaN","rootStyle","minHeight","useEffect","renderMath","value","draggedLabel","label","createElement","clickable","ref","component","Fragment","draggable","className","classnames","hidden","dangerouslySetInnerHTML","__html","parentOver","undefined","variant","defaultProps","propTypes","id","PropTypes","oneOfType","string","number","bool","duplicates","object","onChange","func","instanceId","DragDropBlank","_ref3","_dragItem$data","_useDraggable","useDraggable","data","fromChoice","type","dragAttributes","attributes","dragListeners","listeners","setDragNodeRef","setNodeRef","_useDroppable","useDroppable","accepts","setDropNodeRef","active","node","CSS","Translate","toString","_extends2","_default","exports"],"sources":["../../src/components/blank.jsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport debug from 'debug';\nimport { useDraggable, useDroppable } from '@dnd-kit/core';\nimport { CSS } from '@dnd-kit/utilities';\nimport { styled } from '@mui/material/styles';\nimport Chip from '@mui/material/Chip';\nimport classnames from 'classnames';\nimport { color } from '@pie-lib/render-ui';\nimport { grey } from '@mui/material/colors';\n\nconst log = debug('pie-lib:mask-markup:blank');\n\nconst StyledContent = styled('span')(({ dragged, over }) => ({\n  border: `solid 0px ${color.primary()}`,\n  minWidth: '200px',\n  touchAction: 'none',\n  overflow: 'hidden',\n  whiteSpace: 'nowrap',\n  opacity: 1,\n  ...(over && {\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n  }),\n  ...(dragged && {\n    opacity: 0.5,\n  }),\n}));\n\nconst StyledChip = styled(Chip)(() => ({\n  backgroundColor: color.background(),\n  border: `2px dashed ${color.text()}`,\n  color: color.text(),\n  fontSize: 'inherit',\n  maxWidth: '374px',\n  position: 'relative',\n  borderRadius: '3px',\n  '&.over': {\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n  },\n  '&.parentOver': {\n    border: `1px solid ${grey[500]}`,\n    backgroundColor: `${grey[300]}`,\n  },\n  '&.correct': {\n    border: `solid 1px ${color.correct()}`,\n  },\n  '&.incorrect': {\n    border: `solid 1px ${color.incorrect()}`,\n  },\n  '&.Mui-disabled': {\n    opacity: 1,\n  },\n}));\n\nconst StyledChipLabel = styled('span')(() => ({\n  whiteSpace: 'normal',\n  // Added for touch devices, for image content.\n  // This will prevent the context menu from appearing and not allowing other interactions with the image.\n  // If interactions with the image in the token will be requested we should handle only the context Menu.\n  pointerEvents: 'none',\n  '& img': {\n    display: 'block',\n    padding: '2px 0',\n  },\n  // Remove default <p> margins to ensure consistent spacing across all wrapped content (p, span, div, math)\n  // Padding for top and bottom will instead be controlled by the container for consistent layout\n  // Ensures consistent behavior with pie-api-browser, where marginTop is already removed by a Bootstrap stylesheet\n  '& p': {\n    marginTop: '0',\n    marginBottom: '0',\n  },\n  '& mjx-frac': {\n    fontSize: '120% !important',\n  },\n  '&.over': {\n    whiteSpace: 'nowrap',\n    overflow: 'hidden',\n  },\n  '&.hidden': {\n    color: 'transparent',\n    opacity: 0,\n  },\n  '&.dragged': {\n    position: 'absolute',\n    left: 16,\n    maxWidth: '60px',\n    top: '50%',\n    transform: 'translateY(-50%)',\n  },\n}));\n\nfunction BlankContent({\n  disabled,\n  choice,\n  isOver,\n  isDragging,\n  dragItem,\n  correct,\n  emptyResponseAreaWidth,\n  emptyResponseAreaHeight,\n}) {\n  const rootRef = useRef(null);\n  const spanRef = useRef(null);\n  const frozenRef = useRef(null); // to use during dragging to prevent flickering\n  const [dimensions, setDimensions] = useState({ height: 0, width: 0 });\n\n  const handleImageLoad = () => {\n    updateDimensions();\n  };\n\n  const handleElements = () => {\n    const imageElement = spanRef.current?.querySelector('img');\n    if (imageElement) {\n      imageElement.onload = handleImageLoad;\n    } else {\n      setTimeout(() => {\n        updateDimensions();\n      }, 300);\n    }\n  };\n\n  const updateDimensions = () => {\n    if (spanRef.current && rootRef.current) {\n      // Temporarily set rootRef width to 'auto' for natural measurement\n      rootRef.current.style.width = 'auto';\n\n      // Get the natural dimensions of the content\n      const width = spanRef.current.offsetWidth || 0;\n      const height = spanRef.current.offsetHeight || 0;\n\n      const widthWithPadding = width + 24; // 12px padding on each side\n      const heightWithPadding = height + 24; // 12px padding on top and bottom\n\n      const responseAreaWidth = parseFloat(emptyResponseAreaWidth) || 0;\n      const responseAreaHeight = parseFloat(emptyResponseAreaHeight) || 0;\n\n      const adjustedWidth = widthWithPadding <= responseAreaWidth ? responseAreaWidth : widthWithPadding;\n      const adjustedHeight = heightWithPadding <= responseAreaHeight ? responseAreaHeight : heightWithPadding;\n\n      setDimensions((prevState) => ({\n        width: adjustedWidth > responseAreaWidth ? adjustedWidth : prevState.width,\n        height: adjustedHeight > responseAreaHeight ? adjustedHeight : prevState.height,\n      }));\n\n      rootRef.current.style.width = `${adjustedWidth}px`;\n      rootRef.current.style.height = `${adjustedHeight}px`;\n    }\n  };\n\n  const getRootDimensions = () => {\n    // Handle potential non-numeric values\n    const responseAreaWidth = !isNaN(parseFloat(emptyResponseAreaWidth)) ? parseFloat(emptyResponseAreaWidth) : 0;\n    const responseAreaHeight = !isNaN(parseFloat(emptyResponseAreaHeight)) ? parseFloat(emptyResponseAreaHeight) : 0;\n\n    const rootStyle = {\n      height: dimensions.height || responseAreaHeight,\n      width: dimensions.width || responseAreaWidth,\n    };\n\n    // add minWidth, minHeight if width and height are not defined\n    return {\n      ...rootStyle,\n      ...(responseAreaWidth ? {} : { minWidth: 90 }),\n      ...(responseAreaHeight ? {} : { minHeight: 32 }),\n    };\n  };\n\n  useEffect(() => {\n    handleElements();\n  }, []);\n\n  // Render math for the placeholder/preview when dragging over\n  useEffect(() => {\n    if (rootRef.current) {\n      renderMath(rootRef.current);\n    }\n  }, [isOver, dragItem?.choice?.value]);\n\n  useEffect(() => {\n    if (!choice) {\n      setDimensions({ height: 0, width: 0 });\n      return;\n    }\n    handleElements();\n  }, [choice]);\n\n  useEffect(() => {\n    if (!isOver && !isDragging) {\n      frozenRef.current = {\n        width: rootRef.current.offsetWidth,\n        height: rootRef.current.offsetHeight,\n      };\n    }\n  }, [choice, isOver, isDragging]);\n\n  const draggedLabel = dragItem && isOver && dragItem.choice && dragItem.choice.value;\n  const label = choice && choice.value;\n  const style =\n    isOver || isDragging\n      ? {\n          width: frozenRef.current?.width,\n          height: frozenRef.current?.height,\n        }\n      : getRootDimensions();\n\n  return (\n    <StyledChip\n      clickable={false}\n      disabled={disabled}\n      ref={rootRef}\n      component=\"span\"\n      label={\n        <React.Fragment>\n          <StyledChipLabel\n            ref={spanRef}\n            draggable={true}\n            className={classnames({\n              over: isOver,\n              hidden: draggedLabel,\n            })}\n            dangerouslySetInnerHTML={{ __html: label || '' }}\n          />\n          {draggedLabel && (\n            <StyledChipLabel\n              draggable={true}\n              className={classnames({\n                over: isOver,\n                dragged: true,\n              })}\n              dangerouslySetInnerHTML={{ __html: draggedLabel || '' }}\n            />\n          )}\n        </React.Fragment>\n      }\n      className={classnames({\n        over: isOver,\n        parentOver: isOver,\n        correct: correct !== undefined && correct,\n        incorrect: correct !== undefined && !correct,\n      })}\n      variant={disabled ? 'outlined' : undefined}\n      style={style}\n    />\n  );\n}\n\nBlankContent.defaultProps = {\n  emptyResponseAreaWidth: 0,\n  emptyResponseAreaHeight: 0,\n};\n\nBlankContent.propTypes = {\n  id: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  disabled: PropTypes.bool,\n  duplicates: PropTypes.bool,\n  choice: PropTypes.object,\n  isOver: PropTypes.bool,\n  dragItem: PropTypes.object,\n  correct: PropTypes.bool,\n  onChange: PropTypes.func,\n  emptyResponseAreaWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  emptyResponseAreaHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  instanceId: PropTypes.string,\n};\n\n// New functional component using @dnd-kit hooks\nfunction DragDropBlank({\n  id,\n  disabled,\n  duplicates,\n  choice,\n  correct,\n  onChange,\n  emptyResponseAreaWidth,\n  emptyResponseAreaHeight,\n  instanceId,\n}) {\n  // Setup draggable functionality\n  const {\n    attributes: dragAttributes,\n    listeners: dragListeners,\n    setNodeRef: setDragNodeRef,\n    transform,\n    isDragging,\n  } = useDraggable({\n    id: `mask-blank-drag-${id}`,\n    disabled: disabled || !choice,\n    data: {\n      id: id,\n      choice: choice,\n      instanceId: instanceId,\n      fromChoice: false, // This is from a blank, not from choices\n      type: 'MaskBlank',\n    },\n  });\n\n  // Setup droppable functionality\n  const {\n    setNodeRef: setDropNodeRef,\n    isOver,\n    active: dragItem,\n  } = useDroppable({\n    id: `mask-blank-drop-${id}`,\n    data: {\n      id: id,\n      accepts: ['MaskBlank'],\n      instanceId: instanceId,\n    },\n  });\n\n  // Combine refs for both drag and drop\n  const setNodeRef = (node) => {\n    setDragNodeRef(node);\n    setDropNodeRef(node);\n  };\n\n  const style = {\n    transform: CSS.Translate.toString(transform),\n  };\n\n  return (\n    <StyledContent\n      ref={setNodeRef}\n      style={style}\n      dragged={isDragging}\n      over={isOver}\n      {...dragAttributes}\n      {...dragListeners}\n    >\n      <BlankContent\n        id={id}\n        disabled={disabled}\n        duplicates={duplicates}\n        choice={choice}\n        isOver={isOver}\n        dragItem={dragItem?.data?.current}\n        correct={correct}\n        onChange={onChange}\n        emptyResponseAreaWidth={emptyResponseAreaWidth}\n        emptyResponseAreaHeight={emptyResponseAreaHeight}\n        instanceId={instanceId}\n      />\n    </StyledContent>\n  );\n}\n\nDragDropBlank.defaultProps = {\n  emptyResponseAreaWidth: 0,\n  emptyResponseAreaHeight: 0,\n};\n\nDragDropBlank.propTypes = {\n  id: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  disabled: PropTypes.bool,\n  duplicates: PropTypes.bool,\n  choice: PropTypes.object,\n  correct: PropTypes.bool,\n  onChange: PropTypes.func,\n  emptyResponseAreaWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  emptyResponseAreaHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  instanceId: PropTypes.string,\n};\n\nexport default DragDropBlank;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -91,4 +91,4 @@ var CorrectInput = function CorrectInput(props) {
|
|
|
91
91
|
}, rest));
|
|
92
92
|
};
|
|
93
93
|
var _default = exports["default"] = CorrectInput;
|
|
94
|
-
//# sourceMappingURL=
|
|
94
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9PdXRsaW5lZElucHV0IiwiX2NsYXNzbmFtZXMyIiwiX3N0eWxlcyIsIl9yZW5kZXJVaSIsIl9leGNsdWRlZCIsIlN0eWxlZE91dGxpbmVkSW5wdXQiLCJzdHlsZWQiLCJPdXRsaW5lZElucHV0IiwicGFkZGluZyIsImJvcmRlclJhZGl1cyIsImZvbnRTaXplIiwiZGlzcGxheSIsInZlcnRpY2FsQWxpZ24iLCJib3JkZXIiLCJjb2xvciIsInRleHQiLCJiYWNrZ3JvdW5kQ29sb3IiLCJiYWNrZ3JvdW5kIiwiYm9yZGVyV2lkdGgiLCJib3JkZXJTdHlsZSIsIm9wYWNpdHkiLCJjdXJzb3IiLCJib3JkZXJDb2xvciIsInByaW1hcnkiLCJwcmltYXJ5RGFyayIsImNvbmNhdCIsImNvcnJlY3QiLCJpbmNvcnJlY3QiLCJDb3JyZWN0SW5wdXQiLCJwcm9wcyIsImNoYXJhY3RlcnNMaW1pdCIsImRpc2FibGVkIiwiaXNCb3giLCJpc0NvbnN0cnVjdGVkUmVzcG9uc2UiLCJ3aWR0aCIsInNwZWxsQ2hlY2siLCJyZXN0IiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsImxhYmVsIiwidW5kZWZpbmVkIiwiaW5wdXRQcm9wcyIsIm1heExlbmd0aCIsInN0eWxlIiwiTWF0aCIsInJvdW5kIiwiY3JlYXRlRWxlbWVudCIsIl9leHRlbmRzMiIsImNsYXNzTmFtZSIsImNsYXNzbmFtZXMiLCJkaXNhYmxlZElucHV0IiwiYm94IiwiY2xhc3NlcyIsImlucHV0IiwiX2RlZmluZVByb3BlcnR5MiIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2NvcnJlY3QtaW5wdXQuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgT3V0bGluZWRJbnB1dCBmcm9tICdAbXVpL21hdGVyaWFsL091dGxpbmVkSW5wdXQnO1xuaW1wb3J0IGNsYXNzbmFtZXMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgeyBzdHlsZWQgfSBmcm9tICdAbXVpL21hdGVyaWFsL3N0eWxlcyc7XG5pbXBvcnQgeyBjb2xvciB9IGZyb20gJ0BwaWUtbGliL3JlbmRlci11aSc7XG5cbmNvbnN0IFN0eWxlZE91dGxpbmVkSW5wdXQgPSBzdHlsZWQoT3V0bGluZWRJbnB1dCkoKCkgPT4gKHtcbiAgcGFkZGluZzogJzJweCcsXG4gIGJvcmRlclJhZGl1czogJzRweCcsXG4gIGZvbnRTaXplOiAnaW5oZXJpdCcsXG4gIGRpc3BsYXk6ICdpbmxpbmUtYmxvY2snLFxuICB2ZXJ0aWNhbEFsaWduOiAnbWlkZGxlJyxcbiAgJyYgZmllbGRzZXQnOiB7XG4gICAgYm9yZGVyOiAwLFxuICB9LFxuICAnJiAuTXVpT3V0bGluZWRJbnB1dC1pbnB1dCc6IHtcbiAgICBjb2xvcjogY29sb3IudGV4dCgpLFxuICAgIGJhY2tncm91bmRDb2xvcjogY29sb3IuYmFja2dyb3VuZCgpLFxuICAgIGJvcmRlclJhZGl1czogJzRweCAhaW1wb3J0YW50JyxcbiAgICBib3JkZXJXaWR0aDogJzFweCcsXG4gICAgYm9yZGVyU3R5bGU6ICdzb2xpZCcsXG4gICAgcGFkZGluZzogJzEwcHggMjBweCAxMHB4IDEwcHgnLFxuICAgICcmOmRpc2FibGVkJzoge1xuICAgICAgb3BhY2l0eTogMC44LFxuICAgICAgY3Vyc29yOiAnbm90LWFsbG93ZWQgIWltcG9ydGFudCcsXG4gICAgfSxcbiAgICAnJjpob3Zlcic6IHtcbiAgICAgIGJvcmRlckNvbG9yOiBjb2xvci5wcmltYXJ5KCksXG4gICAgICAnJjpkaXNhYmxlZCc6IHtcbiAgICAgICAgYm9yZGVyQ29sb3I6ICdpbml0aWFsJyxcbiAgICAgIH0sXG4gICAgfSxcbiAgICAnJi5NdWktZm9jdXNlZCc6IHtcbiAgICAgIGJvcmRlckNvbG9yOiBjb2xvci5wcmltYXJ5RGFyaygpLFxuICAgIH0sXG4gICAgJyYuY3JJbnB1dCc6IHtcbiAgICAgIHBhZGRpbmc6ICc4cHggIWltcG9ydGFudCcsXG4gICAgfSxcbiAgICAnJi5jb3JyZWN0Jzoge1xuICAgICAgYm9yZGVyQ29sb3I6IGAke2NvbG9yLmNvcnJlY3QoKX0gIWltcG9ydGFudGAsXG4gICAgfSxcbiAgICAnJi5pbmNvcnJlY3QnOiB7XG4gICAgICBib3JkZXJDb2xvcjogYCR7Y29sb3IuaW5jb3JyZWN0KCl9ICFpbXBvcnRhbnRgLFxuICAgIH0sXG4gIH0sXG59KSk7XG5cbmNvbnN0IENvcnJlY3RJbnB1dCA9IChwcm9wcykgPT4ge1xuICBjb25zdCB7IGNvcnJlY3QsIGNoYXJhY3RlcnNMaW1pdCwgZGlzYWJsZWQsIGlzQm94LCBpc0NvbnN0cnVjdGVkUmVzcG9uc2UsIHdpZHRoLCBzcGVsbENoZWNrLCAuLi5yZXN0IH0gPSBwcm9wcztcblxuICBjb25zdCBsYWJlbCA9IHR5cGVvZiBjb3JyZWN0ID09PSAnYm9vbGVhbicgPyAoY29ycmVjdCA/ICdjb3JyZWN0JyA6ICdpbmNvcnJlY3QnKSA6IHVuZGVmaW5lZDtcbiAgY29uc3QgaW5wdXRQcm9wcyA9IGNoYXJhY3RlcnNMaW1pdFxuICAgID8geyBtYXhMZW5ndGg6IGNoYXJhY3RlcnNMaW1pdCwgJ2FyaWEtbGFiZWwnOiAnRW50ZXIgYW5zd2VyJyB9XG4gICAgOiB7ICdhcmlhLWxhYmVsJzogJ0VudGVyIGFuc3dlcicgfTtcblxuICBpZiAod2lkdGgpIHtcbiAgICBpbnB1dFByb3BzLnN0eWxlID0ge1xuICAgICAgd2lkdGg6IGAke3dpZHRoICsgTWF0aC5yb3VuZCh3aWR0aCAvIDEwKSArIDF9Y2hgLCAvLyBhZGRlZCBzb21lIGV4dHJhIHNwYWNlIGZvciBjYXBpdGFsIGxldHRlcnNcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkT3V0bGluZWRJbnB1dFxuICAgICAgY2xhc3NOYW1lPXtjbGFzc25hbWVzKHtcbiAgICAgICAgZGlzYWJsZWRJbnB1dDogZGlzYWJsZWQsXG4gICAgICAgIGJveDogaXNCb3gsXG4gICAgICB9KX1cbiAgICAgIGNsYXNzZXM9e3tcbiAgICAgICAgaW5wdXQ6IGNsYXNzbmFtZXMoe1xuICAgICAgICAgIFtsYWJlbF06IGxhYmVsLFxuICAgICAgICAgIGNySW5wdXQ6IGlzQ29uc3RydWN0ZWRSZXNwb25zZSxcbiAgICAgICAgfSksXG4gICAgICB9fVxuICAgICAgaW5wdXRQcm9wcz17aW5wdXRQcm9wc31cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIHNwZWxsQ2hlY2s9e3NwZWxsQ2hlY2t9XG4gICAgICB7Li4ucmVzdH1cbiAgICAvPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ycmVjdElucHV0O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsY0FBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUUsWUFBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUcsT0FBQSxHQUFBSCxPQUFBO0FBQ0EsSUFBQUksU0FBQSxHQUFBSixPQUFBO0FBQTJDLElBQUFLLFNBQUE7QUFFM0MsSUFBTUMsbUJBQW1CLEdBQUcsSUFBQUMsY0FBTSxFQUFDQyx5QkFBYSxDQUFDLENBQUM7RUFBQSxPQUFPO0lBQ3ZEQyxPQUFPLEVBQUUsS0FBSztJQUNkQyxZQUFZLEVBQUUsS0FBSztJQUNuQkMsUUFBUSxFQUFFLFNBQVM7SUFDbkJDLE9BQU8sRUFBRSxjQUFjO0lBQ3ZCQyxhQUFhLEVBQUUsUUFBUTtJQUN2QixZQUFZLEVBQUU7TUFDWkMsTUFBTSxFQUFFO0lBQ1YsQ0FBQztJQUNELDJCQUEyQixFQUFFO01BQzNCQyxLQUFLLEVBQUVBLGVBQUssQ0FBQ0MsSUFBSSxDQUFDLENBQUM7TUFDbkJDLGVBQWUsRUFBRUYsZUFBSyxDQUFDRyxVQUFVLENBQUMsQ0FBQztNQUNuQ1IsWUFBWSxFQUFFLGdCQUFnQjtNQUM5QlMsV0FBVyxFQUFFLEtB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
|
|
@@ -465,4 +465,4 @@ var Dropdown = /*#__PURE__*/function (_React$Component) {
|
|
|
465
465
|
correctValue: _propTypes["default"].string
|
|
466
466
|
});
|
|
467
467
|
var _default = exports["default"] = Dropdown;
|
|
468
|
-
//# sourceMappingURL=dropdown.js.map
|
|
468
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_Button","_InputLabel","_Menu","_MenuItem","_ArrowDropDown","_ArrowDropUp","_Close","_Check","_styles","_renderUi","_mathRendering","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","StyledButton","styled","Button","color","text","border","concat","borderGray","borderRadius","justifyContent","backgroundColor","background","position","height","width","margin","textTransform","paddingRight","right","top","pointerEvents","marginLeft","outline","tertiary","outlineOffset","borderWidth","borderColor","correct","incorrectWithIcon","StyledMenu","Menu","padding","StyledMenuItem","MenuItem","overflow","fontSize","fontWeight","fontFamily","lineHeight","whiteSpace","dropdownBackground","boxSizing","StyledLabel","StyledSelectedIndicator","StyledInputLabel","InputLabel","left","StyledCorrectnessIcon","Check","white","StyledIncorrectnessIcon","Close","Dropdown","_React$Component","props","_this","_classCallCheck2","event","setState","anchorEl","currentTarget","value","previewValue","highlightedOptionId","previewRef","current","innerHTML","index","id","stateUpdate","choices","onChange","handleHighlight","handleClose","selectedValue","state","ref","elementRefs","preview","menuWidth","hiddenRef","React","createRef","buttonRef","_inherits2","_createClass2","key","componentDidMount","clientWidth","componentDidUpdate","prevProps","prevState","hiddenEl","dropdownJustOpened","containsLatex","querySelector","hasMathJax","mathHandled","renderMath","newWidth","getLabel","found","find","choice","label","trim","undefined","render","_this2","_this$props","disabled","showCorrectAnswer","singleQuery","correctValue","open","buttonId","menuId","valueDisplayId","disabledClass","incrementedId","parseInt","labelId","labelText","correctnessIcon","createElement","className","Fragment","style","visibility","tabIndex","map","c","dangerouslySetInnerHTML","__html","minWidth","transition","onClick","handleClick","role","keepMounted","onClose","getContentAnchorEl","anchorOrigin","vertical","horizontal","transformOrigin","transitionDuration","enter","exit","slotProps","paper","list","disablePadding","optionId","handleSelect","onMouseOver","handleHover","Component","PropTypes","string","bool","func","arrayOf","shape","_default","exports"],"sources":["../../src/components/dropdown.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Button from '@mui/material/Button';\nimport InputLabel from '@mui/material/InputLabel';\nimport Menu from '@mui/material/Menu';\nimport MenuItem from '@mui/material/MenuItem';\nimport ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';\nimport ArrowDropUpIcon from '@mui/icons-material/ArrowDropUp';\nimport Close from '@mui/icons-material/Close';\nimport Check from '@mui/icons-material/Check';\nimport { styled } from '@mui/material/styles';\n\nimport { color } from '@pie-lib/render-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\n\nconst StyledButton = styled(Button)(() => ({\n  color: color.text(),\n  border: `1px solid ${color.borderGray()}`,\n  borderRadius: '4px',\n  justifyContent: 'space-between',\n  backgroundColor: color.background(),\n  position: 'relative',\n  height: '45px',\n  width: 'fit-content',\n  margin: '2px',\n  textTransform: 'none',\n  '& span': {\n    paddingRight: '5px',\n  },\n  '& svg': {\n    position: 'absolute',\n    right: 0,\n    top: 'calc(50% - 12px)',\n    pointerEvents: 'none',\n    color: color.text(),\n    marginLeft: '5px',\n  },\n  '&.Mui-focused': {\n    outline: `3px solid ${color.tertiary()}`,\n    outlineOffset: '2px',\n    borderWidth: '3px',\n  },\n  '&.disabledCorrect': {\n    borderWidth: '2px',\n    borderColor: color.correct(),\n    color: `${color.text()} !important`,\n  },\n  '&.disabledIncorrect': {\n    borderWidth: '2px',\n    borderColor: color.incorrectWithIcon(),\n    color: `${color.text()} !important`,\n  },\n}));\n\nconst StyledMenu = styled(Menu)(() => ({\n  backgroundColor: color.background(),\n  border: `1px solid ${color.correct()} !important`,\n  '&:hover': {\n    border: `1px solid ${color.text()} `,\n    borderColor: 'initial',\n  },\n  '&:focus': {\n    border: `1px solid ${color.text()}`,\n    borderColor: 'initial',\n  },\n  // remove default padding on the inner list\n  '& .MuiList-root': {\n    padding: 0,\n  },\n}));\n\nconst StyledMenuItem = styled(MenuItem)(() => ({\n  // base text/layout styles (from old JSS - before mui v5 migration)\n  height: 24,\n  overflow: 'hidden',\n  fontSize: '1rem',\n  fontWeight: 400,\n  fontFamily: 'inherit',\n  lineHeight: '1.5em',\n  whiteSpace: 'nowrap',\n\n  // custom styles\n  color: color.text(),\n  backgroundColor: color.background(),\n  '&.Mui-focusVisible': {\n    outline: `3px solid ${color.tertiary()}`,\n    outlineOffset: '-1px', // keeps it inside the item\n    color: color.text(),\n    backgroundColor: color.background(),\n  },\n  '&:hover': {\n    color: color.text(),\n    backgroundColor: color.dropdownBackground(),\n  },\n  boxSizing: 'border-box',\n  padding: '25px',\n  borderRadius: '4px',\n  '&.selected': {\n    color: `${color.text()} !important`,\n    backgroundColor: `${color.background()} !important`,\n    '&:hover': {\n      color: color.text(),\n      backgroundColor: `${color.dropdownBackground()} !important`,\n    },\n  },\n}));\n\nconst StyledLabel = styled('span')(() => ({\n  fontSize: 'max(1rem, 14px)',\n}));\n\nconst StyledSelectedIndicator = styled('span')(() => ({\n  fontSize: 'max(1rem, 14px)',\n  position: 'absolute',\n  right: '10px',\n}));\n\nconst StyledInputLabel = styled(InputLabel)(() => ({\n  position: 'absolute',\n  left: '-10000px',\n  top: 'auto',\n  width: '1px',\n  height: '1px',\n  overflow: 'hidden',\n}));\n\nconst StyledCorrectnessIcon = styled(Check)(() => ({\n  color: `${color.white()} !important`,\n  position: 'absolute',\n  top: '-8px !important',\n  left: '-8px',\n  marginLeft: '0 !important',\n  borderRadius: '50%',\n  fontSize: '16px',\n  padding: '2px',\n  '&.correct': {\n    backgroundColor: color.correct(),\n  },\n  '&.incorrect': {\n    backgroundColor: color.incorrectWithIcon(),\n  },\n}));\n\nconst StyledIncorrectnessIcon = styled(Close)(() => ({\n  color: `${color.white()} !important`,\n  position: 'absolute',\n  top: '-8px !important',\n  left: '-8px',\n  marginLeft: '0 !important',\n  borderRadius: '50%',\n  fontSize: '16px',\n  padding: '2px',\n  '&.correct': {\n    backgroundColor: color.correct(),\n  },\n  '&.incorrect': {\n    backgroundColor: color.incorrectWithIcon(),\n  },\n}));\n\nclass Dropdown extends React.Component {\n  static propTypes = {\n    id: PropTypes.string,\n    value: PropTypes.string,\n    disabled: PropTypes.bool,\n    onChange: PropTypes.func,\n    correct: PropTypes.bool,\n    choices: PropTypes.arrayOf(PropTypes.shape({ value: PropTypes.string, label: PropTypes.string })),\n    showCorrectAnswer: PropTypes.bool,\n    singleQuery: PropTypes.bool,\n    correctValue: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      anchorEl: null,\n      highlightedOptionId: null,\n      menuWidth: null,\n      previewValue: null,\n    };\n    this.hiddenRef = React.createRef();\n    this.buttonRef = React.createRef();\n    this.previewRef = React.createRef();\n    this.elementRefs = [];\n  }\n\n  componentDidMount() {\n    // measure hidden menu width once\n    if (this.hiddenRef.current && this.state.menuWidth === null) {\n      this.setState({ menuWidth: this.hiddenRef.current.clientWidth });\n    }\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    const hiddenEl = this.hiddenRef.current;\n\n    const dropdownJustOpened = !prevState.anchorEl && this.state.anchorEl;\n    if (dropdownJustOpened) {\n      this.elementRefs.forEach((ref) => {\n        if (!ref) return;\n\n        const containsLatex = ref.querySelector('[data-latex], [data-raw]');\n        const hasMathJax = ref.querySelector('mjx-container');\n        const mathHandled = ref.querySelector('[data-math-handled=\"true\"]');\n\n        if (containsLatex && (!mathHandled || !hasMathJax)) {\n          renderMath(ref);\n        }\n      });\n    }\n\n    if (hiddenEl) {\n      const newWidth = hiddenEl.clientWidth;\n      if (newWidth !== this.state.menuWidth) {\n        this.elementRefs.forEach((ref) => {\n          if (ref) renderMath(ref);\n        });\n\n        renderMath(hiddenEl);\n        this.setState({ menuWidth: newWidth });\n      }\n    }\n  }\n\n  handleClick = (event) => this.setState({ anchorEl: event.currentTarget });\n\n  handleClose = () => {\n    const { value } = this.props;\n    this.setState({ anchorEl: null, previewValue: null, highlightedOptionId: null });\n    // clear displayed preview if no selection\n    if (!value && this.previewRef.current) {\n      this.previewRef.current.innerHTML = '';\n    }\n  };\n\n  handleHighlight = (index) => {\n    const highlightedOptionId = `dropdown-option-${this.props.id}-${index}`;\n\n    // preview on hover if nothing selected\n    const stateUpdate = { highlightedOptionId };\n    if (!this.props.value) {\n      stateUpdate.previewValue = this.props.choices[index].value;\n    }\n    this.setState(stateUpdate);\n  };\n\n  handleSelect = (value, index) => {\n    this.props.onChange(this.props.id, value);\n    this.handleHighlight(index);\n    this.handleClose();\n  };\n\n  handleHover = (index) => {\n    const selectedValue = this.props.value;\n\n    if (selectedValue) return;\n\n    const highlightedOptionId = `dropdown-option-${this.props.id}-${index}`;\n    const previewValue = this.state.previewValue;\n\n    this.setState({ highlightedOptionId, previewValue }, () => {\n      // On hover, preview the math-rendered content inside the button if no value is selected.\n      const ref = this.elementRefs[index];\n      const preview = this.previewRef.current;\n\n      if (ref && preview) {\n        preview.innerHTML = ref.innerHTML;\n      }\n    });\n  };\n\n  getLabel(choices, value) {\n    const found = (choices || []).find((choice) => choice.value === value);\n\n    return found ? found.label.trim() : undefined;\n  }\n\n  render() {\n    const { id, correct, disabled, value, choices, showCorrectAnswer, singleQuery, correctValue } = this.props;\n    const { anchorEl } = this.state;\n    const open = Boolean(anchorEl);\n    const buttonId = `dropdown-button-${id}`;\n    const menuId = `dropdown-menu-${id}`;\n    const valueDisplayId = `dropdown-value-${id}`;\n\n    // Determine the class for disabled state, view mode and evaluate mode\n    let disabledClass;\n    // Reset elementRefs before each render to avoid stale references\n    this.elementRefs = [];\n\n    if (disabled && correct !== undefined) {\n      disabledClass = correct || showCorrectAnswer ? 'disabledCorrect' : 'disabledIncorrect';\n    }\n\n    // Create distinct, visually hidden labels for each dropdown\n    const incrementedId = parseInt(id, 10) + 1;\n    const labelId = singleQuery ? 'Query-label' : `Query-label-${incrementedId}`;\n    const labelText = singleQuery ? 'Query' : `Query ${incrementedId}`;\n\n    // Changed from Select to Button for dropdown to enhance accessibility. This modification offers explicit control over aria attributes and focuses management, ensuring the dropdown is compliant with accessibility standards. The use of Button and Menu components allows for better handling of keyboard interactions and provides accessible labels and menus, aligning with WCAG guidelines and improving usability for assistive technology users.\n    let correctnessIcon = null;\n    if (disabled && correct !== undefined) {\n      correctnessIcon =\n        correct || showCorrectAnswer ? (\n          <StyledCorrectnessIcon className=\"correct\" />\n        ) : (\n          <StyledIncorrectnessIcon className=\"incorrect\" />\n        );\n    }\n\n    return (\n      <>\n        <div\n          ref={this.hiddenRef}\n          style={{ position: 'absolute', visibility: 'hidden', top: 0, left: 0 }}\n          tabIndex={-1}\n          aria-hidden=\"true\"\n        >\n          {(choices || []).map((c, index) => (\n            <StyledMenuItem key={index} tabIndex={-1} aria-hidden=\"true\">\n              <StyledLabel dangerouslySetInnerHTML={{ __html: c.label }} />\n            </StyledMenuItem>\n          ))}\n        </div>\n        <StyledInputLabel id={labelId} tabIndex={-1} aria-hidden=\"true\">\n          {labelText}\n        </StyledInputLabel>\n        <StyledButton\n          ref={this.buttonRef}\n          style={{\n            ...(this.state.menuWidth && { minWidth: `calc(${this.state.menuWidth}px + 8px)` }),\n            borderWidth: open ? '2px' : '1px',\n            transition: 'border-width 0.2s ease-in-out',\n          }}\n          aria-controls={open ? menuId : undefined}\n          aria-haspopup=\"listbox\"\n          aria-expanded={open ? 'true' : undefined}\n          aria-activedescendant={this.state.highlightedOptionId}\n          onClick={this.handleClick}\n          className={disabledClass}\n          disabled={disabled}\n          id={buttonId}\n          role=\"combobox\"\n          aria-label={`Select an option for ${labelText}`}\n          aria-labelledby={valueDisplayId}\n        >\n          {correctnessIcon}\n          <StyledLabel\n            id={valueDisplayId}\n            ref={this.previewRef}\n            dangerouslySetInnerHTML={{\n              __html: correctValue\n                ? correctValue\n                : open && this.state.previewValue\n                  ? this.getLabel(choices, this.state.previewValue)\n                  : this.getLabel(choices, value) || '',\n            }}\n          />\n          {open ? <ArrowDropUpIcon /> : <ArrowDropDownIcon />}\n        </StyledButton>\n        <StyledMenu\n          id={menuId}\n          anchorEl={anchorEl}\n          keepMounted\n          open={open}\n          onClose={this.handleClose}\n          getContentAnchorEl={null}\n          anchorOrigin={{ vertical: 'bottom', horizontal: 'left' }}\n          transformOrigin={{ vertical: 'top', horizontal: 'left' }}\n          transitionDuration={{ enter: 225, exit: 195 }}\n          slotProps={{\n            paper: this.state.menuWidth ? { style: { minWidth: this.state.menuWidth, padding: '4px' } } : undefined,\n            list: {\n              'aria-labelledby': buttonId,\n              role: 'listbox',\n              disablePadding: true,\n            },\n          }}\n        >\n          {(choices || []).map((c, index) => {\n            const optionId = `dropdown-option-${id}-${index}`;\n\n            return (\n              <StyledMenuItem\n                id={optionId}\n                className={c.value === value ? 'selected' : ''}\n                key={`${c.label}-${index}`}\n                value={c.value}\n                onClick={() => this.handleSelect(c.value, index)}\n                role=\"option\"\n                aria-selected={this.state.highlightedOptionId === optionId ? 'true' : undefined}\n                onMouseOver={() => this.handleHover(index)}\n              >\n                <StyledLabel\n                  ref={(ref) => (this.elementRefs[index] = ref)}\n                  dangerouslySetInnerHTML={{ __html: c.label }}\n                />\n                <StyledSelectedIndicator dangerouslySetInnerHTML={{ __html: c.value === value ? ' &check;' : '' }} />\n              </StyledMenuItem>\n            );\n          })}\n        </StyledMenu>\n      </>\n    );\n  }\n}\n\nexport default Dropdown;\n"],"mappings":"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","ignoreList":[]}
|
package/lib/components/input.js
CHANGED
|
@@ -47,4 +47,4 @@ Input.propTypes = {
|
|
|
47
47
|
isConstructedResponse: _propTypes["default"].bool
|
|
48
48
|
};
|
|
49
49
|
var _default = exports["default"] = Input;
|
|
50
|
-
//# sourceMappingURL=
|
|
50
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9wcm9wVHlwZXMiLCJfY29ycmVjdElucHV0IiwiSW5wdXQiLCJfcmVmIiwiZGlzYWJsZWQiLCJjb3JyZWN0IiwiY2hhcmFjdGVyc0xpbWl0IiwiaWQiLCJpc0NvbnN0cnVjdGVkUmVzcG9uc2UiLCJ2YWx1ZSIsIm9uQ2hhbmdlIiwic2hvd0NvcnJlY3RBbnN3ZXIiLCJzcGVsbENoZWNrIiwid2lkdGgiLCJjcmVhdGVFbGVtZW50IiwidmFyaWFudCIsImlzQm94IiwiZSIsInRhcmdldCIsInByb3BUeXBlcyIsIlByb3BUeXBlcyIsInN0cmluZyIsImZ1bmMiLCJib29sIiwibnVtYmVyIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbXBvbmVudHMvaW5wdXQuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IENvcnJlY3RJbnB1dCBmcm9tICcuL2NvcnJlY3QtaW5wdXQnO1xuXG5jb25zdCBJbnB1dCA9ICh7XG4gIGRpc2FibGVkLFxuICBjb3JyZWN0LFxuICBjaGFyYWN0ZXJzTGltaXQsXG4gIGlkLFxuICBpc0NvbnN0cnVjdGVkUmVzcG9uc2UsXG4gIHZhbHVlLFxuICBvbkNoYW5nZSxcbiAgc2hvd0NvcnJlY3RBbnN3ZXIsXG4gIHNwZWxsQ2hlY2ssXG4gIHdpZHRoLFxufSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxDb3JyZWN0SW5wdXRcbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIGNvcnJlY3Q9e3Nob3dDb3JyZWN0QW5zd2VyIHx8IGNvcnJlY3R9XG4gICAgICBjaGFyYWN0ZXJzTGltaXQ9e2NoYXJhY3RlcnNMaW1pdH1cbiAgICAgIHZhcmlhbnQ9XCJvdXRsaW5lZFwiXG4gICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICBpc0NvbnN0cnVjdGVkUmVzcG9uc2U9e2lzQ29uc3RydWN0ZWRSZXNwb25zZX1cbiAgICAgIHNwZWxsQ2hlY2s9e3NwZWxsQ2hlY2t9XG4gICAgICBpc0JveD17dHJ1ZX1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIG9uQ2hhbmdlPXsoZSkgPT4ge1xuICAgICAgICBvbkNoYW5nZShpZCwgZS50YXJnZXQudmFsdWUpO1xuICAgICAgfX1cbiAgICAvPlxuICApO1xufTtcblxuSW5wdXQucHJvcFR5cGVzID0ge1xuICBpZDogUHJvcFR5cGVzLnN0cmluZyxcbiAgdmFsdWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgZGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBzcGVsbENoZWNrOiBQcm9wVHlwZXMuYm9vbCxcbiAgY29ycmVjdDogUHJvcFR5cGVzLmJvb2wsXG4gIHNob3dDb3JyZWN0QW5zd2VyOiBQcm9wVHlwZXMuYm9vbCxcbiAgY2hhcmFjdGVyc0xpbWl0OiBQcm9wVHlwZXMubnVtYmVyLFxuICB3aWR0aDogUHJvcFR5cGVzLm51bWJlcixcbiAgaXNDb25zdHJ1Y3RlZFJlc3BvbnNlOiBQcm9wVHlwZXMuYm9vbCxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IElucHV0O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUUsYUFBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBTUcsS0FBSyxHQUFHLFNBQVJBLEtBQUtBLENBQUFDLElBQUEsRUFXTDtFQUFBLElBVkpDLFFBQVEsR0FBQUQsSUFBQSxDQUFSQyxRQUFRO0lBQ1JDLE9BQU8sR0FBQUYsSUFBQSxDQUFQRSxPQUFPO0lBQ1BDLGVBQWUsR0FBQUgsSUFBQSxDQUFmRyxlQUFlO0lBQ2ZDLEVBQUUsR0FBQUosSUFBQSxDQUFGSSxFQUFFO0lBQ0ZDLHFCQUFxQixHQUFBTCxJQUFBLENBQXJCSyxxQkFBcUI7SUFDckJDLEtBQUssR0FBQU4sSUFBQSxDQUFMTSxLQUFLO0lBQ0xDLFNBQVEsR0FBQVAsSUFBQSxDQUFSTyxRQUFRO0lBQ1JDLGlCQUFpQixHQUFBUixJQUFBLENBQWpCUSxpQkFBaUI7SUFDakJDLFVBQVUsR0FBQVQsSUFBQSxDQUFWUyxVQUFVO0lBQ1ZDLEtBQUssR0FBQVYsSUFBQSxDQUFMVSxLQUFLO0VBRUwsb0JBQ0VoQixNQUFBLFlBQUFpQixhQUFBLENBQUNiLGFBQUEsV0FBWTtJQUNYRyxRQUFRLEVBQUVBLFFBQVM7SUFDbkJDLE9BQU8sRUFBRU0saUJBQWlCLElBQUlOLE9BQVE7SUFDdENDLGVBQWUsRUFBRUEsZUFBZ0I7SUFDakNTLE9BQU8sRUFBQyxVQUFVO0lBQ2xCTixLQUFLLEVBQUVBLEtBQU07SUFDYkQscUJBQXFCLEVBQUVBLHFCQUFzQjtJQUM3Q0ksVUFBVSxFQUFFQSxVQUFXO0lBQ3ZCSSxLQUFLLEVBQUUsSUFBSztJQUNaSCxLQUFLLEVBQUVBLEtBQU07SUFDYkgsUUFBUSxFQUFFLFNBQVZBLFFBQVFBLENBQUdPLENBQUMsRUFBSztNQUNmUCxTQUFRLENBQUNILEVBQUUsRUFBRVUsQ0FBQyxDQUFDQyxNQUFNLENBQUNULEtBQUssQ0FBQztJQUM5QjtFQUFFLENBQ0gsQ0FBQztBQUVOLENBQUM7QUFFRFAsS0FBSyxDQUFDaUIsU0FBUyxHQUFHO0VBQ2hCWixFQUFFLEVBQUVhLHFCQUFTLENBQUNDLE1BQU07RUFDcEJaLEtBQUssRUFBRVcscUJBQVMsQ0FBQ0MsTUFBTTtFQUN2QlgsUUFBUSxFQUFFVSxxQkFBUyxDQUFDRSxJQUFJO0VBQ3hCbEIsUUFBUSxFQUFFZ0IscUJBQVMsQ0FBQ0csSUFBSTtFQUN4QlgsVUFBVSxFQUFFUSxxQkFBUyxDQUFDRyxJQUFJO0VBQzFCbEIsT0FBTyxFQUFFZSxxQkFBUyxDQUFDRyxJQUFJO0VBQ3ZCWixpQkFBaUIsRUFBRVMscUJBQVMsQ0FBQ0csSUFBSTtFQUNqQ2pCLGVBQWUsRUFBRWMscUJBQVMsQ0FBQ0ksTUFBTTtFQUNqQ1gsS0FBSyxFQUFFTyxxQkFBUyxDQUFDSSxNQUFNO0VBQ3ZCaEIscUJBQXFCLEVBQUVZLHFCQUFTLENBQUNHO0FBQ25DLENBQUM7QUFBQyxJQUFBRSxRQUFBLEdBQUFDLE9BQUEsY0FFYXhCLEtBQUsiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -98,4 +98,4 @@ var MaskedInput = function MaskedInput(props) {
|
|
|
98
98
|
};
|
|
99
99
|
};
|
|
100
100
|
var _default = exports["default"] = (0, _withMask.withMask)('input', MaskedInput);
|
|
101
|
-
//# sourceMappingURL=constructed-response.js.map
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_styles","_classnames","_renderUi","_withMask","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","EditableHtml","StyledEditableHtml","window","styled","display","verticalAlign","margin","borderRadius","border","concat","color","black","correct","incorrect","MaskedInput","props","node","data","_node$data","adjustedLimit","disabled","feedback","showCorrectAnswer","maxLength","spellCheck","pluginProps","onChange","dataset","component","_pluginProps$characte","correctAnswer","choices","id","finalValue","label","width","feedbackStatus","isCorrect","isIncorrect","handleInputChange","newValue","updatedValue","handleKeyDown","event","key","keyCode","createElement","type","disableUnderline","markup","charactersLimit","activePlugins","languageCharactersProps","language","adjustWidthForLimit","onKeyDown","autoWidthToolbar","toolbarOpts","minWidth","noBorder","isHidden","characters","className","classnames","_default","exports","withMask"],"sources":["../src/constructed-response.jsx"],"sourcesContent":["import React from 'react';\nimport { styled } from '@mui/material/styles';\nimport classnames from 'classnames';\n\nimport { color } from '@pie-lib/render-ui';\nimport { withMask } from './with-mask';\n//import EditableHtml from '@pie-lib/editable-html-tip-tap';\n\nlet EditableHtml;\nlet StyledEditableHtml;\n\n// - mathquill error window not defined\nif (typeof window !== 'undefined') {\n  EditableHtml = require('@pie-lib/editable-html-tip-tap')['default'];\n  StyledEditableHtml = styled(EditableHtml)(() => ({\n    display: 'inline-block',\n    verticalAlign: 'middle',\n    margin: '4px',\n    borderRadius: '4px',\n    border: `1px solid ${color.black()}`,\n    '&.correct': {\n      border: `1px solid ${color.correct()}`,\n    },\n    '&.incorrect': {\n      border: `1px solid ${color.incorrect()}`,\n    },\n  }));\n}\n\nconst MaskedInput = (props) => (node, data) => {\n  const { adjustedLimit, disabled, feedback, showCorrectAnswer, maxLength, spellCheck, pluginProps, onChange } = props;\n  const dataset = node.data?.dataset || {};\n\n  if (dataset.component === 'input') {\n    const correctAnswer = ((props.choices && dataset && props.choices[dataset.id]) || [])[0];\n    const finalValue = showCorrectAnswer ? correctAnswer && correctAnswer.label : data[dataset.id] || '';\n    const width = maxLength && maxLength[dataset.id];\n    const feedbackStatus = feedback && feedback[dataset.id];\n    const isCorrect = showCorrectAnswer || feedbackStatus === 'correct';\n    const isIncorrect = !showCorrectAnswer && feedbackStatus === 'incorrect';\n\n    const handleInputChange = (newValue) => {\n      const updatedValue = {\n        ...data,\n        [dataset.id]: newValue,\n      };\n      onChange(updatedValue);\n    };\n\n    const handleKeyDown = (event) => {\n      // the keyCode value for the Enter/Return key is 13\n      if (event.key === 'Enter' || event.keyCode === 13) {\n        return true;\n      }\n    };\n\n    return (\n      <StyledEditableHtml\n        id={dataset.id}\n        key={`${node.type}-input-${dataset.id}`}\n        disabled={showCorrectAnswer || disabled}\n        disableUnderline\n        onChange={handleInputChange}\n        markup={finalValue || ''}\n        charactersLimit={adjustedLimit ? width : 25}\n        activePlugins={['languageCharacters']}\n        pluginProps={pluginProps}\n        languageCharactersProps={[{ language: 'spanish' }]}\n        spellCheck={spellCheck}\n        adjustWidthForLimit\n        onKeyDown={handleKeyDown}\n        autoWidthToolbar\n        toolbarOpts={{\n          minWidth: 'auto',\n          noBorder: true,\n          isHidden: !!pluginProps?.characters?.disabled,\n        }}\n        className={classnames({\n          correct: isCorrect,\n          incorrect: isIncorrect,\n        })}\n      />\n    );\n  }\n};\n\nexport default withMask('input', MaskedInput);\n"],"mappings":"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","ignoreList":[]}
|
package/lib/customizable.js
CHANGED
|
@@ -39,4 +39,4 @@ var _default = exports["default"] = (0, _withMask.withMask)('input', function (p
|
|
|
39
39
|
}
|
|
40
40
|
};
|
|
41
41
|
});
|
|
42
|
-
//# sourceMappingURL=
|
|
42
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfd2l0aE1hc2siLCJyZXF1aXJlIiwiX2RlZmF1bHQiLCJleHBvcnRzIiwid2l0aE1hc2siLCJwcm9wcyIsIm5vZGUiLCJkYXRhIiwib25DaGFuZ2UiLCJkYXRhc2V0IiwiY29tcG9uZW50IiwiY3VzdG9tTWFya01hcmt1cENvbXBvbmVudCIsImlkIl0sInNvdXJjZXMiOlsiLi4vc3JjL2N1c3RvbWl6YWJsZS5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiLy8gaW1wb3J0IElucHV0IGZyb20gJy4vY29tcG9uZW50cy9pbnB1dCc7XG5pbXBvcnQgeyB3aXRoTWFzayB9IGZyb20gJy4vd2l0aC1tYXNrJztcblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0L2Rpc3BsYXktbmFtZVxuZXhwb3J0IGRlZmF1bHQgd2l0aE1hc2soJ2lucHV0JywgKHByb3BzKSA9PiAobm9kZSwgZGF0YSwgb25DaGFuZ2UpID0+IHtcbiAgY29uc3QgZGF0YXNldCA9IG5vZGUuZGF0YSA/IG5vZGUuZGF0YS5kYXRhc2V0IHx8IHt9IDoge307XG4gIGlmIChkYXRhc2V0LmNvbXBvbmVudCA9PT0gJ2lucHV0Jykge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9wcm9wLXR5cGVzXG4gICAgLy8gY29uc3QgeyBhZGp1c3RlZExpbWl0LCBkaXNhYmxlZCwgZmVlZGJhY2ssIHNob3dDb3JyZWN0QW5zd2VyLCBtYXhMZW5ndGgsIHNwZWxsQ2hlY2sgfSA9IHByb3BzO1xuXG4gICAgLy8gdGhlIGZpcnN0IGFuc3dlciBpcyB0aGUgY29ycmVjdCBvbmVcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3QvcHJvcC10eXBlc1xuICAgIC8vIGNvbnN0IGNvcnJlY3RBbnN3ZXIgPSAoKHByb3BzLmNob2ljZXMgJiYgZGF0YXNldCAmJiBwcm9wcy5jaG9pY2VzW2RhdGFzZXQuaWRdKSB8fCBbXSlbMF07XG4gICAgLy8gY29uc3QgZmluYWxWYWx1ZSA9IHNob3dDb3JyZWN0QW5zd2VyID8gY29ycmVjdEFuc3dlciAmJiBjb3JyZWN0QW5zd2VyLmxhYmVsIDogZGF0YVtkYXRhc2V0LmlkXSB8fCAnJztcbiAgICAvLyBjb25zdCB3aWR0aCA9IG1heExlbmd0aCAmJiBtYXhMZW5ndGhbZGF0YXNldC5pZF07XG5cbiAgICByZXR1cm4gcHJvcHMuY3VzdG9tTWFya01hcmt1cENvbXBvbmVudChkYXRhc2V0LmlkKTtcbiAgICAvLyByZXR1cm4gKFxuICAgIC8vICAgPElucHV0XG4gICAgLy8gICAgIGtleT17YCR7bm9kZS50eXBlfS1pbnB1dC0ke2RhdGFzZXQuaWR9YH1cbiAgICAvLyAgICAgY29ycmVjdD17ZmVlZGJhY2sgJiYgZmVlZGJhY2tbZGF0YXNldC5pZF0gJiYgZmVlZGJhY2tbZGF0YXNldC5pZF0gPT09ICdjb3JyZWN0J31cbiAgICAvLyAgICAgZGlzYWJsZWQ9e3Nob3dDb3JyZWN0QW5zd2VyIHx8IGRpc2FibGVkfVxuICAgIC8vICAgICB2YWx1ZT17ZmluYWxWYWx1ZX1cbiAgICAvLyAgICAgaWQ9e2RhdGFzZXQuaWR9XG4gICAgLy8gICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAvLyAgICAgc2hvd0NvcnJlY3RBbnN3ZXI9e3Nob3dDb3JyZWN0QW5zd2VyfVxuICAgIC8vICAgICB3aWR0aD17d2lkdGh9XG4gICAgLy8gICAgIGNoYXJhY3RlcnNMaW1pdD17YWRqdXN0ZWRMaW1pdCA/IHdpZHRoIDogMjV9XG4gICAgLy8gICAgIGlzQ29uc3RydWN0ZWRSZXNwb25zZT17dHJ1ZX1cbiAgICAvLyAgICAgc3BlbGxDaGVjaz17c3BlbGxDaGVja31cbiAgICAvLyAgIC8+XG4gICAgLy8gKTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLElBQUFBLFNBQUEsR0FBQUMsT0FBQTtBQURBO0FBR0E7QUFBQSxJQUFBQyxRQUFBLEdBQUFDLE9BQUEsY0FDZSxJQUFBQyxrQkFBUSxFQUFDLE9BQU8sRUFBRSxVQUFDQyxLQUFLO0VBQUEsT0FBSyxVQUFDQyxJQUFJLEVBQUVDLElBQUksRUFBRUMsUUFBUSxFQUFLO0lBQ3BFLElBQU1DLE9BQU8sR0FBR0gsSUFBSSxDQUFDQyxJQUFJLEdBQUdELElBQUksQ0FBQ0MsSUFBSSxDQUFDRSxPQUFPLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3hELElBQUlBLE9BQU8sQ0FBQ0MsU0FBUyxLQUFLLE9BQU8sRUFBRTtNQUNqQztNQUNBOztNQUVBO01BQ0E7TUFDQTtNQUNBO01BQ0E7O01BRUEsT0FBT0wsS0FBSyxDQUFDTSx5QkFBeUIsQ0FBQ0YsT0FBTyxDQUFDRyxFQUFFLENBQUM7TUFDbEQ7TUFDQTtNQUNBO01BQ0E7TUFDQTtNQUNBO01BQ0E7TUFDQTtNQUNBO01BQ0E7TUFDQTtNQUNBO01BQ0E7TUFDQTtNQUNBO0lBQ0Y7RUFDRixDQUFDO0FBQUEsRUFBQyIsImlnbm9yZUxpc3QiOltdfQ==
|