@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.
- package/dist/components/CharacterPicker.d.ts +31 -0
- package/dist/components/CharacterPicker.js +131 -0
- package/dist/components/EditableHtml.d.ts +11 -0
- package/dist/components/EditableHtml.js +291 -0
- package/dist/components/MenuBar.d.ts +11 -0
- package/dist/components/MenuBar.js +462 -0
- package/dist/components/TiptapContainer.d.ts +11 -0
- package/dist/components/TiptapContainer.js +154 -0
- package/dist/components/characters/characterUtils.d.ts +35 -0
- package/dist/components/characters/characterUtils.js +465 -0
- package/dist/components/characters/custom-popper.d.ts +14 -0
- package/dist/components/characters/custom-popper.js +32 -0
- package/dist/components/common/done-button.d.ts +30 -0
- package/dist/components/common/done-button.js +26 -0
- package/dist/components/common/toolbar-buttons.d.ts +38 -0
- package/dist/components/common/toolbar-buttons.js +91 -0
- package/dist/components/icons/CssIcon.d.ts +11 -0
- package/dist/components/icons/CssIcon.js +14 -0
- package/dist/components/icons/RespArea.d.ts +26 -0
- package/dist/components/icons/RespArea.js +42 -0
- package/dist/components/icons/TableIcons.d.ts +14 -0
- package/dist/components/icons/TableIcons.js +32 -0
- package/dist/components/icons/TextAlign.d.ts +18 -0
- package/dist/components/icons/TextAlign.js +134 -0
- package/dist/components/image/AltDialog.d.ts +22 -0
- package/dist/components/image/AltDialog.js +61 -0
- package/dist/components/image/ImageToolbar.d.ts +24 -0
- package/dist/components/image/ImageToolbar.js +80 -0
- package/dist/components/image/InsertImageHandler.d.ts +32 -0
- package/dist/components/image/InsertImageHandler.js +53 -0
- package/dist/components/media/MediaDialog.d.ts +43 -0
- package/dist/components/media/MediaDialog.js +389 -0
- package/dist/components/media/MediaToolbar.d.ts +19 -0
- package/dist/components/media/MediaToolbar.js +41 -0
- package/dist/components/media/MediaWrapper.d.ts +19 -0
- package/dist/components/respArea/DragInTheBlank/DragInTheBlank.d.ts +23 -0
- package/dist/components/respArea/DragInTheBlank/DragInTheBlank.js +58 -0
- package/dist/components/respArea/DragInTheBlank/choice.d.ts +56 -0
- package/dist/components/respArea/DragInTheBlank/choice.js +156 -0
- package/dist/components/respArea/ExplicitConstructedResponse.d.ts +20 -0
- package/dist/components/respArea/ExplicitConstructedResponse.js +83 -0
- package/dist/components/respArea/InlineDropdown.d.ts +18 -0
- package/dist/components/respArea/InlineDropdown.js +119 -0
- package/dist/components/respArea/MathTemplated.d.ts +19 -0
- package/dist/components/respArea/MathTemplated.js +97 -0
- package/dist/components/respArea/ToolbarIcon.d.ts +14 -0
- package/dist/components/respArea/ToolbarIcon.js +17 -0
- package/dist/components/respArea/inlineDropdownUtils.d.ts +15 -0
- package/dist/components/respArea/inlineDropdownUtils.js +15 -0
- package/dist/constants.d.ts +13 -0
- package/dist/constants.js +4 -0
- package/dist/extensions/css.d.ts +11 -0
- package/dist/extensions/css.js +115 -0
- package/dist/extensions/custom-toolbar-wrapper.d.ts +11 -0
- package/dist/extensions/custom-toolbar-wrapper.js +61 -0
- package/dist/extensions/div-node.d.ts +10 -0
- package/dist/extensions/div-node.js +42 -0
- package/dist/extensions/ensure-empty-root-div.d.ts +14 -0
- package/dist/extensions/ensure-empty-root-div.js +24 -0
- package/dist/extensions/ensure-list-item-content-is-div.d.ts +15 -0
- package/dist/extensions/ensure-list-item-content-is-div.js +31 -0
- package/dist/extensions/extended-list-item.d.ts +13 -0
- package/dist/extensions/extended-list-item.js +5 -0
- package/dist/extensions/extended-table-cell.d.ts +10 -0
- package/dist/extensions/extended-table-cell.js +6 -0
- package/dist/extensions/extended-table.d.ts +17 -0
- package/dist/extensions/extended-table.js +34 -0
- package/dist/extensions/heading-paragraph.d.ts +17 -0
- package/dist/extensions/heading-paragraph.js +30 -0
- package/dist/extensions/image-component.d.ts +22 -0
- package/dist/extensions/image-component.js +220 -0
- package/dist/extensions/image.d.ts +10 -0
- package/dist/extensions/image.js +68 -0
- package/dist/extensions/index.d.ts +16 -0
- package/dist/extensions/index.js +64 -0
- package/dist/extensions/math.d.ts +15 -0
- package/dist/extensions/math.js +158 -0
- package/dist/extensions/media.d.ts +19 -0
- package/dist/extensions/media.js +149 -0
- package/dist/extensions/responseArea.d.ts +27 -0
- package/dist/extensions/responseArea.js +259 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.js +7 -0
- package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +16 -0
- package/dist/styles/editorContainerStyles.d.ts +134 -0
- package/dist/theme.d.ts +9 -0
- package/dist/utils/helper.d.ts +9 -0
- package/dist/utils/helper.js +27 -0
- package/dist/utils/size.d.ts +9 -0
- package/dist/utils/size.js +14 -0
- package/package.json +56 -40
- package/CHANGELOG.json +0 -32
- package/CHANGELOG.md +0 -2532
- package/LICENSE.md +0 -5
- package/lib/components/CharacterPicker.js +0 -195
- package/lib/components/CharacterPicker.js.map +0 -1
- package/lib/components/EditableHtml.js +0 -375
- package/lib/components/EditableHtml.js.map +0 -1
- package/lib/components/MenuBar.js +0 -693
- package/lib/components/MenuBar.js.map +0 -1
- package/lib/components/TiptapContainer.js +0 -234
- package/lib/components/TiptapContainer.js.map +0 -1
- package/lib/components/characters/characterUtils.js +0 -378
- package/lib/components/characters/characterUtils.js.map +0 -1
- package/lib/components/characters/custom-popper.js +0 -44
- package/lib/components/characters/custom-popper.js.map +0 -1
- package/lib/components/common/done-button.js +0 -34
- package/lib/components/common/done-button.js.map +0 -1
- package/lib/components/common/toolbar-buttons.js +0 -144
- package/lib/components/common/toolbar-buttons.js.map +0 -1
- package/lib/components/icons/CssIcon.js +0 -25
- package/lib/components/icons/CssIcon.js.map +0 -1
- package/lib/components/icons/RespArea.js +0 -72
- package/lib/components/icons/RespArea.js.map +0 -1
- package/lib/components/icons/TableIcons.js +0 -53
- package/lib/components/icons/TableIcons.js.map +0 -1
- package/lib/components/icons/TextAlign.js +0 -157
- package/lib/components/icons/TextAlign.js.map +0 -1
- package/lib/components/image/AltDialog.js +0 -98
- package/lib/components/image/AltDialog.js.map +0 -1
- package/lib/components/image/ImageToolbar.js +0 -137
- package/lib/components/image/ImageToolbar.js.map +0 -1
- package/lib/components/image/InsertImageHandler.js +0 -135
- package/lib/components/image/InsertImageHandler.js.map +0 -1
- package/lib/components/media/MediaDialog.js +0 -594
- package/lib/components/media/MediaDialog.js.map +0 -1
- package/lib/components/media/MediaToolbar.js +0 -74
- package/lib/components/media/MediaToolbar.js.map +0 -1
- package/lib/components/media/MediaWrapper.js +0 -67
- package/lib/components/media/MediaWrapper.js.map +0 -1
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +0 -84
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +0 -1
- package/lib/components/respArea/DragInTheBlank/choice.js +0 -250
- package/lib/components/respArea/DragInTheBlank/choice.js.map +0 -1
- package/lib/components/respArea/ExplicitConstructedResponse.js +0 -136
- package/lib/components/respArea/ExplicitConstructedResponse.js.map +0 -1
- package/lib/components/respArea/InlineDropdown.js +0 -165
- package/lib/components/respArea/InlineDropdown.js.map +0 -1
- package/lib/components/respArea/MathTemplated.js +0 -130
- package/lib/components/respArea/MathTemplated.js.map +0 -1
- package/lib/components/respArea/ToolbarIcon.js +0 -81
- package/lib/components/respArea/ToolbarIcon.js.map +0 -1
- package/lib/constants.js +0 -11
- package/lib/constants.js.map +0 -1
- package/lib/extensions/css.js +0 -217
- package/lib/extensions/css.js.map +0 -1
- package/lib/extensions/custom-toolbar-wrapper.js +0 -92
- package/lib/extensions/custom-toolbar-wrapper.js.map +0 -1
- package/lib/extensions/div-node.js +0 -83
- package/lib/extensions/div-node.js.map +0 -1
- package/lib/extensions/ensure-empty-root-div.js +0 -48
- package/lib/extensions/ensure-empty-root-div.js.map +0 -1
- package/lib/extensions/ensure-list-item-content-is-div.js +0 -64
- package/lib/extensions/ensure-list-item-content-is-div.js.map +0 -1
- package/lib/extensions/extended-list-item.js +0 -15
- package/lib/extensions/extended-list-item.js.map +0 -1
- package/lib/extensions/extended-table-cell.js +0 -22
- package/lib/extensions/extended-table-cell.js.map +0 -1
- package/lib/extensions/extended-table.js +0 -75
- package/lib/extensions/extended-table.js.map +0 -1
- package/lib/extensions/heading-paragraph.js +0 -61
- package/lib/extensions/heading-paragraph.js.map +0 -1
- package/lib/extensions/image-component.js +0 -348
- package/lib/extensions/image-component.js.map +0 -1
- package/lib/extensions/image.js +0 -134
- package/lib/extensions/image.js.map +0 -1
- package/lib/extensions/index.js +0 -46
- package/lib/extensions/index.js.map +0 -1
- package/lib/extensions/math.js +0 -343
- package/lib/extensions/math.js.map +0 -1
- package/lib/extensions/media.js +0 -243
- package/lib/extensions/media.js.map +0 -1
- package/lib/extensions/responseArea.js +0 -446
- package/lib/extensions/responseArea.js.map +0 -1
- package/lib/index.js +0 -30
- package/lib/index.js.map +0 -1
- package/lib/styles/editorContainerStyles.js +0 -137
- package/lib/styles/editorContainerStyles.js.map +0 -1
- package/lib/theme.js +0 -8
- package/lib/theme.js.map +0 -1
- package/lib/utils/helper.js +0 -73
- package/lib/utils/helper.js.map +0 -1
- package/lib/utils/size.js +0 -26
- package/lib/utils/size.js.map +0 -1
- package/src/__tests__/EditableHtml.test.jsx +0 -474
- package/src/__tests__/constants.test.js +0 -19
- package/src/__tests__/div-to-paragraph-conversion.test.jsx +0 -125
- package/src/__tests__/extensions.test.js +0 -208
- package/src/__tests__/index.test.jsx +0 -154
- package/src/__tests__/size-utils.test.js +0 -64
- package/src/__tests__/theme.test.js +0 -17
- package/src/components/CharacterPicker.jsx +0 -200
- package/src/components/EditableHtml.jsx +0 -438
- package/src/components/MenuBar.jsx +0 -549
- package/src/components/TiptapContainer.jsx +0 -219
- package/src/components/__tests__/AltDialog.test.jsx +0 -147
- package/src/components/__tests__/CharacterPicker.test.jsx +0 -219
- package/src/components/__tests__/CssIcon.test.jsx +0 -46
- package/src/components/__tests__/DragInTheBlank.test.jsx +0 -255
- package/src/components/__tests__/ExplicitConstructedResponse.test.jsx +0 -204
- package/src/components/__tests__/ImageToolbar.test.jsx +0 -128
- package/src/components/__tests__/InlineDropdown.test.jsx +0 -380
- package/src/components/__tests__/InsertImageHandler.test.js +0 -161
- package/src/components/__tests__/MediaDialog.test.jsx +0 -293
- package/src/components/__tests__/MediaToolbar.test.jsx +0 -74
- package/src/components/__tests__/MediaWrapper.test.jsx +0 -81
- package/src/components/__tests__/MenuBar.test.jsx +0 -249
- package/src/components/__tests__/RespArea.test.jsx +0 -122
- package/src/components/__tests__/TableIcons.test.jsx +0 -149
- package/src/components/__tests__/TextAlign.test.jsx +0 -167
- package/src/components/__tests__/TiptapContainer.test.jsx +0 -138
- package/src/components/__tests__/characterUtils.test.js +0 -166
- package/src/components/__tests__/choice.test.jsx +0 -171
- package/src/components/__tests__/custom-popper.test.jsx +0 -82
- package/src/components/__tests__/done-button.test.jsx +0 -54
- package/src/components/__tests__/toolbar-buttons.test.jsx +0 -234
- package/src/components/characters/characterUtils.js +0 -447
- package/src/components/characters/custom-popper.js +0 -38
- package/src/components/common/done-button.jsx +0 -27
- package/src/components/common/toolbar-buttons.jsx +0 -122
- package/src/components/icons/CssIcon.jsx +0 -15
- package/src/components/icons/RespArea.jsx +0 -71
- package/src/components/icons/TableIcons.jsx +0 -52
- package/src/components/icons/TextAlign.jsx +0 -114
- package/src/components/image/AltDialog.jsx +0 -82
- package/src/components/image/ImageToolbar.jsx +0 -99
- package/src/components/image/InsertImageHandler.js +0 -107
- package/src/components/media/MediaDialog.jsx +0 -596
- package/src/components/media/MediaToolbar.jsx +0 -49
- package/src/components/media/MediaWrapper.jsx +0 -39
- package/src/components/respArea/DragInTheBlank/DragInTheBlank.jsx +0 -76
- package/src/components/respArea/DragInTheBlank/choice.jsx +0 -256
- package/src/components/respArea/ExplicitConstructedResponse.jsx +0 -135
- package/src/components/respArea/InlineDropdown.jsx +0 -167
- package/src/components/respArea/MathTemplated.jsx +0 -124
- package/src/components/respArea/ToolbarIcon.jsx +0 -66
- package/src/components/respArea/__tests__/MathTemplated.test.jsx +0 -210
- package/src/constants.js +0 -5
- package/src/extensions/__tests__/css.test.js +0 -196
- package/src/extensions/__tests__/custom-toolbar-wrapper.test.jsx +0 -180
- package/src/extensions/__tests__/divNode.test.js +0 -87
- package/src/extensions/__tests__/ensure-empty-root-div.test.js +0 -57
- package/src/extensions/__tests__/ensure-list-item-content-is-div.test.js +0 -44
- package/src/extensions/__tests__/extended-list-item.test.js +0 -13
- package/src/extensions/__tests__/extended-table-cell.test.js +0 -22
- package/src/extensions/__tests__/extended-table.test.js +0 -183
- package/src/extensions/__tests__/image-component.test.jsx +0 -345
- package/src/extensions/__tests__/image.test.js +0 -237
- package/src/extensions/__tests__/math.test.js +0 -459
- package/src/extensions/__tests__/media-node-view.test.jsx +0 -298
- package/src/extensions/__tests__/media.test.js +0 -271
- package/src/extensions/__tests__/responseArea.test.js +0 -601
- package/src/extensions/css.js +0 -220
- package/src/extensions/custom-toolbar-wrapper.jsx +0 -78
- package/src/extensions/div-node.js +0 -86
- package/src/extensions/ensure-empty-root-div.js +0 -47
- package/src/extensions/ensure-list-item-content-is-div.js +0 -62
- package/src/extensions/extended-list-item.js +0 -10
- package/src/extensions/extended-table-cell.js +0 -19
- package/src/extensions/extended-table.js +0 -60
- package/src/extensions/heading-paragraph.js +0 -53
- package/src/extensions/image-component.jsx +0 -338
- package/src/extensions/image.js +0 -109
- package/src/extensions/index.js +0 -81
- package/src/extensions/math.js +0 -327
- package/src/extensions/media.js +0 -188
- package/src/extensions/responseArea.js +0 -401
- package/src/index.jsx +0 -5
- package/src/styles/editorContainerStyles.js +0 -145
- package/src/theme.js +0 -1
- package/src/utils/__tests__/helper.test.js +0 -126
- package/src/utils/helper.js +0 -69
- 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
|
-
});
|