@pie-element/categorize 11.3.4-next.3 → 12.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +0 -11
- package/configure/CHANGELOG.md +0 -11
- package/configure/lib/__tests__/main.test.js +100 -0
- package/configure/lib/__tests__/utils.js +39 -0
- package/configure/lib/defaults.js +3 -6
- package/configure/lib/defaults.js.map +1 -1
- package/configure/lib/design/__tests__/builder.test.js +34 -0
- package/configure/lib/design/__tests__/buttons.test.js +36 -0
- package/configure/lib/design/__tests__/header.test.js +37 -0
- package/configure/lib/design/__tests__/index.test.js +125 -0
- package/configure/lib/design/__tests__/input-header.test.js +41 -0
- package/configure/lib/design/builder.js +16 -34
- package/configure/lib/design/builder.js.map +1 -1
- package/configure/lib/design/buttons.js +42 -96
- package/configure/lib/design/buttons.js.map +1 -1
- package/configure/lib/design/categories/RowLabel.js +34 -47
- package/configure/lib/design/categories/RowLabel.js.map +1 -1
- package/configure/lib/design/categories/__tests__/alternateResponses.test.js +93 -0
- package/configure/lib/design/categories/__tests__/category.test.js +65 -0
- package/configure/lib/design/categories/__tests__/choice-preview.test.js +52 -0
- package/configure/lib/design/categories/__tests__/droppable-placeholder.test.js +63 -0
- package/configure/lib/design/categories/__tests__/index.test.js +91 -0
- package/configure/lib/design/categories/alternateResponses.js +97 -252
- package/configure/lib/design/categories/alternateResponses.js.map +1 -1
- package/configure/lib/design/categories/category.js +136 -209
- package/configure/lib/design/categories/category.js.map +1 -1
- package/configure/lib/design/categories/choice-preview.js +62 -127
- package/configure/lib/design/categories/choice-preview.js.map +1 -1
- package/configure/lib/design/categories/droppable-placeholder.js +74 -166
- package/configure/lib/design/categories/droppable-placeholder.js.map +1 -1
- package/configure/lib/design/categories/index.js +196 -385
- package/configure/lib/design/categories/index.js.map +1 -1
- package/configure/lib/design/choices/__tests__/choice.test.js +62 -0
- package/configure/lib/design/choices/__tests__/config.test.js +66 -0
- package/configure/lib/design/choices/__tests__/index.test.js +70 -0
- package/configure/lib/design/choices/choice.js +156 -265
- package/configure/lib/design/choices/choice.js.map +1 -1
- package/configure/lib/design/choices/config.js +43 -99
- package/configure/lib/design/choices/config.js.map +1 -1
- package/configure/lib/design/choices/index.js +149 -237
- package/configure/lib/design/choices/index.js.map +1 -1
- package/configure/lib/design/header.js +58 -112
- package/configure/lib/design/header.js.map +1 -1
- package/configure/lib/design/index.js +633 -478
- package/configure/lib/design/index.js.map +1 -1
- package/configure/lib/design/input-header.js +95 -151
- package/configure/lib/design/input-header.js.map +1 -1
- package/configure/lib/design/utils.js +5 -16
- package/configure/lib/design/utils.js.map +1 -1
- package/configure/lib/index.js +121 -184
- package/configure/lib/index.js.map +1 -1
- package/configure/lib/main.js +31 -75
- package/configure/lib/main.js.map +1 -1
- package/configure/lib/utils.js +23 -33
- package/configure/lib/utils.js.map +1 -1
- package/configure/package.json +15 -15
- package/controller/CHANGELOG.md +0 -11
- package/controller/lib/__tests__/index.test.js +526 -0
- package/controller/lib/defaults.js +3 -6
- package/controller/lib/defaults.js.map +1 -1
- package/controller/lib/index.js +238 -319
- package/controller/lib/index.js.map +1 -1
- package/controller/lib/utils.js +29 -66
- package/controller/lib/utils.js.map +1 -1
- package/controller/package.json +5 -5
- package/docs/demo/.pie/.configure/package.json +10 -0
- package/docs/demo/.pie/.configure/yarn.lock +2181 -0
- package/docs/demo/.pie/.controllers/package.json +10 -0
- package/docs/demo/.pie/.controllers/yarn.lock +110 -0
- package/docs/demo/.pie/info.entry.js +89 -0
- package/docs/demo/.pie/info.webpack.config.js +119 -0
- package/docs/demo/.pie/package.json +10 -0
- package/docs/demo/.pie/yarn.lock +2190 -0
- package/docs/demo/pie.manifest.json +11 -0
- package/lib/__tests__/index.test.js +197 -0
- package/lib/categorize/__tests__/categories.test.js +138 -0
- package/lib/categorize/__tests__/category.test.js +137 -0
- package/lib/categorize/__tests__/choice.test.js +88 -0
- package/lib/categorize/__tests__/choices.test.js +118 -0
- package/lib/categorize/__tests__/droppable-placeholder.test.js +96 -0
- package/lib/categorize/__tests__/grid-content.test.js +48 -0
- package/lib/categorize/__tests__/index.test.js +152 -0
- package/lib/categorize/categories.js +107 -165
- package/lib/categorize/categories.js.map +1 -1
- package/lib/categorize/category.js +74 -124
- package/lib/categorize/category.js.map +1 -1
- package/lib/categorize/choice.js +119 -246
- package/lib/categorize/choice.js.map +1 -1
- package/lib/categorize/choices.js +67 -132
- package/lib/categorize/choices.js.map +1 -1
- package/lib/categorize/droppable-placeholder.js +47 -104
- package/lib/categorize/droppable-placeholder.js.map +1 -1
- package/lib/categorize/grid-content.js +40 -88
- package/lib/categorize/grid-content.js.map +1 -1
- package/lib/categorize/index.js +342 -318
- package/lib/categorize/index.js.map +1 -1
- package/lib/index.js +286 -307
- package/lib/index.js.map +1 -1
- package/package.json +16 -14
- package/esm/configure.js +0 -34401
- package/esm/configure.js.map +0 -1
- package/esm/controller.js +0 -1468
- package/esm/controller.js.map +0 -1
- package/esm/element.js +0 -13134
- package/esm/element.js.map +0 -1
- package/esm/package.json +0 -3
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _styles = require("@mui/material/styles");
|
|
7
|
+
var _choices = require("../choices");
|
|
8
|
+
jest.mock('../choice', () => ({
|
|
9
|
+
__esModule: true,
|
|
10
|
+
default: ({
|
|
11
|
+
label,
|
|
12
|
+
id
|
|
13
|
+
}) => /*#__PURE__*/_react.default.createElement("div", {
|
|
14
|
+
"data-testid": `choice-${id}`
|
|
15
|
+
}, label),
|
|
16
|
+
ChoiceType: {}
|
|
17
|
+
}));
|
|
18
|
+
jest.mock('@pie-lib/drag', () => ({
|
|
19
|
+
DraggableChoice: props => /*#__PURE__*/_react.default.createElement("div", props),
|
|
20
|
+
PlaceHolder: ({
|
|
21
|
+
children
|
|
22
|
+
}) => /*#__PURE__*/_react.default.createElement("div", null, children),
|
|
23
|
+
uid: {
|
|
24
|
+
withUid: jest.fn(input => input),
|
|
25
|
+
generateUid: jest.fn().mockReturnValue('1')
|
|
26
|
+
}
|
|
27
|
+
}));
|
|
28
|
+
const theme = (0, _styles.createTheme)();
|
|
29
|
+
describe('Choices', () => {
|
|
30
|
+
const renderChoices = extras => {
|
|
31
|
+
const defaults = {
|
|
32
|
+
classes: {},
|
|
33
|
+
choices: [],
|
|
34
|
+
onDropChoice: jest.fn(),
|
|
35
|
+
onRemoveChoice: jest.fn(),
|
|
36
|
+
id: '1',
|
|
37
|
+
label: 'Category Label',
|
|
38
|
+
grid: {
|
|
39
|
+
columns: 1,
|
|
40
|
+
rows: 1
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const props = {
|
|
44
|
+
...defaults,
|
|
45
|
+
...extras
|
|
46
|
+
};
|
|
47
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
|
|
48
|
+
theme: theme
|
|
49
|
+
}, /*#__PURE__*/_react.default.createElement(_choices.Choices, props)));
|
|
50
|
+
};
|
|
51
|
+
describe('rendering', () => {
|
|
52
|
+
it('renders without crashing', () => {
|
|
53
|
+
const {
|
|
54
|
+
container
|
|
55
|
+
} = renderChoices();
|
|
56
|
+
expect(container).toBeInTheDocument();
|
|
57
|
+
});
|
|
58
|
+
it('renders when disabled', () => {
|
|
59
|
+
const {
|
|
60
|
+
container
|
|
61
|
+
} = renderChoices({
|
|
62
|
+
disabled: true
|
|
63
|
+
});
|
|
64
|
+
expect(container).toBeInTheDocument();
|
|
65
|
+
});
|
|
66
|
+
it('renders choices with their labels', () => {
|
|
67
|
+
renderChoices({
|
|
68
|
+
choices: [{
|
|
69
|
+
id: '1',
|
|
70
|
+
label: 'Choice One'
|
|
71
|
+
}, {
|
|
72
|
+
id: '2',
|
|
73
|
+
label: 'Choice Two'
|
|
74
|
+
}]
|
|
75
|
+
});
|
|
76
|
+
expect(_react2.screen.getByTestId('choice-1')).toBeInTheDocument();
|
|
77
|
+
expect(_react2.screen.getByTestId('choice-2')).toBeInTheDocument();
|
|
78
|
+
expect(_react2.screen.getByText('Choice One')).toBeInTheDocument();
|
|
79
|
+
expect(_react2.screen.getByText('Choice Two')).toBeInTheDocument();
|
|
80
|
+
});
|
|
81
|
+
it('does not render empty choices as visible elements', () => {
|
|
82
|
+
const {
|
|
83
|
+
container
|
|
84
|
+
} = renderChoices({
|
|
85
|
+
choices: [{
|
|
86
|
+
empty: true
|
|
87
|
+
}, {
|
|
88
|
+
id: '1',
|
|
89
|
+
label: 'Visible Choice'
|
|
90
|
+
}]
|
|
91
|
+
});
|
|
92
|
+
expect(_react2.screen.getByText('Visible Choice')).toBeInTheDocument();
|
|
93
|
+
// Empty choice renders as empty div
|
|
94
|
+
expect(container.querySelectorAll('[data-testid^="choice-"]').length).toBe(1);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
describe('choices label', () => {
|
|
98
|
+
it('displays choices label when provided', () => {
|
|
99
|
+
renderChoices({
|
|
100
|
+
model: {
|
|
101
|
+
choicesLabel: 'Available Choices',
|
|
102
|
+
categoriesPerRow: 1
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
expect(_react2.screen.getByText('Available Choices')).toBeInTheDocument();
|
|
106
|
+
});
|
|
107
|
+
it('does not display label when choicesLabel is empty', () => {
|
|
108
|
+
renderChoices({
|
|
109
|
+
model: {
|
|
110
|
+
choicesLabel: '',
|
|
111
|
+
categoriesPerRow: 1
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
expect(_react2.screen.queryByText('Available Choices')).not.toBeInTheDocument();
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_styles","_choices","jest","mock","__esModule","default","label","id","createElement","ChoiceType","DraggableChoice","props","PlaceHolder","children","uid","withUid","fn","input","generateUid","mockReturnValue","theme","createTheme","describe","renderChoices","extras","defaults","classes","choices","onDropChoice","onRemoveChoice","grid","columns","rows","render","ThemeProvider","Choices","it","container","expect","toBeInTheDocument","disabled","screen","getByTestId","getByText","empty","querySelectorAll","length","toBe","model","choicesLabel","categoriesPerRow","queryByText","not"],"sources":["../../../src/categorize/__tests__/choices.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport { Choices } from '../choices';\n\njest.mock('../choice', () => ({\n  __esModule: true,\n  default: ({ label, id }) => <div data-testid={`choice-${id}`}>{label}</div>,\n  ChoiceType: {},\n}));\njest.mock('@pie-lib/drag', () => ({\n  DraggableChoice: (props) => <div {...props} />,\n  PlaceHolder: ({ children }) => <div>{children}</div>,\n  uid: {\n    withUid: jest.fn((input) => input),\n    generateUid: jest.fn().mockReturnValue('1'),\n  },\n}));\n\nconst theme = createTheme();\n\ndescribe('Choices', () => {\n  const renderChoices = (extras) => {\n    const defaults = {\n      classes: {},\n      choices: [],\n      onDropChoice: jest.fn(),\n      onRemoveChoice: jest.fn(),\n      id: '1',\n      label: 'Category Label',\n      grid: { columns: 1, rows: 1 },\n    };\n\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <Choices {...props} />\n      </ThemeProvider>\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders without crashing', () => {\n      const { container } = renderChoices();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders when disabled', () => {\n      const { container } = renderChoices({ disabled: true });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders choices with their labels', () => {\n      renderChoices({\n        choices: [\n          { id: '1', label: 'Choice One' },\n          { id: '2', label: 'Choice Two' },\n        ],\n      });\n      expect(screen.getByTestId('choice-1')).toBeInTheDocument();\n      expect(screen.getByTestId('choice-2')).toBeInTheDocument();\n      expect(screen.getByText('Choice One')).toBeInTheDocument();\n      expect(screen.getByText('Choice Two')).toBeInTheDocument();\n    });\n\n    it('does not render empty choices as visible elements', () => {\n      const { container } = renderChoices({\n        choices: [{ empty: true }, { id: '1', label: 'Visible Choice' }],\n      });\n      expect(screen.getByText('Visible Choice')).toBeInTheDocument();\n      // Empty choice renders as empty div\n      expect(container.querySelectorAll('[data-testid^=\"choice-\"]').length).toBe(1);\n    });\n  });\n\n  describe('choices label', () => {\n    it('displays choices label when provided', () => {\n      renderChoices({\n        model: { choicesLabel: 'Available Choices', categoriesPerRow: 1 },\n      });\n      expect(screen.getByText('Available Choices')).toBeInTheDocument();\n    });\n\n    it('does not display label when choicesLabel is empty', () => {\n      renderChoices({\n        model: { choicesLabel: '', categoriesPerRow: 1 },\n      });\n      expect(screen.queryByText('Available Choices')).not.toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _styles = require("@mui/material/styles");
|
|
7
|
+
var _droppablePlaceholder = _interopRequireDefault(require("../droppable-placeholder"));
|
|
8
|
+
jest.mock('../grid-content', () => ({
|
|
9
|
+
GridContent: props => /*#__PURE__*/_react.default.createElement("div", props)
|
|
10
|
+
}));
|
|
11
|
+
jest.mock('@dnd-kit/core', () => ({
|
|
12
|
+
useDroppable: () => ({
|
|
13
|
+
setNodeRef: jest.fn(),
|
|
14
|
+
isOver: false
|
|
15
|
+
})
|
|
16
|
+
}));
|
|
17
|
+
jest.mock('@pie-lib/drag', () => ({
|
|
18
|
+
PlaceHolder: ({
|
|
19
|
+
children,
|
|
20
|
+
isOver,
|
|
21
|
+
disabled
|
|
22
|
+
}) => /*#__PURE__*/_react.default.createElement("div", {
|
|
23
|
+
"data-testid": "placeholder",
|
|
24
|
+
"data-is-over": isOver,
|
|
25
|
+
"data-disabled": disabled
|
|
26
|
+
}, children)
|
|
27
|
+
}));
|
|
28
|
+
const theme = (0, _styles.createTheme)();
|
|
29
|
+
describe('DroppablePlaceholder', () => {
|
|
30
|
+
const renderPlaceholder = extras => {
|
|
31
|
+
const defaults = {
|
|
32
|
+
id: 'test-placeholder',
|
|
33
|
+
classes: {}
|
|
34
|
+
};
|
|
35
|
+
const props = {
|
|
36
|
+
...defaults,
|
|
37
|
+
...extras
|
|
38
|
+
};
|
|
39
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
|
|
40
|
+
theme: theme
|
|
41
|
+
}, /*#__PURE__*/_react.default.createElement(_droppablePlaceholder.default, props, /*#__PURE__*/_react.default.createElement("span", null, "Child Content"))));
|
|
42
|
+
};
|
|
43
|
+
describe('rendering', () => {
|
|
44
|
+
it('renders without crashing', () => {
|
|
45
|
+
const {
|
|
46
|
+
container
|
|
47
|
+
} = renderPlaceholder();
|
|
48
|
+
expect(container).toBeInTheDocument();
|
|
49
|
+
});
|
|
50
|
+
it('renders children content', () => {
|
|
51
|
+
renderPlaceholder();
|
|
52
|
+
expect(_react2.screen.getByText('Child Content')).toBeInTheDocument();
|
|
53
|
+
});
|
|
54
|
+
it('renders the placeholder wrapper', () => {
|
|
55
|
+
renderPlaceholder();
|
|
56
|
+
expect(_react2.screen.getByTestId('placeholder')).toBeInTheDocument();
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
describe('disabled state', () => {
|
|
60
|
+
it('passes disabled prop to placeholder', () => {
|
|
61
|
+
renderPlaceholder({
|
|
62
|
+
disabled: true
|
|
63
|
+
});
|
|
64
|
+
const placeholder = _react2.screen.getByTestId('placeholder');
|
|
65
|
+
expect(placeholder).toHaveAttribute('data-disabled', 'true');
|
|
66
|
+
});
|
|
67
|
+
it('passes disabled=false when not disabled', () => {
|
|
68
|
+
renderPlaceholder({
|
|
69
|
+
disabled: false
|
|
70
|
+
});
|
|
71
|
+
const placeholder = _react2.screen.getByTestId('placeholder');
|
|
72
|
+
expect(placeholder).toHaveAttribute('data-disabled', 'false');
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
describe('minRowHeight', () => {
|
|
76
|
+
it('renders with default min height', () => {
|
|
77
|
+
const {
|
|
78
|
+
container
|
|
79
|
+
} = renderPlaceholder();
|
|
80
|
+
expect(container.firstChild).toHaveStyle({
|
|
81
|
+
minHeight: '80px'
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
it('applies custom minRowHeight', () => {
|
|
85
|
+
const {
|
|
86
|
+
container
|
|
87
|
+
} = renderPlaceholder({
|
|
88
|
+
minRowHeight: '120px'
|
|
89
|
+
});
|
|
90
|
+
expect(container.firstChild).toHaveStyle({
|
|
91
|
+
minHeight: '120px'
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdDIiLCJfc3R5bGVzIiwiX2Ryb3BwYWJsZVBsYWNlaG9sZGVyIiwiamVzdCIsIm1vY2siLCJHcmlkQ29udGVudCIsInByb3BzIiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJ1c2VEcm9wcGFibGUiLCJzZXROb2RlUmVmIiwiZm4iLCJpc092ZXIiLCJQbGFjZUhvbGRlciIsImNoaWxkcmVuIiwiZGlzYWJsZWQiLCJ0aGVtZSIsImNyZWF0ZVRoZW1lIiwiZGVzY3JpYmUiLCJyZW5kZXJQbGFjZWhvbGRlciIsImV4dHJhcyIsImRlZmF1bHRzIiwiaWQiLCJjbGFzc2VzIiwicmVuZGVyIiwiVGhlbWVQcm92aWRlciIsIml0IiwiY29udGFpbmVyIiwiZXhwZWN0IiwidG9CZUluVGhlRG9jdW1lbnQiLCJzY3JlZW4iLCJnZXRCeVRleHQiLCJnZXRCeVRlc3RJZCIsInBsYWNlaG9sZGVyIiwidG9IYXZlQXR0cmlidXRlIiwiZmlyc3RDaGlsZCIsInRvSGF2ZVN0eWxlIiwibWluSGVpZ2h0IiwibWluUm93SGVpZ2h0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NhdGVnb3JpemUvX190ZXN0c19fL2Ryb3BwYWJsZS1wbGFjZWhvbGRlci50ZXN0LmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgcmVuZGVyLCBzY3JlZW4gfSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JztcbmltcG9ydCB7IFRoZW1lUHJvdmlkZXIsIGNyZWF0ZVRoZW1lIH0gZnJvbSAnQG11aS9tYXRlcmlhbC9zdHlsZXMnO1xuXG5pbXBvcnQgRHJvcHBhYmxlUGxhY2Vob2xkZXIgZnJvbSAnLi4vZHJvcHBhYmxlLXBsYWNlaG9sZGVyJztcblxuamVzdC5tb2NrKCcuLi9ncmlkLWNvbnRlbnQnLCAoKSA9PiAoe1xuICBHcmlkQ29udGVudDogKHByb3BzKSA9PiA8ZGl2IHsuLi5wcm9wc30gLz4sXG59KSk7XG5cbmplc3QubW9jaygnQGRuZC1raXQvY29yZScsICgpID0+ICh7XG4gIHVzZURyb3BwYWJsZTogKCkgPT4gKHtcbiAgICBzZXROb2RlUmVmOiBqZXN0LmZuKCksXG4gICAgaXNPdmVyOiBmYWxzZSxcbiAgfSksXG59KSk7XG5cbmplc3QubW9jaygnQHBpZS1saWIvZHJhZycsICgpID0+ICh7XG4gIFBsYWNlSG9sZGVyOiAoeyBjaGlsZHJlbiwgaXNPdmVyLCBkaXNhYmxlZCB9KSA9PiAoXG4gICAgPGRpdiBkYXRhLXRlc3RpZD1cInBsYWNlaG9sZGVyXCIgZGF0YS1pcy1vdmVyPXtpc092ZXJ9IGRhdGEtZGlzYWJsZWQ9e2Rpc2FibGVkfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L2Rpdj5cbiAgKSxcbn0pKTtcblxuY29uc3QgdGhlbWUgPSBjcmVhdGVUaGVtZSgpO1xuXG5kZXNjcmliZSgnRHJvcHBhYmxlUGxhY2Vob2xkZXInLCAoKSA9PiB7XG4gIGNvbnN0IHJlbmRlclBsYWNlaG9sZGVyID0gKGV4dHJhcykgPT4ge1xuICAgIGNvbnN0IGRlZmF1bHRzID0ge1xuICAgICAgaWQ6ICd0ZXN0LXBsYWNlaG9sZGVyJyxcbiAgICAgIGNsYXNzZXM6IHt9LFxuICAgIH07XG4gICAgY29uc3QgcHJvcHMgPSB7IC4uLmRlZmF1bHRzLCAuLi5leHRyYXMgfTtcbiAgICByZXR1cm4gcmVuZGVyKFxuICAgICAgPFRoZW1lUHJvdmlkZXIgdGhlbWU9e3RoZW1lfT5cbiAgICAgICAgPERyb3BwYWJsZVBsYWNlaG9sZGVyIHsuLi5wcm9wc30+XG4gICAgICAgICAgPHNwYW4+Q2hpbGQgQ29udGVudDwvc3Bhbj5cbiAgICAgICAgPC9Ecm9wcGFibGVQbGFjZWhvbGRlcj5cbiAgICAgIDwvVGhlbWVQcm92aWRlcj5cbiAgICApO1xuICB9O1xuXG4gIGRlc2NyaWJlKCdyZW5kZXJpbmcnLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMgd2l0aG91dCBjcmFzaGluZycsICgpID0+IHtcbiAgICAgIGNvbnN0IHsgY29udGFpbmVyIH0gPSByZW5kZXJQbGFjZWhvbGRlcigpO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lcikudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIGNoaWxkcmVuIGNvbnRlbnQnLCAoKSA9PiB7XG4gICAgICByZW5kZXJQbGFjZWhvbGRlcigpO1xuICAgICAgZXhwZWN0KHNjcmVlbi5nZXRCeVRleHQoJ0NoaWxkIENvbnRlbnQnKSkudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIHRoZSBwbGFjZWhvbGRlciB3cmFwcGVyJywgKCkgPT4ge1xuICAgICAgcmVuZGVyUGxhY2Vob2xkZXIoKTtcbiAgICAgIGV4cGVjdChzY3JlZW4uZ2V0QnlUZXN0SWQoJ3BsYWNlaG9sZGVyJykpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdkaXNhYmxlZCBzdGF0ZScsICgpID0+IHtcbiAgICBpdCgncGFzc2VzIGRpc2FibGVkIHByb3AgdG8gcGxhY2Vob2xkZXInLCAoKSA9PiB7XG4gICAgICByZW5kZXJQbGFjZWhvbGRlcih7IGRpc2FibGVkOiB0cnVlIH0pO1xuICAgICAgY29uc3QgcGxhY2Vob2xkZXIgPSBzY3JlZW4uZ2V0QnlUZXN0SWQoJ3BsYWNlaG9sZGVyJyk7XG4gICAgICBleHBlY3QocGxhY2Vob2xkZXIpLnRvSGF2ZUF0dHJpYnV0ZSgnZGF0YS1kaXNhYmxlZCcsICd0cnVlJyk7XG4gICAgfSk7XG5cbiAgICBpdCgncGFzc2VzIGRpc2FibGVkPWZhbHNlIHdoZW4gbm90IGRpc2FibGVkJywgKCkgPT4ge1xuICAgICAgcmVuZGVyUGxhY2Vob2xkZXIoeyBkaXNhYmxlZDogZmFsc2UgfSk7XG4gICAgICBjb25zdCBwbGFjZWhvbGRlciA9IHNjcmVlbi5nZXRCeVRlc3RJZCgncGxhY2Vob2xkZXInKTtcbiAgICAgIGV4cGVjdChwbGFjZWhvbGRlcikudG9IYXZlQXR0cmlidXRlKCdkYXRhLWRpc2FibGVkJywgJ2ZhbHNlJyk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdtaW5Sb3dIZWlnaHQnLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMgd2l0aCBkZWZhdWx0IG1pbiBoZWlnaHQnLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyUGxhY2Vob2xkZXIoKTtcbiAgICAgIGV4cGVjdChjb250YWluZXIuZmlyc3RDaGlsZCkudG9IYXZlU3R5bGUoeyBtaW5IZWlnaHQ6ICc4MHB4JyB9KTtcbiAgICB9KTtcblxuICAgIGl0KCdhcHBsaWVzIGN1c3RvbSBtaW5Sb3dIZWlnaHQnLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyUGxhY2Vob2xkZXIoeyBtaW5Sb3dIZWlnaHQ6ICcxMjBweCcgfSk7XG4gICAgICBleHBlY3QoY29udGFpbmVyLmZpcnN0Q2hpbGQpLnRvSGF2ZVN0eWxlKHsgbWluSGVpZ2h0OiAnMTIwcHgnIH0pO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOzs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxPQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxPQUFBLEdBQUFGLE9BQUE7QUFFQSxJQUFBRyxxQkFBQSxHQUFBSixzQkFBQSxDQUFBQyxPQUFBO0FBRUFJLElBQUksQ0FBQ0MsSUFBSSxDQUFDLGlCQUFpQixFQUFFLE9BQU87RUFDbENDLFdBQVcsRUFBR0MsS0FBSyxpQkFBS1QsTUFBQSxDQUFBVSxPQUFBLENBQUFDLGFBQUEsUUFBU0YsS0FBUTtBQUMzQyxDQUFDLENBQUMsQ0FBQztBQUVISCxJQUFJLENBQUNDLElBQUksQ0FBQyxlQUFlLEVBQUUsT0FBTztFQUNoQ0ssWUFBWSxFQUFFQSxDQUFBLE1BQU87SUFDbkJDLFVBQVUsRUFBRVAsSUFB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
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _styles = require("@mui/material/styles");
|
|
7
|
+
var _gridContent = require("../grid-content");
|
|
8
|
+
const theme = (0, _styles.createTheme)();
|
|
9
|
+
describe('grid-content', () => {
|
|
10
|
+
const renderGridContent = extras => {
|
|
11
|
+
const defaults = {
|
|
12
|
+
classes: {},
|
|
13
|
+
columns: 2
|
|
14
|
+
};
|
|
15
|
+
const props = {
|
|
16
|
+
...defaults,
|
|
17
|
+
...extras
|
|
18
|
+
};
|
|
19
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
|
|
20
|
+
theme: theme
|
|
21
|
+
}, /*#__PURE__*/_react.default.createElement(_gridContent.GridContent, props, "content")));
|
|
22
|
+
};
|
|
23
|
+
describe('renders', () => {
|
|
24
|
+
it('renders without crashing', () => {
|
|
25
|
+
const {
|
|
26
|
+
container
|
|
27
|
+
} = renderGridContent();
|
|
28
|
+
expect(container).toBeInTheDocument();
|
|
29
|
+
});
|
|
30
|
+
it('renders with different columns', () => {
|
|
31
|
+
const {
|
|
32
|
+
container
|
|
33
|
+
} = renderGridContent({
|
|
34
|
+
columns: 3
|
|
35
|
+
});
|
|
36
|
+
expect(container).toBeInTheDocument();
|
|
37
|
+
});
|
|
38
|
+
it('renders with className', () => {
|
|
39
|
+
const {
|
|
40
|
+
container
|
|
41
|
+
} = renderGridContent({
|
|
42
|
+
className: 'foo'
|
|
43
|
+
});
|
|
44
|
+
expect(container).toBeInTheDocument();
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdDIiLCJfc3R5bGVzIiwiX2dyaWRDb250ZW50IiwidGhlbWUiLCJjcmVhdGVUaGVtZSIsImRlc2NyaWJlIiwicmVuZGVyR3JpZENvbnRlbnQiLCJleHRyYXMiLCJkZWZhdWx0cyIsImNsYXNzZXMiLCJjb2x1bW5zIiwicHJvcHMiLCJyZW5kZXIiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsIlRoZW1lUHJvdmlkZXIiLCJHcmlkQ29udGVudCIsIml0IiwiY29udGFpbmVyIiwiZXhwZWN0IiwidG9CZUluVGhlRG9jdW1lbnQiLCJjbGFzc05hbWUiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY2F0ZWdvcml6ZS9fX3Rlc3RzX18vZ3JpZC1jb250ZW50LnRlc3QuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyByZW5kZXIgfSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JztcbmltcG9ydCB7IFRoZW1lUHJvdmlkZXIsIGNyZWF0ZVRoZW1lIH0gZnJvbSAnQG11aS9tYXRlcmlhbC9zdHlsZXMnO1xuaW1wb3J0IHsgR3JpZENvbnRlbnQgfSBmcm9tICcuLi9ncmlkLWNvbnRlbnQnO1xuXG5jb25zdCB0aGVtZSA9IGNyZWF0ZVRoZW1lKCk7XG5cbmRlc2NyaWJlKCdncmlkLWNvbnRlbnQnLCAoKSA9PiB7XG4gIGNvbnN0IHJlbmRlckdyaWRDb250ZW50ID0gKGV4dHJhcykgPT4ge1xuICAgIGNvbnN0IGRlZmF1bHRzID0ge1xuICAgICAgY2xhc3Nlczoge30sXG4gICAgICBjb2x1bW5zOiAyLFxuICAgIH07XG5cbiAgICBjb25zdCBwcm9wcyA9IHsgLi4uZGVmYXVsdHMsIC4uLmV4dHJhcyB9O1xuICAgIHJldHVybiByZW5kZXIoXG4gICAgICA8VGhlbWVQcm92aWRlciB0aGVtZT17dGhlbWV9PlxuICAgICAgICA8R3JpZENvbnRlbnQgey4uLnByb3BzfT5jb250ZW50PC9HcmlkQ29udGVudD5cbiAgICAgIDwvVGhlbWVQcm92aWRlcj5cbiAgICApO1xuICB9O1xuXG4gIGRlc2NyaWJlKCdyZW5kZXJzJywgKCkgPT4ge1xuICAgIGl0KCdyZW5kZXJzIHdpdGhvdXQgY3Jhc2hpbmcnLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyR3JpZENvbnRlbnQoKTtcbiAgICAgIGV4cGVjdChjb250YWluZXIpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG5cbiAgICBpdCgncmVuZGVycyB3aXRoIGRpZmZlcmVudCBjb2x1bW5zJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlckdyaWRDb250ZW50KHsgY29sdW1uczogMyB9KTtcbiAgICAgIGV4cGVjdChjb250YWluZXIpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG4gICAgaXQoJ3JlbmRlcnMgd2l0aCBjbGFzc05hbWUnLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyR3JpZENvbnRlbnQoeyBjbGFzc05hbWU6ICdmb28nIH0pO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lcikudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsT0FBQSxHQUFBRixPQUFBO0FBQ0EsSUFBQUcsWUFBQSxHQUFBSCxPQUFBO0FBRUEsTUFBTUksS0FBSyxHQUFHLElBQUFDLG1CQUFXLEVBQUMsQ0FBQztBQUUzQkMsUUFBUSxDQUFDLGNBQWMsRUFBRSxNQUFNO0VBQzdCLE1BQU1DLGlCQUFpQixHQUFJQyxNQUFNLElBQUs7SUFDcEMsTUFBTUMsUUFBUSxHQUFHO01BQ2ZDLE9BQU8sRUFBRSxDQUFDLENBQUM7TUFDWEMsT0FBTyxFQUFFO0lBQ1gsQ0FBQztJQUVELE1BQU1DLEtBQUssR0FBRztNQUFFLEdBQUdILFFBQVE7TUFBRSxHQUFHRDtJQUFPLENBQUM7SUFDeEMsT0FBTyxJQUFBSyxjQUFNLGVBQ1hmLE1BQUEsQ0FBQWdCLE9BQUEsQ0FBQUMsYUFBQSxDQUFDYixPQUFBLENBQUFjLGFBQWE7TUFBQ1osS0FBSyxFQUFFQTtJQUFNLGdCQUMxQk4sTUFBQSxDQUFBZ0IsT0FBQSxDQUFBQyxhQUFBLENBQUNaLFlBQUEsQ0FBQWMsV0FBVyxFQUFLTCxLQUFLLEVBQUUsU0FBb0IsQ0FDL0IsQ0FDakIsQ0FBQztFQUNILENBQUM7RUFFRE4sUUFBUSxDQUFDLFNBQVMsRUFBRSxNQUFNO0lBQ3hCWSxFQUFFLENBQUMsMEJBQTBCLEVBQUUsTUFBTTtNQUNuQyxNQUFNO1FBQUVDO01BQVUsQ0FBQyxHQUFHWixpQkFBaUIsQ0FBQyxDQUFDO01BQ3pDYSxNQUFNLENBQUNELFNBQVMsQ0FBQyxDQUFDRSxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3ZDLENBQUMsQ0FBQztJQUVGSCxFQUFFLENBQUMsZ0NBQWdDLEVBQUUsTUFBTTtNQUN6QyxNQUFNO1FBQUVDO01BQVUsQ0FBQyxHQUFHWixpQkFBaUIsQ0FBQztRQUFFSSxPQUFPLEVBQUU7TUFBRSxDQUFDLENBQUM7TUFDdkRTLE1BQU0sQ0FBQ0QsU0FBUyxDQUFDLENBQUNFLGlCQUFpQixDQUFDLENBQUM7SUFDdkMsQ0FBQyxDQUFDO0lBQ0ZILEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSxNQUFNO01BQ2pDLE1BQU07UUFBRUM7TUFBVSxDQUFDLEdBQUdaLGlCQUFpQixDQUFDO1FBQUVlLFNBQVMsRUFBRTtNQUFNLENBQUMsQ0FBQztNQUM3REYsTUFBTSxDQUFDRCxTQUFTLENBQUMsQ0FBQ0UsaUJBQWlCLENBQUMsQ0FBQztJQUN2QyxDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _react2 = require("@testing-library/react");
|
|
7
|
+
var _styles = require("@mui/material/styles");
|
|
8
|
+
var _index = require("../index");
|
|
9
|
+
jest.mock('@pie-lib/drag', () => ({
|
|
10
|
+
uid: {
|
|
11
|
+
withUid: jest.fn(a => a),
|
|
12
|
+
Provider: ({
|
|
13
|
+
children
|
|
14
|
+
}) => /*#__PURE__*/_react.default.createElement("div", null, children),
|
|
15
|
+
generateId: jest.fn().mockReturnValue('1')
|
|
16
|
+
},
|
|
17
|
+
withDragContext: jest.fn(n => n),
|
|
18
|
+
DragProvider: ({
|
|
19
|
+
children
|
|
20
|
+
}) => /*#__PURE__*/_react.default.createElement("div", null, children)
|
|
21
|
+
}));
|
|
22
|
+
jest.mock('@dnd-kit/core', () => ({
|
|
23
|
+
DragOverlay: ({
|
|
24
|
+
children
|
|
25
|
+
}) => /*#__PURE__*/_react.default.createElement("div", null, children),
|
|
26
|
+
useSensor: jest.fn(),
|
|
27
|
+
useSensors: jest.fn(() => []),
|
|
28
|
+
PointerSensor: jest.fn()
|
|
29
|
+
}));
|
|
30
|
+
jest.mock('../categories', () => ({
|
|
31
|
+
__esModule: true,
|
|
32
|
+
default: props => /*#__PURE__*/_react.default.createElement("div", props)
|
|
33
|
+
}));
|
|
34
|
+
jest.mock('../choices', () => ({
|
|
35
|
+
__esModule: true,
|
|
36
|
+
default: props => /*#__PURE__*/_react.default.createElement("div", props)
|
|
37
|
+
}));
|
|
38
|
+
jest.mock('../choice', () => ({
|
|
39
|
+
__esModule: true,
|
|
40
|
+
default: props => /*#__PURE__*/_react.default.createElement("div", props)
|
|
41
|
+
}));
|
|
42
|
+
jest.mock('@pie-lib/correct-answer-toggle', () => ({
|
|
43
|
+
__esModule: true,
|
|
44
|
+
default: props => /*#__PURE__*/_react.default.createElement("div", props)
|
|
45
|
+
}));
|
|
46
|
+
jest.mock('@pie-lib/categorize', () => ({
|
|
47
|
+
buildState: jest.fn(() => ({})),
|
|
48
|
+
removeChoiceFromCategory: jest.fn(() => []),
|
|
49
|
+
moveChoiceToCategory: jest.fn(() => [])
|
|
50
|
+
}));
|
|
51
|
+
jest.mock('@pie-lib/config-ui', () => ({
|
|
52
|
+
AlertDialog: props => /*#__PURE__*/_react.default.createElement("div", props)
|
|
53
|
+
}));
|
|
54
|
+
jest.mock('@pie-lib/render-ui', () => {
|
|
55
|
+
const React = require('react');
|
|
56
|
+
const UiLayout = React.forwardRef((props, ref) => /*#__PURE__*/React.createElement("div", (0, _extends2.default)({
|
|
57
|
+
ref: ref
|
|
58
|
+
}, props)));
|
|
59
|
+
UiLayout.displayName = 'UiLayout';
|
|
60
|
+
return {
|
|
61
|
+
Collapsible: ({
|
|
62
|
+
children
|
|
63
|
+
}) => /*#__PURE__*/React.createElement("div", null, children),
|
|
64
|
+
Feedback: props => /*#__PURE__*/React.createElement("div", props),
|
|
65
|
+
UiLayout,
|
|
66
|
+
hasText: jest.fn(() => false),
|
|
67
|
+
hasMedia: jest.fn(() => false),
|
|
68
|
+
PreviewPrompt: props => /*#__PURE__*/React.createElement("div", props),
|
|
69
|
+
color: {
|
|
70
|
+
text: () => '#000',
|
|
71
|
+
background: () => '#fff',
|
|
72
|
+
white: () => '#fff',
|
|
73
|
+
correct: () => '#00ff00',
|
|
74
|
+
incorrect: () => '#ff0000'
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
});
|
|
78
|
+
const theme = (0, _styles.createTheme)();
|
|
79
|
+
describe('categorize', () => {
|
|
80
|
+
const defaultProps = {
|
|
81
|
+
classes: {},
|
|
82
|
+
session: {
|
|
83
|
+
answers: []
|
|
84
|
+
},
|
|
85
|
+
model: {
|
|
86
|
+
choices: [],
|
|
87
|
+
categories: []
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
let onAnswersChange;
|
|
91
|
+
let onShowCorrectToggle;
|
|
92
|
+
beforeEach(() => {
|
|
93
|
+
onAnswersChange = jest.fn();
|
|
94
|
+
onShowCorrectToggle = jest.fn();
|
|
95
|
+
});
|
|
96
|
+
const renderCategorize = extras => {
|
|
97
|
+
const defaults = {
|
|
98
|
+
...defaultProps,
|
|
99
|
+
onAnswersChange,
|
|
100
|
+
onShowCorrectToggle
|
|
101
|
+
};
|
|
102
|
+
const props = {
|
|
103
|
+
...defaults,
|
|
104
|
+
...extras
|
|
105
|
+
};
|
|
106
|
+
return (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_styles.ThemeProvider, {
|
|
107
|
+
theme: theme
|
|
108
|
+
}, /*#__PURE__*/_react.default.createElement(_index.Categorize, props)));
|
|
109
|
+
};
|
|
110
|
+
describe('renders', () => {
|
|
111
|
+
it('renders without crashing', () => {
|
|
112
|
+
const {
|
|
113
|
+
container
|
|
114
|
+
} = renderCategorize();
|
|
115
|
+
expect(container).toBeInTheDocument();
|
|
116
|
+
});
|
|
117
|
+
it('renders with feedback', () => {
|
|
118
|
+
const {
|
|
119
|
+
container
|
|
120
|
+
} = renderCategorize({
|
|
121
|
+
model: {
|
|
122
|
+
...defaultProps.model,
|
|
123
|
+
correctness: 'correct',
|
|
124
|
+
feedback: {
|
|
125
|
+
correct: {
|
|
126
|
+
type: 'default',
|
|
127
|
+
default: 'Correct'
|
|
128
|
+
},
|
|
129
|
+
incorrect: {
|
|
130
|
+
type: 'default',
|
|
131
|
+
default: 'Incorrect'
|
|
132
|
+
},
|
|
133
|
+
partial: {
|
|
134
|
+
type: 'default',
|
|
135
|
+
default: 'Nearly'
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
expect(container).toBeInTheDocument();
|
|
141
|
+
});
|
|
142
|
+
it('renders when incorrect', () => {
|
|
143
|
+
const {
|
|
144
|
+
container
|
|
145
|
+
} = renderCategorize({
|
|
146
|
+
incorrect: true
|
|
147
|
+
});
|
|
148
|
+
expect(container).toBeInTheDocument();
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_styles","_index","jest","mock","uid","withUid","fn","a","Provider","children","default","createElement","generateId","mockReturnValue","withDragContext","n","DragProvider","DragOverlay","useSensor","useSensors","PointerSensor","__esModule","props","buildState","removeChoiceFromCategory","moveChoiceToCategory","AlertDialog","React","UiLayout","forwardRef","ref","_extends2","displayName","Collapsible","Feedback","hasText","hasMedia","PreviewPrompt","color","text","background","white","correct","incorrect","theme","createTheme","describe","defaultProps","classes","session","answers","model","choices","categories","onAnswersChange","onShowCorrectToggle","beforeEach","renderCategorize","extras","defaults","render","ThemeProvider","Categorize","it","container","expect","toBeInTheDocument","correctness","feedback","type","partial"],"sources":["../../../src/categorize/__tests__/index.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render } from '@testing-library/react';\nimport { ThemeProvider, createTheme } from '@mui/material/styles';\nimport { Categorize } from '../index';\n\njest.mock('@pie-lib/drag', () => ({\n  uid: {\n    withUid: jest.fn((a) => a),\n    Provider: ({ children }) => <div>{children}</div>,\n    generateId: jest.fn().mockReturnValue('1'),\n  },\n  withDragContext: jest.fn((n) => n),\n  DragProvider: ({ children }) => <div>{children}</div>,\n}));\n\njest.mock('@dnd-kit/core', () => ({\n  DragOverlay: ({ children }) => <div>{children}</div>,\n  useSensor: jest.fn(),\n  useSensors: jest.fn(() => []),\n  PointerSensor: jest.fn(),\n}));\n\njest.mock('../categories', () => ({\n  __esModule: true,\n  default: (props) => <div {...props} />,\n}));\njest.mock('../choices', () => ({\n  __esModule: true,\n  default: (props) => <div {...props} />,\n}));\njest.mock('../choice', () => ({\n  __esModule: true,\n  default: (props) => <div {...props} />,\n}));\njest.mock('@pie-lib/correct-answer-toggle', () => ({\n  __esModule: true,\n  default: (props) => <div {...props} />,\n}));\njest.mock('@pie-lib/categorize', () => ({\n  buildState: jest.fn(() => ({})),\n  removeChoiceFromCategory: jest.fn(() => []),\n  moveChoiceToCategory: jest.fn(() => []),\n}));\njest.mock('@pie-lib/config-ui', () => ({\n  AlertDialog: (props) => <div {...props} />,\n}));\njest.mock('@pie-lib/render-ui', () => {\n  const React = require('react');\n  const UiLayout = React.forwardRef((props, ref) => <div ref={ref} {...props} />);\n  UiLayout.displayName = 'UiLayout';\n\n  return {\n    Collapsible: ({ children }) => <div>{children}</div>,\n    Feedback: (props) => <div {...props} />,\n    UiLayout,\n    hasText: jest.fn(() => false),\n    hasMedia: jest.fn(() => false),\n    PreviewPrompt: (props) => <div {...props} />,\n    color: {\n      text: () => '#000',\n      background: () => '#fff',\n      white: () => '#fff',\n      correct: () => '#00ff00',\n      incorrect: () => '#ff0000',\n    },\n  };\n});\n\nconst theme = createTheme();\n\ndescribe('categorize', () => {\n  const defaultProps = {\n    classes: {},\n    session: {\n      answers: [],\n    },\n    model: {\n      choices: [],\n      categories: [],\n    },\n  };\n  let onAnswersChange;\n  let onShowCorrectToggle;\n\n  beforeEach(() => {\n    onAnswersChange = jest.fn();\n    onShowCorrectToggle = jest.fn();\n  });\n\n  const renderCategorize = (extras) => {\n    const defaults = {\n      ...defaultProps,\n      onAnswersChange,\n      onShowCorrectToggle,\n    };\n    const props = { ...defaults, ...extras };\n\n    return render(\n      <ThemeProvider theme={theme}>\n        <Categorize {...props} />\n      </ThemeProvider>\n    );\n  };\n\n  describe('renders', () => {\n    it('renders without crashing', () => {\n      const { container } = renderCategorize();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with feedback', () => {\n      const { container } = renderCategorize({\n        model: {\n          ...defaultProps.model,\n          correctness: 'correct',\n          feedback: {\n            correct: {\n              type: 'default',\n              default: 'Correct',\n            },\n            incorrect: {\n              type: 'default',\n              default: 'Incorrect',\n            },\n            partial: {\n              type: 'default',\n              default: 'Nearly',\n            },\n          },\n        },\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders when incorrect', () => {\n      const { container } = renderCategorize({ incorrect: true });\n      expect(container).toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|