@pie-lib/editable-html-tip-tap 1.1.1-next.0 → 1.1.1-next.2
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/lib/__tests__/EditableHtml.test.js +387 -0
- package/lib/__tests__/constants.test.js +28 -0
- package/lib/__tests__/extensions.test.js +214 -0
- package/lib/__tests__/index.test.js +246 -0
- package/lib/__tests__/size-utils.test.js +57 -0
- package/lib/__tests__/theme.test.js +17 -0
- package/lib/components/CharacterPicker.js +8 -3
- package/lib/components/EditableHtml.js +6 -6
- package/lib/components/EditableHtml.js.map +1 -1
- package/lib/components/MenuBar.js +1 -1
- package/lib/components/TiptapContainer.js +4 -1
- package/lib/components/__tests__/AltDialog.test.js +201 -0
- package/lib/components/__tests__/CharacterPicker.test.js +313 -0
- package/lib/components/__tests__/CssIcon.test.js +58 -0
- package/lib/components/__tests__/DragInTheBlank.test.js +309 -0
- package/lib/components/__tests__/ExplicitConstructedResponse.test.js +263 -0
- package/lib/components/__tests__/ImageToolbar.test.js +195 -0
- package/lib/components/__tests__/InlineDropdown.test.js +297 -0
- package/lib/components/__tests__/InsertImageHandler.test.js +162 -0
- package/lib/components/__tests__/MediaDialog.test.js +435 -0
- package/lib/components/__tests__/MediaToolbar.test.js +126 -0
- package/lib/components/__tests__/MediaWrapper.test.js +96 -0
- package/lib/components/__tests__/MenuBar.test.js +459 -0
- package/lib/components/__tests__/RespArea.test.js +171 -0
- package/lib/components/__tests__/TableIcons.test.js +153 -0
- package/lib/components/__tests__/TextAlign.test.js +216 -0
- package/lib/components/__tests__/TiptapContainer.test.js +196 -0
- package/lib/components/__tests__/characterUtils.test.js +189 -0
- package/lib/components/__tests__/choice.test.js +213 -0
- package/lib/components/__tests__/custom-popper.test.js +108 -0
- package/lib/components/__tests__/done-button.test.js +72 -0
- package/lib/components/__tests__/toolbar-buttons.test.js +277 -0
- package/lib/components/characters/characterUtils.js +1 -1
- package/lib/components/characters/custom-popper.js +1 -1
- package/lib/components/common/done-button.js +1 -1
- package/lib/components/common/toolbar-buttons.js +1 -1
- package/lib/components/icons/CssIcon.js +1 -1
- package/lib/components/icons/RespArea.js +1 -1
- package/lib/components/icons/TableIcons.js +1 -1
- package/lib/components/icons/TextAlign.js +1 -1
- package/lib/components/image/AltDialog.js +1 -1
- package/lib/components/image/ImageToolbar.js +1 -1
- package/lib/components/image/InsertImageHandler.js +1 -1
- package/lib/components/media/MediaDialog.js +1 -1
- package/lib/components/media/MediaToolbar.js +1 -1
- package/lib/components/media/MediaWrapper.js +1 -1
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +1 -1
- package/lib/components/respArea/DragInTheBlank/choice.js +1 -1
- package/lib/components/respArea/ExplicitConstructedResponse.js +1 -1
- package/lib/components/respArea/InlineDropdown.js +1 -1
- package/lib/components/respArea/ToolbarIcon.js +1 -1
- package/lib/constants.js +1 -1
- package/lib/extensions/__tests__/component.test.js +314 -0
- package/lib/extensions/__tests__/css.test.js +218 -0
- package/lib/extensions/__tests__/custom-toolbar-wrapper.test.js +185 -0
- package/lib/extensions/__tests__/extended-table.test.js +114 -0
- package/lib/extensions/__tests__/image-component.test.js +315 -0
- package/lib/extensions/__tests__/image.test.js +178 -0
- package/lib/extensions/__tests__/media.test.js +296 -0
- package/lib/extensions/__tests__/responseArea.test.js +332 -0
- package/lib/extensions/component.js +1 -1
- package/lib/extensions/css.js +1 -1
- package/lib/extensions/custom-toolbar-wrapper.js +1 -1
- package/lib/extensions/extended-table.js +2 -2
- package/lib/extensions/image-component.js +314 -0
- package/lib/extensions/image-component.js.map +1 -0
- package/lib/extensions/image.js +3 -3
- package/lib/extensions/image.js.map +1 -1
- package/lib/extensions/index.js +6 -3
- package/lib/extensions/index.js.map +1 -1
- package/lib/extensions/math.js +1 -1
- package/lib/extensions/media.js +1 -1
- package/lib/extensions/responseArea.js +1 -1
- package/lib/index.js +1 -1
- package/lib/styles/editorContainerStyles.js +1 -1
- package/lib/theme.js +1 -1
- package/lib/utils/size.js +1 -1
- package/package.json +1 -1
- package/src/__tests__/EditableHtml.test.jsx +1 -0
- package/src/__tests__/extensions.test.js +2 -2
- package/src/components/CharacterPicker.jsx +9 -2
- package/src/components/EditableHtml.jsx +8 -6
- package/src/components/TiptapContainer.jsx +3 -0
- package/src/extensions/__tests__/{component.test.jsx → image-component.test.jsx} +2 -1
- package/src/extensions/__tests__/image.test.js +1 -1
- package/src/extensions/extended-table.js +1 -6
- package/src/extensions/{component.jsx → image-component.jsx} +11 -1
- package/src/extensions/image.js +8 -6
- package/src/extensions/index.js +5 -1
- package/LICENSE.md +0 -5
- package/NEXT.CHANGELOG.json +0 -1
- package/lib/extensions/component.js.map +0 -1
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.symbol.js");
|
|
4
|
+
require("core-js/modules/es.array.filter.js");
|
|
5
|
+
require("core-js/modules/es.array.for-each.js");
|
|
6
|
+
require("core-js/modules/es.object.define-properties.js");
|
|
7
|
+
require("core-js/modules/es.object.define-property.js");
|
|
8
|
+
require("core-js/modules/es.object.get-own-property-descriptor.js");
|
|
9
|
+
require("core-js/modules/es.object.get-own-property-descriptors.js");
|
|
10
|
+
require("core-js/modules/es.object.keys.js");
|
|
11
|
+
require("core-js/modules/es.object.to-string.js");
|
|
12
|
+
require("core-js/modules/web.dom-collections.for-each.js");
|
|
13
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
14
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
15
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
16
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
17
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
18
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
19
|
+
var _react = _interopRequireDefault(require("react"));
|
|
20
|
+
var _react2 = require("@testing-library/react");
|
|
21
|
+
var _ExplicitConstructedResponse = _interopRequireDefault(require("../respArea/ExplicitConstructedResponse"));
|
|
22
|
+
var _excluded = ["children"];
|
|
23
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
24
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
25
|
+
jest.mock('@tiptap/react', function () {
|
|
26
|
+
return {
|
|
27
|
+
NodeViewWrapper: function NodeViewWrapper(_ref) {
|
|
28
|
+
var children = _ref.children,
|
|
29
|
+
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
|
|
30
|
+
return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
|
|
31
|
+
"data-testid": "node-view-wrapper"
|
|
32
|
+
}, props), children);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
describe('ExplicitConstructedResponse', function () {
|
|
37
|
+
var mockEditor = {
|
|
38
|
+
state: {
|
|
39
|
+
selection: {
|
|
40
|
+
from: 0,
|
|
41
|
+
to: 1
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
commands: {
|
|
45
|
+
focus: jest.fn()
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
var mockNode = {
|
|
49
|
+
attrs: {
|
|
50
|
+
index: '0',
|
|
51
|
+
value: 'Test value'
|
|
52
|
+
},
|
|
53
|
+
nodeSize: 1
|
|
54
|
+
};
|
|
55
|
+
var mockOptions = {
|
|
56
|
+
respAreaToolbar: jest.fn(function () {
|
|
57
|
+
return function () {
|
|
58
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
59
|
+
"data-testid": "toolbar"
|
|
60
|
+
}, "Toolbar");
|
|
61
|
+
};
|
|
62
|
+
}),
|
|
63
|
+
error: jest.fn(function () {
|
|
64
|
+
return {};
|
|
65
|
+
})
|
|
66
|
+
};
|
|
67
|
+
var defaultProps = {
|
|
68
|
+
editor: mockEditor,
|
|
69
|
+
node: mockNode,
|
|
70
|
+
getPos: function getPos() {
|
|
71
|
+
return 5;
|
|
72
|
+
},
|
|
73
|
+
options: mockOptions,
|
|
74
|
+
selected: false
|
|
75
|
+
};
|
|
76
|
+
beforeEach(function () {
|
|
77
|
+
jest.clearAllMocks();
|
|
78
|
+
});
|
|
79
|
+
it('renders without crashing', function () {
|
|
80
|
+
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
81
|
+
container = _render.container;
|
|
82
|
+
expect(container).toBeInTheDocument();
|
|
83
|
+
});
|
|
84
|
+
it('renders NodeViewWrapper', function () {
|
|
85
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
86
|
+
getByTestId = _render2.getByTestId;
|
|
87
|
+
expect(getByTestId('node-view-wrapper')).toBeInTheDocument();
|
|
88
|
+
});
|
|
89
|
+
it('displays node value', function () {
|
|
90
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
91
|
+
container = _render3.container;
|
|
92
|
+
var valueDiv = container.querySelector('div[style*="padding"]');
|
|
93
|
+
expect(valueDiv).toBeInTheDocument();
|
|
94
|
+
});
|
|
95
|
+
it('applies correct border when no error', function () {
|
|
96
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
97
|
+
container = _render4.container;
|
|
98
|
+
var contentDiv = container.querySelector('div[style*="border"]');
|
|
99
|
+
expect(contentDiv).toHaveStyle({
|
|
100
|
+
border: '1px solid #C0C3CF'
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
it('applies red border when error exists', function () {
|
|
104
|
+
var errorFn = jest.fn(function () {
|
|
105
|
+
return {
|
|
106
|
+
0: ['error']
|
|
107
|
+
};
|
|
108
|
+
});
|
|
109
|
+
var options = _objectSpread(_objectSpread({}, mockOptions), {}, {
|
|
110
|
+
error: errorFn
|
|
111
|
+
});
|
|
112
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
113
|
+
options: options
|
|
114
|
+
}))),
|
|
115
|
+
container = _render5.container;
|
|
116
|
+
var contentDiv = container.querySelector('div[style*="border"]');
|
|
117
|
+
expect(contentDiv).toHaveStyle({
|
|
118
|
+
border: '1px solid red'
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
it('shows toolbar when selected and only this node is selected', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
122
|
+
var _render6, container;
|
|
123
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
124
|
+
while (1) switch (_context.prev = _context.next) {
|
|
125
|
+
case 0:
|
|
126
|
+
_render6 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
127
|
+
selected: true
|
|
128
|
+
}))), container = _render6.container;
|
|
129
|
+
_context.next = 1;
|
|
130
|
+
return (0, _react2.waitFor)(function () {
|
|
131
|
+
var toolbar = container.querySelector('[data-testid="toolbar"]');
|
|
132
|
+
// Toolbar might be hidden initially based on selection logic
|
|
133
|
+
expect(container).toBeInTheDocument();
|
|
134
|
+
});
|
|
135
|
+
case 1:
|
|
136
|
+
case "end":
|
|
137
|
+
return _context.stop();
|
|
138
|
+
}
|
|
139
|
+
}, _callee);
|
|
140
|
+
})));
|
|
141
|
+
it('does not show toolbar when not selected', function () {
|
|
142
|
+
var _render7 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
143
|
+
selected: false
|
|
144
|
+
}))),
|
|
145
|
+
queryByTestId = _render7.queryByTestId;
|
|
146
|
+
expect(queryByTestId('toolbar')).not.toBeInTheDocument();
|
|
147
|
+
});
|
|
148
|
+
it('shows toolbar on click', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
149
|
+
var _render8, container, queryByTestId, clickableDiv;
|
|
150
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
151
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
152
|
+
case 0:
|
|
153
|
+
_render8 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)), container = _render8.container, queryByTestId = _render8.queryByTestId;
|
|
154
|
+
clickableDiv = container.querySelector('div[style*="border"]');
|
|
155
|
+
_react2.fireEvent.click(clickableDiv);
|
|
156
|
+
_context2.next = 1;
|
|
157
|
+
return (0, _react2.waitFor)(function () {
|
|
158
|
+
// After click, toolbar should be shown
|
|
159
|
+
expect(container).toBeInTheDocument();
|
|
160
|
+
});
|
|
161
|
+
case 1:
|
|
162
|
+
case "end":
|
|
163
|
+
return _context2.stop();
|
|
164
|
+
}
|
|
165
|
+
}, _callee2);
|
|
166
|
+
})));
|
|
167
|
+
it('hides content when toolbar is shown', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
168
|
+
var _render9, container;
|
|
169
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
170
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
171
|
+
case 0:
|
|
172
|
+
_render9 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
173
|
+
selected: true
|
|
174
|
+
}))), container = _render9.container;
|
|
175
|
+
_context3.next = 1;
|
|
176
|
+
return (0, _react2.waitFor)(function () {
|
|
177
|
+
// Check visibility state
|
|
178
|
+
expect(container).toBeInTheDocument();
|
|
179
|
+
});
|
|
180
|
+
case 1:
|
|
181
|
+
case "end":
|
|
182
|
+
return _context3.stop();
|
|
183
|
+
}
|
|
184
|
+
}, _callee3);
|
|
185
|
+
})));
|
|
186
|
+
it('has correct minimum dimensions', function () {
|
|
187
|
+
var _render0 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
188
|
+
container = _render0.container;
|
|
189
|
+
var wrapper = container.querySelector('[data-testid="node-view-wrapper"]');
|
|
190
|
+
expect(wrapper).toHaveStyle({
|
|
191
|
+
minHeight: '55px'
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
it('renders with empty value as nbsp', function () {
|
|
195
|
+
var emptyNode = _objectSpread(_objectSpread({}, mockNode), {}, {
|
|
196
|
+
attrs: _objectSpread(_objectSpread({}, mockNode.attrs), {}, {
|
|
197
|
+
value: ''
|
|
198
|
+
})
|
|
199
|
+
});
|
|
200
|
+
var _render1 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
201
|
+
node: emptyNode
|
|
202
|
+
}))),
|
|
203
|
+
container = _render1.container;
|
|
204
|
+
expect(container).toBeInTheDocument();
|
|
205
|
+
});
|
|
206
|
+
it('calls respAreaToolbar with correct params', function () {
|
|
207
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps));
|
|
208
|
+
expect(mockOptions.respAreaToolbar).toHaveBeenCalledWith(mockNode, mockEditor, expect.any(Function));
|
|
209
|
+
});
|
|
210
|
+
it('has cursor pointer style', function () {
|
|
211
|
+
var _render10 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
212
|
+
container = _render10.container;
|
|
213
|
+
var wrapper = container.querySelector('[data-testid="node-view-wrapper"]');
|
|
214
|
+
expect(wrapper).toHaveStyle({
|
|
215
|
+
cursor: 'pointer'
|
|
216
|
+
});
|
|
217
|
+
});
|
|
218
|
+
it('has inline-flex display', function () {
|
|
219
|
+
var _render11 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
220
|
+
container = _render11.container;
|
|
221
|
+
var wrapper = container.querySelector('[data-testid="node-view-wrapper"]');
|
|
222
|
+
expect(wrapper).toHaveStyle({
|
|
223
|
+
display: 'inline-flex'
|
|
224
|
+
});
|
|
225
|
+
});
|
|
226
|
+
it('closes toolbar on outside click', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4() {
|
|
227
|
+
var _render12, container;
|
|
228
|
+
return _regenerator["default"].wrap(function (_context4) {
|
|
229
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
230
|
+
case 0:
|
|
231
|
+
_render12 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
232
|
+
selected: true
|
|
233
|
+
}))), container = _render12.container;
|
|
234
|
+
_context4.next = 1;
|
|
235
|
+
return (0, _react2.waitFor)(function () {
|
|
236
|
+
_react2.fireEvent.mouseDown(document.body);
|
|
237
|
+
});
|
|
238
|
+
case 1:
|
|
239
|
+
expect(container).toBeInTheDocument();
|
|
240
|
+
case 2:
|
|
241
|
+
case "end":
|
|
242
|
+
return _context4.stop();
|
|
243
|
+
}
|
|
244
|
+
}, _callee4);
|
|
245
|
+
})));
|
|
246
|
+
it('applies correct padding to content', function () {
|
|
247
|
+
var _render13 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
248
|
+
container = _render13.container;
|
|
249
|
+
var contentDiv = container.querySelector('div[style*="padding"]');
|
|
250
|
+
expect(contentDiv).toHaveStyle({
|
|
251
|
+
padding: '12px 21px'
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
it('applies correct min width', function () {
|
|
255
|
+
var _render14 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], defaultProps)),
|
|
256
|
+
container = _render14.container;
|
|
257
|
+
var contentDiv = container.querySelector('div[style*="padding"]');
|
|
258
|
+
expect(contentDiv).toHaveStyle({
|
|
259
|
+
minWidth: '178px'
|
|
260
|
+
});
|
|
261
|
+
});
|
|
262
|
+
});
|
|
263
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_ExplicitConstructedResponse","_excluded","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","jest","mock","NodeViewWrapper","_ref","children","props","_objectWithoutProperties2","createElement","_extends2","describe","mockEditor","state","selection","from","to","commands","focus","fn","mockNode","attrs","index","value","nodeSize","mockOptions","respAreaToolbar","error","defaultProps","editor","node","getPos","options","selected","beforeEach","clearAllMocks","it","_render","render","container","expect","toBeInTheDocument","_render2","getByTestId","_render3","valueDiv","querySelector","_render4","contentDiv","toHaveStyle","border","errorFn","_render5","_asyncToGenerator2","_regenerator","mark","_callee","_render6","wrap","_context","prev","next","waitFor","toolbar","stop","_render7","queryByTestId","not","_callee2","_render8","clickableDiv","_context2","fireEvent","click","_callee3","_render9","_context3","_render0","wrapper","minHeight","emptyNode","_render1","toHaveBeenCalledWith","any","Function","_render10","cursor","_render11","display","_callee4","_render12","_context4","mouseDown","document","body","_render13","padding","_render14","minWidth"],"sources":["../../../src/components/__tests__/ExplicitConstructedResponse.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, fireEvent, waitFor } from '@testing-library/react';\nimport ExplicitConstructedResponse from '../respArea/ExplicitConstructedResponse';\n\njest.mock('@tiptap/react', () => ({\n  NodeViewWrapper: ({ children, ...props }) => (\n    <div data-testid=\"node-view-wrapper\" {...props}>\n      {children}\n    </div>\n  ),\n}));\n\ndescribe('ExplicitConstructedResponse', () => {\n  const mockEditor = {\n    state: {\n      selection: {\n        from: 0,\n        to: 1,\n      },\n    },\n    commands: {\n      focus: jest.fn(),\n    },\n  };\n\n  const mockNode = {\n    attrs: {\n      index: '0',\n      value: 'Test value',\n    },\n    nodeSize: 1,\n  };\n\n  const mockOptions = {\n    respAreaToolbar: jest.fn(() => () => <div data-testid=\"toolbar\">Toolbar</div>),\n    error: jest.fn(() => ({})),\n  };\n\n  const defaultProps = {\n    editor: mockEditor,\n    node: mockNode,\n    getPos: () => 5,\n    options: mockOptions,\n    selected: false,\n  };\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n  });\n\n  it('renders without crashing', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    expect(container).toBeInTheDocument();\n  });\n\n  it('renders NodeViewWrapper', () => {\n    const { getByTestId } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    expect(getByTestId('node-view-wrapper')).toBeInTheDocument();\n  });\n\n  it('displays node value', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const valueDiv = container.querySelector('div[style*=\"padding\"]');\n    expect(valueDiv).toBeInTheDocument();\n  });\n\n  it('applies correct border when no error', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const contentDiv = container.querySelector('div[style*=\"border\"]');\n    expect(contentDiv).toHaveStyle({ border: '1px solid #C0C3CF' });\n  });\n\n  it('applies red border when error exists', () => {\n    const errorFn = jest.fn(() => ({ 0: ['error'] }));\n    const options = { ...mockOptions, error: errorFn };\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} options={options} />);\n    const contentDiv = container.querySelector('div[style*=\"border\"]');\n    expect(contentDiv).toHaveStyle({ border: '1px solid red' });\n  });\n\n  it('shows toolbar when selected and only this node is selected', async () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} selected={true} />);\n    await waitFor(() => {\n      const toolbar = container.querySelector('[data-testid=\"toolbar\"]');\n      // Toolbar might be hidden initially based on selection logic\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  it('does not show toolbar when not selected', () => {\n    const { queryByTestId } = render(<ExplicitConstructedResponse {...defaultProps} selected={false} />);\n    expect(queryByTestId('toolbar')).not.toBeInTheDocument();\n  });\n\n  it('shows toolbar on click', async () => {\n    const { container, queryByTestId } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const clickableDiv = container.querySelector('div[style*=\"border\"]');\n    fireEvent.click(clickableDiv);\n    await waitFor(() => {\n      // After click, toolbar should be shown\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  it('hides content when toolbar is shown', async () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} selected={true} />);\n    await waitFor(() => {\n      // Check visibility state\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  it('has correct minimum dimensions', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const wrapper = container.querySelector('[data-testid=\"node-view-wrapper\"]');\n    expect(wrapper).toHaveStyle({ minHeight: '55px' });\n  });\n\n  it('renders with empty value as nbsp', () => {\n    const emptyNode = { ...mockNode, attrs: { ...mockNode.attrs, value: '' } };\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} node={emptyNode} />);\n    expect(container).toBeInTheDocument();\n  });\n\n  it('calls respAreaToolbar with correct params', () => {\n    render(<ExplicitConstructedResponse {...defaultProps} />);\n    expect(mockOptions.respAreaToolbar).toHaveBeenCalledWith(mockNode, mockEditor, expect.any(Function));\n  });\n\n  it('has cursor pointer style', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const wrapper = container.querySelector('[data-testid=\"node-view-wrapper\"]');\n    expect(wrapper).toHaveStyle({ cursor: 'pointer' });\n  });\n\n  it('has inline-flex display', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const wrapper = container.querySelector('[data-testid=\"node-view-wrapper\"]');\n    expect(wrapper).toHaveStyle({ display: 'inline-flex' });\n  });\n\n  it('closes toolbar on outside click', async () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} selected={true} />);\n    await waitFor(() => {\n      fireEvent.mouseDown(document.body);\n    });\n    expect(container).toBeInTheDocument();\n  });\n\n  it('applies correct padding to content', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const contentDiv = container.querySelector('div[style*=\"padding\"]');\n    expect(contentDiv).toHaveStyle({ padding: '12px 21px' });\n  });\n\n  it('applies correct min width', () => {\n    const { container } = render(<ExplicitConstructedResponse {...defaultProps} />);\n    const contentDiv = container.querySelector('div[style*=\"padding\"]');\n    expect(contentDiv).toHaveStyle({ minWidth: '178px' });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.symbol.js");
|
|
4
|
+
require("core-js/modules/es.array.filter.js");
|
|
5
|
+
require("core-js/modules/es.array.for-each.js");
|
|
6
|
+
require("core-js/modules/es.object.define-properties.js");
|
|
7
|
+
require("core-js/modules/es.object.define-property.js");
|
|
8
|
+
require("core-js/modules/es.object.get-own-property-descriptor.js");
|
|
9
|
+
require("core-js/modules/es.object.get-own-property-descriptors.js");
|
|
10
|
+
require("core-js/modules/es.object.keys.js");
|
|
11
|
+
require("core-js/modules/es.object.to-string.js");
|
|
12
|
+
require("core-js/modules/web.dom-collections.for-each.js");
|
|
13
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
14
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
15
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
16
|
+
var _react = _interopRequireDefault(require("react"));
|
|
17
|
+
var _react2 = require("@testing-library/react");
|
|
18
|
+
var _ImageToolbar = require("../image/ImageToolbar");
|
|
19
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
20
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
21
|
+
jest.mock('react-dom', function () {
|
|
22
|
+
return _objectSpread(_objectSpread({}, jest.requireActual('react-dom')), {}, {
|
|
23
|
+
render: jest.fn()
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
jest.mock('../image/AltDialog', function () {
|
|
27
|
+
return {
|
|
28
|
+
__esModule: true,
|
|
29
|
+
"default": jest.fn(function () {
|
|
30
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
31
|
+
"data-testid": "alt-dialog"
|
|
32
|
+
});
|
|
33
|
+
})
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
jest.mock('../common/toolbar-buttons', function () {
|
|
37
|
+
return {
|
|
38
|
+
MarkButton: function MarkButton(_ref) {
|
|
39
|
+
var onToggle = _ref.onToggle,
|
|
40
|
+
active = _ref.active,
|
|
41
|
+
label = _ref.label,
|
|
42
|
+
children = _ref.children;
|
|
43
|
+
return /*#__PURE__*/_react["default"].createElement("button", {
|
|
44
|
+
onClick: function onClick() {
|
|
45
|
+
return onToggle();
|
|
46
|
+
},
|
|
47
|
+
"data-testid": "mark-button-".concat(label),
|
|
48
|
+
"data-active": active
|
|
49
|
+
}, children);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
});
|
|
53
|
+
describe('ImageToolbar', function () {
|
|
54
|
+
var defaultProps = {
|
|
55
|
+
onChange: jest.fn(),
|
|
56
|
+
alignment: 'left',
|
|
57
|
+
alt: 'Test alt text',
|
|
58
|
+
imageLoaded: true,
|
|
59
|
+
disableImageAlignmentButtons: false
|
|
60
|
+
};
|
|
61
|
+
beforeEach(function () {
|
|
62
|
+
jest.clearAllMocks();
|
|
63
|
+
});
|
|
64
|
+
it('renders without crashing', function () {
|
|
65
|
+
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, defaultProps)),
|
|
66
|
+
container = _render.container;
|
|
67
|
+
expect(container).toBeInTheDocument();
|
|
68
|
+
});
|
|
69
|
+
it('renders alignment buttons when not disabled', function () {
|
|
70
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, defaultProps)),
|
|
71
|
+
getByTestId = _render2.getByTestId;
|
|
72
|
+
expect(getByTestId('mark-button-left')).toBeInTheDocument();
|
|
73
|
+
expect(getByTestId('mark-button-center')).toBeInTheDocument();
|
|
74
|
+
expect(getByTestId('mark-button-right')).toBeInTheDocument();
|
|
75
|
+
});
|
|
76
|
+
it('does not render alignment buttons when disabled', function () {
|
|
77
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
78
|
+
disableImageAlignmentButtons: true
|
|
79
|
+
}))),
|
|
80
|
+
queryByTestId = _render3.queryByTestId;
|
|
81
|
+
expect(queryByTestId('mark-button-left')).not.toBeInTheDocument();
|
|
82
|
+
expect(queryByTestId('mark-button-center')).not.toBeInTheDocument();
|
|
83
|
+
expect(queryByTestId('mark-button-right')).not.toBeInTheDocument();
|
|
84
|
+
});
|
|
85
|
+
it('renders "Alt text" label', function () {
|
|
86
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, defaultProps)),
|
|
87
|
+
getByText = _render4.getByText;
|
|
88
|
+
expect(getByText('Alt text')).toBeInTheDocument();
|
|
89
|
+
});
|
|
90
|
+
it('calls onChange with alignment when alignment button clicked', function () {
|
|
91
|
+
var onChange = jest.fn();
|
|
92
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
93
|
+
onChange: onChange
|
|
94
|
+
}))),
|
|
95
|
+
getByTestId = _render5.getByTestId;
|
|
96
|
+
_react2.fireEvent.click(getByTestId('mark-button-center'));
|
|
97
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
98
|
+
alignment: 'center'
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
it('shows left button as active when alignment is left', function () {
|
|
102
|
+
var _render6 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
103
|
+
alignment: "left"
|
|
104
|
+
}))),
|
|
105
|
+
getByTestId = _render6.getByTestId;
|
|
106
|
+
expect(getByTestId('mark-button-left')).toHaveAttribute('data-active', 'true');
|
|
107
|
+
});
|
|
108
|
+
it('shows center button as active when alignment is center', function () {
|
|
109
|
+
var _render7 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
110
|
+
alignment: "center"
|
|
111
|
+
}))),
|
|
112
|
+
getByTestId = _render7.getByTestId;
|
|
113
|
+
expect(getByTestId('mark-button-center')).toHaveAttribute('data-active', 'true');
|
|
114
|
+
});
|
|
115
|
+
it('shows right button as active when alignment is right', function () {
|
|
116
|
+
var _render8 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
117
|
+
alignment: "right"
|
|
118
|
+
}))),
|
|
119
|
+
getByTestId = _render8.getByTestId;
|
|
120
|
+
expect(getByTestId('mark-button-right')).toHaveAttribute('data-active', 'true');
|
|
121
|
+
});
|
|
122
|
+
it('disables alt text when image is not loaded', function () {
|
|
123
|
+
var _render9 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
124
|
+
imageLoaded: false
|
|
125
|
+
}))),
|
|
126
|
+
getByText = _render9.getByText;
|
|
127
|
+
var altText = getByText('Alt text');
|
|
128
|
+
expect(altText).toHaveStyle({
|
|
129
|
+
opacity: '0.5'
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
it('does not disable alt text when image is loaded', function () {
|
|
133
|
+
var _render0 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
134
|
+
imageLoaded: true
|
|
135
|
+
}))),
|
|
136
|
+
getByText = _render0.getByText;
|
|
137
|
+
var altText = getByText('Alt text');
|
|
138
|
+
expect(altText).not.toHaveStyle({
|
|
139
|
+
opacity: '0.5'
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
it('renders alt text dialog on mouse down when image is loaded', function () {
|
|
143
|
+
var _render1 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
144
|
+
imageLoaded: true
|
|
145
|
+
}))),
|
|
146
|
+
getByText = _render1.getByText,
|
|
147
|
+
container = _render1.container;
|
|
148
|
+
var altText = getByText('Alt text');
|
|
149
|
+
_react2.fireEvent.mouseDown(altText);
|
|
150
|
+
// Just verify the component rendered and mouseDown didn't throw
|
|
151
|
+
expect(container).toBeInTheDocument();
|
|
152
|
+
});
|
|
153
|
+
it('does not render alt text dialog on mouse down when image is not loaded', function () {
|
|
154
|
+
var _render10 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
155
|
+
imageLoaded: false
|
|
156
|
+
}))),
|
|
157
|
+
getByText = _render10.getByText,
|
|
158
|
+
container = _render10.container;
|
|
159
|
+
var altText = getByText('Alt text');
|
|
160
|
+
_react2.fireEvent.mouseDown(altText);
|
|
161
|
+
// Just verify the component rendered and mouseDown didn't throw
|
|
162
|
+
expect(container).toBeInTheDocument();
|
|
163
|
+
});
|
|
164
|
+
it('calls onChange with new alt text and true when alt dialog is done', function () {
|
|
165
|
+
var onChange = jest.fn();
|
|
166
|
+
var toolbar = new _ImageToolbar.ImageToolbar(_objectSpread(_objectSpread({}, defaultProps), {}, {
|
|
167
|
+
onChange: onChange
|
|
168
|
+
}));
|
|
169
|
+
toolbar.onAltTextDone('New alt text');
|
|
170
|
+
expect(onChange).toHaveBeenCalledWith({
|
|
171
|
+
alt: 'New alt text'
|
|
172
|
+
}, true);
|
|
173
|
+
});
|
|
174
|
+
it('has border on alt text when alignment buttons are shown', function () {
|
|
175
|
+
var _render11 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
176
|
+
disableImageAlignmentButtons: false
|
|
177
|
+
}))),
|
|
178
|
+
getByText = _render11.getByText;
|
|
179
|
+
var altText = getByText('Alt text');
|
|
180
|
+
expect(altText).toHaveStyle({
|
|
181
|
+
borderLeft: '1px solid grey'
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
it('does not have border on alt text when alignment buttons are hidden', function () {
|
|
185
|
+
var _render12 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_ImageToolbar.ImageToolbar, (0, _extends2["default"])({}, defaultProps, {
|
|
186
|
+
disableImageAlignmentButtons: true
|
|
187
|
+
}))),
|
|
188
|
+
getByText = _render12.getByText;
|
|
189
|
+
var altText = getByText('Alt text');
|
|
190
|
+
expect(altText).not.toHaveStyle({
|
|
191
|
+
borderLeft: '1px solid grey'
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
});
|
|
195
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_ImageToolbar","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","jest","mock","requireActual","render","fn","__esModule","createElement","MarkButton","_ref","onToggle","active","label","children","onClick","concat","describe","defaultProps","onChange","alignment","alt","imageLoaded","disableImageAlignmentButtons","beforeEach","clearAllMocks","it","_render","ImageToolbar","container","expect","toBeInTheDocument","_render2","getByTestId","_render3","_extends2","queryByTestId","not","_render4","getByText","_render5","fireEvent","click","toHaveBeenCalledWith","_render6","toHaveAttribute","_render7","_render8","_render9","altText","toHaveStyle","opacity","_render0","_render1","mouseDown","_render10","toolbar","onAltTextDone","_render11","borderLeft","_render12"],"sources":["../../../src/components/__tests__/ImageToolbar.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, fireEvent } from '@testing-library/react';\nimport { ImageToolbar } from '../image/ImageToolbar';\n\njest.mock('react-dom', () => ({\n  ...jest.requireActual('react-dom'),\n  render: jest.fn(),\n}));\n\njest.mock('../image/AltDialog', () => ({\n  __esModule: true,\n  default: jest.fn(() => <div data-testid=\"alt-dialog\" />),\n}));\n\njest.mock('../common/toolbar-buttons', () => ({\n  MarkButton: ({ onToggle, active, label, children }) => (\n    <button onClick={() => onToggle()} data-testid={`mark-button-${label}`} data-active={active}>\n      {children}\n    </button>\n  ),\n}));\n\ndescribe('ImageToolbar', () => {\n  const defaultProps = {\n    onChange: jest.fn(),\n    alignment: 'left',\n    alt: 'Test alt text',\n    imageLoaded: true,\n    disableImageAlignmentButtons: false,\n  };\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n  });\n\n  it('renders without crashing', () => {\n    const { container } = render(<ImageToolbar {...defaultProps} />);\n    expect(container).toBeInTheDocument();\n  });\n\n  it('renders alignment buttons when not disabled', () => {\n    const { getByTestId } = render(<ImageToolbar {...defaultProps} />);\n    expect(getByTestId('mark-button-left')).toBeInTheDocument();\n    expect(getByTestId('mark-button-center')).toBeInTheDocument();\n    expect(getByTestId('mark-button-right')).toBeInTheDocument();\n  });\n\n  it('does not render alignment buttons when disabled', () => {\n    const { queryByTestId } = render(<ImageToolbar {...defaultProps} disableImageAlignmentButtons={true} />);\n    expect(queryByTestId('mark-button-left')).not.toBeInTheDocument();\n    expect(queryByTestId('mark-button-center')).not.toBeInTheDocument();\n    expect(queryByTestId('mark-button-right')).not.toBeInTheDocument();\n  });\n\n  it('renders \"Alt text\" label', () => {\n    const { getByText } = render(<ImageToolbar {...defaultProps} />);\n    expect(getByText('Alt text')).toBeInTheDocument();\n  });\n\n  it('calls onChange with alignment when alignment button clicked', () => {\n    const onChange = jest.fn();\n    const { getByTestId } = render(<ImageToolbar {...defaultProps} onChange={onChange} />);\n    fireEvent.click(getByTestId('mark-button-center'));\n    expect(onChange).toHaveBeenCalledWith({ alignment: 'center' });\n  });\n\n  it('shows left button as active when alignment is left', () => {\n    const { getByTestId } = render(<ImageToolbar {...defaultProps} alignment=\"left\" />);\n    expect(getByTestId('mark-button-left')).toHaveAttribute('data-active', 'true');\n  });\n\n  it('shows center button as active when alignment is center', () => {\n    const { getByTestId } = render(<ImageToolbar {...defaultProps} alignment=\"center\" />);\n    expect(getByTestId('mark-button-center')).toHaveAttribute('data-active', 'true');\n  });\n\n  it('shows right button as active when alignment is right', () => {\n    const { getByTestId } = render(<ImageToolbar {...defaultProps} alignment=\"right\" />);\n    expect(getByTestId('mark-button-right')).toHaveAttribute('data-active', 'true');\n  });\n\n  it('disables alt text when image is not loaded', () => {\n    const { getByText } = render(<ImageToolbar {...defaultProps} imageLoaded={false} />);\n    const altText = getByText('Alt text');\n    expect(altText).toHaveStyle({ opacity: '0.5' });\n  });\n\n  it('does not disable alt text when image is loaded', () => {\n    const { getByText } = render(<ImageToolbar {...defaultProps} imageLoaded={true} />);\n    const altText = getByText('Alt text');\n    expect(altText).not.toHaveStyle({ opacity: '0.5' });\n  });\n\n  it('renders alt text dialog on mouse down when image is loaded', () => {\n    const { getByText, container } = render(<ImageToolbar {...defaultProps} imageLoaded={true} />);\n    const altText = getByText('Alt text');\n    fireEvent.mouseDown(altText);\n    // Just verify the component rendered and mouseDown didn't throw\n    expect(container).toBeInTheDocument();\n  });\n\n  it('does not render alt text dialog on mouse down when image is not loaded', () => {\n    const { getByText, container } = render(<ImageToolbar {...defaultProps} imageLoaded={false} />);\n    const altText = getByText('Alt text');\n    fireEvent.mouseDown(altText);\n    // Just verify the component rendered and mouseDown didn't throw\n    expect(container).toBeInTheDocument();\n  });\n\n  it('calls onChange with new alt text and true when alt dialog is done', () => {\n    const onChange = jest.fn();\n    const toolbar = new ImageToolbar({ ...defaultProps, onChange });\n    toolbar.onAltTextDone('New alt text');\n    expect(onChange).toHaveBeenCalledWith({ alt: 'New alt text' }, true);\n  });\n\n  it('has border on alt text when alignment buttons are shown', () => {\n    const { getByText } = render(<ImageToolbar {...defaultProps} disableImageAlignmentButtons={false} />);\n    const altText = getByText('Alt text');\n    expect(altText).toHaveStyle({ borderLeft: '1px solid grey' });\n  });\n\n  it('does not have border on alt text when alignment buttons are hidden', () => {\n    const { getByText } = render(<ImageToolbar {...defaultProps} disableImageAlignmentButtons={true} />);\n    const altText = getByText('Alt text');\n    expect(altText).not.toHaveStyle({ borderLeft: '1px solid grey' });\n  });\n});\n"],"mappings":";;;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,aAAA,GAAAF,OAAA;AAAqD,SAAAG,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA;AAErDoB,IAAI,CAACC,IAAI,CAAC,WAAW,EAAE;EAAA,OAAAT,aAAA,CAAAA,aAAA,KAClBQ,IAAI,CAACE,aAAa,CAAC,WAAW,CAAC;IAClCC,MAAM,EAAEH,IAAI,CAACI,EAAE,CAAC;EAAC;AAAA,CACjB,CAAC;AAEHJ,IAAI,CAACC,IAAI,CAAC,oBAAoB,EAAE;EAAA,OAAO;IACrCI,UAAU,EAAE,IAAI;IAChB,WAASL,IAAI,CAACI,EAAE,CAAC;MAAA,oBAAM9B,MAAA,YAAAgC,aAAA;QAAK,eAAY;MAAY,CAAE,CAAC;IAAA;EACzD,CAAC;AAAA,CAAC,CAAC;AAEHN,IAAI,CAACC,IAAI,CAAC,2BAA2B,EAAE;EAAA,OAAO;IAC5CM,UAAU,EAAE,SAAZA,UAAUA,CAAAC,IAAA;MAAA,IAAKC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;QAAEC,MAAM,GAAAF,IAAA,CAANE,MAAM;QAAEC,KAAK,GAAAH,IAAA,CAALG,KAAK;QAAEC,QAAQ,GAAAJ,IAAA,CAARI,QAAQ;MAAA,oBAC9CtC,MAAA,YAAAgC,aAAA;QAAQO,OAAO,EAAE,SAATA,OAAOA,CAAA;UAAA,OAAQJ,QAAQ,CAAC,CAAC;QAAA,CAAC;QAAC,8BAAAK,MAAA,CAA4BH,KAAK,CAAG;QAAC,eAAaD;MAAO,GACzFE,QACK,CAAC;IAAA;EAEb,CAAC;AAAA,CAAC,CAAC;AAEHG,QAAQ,CAAC,cAAc,EAAE,YAAM;EAC7B,IAAMC,YAAY,GAAG;IACnBC,QAAQ,EAAEjB,IAAI,CAACI,EAAE,CAAC,CAAC;IACnBc,SAAS,EAAE,MAAM;IACjBC,GAAG,EAAE,eAAe;IACpBC,WAAW,EAAE,IAAI;IACjBC,4BAA4B,EAAE;EAChC,CAAC;EAEDC,UAAU,CAAC,YAAM;IACftB,IAAI,CAACuB,aAAa,CAAC,CAAC;EACtB,CAAC,CAAC;EAEFC,EAAE,CAAC,0BAA0B,EAAE,YAAM;IACnC,IAAAC,OAAA,GAAsB,IAAAtB,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,EAAKV,YAAe,CAAC,CAAC;MAAxDW,SAAS,GAAAF,OAAA,CAATE,SAAS;IACjBC,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;EACvC,CAAC,CAAC;EAEFL,EAAE,CAAC,6CAA6C,EAAE,YAAM;IACtD,IAAAM,QAAA,GAAwB,IAAA3B,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,EAAKV,YAAe,CAAC,CAAC;MAA1De,WAAW,GAAAD,QAAA,CAAXC,WAAW;IACnBH,MAAM,CAACG,WAAW,CAAC,kBAAkB,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IAC3DD,MAAM,CAACG,WAAW,CAAC,oBAAoB,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IAC7DD,MAAM,CAACG,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;EAC9D,CAAC,CAAC;EAEFL,EAAE,CAAC,iDAAiD,EAAE,YAAM;IAC1D,IAAAQ,QAAA,GAA0B,IAAA7B,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEK,4BAA4B,EAAE;MAAK,EAAE,CAAC,CAAC;MAAhGa,aAAa,GAAAF,QAAA,CAAbE,aAAa;IACrBN,MAAM,CAACM,aAAa,CAAC,kBAAkB,CAAC,CAAC,CAACC,GAAG,CAACN,iBAAiB,CAAC,CAAC;IACjED,MAAM,CAACM,aAAa,CAAC,oBAAoB,CAAC,CAAC,CAACC,GAAG,CAACN,iBAAiB,CAAC,CAAC;IACnED,MAAM,CAACM,aAAa,CAAC,mBAAmB,CAAC,CAAC,CAACC,GAAG,CAACN,iBAAiB,CAAC,CAAC;EACpE,CAAC,CAAC;EAEFL,EAAE,CAAC,0BAA0B,EAAE,YAAM;IACnC,IAAAY,QAAA,GAAsB,IAAAjC,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,EAAKV,YAAe,CAAC,CAAC;MAAxDqB,SAAS,GAAAD,QAAA,CAATC,SAAS;IACjBT,MAAM,CAACS,SAAS,CAAC,UAAU,CAAC,CAAC,CAACR,iBAAiB,CAAC,CAAC;EACnD,CAAC,CAAC;EAEFL,EAAE,CAAC,6DAA6D,EAAE,YAAM;IACtE,IAAMP,QAAQ,GAAGjB,IAAI,CAACI,EAAE,CAAC,CAAC;IAC1B,IAAAkC,QAAA,GAAwB,IAAAnC,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEC,QAAQ,EAAEA;MAAS,EAAE,CAAC,CAAC;MAA9Ec,WAAW,GAAAO,QAAA,CAAXP,WAAW;IACnBQ,iBAAS,CAACC,KAAK,CAACT,WAAW,CAAC,oBAAoB,CAAC,CAAC;IAClDH,MAAM,CAACX,QAAQ,CAAC,CAACwB,oBAAoB,CAAC;MAAEvB,SAAS,EAAE;IAAS,CAAC,CAAC;EAChE,CAAC,CAAC;EAEFM,EAAE,CAAC,oDAAoD,EAAE,YAAM;IAC7D,IAAAkB,QAAA,GAAwB,IAAAvC,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEE,SAAS,EAAC;MAAM,EAAE,CAAC,CAAC;MAA3Ea,WAAW,GAAAW,QAAA,CAAXX,WAAW;IACnBH,MAAM,CAACG,WAAW,CAAC,kBAAkB,CAAC,CAAC,CAACY,eAAe,CAAC,aAAa,EAAE,MAAM,CAAC;EAChF,CAAC,CAAC;EAEFnB,EAAE,CAAC,wDAAwD,EAAE,YAAM;IACjE,IAAAoB,QAAA,GAAwB,IAAAzC,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEE,SAAS,EAAC;MAAQ,EAAE,CAAC,CAAC;MAA7Ea,WAAW,GAAAa,QAAA,CAAXb,WAAW;IACnBH,MAAM,CAACG,WAAW,CAAC,oBAAoB,CAAC,CAAC,CAACY,eAAe,CAAC,aAAa,EAAE,MAAM,CAAC;EAClF,CAAC,CAAC;EAEFnB,EAAE,CAAC,sDAAsD,EAAE,YAAM;IAC/D,IAAAqB,QAAA,GAAwB,IAAA1C,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEE,SAAS,EAAC;MAAO,EAAE,CAAC,CAAC;MAA5Ea,WAAW,GAAAc,QAAA,CAAXd,WAAW;IACnBH,MAAM,CAACG,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAACY,eAAe,CAAC,aAAa,EAAE,MAAM,CAAC;EACjF,CAAC,CAAC;EAEFnB,EAAE,CAAC,4CAA4C,EAAE,YAAM;IACrD,IAAAsB,QAAA,GAAsB,IAAA3C,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEI,WAAW,EAAE;MAAM,EAAE,CAAC,CAAC;MAA5EiB,SAAS,GAAAS,QAAA,CAATT,SAAS;IACjB,IAAMU,OAAO,GAAGV,SAAS,CAAC,UAAU,CAAC;IACrCT,MAAM,CAACmB,OAAO,CAAC,CAACC,WAAW,CAAC;MAAEC,OAAO,EAAE;IAAM,CAAC,CAAC;EACjD,CAAC,CAAC;EAEFzB,EAAE,CAAC,gDAAgD,EAAE,YAAM;IACzD,IAAA0B,QAAA,GAAsB,IAAA/C,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEI,WAAW,EAAE;MAAK,EAAE,CAAC,CAAC;MAA3EiB,SAAS,GAAAa,QAAA,CAATb,SAAS;IACjB,IAAMU,OAAO,GAAGV,SAAS,CAAC,UAAU,CAAC;IACrCT,MAAM,CAACmB,OAAO,CAAC,CAACZ,GAAG,CAACa,WAAW,CAAC;MAAEC,OAAO,EAAE;IAAM,CAAC,CAAC;EACrD,CAAC,CAAC;EAEFzB,EAAE,CAAC,4DAA4D,EAAE,YAAM;IACrE,IAAA2B,QAAA,GAAiC,IAAAhD,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEI,WAAW,EAAE;MAAK,EAAE,CAAC,CAAC;MAAtFiB,SAAS,GAAAc,QAAA,CAATd,SAAS;MAAEV,SAAS,GAAAwB,QAAA,CAATxB,SAAS;IAC5B,IAAMoB,OAAO,GAAGV,SAAS,CAAC,UAAU,CAAC;IACrCE,iBAAS,CAACa,SAAS,CAACL,OAAO,CAAC;IAC5B;IACAnB,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;EACvC,CAAC,CAAC;EAEFL,EAAE,CAAC,wEAAwE,EAAE,YAAM;IACjF,IAAA6B,SAAA,GAAiC,IAAAlD,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEI,WAAW,EAAE;MAAM,EAAE,CAAC,CAAC;MAAvFiB,SAAS,GAAAgB,SAAA,CAAThB,SAAS;MAAEV,SAAS,GAAA0B,SAAA,CAAT1B,SAAS;IAC5B,IAAMoB,OAAO,GAAGV,SAAS,CAAC,UAAU,CAAC;IACrCE,iBAAS,CAACa,SAAS,CAACL,OAAO,CAAC;IAC5B;IACAnB,MAAM,CAACD,SAAS,CAAC,CAACE,iBAAiB,CAAC,CAAC;EACvC,CAAC,CAAC;EAEFL,EAAE,CAAC,mEAAmE,EAAE,YAAM;IAC5E,IAAMP,QAAQ,GAAGjB,IAAI,CAACI,EAAE,CAAC,CAAC;IAC1B,IAAMkD,OAAO,GAAG,IAAI5B,0BAAY,CAAAlC,aAAA,CAAAA,aAAA,KAAMwB,YAAY;MAAEC,QAAQ,EAARA;IAAQ,EAAE,CAAC;IAC/DqC,OAAO,CAACC,aAAa,CAAC,cAAc,CAAC;IACrC3B,MAAM,CAACX,QAAQ,CAAC,CAACwB,oBAAoB,CAAC;MAAEtB,GAAG,EAAE;IAAe,CAAC,EAAE,IAAI,CAAC;EACtE,CAAC,CAAC;EAEFK,EAAE,CAAC,yDAAyD,EAAE,YAAM;IAClE,IAAAgC,SAAA,GAAsB,IAAArD,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEK,4BAA4B,EAAE;MAAM,EAAE,CAAC,CAAC;MAA7FgB,SAAS,GAAAmB,SAAA,CAATnB,SAAS;IACjB,IAAMU,OAAO,GAAGV,SAAS,CAAC,UAAU,CAAC;IACrCT,MAAM,CAACmB,OAAO,CAAC,CAACC,WAAW,CAAC;MAAES,UAAU,EAAE;IAAiB,CAAC,CAAC;EAC/D,CAAC,CAAC;EAEFjC,EAAE,CAAC,oEAAoE,EAAE,YAAM;IAC7E,IAAAkC,SAAA,GAAsB,IAAAvD,cAAM,eAAC7B,MAAA,YAAAgC,aAAA,CAAC5B,aAAA,CAAAgD,YAAY,MAAAO,SAAA,iBAAKjB,YAAY;QAAEK,4BAA4B,EAAE;MAAK,EAAE,CAAC,CAAC;MAA5FgB,SAAS,GAAAqB,SAAA,CAATrB,SAAS;IACjB,IAAMU,OAAO,GAAGV,SAAS,CAAC,UAAU,CAAC;IACrCT,MAAM,CAACmB,OAAO,CAAC,CAACZ,GAAG,CAACa,WAAW,CAAC;MAAES,UAAU,EAAE;IAAiB,CAAC,CAAC;EACnE,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|