@pie-lib/editable-html-tip-tap 2.1.1-next.3 → 2.1.2-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/dist/components/CharacterPicker.d.ts +31 -0
  2. package/dist/components/CharacterPicker.js +131 -0
  3. package/dist/components/EditableHtml.d.ts +11 -0
  4. package/dist/components/EditableHtml.js +291 -0
  5. package/dist/components/MenuBar.d.ts +11 -0
  6. package/dist/components/MenuBar.js +462 -0
  7. package/dist/components/TiptapContainer.d.ts +11 -0
  8. package/dist/components/TiptapContainer.js +154 -0
  9. package/dist/components/characters/characterUtils.d.ts +35 -0
  10. package/dist/components/characters/characterUtils.js +465 -0
  11. package/dist/components/characters/custom-popper.d.ts +14 -0
  12. package/dist/components/characters/custom-popper.js +32 -0
  13. package/dist/components/common/done-button.d.ts +30 -0
  14. package/dist/components/common/done-button.js +26 -0
  15. package/dist/components/common/toolbar-buttons.d.ts +38 -0
  16. package/dist/components/common/toolbar-buttons.js +91 -0
  17. package/dist/components/icons/CssIcon.d.ts +11 -0
  18. package/dist/components/icons/CssIcon.js +14 -0
  19. package/dist/components/icons/RespArea.d.ts +26 -0
  20. package/dist/components/icons/RespArea.js +42 -0
  21. package/dist/components/icons/TableIcons.d.ts +14 -0
  22. package/dist/components/icons/TableIcons.js +32 -0
  23. package/dist/components/icons/TextAlign.d.ts +18 -0
  24. package/dist/components/icons/TextAlign.js +134 -0
  25. package/dist/components/image/AltDialog.d.ts +22 -0
  26. package/dist/components/image/AltDialog.js +61 -0
  27. package/dist/components/image/ImageToolbar.d.ts +24 -0
  28. package/dist/components/image/ImageToolbar.js +80 -0
  29. package/dist/components/image/InsertImageHandler.d.ts +32 -0
  30. package/dist/components/image/InsertImageHandler.js +53 -0
  31. package/dist/components/media/MediaDialog.d.ts +43 -0
  32. package/dist/components/media/MediaDialog.js +389 -0
  33. package/dist/components/media/MediaToolbar.d.ts +19 -0
  34. package/dist/components/media/MediaToolbar.js +41 -0
  35. package/dist/components/media/MediaWrapper.d.ts +19 -0
  36. package/dist/components/respArea/DragInTheBlank/DragInTheBlank.d.ts +23 -0
  37. package/dist/components/respArea/DragInTheBlank/DragInTheBlank.js +58 -0
  38. package/dist/components/respArea/DragInTheBlank/choice.d.ts +56 -0
  39. package/dist/components/respArea/DragInTheBlank/choice.js +156 -0
  40. package/dist/components/respArea/ExplicitConstructedResponse.d.ts +20 -0
  41. package/dist/components/respArea/ExplicitConstructedResponse.js +83 -0
  42. package/dist/components/respArea/InlineDropdown.d.ts +18 -0
  43. package/dist/components/respArea/InlineDropdown.js +119 -0
  44. package/dist/components/respArea/MathTemplated.d.ts +19 -0
  45. package/dist/components/respArea/MathTemplated.js +97 -0
  46. package/dist/components/respArea/ToolbarIcon.d.ts +14 -0
  47. package/dist/components/respArea/ToolbarIcon.js +17 -0
  48. package/dist/components/respArea/inlineDropdownUtils.d.ts +15 -0
  49. package/dist/components/respArea/inlineDropdownUtils.js +15 -0
  50. package/dist/constants.d.ts +13 -0
  51. package/dist/constants.js +4 -0
  52. package/dist/extensions/css.d.ts +11 -0
  53. package/dist/extensions/css.js +115 -0
  54. package/dist/extensions/custom-toolbar-wrapper.d.ts +11 -0
  55. package/dist/extensions/custom-toolbar-wrapper.js +61 -0
  56. package/dist/extensions/div-node.d.ts +10 -0
  57. package/dist/extensions/div-node.js +42 -0
  58. package/dist/extensions/ensure-empty-root-div.d.ts +14 -0
  59. package/dist/extensions/ensure-empty-root-div.js +24 -0
  60. package/dist/extensions/ensure-list-item-content-is-div.d.ts +15 -0
  61. package/dist/extensions/ensure-list-item-content-is-div.js +31 -0
  62. package/dist/extensions/extended-list-item.d.ts +13 -0
  63. package/dist/extensions/extended-list-item.js +5 -0
  64. package/dist/extensions/extended-table-cell.d.ts +10 -0
  65. package/dist/extensions/extended-table-cell.js +6 -0
  66. package/dist/extensions/extended-table.d.ts +17 -0
  67. package/dist/extensions/extended-table.js +34 -0
  68. package/dist/extensions/heading-paragraph.d.ts +17 -0
  69. package/dist/extensions/heading-paragraph.js +30 -0
  70. package/dist/extensions/image-component.d.ts +22 -0
  71. package/dist/extensions/image-component.js +220 -0
  72. package/dist/extensions/image.d.ts +10 -0
  73. package/dist/extensions/image.js +68 -0
  74. package/dist/extensions/index.d.ts +16 -0
  75. package/dist/extensions/index.js +65 -0
  76. package/dist/extensions/math.d.ts +15 -0
  77. package/dist/extensions/math.js +158 -0
  78. package/dist/extensions/media.d.ts +19 -0
  79. package/dist/extensions/media.js +149 -0
  80. package/dist/extensions/responseArea.d.ts +27 -0
  81. package/dist/extensions/responseArea.js +259 -0
  82. package/dist/index.d.ts +13 -0
  83. package/dist/index.js +7 -0
  84. package/dist/styles/editorContainerStyles.d.ts +134 -0
  85. package/dist/theme.d.ts +9 -0
  86. package/dist/utils/helper.d.ts +9 -0
  87. package/dist/utils/helper.js +27 -0
  88. package/dist/utils/size.d.ts +9 -0
  89. package/dist/utils/size.js +14 -0
  90. package/package.json +51 -38
  91. package/CHANGELOG.json +0 -32
  92. package/CHANGELOG.md +0 -2526
  93. package/LICENSE.md +0 -5
  94. package/lib/components/CharacterPicker.js +0 -195
  95. package/lib/components/CharacterPicker.js.map +0 -1
  96. package/lib/components/EditableHtml.js +0 -375
  97. package/lib/components/EditableHtml.js.map +0 -1
  98. package/lib/components/MenuBar.js +0 -693
  99. package/lib/components/MenuBar.js.map +0 -1
  100. package/lib/components/TiptapContainer.js +0 -234
  101. package/lib/components/TiptapContainer.js.map +0 -1
  102. package/lib/components/characters/characterUtils.js +0 -378
  103. package/lib/components/characters/characterUtils.js.map +0 -1
  104. package/lib/components/characters/custom-popper.js +0 -44
  105. package/lib/components/characters/custom-popper.js.map +0 -1
  106. package/lib/components/common/done-button.js +0 -34
  107. package/lib/components/common/done-button.js.map +0 -1
  108. package/lib/components/common/toolbar-buttons.js +0 -144
  109. package/lib/components/common/toolbar-buttons.js.map +0 -1
  110. package/lib/components/icons/CssIcon.js +0 -25
  111. package/lib/components/icons/CssIcon.js.map +0 -1
  112. package/lib/components/icons/RespArea.js +0 -72
  113. package/lib/components/icons/RespArea.js.map +0 -1
  114. package/lib/components/icons/TableIcons.js +0 -53
  115. package/lib/components/icons/TableIcons.js.map +0 -1
  116. package/lib/components/icons/TextAlign.js +0 -157
  117. package/lib/components/icons/TextAlign.js.map +0 -1
  118. package/lib/components/image/AltDialog.js +0 -98
  119. package/lib/components/image/AltDialog.js.map +0 -1
  120. package/lib/components/image/ImageToolbar.js +0 -137
  121. package/lib/components/image/ImageToolbar.js.map +0 -1
  122. package/lib/components/image/InsertImageHandler.js +0 -135
  123. package/lib/components/image/InsertImageHandler.js.map +0 -1
  124. package/lib/components/media/MediaDialog.js +0 -594
  125. package/lib/components/media/MediaDialog.js.map +0 -1
  126. package/lib/components/media/MediaToolbar.js +0 -74
  127. package/lib/components/media/MediaToolbar.js.map +0 -1
  128. package/lib/components/media/MediaWrapper.js +0 -67
  129. package/lib/components/media/MediaWrapper.js.map +0 -1
  130. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +0 -84
  131. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +0 -1
  132. package/lib/components/respArea/DragInTheBlank/choice.js +0 -250
  133. package/lib/components/respArea/DragInTheBlank/choice.js.map +0 -1
  134. package/lib/components/respArea/ExplicitConstructedResponse.js +0 -136
  135. package/lib/components/respArea/ExplicitConstructedResponse.js.map +0 -1
  136. package/lib/components/respArea/InlineDropdown.js +0 -165
  137. package/lib/components/respArea/InlineDropdown.js.map +0 -1
  138. package/lib/components/respArea/MathTemplated.js +0 -130
  139. package/lib/components/respArea/MathTemplated.js.map +0 -1
  140. package/lib/components/respArea/ToolbarIcon.js +0 -81
  141. package/lib/components/respArea/ToolbarIcon.js.map +0 -1
  142. package/lib/constants.js +0 -11
  143. package/lib/constants.js.map +0 -1
  144. package/lib/extensions/css.js +0 -217
  145. package/lib/extensions/css.js.map +0 -1
  146. package/lib/extensions/custom-toolbar-wrapper.js +0 -92
  147. package/lib/extensions/custom-toolbar-wrapper.js.map +0 -1
  148. package/lib/extensions/div-node.js +0 -83
  149. package/lib/extensions/div-node.js.map +0 -1
  150. package/lib/extensions/ensure-empty-root-div.js +0 -48
  151. package/lib/extensions/ensure-empty-root-div.js.map +0 -1
  152. package/lib/extensions/ensure-list-item-content-is-div.js +0 -64
  153. package/lib/extensions/ensure-list-item-content-is-div.js.map +0 -1
  154. package/lib/extensions/extended-list-item.js +0 -15
  155. package/lib/extensions/extended-list-item.js.map +0 -1
  156. package/lib/extensions/extended-table-cell.js +0 -22
  157. package/lib/extensions/extended-table-cell.js.map +0 -1
  158. package/lib/extensions/extended-table.js +0 -75
  159. package/lib/extensions/extended-table.js.map +0 -1
  160. package/lib/extensions/heading-paragraph.js +0 -61
  161. package/lib/extensions/heading-paragraph.js.map +0 -1
  162. package/lib/extensions/image-component.js +0 -348
  163. package/lib/extensions/image-component.js.map +0 -1
  164. package/lib/extensions/image.js +0 -134
  165. package/lib/extensions/image.js.map +0 -1
  166. package/lib/extensions/index.js +0 -46
  167. package/lib/extensions/index.js.map +0 -1
  168. package/lib/extensions/math.js +0 -343
  169. package/lib/extensions/math.js.map +0 -1
  170. package/lib/extensions/media.js +0 -243
  171. package/lib/extensions/media.js.map +0 -1
  172. package/lib/extensions/responseArea.js +0 -446
  173. package/lib/extensions/responseArea.js.map +0 -1
  174. package/lib/index.js +0 -30
  175. package/lib/index.js.map +0 -1
  176. package/lib/styles/editorContainerStyles.js +0 -137
  177. package/lib/styles/editorContainerStyles.js.map +0 -1
  178. package/lib/theme.js +0 -8
  179. package/lib/theme.js.map +0 -1
  180. package/lib/utils/helper.js +0 -73
  181. package/lib/utils/helper.js.map +0 -1
  182. package/lib/utils/size.js +0 -26
  183. package/lib/utils/size.js.map +0 -1
  184. package/src/__tests__/EditableHtml.test.jsx +0 -474
  185. package/src/__tests__/constants.test.js +0 -19
  186. package/src/__tests__/div-to-paragraph-conversion.test.jsx +0 -125
  187. package/src/__tests__/extensions.test.js +0 -208
  188. package/src/__tests__/index.test.jsx +0 -154
  189. package/src/__tests__/size-utils.test.js +0 -64
  190. package/src/__tests__/theme.test.js +0 -17
  191. package/src/components/CharacterPicker.jsx +0 -200
  192. package/src/components/EditableHtml.jsx +0 -438
  193. package/src/components/MenuBar.jsx +0 -549
  194. package/src/components/TiptapContainer.jsx +0 -219
  195. package/src/components/__tests__/AltDialog.test.jsx +0 -147
  196. package/src/components/__tests__/CharacterPicker.test.jsx +0 -219
  197. package/src/components/__tests__/CssIcon.test.jsx +0 -46
  198. package/src/components/__tests__/DragInTheBlank.test.jsx +0 -255
  199. package/src/components/__tests__/ExplicitConstructedResponse.test.jsx +0 -204
  200. package/src/components/__tests__/ImageToolbar.test.jsx +0 -128
  201. package/src/components/__tests__/InlineDropdown.test.jsx +0 -380
  202. package/src/components/__tests__/InsertImageHandler.test.js +0 -161
  203. package/src/components/__tests__/MediaDialog.test.jsx +0 -293
  204. package/src/components/__tests__/MediaToolbar.test.jsx +0 -74
  205. package/src/components/__tests__/MediaWrapper.test.jsx +0 -81
  206. package/src/components/__tests__/MenuBar.test.jsx +0 -249
  207. package/src/components/__tests__/RespArea.test.jsx +0 -122
  208. package/src/components/__tests__/TableIcons.test.jsx +0 -149
  209. package/src/components/__tests__/TextAlign.test.jsx +0 -167
  210. package/src/components/__tests__/TiptapContainer.test.jsx +0 -138
  211. package/src/components/__tests__/characterUtils.test.js +0 -166
  212. package/src/components/__tests__/choice.test.jsx +0 -171
  213. package/src/components/__tests__/custom-popper.test.jsx +0 -82
  214. package/src/components/__tests__/done-button.test.jsx +0 -54
  215. package/src/components/__tests__/toolbar-buttons.test.jsx +0 -234
  216. package/src/components/characters/characterUtils.js +0 -447
  217. package/src/components/characters/custom-popper.js +0 -38
  218. package/src/components/common/done-button.jsx +0 -27
  219. package/src/components/common/toolbar-buttons.jsx +0 -122
  220. package/src/components/icons/CssIcon.jsx +0 -15
  221. package/src/components/icons/RespArea.jsx +0 -71
  222. package/src/components/icons/TableIcons.jsx +0 -52
  223. package/src/components/icons/TextAlign.jsx +0 -114
  224. package/src/components/image/AltDialog.jsx +0 -82
  225. package/src/components/image/ImageToolbar.jsx +0 -99
  226. package/src/components/image/InsertImageHandler.js +0 -107
  227. package/src/components/media/MediaDialog.jsx +0 -596
  228. package/src/components/media/MediaToolbar.jsx +0 -49
  229. package/src/components/media/MediaWrapper.jsx +0 -39
  230. package/src/components/respArea/DragInTheBlank/DragInTheBlank.jsx +0 -76
  231. package/src/components/respArea/DragInTheBlank/choice.jsx +0 -256
  232. package/src/components/respArea/ExplicitConstructedResponse.jsx +0 -135
  233. package/src/components/respArea/InlineDropdown.jsx +0 -167
  234. package/src/components/respArea/MathTemplated.jsx +0 -124
  235. package/src/components/respArea/ToolbarIcon.jsx +0 -66
  236. package/src/components/respArea/__tests__/MathTemplated.test.jsx +0 -210
  237. package/src/constants.js +0 -5
  238. package/src/extensions/__tests__/css.test.js +0 -196
  239. package/src/extensions/__tests__/custom-toolbar-wrapper.test.jsx +0 -180
  240. package/src/extensions/__tests__/divNode.test.js +0 -87
  241. package/src/extensions/__tests__/ensure-empty-root-div.test.js +0 -57
  242. package/src/extensions/__tests__/ensure-list-item-content-is-div.test.js +0 -44
  243. package/src/extensions/__tests__/extended-list-item.test.js +0 -13
  244. package/src/extensions/__tests__/extended-table-cell.test.js +0 -22
  245. package/src/extensions/__tests__/extended-table.test.js +0 -183
  246. package/src/extensions/__tests__/image-component.test.jsx +0 -345
  247. package/src/extensions/__tests__/image.test.js +0 -237
  248. package/src/extensions/__tests__/math.test.js +0 -459
  249. package/src/extensions/__tests__/media-node-view.test.jsx +0 -298
  250. package/src/extensions/__tests__/media.test.js +0 -271
  251. package/src/extensions/__tests__/responseArea.test.js +0 -601
  252. package/src/extensions/css.js +0 -220
  253. package/src/extensions/custom-toolbar-wrapper.jsx +0 -78
  254. package/src/extensions/div-node.js +0 -86
  255. package/src/extensions/ensure-empty-root-div.js +0 -47
  256. package/src/extensions/ensure-list-item-content-is-div.js +0 -62
  257. package/src/extensions/extended-list-item.js +0 -10
  258. package/src/extensions/extended-table-cell.js +0 -19
  259. package/src/extensions/extended-table.js +0 -60
  260. package/src/extensions/heading-paragraph.js +0 -53
  261. package/src/extensions/image-component.jsx +0 -338
  262. package/src/extensions/image.js +0 -109
  263. package/src/extensions/index.js +0 -81
  264. package/src/extensions/math.js +0 -327
  265. package/src/extensions/media.js +0 -188
  266. package/src/extensions/responseArea.js +0 -401
  267. package/src/index.jsx +0 -5
  268. package/src/styles/editorContainerStyles.js +0 -145
  269. package/src/theme.js +0 -1
  270. package/src/utils/__tests__/helper.test.js +0 -126
  271. package/src/utils/helper.js +0 -69
  272. package/src/utils/size.js +0 -32
@@ -1,249 +0,0 @@
1
- import React from 'react';
2
- import { fireEvent, render } from '@testing-library/react';
3
- import StyledMenuBar from '../MenuBar';
4
-
5
- jest.mock('@tiptap/react', () => ({
6
- EditorContent: ({ editor }) => <div data-testid="editor-content" />,
7
- useEditorState: ({ selector }) => {
8
- const mockEditor = {
9
- isActive: jest.fn(() => false),
10
- can: jest.fn(() => ({
11
- chain: jest.fn(() => ({
12
- toggleBold: jest.fn(() => ({ run: jest.fn(() => true) })),
13
- insertTable: jest.fn(() => ({ run: jest.fn(() => true) })),
14
- toggleItalic: jest.fn(() => ({ run: jest.fn(() => true) })),
15
- toggleStrike: jest.fn(() => ({ run: jest.fn(() => true) })),
16
- toggleCode: jest.fn(() => ({ run: jest.fn(() => true) })),
17
- unsetAllMarks: jest.fn(() => ({ run: jest.fn(() => true) })),
18
- undo: jest.fn(() => ({ run: jest.fn(() => true) })),
19
- redo: jest.fn(() => ({ run: jest.fn(() => true) })),
20
- })),
21
- })),
22
- getAttributes: jest.fn(() => ({ border: '1' })),
23
- isFocused: true,
24
- state: {
25
- selection: {},
26
- },
27
- };
28
-
29
- return selector({ editor: mockEditor });
30
- },
31
- }));
32
-
33
- jest.mock('prosemirror-state', () => ({
34
- NodeSelection: jest.fn(),
35
- }));
36
-
37
- jest.mock('../CharacterPicker', () => ({
38
- CharacterIcon: ({ letter }) => <div data-testid="character-icon">{letter}</div>,
39
- CharacterPicker: ({ onClose }) => (
40
- <div data-testid="character-picker">
41
- <button onClick={onClose} data-testid="close-picker">
42
- Close
43
- </button>
44
- </div>
45
- ),
46
- }));
47
-
48
- jest.mock('../common/done-button', () => ({
49
- DoneButton: ({ onClick }) => (
50
- <button onClick={onClick} data-testid="done-button">
51
- Done
52
- </button>
53
- ),
54
- }));
55
-
56
- describe('StyledMenuBar', () => {
57
- const mockEditor = {
58
- chain: jest.fn(() => ({
59
- focus: jest.fn(() => ({
60
- insertTable: jest.fn(() => ({ run: jest.fn() })),
61
- toggleBold: jest.fn(() => ({ run: jest.fn() })),
62
- toggleItalic: jest.fn(() => ({ run: jest.fn() })),
63
- toggleStrike: jest.fn(() => ({ run: jest.fn() })),
64
- toggleCode: jest.fn(() => ({ run: jest.fn() })),
65
- toggleUnderline: jest.fn(() => ({ run: jest.fn() })),
66
- toggleSubscript: jest.fn(() => ({ run: jest.fn() })),
67
- toggleSuperscript: jest.fn(() => ({ run: jest.fn() })),
68
- setImageUploadNode: jest.fn(() => ({ run: jest.fn() })),
69
- insertMedia: jest.fn(() => ({ run: jest.fn() })),
70
- toggleHeading: jest.fn(() => ({ run: jest.fn() })),
71
- insertMath: jest.fn(() => ({ run: jest.fn() })),
72
- toggleBulletList: jest.fn(() => ({ run: jest.fn() })),
73
- toggleOrderedList: jest.fn(() => ({ run: jest.fn() })),
74
- undo: jest.fn(() => ({ run: jest.fn() })),
75
- redo: jest.fn(() => ({ run: jest.fn() })),
76
- addRowAfter: jest.fn(() => ({ run: jest.fn() })),
77
- deleteRow: jest.fn(() => ({ run: jest.fn() })),
78
- addColumnAfter: jest.fn(() => ({ run: jest.fn() })),
79
- deleteColumn: jest.fn(() => ({ run: jest.fn() })),
80
- deleteTable: jest.fn(() => ({ run: jest.fn() })),
81
- insertResponseArea: jest.fn(() => ({ run: jest.fn() })),
82
- })),
83
- })),
84
- can: jest.fn(() => ({
85
- chain: jest.fn(() => ({
86
- toggleBold: jest.fn(() => ({ run: jest.fn(() => true) })),
87
- insertTable: jest.fn(() => ({ run: jest.fn(() => true) })),
88
- undo: jest.fn(() => ({ run: jest.fn(() => true) })),
89
- redo: jest.fn(() => ({ run: jest.fn(() => true) })),
90
- })),
91
- })),
92
- isActive: jest.fn((name) => {
93
- if (name === 'bold') return true;
94
- if (name === 'italic') return false;
95
- return false;
96
- }),
97
- getAttributes: jest.fn(() => ({ border: '1' })),
98
- getHTML: jest.fn(() => '<p>Test</p>'),
99
- commands: {
100
- blur: jest.fn(),
101
- openCSSClassDialog: jest.fn(),
102
- updateAttributes: jest.fn(),
103
- },
104
- isFocused: true,
105
- state: {
106
- selection: {},
107
- },
108
- _toolbarOpened: false,
109
- };
110
-
111
- const defaultProps = {
112
- editor: mockEditor,
113
- activePlugins: ['bold', 'italic', 'underline', 'table'],
114
- toolbarOpts: {},
115
- responseAreaProps: { type: 'explicit-constructed-response' },
116
- };
117
-
118
- beforeEach(() => {
119
- jest.clearAllMocks();
120
- });
121
-
122
- it('renders without crashing', () => {
123
- const { container } = render(<StyledMenuBar {...defaultProps} />);
124
- expect(container).toBeInTheDocument();
125
- });
126
-
127
- it('renders toolbar with buttons', () => {
128
- const { container } = render(<StyledMenuBar {...defaultProps} />);
129
- const buttons = container.querySelectorAll('button');
130
- expect(buttons.length).toBeGreaterThan(0);
131
- });
132
-
133
- it('shows bold button when bold plugin is active', () => {
134
- const { container } = render(<StyledMenuBar {...defaultProps} />);
135
- expect(container).toBeInTheDocument();
136
- });
137
-
138
- it('hides buttons when isTable is true', () => {
139
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['table']} />);
140
- expect(container).toBeInTheDocument();
141
- });
142
-
143
- it('shows table buttons when in table context', () => {
144
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['table']} />);
145
- expect(container).toBeInTheDocument();
146
- });
147
-
148
- it('handles button clicks', () => {
149
- const { container } = render(<StyledMenuBar {...defaultProps} />);
150
- const button = container.querySelector('button');
151
- if (button) {
152
- fireEvent.click(button);
153
- }
154
- expect(container).toBeInTheDocument();
155
- });
156
-
157
- it('shows done button when toolbarOpts.showDone is true', () => {
158
- const { getByTestId } = render(
159
- <StyledMenuBar {...defaultProps} toolbarOpts={{ showDone: true }} onChange={jest.fn()} />,
160
- );
161
- expect(getByTestId('done-button')).toBeInTheDocument();
162
- });
163
-
164
- it('does not show done button when toolbarOpts.showDone is false', () => {
165
- const { queryByTestId } = render(<StyledMenuBar {...defaultProps} toolbarOpts={{ showDone: false }} />);
166
- expect(queryByTestId('done-button')).not.toBeInTheDocument();
167
- });
168
-
169
- it('handles done button click', () => {
170
- const onChange = jest.fn();
171
- const { getByTestId } = render(
172
- <StyledMenuBar {...defaultProps} toolbarOpts={{ showDone: true }} onChange={onChange} />,
173
- );
174
- fireEvent.click(getByTestId('done-button'));
175
- expect(onChange).toHaveBeenCalledWith('<p>Test</p>');
176
- expect(mockEditor.commands.blur).toHaveBeenCalled();
177
- });
178
-
179
- it('applies custom minWidth from toolbarOpts', () => {
180
- const { container } = render(<StyledMenuBar {...defaultProps} toolbarOpts={{ minWidth: 500 }} />);
181
- const toolbar = container.querySelector('.toolbar');
182
- expect(toolbar).toHaveStyle({ minWidth: '500px' });
183
- });
184
-
185
- it('applies hidden class when toolbarOpts.isHidden is true', () => {
186
- const { container } = render(<StyledMenuBar {...defaultProps} toolbarOpts={{ isHidden: true }} />);
187
- const toolbar = container.querySelector('.toolbar');
188
- expect(toolbar).toHaveClass('hidden');
189
- });
190
-
191
- it('shows character picker when language character button is clicked', () => {
192
- const { container, queryByTestId } = render(
193
- <StyledMenuBar {...defaultProps} activePlugins={['languageCharacters']} />,
194
- );
195
- expect(queryByTestId('character-picker')).not.toBeInTheDocument();
196
- });
197
-
198
- it('applies focused class when editor is focused', () => {
199
- const { container } = render(<StyledMenuBar {...defaultProps} toolbarOpts={{ alwaysVisible: false }} />);
200
- const toolbar = container.querySelector('.toolbar');
201
- expect(toolbar).toHaveClass('focused');
202
- });
203
-
204
- it('shows response area button when responseArea plugin is active', () => {
205
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['responseArea']} />);
206
- expect(container).toBeInTheDocument();
207
- });
208
-
209
- it('prevents default on mouse down', () => {
210
- const { container } = render(<StyledMenuBar {...defaultProps} />);
211
- const toolbar = container.querySelector('.toolbar');
212
- const event = new MouseEvent('mousedown', { bubbles: true, cancelable: true });
213
- const preventDefaultSpy = jest.spyOn(event, 'preventDefault');
214
- toolbar?.dispatchEvent(event);
215
- expect(preventDefaultSpy).toHaveBeenCalled();
216
- });
217
-
218
- it('calculates hasTextSelectionInTable correctly when selection is not empty in table', () => {
219
- // This test verifies the hasTextSelectionInTable state computation
220
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['table', 'bold', 'italic']} />);
221
- expect(container).toBeInTheDocument();
222
- });
223
-
224
- it('hides table manipulation buttons when text is selected in table', () => {
225
- // When hasTextSelectionInTable is true, table row/column buttons should be hidden
226
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['table']} />);
227
- // The component should render but table manipulation buttons should be conditional
228
- expect(container).toBeInTheDocument();
229
- });
230
-
231
- it('shows table manipulation buttons when no text is selected in table', () => {
232
- // When hasTextSelectionInTable is false, table row/column buttons should be visible
233
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['table']} />);
234
- expect(container).toBeInTheDocument();
235
- });
236
-
237
- it('shows text formatting buttons regardless of table state', () => {
238
- // Bold, italic, etc. should always be visible when their plugin is active
239
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['bold', 'italic', 'underline']} />);
240
- const buttons = container.querySelectorAll('button');
241
- expect(buttons.length).toBeGreaterThan(0);
242
- });
243
-
244
- it('does not hide text formatting buttons when in table', () => {
245
- // Verify that the removal of "|| state.isTable" condition works correctly
246
- const { container } = render(<StyledMenuBar {...defaultProps} activePlugins={['table', 'bold', 'italic']} />);
247
- expect(container).toBeInTheDocument();
248
- });
249
- });
@@ -1,122 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
- import { Chevron, GripIcon, ToolbarIcon } from '../icons/RespArea';
4
-
5
- describe('Chevron', () => {
6
- it('renders without crashing', () => {
7
- const { container } = render(<Chevron />);
8
- expect(container).toBeInTheDocument();
9
- });
10
-
11
- it('rotates 0 degrees for right direction (default)', () => {
12
- const { container } = render(<Chevron direction="right" />);
13
- const svg = container.querySelector('svg');
14
- expect(svg).toHaveStyle({ transform: 'rotate(0deg)' });
15
- });
16
-
17
- it('rotates 90 degrees for down direction', () => {
18
- const { container } = render(<Chevron direction="down" />);
19
- const svg = container.querySelector('svg');
20
- expect(svg).toHaveStyle({ transform: 'rotate(90deg)' });
21
- });
22
-
23
- it('rotates -90 degrees for up direction', () => {
24
- const { container } = render(<Chevron direction="up" />);
25
- const svg = container.querySelector('svg');
26
- expect(svg).toHaveStyle({ transform: 'rotate(-90deg)' });
27
- });
28
-
29
- it('rotates 180 degrees for left direction', () => {
30
- const { container } = render(<Chevron direction="left" />);
31
- const svg = container.querySelector('svg');
32
- expect(svg).toHaveStyle({ transform: 'rotate(180deg)' });
33
- });
34
-
35
- it('applies custom style prop', () => {
36
- const customStyle = { color: 'red', fontSize: '20px' };
37
- const { container } = render(<Chevron style={customStyle} />);
38
- const svg = container.querySelector('svg');
39
- expect(svg).toHaveStyle({ color: 'red', fontSize: '20px' });
40
- });
41
-
42
- it('defaults to 0 rotation when no direction specified', () => {
43
- const { container } = render(<Chevron />);
44
- const svg = container.querySelector('svg');
45
- expect(svg).toHaveStyle({ transform: 'rotate(0deg)' });
46
- });
47
- });
48
-
49
- describe('GripIcon', () => {
50
- it('renders without crashing', () => {
51
- const { container } = render(<GripIcon />);
52
- expect(container).toBeInTheDocument();
53
- });
54
-
55
- it('renders two MoreVert icons', () => {
56
- const { container } = render(<GripIcon />);
57
- const moreVertIcons = container.querySelectorAll('svg');
58
- expect(moreVertIcons.length).toBe(2);
59
- });
60
-
61
- it('applies custom style prop', () => {
62
- const customStyle = { color: 'blue' };
63
- const { container } = render(<GripIcon style={customStyle} />);
64
- const span = container.querySelector('span');
65
- expect(span).toHaveStyle({ color: 'blue' });
66
- });
67
-
68
- it('applies negative margin to first icon', () => {
69
- const { container } = render(<GripIcon />);
70
- const firstIcon = container.querySelector('svg');
71
- expect(firstIcon).toHaveStyle({ margin: '0 -16px' });
72
- });
73
- });
74
-
75
- describe('ToolbarIcon', () => {
76
- it('renders without crashing', () => {
77
- const { container } = render(<ToolbarIcon />);
78
- expect(container).toBeInTheDocument();
79
- });
80
-
81
- it('renders "+ Response Area" text', () => {
82
- const { getByText } = render(<ToolbarIcon />);
83
- expect(getByText('+ Response Area')).toBeInTheDocument();
84
- });
85
-
86
- it('applies correct font family', () => {
87
- const { getByText } = render(<ToolbarIcon />);
88
- const element = getByText('+ Response Area');
89
- // Font family is applied via styled component, just verify text renders
90
- expect(element).toBeInTheDocument();
91
- });
92
-
93
- it('applies bold font weight', () => {
94
- const { getByText } = render(<ToolbarIcon />);
95
- const element = getByText('+ Response Area');
96
- expect(element).toHaveStyle({ fontWeight: 'bold' });
97
- });
98
-
99
- it('has correct dimensions', () => {
100
- const { getByText } = render(<ToolbarIcon />);
101
- const element = getByText('+ Response Area');
102
- expect(element).toHaveStyle({ width: '110px', height: '28px' });
103
- });
104
-
105
- it('has relative positioning', () => {
106
- const { getByText } = render(<ToolbarIcon />);
107
- const element = getByText('+ Response Area');
108
- expect(element).toHaveStyle({ position: 'relative' });
109
- });
110
-
111
- it('has nowrap white space', () => {
112
- const { getByText } = render(<ToolbarIcon />);
113
- const element = getByText('+ Response Area');
114
- expect(element).toHaveStyle({ whiteSpace: 'nowrap' });
115
- });
116
-
117
- it('has top offset', () => {
118
- const { getByText } = render(<ToolbarIcon />);
119
- const element = getByText('+ Response Area');
120
- expect(element).toHaveStyle({ top: '7px' });
121
- });
122
- });
@@ -1,149 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
- import { AddColumn, AddRow, RemoveColumn, RemoveRow, RemoveTable } from '../icons/TableIcons';
4
-
5
- describe('AddRow', () => {
6
- it('renders without crashing', () => {
7
- const { container } = render(<AddRow />);
8
- expect(container).toBeInTheDocument();
9
- });
10
-
11
- it('renders SVG', () => {
12
- const { container } = render(<AddRow />);
13
- const svg = container.querySelector('svg');
14
- expect(svg).toBeInTheDocument();
15
- });
16
-
17
- it('has correct viewBox', () => {
18
- const { container } = render(<AddRow />);
19
- const svg = container.querySelector('svg');
20
- expect(svg).toHaveAttribute('viewBox', '0 0 24 24');
21
- });
22
-
23
- it('has correct dimensions', () => {
24
- const { container } = render(<AddRow />);
25
- const svg = container.querySelector('svg');
26
- expect(svg).toHaveAttribute('width', '24');
27
- expect(svg).toHaveAttribute('height', '24');
28
- });
29
-
30
- it('contains path element', () => {
31
- const { container } = render(<AddRow />);
32
- const path = container.querySelector('path');
33
- expect(path).toBeInTheDocument();
34
- });
35
- });
36
-
37
- describe('RemoveRow', () => {
38
- it('renders without crashing', () => {
39
- const { container } = render(<RemoveRow />);
40
- expect(container).toBeInTheDocument();
41
- });
42
-
43
- it('renders SVG', () => {
44
- const { container } = render(<RemoveRow />);
45
- const svg = container.querySelector('svg');
46
- expect(svg).toBeInTheDocument();
47
- });
48
-
49
- it('has correct viewBox', () => {
50
- const { container } = render(<RemoveRow />);
51
- const svg = container.querySelector('svg');
52
- expect(svg).toHaveAttribute('viewBox', '0 0 24 24');
53
- });
54
-
55
- it('contains path element', () => {
56
- const { container } = render(<RemoveRow />);
57
- const path = container.querySelector('path');
58
- expect(path).toBeInTheDocument();
59
- });
60
- });
61
-
62
- describe('AddColumn', () => {
63
- it('renders without crashing', () => {
64
- const { container } = render(<AddColumn />);
65
- expect(container).toBeInTheDocument();
66
- });
67
-
68
- it('renders SVG', () => {
69
- const { container } = render(<AddColumn />);
70
- const svg = container.querySelector('svg');
71
- expect(svg).toBeInTheDocument();
72
- });
73
-
74
- it('has correct viewBox', () => {
75
- const { container } = render(<AddColumn />);
76
- const svg = container.querySelector('svg');
77
- expect(svg).toHaveAttribute('viewBox', '0 0 24 24');
78
- });
79
-
80
- it('has correct dimensions', () => {
81
- const { container } = render(<AddColumn />);
82
- const svg = container.querySelector('svg');
83
- expect(svg).toHaveAttribute('width', '24');
84
- expect(svg).toHaveAttribute('height', '24');
85
- });
86
-
87
- it('contains path element', () => {
88
- const { container } = render(<AddColumn />);
89
- const path = container.querySelector('path');
90
- expect(path).toBeInTheDocument();
91
- });
92
- });
93
-
94
- describe('RemoveColumn', () => {
95
- it('renders without crashing', () => {
96
- const { container } = render(<RemoveColumn />);
97
- expect(container).toBeInTheDocument();
98
- });
99
-
100
- it('renders SVG', () => {
101
- const { container } = render(<RemoveColumn />);
102
- const svg = container.querySelector('svg');
103
- expect(svg).toBeInTheDocument();
104
- });
105
-
106
- it('has correct viewBox', () => {
107
- const { container } = render(<RemoveColumn />);
108
- const svg = container.querySelector('svg');
109
- expect(svg).toHaveAttribute('viewBox', '0 0 24 24');
110
- });
111
-
112
- it('contains path element', () => {
113
- const { container } = render(<RemoveColumn />);
114
- const path = container.querySelector('path');
115
- expect(path).toBeInTheDocument();
116
- });
117
- });
118
-
119
- describe('RemoveTable', () => {
120
- it('renders without crashing', () => {
121
- const { container } = render(<RemoveTable />);
122
- expect(container).toBeInTheDocument();
123
- });
124
-
125
- it('renders SVG', () => {
126
- const { container } = render(<RemoveTable />);
127
- const svg = container.querySelector('svg');
128
- expect(svg).toBeInTheDocument();
129
- });
130
-
131
- it('has correct viewBox', () => {
132
- const { container } = render(<RemoveTable />);
133
- const svg = container.querySelector('svg');
134
- expect(svg).toHaveAttribute('viewBox', '0 0 24 24');
135
- });
136
-
137
- it('has correct dimensions', () => {
138
- const { container } = render(<RemoveTable />);
139
- const svg = container.querySelector('svg');
140
- expect(svg).toHaveAttribute('width', '24');
141
- expect(svg).toHaveAttribute('height', '24');
142
- });
143
-
144
- it('contains path element', () => {
145
- const { container } = render(<RemoveTable />);
146
- const path = container.querySelector('path');
147
- expect(path).toBeInTheDocument();
148
- });
149
- });
@@ -1,167 +0,0 @@
1
- import React from 'react';
2
- import { fireEvent, render } from '@testing-library/react';
3
- import TextAlignIcon, { AlignCenter, AlignJustify, AlignLeft, AlignRight } from '../icons/TextAlign';
4
-
5
- jest.mock('@mui/material/ListItem', () => ({
6
- __esModule: true,
7
- default: ({ children, onClick, value, ...props }) => (
8
- <div {...props} value={value} onClick={onClick} role="listitem">
9
- {children}
10
- </div>
11
- ),
12
- }));
13
-
14
- describe('AlignLeft', () => {
15
- it('renders SVG', () => {
16
- const { container } = render(<AlignLeft />);
17
- expect(container.querySelector('svg')).toBeInTheDocument();
18
- });
19
-
20
- it('has correct viewBox', () => {
21
- const { container } = render(<AlignLeft />);
22
- const svg = container.querySelector('svg');
23
- expect(svg).toHaveAttribute('viewBox', '0 0 66 66');
24
- });
25
- });
26
-
27
- describe('AlignRight', () => {
28
- it('renders SVG', () => {
29
- const { container } = render(<AlignRight />);
30
- expect(container.querySelector('svg')).toBeInTheDocument();
31
- });
32
-
33
- it('has correct viewBox', () => {
34
- const { container } = render(<AlignRight />);
35
- const svg = container.querySelector('svg');
36
- expect(svg).toHaveAttribute('viewBox', '0 0 66 66');
37
- });
38
- });
39
-
40
- describe('AlignCenter', () => {
41
- it('renders SVG', () => {
42
- const { container } = render(<AlignCenter />);
43
- expect(container.querySelector('svg')).toBeInTheDocument();
44
- });
45
-
46
- it('has correct viewBox', () => {
47
- const { container } = render(<AlignCenter />);
48
- const svg = container.querySelector('svg');
49
- expect(svg).toHaveAttribute('viewBox', '0 0 66 66');
50
- });
51
- });
52
-
53
- describe('AlignJustify', () => {
54
- it('renders SVG', () => {
55
- const { container } = render(<AlignJustify />);
56
- expect(container.querySelector('svg')).toBeInTheDocument();
57
- });
58
-
59
- it('has correct viewBox', () => {
60
- const { container } = render(<AlignJustify />);
61
- const svg = container.querySelector('svg');
62
- expect(svg).toHaveAttribute('viewBox', '0 0 66 66');
63
- });
64
- });
65
-
66
- describe('TextAlignIcon', () => {
67
- const mockEditor = {
68
- isActive: jest.fn(),
69
- commands: {
70
- setTextAlign: jest.fn(),
71
- },
72
- };
73
-
74
- beforeEach(() => {
75
- jest.clearAllMocks();
76
- });
77
-
78
- it('renders without crashing', () => {
79
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
80
- expect(container).toBeInTheDocument();
81
- });
82
-
83
- it('shows AlignLeft icon by default', () => {
84
- mockEditor.isActive.mockReturnValue(false);
85
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
86
- expect(container.querySelector('svg')).toBeInTheDocument();
87
- });
88
-
89
- it('shows AlignRight icon when right alignment is active', () => {
90
- mockEditor.isActive.mockImplementation((options) => options?.textAlign === 'right');
91
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
92
- expect(container.querySelector('svg')).toBeInTheDocument();
93
- });
94
-
95
- it('shows AlignCenter icon when center alignment is active', () => {
96
- mockEditor.isActive.mockImplementation((options) => options?.textAlign === 'center');
97
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
98
- expect(container.querySelector('svg')).toBeInTheDocument();
99
- });
100
-
101
- it('shows AlignJustify icon when justify alignment is active', () => {
102
- mockEditor.isActive.mockImplementation((options) => options?.textAlign === 'justify');
103
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
104
- expect(container.querySelector('svg')).toBeInTheDocument();
105
- });
106
-
107
- it('toggles dropdown on click', () => {
108
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
109
- const button = container.querySelector('div[style*="display: flex"]');
110
- fireEvent.click(button);
111
- expect(container).toBeInTheDocument();
112
- });
113
-
114
- it('applies alignment when list item is clicked', () => {
115
- const { container, getByLabelText } = render(<TextAlignIcon editor={mockEditor} />);
116
- const button = container.querySelector('div[style*="display: flex"]');
117
- fireEvent.click(button);
118
-
119
- const leftButton = getByLabelText('Align text left');
120
- fireEvent.click(leftButton);
121
- expect(mockEditor.commands.setTextAlign).toHaveBeenCalledWith('left');
122
- });
123
-
124
- it('prevents default and stops propagation on mouse down', () => {
125
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
126
- const button = container.querySelector('div[style*="display"]');
127
- if (button) {
128
- fireEvent.mouseDown(button);
129
- // Just verify the event handler didn't throw
130
- expect(container).toBeInTheDocument();
131
- } else {
132
- expect(container).toBeInTheDocument();
133
- }
134
- });
135
-
136
- it('shows dropdown arrow', () => {
137
- const { container } = render(<TextAlignIcon editor={mockEditor} />);
138
- const span = container.querySelector('span[style*="marginLeft"]');
139
- if (span) {
140
- expect(span).toBeInTheDocument();
141
- } else {
142
- // Arrow might be rendered differently in test environment
143
- expect(container).toBeInTheDocument();
144
- }
145
- });
146
-
147
- it('closes dropdown after selecting alignment', () => {
148
- const { container, getByLabelText } = render(<TextAlignIcon editor={mockEditor} />);
149
- const button = container.querySelector('div[style*="display: flex"]');
150
- fireEvent.click(button);
151
-
152
- const centerButton = getByLabelText('Align text center');
153
- fireEvent.click(centerButton);
154
- expect(mockEditor.commands.setTextAlign).toHaveBeenCalledWith('center');
155
- });
156
-
157
- it('renders all alignment options in dropdown', () => {
158
- const { container, getByLabelText } = render(<TextAlignIcon editor={mockEditor} />);
159
- const button = container.querySelector('div[style*="display: flex"]');
160
- fireEvent.click(button);
161
-
162
- expect(getByLabelText('Align text left')).toBeInTheDocument();
163
- expect(getByLabelText('Align text center')).toBeInTheDocument();
164
- expect(getByLabelText('Align text right')).toBeInTheDocument();
165
- expect(getByLabelText('Justify text')).toBeInTheDocument();
166
- });
167
- });