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

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 (273) 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 +64 -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/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +16 -0
  85. package/dist/styles/editorContainerStyles.d.ts +134 -0
  86. package/dist/theme.d.ts +9 -0
  87. package/dist/utils/helper.d.ts +9 -0
  88. package/dist/utils/helper.js +27 -0
  89. package/dist/utils/size.d.ts +9 -0
  90. package/dist/utils/size.js +14 -0
  91. package/package.json +56 -40
  92. package/CHANGELOG.json +0 -32
  93. package/CHANGELOG.md +0 -2532
  94. package/LICENSE.md +0 -5
  95. package/lib/components/CharacterPicker.js +0 -195
  96. package/lib/components/CharacterPicker.js.map +0 -1
  97. package/lib/components/EditableHtml.js +0 -375
  98. package/lib/components/EditableHtml.js.map +0 -1
  99. package/lib/components/MenuBar.js +0 -693
  100. package/lib/components/MenuBar.js.map +0 -1
  101. package/lib/components/TiptapContainer.js +0 -234
  102. package/lib/components/TiptapContainer.js.map +0 -1
  103. package/lib/components/characters/characterUtils.js +0 -378
  104. package/lib/components/characters/characterUtils.js.map +0 -1
  105. package/lib/components/characters/custom-popper.js +0 -44
  106. package/lib/components/characters/custom-popper.js.map +0 -1
  107. package/lib/components/common/done-button.js +0 -34
  108. package/lib/components/common/done-button.js.map +0 -1
  109. package/lib/components/common/toolbar-buttons.js +0 -144
  110. package/lib/components/common/toolbar-buttons.js.map +0 -1
  111. package/lib/components/icons/CssIcon.js +0 -25
  112. package/lib/components/icons/CssIcon.js.map +0 -1
  113. package/lib/components/icons/RespArea.js +0 -72
  114. package/lib/components/icons/RespArea.js.map +0 -1
  115. package/lib/components/icons/TableIcons.js +0 -53
  116. package/lib/components/icons/TableIcons.js.map +0 -1
  117. package/lib/components/icons/TextAlign.js +0 -157
  118. package/lib/components/icons/TextAlign.js.map +0 -1
  119. package/lib/components/image/AltDialog.js +0 -98
  120. package/lib/components/image/AltDialog.js.map +0 -1
  121. package/lib/components/image/ImageToolbar.js +0 -137
  122. package/lib/components/image/ImageToolbar.js.map +0 -1
  123. package/lib/components/image/InsertImageHandler.js +0 -135
  124. package/lib/components/image/InsertImageHandler.js.map +0 -1
  125. package/lib/components/media/MediaDialog.js +0 -594
  126. package/lib/components/media/MediaDialog.js.map +0 -1
  127. package/lib/components/media/MediaToolbar.js +0 -74
  128. package/lib/components/media/MediaToolbar.js.map +0 -1
  129. package/lib/components/media/MediaWrapper.js +0 -67
  130. package/lib/components/media/MediaWrapper.js.map +0 -1
  131. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +0 -84
  132. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +0 -1
  133. package/lib/components/respArea/DragInTheBlank/choice.js +0 -250
  134. package/lib/components/respArea/DragInTheBlank/choice.js.map +0 -1
  135. package/lib/components/respArea/ExplicitConstructedResponse.js +0 -136
  136. package/lib/components/respArea/ExplicitConstructedResponse.js.map +0 -1
  137. package/lib/components/respArea/InlineDropdown.js +0 -165
  138. package/lib/components/respArea/InlineDropdown.js.map +0 -1
  139. package/lib/components/respArea/MathTemplated.js +0 -130
  140. package/lib/components/respArea/MathTemplated.js.map +0 -1
  141. package/lib/components/respArea/ToolbarIcon.js +0 -81
  142. package/lib/components/respArea/ToolbarIcon.js.map +0 -1
  143. package/lib/constants.js +0 -11
  144. package/lib/constants.js.map +0 -1
  145. package/lib/extensions/css.js +0 -217
  146. package/lib/extensions/css.js.map +0 -1
  147. package/lib/extensions/custom-toolbar-wrapper.js +0 -92
  148. package/lib/extensions/custom-toolbar-wrapper.js.map +0 -1
  149. package/lib/extensions/div-node.js +0 -83
  150. package/lib/extensions/div-node.js.map +0 -1
  151. package/lib/extensions/ensure-empty-root-div.js +0 -48
  152. package/lib/extensions/ensure-empty-root-div.js.map +0 -1
  153. package/lib/extensions/ensure-list-item-content-is-div.js +0 -64
  154. package/lib/extensions/ensure-list-item-content-is-div.js.map +0 -1
  155. package/lib/extensions/extended-list-item.js +0 -15
  156. package/lib/extensions/extended-list-item.js.map +0 -1
  157. package/lib/extensions/extended-table-cell.js +0 -22
  158. package/lib/extensions/extended-table-cell.js.map +0 -1
  159. package/lib/extensions/extended-table.js +0 -75
  160. package/lib/extensions/extended-table.js.map +0 -1
  161. package/lib/extensions/heading-paragraph.js +0 -61
  162. package/lib/extensions/heading-paragraph.js.map +0 -1
  163. package/lib/extensions/image-component.js +0 -348
  164. package/lib/extensions/image-component.js.map +0 -1
  165. package/lib/extensions/image.js +0 -134
  166. package/lib/extensions/image.js.map +0 -1
  167. package/lib/extensions/index.js +0 -46
  168. package/lib/extensions/index.js.map +0 -1
  169. package/lib/extensions/math.js +0 -343
  170. package/lib/extensions/math.js.map +0 -1
  171. package/lib/extensions/media.js +0 -243
  172. package/lib/extensions/media.js.map +0 -1
  173. package/lib/extensions/responseArea.js +0 -446
  174. package/lib/extensions/responseArea.js.map +0 -1
  175. package/lib/index.js +0 -30
  176. package/lib/index.js.map +0 -1
  177. package/lib/styles/editorContainerStyles.js +0 -137
  178. package/lib/styles/editorContainerStyles.js.map +0 -1
  179. package/lib/theme.js +0 -8
  180. package/lib/theme.js.map +0 -1
  181. package/lib/utils/helper.js +0 -73
  182. package/lib/utils/helper.js.map +0 -1
  183. package/lib/utils/size.js +0 -26
  184. package/lib/utils/size.js.map +0 -1
  185. package/src/__tests__/EditableHtml.test.jsx +0 -474
  186. package/src/__tests__/constants.test.js +0 -19
  187. package/src/__tests__/div-to-paragraph-conversion.test.jsx +0 -125
  188. package/src/__tests__/extensions.test.js +0 -208
  189. package/src/__tests__/index.test.jsx +0 -154
  190. package/src/__tests__/size-utils.test.js +0 -64
  191. package/src/__tests__/theme.test.js +0 -17
  192. package/src/components/CharacterPicker.jsx +0 -200
  193. package/src/components/EditableHtml.jsx +0 -438
  194. package/src/components/MenuBar.jsx +0 -549
  195. package/src/components/TiptapContainer.jsx +0 -219
  196. package/src/components/__tests__/AltDialog.test.jsx +0 -147
  197. package/src/components/__tests__/CharacterPicker.test.jsx +0 -219
  198. package/src/components/__tests__/CssIcon.test.jsx +0 -46
  199. package/src/components/__tests__/DragInTheBlank.test.jsx +0 -255
  200. package/src/components/__tests__/ExplicitConstructedResponse.test.jsx +0 -204
  201. package/src/components/__tests__/ImageToolbar.test.jsx +0 -128
  202. package/src/components/__tests__/InlineDropdown.test.jsx +0 -380
  203. package/src/components/__tests__/InsertImageHandler.test.js +0 -161
  204. package/src/components/__tests__/MediaDialog.test.jsx +0 -293
  205. package/src/components/__tests__/MediaToolbar.test.jsx +0 -74
  206. package/src/components/__tests__/MediaWrapper.test.jsx +0 -81
  207. package/src/components/__tests__/MenuBar.test.jsx +0 -249
  208. package/src/components/__tests__/RespArea.test.jsx +0 -122
  209. package/src/components/__tests__/TableIcons.test.jsx +0 -149
  210. package/src/components/__tests__/TextAlign.test.jsx +0 -167
  211. package/src/components/__tests__/TiptapContainer.test.jsx +0 -138
  212. package/src/components/__tests__/characterUtils.test.js +0 -166
  213. package/src/components/__tests__/choice.test.jsx +0 -171
  214. package/src/components/__tests__/custom-popper.test.jsx +0 -82
  215. package/src/components/__tests__/done-button.test.jsx +0 -54
  216. package/src/components/__tests__/toolbar-buttons.test.jsx +0 -234
  217. package/src/components/characters/characterUtils.js +0 -447
  218. package/src/components/characters/custom-popper.js +0 -38
  219. package/src/components/common/done-button.jsx +0 -27
  220. package/src/components/common/toolbar-buttons.jsx +0 -122
  221. package/src/components/icons/CssIcon.jsx +0 -15
  222. package/src/components/icons/RespArea.jsx +0 -71
  223. package/src/components/icons/TableIcons.jsx +0 -52
  224. package/src/components/icons/TextAlign.jsx +0 -114
  225. package/src/components/image/AltDialog.jsx +0 -82
  226. package/src/components/image/ImageToolbar.jsx +0 -99
  227. package/src/components/image/InsertImageHandler.js +0 -107
  228. package/src/components/media/MediaDialog.jsx +0 -596
  229. package/src/components/media/MediaToolbar.jsx +0 -49
  230. package/src/components/media/MediaWrapper.jsx +0 -39
  231. package/src/components/respArea/DragInTheBlank/DragInTheBlank.jsx +0 -76
  232. package/src/components/respArea/DragInTheBlank/choice.jsx +0 -256
  233. package/src/components/respArea/ExplicitConstructedResponse.jsx +0 -135
  234. package/src/components/respArea/InlineDropdown.jsx +0 -167
  235. package/src/components/respArea/MathTemplated.jsx +0 -124
  236. package/src/components/respArea/ToolbarIcon.jsx +0 -66
  237. package/src/components/respArea/__tests__/MathTemplated.test.jsx +0 -210
  238. package/src/constants.js +0 -5
  239. package/src/extensions/__tests__/css.test.js +0 -196
  240. package/src/extensions/__tests__/custom-toolbar-wrapper.test.jsx +0 -180
  241. package/src/extensions/__tests__/divNode.test.js +0 -87
  242. package/src/extensions/__tests__/ensure-empty-root-div.test.js +0 -57
  243. package/src/extensions/__tests__/ensure-list-item-content-is-div.test.js +0 -44
  244. package/src/extensions/__tests__/extended-list-item.test.js +0 -13
  245. package/src/extensions/__tests__/extended-table-cell.test.js +0 -22
  246. package/src/extensions/__tests__/extended-table.test.js +0 -183
  247. package/src/extensions/__tests__/image-component.test.jsx +0 -345
  248. package/src/extensions/__tests__/image.test.js +0 -237
  249. package/src/extensions/__tests__/math.test.js +0 -459
  250. package/src/extensions/__tests__/media-node-view.test.jsx +0 -298
  251. package/src/extensions/__tests__/media.test.js +0 -271
  252. package/src/extensions/__tests__/responseArea.test.js +0 -601
  253. package/src/extensions/css.js +0 -220
  254. package/src/extensions/custom-toolbar-wrapper.jsx +0 -78
  255. package/src/extensions/div-node.js +0 -86
  256. package/src/extensions/ensure-empty-root-div.js +0 -47
  257. package/src/extensions/ensure-list-item-content-is-div.js +0 -62
  258. package/src/extensions/extended-list-item.js +0 -10
  259. package/src/extensions/extended-table-cell.js +0 -19
  260. package/src/extensions/extended-table.js +0 -60
  261. package/src/extensions/heading-paragraph.js +0 -53
  262. package/src/extensions/image-component.jsx +0 -338
  263. package/src/extensions/image.js +0 -109
  264. package/src/extensions/index.js +0 -81
  265. package/src/extensions/math.js +0 -327
  266. package/src/extensions/media.js +0 -188
  267. package/src/extensions/responseArea.js +0 -401
  268. package/src/index.jsx +0 -5
  269. package/src/styles/editorContainerStyles.js +0 -145
  270. package/src/theme.js +0 -1
  271. package/src/utils/__tests__/helper.test.js +0 -126
  272. package/src/utils/helper.js +0 -69
  273. 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
- });