@pie-lib/mask-markup 2.0.0-next.0 → 2.1.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/__tests__/drag-in-the-blank.test.js +129 -0
- package/lib/__tests__/index.test.js +42 -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 +189 -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 +5 -5
- package/lib/constructed-response.js.map +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 +6 -14
- package/src/constructed-response.jsx +6 -15
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
6
|
+
var React = _interopRequireWildcard(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _choice = _interopRequireDefault(require("../choice"));
|
|
9
|
+
var _utils = require("../../__tests__/utils");
|
|
10
|
+
var _index = _interopRequireDefault(require("../index"));
|
|
11
|
+
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); }
|
|
12
|
+
// Mock @dnd-kit hooks to avoid DndContext requirement
|
|
13
|
+
jest.mock('@dnd-kit/core', function () {
|
|
14
|
+
return {
|
|
15
|
+
useDraggable: jest.fn(function () {
|
|
16
|
+
return {
|
|
17
|
+
attributes: {},
|
|
18
|
+
listeners: {},
|
|
19
|
+
setNodeRef: jest.fn(),
|
|
20
|
+
isDragging: false
|
|
21
|
+
};
|
|
22
|
+
}),
|
|
23
|
+
useDroppable: jest.fn(function () {
|
|
24
|
+
return {
|
|
25
|
+
setNodeRef: jest.fn(),
|
|
26
|
+
isOver: false,
|
|
27
|
+
active: null
|
|
28
|
+
};
|
|
29
|
+
})
|
|
30
|
+
};
|
|
31
|
+
});
|
|
32
|
+
describe('index', function () {
|
|
33
|
+
describe('Choices', function () {
|
|
34
|
+
var defaultProps = {
|
|
35
|
+
disabled: false,
|
|
36
|
+
choices: [(0, _utils.choice)('Jumped', '0'), (0, _utils.choice)('Laughed', '1'), (0, _utils.choice)('Spoon', '2')],
|
|
37
|
+
choicePosition: 'below',
|
|
38
|
+
instanceId: 'test-instance'
|
|
39
|
+
};
|
|
40
|
+
it('renders correctly with default props', function () {
|
|
41
|
+
var _render = (0, _react2.render)(/*#__PURE__*/React.createElement(_index["default"], defaultProps)),
|
|
42
|
+
container = _render.container;
|
|
43
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
44
|
+
expect(_react2.screen.getByText('Jumped')).toBeInTheDocument();
|
|
45
|
+
expect(_react2.screen.getByText('Laughed')).toBeInTheDocument();
|
|
46
|
+
expect(_react2.screen.getByText('Spoon')).toBeInTheDocument();
|
|
47
|
+
});
|
|
48
|
+
it('renders correctly with disabled prop as true', function () {
|
|
49
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/React.createElement(_index["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
50
|
+
disabled: true
|
|
51
|
+
}))),
|
|
52
|
+
container = _render2.container;
|
|
53
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
54
|
+
});
|
|
55
|
+
it('renders without duplicates', function () {
|
|
56
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/React.createElement(_index["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
57
|
+
duplicates: undefined,
|
|
58
|
+
value: {
|
|
59
|
+
0: '0',
|
|
60
|
+
1: '1'
|
|
61
|
+
}
|
|
62
|
+
}))),
|
|
63
|
+
container = _render3.container;
|
|
64
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
65
|
+
});
|
|
66
|
+
it('renders with duplicates', function () {
|
|
67
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/React.createElement(_index["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
68
|
+
duplicates: true,
|
|
69
|
+
value: {
|
|
70
|
+
0: '0',
|
|
71
|
+
1: '1'
|
|
72
|
+
}
|
|
73
|
+
}))),
|
|
74
|
+
container = _render4.container;
|
|
75
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
describe('Choice', function () {
|
|
79
|
+
var defaultProps = {
|
|
80
|
+
disabled: false,
|
|
81
|
+
choice: (0, _utils.choice)('Label', '1'),
|
|
82
|
+
instanceId: 'test-instance'
|
|
83
|
+
};
|
|
84
|
+
describe('render', function () {
|
|
85
|
+
it('renders correctly with default props', function () {
|
|
86
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/React.createElement(_choice["default"], defaultProps)),
|
|
87
|
+
container = _render5.container;
|
|
88
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
89
|
+
expect(_react2.screen.getByText('Label')).toBeInTheDocument();
|
|
90
|
+
});
|
|
91
|
+
it('renders correctly with disabled prop as true', function () {
|
|
92
|
+
var _render6 = (0, _react2.render)(/*#__PURE__*/React.createElement(_choice["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
93
|
+
disabled: true
|
|
94
|
+
}))),
|
|
95
|
+
container = _render6.container;
|
|
96
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_choice","_interopRequireDefault","_utils","_index","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","jest","mock","useDraggable","fn","attributes","listeners","setNodeRef","isDragging","useDroppable","isOver","active","describe","defaultProps","disabled","choices","choice","choicePosition","instanceId","it","_render","render","createElement","container","expect","firstChild","toBeInTheDocument","screen","getByText","_render2","_extends2","_render3","duplicates","undefined","value","_render4","_render5","_render6"],"sources":["../../../src/choices/__tests__/index.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport Choice from '../choice';\nimport { choice } from '../../__tests__/utils';\nimport Choices from '../index';\n\n// Mock @dnd-kit hooks to avoid DndContext requirement\njest.mock('@dnd-kit/core', () => ({\n  useDraggable: jest.fn(() => ({\n    attributes: {},\n    listeners: {},\n    setNodeRef: jest.fn(),\n    isDragging: false,\n  })),\n  useDroppable: jest.fn(() => ({\n    setNodeRef: jest.fn(),\n    isOver: false,\n    active: null,\n  })),\n}));\n\ndescribe('index', () => {\n  describe('Choices', () => {\n    const defaultProps = {\n      disabled: false,\n      choices: [choice('Jumped', '0'), choice('Laughed', '1'), choice('Spoon', '2')],\n      choicePosition: 'below',\n      instanceId: 'test-instance',\n    };\n\n    it('renders correctly with default props', () => {\n      const { container } = render(<Choices {...defaultProps} />);\n      expect(container.firstChild).toBeInTheDocument();\n      expect(screen.getByText('Jumped')).toBeInTheDocument();\n      expect(screen.getByText('Laughed')).toBeInTheDocument();\n      expect(screen.getByText('Spoon')).toBeInTheDocument();\n    });\n\n    it('renders correctly with disabled prop as true', () => {\n      const { container } = render(<Choices {...defaultProps} disabled={true} />);\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders without duplicates', () => {\n      const { container } = render(<Choices {...defaultProps} duplicates={undefined} value={{ 0: '0', 1: '1' }} />);\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders with duplicates', () => {\n      const { container } = render(<Choices {...defaultProps} duplicates={true} value={{ 0: '0', 1: '1' }} />);\n      expect(container.firstChild).toBeInTheDocument();\n    });\n  });\n\n  describe('Choice', () => {\n    const defaultProps = {\n      disabled: false,\n      choice: choice('Label', '1'),\n      instanceId: 'test-instance',\n    };\n\n    describe('render', () => {\n      it('renders correctly with default props', () => {\n        const { container } = render(<Choice {...defaultProps} />);\n        expect(container.firstChild).toBeInTheDocument();\n        expect(screen.getByText('Label')).toBeInTheDocument();\n      });\n\n      it('renders correctly with disabled prop as true', () => {\n        const { container } = render(<Choice {...defaultProps} disabled={true} />);\n        expect(container.firstChild).toBeInTheDocument();\n      });\n    });\n  });\n});\n"],"mappings":";;;;;AAAA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,MAAA,GAAAF,sBAAA,CAAAH,OAAA;AAA+B,SAAAD,wBAAAO,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAT,uBAAA,YAAAA,wBAAAO,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,mBAAAT,CAAA,iBAAAA,CAAA,gBAAAU,OAAA,CAAAV,CAAA,0BAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,cAAAM,EAAA,IAAAd,CAAA,gBAAAc,EAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,EAAA,OAAAP,CAAA,IAAAD,CAAA,GAAAW,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAnB,CAAA,EAAAc,EAAA,OAAAP,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAM,EAAA,EAAAP,CAAA,IAAAC,CAAA,CAAAM,EAAA,IAAAd,CAAA,CAAAc,EAAA,WAAAN,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAE/B;AACAmB,IAAI,CAACC,IAAI,CAAC,eAAe,EAAE;EAAA,OAAO;IAChCC,YAAY,EAAEF,IAAI,CAACG,EAAE,CAAC;MAAA,OAAO;QAC3BC,UAAU,EAAE,CAAC,CAAC;QACdC,SAAS,EAAE,CAAC,CAAC;QACbC,UAAU,EAAEN,IAAI,CAACG,EAAE,CAAC,CAAC;QACrBI,UAAU,EAAE;MACd,CAAC;IAAA,CAAC,CAAC;IACHC,YAAY,EAAER,IAAI,CAACG,EAAE,CAAC;MAAA,OAAO;QAC3BG,UAAU,EAAEN,IAAI,CAACG,EAAE,CAAC,CAAC;QACrBM,MAAM,EAAE,KAAK;QACbC,MAAM,EAAE;MACV,CAAC;IAAA,CAAC;EACJ,CAAC;AAAA,CAAC,CAAC;AAEHC,QAAQ,CAAC,OAAO,EAAE,YAAM;EACtBA,QAAQ,CAAC,SAAS,EAAE,YAAM;IACxB,IAAMC,YAAY,GAAG;MACnBC,QAAQ,EAAE,KAAK;MACfC,OAAO,EAAE,CAAC,IAAAC,aAAM,EAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,IAAAA,aAAM,EAAC,SAAS,EAAE,GAAG,CAAC,EAAE,IAAAA,aAAM,EAAC,OAAO,EAAE,GAAG,CAAC,CAAC;MAC9EC,cAAc,EAAE,OAAO;MACvBC,UAAU,EAAE;IACd,CAAC;IAEDC,EAAE,CAAC,sCAAsC,EAAE,YAAM;MAC/C,IAAAC,OAAA,GAAsB,IAAAC,cAAM,eAAChD,KAAA,CAAAiD,aAAA,CAAC1C,MAAA,WAAO,EAAKiC,YAAe,CAAC,CAAC;QAAnDU,SAAS,GAAAH,OAAA,CAATG,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;MAChDF,MAAM,CAACG,cAAM,CAACC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MACtDF,MAAM,CAACG,cAAM,CAACC,SAAS,CAAC,SAAS,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MACvDF,MAAM,CAACG,cAAM,CAACC,SAAS,CAAC,OAAO,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACvD,CAAC,CAAC;IAEFP,EAAE,CAAC,8CAA8C,EAAE,YAAM;MACvD,IAAAU,QAAA,GAAsB,IAAAR,cAAM,eAAChD,KAAA,CAAAiD,aAAA,CAAC1C,MAAA,WAAO,MAAAkD,SAAA,iBAAKjB,YAAY;UAAEC,QAAQ,EAAE;QAAK,EAAE,CAAC,CAAC;QAAnES,SAAS,GAAAM,QAAA,CAATN,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;IAEFP,EAAE,CAAC,4BAA4B,EAAE,YAAM;MACrC,IAAAY,QAAA,GAAsB,IAAAV,cAAM,eAAChD,KAAA,CAAAiD,aAAA,CAAC1C,MAAA,WAAO,MAAAkD,SAAA,iBAAKjB,YAAY;UAAEmB,UAAU,EAAEC,SAAU;UAACC,KAAK,EAAE;YAAE,CAAC,EAAE,GAAG;YAAE,CAAC,EAAE;UAAI;QAAE,EAAE,CAAC,CAAC;QAArGX,SAAS,GAAAQ,QAAA,CAATR,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;IAEFP,EAAE,CAAC,yBAAyB,EAAE,YAAM;MAClC,IAAAgB,QAAA,GAAsB,IAAAd,cAAM,eAAChD,KAAA,CAAAiD,aAAA,CAAC1C,MAAA,WAAO,MAAAkD,SAAA,iBAAKjB,YAAY;UAAEmB,UAAU,EAAE,IAAK;UAACE,KAAK,EAAE;YAAE,CAAC,EAAE,GAAG;YAAE,CAAC,EAAE;UAAI;QAAE,EAAE,CAAC,CAAC;QAAhGX,SAAS,GAAAY,QAAA,CAATZ,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFd,QAAQ,CAAC,QAAQ,EAAE,YAAM;IACvB,IAAMC,YAAY,GAAG;MACnBC,QAAQ,EAAE,KAAK;MACfE,MAAM,EAAE,IAAAA,aAAM,EAAC,OAAO,EAAE,GAAG,CAAC;MAC5BE,UAAU,EAAE;IACd,CAAC;IAEDN,QAAQ,CAAC,QAAQ,EAAE,YAAM;MACvBO,EAAE,CAAC,sCAAsC,EAAE,YAAM;QAC/C,IAAAiB,QAAA,GAAsB,IAAAf,cAAM,eAAChD,KAAA,CAAAiD,aAAA,CAAC7C,OAAA,WAAM,EAAKoC,YAAe,CAAC,CAAC;UAAlDU,SAAS,GAAAa,QAAA,CAATb,SAAS;QACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;QAChDF,MAAM,CAACG,cAAM,CAACC,SAAS,CAAC,OAAO,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MACvD,CAAC,CAAC;MAEFP,EAAE,CAAC,8CAA8C,EAAE,YAAM;QACvD,IAAAkB,QAAA,GAAsB,IAAAhB,cAAM,eAAChD,KAAA,CAAAiD,aAAA,CAAC7C,OAAA,WAAM,MAAAqD,SAAA,iBAAKjB,YAAY;YAAEC,QAAQ,EAAE;UAAK,EAAE,CAAC,CAAC;UAAlES,SAAS,GAAAc,QAAA,CAATd,SAAS;QACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;MAClD,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|
package/lib/choices/choice.js
CHANGED
|
@@ -113,4 +113,4 @@ Choice.propTypes = {
|
|
|
113
113
|
disabled: _propTypes["default"].bool,
|
|
114
114
|
instanceId: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number])
|
|
115
115
|
};
|
|
116
|
-
//# sourceMappingURL=choice.js.map
|
|
116
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_core","_styles","_Chip","_mathRendering","_renderUi","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","DRAG_TYPE","exports","StyledChoice","styled","_ref","theme","disabled","border","concat","palette","primary","main","borderRadius","spacing","margin","transform","display","StyledChip","Chip","backgroundColor","color","white","text","alignItems","height","minHeight","fontSize","whiteSpace","maxWidth","pointerEvents","paddingTop","paddingBottom","opacity","StyledChipLabel","padding","Choice","_ref2","_rootRef$current","_rootRef$current2","choice","instanceId","rootRef","useRef","_useDraggable","useDraggable","id","data","fromChoice","type","attributes","listeners","setNodeRef","isDragging","useEffect","renderMath","current","value","createElement","_extends2","ref","style","width","offsetWidth","offsetHeight","clickable","label","dangerouslySetInnerHTML","__html","propTypes","PropTypes","object","isRequired","bool","oneOfType","string","number"],"sources":["../../src/choices/choice.jsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { useDraggable } from '@dnd-kit/core';\nimport { styled } from '@mui/material/styles';\nimport Chip from '@mui/material/Chip';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { color } from '@pie-lib/render-ui';\n\nexport const DRAG_TYPE = 'MaskBlank';\n\nconst StyledChoice = styled('span')(({ theme, disabled }) => ({\n  border: `solid 0px ${theme.palette.primary.main}`,\n  borderRadius: theme.spacing(2),\n  margin: theme.spacing(0.5),\n  transform: 'translate(0, 0)',\n  display: 'inline-flex',\n  ...(disabled && {}),\n}));\n\nconst StyledChip = styled(Chip)(() => ({\n  backgroundColor: color.white(),\n  border: `1px solid ${color.text()}`,\n  color: color.text(),\n  alignItems: 'center',\n  display: 'inline-flex',\n  height: 'initial',\n  minHeight: '32px',\n  fontSize: 'inherit',\n  whiteSpace: 'pre-wrap',\n  maxWidth: '374px',\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  borderRadius: '3px',\n  paddingTop: '12px',\n  paddingBottom: '12px',\n\n  '&.Mui-disabled': {\n    opacity: 1,\n  },\n}));\n\nconst StyledChipLabel = styled('span')(() => ({\n  whiteSpace: 'normal',\n  '& img': {\n    display: 'block',\n    padding: '2px 0',\n  },\n  '& mjx-frac': {\n    fontSize: '120% !important',\n  },\n}));\n\nexport default function Choice({ choice, disabled, instanceId }) {\n  const rootRef = useRef(null);\n\n  const { attributes, listeners, setNodeRef, isDragging } = useDraggable({\n    id: `choice-${choice.id}`,\n    data: { choice, instanceId, fromChoice: true, type: DRAG_TYPE },\n    disabled,\n  });\n\n  useEffect(() => {\n    renderMath(rootRef.current);\n  }, [choice.value]);\n\n  return (\n    <StyledChoice\n      ref={setNodeRef}\n      style={\n        isDragging\n          ? {\n              width: rootRef.current?.offsetWidth,\n              height: rootRef.current?.offsetHeight,\n            }\n          : {}\n      }\n      disabled={disabled}\n      {...listeners}\n      {...attributes}\n    >\n      <StyledChip\n        clickable={false}\n        disabled={disabled}\n        ref={rootRef}\n        label={<StyledChipLabel dangerouslySetInnerHTML={{ __html: choice.value }} />}\n      />\n    </StyledChoice>\n  );\n}\n\nChoice.propTypes = {\n  choice: PropTypes.object.isRequired,\n  disabled: PropTypes.bool,\n  instanceId: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n};\n"],"mappings":"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","ignoreList":[]}
|
package/lib/choices/index.js
CHANGED
|
@@ -100,4 +100,4 @@ var Choices = exports["default"] = /*#__PURE__*/function (_React$Component) {
|
|
|
100
100
|
choicePosition: _propTypes["default"].string.isRequired,
|
|
101
101
|
instanceId: _propTypes["default"].string // Added for drag isolation
|
|
102
102
|
});
|
|
103
|
-
//# sourceMappingURL=
|
|
103
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_propTypes","_findKey","_choice","_drag","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","Choices","exports","_React$Component","_this","_classCallCheck2","_len","args","Array","_key","concat","choicePosition","props","margin","_inherits2","_createClass2","key","value","render","_this$props","disabled","duplicates","choices","instanceId","filteredChoices","c","foundChoice","findKey","v","id","undefined","elementStyle","getStyleForWrapper","minWidth","createElement","style","DragDroppablePlaceholder","map","index","choice","React","Component","PropTypes","bool","arrayOf","shape","label","string","object","isRequired"],"sources":["../../src/choices/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport findKey from 'lodash/findKey';\nimport Choice from './choice';\nimport { DragDroppablePlaceholder } from '@pie-lib/drag';\n\nexport default class Choices extends React.Component {\n  static propTypes = {\n    disabled: PropTypes.bool,\n    duplicates: PropTypes.bool,\n    choices: PropTypes.arrayOf(PropTypes.shape({ label: PropTypes.string, value: PropTypes.string })),\n    value: PropTypes.object,\n    choicePosition: PropTypes.string.isRequired,\n    instanceId: PropTypes.string, // Added for drag isolation\n  };\n\n  getStyleForWrapper = () => {\n    const { choicePosition } = this.props;\n\n    switch (choicePosition) {\n      case 'above':\n        return {\n          margin: '0 0 40px 0',\n        };\n\n      case 'below':\n        return {\n          margin: '40px 0 0 0',\n        };\n\n      case 'right':\n        return {\n          margin: '0 0 0 40px',\n        };\n\n      default:\n        return {\n          margin: '0 40px 0 0',\n        };\n    }\n  };\n\n  render() {\n    const { disabled, duplicates, choices, value, instanceId } = this.props;\n    const filteredChoices = choices.filter((c) => {\n      if (duplicates === true) {\n        return true;\n      }\n      const foundChoice = findKey(value, (v) => v === c.id);\n      return foundChoice === undefined;\n    });\n    const elementStyle = { ...this.getStyleForWrapper(), minWidth: '100px' };\n\n    return (\n      <div style={elementStyle}>\n        <DragDroppablePlaceholder disabled={disabled} instanceId={instanceId}>\n          {filteredChoices.map((c, index) => (\n            <Choice \n              key={`${c.value}-${index}`} \n              disabled={disabled} \n              choice={c} \n              instanceId={instanceId}\n            />\n          ))}\n        </DragDroppablePlaceholder>\n      </div>\n    );\n  }\n}\n"],"mappings":"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","ignoreList":[]}
|
package/lib/componentize.js
CHANGED
|
@@ -18,4 +18,4 @@ var _default = exports["default"] = function _default(s, t) {
|
|
|
18
18
|
markup: markup
|
|
19
19
|
};
|
|
20
20
|
};
|
|
21
|
-
//# sourceMappingURL=
|
|
21
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUdFWCIsIl9kZWZhdWx0IiwiZXhwb3J0cyIsInMiLCJ0IiwibWFya3VwIiwicmVwbGFjZSIsIm1hdGNoIiwiZyIsImNvbmNhdCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9jb21wb25lbnRpemUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgUkVHRVggPSAvXFx7XFx7KFxcZCspXFx9XFx9L2c7XG5cbmV4cG9ydCBkZWZhdWx0IChzLCB0KSA9PiB7XG4gIGlmICghcykge1xuICAgIHJldHVybiB7IG1hcmt1cDogJycgfTtcbiAgfVxuXG4gIGNvbnN0IG1hcmt1cCA9IHMucmVwbGFjZShSRUdFWCwgKG1hdGNoLCBnKSA9PiB7XG4gICAgcmV0dXJuIGA8c3BhbiBkYXRhLWNvbXBvbmVudD1cIiR7dH1cIiBkYXRhLWlkPVwiJHtnfVwiPjwvc3Bhbj5gO1xuICB9KTtcblxuICByZXR1cm4geyBtYXJrdXAgfTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQU1BLEtBQUssR0FBRyxnQkFBZ0I7QUFBQyxJQUFBQyxRQUFBLEdBQUFDLE9BQUEsY0FFaEIsU0FBQUQsU0FBQ0UsQ0FBQyxFQUFFQyxDQUFDLEVBQUs7RUFDdkIsSUFBSSxDQUFDRCxDQUFDLEVBQUU7SUFDTixPQUFPO01BQUVFLE1BQU0sRUFBRTtJQUFHLENBQUM7RUFDdkI7RUFFQSxJQUFNQSxNQUFNLEdBQUdGLENBQUMsQ0FBQ0csT0FBTyxDQUFDTixLQUFLLEVBQUUsVUFBQ08sS0FBSyxFQUFFQyxDQUFDLEVBQUs7SUFDNUMsaUNBQUFDLE1BQUEsQ0FBZ0NMLENBQUMsbUJBQUFLLE1BQUEsQ0FBY0QsQ0FBQztFQUNsRCxDQUFDLENBQUM7RUFFRixPQUFPO0lBQUVILE1BQU0sRUFBTkE7RUFBTyxDQUFDO0FBQ25CLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
6
|
+
var React = _interopRequireWildcard(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
9
|
+
var _blank = _interopRequireDefault(require("../blank"));
|
|
10
|
+
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); }
|
|
11
|
+
// Mock @dnd-kit hooks to avoid DndContext requirement
|
|
12
|
+
jest.mock('@dnd-kit/core', function () {
|
|
13
|
+
return {
|
|
14
|
+
useDraggable: jest.fn(function () {
|
|
15
|
+
return {
|
|
16
|
+
attributes: {},
|
|
17
|
+
listeners: {},
|
|
18
|
+
setNodeRef: jest.fn(),
|
|
19
|
+
transform: null,
|
|
20
|
+
isDragging: false
|
|
21
|
+
};
|
|
22
|
+
}),
|
|
23
|
+
useDroppable: jest.fn(function () {
|
|
24
|
+
return {
|
|
25
|
+
setNodeRef: jest.fn(),
|
|
26
|
+
isOver: false,
|
|
27
|
+
active: null
|
|
28
|
+
};
|
|
29
|
+
})
|
|
30
|
+
};
|
|
31
|
+
});
|
|
32
|
+
jest.mock('@dnd-kit/utilities', function () {
|
|
33
|
+
return {
|
|
34
|
+
CSS: {
|
|
35
|
+
Translate: {
|
|
36
|
+
toString: jest.fn(function () {
|
|
37
|
+
return 'translate3d(0, 0, 0)';
|
|
38
|
+
})
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
});
|
|
43
|
+
describe('Blank', function () {
|
|
44
|
+
var onChange = jest.fn();
|
|
45
|
+
var defaultProps = {
|
|
46
|
+
disabled: false,
|
|
47
|
+
choice: {
|
|
48
|
+
value: 'Cow'
|
|
49
|
+
},
|
|
50
|
+
isOver: false,
|
|
51
|
+
dragItem: {},
|
|
52
|
+
correct: false,
|
|
53
|
+
onChange: onChange
|
|
54
|
+
};
|
|
55
|
+
beforeEach(function () {
|
|
56
|
+
onChange.mockClear();
|
|
57
|
+
});
|
|
58
|
+
describe('rendering', function () {
|
|
59
|
+
it('renders with default props', function () {
|
|
60
|
+
var _render = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], defaultProps)),
|
|
61
|
+
container = _render.container;
|
|
62
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
63
|
+
});
|
|
64
|
+
it('displays the value when provided', function () {
|
|
65
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], defaultProps));
|
|
66
|
+
expect(_react2.screen.getByText('Cow')).toBeInTheDocument();
|
|
67
|
+
});
|
|
68
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
69
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
70
|
+
disabled: true
|
|
71
|
+
})));
|
|
72
|
+
// Check that delete button is not present when disabled
|
|
73
|
+
expect(_react2.screen.queryByRole('button', {
|
|
74
|
+
name: /delete/i
|
|
75
|
+
})).not.toBeInTheDocument();
|
|
76
|
+
});
|
|
77
|
+
it('renders with dragged item preview', function () {
|
|
78
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
79
|
+
dragItem: {
|
|
80
|
+
choice: {
|
|
81
|
+
value: 'Dog'
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
})));
|
|
85
|
+
// Blank component should render
|
|
86
|
+
expect(_react2.screen.getByText('Cow')).toBeInTheDocument();
|
|
87
|
+
});
|
|
88
|
+
it('shows hover state when isOver is true', function () {
|
|
89
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
90
|
+
dragItem: {
|
|
91
|
+
choice: {
|
|
92
|
+
value: 'Dog'
|
|
93
|
+
}
|
|
94
|
+
},
|
|
95
|
+
isOver: true
|
|
96
|
+
}))),
|
|
97
|
+
container = _render2.container;
|
|
98
|
+
// Component should have hover styling
|
|
99
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
100
|
+
});
|
|
101
|
+
it('shows correct state when correct is true', function () {
|
|
102
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
103
|
+
correct: true
|
|
104
|
+
}))),
|
|
105
|
+
container = _render3.container;
|
|
106
|
+
// Component should indicate correctness
|
|
107
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
describe('delete functionality', function () {
|
|
111
|
+
it('does not show delete button when disabled', function () {
|
|
112
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
113
|
+
disabled: true
|
|
114
|
+
})));
|
|
115
|
+
expect(_react2.screen.queryByRole('button', {
|
|
116
|
+
name: /delete/i
|
|
117
|
+
})).not.toBeInTheDocument();
|
|
118
|
+
});
|
|
119
|
+
it('does not show delete button when no value is set', function () {
|
|
120
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
121
|
+
choice: undefined
|
|
122
|
+
})));
|
|
123
|
+
expect(_react2.screen.queryByRole('button', {
|
|
124
|
+
name: /delete/i
|
|
125
|
+
})).not.toBeInTheDocument();
|
|
126
|
+
});
|
|
127
|
+
it('shows delete button when value is present and not disabled', function () {
|
|
128
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], defaultProps));
|
|
129
|
+
// If delete button is present, it should be clickable
|
|
130
|
+
var deleteButton = _react2.screen.queryByRole('button');
|
|
131
|
+
if (deleteButton) {
|
|
132
|
+
expect(deleteButton).toBeInTheDocument();
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
describe('dimensions', function () {
|
|
137
|
+
it('renders with custom dimensions when provided', function () {
|
|
138
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
139
|
+
emptyResponseAreaHeight: 100,
|
|
140
|
+
emptyResponseAreaWidth: 200
|
|
141
|
+
}))),
|
|
142
|
+
container = _render4.container;
|
|
143
|
+
var element = container.firstChild;
|
|
144
|
+
expect(element).toBeInTheDocument();
|
|
145
|
+
});
|
|
146
|
+
it('renders with min dimensions by default', function () {
|
|
147
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], defaultProps)),
|
|
148
|
+
container = _render5.container;
|
|
149
|
+
var element = container.firstChild;
|
|
150
|
+
expect(element).toBeInTheDocument();
|
|
151
|
+
// Component should have minimum dimensions applied
|
|
152
|
+
});
|
|
153
|
+
it('handles non-numeric dimension props gracefully', function () {
|
|
154
|
+
var _render6 = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
155
|
+
emptyResponseAreaHeight: "non-numeric",
|
|
156
|
+
emptyResponseAreaWidth: "non-numeric"
|
|
157
|
+
}))),
|
|
158
|
+
container = _render6.container;
|
|
159
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
describe('drag and drop', function () {
|
|
163
|
+
it('accepts drag item when not disabled', function () {
|
|
164
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
165
|
+
isOver: true,
|
|
166
|
+
dragItem: {
|
|
167
|
+
choice: {
|
|
168
|
+
value: 'Dog'
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
})));
|
|
172
|
+
expect(_react2.screen.getByText('Cow')).toBeInTheDocument();
|
|
173
|
+
});
|
|
174
|
+
it('shows drag preview when dragging over', function () {
|
|
175
|
+
var _render7 = (0, _react2.render)(/*#__PURE__*/React.createElement(_blank["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
176
|
+
isOver: true,
|
|
177
|
+
dragItem: {
|
|
178
|
+
choice: {
|
|
179
|
+
value: 'Dog'
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}))),
|
|
183
|
+
container = _render7.container;
|
|
184
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
185
|
+
// Should show visual feedback for drag over
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
});
|
|
189
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_blank","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","jest","mock","useDraggable","fn","attributes","listeners","setNodeRef","transform","isDragging","useDroppable","isOver","active","CSS","Translate","toString","describe","onChange","defaultProps","disabled","choice","value","dragItem","correct","beforeEach","mockClear","it","_render","render","createElement","container","expect","firstChild","toBeInTheDocument","screen","getByText","_extends2","queryByRole","name","not","_render2","_render3","undefined","deleteButton","_render4","emptyResponseAreaHeight","emptyResponseAreaWidth","element","_render5","_render6","_render7"],"sources":["../../../src/components/__tests__/blank.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport Blank from '../blank';\n\n// Mock @dnd-kit hooks to avoid DndContext requirement\njest.mock('@dnd-kit/core', () => ({\n  useDraggable: jest.fn(() => ({\n    attributes: {},\n    listeners: {},\n    setNodeRef: jest.fn(),\n    transform: null,\n    isDragging: false,\n  })),\n  useDroppable: jest.fn(() => ({\n    setNodeRef: jest.fn(),\n    isOver: false,\n    active: null,\n  })),\n}));\n\njest.mock('@dnd-kit/utilities', () => ({\n  CSS: {\n    Translate: {\n      toString: jest.fn(() => 'translate3d(0, 0, 0)'),\n    },\n  },\n}));\n\ndescribe('Blank', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    disabled: false,\n    choice: { value: 'Cow' },\n    isOver: false,\n    dragItem: {},\n    correct: false,\n    onChange,\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders with default props', () => {\n      const { container } = render(<Blank {...defaultProps} />);\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('displays the value when provided', () => {\n      render(<Blank {...defaultProps} />);\n      expect(screen.getByText('Cow')).toBeInTheDocument();\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<Blank {...defaultProps} disabled={true} />);\n      // Check that delete button is not present when disabled\n      expect(screen.queryByRole('button', { name: /delete/i })).not.toBeInTheDocument();\n    });\n\n    it('renders with dragged item preview', () => {\n      render(<Blank {...defaultProps} dragItem={{ choice: { value: 'Dog' } }} />);\n      // Blank component should render\n      expect(screen.getByText('Cow')).toBeInTheDocument();\n    });\n\n    it('shows hover state when isOver is true', () => {\n      const { container } = render(<Blank {...defaultProps} dragItem={{ choice: { value: 'Dog' } }} isOver={true} />);\n      // Component should have hover styling\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('shows correct state when correct is true', () => {\n      const { container } = render(<Blank {...defaultProps} correct={true} />);\n      // Component should indicate correctness\n      expect(container.firstChild).toBeInTheDocument();\n    });\n  });\n\n  describe('delete functionality', () => {\n    it('does not show delete button when disabled', () => {\n      render(<Blank {...defaultProps} disabled={true} />);\n      expect(screen.queryByRole('button', { name: /delete/i })).not.toBeInTheDocument();\n    });\n\n    it('does not show delete button when no value is set', () => {\n      render(<Blank {...defaultProps} choice={undefined} />);\n      expect(screen.queryByRole('button', { name: /delete/i })).not.toBeInTheDocument();\n    });\n\n    it('shows delete button when value is present and not disabled', () => {\n      render(<Blank {...defaultProps} />);\n      // If delete button is present, it should be clickable\n      const deleteButton = screen.queryByRole('button');\n      if (deleteButton) {\n        expect(deleteButton).toBeInTheDocument();\n      }\n    });\n  });\n\n  describe('dimensions', () => {\n    it('renders with custom dimensions when provided', () => {\n      const { container } = render(\n        <Blank {...defaultProps} emptyResponseAreaHeight={100} emptyResponseAreaWidth={200} />,\n      );\n      const element = container.firstChild;\n      expect(element).toBeInTheDocument();\n    });\n\n    it('renders with min dimensions by default', () => {\n      const { container } = render(<Blank {...defaultProps} />);\n      const element = container.firstChild;\n      expect(element).toBeInTheDocument();\n      // Component should have minimum dimensions applied\n    });\n\n    it('handles non-numeric dimension props gracefully', () => {\n      const { container } = render(\n        <Blank {...defaultProps} emptyResponseAreaHeight=\"non-numeric\" emptyResponseAreaWidth=\"non-numeric\" />,\n      );\n      expect(container.firstChild).toBeInTheDocument();\n    });\n  });\n\n  describe('drag and drop', () => {\n    it('accepts drag item when not disabled', () => {\n      render(<Blank {...defaultProps} isOver={true} dragItem={{ choice: { value: 'Dog' } }} />);\n      expect(screen.getByText('Cow')).toBeInTheDocument();\n    });\n\n    it('shows drag preview when dragging over', () => {\n      const { container } = render(<Blank {...defaultProps} isOver={true} dragItem={{ choice: { value: 'Dog' } }} />);\n      expect(container.firstChild).toBeInTheDocument();\n      // Should show visual feedback for drag over\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,132 @@
|
|
|
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 _correctInput = _interopRequireDefault(require("../correct-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
|
+
describe('CorrectInput', function () {
|
|
14
|
+
var onChange = jest.fn();
|
|
15
|
+
var defaultProps = {
|
|
16
|
+
disabled: false,
|
|
17
|
+
correct: false,
|
|
18
|
+
variant: 'outlined',
|
|
19
|
+
value: 'Cow',
|
|
20
|
+
onChange: onChange
|
|
21
|
+
};
|
|
22
|
+
beforeEach(function () {
|
|
23
|
+
onChange.mockClear();
|
|
24
|
+
});
|
|
25
|
+
describe('rendering', function () {
|
|
26
|
+
it('renders input with default props', function () {
|
|
27
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
|
|
28
|
+
var input = _react2.screen.getByRole('textbox');
|
|
29
|
+
expect(input).toBeInTheDocument();
|
|
30
|
+
expect(input).toHaveValue('Cow');
|
|
31
|
+
});
|
|
32
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
33
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
34
|
+
disabled: true
|
|
35
|
+
})));
|
|
36
|
+
var input = _react2.screen.getByRole('textbox');
|
|
37
|
+
expect(input).toBeDisabled();
|
|
38
|
+
});
|
|
39
|
+
it('renders with correct state as false', function () {
|
|
40
|
+
var _render = (0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
41
|
+
correct: false
|
|
42
|
+
}))),
|
|
43
|
+
container = _render.container;
|
|
44
|
+
var input = _react2.screen.getByRole('textbox');
|
|
45
|
+
expect(input).toBeInTheDocument();
|
|
46
|
+
});
|
|
47
|
+
it('renders with correct state as true', function () {
|
|
48
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
49
|
+
correct: true
|
|
50
|
+
}))),
|
|
51
|
+
container = _render2.container;
|
|
52
|
+
var input = _react2.screen.getByRole('textbox');
|
|
53
|
+
expect(input).toBeInTheDocument();
|
|
54
|
+
// Should show visual indication of correctness
|
|
55
|
+
});
|
|
56
|
+
it('renders with outlined variant', function () {
|
|
57
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
58
|
+
variant: "outlined"
|
|
59
|
+
})));
|
|
60
|
+
var input = _react2.screen.getByRole('textbox');
|
|
61
|
+
expect(input).toBeInTheDocument();
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
describe('user interactions', function () {
|
|
65
|
+
it('calls onChange when user types', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
66
|
+
var user, input;
|
|
67
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
68
|
+
while (1) switch (_context.prev = _context.next) {
|
|
69
|
+
case 0:
|
|
70
|
+
user = _userEvent["default"].setup();
|
|
71
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
|
|
72
|
+
input = _react2.screen.getByRole('textbox');
|
|
73
|
+
_context.next = 1;
|
|
74
|
+
return user.clear(input);
|
|
75
|
+
case 1:
|
|
76
|
+
_context.next = 2;
|
|
77
|
+
return user.type(input, '1');
|
|
78
|
+
case 2:
|
|
79
|
+
expect(onChange).toHaveBeenCalled();
|
|
80
|
+
case 3:
|
|
81
|
+
case "end":
|
|
82
|
+
return _context.stop();
|
|
83
|
+
}
|
|
84
|
+
}, _callee);
|
|
85
|
+
})));
|
|
86
|
+
it('calls onChange with event object', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
87
|
+
var user, input, lastCall;
|
|
88
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
89
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
90
|
+
case 0:
|
|
91
|
+
user = _userEvent["default"].setup();
|
|
92
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
93
|
+
value: ""
|
|
94
|
+
})));
|
|
95
|
+
input = _react2.screen.getByRole('textbox');
|
|
96
|
+
_context2.next = 1;
|
|
97
|
+
return user.type(input, 'test');
|
|
98
|
+
case 1:
|
|
99
|
+
expect(onChange).toHaveBeenCalled();
|
|
100
|
+
// Check that onChange receives an event-like object
|
|
101
|
+
lastCall = onChange.mock.calls[onChange.mock.calls.length - 1][0];
|
|
102
|
+
expect(lastCall).toHaveProperty('target');
|
|
103
|
+
case 2:
|
|
104
|
+
case "end":
|
|
105
|
+
return _context2.stop();
|
|
106
|
+
}
|
|
107
|
+
}, _callee2);
|
|
108
|
+
})));
|
|
109
|
+
it('updates value when user changes input', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
110
|
+
var user, input;
|
|
111
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
112
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
113
|
+
case 0:
|
|
114
|
+
user = _userEvent["default"].setup();
|
|
115
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
|
|
116
|
+
input = _react2.screen.getByRole('textbox');
|
|
117
|
+
_context3.next = 1;
|
|
118
|
+
return user.clear(input);
|
|
119
|
+
case 1:
|
|
120
|
+
_context3.next = 2;
|
|
121
|
+
return user.type(input, 'Dog');
|
|
122
|
+
case 2:
|
|
123
|
+
expect(onChange).toHaveBeenCalled();
|
|
124
|
+
case 3:
|
|
125
|
+
case "end":
|
|
126
|
+
return _context3.stop();
|
|
127
|
+
}
|
|
128
|
+
}, _callee3);
|
|
129
|
+
})));
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_correctInput","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","disabled","correct","variant","value","beforeEach","mockClear","it","render","createElement","input","screen","getByRole","expect","toBeInTheDocument","toHaveValue","_extends2","toBeDisabled","_render","container","_render2","_asyncToGenerator2","_regenerator","mark","_callee","user","wrap","_context","prev","next","userEvent","setup","clear","type","toHaveBeenCalled","stop","_callee2","lastCall","_context2","mock","calls","length","toHaveProperty","_callee3","_context3"],"sources":["../../../src/components/__tests__/correct-input.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport CorrectInput from '../correct-input';\n\ndescribe('CorrectInput', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    disabled: false,\n    correct: false,\n    variant: 'outlined',\n    value: 'Cow',\n    onChange,\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders input with default props', () => {\n      render(<CorrectInput {...defaultProps} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n      expect(input).toHaveValue('Cow');\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<CorrectInput {...defaultProps} disabled={true} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeDisabled();\n    });\n\n    it('renders with correct state as false', () => {\n      const { container } = render(<CorrectInput {...defaultProps} correct={false} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n    });\n\n    it('renders with correct state as true', () => {\n      const { container } = render(<CorrectInput {...defaultProps} correct={true} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n      // Should show visual indication of correctness\n    });\n\n    it('renders with outlined variant', () => {\n      render(<CorrectInput {...defaultProps} variant=\"outlined\" />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange when user types', async () => {\n      const user = userEvent.setup();\n      render(<CorrectInput {...defaultProps} />);\n\n      const input = screen.getByRole('textbox');\n      await user.clear(input);\n      await user.type(input, '1');\n\n      expect(onChange).toHaveBeenCalled();\n    });\n\n    it('calls onChange with event object', async () => {\n      const user = userEvent.setup();\n      render(<CorrectInput {...defaultProps} value=\"\" />);\n\n      const input = screen.getByRole('textbox');\n      await user.type(input, 'test');\n\n      expect(onChange).toHaveBeenCalled();\n      // Check that onChange receives an event-like object\n      const lastCall = onChange.mock.calls[onChange.mock.calls.length - 1][0];\n      expect(lastCall).toHaveProperty('target');\n    });\n\n    it('updates value when user changes input', async () => {\n      const user = userEvent.setup();\n      render(<CorrectInput {...defaultProps} />);\n\n      const input = screen.getByRole('textbox');\n      await user.clear(input);\n      await user.type(input, 'Dog');\n\n      expect(onChange).toHaveBeenCalled();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|