@milkdown/plugin-emoji 5.1.2 → 5.3.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.
@@ -1 +1 @@
1
- {"version":3,"file":"style.d.ts","sourceRoot":"","sources":["../../src/filter/style.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,eAAO,MAAM,WAAW,mCAAoC,SAAS,WAoCpE,CAAC"}
1
+ {"version":3,"file":"style.d.ts","sourceRoot":"","sources":["../../src/filter/style.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,eAAO,MAAM,WAAW,mCAAoC,SAAS,WAsCpE,CAAC"}
@@ -0,0 +1,489 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { createNode, AtomList } from "@milkdown/utils";
21
+ import { css, cx, injectGlobal } from "@emotion/css";
22
+ import { Plugin, calculateNodePosition, DecorationSet, Decoration, InputRule } from "@milkdown/prose";
23
+ import nodeEmoji, { search } from "node-emoji";
24
+ import remarkEmoji from "remark-emoji";
25
+ import twemoji from "twemoji";
26
+ import { EmojiButton } from "@joeattardi/emoji-button";
27
+ import emojiRegex from "emoji-regex";
28
+ const part = /:\+1|:-1|:[\w-]+/;
29
+ const full = /:\+1:|:-1:|:[\w-]+:/;
30
+ const input = /(:([^:\s]+):)$/;
31
+ const parse = (emoji2) => twemoji.parse(emoji2, { attributes: (text) => ({ title: text }) });
32
+ const checkTrigger$1 = (view, from, to, text, setRange, setSearch) => {
33
+ if (view.composing)
34
+ return false;
35
+ const { state } = view;
36
+ const $from = state.doc.resolve(from);
37
+ if ($from.parent.type.spec.code)
38
+ return false;
39
+ const textBefore = $from.parent.textBetween(Math.max(0, $from.parentOffset - 10), $from.parentOffset, void 0, "\uFFFC") + text;
40
+ if (full.test(textBefore)) {
41
+ return false;
42
+ }
43
+ const regex2 = part.exec(textBefore);
44
+ if (regex2 && textBefore.endsWith(regex2[0])) {
45
+ const match = regex2[0];
46
+ setRange(from - (match.length - text.length), to);
47
+ setSearch(match);
48
+ return true;
49
+ }
50
+ return false;
51
+ };
52
+ const renderDropdownList = (list, dropDown, $active, onConfirm, setActive) => {
53
+ dropDown.innerHTML = "";
54
+ list.forEach(({ emoji: emoji2, key }, i) => {
55
+ const container = document.createElement("div");
56
+ container.className = "milkdown-emoji-filter_item";
57
+ const emojiSpan = document.createElement("span");
58
+ emojiSpan.innerHTML = parse(emoji2);
59
+ emojiSpan.className = "milkdown-emoji-filter_item-emoji";
60
+ const keySpan = document.createElement("span");
61
+ keySpan.textContent = ":" + key + ":";
62
+ keySpan.className = "milkdown-emoji-filter_item-key";
63
+ container.appendChild(emojiSpan);
64
+ container.appendChild(keySpan);
65
+ dropDown.appendChild(container);
66
+ if (i === 0) {
67
+ container.classList.add("active");
68
+ setActive(container);
69
+ }
70
+ container.addEventListener("mouseenter", (e) => {
71
+ if ($active) {
72
+ $active.classList.remove("active");
73
+ }
74
+ const { target } = e;
75
+ if (!(target instanceof HTMLElement))
76
+ return;
77
+ target.classList.add("active");
78
+ setActive(target);
79
+ });
80
+ container.addEventListener("mouseleave", (e) => {
81
+ const { target } = e;
82
+ if (!(target instanceof HTMLElement))
83
+ return;
84
+ target.classList.remove("active");
85
+ });
86
+ container.addEventListener("mousedown", (e) => {
87
+ onConfirm();
88
+ e.preventDefault();
89
+ });
90
+ });
91
+ };
92
+ const injectStyle = ({ size, mixin, palette, font }) => {
93
+ var _a, _b;
94
+ const border = (_a = mixin.border) == null ? void 0 : _a.call(mixin);
95
+ const shadow = (_b = mixin.shadow) == null ? void 0 : _b.call(mixin);
96
+ const style = css`
97
+ position: absolute;
98
+ &.hide {
99
+ display: none;
100
+ }
101
+
102
+ border-radius: ${size.radius};
103
+ background: ${palette("surface")};
104
+
105
+ .milkdown-emoji-filter_item {
106
+ display: flex;
107
+ gap: 0.5rem;
108
+ height: 2.25rem;
109
+ padding: 0 1rem;
110
+ align-items: center;
111
+ justify-content: flex-start;
112
+ cursor: pointer;
113
+ line-height: 2;
114
+ font-family: ${font.typography};
115
+ font-size: 0.875rem;
116
+ &.active {
117
+ background: ${palette("secondary", 0.12)};
118
+ color: ${palette("primary")};
119
+ }
120
+ }
121
+
122
+ .emoji {
123
+ height: 1em;
124
+ width: 1em;
125
+ margin: 0 0.05em 0 0.1em;
126
+ vertical-align: -0.1em;
127
+ }
128
+ `;
129
+ return cx(border, shadow, style);
130
+ };
131
+ const filter = (utils) => {
132
+ let trigger = false;
133
+ let _from = 0;
134
+ let _search = "";
135
+ let $active = null;
136
+ const off = () => {
137
+ trigger = false;
138
+ _from = 0;
139
+ _search = "";
140
+ $active = null;
141
+ };
142
+ return new Plugin({
143
+ props: {
144
+ handleKeyDown(_, event) {
145
+ if (["Delete", "Backspace"].includes(event.key)) {
146
+ _search = _search.slice(0, -1);
147
+ if (_search.length <= 1) {
148
+ off();
149
+ }
150
+ return false;
151
+ }
152
+ if (!trigger)
153
+ return false;
154
+ if (!["ArrowUp", "ArrowDown", "Enter"].includes(event.key)) {
155
+ return false;
156
+ }
157
+ return true;
158
+ },
159
+ handleTextInput(view, from, to, text) {
160
+ trigger = checkTrigger$1(view, from, to, text, (from2) => {
161
+ _from = from2;
162
+ }, (search2) => {
163
+ _search = search2;
164
+ });
165
+ if (!trigger) {
166
+ off();
167
+ }
168
+ return false;
169
+ }
170
+ },
171
+ view: (editorView) => {
172
+ const { parentNode } = editorView.dom;
173
+ if (!parentNode) {
174
+ throw new Error();
175
+ }
176
+ const dropDown = document.createElement("div");
177
+ const style = utils.getStyle(injectStyle);
178
+ if (style) {
179
+ style.split(" ").forEach((x) => dropDown.classList.add(x));
180
+ }
181
+ dropDown.classList.add("milkdown-emoji-filter", "hide");
182
+ const replace = () => {
183
+ var _a;
184
+ if (!$active)
185
+ return;
186
+ const { tr } = editorView.state;
187
+ const node = editorView.state.schema.node("emoji", { html: (_a = $active.firstElementChild) == null ? void 0 : _a.innerHTML });
188
+ editorView.dispatch(tr.delete(_from, _from + _search.length).insert(_from, node));
189
+ off();
190
+ dropDown.classList.add("hide");
191
+ };
192
+ parentNode.appendChild(dropDown);
193
+ parentNode.addEventListener("keydown", (e) => {
194
+ if (!trigger || !(e instanceof KeyboardEvent))
195
+ return;
196
+ const { key } = e;
197
+ if (key === "Enter") {
198
+ replace();
199
+ return;
200
+ }
201
+ if (["ArrowDown", "ArrowUp"].includes(key)) {
202
+ const next = key === "ArrowDown" ? ($active == null ? void 0 : $active.nextElementSibling) || dropDown.firstElementChild : ($active == null ? void 0 : $active.previousElementSibling) || dropDown.lastElementChild;
203
+ if ($active) {
204
+ $active.classList.remove("active");
205
+ }
206
+ if (!next)
207
+ return;
208
+ next.classList.add("active");
209
+ $active = next;
210
+ return;
211
+ }
212
+ });
213
+ parentNode.addEventListener("mousedown", (e) => {
214
+ if (!trigger)
215
+ return;
216
+ e.stopPropagation();
217
+ off();
218
+ dropDown.classList.add("hide");
219
+ });
220
+ return {
221
+ update: (view) => {
222
+ if (!trigger) {
223
+ dropDown.classList.add("hide");
224
+ return null;
225
+ }
226
+ const result = search(_search).slice(0, 5);
227
+ const { node } = view.domAtPos(_from);
228
+ if (result.length === 0 || !node) {
229
+ dropDown.classList.add("hide");
230
+ return null;
231
+ }
232
+ dropDown.classList.remove("hide");
233
+ renderDropdownList(result, dropDown, $active, replace, (a) => {
234
+ $active = a;
235
+ });
236
+ calculateNodePosition(view, dropDown, (selected, target, parent) => {
237
+ const start = view.coordsAtPos(_from);
238
+ let left = start.left - parent.left;
239
+ let top = selected.bottom - parent.top + 14;
240
+ if (left < 0) {
241
+ left = 0;
242
+ }
243
+ if (window.innerHeight - start.bottom < target.height) {
244
+ top = selected.top - parent.top - target.height - 14;
245
+ }
246
+ return [top, left];
247
+ });
248
+ return null;
249
+ }
250
+ };
251
+ }
252
+ });
253
+ };
254
+ const keyword = ":emoji:";
255
+ const checkTrigger = (view, from, to, text, setRange) => {
256
+ if (view.composing)
257
+ return false;
258
+ const { state } = view;
259
+ const $from = state.doc.resolve(from);
260
+ if ($from.parent.type.spec.code)
261
+ return false;
262
+ const textBefore = $from.parent.textBetween($from.parentOffset - keyword.length + 1, $from.parentOffset, void 0, "\uFFFC") + text;
263
+ if (textBefore === keyword) {
264
+ setRange(from - keyword.length + 1, to + 1);
265
+ return true;
266
+ }
267
+ return false;
268
+ };
269
+ const picker = (utils) => {
270
+ let trigger = false;
271
+ const holder = document.createElement("span");
272
+ let _from = 0;
273
+ let _to = 0;
274
+ const off = () => {
275
+ trigger = false;
276
+ _from = 0;
277
+ _to = 0;
278
+ };
279
+ const plugin = new Plugin({
280
+ props: {
281
+ handleKeyDown() {
282
+ off();
283
+ return false;
284
+ },
285
+ handleClick() {
286
+ off();
287
+ return false;
288
+ },
289
+ handleTextInput(view, from, to, text) {
290
+ trigger = checkTrigger(view, from, to, text, (from2, to2) => {
291
+ _from = from2;
292
+ _to = to2;
293
+ });
294
+ if (!trigger) {
295
+ off();
296
+ }
297
+ return false;
298
+ },
299
+ decorations(state) {
300
+ if (!trigger)
301
+ return null;
302
+ return DecorationSet.create(state.doc, [Decoration.widget(state.selection.to, holder)]);
303
+ }
304
+ },
305
+ view: (editorView) => {
306
+ const { parentNode } = editorView.dom;
307
+ if (!parentNode) {
308
+ throw new Error();
309
+ }
310
+ utils.getStyle(({ palette, font }) => {
311
+ const css2 = injectGlobal;
312
+ css2`
313
+ .emoji-picker {
314
+ --dark-search-background-color: ${palette("surface")} !important;
315
+ --dark-text-color: ${palette("neutral", 0.87)} !important;
316
+ --dark-background-color: ${palette("background")} !important;
317
+ --dark-border-color: ${palette("shadow")} !important;
318
+ --dark-hover-color: ${palette("secondary", 0.12)} !important;
319
+ --dark-blue-color: ${palette("primary")} !important;
320
+ --dark-search-icon-color: ${palette("primary")} !important;
321
+ --dark-category-button-color: ${palette("secondary", 0.4)} !important;
322
+ --font: ${font.typography} !important;
323
+ --font-size: 1rem !important;
324
+ }
325
+ `;
326
+ });
327
+ const emojiPicker = new EmojiButton({
328
+ rootElement: parentNode,
329
+ autoFocusSearch: false,
330
+ style: "twemoji",
331
+ theme: "dark",
332
+ zIndex: 99
333
+ });
334
+ emojiPicker.on("emoji", (selection) => {
335
+ const start = _from;
336
+ const end = _to;
337
+ off();
338
+ const html = parse(selection.emoji);
339
+ const node = editorView.state.schema.node("emoji", { html });
340
+ const { tr } = editorView.state;
341
+ editorView.dispatch(tr.replaceRangeWith(start, end, node));
342
+ });
343
+ return {
344
+ update: () => {
345
+ if (!trigger) {
346
+ emojiPicker.hidePicker();
347
+ return null;
348
+ }
349
+ emojiPicker.showPicker(holder);
350
+ return null;
351
+ },
352
+ destroy: () => {
353
+ emojiPicker.destroyPicker();
354
+ }
355
+ };
356
+ }
357
+ });
358
+ return plugin;
359
+ };
360
+ const regex = emojiRegex();
361
+ const isParent = (node) => !!node.children;
362
+ const isLiteral = (node) => !!node.value;
363
+ function flatMap(ast, fn) {
364
+ return transform(ast, 0, null)[0];
365
+ function transform(node, index, parent) {
366
+ if (isParent(node)) {
367
+ const out = [];
368
+ for (let i = 0, n = node.children.length; i < n; i++) {
369
+ const xs = transform(node.children[i], i, node);
370
+ if (xs) {
371
+ for (let j = 0, m = xs.length; j < m; j++) {
372
+ out.push(xs[j]);
373
+ }
374
+ }
375
+ }
376
+ node.children = out;
377
+ }
378
+ return fn(node, index, parent);
379
+ }
380
+ }
381
+ const twemojiPlugin = () => {
382
+ function transformer(tree) {
383
+ flatMap(tree, (node) => {
384
+ if (!isLiteral(node)) {
385
+ return [node];
386
+ }
387
+ const value = node.value;
388
+ const output = [];
389
+ let match;
390
+ let str = value;
391
+ while (match = regex.exec(str)) {
392
+ const { index } = match;
393
+ const emoji2 = match[0];
394
+ if (index > 0) {
395
+ output.push(__spreadProps(__spreadValues({}, node), { value: str.slice(0, index) }));
396
+ }
397
+ output.push(__spreadProps(__spreadValues({}, node), { value: parse(emoji2), type: "emoji" }));
398
+ str = str.slice(index + emoji2.length);
399
+ }
400
+ if (str.length) {
401
+ output.push(__spreadProps(__spreadValues({}, node), { value: str }));
402
+ }
403
+ return output;
404
+ });
405
+ }
406
+ return transformer;
407
+ };
408
+ const emojiNode = createNode((utils) => {
409
+ const style = utils.getStyle(() => css`
410
+ display: inline-flex;
411
+ justify-content: center;
412
+ align-items: center;
413
+
414
+ .emoji {
415
+ height: 1em;
416
+ width: 1em;
417
+ margin: 0 0.05em 0 0.1em;
418
+ vertical-align: -0.1em;
419
+ }
420
+ `);
421
+ return {
422
+ id: "emoji",
423
+ schema: () => ({
424
+ group: "inline",
425
+ inline: true,
426
+ selectable: false,
427
+ attrs: {
428
+ html: {
429
+ default: ""
430
+ }
431
+ },
432
+ parseDOM: [
433
+ {
434
+ tag: 'span[data-type="emoji"]',
435
+ getAttrs: (dom) => {
436
+ if (!(dom instanceof HTMLElement)) {
437
+ throw new Error();
438
+ }
439
+ return { html: dom.innerHTML };
440
+ }
441
+ }
442
+ ],
443
+ toDOM: (node) => {
444
+ const span = document.createElement("span");
445
+ span.dataset.type = "emoji";
446
+ if (style) {
447
+ span.classList.add(style);
448
+ }
449
+ span.classList.add("emoji-wrapper");
450
+ span.innerHTML = node.attrs.html;
451
+ return { dom: span };
452
+ },
453
+ parseMarkdown: {
454
+ match: ({ type }) => type === "emoji",
455
+ runner: (state, node, type) => {
456
+ state.addNode(type, { html: node.value });
457
+ }
458
+ },
459
+ toMarkdown: {
460
+ match: (node) => node.type.name === "emoji",
461
+ runner: (state, node) => {
462
+ const span = document.createElement("span");
463
+ span.innerHTML = node.attrs.html;
464
+ const img = span.querySelector("img");
465
+ const title = img == null ? void 0 : img.title;
466
+ span.remove();
467
+ state.addNode("text", void 0, title);
468
+ }
469
+ }
470
+ }),
471
+ inputRules: (nodeType) => [
472
+ new InputRule(input, (state, match, start, end) => {
473
+ const content = match[0];
474
+ if (!content)
475
+ return null;
476
+ const got = nodeEmoji.get(content);
477
+ if (!got || content.includes(got))
478
+ return null;
479
+ const html = parse(got);
480
+ return state.tr.setMeta("emoji", true).replaceRangeWith(start, end, nodeType.create({ html })).scrollIntoView();
481
+ })
482
+ ],
483
+ remarkPlugins: () => [remarkEmoji, twemojiPlugin],
484
+ prosePlugins: () => [picker(utils), filter(utils)]
485
+ };
486
+ });
487
+ const emoji = AtomList.create([emojiNode()]);
488
+ export { emoji, emojiNode };
489
+ //# sourceMappingURL=index.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.es.js","sources":["../src/constant.ts","../src/parse.ts","../src/filter/helper.ts","../src/filter/style.ts","../src/filter/index.ts","../src/picker.ts","../src/remark-twemoji.ts","../src/node.ts","../src/index.ts"],"sourcesContent":["/* Copyright 2021, Milkdown by Mirone. */\nexport const part = /:\\+1|:-1|:[\\w-]+/;\nexport const full = /:\\+1:|:-1:|:[\\w-]+:/;\nexport const input = /(:([^:\\s]+):)$/;\nexport const keyword = ':emoji:';\n","/* Copyright 2021, Milkdown by Mirone. */\nimport twemoji from 'twemoji';\n\nexport const parse = (emoji: string) => twemoji.parse(emoji, { attributes: (text) => ({ title: text }) });\n","/* Copyright 2021, Milkdown by Mirone. */\n\nimport { EditorView } from '@milkdown/prose';\nimport { Emoji } from 'node-emoji';\n\nimport { full, part } from '../constant';\nimport { parse } from '../parse';\n\nexport const checkTrigger = (\n view: EditorView,\n from: number,\n to: number,\n text: string,\n setRange: (from: number, to: number) => void,\n setSearch: (words: string) => void,\n) => {\n if (view.composing) return false;\n const { state } = view;\n const $from = state.doc.resolve(from);\n if ($from.parent.type.spec.code) return false;\n const textBefore =\n $from.parent.textBetween(Math.max(0, $from.parentOffset - 10), $from.parentOffset, undefined, '\\ufffc') + text;\n if (full.test(textBefore)) {\n return false;\n }\n const regex = part.exec(textBefore);\n if (regex && textBefore.endsWith(regex[0])) {\n const match = regex[0];\n setRange(from - (match.length - text.length), to);\n setSearch(match);\n return true;\n }\n return false;\n};\n\nexport const renderDropdownList = (\n list: Emoji[],\n dropDown: HTMLElement,\n $active: HTMLElement | null,\n onConfirm: () => void,\n setActive: (active: HTMLElement | null) => void,\n) => {\n dropDown.innerHTML = '';\n list.forEach(({ emoji, key }, i) => {\n const container = document.createElement('div');\n container.className = 'milkdown-emoji-filter_item';\n\n const emojiSpan = document.createElement('span');\n emojiSpan.innerHTML = parse(emoji);\n\n emojiSpan.className = 'milkdown-emoji-filter_item-emoji';\n const keySpan = document.createElement('span');\n keySpan.textContent = ':' + key + ':';\n keySpan.className = 'milkdown-emoji-filter_item-key';\n\n container.appendChild(emojiSpan);\n container.appendChild(keySpan);\n dropDown.appendChild(container);\n\n if (i === 0) {\n container.classList.add('active');\n setActive(container);\n }\n\n container.addEventListener('mouseenter', (e) => {\n if ($active) {\n $active.classList.remove('active');\n }\n const { target } = e;\n if (!(target instanceof HTMLElement)) return;\n target.classList.add('active');\n setActive(target);\n });\n container.addEventListener('mouseleave', (e) => {\n const { target } = e;\n if (!(target instanceof HTMLElement)) return;\n target.classList.remove('active');\n });\n container.addEventListener('mousedown', (e) => {\n onConfirm();\n e.preventDefault();\n });\n });\n};\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { css, cx } from '@emotion/css';\nimport type { ThemeTool } from '@milkdown/core';\n\nexport const injectStyle = ({ size, mixin, palette, font }: ThemeTool) => {\n const border = mixin.border?.();\n const shadow = mixin.shadow?.();\n\n const style = css`\n position: absolute;\n &.hide {\n display: none;\n }\n\n border-radius: ${size.radius};\n background: ${palette('surface')};\n\n .milkdown-emoji-filter_item {\n display: flex;\n gap: 0.5rem;\n height: 2.25rem;\n padding: 0 1rem;\n align-items: center;\n justify-content: flex-start;\n cursor: pointer;\n line-height: 2;\n font-family: ${font.typography};\n font-size: 0.875rem;\n &.active {\n background: ${palette('secondary', 0.12)};\n color: ${palette('primary')};\n }\n }\n\n .emoji {\n height: 1em;\n width: 1em;\n margin: 0 0.05em 0 0.1em;\n vertical-align: -0.1em;\n }\n `;\n return cx(border, shadow, style);\n};\n","/* Copyright 2021, Milkdown by Mirone. */\n\nimport { calculateNodePosition, Plugin } from '@milkdown/prose';\nimport { Utils } from '@milkdown/utils';\nimport { search } from 'node-emoji';\n\nimport { checkTrigger, renderDropdownList } from './helper';\nimport { injectStyle } from './style';\n\nexport const filter = (utils: Utils) => {\n let trigger = false;\n let _from = 0;\n let _search = '';\n let $active: null | HTMLElement = null;\n\n const off = () => {\n trigger = false;\n _from = 0;\n _search = '';\n $active = null;\n };\n\n return new Plugin({\n props: {\n handleKeyDown(_, event) {\n if (['Delete', 'Backspace'].includes(event.key)) {\n _search = _search.slice(0, -1);\n if (_search.length <= 1) {\n off();\n }\n return false;\n }\n if (!trigger) return false;\n if (!['ArrowUp', 'ArrowDown', 'Enter'].includes(event.key)) {\n return false;\n }\n return true;\n },\n handleTextInput(view, from, to, text) {\n trigger = checkTrigger(\n view,\n from,\n to,\n text,\n (from) => {\n _from = from;\n },\n (search) => {\n _search = search;\n },\n );\n if (!trigger) {\n off();\n }\n return false;\n },\n },\n view: (editorView) => {\n const { parentNode } = editorView.dom;\n if (!parentNode) {\n throw new Error();\n }\n\n const dropDown = document.createElement('div');\n const style = utils.getStyle(injectStyle);\n\n if (style) {\n style.split(' ').forEach((x) => dropDown.classList.add(x));\n }\n\n dropDown.classList.add('milkdown-emoji-filter', 'hide');\n\n const replace = () => {\n if (!$active) return;\n\n const { tr } = editorView.state;\n const node = editorView.state.schema.node('emoji', { html: $active.firstElementChild?.innerHTML });\n\n editorView.dispatch(tr.delete(_from, _from + _search.length).insert(_from, node));\n off();\n dropDown.classList.add('hide');\n };\n\n parentNode.appendChild(dropDown);\n parentNode.addEventListener('keydown', (e) => {\n if (!trigger || !(e instanceof KeyboardEvent)) return;\n\n const { key } = e;\n\n if (key === 'Enter') {\n replace();\n return;\n }\n\n if (['ArrowDown', 'ArrowUp'].includes(key)) {\n const next =\n key === 'ArrowDown'\n ? $active?.nextElementSibling || dropDown.firstElementChild\n : $active?.previousElementSibling || dropDown.lastElementChild;\n if ($active) {\n $active.classList.remove('active');\n }\n if (!next) return;\n next.classList.add('active');\n $active = next as HTMLElement;\n\n return;\n }\n });\n parentNode.addEventListener('mousedown', (e) => {\n if (!trigger) return;\n\n e.stopPropagation();\n off();\n dropDown.classList.add('hide');\n });\n\n return {\n update: (view) => {\n if (!trigger) {\n dropDown.classList.add('hide');\n return null;\n }\n const result = search(_search).slice(0, 5);\n const { node } = view.domAtPos(_from);\n if (result.length === 0 || !node) {\n dropDown.classList.add('hide');\n return null;\n }\n\n dropDown.classList.remove('hide');\n renderDropdownList(result, dropDown, $active, replace, (a) => {\n $active = a;\n });\n calculateNodePosition(view, dropDown, (selected, target, parent) => {\n const start = view.coordsAtPos(_from);\n let left = start.left - parent.left;\n let top = selected.bottom - parent.top + 14;\n\n if (left < 0) {\n left = 0;\n }\n\n if (window.innerHeight - start.bottom < target.height) {\n top = selected.top - parent.top - target.height - 14;\n }\n return [top, left];\n });\n\n return null;\n },\n };\n },\n });\n};\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { injectGlobal } from '@emotion/css';\nimport { EmojiButton } from '@joeattardi/emoji-button';\nimport { Decoration, DecorationSet, EditorView, Plugin } from '@milkdown/prose';\nimport { Utils } from '@milkdown/utils';\n\nimport { parse } from './parse';\n\nconst keyword = ':emoji:';\n\nconst checkTrigger = (\n view: EditorView,\n from: number,\n to: number,\n text: string,\n setRange: (from: number, to: number) => void,\n) => {\n if (view.composing) return false;\n const { state } = view;\n const $from = state.doc.resolve(from);\n if ($from.parent.type.spec.code) return false;\n const textBefore =\n $from.parent.textBetween($from.parentOffset - keyword.length + 1, $from.parentOffset, undefined, '\\ufffc') +\n text;\n if (textBefore === keyword) {\n setRange(from - keyword.length + 1, to + 1);\n return true;\n }\n return false;\n};\n\nexport const picker = (utils: Utils) => {\n let trigger = false;\n const holder = document.createElement('span');\n let _from = 0;\n let _to = 0;\n const off = () => {\n trigger = false;\n _from = 0;\n _to = 0;\n };\n\n const plugin = new Plugin({\n props: {\n handleKeyDown() {\n off();\n return false;\n },\n handleClick() {\n off();\n return false;\n },\n handleTextInput(view, from, to, text) {\n trigger = checkTrigger(view, from, to, text, (from, to) => {\n _from = from;\n _to = to;\n });\n\n if (!trigger) {\n off();\n }\n return false;\n },\n decorations(state) {\n if (!trigger) return null;\n\n return DecorationSet.create(state.doc, [Decoration.widget(state.selection.to, holder)]);\n },\n },\n view: (editorView) => {\n const { parentNode } = editorView.dom;\n if (!parentNode) {\n throw new Error();\n }\n utils.getStyle(({ palette, font }) => {\n const css = injectGlobal;\n css`\n .emoji-picker {\n --dark-search-background-color: ${palette('surface')} !important;\n --dark-text-color: ${palette('neutral', 0.87)} !important;\n --dark-background-color: ${palette('background')} !important;\n --dark-border-color: ${palette('shadow')} !important;\n --dark-hover-color: ${palette('secondary', 0.12)} !important;\n --dark-blue-color: ${palette('primary')} !important;\n --dark-search-icon-color: ${palette('primary')} !important;\n --dark-category-button-color: ${palette('secondary', 0.4)} !important;\n --font: ${font.typography} !important;\n --font-size: 1rem !important;\n }\n `;\n });\n const emojiPicker = new EmojiButton({\n rootElement: parentNode as HTMLElement,\n autoFocusSearch: false,\n style: 'twemoji',\n theme: 'dark',\n zIndex: 99,\n });\n emojiPicker.on('emoji', (selection) => {\n const start = _from;\n const end = _to;\n off();\n const html = parse(selection.emoji);\n const node = editorView.state.schema.node('emoji', { html });\n const { tr } = editorView.state;\n\n editorView.dispatch(tr.replaceRangeWith(start, end, node));\n });\n return {\n update: () => {\n if (!trigger) {\n emojiPicker.hidePicker();\n return null;\n }\n emojiPicker.showPicker(holder);\n return null;\n },\n destroy: () => {\n emojiPicker.destroyPicker();\n },\n };\n },\n });\n\n return plugin;\n};\n","/* Copyright 2021, Milkdown by Mirone. */\nimport emojiRegex from 'emoji-regex';\nimport { Literal, Node, Parent } from 'unist';\n\nimport { parse } from './parse';\n\nconst regex = emojiRegex();\n\nconst isParent = (node: Node): node is Parent => !!(node as Parent).children;\nconst isLiteral = (node: Node): node is Literal => !!(node as Literal).value;\n\nfunction flatMap(ast: Node, fn: (node: Node, index: number, parent: Node | null) => Node[]) {\n return transform(ast, 0, null)[0];\n\n function transform(node: Node, index: number, parent: Node | null) {\n if (isParent(node)) {\n const out = [];\n for (let i = 0, n = node.children.length; i < n; i++) {\n const xs = transform(node.children[i], i, node);\n if (xs) {\n for (let j = 0, m = xs.length; j < m; j++) {\n out.push(xs[j]);\n }\n }\n }\n node.children = out;\n }\n\n return fn(node, index, parent);\n }\n}\n\nexport const twemojiPlugin = () => {\n function transformer(tree: Node) {\n flatMap(tree, (node) => {\n if (!isLiteral(node)) {\n return [node];\n }\n const value = node.value as string;\n const output: Literal<string>[] = [];\n let match;\n let str = value;\n while ((match = regex.exec(str))) {\n const { index } = match;\n const emoji = match[0];\n if (index > 0) {\n output.push({ ...node, value: str.slice(0, index) });\n }\n output.push({ ...node, value: parse(emoji), type: 'emoji' });\n str = str.slice(index + emoji.length);\n }\n if (str.length) {\n output.push({ ...node, value: str });\n }\n return output;\n });\n }\n return transformer;\n};\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { css } from '@emotion/css';\nimport { RemarkPlugin } from '@milkdown/core';\nimport { InputRule } from '@milkdown/prose';\nimport { createNode } from '@milkdown/utils';\nimport nodeEmoji from 'node-emoji';\nimport remarkEmoji from 'remark-emoji';\n\nimport { input } from './constant';\nimport { filter } from './filter';\nimport { parse } from './parse';\nimport { picker } from './picker';\nimport { twemojiPlugin } from './remark-twemoji';\n\nexport const emojiNode = createNode((utils) => {\n const style = utils.getStyle(\n () => css`\n display: inline-flex;\n justify-content: center;\n align-items: center;\n\n .emoji {\n height: 1em;\n width: 1em;\n margin: 0 0.05em 0 0.1em;\n vertical-align: -0.1em;\n }\n `,\n );\n return {\n id: 'emoji',\n schema: () => ({\n group: 'inline',\n inline: true,\n selectable: false,\n attrs: {\n html: {\n default: '',\n },\n },\n parseDOM: [\n {\n tag: 'span[data-type=\"emoji\"]',\n getAttrs: (dom) => {\n if (!(dom instanceof HTMLElement)) {\n throw new Error();\n }\n return { html: dom.innerHTML };\n },\n },\n ],\n toDOM: (node) => {\n const span = document.createElement('span');\n span.dataset.type = 'emoji';\n if (style) {\n span.classList.add(style);\n }\n span.classList.add('emoji-wrapper');\n span.innerHTML = node.attrs.html;\n return { dom: span };\n },\n parseMarkdown: {\n match: ({ type }) => type === 'emoji',\n runner: (state, node, type) => {\n state.addNode(type, { html: node.value as string });\n },\n },\n toMarkdown: {\n match: (node) => node.type.name === 'emoji',\n runner: (state, node) => {\n const span = document.createElement('span');\n span.innerHTML = node.attrs.html;\n const img = span.querySelector('img');\n const title = img?.title;\n span.remove();\n state.addNode('text', undefined, title);\n },\n },\n }),\n inputRules: (nodeType) => [\n new InputRule(input, (state, match, start, end) => {\n const content = match[0];\n if (!content) return null;\n const got = nodeEmoji.get(content);\n if (!got || content.includes(got)) return null;\n\n const html = parse(got);\n\n return state.tr\n .setMeta('emoji', true)\n .replaceRangeWith(start, end, nodeType.create({ html }))\n .scrollIntoView();\n }),\n ],\n remarkPlugins: () => [remarkEmoji as RemarkPlugin, twemojiPlugin],\n prosePlugins: () => [picker(utils), filter(utils)],\n };\n});\n","/* Copyright 2021, Milkdown by Mirone. */\nimport { AtomList } from '@milkdown/utils';\n\nimport { emojiNode } from './node';\n\nexport const emoji = AtomList.create([emojiNode()]);\n\nexport { emojiNode } from './node';\n"],"names":["checkTrigger"],"mappings":"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"}
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@milkdown/plugin-emoji",
3
- "version": "5.1.2",
4
- "main": "lib/index.js",
5
- "module": "lib/index.js",
6
- "types": "lib/index.d.ts",
3
+ "version": "5.3.1",
4
+ "type": "module",
5
+ "main": "./lib/index.es.js",
6
+ "types": "./lib/index.d.ts",
7
7
  "sideEffects": false,
8
8
  "license": "MIT",
9
9
  "files": [
@@ -20,21 +20,27 @@
20
20
  "dependencies": {
21
21
  "@emotion/css": "^11.1.3",
22
22
  "@joeattardi/emoji-button": "^4.6.0",
23
- "@milkdown/utils": "5.1.2",
23
+ "@milkdown/utils": "5.3.1",
24
24
  "@types/node-emoji": "^1.8.1",
25
25
  "@types/twemoji": "^12.1.2",
26
- "emoji-regex": "^9.2.2",
26
+ "emoji-regex": "^10.0.0",
27
27
  "node-emoji": "^1.10.0",
28
28
  "remark-emoji": "^3.0.1",
29
29
  "tslib": "^2.3.1",
30
30
  "twemoji": "^13.1.0",
31
31
  "unist-util-visit": "^4.0.0"
32
32
  },
33
+ "devDependencies": {
34
+ "@milkdown/core": "5.3.1",
35
+ "@milkdown/prose": "5.3.1",
36
+ "@milkdown/utils": "5.3.1"
37
+ },
33
38
  "scripts": {
34
39
  "start": "vite",
35
- "watch": "tsc -w",
36
- "test": "jest",
40
+ "watch": "vite build --watch",
41
+ "test": "vitest",
37
42
  "tsc": "tsc --noEmit",
38
- "build": "tsc"
39
- }
43
+ "build": "vite build && tsc --emitDeclarationOnly"
44
+ },
45
+ "readme": "# @milkdown/plugin-emoji\n\nEmoji plugin for [milkdown](https://saul-mirone.github.io/milkdown/).\nAdd support for emoji through [shortcuts](https://www.webfx.com/tools/emoji-cheat-sheet/).\nRendered by [twemoji](https://github.com/twitter/twemoji).\n\n# Example Usage\n\n```typescript\nimport { Editor } from '@milkdown/core';\nimport { commonmark } from '@milkdown/preset-commonmark';\nimport { nord } from '@milkdown/theme-nord';\n\nimport { emoji } from '@milkdown/plugin-emoji';\n\nEditor.make().use(nord).use(commonmark).use(emoji).create();\n```\n\n# License\n\nMilkdown is open sourced software licensed under [MIT license](https://github.com/Saul-Mirone/milkdown/blob/main/LICENSE).\n"
40
46
  }
@@ -65,7 +65,7 @@ export const filter = (utils: Utils) => {
65
65
  const style = utils.getStyle(injectStyle);
66
66
 
67
67
  if (style) {
68
- dropDown.classList.add(style);
68
+ style.split(' ').forEach((x) => dropDown.classList.add(x));
69
69
  }
70
70
 
71
71
  dropDown.classList.add('milkdown-emoji-filter', 'hide');
@@ -1,18 +1,19 @@
1
1
  /* Copyright 2021, Milkdown by Mirone. */
2
- import { css } from '@emotion/css';
2
+ import { css, cx } from '@emotion/css';
3
3
  import type { ThemeTool } from '@milkdown/core';
4
4
 
5
5
  export const injectStyle = ({ size, mixin, palette, font }: ThemeTool) => {
6
- return css`
6
+ const border = mixin.border?.();
7
+ const shadow = mixin.shadow?.();
8
+
9
+ const style = css`
7
10
  position: absolute;
8
11
  &.hide {
9
12
  display: none;
10
13
  }
11
14
 
12
- ${mixin.border?.()};
13
15
  border-radius: ${size.radius};
14
16
  background: ${palette('surface')};
15
- ${mixin.shadow?.()};
16
17
 
17
18
  .milkdown-emoji-filter_item {
18
19
  display: flex;
@@ -38,4 +39,5 @@ export const injectStyle = ({ size, mixin, palette, font }: ThemeTool) => {
38
39
  vertical-align: -0.1em;
39
40
  }
40
41
  `;
42
+ return cx(border, shadow, style);
41
43
  };
package/lib/constant.js DELETED
@@ -1,6 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- export const part = /:\+1|:-1|:[\w-]+/;
3
- export const full = /:\+1:|:-1:|:[\w-]+:/;
4
- export const input = /(:([^:\s]+):)$/;
5
- export const keyword = ':emoji:';
6
- //# sourceMappingURL=constant.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"constant.js","sourceRoot":"","sources":["../src/constant.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,MAAM,CAAC,MAAM,IAAI,GAAG,kBAAkB,CAAC;AACvC,MAAM,CAAC,MAAM,IAAI,GAAG,qBAAqB,CAAC;AAC1C,MAAM,CAAC,MAAM,KAAK,GAAG,gBAAgB,CAAC;AACtC,MAAM,CAAC,MAAM,OAAO,GAAG,SAAS,CAAC"}
@@ -1,64 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import { full, part } from '../constant';
3
- import { parse } from '../parse';
4
- export const checkTrigger = (view, from, to, text, setRange, setSearch) => {
5
- if (view.composing)
6
- return false;
7
- const { state } = view;
8
- const $from = state.doc.resolve(from);
9
- if ($from.parent.type.spec.code)
10
- return false;
11
- const textBefore = $from.parent.textBetween(Math.max(0, $from.parentOffset - 10), $from.parentOffset, undefined, '\ufffc') + text;
12
- if (full.test(textBefore)) {
13
- return false;
14
- }
15
- const regex = part.exec(textBefore);
16
- if (regex && textBefore.endsWith(regex[0])) {
17
- const match = regex[0];
18
- setRange(from - (match.length - text.length), to);
19
- setSearch(match);
20
- return true;
21
- }
22
- return false;
23
- };
24
- export const renderDropdownList = (list, dropDown, $active, onConfirm, setActive) => {
25
- dropDown.innerHTML = '';
26
- list.forEach(({ emoji, key }, i) => {
27
- const container = document.createElement('div');
28
- container.className = 'milkdown-emoji-filter_item';
29
- const emojiSpan = document.createElement('span');
30
- emojiSpan.innerHTML = parse(emoji);
31
- emojiSpan.className = 'milkdown-emoji-filter_item-emoji';
32
- const keySpan = document.createElement('span');
33
- keySpan.textContent = ':' + key + ':';
34
- keySpan.className = 'milkdown-emoji-filter_item-key';
35
- container.appendChild(emojiSpan);
36
- container.appendChild(keySpan);
37
- dropDown.appendChild(container);
38
- if (i === 0) {
39
- container.classList.add('active');
40
- setActive(container);
41
- }
42
- container.addEventListener('mouseenter', (e) => {
43
- if ($active) {
44
- $active.classList.remove('active');
45
- }
46
- const { target } = e;
47
- if (!(target instanceof HTMLElement))
48
- return;
49
- target.classList.add('active');
50
- setActive(target);
51
- });
52
- container.addEventListener('mouseleave', (e) => {
53
- const { target } = e;
54
- if (!(target instanceof HTMLElement))
55
- return;
56
- target.classList.remove('active');
57
- });
58
- container.addEventListener('mousedown', (e) => {
59
- onConfirm();
60
- e.preventDefault();
61
- });
62
- });
63
- };
64
- //# sourceMappingURL=helper.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"helper.js","sourceRoot":"","sources":["../../src/filter/helper.ts"],"names":[],"mappings":"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"}
@@ -1,131 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import { calculateNodePosition, Plugin } from '@milkdown/prose';
3
- import { search } from 'node-emoji';
4
- import { checkTrigger, renderDropdownList } from './helper';
5
- import { injectStyle } from './style';
6
- export const filter = (utils) => {
7
- let trigger = false;
8
- let _from = 0;
9
- let _search = '';
10
- let $active = null;
11
- const off = () => {
12
- trigger = false;
13
- _from = 0;
14
- _search = '';
15
- $active = null;
16
- };
17
- return new Plugin({
18
- props: {
19
- handleKeyDown(_, event) {
20
- if (['Delete', 'Backspace'].includes(event.key)) {
21
- _search = _search.slice(0, -1);
22
- if (_search.length <= 1) {
23
- off();
24
- }
25
- return false;
26
- }
27
- if (!trigger)
28
- return false;
29
- if (!['ArrowUp', 'ArrowDown', 'Enter'].includes(event.key)) {
30
- return false;
31
- }
32
- return true;
33
- },
34
- handleTextInput(view, from, to, text) {
35
- trigger = checkTrigger(view, from, to, text, (from) => {
36
- _from = from;
37
- }, (search) => {
38
- _search = search;
39
- });
40
- if (!trigger) {
41
- off();
42
- }
43
- return false;
44
- },
45
- },
46
- view: (editorView) => {
47
- const { parentNode } = editorView.dom;
48
- if (!parentNode) {
49
- throw new Error();
50
- }
51
- const dropDown = document.createElement('div');
52
- const style = utils.getStyle(injectStyle);
53
- if (style) {
54
- dropDown.classList.add(style);
55
- }
56
- dropDown.classList.add('milkdown-emoji-filter', 'hide');
57
- const replace = () => {
58
- var _a;
59
- if (!$active)
60
- return;
61
- const { tr } = editorView.state;
62
- const node = editorView.state.schema.node('emoji', { html: (_a = $active.firstElementChild) === null || _a === void 0 ? void 0 : _a.innerHTML });
63
- editorView.dispatch(tr.delete(_from, _from + _search.length).insert(_from, node));
64
- off();
65
- dropDown.classList.add('hide');
66
- };
67
- parentNode.appendChild(dropDown);
68
- parentNode.addEventListener('keydown', (e) => {
69
- if (!trigger || !(e instanceof KeyboardEvent))
70
- return;
71
- const { key } = e;
72
- if (key === 'Enter') {
73
- replace();
74
- return;
75
- }
76
- if (['ArrowDown', 'ArrowUp'].includes(key)) {
77
- const next = key === 'ArrowDown'
78
- ? ($active === null || $active === void 0 ? void 0 : $active.nextElementSibling) || dropDown.firstElementChild
79
- : ($active === null || $active === void 0 ? void 0 : $active.previousElementSibling) || dropDown.lastElementChild;
80
- if ($active) {
81
- $active.classList.remove('active');
82
- }
83
- if (!next)
84
- return;
85
- next.classList.add('active');
86
- $active = next;
87
- return;
88
- }
89
- });
90
- parentNode.addEventListener('mousedown', (e) => {
91
- if (!trigger)
92
- return;
93
- e.stopPropagation();
94
- off();
95
- dropDown.classList.add('hide');
96
- });
97
- return {
98
- update: (view) => {
99
- if (!trigger) {
100
- dropDown.classList.add('hide');
101
- return null;
102
- }
103
- const result = search(_search).slice(0, 5);
104
- const { node } = view.domAtPos(_from);
105
- if (result.length === 0 || !node) {
106
- dropDown.classList.add('hide');
107
- return null;
108
- }
109
- dropDown.classList.remove('hide');
110
- renderDropdownList(result, dropDown, $active, replace, (a) => {
111
- $active = a;
112
- });
113
- calculateNodePosition(view, dropDown, (selected, target, parent) => {
114
- const start = view.coordsAtPos(_from);
115
- let left = start.left - parent.left;
116
- let top = selected.bottom - parent.top + 14;
117
- if (left < 0) {
118
- left = 0;
119
- }
120
- if (window.innerHeight - start.bottom < target.height) {
121
- top = selected.top - parent.top - target.height - 14;
122
- }
123
- return [top, left];
124
- });
125
- return null;
126
- },
127
- };
128
- },
129
- });
130
- };
131
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/filter/index.ts"],"names":[],"mappings":"AAAA,yCAAyC;AAEzC,OAAO,EAAE,qBAAqB,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAEpC,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,KAAY,EAAE,EAAE;IACnC,IAAI,OAAO,GAAG,KAAK,CAAC;IACpB,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,IAAI,OAAO,GAAG,EAAE,CAAC;IACjB,IAAI,OAAO,GAAuB,IAAI,CAAC;IAEvC,MAAM,GAAG,GAAG,GAAG,EAAE;QACb,OAAO,GAAG,KAAK,CAAC;QAChB,KAAK,GAAG,CAAC,CAAC;QACV,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,GAAG,IAAI,CAAC;IACnB,CAAC,CAAC;IAEF,OAAO,IAAI,MAAM,CAAC;QACd,KAAK,EAAE;YACH,aAAa,CAAC,CAAC,EAAE,KAAK;gBAClB,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;oBAC7C,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;oBAC/B,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE;wBACrB,GAAG,EAAE,CAAC;qBACT;oBACD,OAAO,KAAK,CAAC;iBAChB;gBACD,IAAI,CAAC,OAAO;oBAAE,OAAO,KAAK,CAAC;gBAC3B,IAAI,CAAC,CAAC,SAAS,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;oBACxD,OAAO,KAAK,CAAC;iBAChB;gBACD,OAAO,IAAI,CAAC;YAChB,CAAC;YACD,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI;gBAChC,OAAO,GAAG,YAAY,CAClB,IAAI,EACJ,IAAI,EACJ,EAAE,EACF,IAAI,EACJ,CAAC,IAAI,EAAE,EAAE;oBACL,KAAK,GAAG,IAAI,CAAC;gBACjB,CAAC,EACD,CAAC,MAAM,EAAE,EAAE;oBACP,OAAO,GAAG,MAAM,CAAC;gBACrB,CAAC,CACJ,CAAC;gBACF,IAAI,CAAC,OAAO,EAAE;oBACV,GAAG,EAAE,CAAC;iBACT;gBACD,OAAO,KAAK,CAAC;YACjB,CAAC;SACJ;QACD,IAAI,EAAE,CAAC,UAAU,EAAE,EAAE;YACjB,MAAM,EAAE,UAAU,EAAE,GAAG,UAAU,CAAC,GAAG,CAAC;YACtC,IAAI,CAAC,UAAU,EAAE;gBACb,MAAM,IAAI,KAAK,EAAE,CAAC;aACrB;YAED,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC/C,MAAM,KAAK,GAAG,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;YAE1C,IAAI,KAAK,EAAE;gBACP,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;aACjC;YAED,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;YAExD,MAAM,OAAO,GAAG,GAAG,EAAE;;gBACjB,IAAI,CAAC,OAAO;oBAAE,OAAO;gBAErB,MAAM,EAAE,EAAE,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC;gBAChC,MAAM,IAAI,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,MAAA,OAAO,CAAC,iBAAiB,0CAAE,SAAS,EAAE,CAAC,CAAC;gBAEnG,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;gBAClF,GAAG,EAAE,CAAC;gBACN,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACnC,CAAC,CAAC;YAEF,UAAU,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YACjC,UAAU,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE;gBACzC,IAAI,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,YAAY,aAAa,CAAC;oBAAE,OAAO;gBAEtD,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;gBAElB,IAAI,GAAG,KAAK,OAAO,EAAE;oBACjB,OAAO,EAAE,CAAC;oBACV,OAAO;iBACV;gBAED,IAAI,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;oBACxC,MAAM,IAAI,GACN,GAAG,KAAK,WAAW;wBACf,CAAC,CAAC,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,kBAAkB,KAAI,QAAQ,CAAC,iBAAiB;wBAC3D,CAAC,CAAC,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,sBAAsB,KAAI,QAAQ,CAAC,gBAAgB,CAAC;oBACvE,IAAI,OAAO,EAAE;wBACT,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;qBACtC;oBACD,IAAI,CAAC,IAAI;wBAAE,OAAO;oBAClB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBAC7B,OAAO,GAAG,IAAmB,CAAC;oBAE9B,OAAO;iBACV;YACL,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE;gBAC3C,IAAI,CAAC,OAAO;oBAAE,OAAO;gBAErB,CAAC,CAAC,eAAe,EAAE,CAAC;gBACpB,GAAG,EAAE,CAAC;gBACN,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;YAEH,OAAO;gBACH,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;oBACb,IAAI,CAAC,OAAO,EAAE;wBACV,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;wBAC/B,OAAO,IAAI,CAAC;qBACf;oBACD,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;oBAC3C,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACtC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE;wBAC9B,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;wBAC/B,OAAO,IAAI,CAAC;qBACf;oBAED,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;oBAClC,kBAAkB,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;wBACzD,OAAO,GAAG,CAAC,CAAC;oBAChB,CAAC,CAAC,CAAC;oBACH,qBAAqB,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE;wBAC/D,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;wBACtC,IAAI,IAAI,GAAG,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;wBACpC,IAAI,GAAG,GAAG,QAAQ,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,EAAE,CAAC;wBAE5C,IAAI,IAAI,GAAG,CAAC,EAAE;4BACV,IAAI,GAAG,CAAC,CAAC;yBACZ;wBAED,IAAI,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE;4BACnD,GAAG,GAAG,QAAQ,CAAC,GAAG,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC;yBACxD;wBACD,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;oBACvB,CAAC,CAAC,CAAC;oBAEH,OAAO,IAAI,CAAC;gBAChB,CAAC;aACJ,CAAC;QACN,CAAC;KACJ,CAAC,CAAC;AACP,CAAC,CAAC"}
@@ -1,41 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import { css } from '@emotion/css';
3
- export const injectStyle = ({ size, mixin, palette, font }) => {
4
- var _a, _b;
5
- return css `
6
- position: absolute;
7
- &.hide {
8
- display: none;
9
- }
10
-
11
- ${(_a = mixin.border) === null || _a === void 0 ? void 0 : _a.call(mixin)};
12
- border-radius: ${size.radius};
13
- background: ${palette('surface')};
14
- ${(_b = mixin.shadow) === null || _b === void 0 ? void 0 : _b.call(mixin)};
15
-
16
- .milkdown-emoji-filter_item {
17
- display: flex;
18
- gap: 0.5rem;
19
- height: 2.25rem;
20
- padding: 0 1rem;
21
- align-items: center;
22
- justify-content: flex-start;
23
- cursor: pointer;
24
- line-height: 2;
25
- font-family: ${font.typography};
26
- font-size: 0.875rem;
27
- &.active {
28
- background: ${palette('secondary', 0.12)};
29
- color: ${palette('primary')};
30
- }
31
- }
32
-
33
- .emoji {
34
- height: 1em;
35
- width: 1em;
36
- margin: 0 0.05em 0 0.1em;
37
- vertical-align: -0.1em;
38
- }
39
- `;
40
- };
41
- //# sourceMappingURL=style.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"style.js","sourceRoot":"","sources":["../../src/filter/style.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AAGnC,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAa,EAAE,EAAE;;IACrE,OAAO,GAAG,CAAA;;;;;;UAMJ,MAAA,KAAK,CAAC,MAAM,+CAAZ,KAAK,CAAW;yBACD,IAAI,CAAC,MAAM;sBACd,OAAO,CAAC,SAAS,CAAC;UAC9B,MAAA,KAAK,CAAC,MAAM,+CAAZ,KAAK,CAAW;;;;;;;;;;;2BAWC,IAAI,CAAC,UAAU;;;8BAGZ,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC;yBAC/B,OAAO,CAAC,SAAS,CAAC;;;;;;;;;;KAUtC,CAAC;AACN,CAAC,CAAC"}
package/lib/index.js DELETED
@@ -1,6 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import { AtomList } from '@milkdown/utils';
3
- import { emojiNode } from './node';
4
- export const emoji = AtomList.create([emojiNode()]);
5
- export { emojiNode } from './node';
6
- //# sourceMappingURL=index.js.map
package/lib/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAEnC,MAAM,CAAC,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;AAEpD,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC"}
package/lib/node.js DELETED
@@ -1,94 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import { css } from '@emotion/css';
3
- import { InputRule } from '@milkdown/prose';
4
- import { createNode } from '@milkdown/utils';
5
- import nodeEmoji from 'node-emoji';
6
- import remarkEmoji from 'remark-emoji';
7
- import { input } from './constant';
8
- import { filter } from './filter';
9
- import { parse } from './parse';
10
- import { picker } from './picker';
11
- import { twemojiPlugin } from './remark-twemoji';
12
- export const emojiNode = createNode((utils) => {
13
- const style = utils.getStyle(() => css `
14
- display: inline-flex;
15
- justify-content: center;
16
- align-items: center;
17
-
18
- .emoji {
19
- height: 1em;
20
- width: 1em;
21
- margin: 0 0.05em 0 0.1em;
22
- vertical-align: -0.1em;
23
- }
24
- `);
25
- return {
26
- id: 'emoji',
27
- schema: () => ({
28
- group: 'inline',
29
- inline: true,
30
- selectable: false,
31
- attrs: {
32
- html: {
33
- default: '',
34
- },
35
- },
36
- parseDOM: [
37
- {
38
- tag: 'span[data-type="emoji"]',
39
- getAttrs: (dom) => {
40
- if (!(dom instanceof HTMLElement)) {
41
- throw new Error();
42
- }
43
- return { html: dom.innerHTML };
44
- },
45
- },
46
- ],
47
- toDOM: (node) => {
48
- const span = document.createElement('span');
49
- span.dataset.type = 'emoji';
50
- if (style) {
51
- span.classList.add(style);
52
- }
53
- span.classList.add('emoji-wrapper');
54
- span.innerHTML = node.attrs.html;
55
- return { dom: span };
56
- },
57
- parseMarkdown: {
58
- match: ({ type }) => type === 'emoji',
59
- runner: (state, node, type) => {
60
- state.addNode(type, { html: node.value });
61
- },
62
- },
63
- toMarkdown: {
64
- match: (node) => node.type.name === 'emoji',
65
- runner: (state, node) => {
66
- const span = document.createElement('span');
67
- span.innerHTML = node.attrs.html;
68
- const img = span.querySelector('img');
69
- const title = img === null || img === void 0 ? void 0 : img.title;
70
- span.remove();
71
- state.addNode('text', undefined, title);
72
- },
73
- },
74
- }),
75
- inputRules: (nodeType) => [
76
- new InputRule(input, (state, match, start, end) => {
77
- const content = match[0];
78
- if (!content)
79
- return null;
80
- const got = nodeEmoji.get(content);
81
- if (!got || content.includes(got))
82
- return null;
83
- const html = parse(got);
84
- return state.tr
85
- .setMeta('emoji', true)
86
- .replaceRangeWith(start, end, nodeType.create({ html }))
87
- .scrollIntoView();
88
- }),
89
- ],
90
- remarkPlugins: () => [remarkEmoji, twemojiPlugin],
91
- prosePlugins: () => [picker(utils), filter(utils)],
92
- };
93
- });
94
- //# sourceMappingURL=node.js.map
package/lib/node.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"node.js","sourceRoot":"","sources":["../src/node.ts"],"names":[],"mappings":"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"}
package/lib/parse.js DELETED
@@ -1,4 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import twemoji from 'twemoji';
3
- export const parse = (emoji) => twemoji.parse(emoji, { attributes: (text) => ({ title: text }) });
4
- //# sourceMappingURL=parse.js.map
package/lib/parse.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"parse.js","sourceRoot":"","sources":["../src/parse.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,MAAM,CAAC,MAAM,KAAK,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,UAAU,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC"}
package/lib/picker.js DELETED
@@ -1,113 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import { injectGlobal } from '@emotion/css';
3
- import { EmojiButton } from '@joeattardi/emoji-button';
4
- import { Decoration, DecorationSet, Plugin } from '@milkdown/prose';
5
- import { parse } from './parse';
6
- const keyword = ':emoji:';
7
- const checkTrigger = (view, from, to, text, setRange) => {
8
- if (view.composing)
9
- return false;
10
- const { state } = view;
11
- const $from = state.doc.resolve(from);
12
- if ($from.parent.type.spec.code)
13
- return false;
14
- const textBefore = $from.parent.textBetween($from.parentOffset - keyword.length + 1, $from.parentOffset, undefined, '\ufffc') +
15
- text;
16
- if (textBefore === keyword) {
17
- setRange(from - keyword.length + 1, to + 1);
18
- return true;
19
- }
20
- return false;
21
- };
22
- export const picker = (utils) => {
23
- let trigger = false;
24
- const holder = document.createElement('span');
25
- let _from = 0;
26
- let _to = 0;
27
- const off = () => {
28
- trigger = false;
29
- _from = 0;
30
- _to = 0;
31
- };
32
- const plugin = new Plugin({
33
- props: {
34
- handleKeyDown() {
35
- off();
36
- return false;
37
- },
38
- handleClick() {
39
- off();
40
- return false;
41
- },
42
- handleTextInput(view, from, to, text) {
43
- trigger = checkTrigger(view, from, to, text, (from, to) => {
44
- _from = from;
45
- _to = to;
46
- });
47
- if (!trigger) {
48
- off();
49
- }
50
- return false;
51
- },
52
- decorations(state) {
53
- if (!trigger)
54
- return null;
55
- return DecorationSet.create(state.doc, [Decoration.widget(state.selection.to, holder)]);
56
- },
57
- },
58
- view: (editorView) => {
59
- const { parentNode } = editorView.dom;
60
- if (!parentNode) {
61
- throw new Error();
62
- }
63
- utils.getStyle(({ palette, font }) => {
64
- const css = injectGlobal;
65
- css `
66
- .emoji-picker {
67
- --dark-search-background-color: ${palette('surface')} !important;
68
- --dark-text-color: ${palette('neutral', 0.87)} !important;
69
- --dark-background-color: ${palette('background')} !important;
70
- --dark-border-color: ${palette('shadow')} !important;
71
- --dark-hover-color: ${palette('secondary', 0.12)} !important;
72
- --dark-blue-color: ${palette('primary')} !important;
73
- --dark-search-icon-color: ${palette('primary')} !important;
74
- --dark-category-button-color: ${palette('secondary', 0.4)} !important;
75
- --font: ${font.typography} !important;
76
- --font-size: 1rem !important;
77
- }
78
- `;
79
- });
80
- const emojiPicker = new EmojiButton({
81
- rootElement: parentNode,
82
- autoFocusSearch: false,
83
- style: 'twemoji',
84
- theme: 'dark',
85
- zIndex: 99,
86
- });
87
- emojiPicker.on('emoji', (selection) => {
88
- const start = _from;
89
- const end = _to;
90
- off();
91
- const html = parse(selection.emoji);
92
- const node = editorView.state.schema.node('emoji', { html });
93
- const { tr } = editorView.state;
94
- editorView.dispatch(tr.replaceRangeWith(start, end, node));
95
- });
96
- return {
97
- update: () => {
98
- if (!trigger) {
99
- emojiPicker.hidePicker();
100
- return null;
101
- }
102
- emojiPicker.showPicker(holder);
103
- return null;
104
- },
105
- destroy: () => {
106
- emojiPicker.destroyPicker();
107
- },
108
- };
109
- },
110
- });
111
- return plugin;
112
- };
113
- //# sourceMappingURL=picker.js.map
package/lib/picker.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"picker.js","sourceRoot":"","sources":["../src/picker.ts"],"names":[],"mappings":"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"}
@@ -1,52 +0,0 @@
1
- /* Copyright 2021, Milkdown by Mirone. */
2
- import emojiRegex from 'emoji-regex';
3
- import { parse } from './parse';
4
- const regex = emojiRegex();
5
- const isParent = (node) => !!node.children;
6
- const isLiteral = (node) => !!node.value;
7
- function flatMap(ast, fn) {
8
- return transform(ast, 0, null)[0];
9
- function transform(node, index, parent) {
10
- if (isParent(node)) {
11
- const out = [];
12
- for (let i = 0, n = node.children.length; i < n; i++) {
13
- const xs = transform(node.children[i], i, node);
14
- if (xs) {
15
- for (let j = 0, m = xs.length; j < m; j++) {
16
- out.push(xs[j]);
17
- }
18
- }
19
- }
20
- node.children = out;
21
- }
22
- return fn(node, index, parent);
23
- }
24
- }
25
- export const twemojiPlugin = () => {
26
- function transformer(tree) {
27
- flatMap(tree, (node) => {
28
- if (!isLiteral(node)) {
29
- return [node];
30
- }
31
- const value = node.value;
32
- const output = [];
33
- let match;
34
- let str = value;
35
- while ((match = regex.exec(str))) {
36
- const { index } = match;
37
- const emoji = match[0];
38
- if (index > 0) {
39
- output.push(Object.assign(Object.assign({}, node), { value: str.slice(0, index) }));
40
- }
41
- output.push(Object.assign(Object.assign({}, node), { value: parse(emoji), type: 'emoji' }));
42
- str = str.slice(index + emoji.length);
43
- }
44
- if (str.length) {
45
- output.push(Object.assign(Object.assign({}, node), { value: str }));
46
- }
47
- return output;
48
- });
49
- }
50
- return transformer;
51
- };
52
- //# sourceMappingURL=remark-twemoji.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"remark-twemoji.js","sourceRoot":"","sources":["../src/remark-twemoji.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,OAAO,UAAU,MAAM,aAAa,CAAC;AAGrC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,MAAM,KAAK,GAAG,UAAU,EAAE,CAAC;AAE3B,MAAM,QAAQ,GAAG,CAAC,IAAU,EAAkB,EAAE,CAAC,CAAC,CAAE,IAAe,CAAC,QAAQ,CAAC;AAC7E,MAAM,SAAS,GAAG,CAAC,IAAU,EAAmB,EAAE,CAAC,CAAC,CAAE,IAAgB,CAAC,KAAK,CAAC;AAE7E,SAAS,OAAO,CAAC,GAAS,EAAE,EAA8D;IACtF,OAAO,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAElC,SAAS,SAAS,CAAC,IAAU,EAAE,KAAa,EAAE,MAAmB;QAC7D,IAAI,QAAQ,CAAC,IAAI,CAAC,EAAE;YAChB,MAAM,GAAG,GAAG,EAAE,CAAC;YACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAClD,MAAM,EAAE,GAAG,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;gBAChD,IAAI,EAAE,EAAE;oBACJ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;wBACvC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;qBACnB;iBACJ;aACJ;YACD,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;SACvB;QAED,OAAO,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;IACnC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE;IAC9B,SAAS,WAAW,CAAC,IAAU;QAC3B,OAAO,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE;YACnB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAClB,OAAO,CAAC,IAAI,CAAC,CAAC;aACjB;YACD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAe,CAAC;YACnC,MAAM,MAAM,GAAsB,EAAE,CAAC;YACrC,IAAI,KAAK,CAAC;YACV,IAAI,GAAG,GAAG,KAAK,CAAC;YAChB,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE;gBAC9B,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC;gBACxB,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBACvB,IAAI,KAAK,GAAG,CAAC,EAAE;oBACX,MAAM,CAAC,IAAI,iCAAM,IAAI,KAAE,KAAK,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,IAAG,CAAC;iBACxD;gBACD,MAAM,CAAC,IAAI,iCAAM,IAAI,KAAE,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,OAAO,IAAG,CAAC;gBAC7D,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;aACzC;YACD,IAAI,GAAG,CAAC,MAAM,EAAE;gBACZ,MAAM,CAAC,IAAI,iCAAM,IAAI,KAAE,KAAK,EAAE,GAAG,IAAG,CAAC;aACxC;YACD,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;IACP,CAAC;IACD,OAAO,WAAW,CAAC;AACvB,CAAC,CAAC"}