@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.
Files changed (106) hide show
  1. package/CHANGELOG.md +0 -11
  2. package/configure/CHANGELOG.md +0 -11
  3. package/configure/lib/__tests__/main.test.js +100 -0
  4. package/configure/lib/__tests__/utils.js +39 -0
  5. package/configure/lib/defaults.js +3 -6
  6. package/configure/lib/defaults.js.map +1 -1
  7. package/configure/lib/design/__tests__/builder.test.js +34 -0
  8. package/configure/lib/design/__tests__/buttons.test.js +36 -0
  9. package/configure/lib/design/__tests__/header.test.js +37 -0
  10. package/configure/lib/design/__tests__/index.test.js +125 -0
  11. package/configure/lib/design/__tests__/input-header.test.js +41 -0
  12. package/configure/lib/design/builder.js +16 -34
  13. package/configure/lib/design/builder.js.map +1 -1
  14. package/configure/lib/design/buttons.js +42 -96
  15. package/configure/lib/design/buttons.js.map +1 -1
  16. package/configure/lib/design/categories/RowLabel.js +34 -47
  17. package/configure/lib/design/categories/RowLabel.js.map +1 -1
  18. package/configure/lib/design/categories/__tests__/alternateResponses.test.js +93 -0
  19. package/configure/lib/design/categories/__tests__/category.test.js +65 -0
  20. package/configure/lib/design/categories/__tests__/choice-preview.test.js +52 -0
  21. package/configure/lib/design/categories/__tests__/droppable-placeholder.test.js +63 -0
  22. package/configure/lib/design/categories/__tests__/index.test.js +91 -0
  23. package/configure/lib/design/categories/alternateResponses.js +97 -252
  24. package/configure/lib/design/categories/alternateResponses.js.map +1 -1
  25. package/configure/lib/design/categories/category.js +136 -209
  26. package/configure/lib/design/categories/category.js.map +1 -1
  27. package/configure/lib/design/categories/choice-preview.js +62 -127
  28. package/configure/lib/design/categories/choice-preview.js.map +1 -1
  29. package/configure/lib/design/categories/droppable-placeholder.js +74 -166
  30. package/configure/lib/design/categories/droppable-placeholder.js.map +1 -1
  31. package/configure/lib/design/categories/index.js +196 -385
  32. package/configure/lib/design/categories/index.js.map +1 -1
  33. package/configure/lib/design/choices/__tests__/choice.test.js +62 -0
  34. package/configure/lib/design/choices/__tests__/config.test.js +66 -0
  35. package/configure/lib/design/choices/__tests__/index.test.js +70 -0
  36. package/configure/lib/design/choices/choice.js +156 -265
  37. package/configure/lib/design/choices/choice.js.map +1 -1
  38. package/configure/lib/design/choices/config.js +43 -99
  39. package/configure/lib/design/choices/config.js.map +1 -1
  40. package/configure/lib/design/choices/index.js +149 -237
  41. package/configure/lib/design/choices/index.js.map +1 -1
  42. package/configure/lib/design/header.js +58 -112
  43. package/configure/lib/design/header.js.map +1 -1
  44. package/configure/lib/design/index.js +633 -478
  45. package/configure/lib/design/index.js.map +1 -1
  46. package/configure/lib/design/input-header.js +95 -151
  47. package/configure/lib/design/input-header.js.map +1 -1
  48. package/configure/lib/design/utils.js +5 -16
  49. package/configure/lib/design/utils.js.map +1 -1
  50. package/configure/lib/index.js +121 -184
  51. package/configure/lib/index.js.map +1 -1
  52. package/configure/lib/main.js +31 -75
  53. package/configure/lib/main.js.map +1 -1
  54. package/configure/lib/utils.js +23 -33
  55. package/configure/lib/utils.js.map +1 -1
  56. package/configure/package.json +15 -15
  57. package/controller/CHANGELOG.md +0 -11
  58. package/controller/lib/__tests__/index.test.js +526 -0
  59. package/controller/lib/defaults.js +3 -6
  60. package/controller/lib/defaults.js.map +1 -1
  61. package/controller/lib/index.js +238 -319
  62. package/controller/lib/index.js.map +1 -1
  63. package/controller/lib/utils.js +29 -66
  64. package/controller/lib/utils.js.map +1 -1
  65. package/controller/package.json +5 -5
  66. package/docs/demo/.pie/.configure/package.json +10 -0
  67. package/docs/demo/.pie/.configure/yarn.lock +2181 -0
  68. package/docs/demo/.pie/.controllers/package.json +10 -0
  69. package/docs/demo/.pie/.controllers/yarn.lock +110 -0
  70. package/docs/demo/.pie/info.entry.js +89 -0
  71. package/docs/demo/.pie/info.webpack.config.js +119 -0
  72. package/docs/demo/.pie/package.json +10 -0
  73. package/docs/demo/.pie/yarn.lock +2190 -0
  74. package/docs/demo/pie.manifest.json +11 -0
  75. package/lib/__tests__/index.test.js +197 -0
  76. package/lib/categorize/__tests__/categories.test.js +138 -0
  77. package/lib/categorize/__tests__/category.test.js +137 -0
  78. package/lib/categorize/__tests__/choice.test.js +88 -0
  79. package/lib/categorize/__tests__/choices.test.js +118 -0
  80. package/lib/categorize/__tests__/droppable-placeholder.test.js +96 -0
  81. package/lib/categorize/__tests__/grid-content.test.js +48 -0
  82. package/lib/categorize/__tests__/index.test.js +152 -0
  83. package/lib/categorize/categories.js +107 -165
  84. package/lib/categorize/categories.js.map +1 -1
  85. package/lib/categorize/category.js +74 -124
  86. package/lib/categorize/category.js.map +1 -1
  87. package/lib/categorize/choice.js +119 -246
  88. package/lib/categorize/choice.js.map +1 -1
  89. package/lib/categorize/choices.js +67 -132
  90. package/lib/categorize/choices.js.map +1 -1
  91. package/lib/categorize/droppable-placeholder.js +47 -104
  92. package/lib/categorize/droppable-placeholder.js.map +1 -1
  93. package/lib/categorize/grid-content.js +40 -88
  94. package/lib/categorize/grid-content.js.map +1 -1
  95. package/lib/categorize/index.js +342 -318
  96. package/lib/categorize/index.js.map +1 -1
  97. package/lib/index.js +286 -307
  98. package/lib/index.js.map +1 -1
  99. package/package.json +16 -14
  100. package/esm/configure.js +0 -34401
  101. package/esm/configure.js.map +0 -1
  102. package/esm/controller.js +0 -1468
  103. package/esm/controller.js.map +0 -1
  104. package/esm/element.js +0 -13134
  105. package/esm/element.js.map +0 -1
  106. 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":";;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AAEAI,IAAI,CAACC,IAAI,CAAC,WAAW,EAAE,OAAO;EAC5BC,UAAU,EAAE,IAAI;EAChBC,OAAO,EAAEA,CAAC;IAAEC,KAAK;IAAEC;EAAG,CAAC,kBAAKX,MAAA,CAAAS,OAAA,CAAAG,aAAA;IAAK,eAAa,UAAUD,EAAE;EAAG,GAAED,KAAW,CAAC;EAC3EG,UAAU,EAAE,CAAC;AACf,CAAC,CAAC,CAAC;AACHP,IAAI,CAACC,IAAI,CAAC,eAAe,EAAE,OAAO;EAChCO,eAAe,EAAGC,KAAK,iBAAKf,MAAA,CAAAS,OAAA,CAAAG,aAAA,QAASG,KAAQ,CAAC;EAC9CC,WAAW,EAAEA,CAAC;IAAEC;EAAS,CAAC,kBAAKjB,MAAA,CAAAS,OAAA,CAAAG,aAAA,cAAMK,QAAc,CAAC;EACpDC,GAAG,EAAE;IACHC,OAAO,EAAEb,IAAI,CAACc,EAAE,CAAEC,KAAK,IAAKA,KAAK,CAAC;IAClCC,WAAW,EAAEhB,IAAI,CAACc,EAAE,CAAC,CAAC,CAACG,eAAe,CAAC,GAAG;EAC5C;AACF,CAAC,CAAC,CAAC;AAEH,MAAMC,KAAK,GAAG,IAAAC,mBAAW,EAAC,CAAC;AAE3BC,QAAQ,CAAC,SAAS,EAAE,MAAM;EACxB,MAAMC,aAAa,GAAIC,MAAM,IAAK;IAChC,MAAMC,QAAQ,GAAG;MACfC,OAAO,EAAE,CAAC,CAAC;MACXC,OAAO,EAAE,EAAE;MACXC,YAAY,EAAE1B,IAAI,CAACc,EAAE,CAAC,CAAC;MACvBa,cAAc,EAAE3B,IAAI,CAACc,EAAE,CAAC,CAAC;MACzBT,EAAE,EAAE,GAAG;MACPD,KAAK,EAAE,gBAAgB;MACvBwB,IAAI,EAAE;QAAEC,OAAO,EAAE,CAAC;QAAEC,IAAI,EAAE;MAAE;IAC9B,CAAC;IAED,MAAMrB,KAAK,GAAG;MAAE,GAAGc,QAAQ;MAAE,GAAGD;IAAO,CAAC;IACxC,OAAO,IAAAS,cAAM,eACXrC,MAAA,CAAAS,OAAA,CAAAG,aAAA,CAACR,OAAA,CAAAkC,aAAa;MAACd,KAAK,EAAEA;IAAM,gBAC1BxB,MAAA,CAAAS,OAAA,CAAAG,aAAA,CAACP,QAAA,CAAAkC,OAAO,EAAKxB,KAAQ,CACR,CACjB,CAAC;EACH,CAAC;EAEDW,QAAQ,CAAC,WAAW,EAAE,MAAM;IAC1Bc,EAAE,CAAC,0BAA0B,EAAE,MAAM;MACnC,MAAM;QAAEC;MAAU,CAAC,GAAGd,aAAa,CAAC,CAAC;MACrCe,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFH,EAAE,CAAC,uBAAuB,EAAE,MAAM;MAChC,MAAM;QAAEC;MAAU,CAAC,GAAGd,aAAa,CAAC;QAAEiB,QAAQ,EAAE;MAAK,CAAC,CAAC;MACvDF,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFH,EAAE,CAAC,mCAAmC,EAAE,MAAM;MAC5Cb,aAAa,CAAC;QACZI,OAAO,EAAE,CACP;UAAEpB,EAAE,EAAE,GAAG;UAAED,KAAK,EAAE;QAAa,CAAC,EAChC;UAAEC,EAAE,EAAE,GAAG;UAAED,KAAK,EAAE;QAAa,CAAC;MAEpC,CAAC,CAAC;MACFgC,MAAM,CAACG,cAAM,CAACC,WAAW,CAAC,UAAU,CAAC,CAAC,CAACH,iBAAiB,CAAC,CAAC;MAC1DD,MAAM,CAACG,cAAM,CAACC,WAAW,CAAC,UAAU,CAAC,CAAC,CAACH,iBAAiB,CAAC,CAAC;MAC1DD,MAAM,CAACG,cAAM,CAACE,SAAS,CAAC,YAAY,CAAC,CAAC,CAACJ,iBAAiB,CAAC,CAAC;MAC1DD,MAAM,CAACG,cAAM,CAACE,SAAS,CAAC,YAAY,CAAC,CAAC,CAACJ,iBAAiB,CAAC,CAAC;IAC5D,CAAC,CAAC;IAEFH,EAAE,CAAC,mDAAmD,EAAE,MAAM;MAC5D,MAAM;QAAEC;MAAU,CAAC,GAAGd,aAAa,CAAC;QAClCI,OAAO,EAAE,CAAC;UAAEiB,KAAK,EAAE;QAAK,CAAC,EAAE;UAAErC,EAAE,EAAE,GAAG;UAAED,KAAK,EAAE;QAAiB,CAAC;MACjE,CAAC,CAAC;MACFgC,MAAM,CAACG,cAAM,CAACE,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAACJ,iBAAiB,CAAC,CAAC;MAC9D;MACAD,MAAM,CAACD,SAAS,CAACQ,gBAAgB,CAAC,0BAA0B,CAAC,CAACC,MAAM,CAAC,CAACC,IAAI,CAAC,CAAC,CAAC;IAC/E,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFzB,QAAQ,CAAC,eAAe,EAAE,MAAM;IAC9Bc,EAAE,CAAC,sCAAsC,EAAE,MAAM;MAC/Cb,aAAa,CAAC;QACZyB,KAAK,EAAE;UAAEC,YAAY,EAAE,mBAAmB;UAAEC,gBAAgB,EAAE;QAAE;MAClE,CAAC,CAAC;MACFZ,MAAM,CAACG,cAAM,CAACE,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAACJ,iBAAiB,CAAC,CAAC;IACnE,CAAC,CAAC;IAEFH,EAAE,CAAC,mDAAmD,EAAE,MAAM;MAC5Db,aAAa,CAAC;QACZyB,KAAK,EAAE;UAAEC,YAAY,EAAE,EAAE;UAAEC,gBAAgB,EAAE;QAAE;MACjD,CAAC,CAAC;MACFZ,MAAM,CAACG,cAAM,CAACU,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAACC,GAAG,CAACb,iBAAiB,CAAC,CAAC;IACzE,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","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":[]}