@pie-lib/editable-html-tip-tap 1.1.0-next.6059 → 1.1.1-next.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +44 -0
- package/lib/__tests__/EditableHtml.test.js +374 -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 +18 -0
- package/lib/components/CharacterPicker.js.map +1 -1
- package/lib/components/EditableHtml.js +22 -5
- package/lib/components/EditableHtml.js.map +1 -1
- package/lib/components/MenuBar.js +17 -0
- package/lib/components/MenuBar.js.map +1 -1
- package/lib/components/TiptapContainer.js +16 -0
- package/lib/components/TiptapContainer.js.map +1 -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 +2 -0
- package/lib/components/characters/characterUtils.js.map +1 -1
- package/lib/components/characters/custom-popper.js +1 -0
- package/lib/components/characters/custom-popper.js.map +1 -1
- package/lib/components/common/done-button.js +1 -0
- package/lib/components/common/done-button.js.map +1 -1
- package/lib/components/common/toolbar-buttons.js +12 -0
- package/lib/components/common/toolbar-buttons.js.map +1 -1
- package/lib/components/icons/CssIcon.js +1 -0
- package/lib/components/icons/CssIcon.js.map +1 -1
- package/lib/components/icons/RespArea.js +10 -0
- package/lib/components/icons/RespArea.js.map +1 -1
- package/lib/components/icons/TableIcons.js +1 -0
- package/lib/components/icons/TableIcons.js.map +1 -1
- package/lib/components/icons/TextAlign.js +7 -0
- package/lib/components/icons/TextAlign.js.map +1 -1
- package/lib/components/image/AltDialog.js +5 -0
- package/lib/components/image/AltDialog.js.map +1 -1
- package/lib/components/image/ImageToolbar.js +13 -0
- package/lib/components/image/ImageToolbar.js.map +1 -1
- package/lib/components/image/InsertImageHandler.js +10 -0
- package/lib/components/image/InsertImageHandler.js.map +1 -1
- package/lib/components/media/MediaDialog.js +18 -0
- package/lib/components/media/MediaDialog.js.map +1 -1
- package/lib/components/media/MediaToolbar.js +2 -0
- package/lib/components/media/MediaToolbar.js.map +1 -1
- package/lib/components/media/MediaWrapper.js +11 -0
- package/lib/components/media/MediaWrapper.js.map +1 -1
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +10 -0
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +1 -1
- package/lib/components/respArea/DragInTheBlank/choice.js +8 -0
- package/lib/components/respArea/DragInTheBlank/choice.js.map +1 -1
- package/lib/components/respArea/ExplicitConstructedResponse.js +8 -0
- package/lib/components/respArea/ExplicitConstructedResponse.js.map +1 -1
- package/lib/components/respArea/InlineDropdown.js +7 -0
- package/lib/components/respArea/InlineDropdown.js.map +1 -1
- package/lib/components/respArea/ToolbarIcon.js +10 -0
- package/lib/components/respArea/ToolbarIcon.js.map +1 -1
- package/lib/constants.js +1 -0
- package/lib/constants.js.map +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.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 +22 -2
- package/lib/extensions/css.js +11 -0
- package/lib/extensions/css.js.map +1 -1
- package/lib/extensions/custom-toolbar-wrapper.js +15 -0
- package/lib/extensions/custom-toolbar-wrapper.js.map +1 -1
- package/lib/extensions/extended-table.js +4 -0
- package/lib/extensions/extended-table.js.map +1 -1
- package/lib/extensions/image-component.js +314 -0
- package/lib/extensions/image-component.js.map +1 -0
- package/lib/extensions/image.js +13 -2
- package/lib/extensions/image.js.map +1 -1
- package/lib/extensions/index.js +12 -2
- package/lib/extensions/index.js.map +1 -1
- package/lib/extensions/math.js +16 -0
- package/lib/extensions/math.js.map +1 -1
- package/lib/extensions/media.js +15 -0
- package/lib/extensions/media.js.map +1 -1
- package/lib/extensions/responseArea.js +22 -0
- package/lib/extensions/responseArea.js.map +1 -1
- package/lib/index.js +7 -0
- package/lib/index.js.map +1 -1
- package/lib/styles/editorContainerStyles.js +1 -0
- package/lib/styles/editorContainerStyles.js.map +1 -1
- package/lib/theme.js +1 -0
- package/lib/theme.js.map +1 -1
- package/lib/utils/size.js +6 -0
- package/lib/utils/size.js.map +1 -1
- package/package.json +8 -8
- package/src/__tests__/EditableHtml.test.jsx +266 -0
- package/src/__tests__/constants.test.js +20 -0
- package/src/__tests__/extensions.test.js +208 -0
- package/src/__tests__/index.test.jsx +146 -0
- package/src/__tests__/size-utils.test.js +64 -0
- package/src/__tests__/theme.test.js +17 -0
- package/src/components/EditableHtml.jsx +8 -6
- package/src/components/__tests__/AltDialog.test.jsx +147 -0
- package/src/components/__tests__/CharacterPicker.test.jsx +195 -0
- package/src/components/__tests__/CssIcon.test.jsx +46 -0
- package/src/components/__tests__/DragInTheBlank.test.jsx +255 -0
- package/src/components/__tests__/ExplicitConstructedResponse.test.jsx +161 -0
- package/src/components/__tests__/ImageToolbar.test.jsx +128 -0
- package/src/components/__tests__/InlineDropdown.test.jsx +187 -0
- package/src/components/__tests__/InsertImageHandler.test.js +154 -0
- package/src/components/__tests__/MediaDialog.test.jsx +293 -0
- package/src/components/__tests__/MediaToolbar.test.jsx +74 -0
- package/src/components/__tests__/MediaWrapper.test.jsx +81 -0
- package/src/components/__tests__/MenuBar.test.jsx +217 -0
- package/src/components/__tests__/RespArea.test.jsx +122 -0
- package/src/components/__tests__/TableIcons.test.jsx +149 -0
- package/src/components/__tests__/TextAlign.test.jsx +167 -0
- package/src/components/__tests__/TiptapContainer.test.jsx +138 -0
- package/src/components/__tests__/characterUtils.test.js +166 -0
- package/src/components/__tests__/choice.test.jsx +171 -0
- package/src/components/__tests__/custom-popper.test.jsx +82 -0
- package/src/components/__tests__/done-button.test.jsx +54 -0
- package/src/components/__tests__/toolbar-buttons.test.jsx +234 -0
- package/src/extensions/__tests__/css.test.js +196 -0
- package/src/extensions/__tests__/custom-toolbar-wrapper.test.jsx +180 -0
- package/src/extensions/__tests__/extended-table.test.js +107 -0
- package/src/extensions/__tests__/image-component.test.jsx +249 -0
- package/src/extensions/__tests__/image.test.js +136 -0
- package/src/extensions/__tests__/media.test.js +270 -0
- package/src/extensions/__tests__/responseArea.test.js +310 -0
- package/src/extensions/{component.jsx → image-component.jsx} +11 -1
- package/src/extensions/image.js +1 -1
- 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,313 @@
|
|
|
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.get-own-property-descriptor.js");
|
|
8
|
+
require("core-js/modules/es.object.get-own-property-descriptors.js");
|
|
9
|
+
require("core-js/modules/es.object.keys.js");
|
|
10
|
+
require("core-js/modules/es.object.to-string.js");
|
|
11
|
+
require("core-js/modules/web.dom-collections.for-each.js");
|
|
12
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
13
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
14
|
+
require("core-js/modules/es.object.define-property.js");
|
|
15
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
16
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
17
|
+
var _react = _interopRequireDefault(require("react"));
|
|
18
|
+
var _react2 = require("@testing-library/react");
|
|
19
|
+
var _CharacterPicker = require("../CharacterPicker");
|
|
20
|
+
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; }
|
|
21
|
+
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; }
|
|
22
|
+
jest.mock('react-dom', function () {
|
|
23
|
+
return _objectSpread(_objectSpread({}, jest.requireActual('react-dom')), {}, {
|
|
24
|
+
createPortal: function createPortal(node) {
|
|
25
|
+
return node;
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
jest.mock('@pie-lib/math-toolbar', function () {
|
|
30
|
+
return {
|
|
31
|
+
PureToolbar: function PureToolbar(_ref) {
|
|
32
|
+
var onChange = _ref.onChange,
|
|
33
|
+
onDone = _ref.onDone,
|
|
34
|
+
additionalKeys = _ref.additionalKeys;
|
|
35
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
36
|
+
"data-testid": "pure-toolbar"
|
|
37
|
+
}, /*#__PURE__*/_react["default"].createElement("button", {
|
|
38
|
+
onClick: function onClick() {
|
|
39
|
+
return onChange('á');
|
|
40
|
+
},
|
|
41
|
+
"data-testid": "char-button"
|
|
42
|
+
}, "\xE1"), /*#__PURE__*/_react["default"].createElement("button", {
|
|
43
|
+
onClick: onDone,
|
|
44
|
+
"data-testid": "done-button"
|
|
45
|
+
}, "Done"));
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
});
|
|
49
|
+
jest.mock('../characters/custom-popper', function () {
|
|
50
|
+
return {
|
|
51
|
+
__esModule: true,
|
|
52
|
+
"default": function _default(_ref2) {
|
|
53
|
+
var children = _ref2.children,
|
|
54
|
+
onClose = _ref2.onClose;
|
|
55
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
56
|
+
"data-testid": "custom-popper"
|
|
57
|
+
}, children, /*#__PURE__*/_react["default"].createElement("button", {
|
|
58
|
+
onClick: onClose,
|
|
59
|
+
"data-testid": "close-popper"
|
|
60
|
+
}, "Close"));
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
});
|
|
64
|
+
describe('CharacterIcon', function () {
|
|
65
|
+
it('renders with letter', function () {
|
|
66
|
+
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterIcon, {
|
|
67
|
+
letter: "\xF1"
|
|
68
|
+
})),
|
|
69
|
+
getByText = _render.getByText;
|
|
70
|
+
expect(getByText('ñ')).toBeInTheDocument();
|
|
71
|
+
});
|
|
72
|
+
it('renders with correct styling', function () {
|
|
73
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterIcon, {
|
|
74
|
+
letter: "\u20AC"
|
|
75
|
+
})),
|
|
76
|
+
container = _render2.container;
|
|
77
|
+
var div = container.firstChild;
|
|
78
|
+
expect(div).toHaveStyle({
|
|
79
|
+
fontSize: '24px',
|
|
80
|
+
lineHeight: '24px'
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
describe('CharacterPicker', function () {
|
|
85
|
+
var mockEditor = {
|
|
86
|
+
chain: jest.fn(function () {
|
|
87
|
+
return {
|
|
88
|
+
focus: jest.fn(function () {
|
|
89
|
+
return {
|
|
90
|
+
insertContent: jest.fn(function () {
|
|
91
|
+
return {
|
|
92
|
+
run: jest.fn()
|
|
93
|
+
};
|
|
94
|
+
})
|
|
95
|
+
};
|
|
96
|
+
})
|
|
97
|
+
};
|
|
98
|
+
}),
|
|
99
|
+
options: {
|
|
100
|
+
element: document.createElement('div')
|
|
101
|
+
},
|
|
102
|
+
view: {
|
|
103
|
+
coordsAtPos: jest.fn(function () {
|
|
104
|
+
return {
|
|
105
|
+
top: 100,
|
|
106
|
+
left: 50
|
|
107
|
+
};
|
|
108
|
+
}),
|
|
109
|
+
dom: document.createElement('div')
|
|
110
|
+
},
|
|
111
|
+
state: {
|
|
112
|
+
selection: {
|
|
113
|
+
from: 0
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
beforeEach(function () {
|
|
118
|
+
jest.clearAllMocks();
|
|
119
|
+
// Reset the element to avoid "Cannot redefine property" error
|
|
120
|
+
mockEditor.options.element = document.createElement('div');
|
|
121
|
+
Object.defineProperty(mockEditor.options.element, 'getBoundingClientRect', {
|
|
122
|
+
value: jest.fn(function () {
|
|
123
|
+
return {
|
|
124
|
+
top: 0,
|
|
125
|
+
left: 0,
|
|
126
|
+
height: 100
|
|
127
|
+
};
|
|
128
|
+
}),
|
|
129
|
+
configurable: true
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
it('returns null when opts has no characters', function () {
|
|
133
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
134
|
+
editor: mockEditor,
|
|
135
|
+
opts: {},
|
|
136
|
+
onClose: jest.fn()
|
|
137
|
+
})),
|
|
138
|
+
container = _render3.container;
|
|
139
|
+
expect(container.firstChild).toBeNull();
|
|
140
|
+
});
|
|
141
|
+
it('returns null when opts is not provided', function () {
|
|
142
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
143
|
+
editor: mockEditor,
|
|
144
|
+
opts: null,
|
|
145
|
+
onClose: jest.fn()
|
|
146
|
+
})),
|
|
147
|
+
container = _render4.container;
|
|
148
|
+
expect(container.firstChild).toBeNull();
|
|
149
|
+
});
|
|
150
|
+
it('renders character picker with spanish config', function () {
|
|
151
|
+
var opts = {
|
|
152
|
+
language: 'spanish',
|
|
153
|
+
characters: [['á', 'é', 'í']]
|
|
154
|
+
};
|
|
155
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
156
|
+
editor: mockEditor,
|
|
157
|
+
opts: opts,
|
|
158
|
+
onClose: jest.fn()
|
|
159
|
+
})),
|
|
160
|
+
getByTestId = _render5.getByTestId;
|
|
161
|
+
expect(getByTestId('pure-toolbar')).toBeInTheDocument();
|
|
162
|
+
});
|
|
163
|
+
it('renders character picker with special config', function () {
|
|
164
|
+
var opts = {
|
|
165
|
+
language: 'special',
|
|
166
|
+
characters: [['€', '£']]
|
|
167
|
+
};
|
|
168
|
+
var _render6 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
169
|
+
editor: mockEditor,
|
|
170
|
+
opts: opts,
|
|
171
|
+
onClose: jest.fn()
|
|
172
|
+
})),
|
|
173
|
+
getByTestId = _render6.getByTestId;
|
|
174
|
+
expect(getByTestId('pure-toolbar')).toBeInTheDocument();
|
|
175
|
+
});
|
|
176
|
+
it('handles character insertion', function () {
|
|
177
|
+
var opts = {
|
|
178
|
+
characters: [['á', 'é']]
|
|
179
|
+
};
|
|
180
|
+
var _render7 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
181
|
+
editor: mockEditor,
|
|
182
|
+
opts: opts,
|
|
183
|
+
onClose: jest.fn()
|
|
184
|
+
})),
|
|
185
|
+
getByTestId = _render7.getByTestId;
|
|
186
|
+
_react2.fireEvent.click(getByTestId('char-button'));
|
|
187
|
+
expect(mockEditor.chain).toHaveBeenCalled();
|
|
188
|
+
});
|
|
189
|
+
it('calls onClose when done button is clicked', function () {
|
|
190
|
+
var onClose = jest.fn();
|
|
191
|
+
var opts = {
|
|
192
|
+
characters: [['á', 'é']]
|
|
193
|
+
};
|
|
194
|
+
var _render8 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
195
|
+
editor: mockEditor,
|
|
196
|
+
opts: opts,
|
|
197
|
+
onClose: onClose
|
|
198
|
+
})),
|
|
199
|
+
getByTestId = _render8.getByTestId;
|
|
200
|
+
_react2.fireEvent.click(getByTestId('done-button'));
|
|
201
|
+
expect(onClose).toHaveBeenCalled();
|
|
202
|
+
});
|
|
203
|
+
it('closes on outside click', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
204
|
+
var onClose, opts;
|
|
205
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
206
|
+
while (1) switch (_context.prev = _context.next) {
|
|
207
|
+
case 0:
|
|
208
|
+
onClose = jest.fn();
|
|
209
|
+
opts = {
|
|
210
|
+
characters: [['á', 'é']]
|
|
211
|
+
};
|
|
212
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
213
|
+
editor: mockEditor,
|
|
214
|
+
opts: opts,
|
|
215
|
+
onClose: onClose
|
|
216
|
+
}));
|
|
217
|
+
_context.next = 1;
|
|
218
|
+
return (0, _react2.waitFor)(function () {
|
|
219
|
+
_react2.fireEvent.mouseDown(document.body);
|
|
220
|
+
});
|
|
221
|
+
case 1:
|
|
222
|
+
expect(onClose).toHaveBeenCalled();
|
|
223
|
+
case 2:
|
|
224
|
+
case "end":
|
|
225
|
+
return _context.stop();
|
|
226
|
+
}
|
|
227
|
+
}, _callee);
|
|
228
|
+
})));
|
|
229
|
+
it('does not close when clicking inside picker', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
230
|
+
var onClose, opts, _render9, container;
|
|
231
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
232
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
233
|
+
case 0:
|
|
234
|
+
onClose = jest.fn();
|
|
235
|
+
opts = {
|
|
236
|
+
characters: [['á', 'é']]
|
|
237
|
+
};
|
|
238
|
+
_render9 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
239
|
+
editor: mockEditor,
|
|
240
|
+
opts: opts,
|
|
241
|
+
onClose: onClose
|
|
242
|
+
})), container = _render9.container;
|
|
243
|
+
_context2.next = 1;
|
|
244
|
+
return (0, _react2.waitFor)(function () {
|
|
245
|
+
var picker = container.querySelector('.insert-character-dialog');
|
|
246
|
+
if (picker) {
|
|
247
|
+
_react2.fireEvent.mouseDown(picker);
|
|
248
|
+
}
|
|
249
|
+
});
|
|
250
|
+
case 1:
|
|
251
|
+
expect(onClose).not.toHaveBeenCalled();
|
|
252
|
+
case 2:
|
|
253
|
+
case "end":
|
|
254
|
+
return _context2.stop();
|
|
255
|
+
}
|
|
256
|
+
}, _callee2);
|
|
257
|
+
})));
|
|
258
|
+
it('renders with custom opts structure', function () {
|
|
259
|
+
var opts = {
|
|
260
|
+
characters: [[{
|
|
261
|
+
name: 'a',
|
|
262
|
+
write: 'á',
|
|
263
|
+
label: 'á'
|
|
264
|
+
}, {
|
|
265
|
+
name: 'e',
|
|
266
|
+
write: 'é',
|
|
267
|
+
label: 'é'
|
|
268
|
+
}]]
|
|
269
|
+
};
|
|
270
|
+
var _render0 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
271
|
+
editor: mockEditor,
|
|
272
|
+
opts: opts,
|
|
273
|
+
onClose: jest.fn()
|
|
274
|
+
})),
|
|
275
|
+
getByTestId = _render0.getByTestId;
|
|
276
|
+
expect(getByTestId('pure-toolbar')).toBeInTheDocument();
|
|
277
|
+
});
|
|
278
|
+
it('renders with hasPreview option', function () {
|
|
279
|
+
var opts = {
|
|
280
|
+
hasPreview: true,
|
|
281
|
+
characters: [[{
|
|
282
|
+
name: 'euro',
|
|
283
|
+
write: '€',
|
|
284
|
+
label: '€',
|
|
285
|
+
description: 'Euro sign',
|
|
286
|
+
unicode: 'U+20AC'
|
|
287
|
+
}]]
|
|
288
|
+
};
|
|
289
|
+
var _render1 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
290
|
+
editor: mockEditor,
|
|
291
|
+
opts: opts,
|
|
292
|
+
onClose: jest.fn()
|
|
293
|
+
})),
|
|
294
|
+
getByTestId = _render1.getByTestId;
|
|
295
|
+
expect(getByTestId('pure-toolbar')).toBeInTheDocument();
|
|
296
|
+
});
|
|
297
|
+
it('calculates position correctly', function () {
|
|
298
|
+
var opts = {
|
|
299
|
+
characters: [['á']]
|
|
300
|
+
};
|
|
301
|
+
var _render10 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CharacterPicker.CharacterPicker, {
|
|
302
|
+
editor: mockEditor,
|
|
303
|
+
opts: opts,
|
|
304
|
+
onClose: jest.fn()
|
|
305
|
+
})),
|
|
306
|
+
container = _render10.container;
|
|
307
|
+
var dialog = container.querySelector('.insert-character-dialog');
|
|
308
|
+
expect(dialog).toHaveStyle({
|
|
309
|
+
position: 'absolute'
|
|
310
|
+
});
|
|
311
|
+
});
|
|
312
|
+
});
|
|
313
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_CharacterPicker","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","jest","mock","requireActual","createPortal","node","PureToolbar","_ref","onChange","onDone","additionalKeys","createElement","onClick","__esModule","default","_ref2","children","onClose","describe","it","_render","render","CharacterIcon","letter","getByText","expect","toBeInTheDocument","_render2","container","div","firstChild","toHaveStyle","fontSize","lineHeight","mockEditor","chain","fn","focus","insertContent","run","options","element","document","view","coordsAtPos","top","left","dom","state","selection","from","beforeEach","clearAllMocks","value","height","configurable","_render3","CharacterPicker","editor","opts","toBeNull","_render4","language","characters","_render5","getByTestId","_render6","_render7","fireEvent","click","toHaveBeenCalled","_render8","_asyncToGenerator2","_regenerator","mark","_callee","wrap","_context","prev","next","waitFor","mouseDown","body","stop","_callee2","_render9","_context2","picker","querySelector","not","name","write","label","_render0","hasPreview","description","unicode","_render1","_render10","dialog","position"],"sources":["../../../src/components/__tests__/CharacterPicker.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, fireEvent, waitFor } from '@testing-library/react';\nimport { CharacterPicker, CharacterIcon } from '../CharacterPicker';\n\njest.mock('react-dom', () => ({\n  ...jest.requireActual('react-dom'),\n  createPortal: (node) => node,\n}));\n\njest.mock('@pie-lib/math-toolbar', () => ({\n  PureToolbar: ({ onChange, onDone, additionalKeys }) => (\n    <div data-testid=\"pure-toolbar\">\n      <button onClick={() => onChange('á')} data-testid=\"char-button\">\n        á\n      </button>\n      <button onClick={onDone} data-testid=\"done-button\">\n        Done\n      </button>\n    </div>\n  ),\n}));\n\njest.mock('../characters/custom-popper', () => ({\n  __esModule: true,\n  default: ({ children, onClose }) => (\n    <div data-testid=\"custom-popper\">\n      {children}\n      <button onClick={onClose} data-testid=\"close-popper\">\n        Close\n      </button>\n    </div>\n  ),\n}));\n\ndescribe('CharacterIcon', () => {\n  it('renders with letter', () => {\n    const { getByText } = render(<CharacterIcon letter=\"ñ\" />);\n    expect(getByText('ñ')).toBeInTheDocument();\n  });\n\n  it('renders with correct styling', () => {\n    const { container } = render(<CharacterIcon letter=\"€\" />);\n    const div = container.firstChild;\n    expect(div).toHaveStyle({ fontSize: '24px', lineHeight: '24px' });\n  });\n});\n\ndescribe('CharacterPicker', () => {\n  const mockEditor = {\n    chain: jest.fn(() => ({\n      focus: jest.fn(() => ({\n        insertContent: jest.fn(() => ({ run: jest.fn() })),\n      })),\n    })),\n    options: {\n      element: document.createElement('div'),\n    },\n    view: {\n      coordsAtPos: jest.fn(() => ({ top: 100, left: 50 })),\n      dom: document.createElement('div'),\n    },\n    state: {\n      selection: { from: 0 },\n    },\n  };\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n    // Reset the element to avoid \"Cannot redefine property\" error\n    mockEditor.options.element = document.createElement('div');\n    Object.defineProperty(mockEditor.options.element, 'getBoundingClientRect', {\n      value: jest.fn(() => ({ top: 0, left: 0, height: 100 })),\n      configurable: true,\n    });\n  });\n\n  it('returns null when opts has no characters', () => {\n    const { container } = render(<CharacterPicker editor={mockEditor} opts={{}} onClose={jest.fn()} />);\n    expect(container.firstChild).toBeNull();\n  });\n\n  it('returns null when opts is not provided', () => {\n    const { container } = render(<CharacterPicker editor={mockEditor} opts={null} onClose={jest.fn()} />);\n    expect(container.firstChild).toBeNull();\n  });\n\n  it('renders character picker with spanish config', () => {\n    const opts = {\n      language: 'spanish',\n      characters: [['á', 'é', 'í']],\n    };\n    const { getByTestId } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={jest.fn()} />);\n    expect(getByTestId('pure-toolbar')).toBeInTheDocument();\n  });\n\n  it('renders character picker with special config', () => {\n    const opts = {\n      language: 'special',\n      characters: [['€', '£']],\n    };\n    const { getByTestId } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={jest.fn()} />);\n    expect(getByTestId('pure-toolbar')).toBeInTheDocument();\n  });\n\n  it('handles character insertion', () => {\n    const opts = {\n      characters: [['á', 'é']],\n    };\n    const { getByTestId } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={jest.fn()} />);\n    fireEvent.click(getByTestId('char-button'));\n    expect(mockEditor.chain).toHaveBeenCalled();\n  });\n\n  it('calls onClose when done button is clicked', () => {\n    const onClose = jest.fn();\n    const opts = {\n      characters: [['á', 'é']],\n    };\n    const { getByTestId } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={onClose} />);\n    fireEvent.click(getByTestId('done-button'));\n    expect(onClose).toHaveBeenCalled();\n  });\n\n  it('closes on outside click', async () => {\n    const onClose = jest.fn();\n    const opts = {\n      characters: [['á', 'é']],\n    };\n    render(<CharacterPicker editor={mockEditor} opts={opts} onClose={onClose} />);\n\n    await waitFor(() => {\n      fireEvent.mouseDown(document.body);\n    });\n\n    expect(onClose).toHaveBeenCalled();\n  });\n\n  it('does not close when clicking inside picker', async () => {\n    const onClose = jest.fn();\n    const opts = {\n      characters: [['á', 'é']],\n    };\n    const { container } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={onClose} />);\n\n    await waitFor(() => {\n      const picker = container.querySelector('.insert-character-dialog');\n      if (picker) {\n        fireEvent.mouseDown(picker);\n      }\n    });\n\n    expect(onClose).not.toHaveBeenCalled();\n  });\n\n  it('renders with custom opts structure', () => {\n    const opts = {\n      characters: [\n        [\n          { name: 'a', write: 'á', label: 'á' },\n          { name: 'e', write: 'é', label: 'é' },\n        ],\n      ],\n    };\n    const { getByTestId } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={jest.fn()} />);\n    expect(getByTestId('pure-toolbar')).toBeInTheDocument();\n  });\n\n  it('renders with hasPreview option', () => {\n    const opts = {\n      hasPreview: true,\n      characters: [\n        [\n          {\n            name: 'euro',\n            write: '€',\n            label: '€',\n            description: 'Euro sign',\n            unicode: 'U+20AC',\n          },\n        ],\n      ],\n    };\n    const { getByTestId } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={jest.fn()} />);\n    expect(getByTestId('pure-toolbar')).toBeInTheDocument();\n  });\n\n  it('calculates position correctly', () => {\n    const opts = {\n      characters: [['á']],\n    };\n    const { container } = render(<CharacterPicker editor={mockEditor} opts={opts} onClose={jest.fn()} />);\n    const dialog = container.querySelector('.insert-character-dialog');\n    expect(dialog).toHaveStyle({ position: 'absolute' });\n  });\n});\n"],"mappings":";;;;;;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,gBAAA,GAAAF,OAAA;AAAoE,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;AAEpEoB,IAAI,CAACC,IAAI,CAAC,WAAW,EAAE;EAAA,OAAAT,aAAA,CAAAA,aAAA,KAClBQ,IAAI,CAACE,aAAa,CAAC,WAAW,CAAC;IAClCC,YAAY,EAAE,SAAdA,YAAYA,CAAGC,IAAI;MAAA,OAAKA,IAAI;IAAA;EAAA;AAAA,CAC5B,CAAC;AAEHJ,IAAI,CAACC,IAAI,CAAC,uBAAuB,EAAE;EAAA,OAAO;IACxCI,WAAW,EAAE,SAAbA,WAAWA,CAAAC,IAAA;MAAA,IAAKC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;QAAEC,MAAM,GAAAF,IAAA,CAANE,MAAM;QAAEC,cAAc,GAAAH,IAAA,CAAdG,cAAc;MAAA,oBAC9CnC,MAAA,YAAAoC,aAAA;QAAK,eAAY;MAAc,gBAC7BpC,MAAA,YAAAoC,aAAA;QAAQC,OAAO,EAAE,SAATA,OAAOA,CAAA;UAAA,OAAQJ,QAAQ,CAAC,GAAG,CAAC;QAAA,CAAC;QAAC,eAAY;MAAa,GAAC,MAExD,CAAC,eACTjC,MAAA,YAAAoC,aAAA;QAAQC,OAAO,EAAEH,MAAO;QAAC,eAAY;MAAa,GAAC,MAE3C,CACL,CAAC;IAAA;EAEV,CAAC;AAAA,CAAC,CAAC;AAEHR,IAAI,CAACC,IAAI,CAAC,6BAA6B,EAAE;EAAA,OAAO;IAC9CW,UAAU,EAAE,IAAI;IAChB,WAAS,SAATC,QAAOA,CAAAC,KAAA;MAAA,IAAKC,QAAQ,GAAAD,KAAA,CAARC,QAAQ;QAAEC,OAAO,GAAAF,KAAA,CAAPE,OAAO;MAAA,oBAC3B1C,MAAA,YAAAoC,aAAA;QAAK,eAAY;MAAe,GAC7BK,QAAQ,eACTzC,MAAA,YAAAoC,aAAA;QAAQC,OAAO,EAAEK,OAAQ;QAAC,eAAY;MAAc,GAAC,OAE7C,CACL,CAAC;IAAA;EAEV,CAAC;AAAA,CAAC,CAAC;AAEHC,QAAQ,CAAC,eAAe,EAAE,YAAM;EAC9BC,EAAE,CAAC,qBAAqB,EAAE,YAAM;IAC9B,IAAAC,OAAA,GAAsB,IAAAC,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA2C,aAAa;QAACC,MAAM,EAAC;MAAG,CAAE,CAAC,CAAC;MAAlDC,SAAS,GAAAJ,OAAA,CAATI,SAAS;IACjBC,MAAM,CAACD,SAAS,CAAC,GAAG,CAAC,CAAC,CAACE,iBAAiB,CAAC,CAAC;EAC5C,CAAC,CAAC;EAEFP,EAAE,CAAC,8BAA8B,EAAE,YAAM;IACvC,IAAAQ,QAAA,GAAsB,IAAAN,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA2C,aAAa;QAACC,MAAM,EAAC;MAAG,CAAE,CAAC,CAAC;MAAlDK,SAAS,GAAAD,QAAA,CAATC,SAAS;IACjB,IAAMC,GAAG,GAAGD,SAAS,CAACE,UAAU;IAChCL,MAAM,CAACI,GAAG,CAAC,CAACE,WAAW,CAAC;MAAEC,QAAQ,EAAE,MAAM;MAAEC,UAAU,EAAE;IAAO,CAAC,CAAC;EACnE,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFf,QAAQ,CAAC,iBAAiB,EAAE,YAAM;EAChC,IAAMgB,UAAU,GAAG;IACjBC,KAAK,EAAElC,IAAI,CAACmC,EAAE,CAAC;MAAA,OAAO;QACpBC,KAAK,EAAEpC,IAAI,CAACmC,EAAE,CAAC;UAAA,OAAO;YACpBE,aAAa,EAAErC,IAAI,CAACmC,EAAE,CAAC;cAAA,OAAO;gBAAEG,GAAG,EAAEtC,IAAI,CAACmC,EAAE,CAAC;cAAE,CAAC;YAAA,CAAC;UACnD,CAAC;QAAA,CAAC;MACJ,CAAC;IAAA,CAAC,CAAC;IACHI,OAAO,EAAE;MACPC,OAAO,EAAEC,QAAQ,CAAC/B,aAAa,CAAC,KAAK;IACvC,CAAC;IACDgC,IAAI,EAAE;MACJC,WAAW,EAAE3C,IAAI,CAACmC,EAAE,CAAC;QAAA,OAAO;UAAES,GAAG,EAAE,GAAG;UAAEC,IAAI,EAAE;QAAG,CAAC;MAAA,CAAC,CAAC;MACpDC,GAAG,EAAEL,QAAQ,CAAC/B,aAAa,CAAC,KAAK;IACnC,CAAC;IACDqC,KAAK,EAAE;MACLC,SAAS,EAAE;QAAEC,IAAI,EAAE;MAAE;IACvB;EACF,CAAC;EAEDC,UAAU,CAAC,YAAM;IACflD,IAAI,CAACmD,aAAa,CAAC,CAAC;IACpB;IACAlB,UAAU,CAACM,OAAO,CAACC,OAAO,GAAGC,QAAQ,CAAC/B,aAAa,CAAC,KAAK,CAAC;IAC1D3B,MAAM,CAACgB,cAAc,CAACkC,UAAU,CAACM,OAAO,CAACC,OAAO,EAAE,uBAAuB,EAAE;MACzEY,KAAK,EAAEpD,IAAI,CAACmC,EAAE,CAAC;QAAA,OAAO;UAAES,GAAG,EAAE,CAAC;UAAEC,IAAI,EAAE,CAAC;UAAEQ,MAAM,EAAE;QAAI,CAAC;MAAA,CAAC,CAAC;MACxDC,YAAY,EAAE;IAChB,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFpC,EAAE,CAAC,0CAA0C,EAAE,YAAM;IACnD,IAAAqC,QAAA,GAAsB,IAAAnC,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAE,CAAC,CAAE;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA3FR,SAAS,GAAA4B,QAAA,CAAT5B,SAAS;IACjBH,MAAM,CAACG,SAAS,CAACE,UAAU,CAAC,CAAC8B,QAAQ,CAAC,CAAC;EACzC,CAAC,CAAC;EAEFzC,EAAE,CAAC,wCAAwC,EAAE,YAAM;IACjD,IAAA0C,QAAA,GAAsB,IAAAxC,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAE,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA7FR,SAAS,GAAAiC,QAAA,CAATjC,SAAS;IACjBH,MAAM,CAACG,SAAS,CAACE,UAAU,CAAC,CAAC8B,QAAQ,CAAC,CAAC;EACzC,CAAC,CAAC;EAEFzC,EAAE,CAAC,8CAA8C,EAAE,YAAM;IACvD,IAAMwC,IAAI,GAAG;MACXG,QAAQ,EAAE,SAAS;MACnBC,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;IAC9B,CAAC;IACD,IAAAC,QAAA,GAAwB,IAAA3C,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA/F6B,WAAW,GAAAD,QAAA,CAAXC,WAAW;IACnBxC,MAAM,CAACwC,WAAW,CAAC,cAAc,CAAC,CAAC,CAACvC,iBAAiB,CAAC,CAAC;EACzD,CAAC,CAAC;EAEFP,EAAE,CAAC,8CAA8C,EAAE,YAAM;IACvD,IAAMwC,IAAI,GAAG;MACXG,QAAQ,EAAE,SAAS;MACnBC,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;IACzB,CAAC;IACD,IAAAG,QAAA,GAAwB,IAAA7C,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA/F6B,WAAW,GAAAC,QAAA,CAAXD,WAAW;IACnBxC,MAAM,CAACwC,WAAW,CAAC,cAAc,CAAC,CAAC,CAACvC,iBAAiB,CAAC,CAAC;EACzD,CAAC,CAAC;EAEFP,EAAE,CAAC,6BAA6B,EAAE,YAAM;IACtC,IAAMwC,IAAI,GAAG;MACXI,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;IACzB,CAAC;IACD,IAAAI,QAAA,GAAwB,IAAA9C,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA/F6B,WAAW,GAAAE,QAAA,CAAXF,WAAW;IACnBG,iBAAS,CAACC,KAAK,CAACJ,WAAW,CAAC,aAAa,CAAC,CAAC;IAC3CxC,MAAM,CAACS,UAAU,CAACC,KAAK,CAAC,CAACmC,gBAAgB,CAAC,CAAC;EAC7C,CAAC,CAAC;EAEFnD,EAAE,CAAC,2CAA2C,EAAE,YAAM;IACpD,IAAMF,OAAO,GAAGhB,IAAI,CAACmC,EAAE,CAAC,CAAC;IACzB,IAAMuB,IAAI,GAAG;MACXI,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;IACzB,CAAC;IACD,IAAAQ,QAAA,GAAwB,IAAAlD,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEA;MAAQ,CAAE,CAAC,CAAC;MAA7FgD,WAAW,GAAAM,QAAA,CAAXN,WAAW;IACnBG,iBAAS,CAACC,KAAK,CAACJ,WAAW,CAAC,aAAa,CAAC,CAAC;IAC3CxC,MAAM,CAACR,OAAO,CAAC,CAACqD,gBAAgB,CAAC,CAAC;EACpC,CAAC,CAAC;EAEFnD,EAAE,CAAC,yBAAyB,mBAAAqD,kBAAA,0BAAAC,YAAA,YAAAC,IAAA,CAAE,SAAAC,QAAA;IAAA,IAAA1D,OAAA,EAAA0C,IAAA;IAAA,OAAAc,YAAA,YAAAG,IAAA,WAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;QAAA;UACtB9D,OAAO,GAAGhB,IAAI,CAACmC,EAAE,CAAC,CAAC;UACnBuB,IAAI,GAAG;YACXI,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;UACzB,CAAC;UACD,IAAA1C,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;YAACC,MAAM,EAAExB,UAAW;YAACyB,IAAI,EAAEA,IAAK;YAAC1C,OAAO,EAAEA;UAAQ,CAAE,CAAC,CAAC;UAAC4D,QAAA,CAAAE,IAAA;UAAA,OAExE,IAAAC,eAAO,EAAC,YAAM;YAClBZ,iBAAS,CAACa,SAAS,CAACvC,QAAQ,CAACwC,IAAI,CAAC;UACpC,CAAC,CAAC;QAAA;UAEFzD,MAAM,CAACR,OAAO,CAAC,CAACqD,gBAAgB,CAAC,CAAC;QAAC;QAAA;UAAA,OAAAO,QAAA,CAAAM,IAAA;MAAA;IAAA,GAAAR,OAAA;EAAA,CACpC,GAAC;EAEFxD,EAAE,CAAC,4CAA4C,mBAAAqD,kBAAA,0BAAAC,YAAA,YAAAC,IAAA,CAAE,SAAAU,SAAA;IAAA,IAAAnE,OAAA,EAAA0C,IAAA,EAAA0B,QAAA,EAAAzD,SAAA;IAAA,OAAA6C,YAAA,YAAAG,IAAA,WAAAU,SAAA;MAAA,kBAAAA,SAAA,CAAAR,IAAA,GAAAQ,SAAA,CAAAP,IAAA;QAAA;UACzC9D,OAAO,GAAGhB,IAAI,CAACmC,EAAE,CAAC,CAAC;UACnBuB,IAAI,GAAG;YACXI,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;UACzB,CAAC;UAAAsB,QAAA,GACqB,IAAAhE,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;YAACC,MAAM,EAAExB,UAAW;YAACyB,IAAI,EAAEA,IAAK;YAAC1C,OAAO,EAAEA;UAAQ,CAAE,CAAC,CAAC,EAA3FW,SAAS,GAAAyD,QAAA,CAATzD,SAAS;UAAA0D,SAAA,CAAAP,IAAA;UAAA,OAEX,IAAAC,eAAO,EAAC,YAAM;YAClB,IAAMO,MAAM,GAAG3D,SAAS,CAAC4D,aAAa,CAAC,0BAA0B,CAAC;YAClE,IAAID,MAAM,EAAE;cACVnB,iBAAS,CAACa,SAAS,CAACM,MAAM,CAAC;YAC7B;UACF,CAAC,CAAC;QAAA;UAEF9D,MAAM,CAACR,OAAO,CAAC,CAACwE,GAAG,CAACnB,gBAAgB,CAAC,CAAC;QAAC;QAAA;UAAA,OAAAgB,SAAA,CAAAH,IAAA;MAAA;IAAA,GAAAC,QAAA;EAAA,CACxC,GAAC;EAEFjE,EAAE,CAAC,oCAAoC,EAAE,YAAM;IAC7C,IAAMwC,IAAI,GAAG;MACXI,UAAU,EAAE,CACV,CACE;QAAE2B,IAAI,EAAE,GAAG;QAAEC,KAAK,EAAE,GAAG;QAAEC,KAAK,EAAE;MAAI,CAAC,EACrC;QAAEF,IAAI,EAAE,GAAG;QAAEC,KAAK,EAAE,GAAG;QAAEC,KAAK,EAAE;MAAI,CAAC,CACtC;IAEL,CAAC;IACD,IAAAC,QAAA,GAAwB,IAAAxE,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA/F6B,WAAW,GAAA4B,QAAA,CAAX5B,WAAW;IACnBxC,MAAM,CAACwC,WAAW,CAAC,cAAc,CAAC,CAAC,CAACvC,iBAAiB,CAAC,CAAC;EACzD,CAAC,CAAC;EAEFP,EAAE,CAAC,gCAAgC,EAAE,YAAM;IACzC,IAAMwC,IAAI,GAAG;MACXmC,UAAU,EAAE,IAAI;MAChB/B,UAAU,EAAE,CACV,CACE;QACE2B,IAAI,EAAE,MAAM;QACZC,KAAK,EAAE,GAAG;QACVC,KAAK,EAAE,GAAG;QACVG,WAAW,EAAE,WAAW;QACxBC,OAAO,EAAE;MACX,CAAC,CACF;IAEL,CAAC;IACD,IAAAC,QAAA,GAAwB,IAAA5E,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA/F6B,WAAW,GAAAgC,QAAA,CAAXhC,WAAW;IACnBxC,MAAM,CAACwC,WAAW,CAAC,cAAc,CAAC,CAAC,CAACvC,iBAAiB,CAAC,CAAC;EACzD,CAAC,CAAC;EAEFP,EAAE,CAAC,+BAA+B,EAAE,YAAM;IACxC,IAAMwC,IAAI,GAAG;MACXI,UAAU,EAAE,CAAC,CAAC,GAAG,CAAC;IACpB,CAAC;IACD,IAAAmC,SAAA,GAAsB,IAAA7E,cAAM,eAAC9C,MAAA,YAAAoC,aAAA,CAAChC,gBAAA,CAAA8E,eAAe;QAACC,MAAM,EAAExB,UAAW;QAACyB,IAAI,EAAEA,IAAK;QAAC1C,OAAO,EAAEhB,IAAI,CAACmC,EAAE,CAAC;MAAE,CAAE,CAAC,CAAC;MAA7FR,SAAS,GAAAsE,SAAA,CAATtE,SAAS;IACjB,IAAMuE,MAAM,GAAGvE,SAAS,CAAC4D,aAAa,CAAC,0BAA0B,CAAC;IAClE/D,MAAM,CAAC0E,MAAM,CAAC,CAACpE,WAAW,CAAC;MAAEqE,QAAQ,EAAE;IAAW,CAAC,CAAC;EACtD,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _CssIcon = _interopRequireDefault(require("../icons/CssIcon"));
|
|
7
|
+
describe('CssIcon', function () {
|
|
8
|
+
it('renders without crashing', function () {
|
|
9
|
+
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
10
|
+
container = _render.container;
|
|
11
|
+
expect(container).toBeInTheDocument();
|
|
12
|
+
});
|
|
13
|
+
it('renders CSS text', function () {
|
|
14
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
15
|
+
getByText = _render2.getByText;
|
|
16
|
+
expect(getByText('CSS')).toBeInTheDocument();
|
|
17
|
+
});
|
|
18
|
+
it('applies correct font family', function () {
|
|
19
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
20
|
+
getByText = _render3.getByText;
|
|
21
|
+
var element = getByText('CSS');
|
|
22
|
+
// Font family is applied via styled component, just verify text renders
|
|
23
|
+
expect(element).toBeInTheDocument();
|
|
24
|
+
});
|
|
25
|
+
it('applies bold font weight', function () {
|
|
26
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
27
|
+
getByText = _render4.getByText;
|
|
28
|
+
var element = getByText('CSS');
|
|
29
|
+
expect(element).toHaveStyle({
|
|
30
|
+
fontWeight: 'bold'
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
it('has correct line height', function () {
|
|
34
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
35
|
+
getByText = _render5.getByText;
|
|
36
|
+
var element = getByText('CSS');
|
|
37
|
+
expect(element).toHaveStyle({
|
|
38
|
+
lineHeight: '14px'
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
it('has relative positioning', function () {
|
|
42
|
+
var _render6 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
43
|
+
getByText = _render6.getByText;
|
|
44
|
+
var element = getByText('CSS');
|
|
45
|
+
expect(element).toHaveStyle({
|
|
46
|
+
position: 'relative'
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
it('has nowrap white space', function () {
|
|
50
|
+
var _render7 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_CssIcon["default"], null)),
|
|
51
|
+
getByText = _render7.getByText;
|
|
52
|
+
var element = getByText('CSS');
|
|
53
|
+
expect(element).toHaveStyle({
|
|
54
|
+
whiteSpace: 'nowrap'
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdDIiLCJfQ3NzSWNvbiIsImRlc2NyaWJlIiwiaXQiLCJfcmVuZGVyIiwicmVuZGVyIiwiY3JlYXRlRWxlbWVudCIsImNvbnRhaW5lciIsImV4cGVjdCIsInRvQmVJblRoZURvY3VtZW50IiwiX3JlbmRlcjIiLCJnZXRCeVRleHQiLCJfcmVuZGVyMyIsImVsZW1lbnQiLCJfcmVuZGVyNCIsInRvSGF2ZVN0eWxlIiwiZm9udFdlaWdodCIsIl9yZW5kZXI1IiwibGluZUhlaWdodCIsIl9yZW5kZXI2IiwicG9zaXRpb24iLCJfcmVuZGVyNyIsIndoaXRlU3BhY2UiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9fX3Rlc3RzX18vQ3NzSWNvbi50ZXN0LmpzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgcmVuZGVyIH0gZnJvbSAnQHRlc3RpbmctbGlicmFyeS9yZWFjdCc7XG5pbXBvcnQgQ3NzSWNvbiBmcm9tICcuLi9pY29ucy9Dc3NJY29uJztcblxuZGVzY3JpYmUoJ0Nzc0ljb24nLCAoKSA9PiB7XG4gIGl0KCdyZW5kZXJzIHdpdGhvdXQgY3Jhc2hpbmcnLCAoKSA9PiB7XG4gICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlcig8Q3NzSWNvbiAvPik7XG4gICAgZXhwZWN0KGNvbnRhaW5lcikudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgfSk7XG5cbiAgaXQoJ3JlbmRlcnMgQ1NTIHRleHQnLCAoKSA9PiB7XG4gICAgY29uc3QgeyBnZXRCeVRleHQgfSA9IHJlbmRlcig8Q3NzSWNvbiAvPik7XG4gICAgZXhwZWN0KGdldEJ5VGV4dCgnQ1NTJykpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gIH0pO1xuXG4gIGl0KCdhcHBsaWVzIGNvcnJlY3QgZm9udCBmYW1pbHknLCAoKSA9PiB7XG4gICAgY29uc3QgeyBnZXRCeVRleHQgfSA9IHJlbmRlcig8Q3NzSWNvbiAvPik7XG4gICAgY29uc3QgZWxlbWVudCA9IGdldEJ5VGV4dCgnQ1NTJyk7XG4gICAgLy8gRm9udCBmYW1pbHkgaXMgYXBwbGllZCB2aWEgc3R5bGVkIGNvbXBvbmVudCwganVzdCB2ZXJpZnkgdGV4dCByZW5kZXJzXG4gICAgZXhwZWN0KGVsZW1lbnQpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gIH0pO1xuXG4gIGl0KCdhcHBsaWVzIGJvbGQgZm9udCB3ZWlnaHQnLCAoKSA9PiB7XG4gICAgY29uc3QgeyBnZXRCeVRleHQgfSA9IHJlbmRlcig8Q3NzSWNvbiAvPik7XG4gICAgY29uc3QgZWxlbWVudCA9IGdldEJ5VGV4dCgnQ1NTJyk7XG4gICAgZXhwZWN0KGVsZW1lbnQpLnRvSGF2ZVN0eWxlKHsgZm9udFdlaWdodDogJ2JvbGQnIH0pO1xuICB9KTtcblxuICBpdCgnaGFzIGNvcnJlY3QgbGluZSBoZWlnaHQnLCAoKSA9PiB7XG4gICAgY29uc3QgeyBnZXRCeVRleHQgfSA9IHJlbmRlcig8Q3NzSWNvbiAvPik7XG4gICAgY29uc3QgZWxlbWVudCA9IGdldEJ5VGV4dCgnQ1NTJyk7XG4gICAgZXhwZWN0KGVsZW1lbnQpLnRvSGF2ZVN0eWxlKHsgbGluZUhlaWdodDogJzE0cHgnIH0pO1xuICB9KTtcblxuICBpdCgnaGFzIHJlbGF0aXZlIHBvc2l0aW9uaW5nJywgKCkgPT4ge1xuICAgIGNvbnN0IHsgZ2V0QnlUZXh0IH0gPSByZW5kZXIoPENzc0ljb24gLz4pO1xuICAgIGNvbnN0IGVsZW1lbnQgPSBnZXRCeVRleHQoJ0NTUycpO1xuICAgIGV4cGVjdChlbGVtZW50KS50b0hhdmVTdHlsZSh7IHBvc2l0aW9uOiAncmVsYXRpdmUnIH0pO1xuICB9KTtcblxuICBpdCgnaGFzIG5vd3JhcCB3aGl0ZSBzcGFjZScsICgpID0+IHtcbiAgICBjb25zdCB7IGdldEJ5VGV4dCB9ID0gcmVuZGVyKDxDc3NJY29uIC8+KTtcbiAgICBjb25zdCBlbGVtZW50ID0gZ2V0QnlUZXh0KCdDU1MnKTtcbiAgICBleHBlY3QoZWxlbWVudCkudG9IYXZlU3R5bGUoeyB3aGl0ZVNwYWNlOiAnbm93cmFwJyB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsUUFBQSxHQUFBSCxzQkFBQSxDQUFBQyxPQUFBO0FBRUFHLFFBQVEsQ0FBQyxTQUFTLEVBQUUsWUFBTTtFQUN4QkMsRUFBRSxDQUFDLDBCQUEwQixFQUFFLFlBQU07SUFDbkMsSUFBQUMsT0FBQSxHQUFzQixJQUFBQyxjQUFNLGVBQUNSLE1BQUEsWUFBQVMsYUFBQSxDQUFDTCxRQUFBLFdBQU8sTUFBRSxDQUFDLENBQUM7TUFBakNNLFNBQVMsR0FBQUgsT0FBQSxDQUFURyxTQUFTO0lBQ2pCQyxNQUFNLENBQUNELFNBQVMsQ0FBQyxDQUFDRSxpQkFBaUIsQ0FBQyxDQUFDO0VBQ3ZDLENBQUMsQ0FBQztFQUVGTixFQUFFLENBQUMsa0JBQWtCLEVBQUUsWUFBTTtJQUMzQixJQUFBTyxRQUFBLEdBQXNCLElBQUFMLGNBQU0sZUFBQ1IsTUFBQSxZQUFBUyxhQUFBLENBQUNMLFFBQUEsV0FBTyxNQUFFLENBQUMsQ0FBQztNQUFqQ1UsU0FBUyxHQUFBRCxRQUFBLENBQVRDLFNBQVM7SUFDakJILE1BQU0sQ0FBQ0csU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUNGLGlCQUFpQixDQUFDLENBQUM7RUFDOUMsQ0FBQyxDQUFDO0VBRUZOLEVBQUUsQ0FBQyw2QkFBNkIsRUFBRSxZQUFNO0lBQ3RDLElBQUFTLFFBQUEsR0FBc0IsSUFBQVAsY0FBTSxlQUFDUixNQUFBLFlBQUFTLGFBQUEsQ0FBQ0wsUUFBQSxXQUFPLE1BQUUsQ0FBQyxDQUFDO01BQWpDVSxTQUFTLEdBQUFDLFFBQUEsQ0FBVEQsU0FBUztJQUNqQixJQUFNRSxPQUFPLEdBQUdGLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDaEM7SUFDQUgsTUFBTSxDQUFDSyxPQUFPLENBQUMsQ0FBQ0osaUJBQWlCLENBQUMsQ0FBQztFQUNyQyxDQUFDLENBQUM7RUFFRk4sRUFBRSxDQUFDLDBCQUEwQixFQUFFLFlBQU07SUFDbkMsSUFBQVcsUUFBQSxHQUFzQixJQUFBVCxjQUFNLGVBQUNSLE1BQUEsWUFBQVMsYUFBQSxDQUFDTCxRQUFBLFdBQU8sTUFBRSxDQUFDLENBQUM7TUFBakNVLFNBQVMsR0FBQUcsUUFBQSxDQUFUSCxTQUFTO0lBQ2pCLElBQU1FLE9BQU8sR0FBR0YsU0FBUyxDQUFDLEtBQUssQ0FBQztJQUNoQ0gsTUFBTSxDQUFDSyxPQUFPLENBQUMsQ0FBQ0UsV0FBVyxDQUFDO01BQUVDLFVBQVUsRUFBRTtJQUFPLENBQUMsQ0FBQztFQUNyRCxDQUFDLENBQUM7RUFFRmIsRUFBRSxDQUFDLHlCQUF5QixFQUFFLFlBQU07SUFDbEMsSUFBQWMsUUFBQSxHQUFzQixJQUFBWixjQUFNLGVBQUNSLE1BQUEsWUFBQVMsYUFBQSxDQUFDTCxRQUFBLFdBQU8sTUFBRSxDQUFDLENBQUM7TUFBakNVLFNBQVMsR0FBQU0sUUFBQSxDQUFUTixTQUFTO0lBQ2pCLElBQU1FLE9BQU8sR0FBR0YsU0FBUyxDQUFDLEtBQUssQ0FBQztJQUNoQ0gsTUFBTSxDQUFDSyxPQUFPLENBQUMsQ0FBQ0UsV0FBVyxDQUFDO01BQUVHLFVBQVUsRUFBRTtJQUFPLENBQUMsQ0FBQztFQUNyRCxDQUFDLENBQUM7RUFFRmYsRUFBRSxDQUFDLDBCQUEwQixFQUFFLFlBQU07SUFDbkMsSUFBQWdCLFFBQUEsR0FBc0IsSUFBQWQsY0FBTSxlQUFDUixNQUFBLFlBQUFTLGFBQUEsQ0FBQ0wsUUFBQSxXQUFPLE1BQUUsQ0FBQyxDQUFDO01BQWpDVSxTQUFTLEdBQUFRLFFBQUEsQ0FBVFIsU0FBUztJQUNqQixJQUFNRSxPQUFPLEdBQUdGLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDaENILE1BQU0sQ0FBQ0ssT0FBTyxDQUFDLENBQUNFLFdBQVcsQ0FBQztNQUFFSyxRQUFRLEVBQUU7SUFBVyxDQUFDLENBQUM7RUFDdkQsQ0FBQyxDQUFDO0VBRUZqQixFQUFFLENBQUMsd0JBQXdCLEVBQUUsWUFBTTtJQUNqQyxJQUFBa0IsUUFBQSxHQUFzQixJQUFBaEIsY0FBTSxlQUFDUixNQUFBLFlBQUFTLGFBQUEsQ0FBQ0wsUUFBQSxXQUFPLE1BQUUsQ0FBQyxDQUFDO01BQWpDVSxTQUFTLEdBQUFVLFFBQUEsQ0FBVFYsU0FBUztJQUNqQixJQUFNRSxPQUFPLEdBQUdGLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDaENILE1BQU0sQ0FBQ0ssT0FBTyxDQUFDLENBQUNFLFdBQVcsQ0FBQztNQUFFTyxVQUFVLEVBQUU7SUFBUyxDQUFDLENBQUM7RUFDdkQsQ0FBQyxDQUFDO0FBQ0osQ0FBQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
|