@cloudea/yang-editor 1.0.5 → 1.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/utils.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SelectionUtils = void 0;
3
+ exports.FormatCleaner = exports.SelectionUtils = void 0;
4
4
  const componets_1 = require("./componets");
5
5
  class SelectionUtils {
6
6
  constructor(element) {
@@ -34,4 +34,87 @@ class SelectionUtils {
34
34
  }
35
35
  }
36
36
  exports.SelectionUtils = SelectionUtils;
37
+ /**
38
+ * utils for format cleaning
39
+ */
40
+ class FormatCleaner {
41
+ /**
42
+ * clean HTML string and return plain text
43
+ * @param htmlString html string
44
+ * @returns plain text
45
+ */
46
+ static cleanHTMLString(htmlString) {
47
+ // remove Word XML namespace labels
48
+ htmlString = htmlString.replace(/<\/?[ovwm]:[^>]*>/gi, '');
49
+ // remove Word conditional comments
50
+ htmlString = htmlString.replace(/<!--\[if[\s\S]*?<!\[endif\]-->/gi, '');
51
+ htmlString = htmlString.replace(/<!--[\s\S]*?-->/g, '');
52
+ const tempDiv = document.createElement('div');
53
+ tempDiv.innerHTML = htmlString;
54
+ // remove all <style> tags (including @page, @font-face rules)
55
+ const styleTags = tempDiv.querySelectorAll('style');
56
+ styleTags.forEach(style => style.remove());
57
+ // remove other unwanted tags
58
+ FormatCleaner.unwantedTags.forEach(tag => {
59
+ const elements = tempDiv.querySelectorAll(tag);
60
+ elements.forEach(el => el.remove());
61
+ });
62
+ return this.extractPlainText(tempDiv);
63
+ }
64
+ /**
65
+ * extract plain text from node, remove all HTML tags and styles
66
+ * @param node DOM node
67
+ * @returns plain text content
68
+ */
69
+ static extractPlainText(node) {
70
+ if (node.nodeType === Node.TEXT_NODE) {
71
+ return node.textContent || '';
72
+ }
73
+ else if (node.nodeType === Node.ELEMENT_NODE) {
74
+ const element = node;
75
+ const tagName = element.tagName.toLowerCase();
76
+ if (FormatCleaner.unwantedTags.includes(tagName)) {
77
+ return '';
78
+ }
79
+ if (tagName === 'br') {
80
+ return '\n';
81
+ }
82
+ // block elements(p、div etc.)
83
+ const isBlock = ['p', 'div', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6',
84
+ 'li', 'tr', 'td', 'th', 'blockquote', 'pre'].includes(tagName);
85
+ let result = '';
86
+ for (let child of Array.from(element.childNodes)) {
87
+ result += this.extractPlainText(child);
88
+ }
89
+ if (isBlock && result.trim()) {
90
+ result += '\n';
91
+ }
92
+ return result;
93
+ }
94
+ return '';
95
+ }
96
+ /**
97
+ * remove all styles and other properties
98
+ * @param element HTML element
99
+ */
100
+ static removeAllStyles(element) {
101
+ // remove style attribute
102
+ element.removeAttribute('style');
103
+ // remove common format attributes
104
+ const formatAttributes = ['class', 'align', 'valign', 'bgcolor', 'color',
105
+ 'face', 'size', 'width', 'height', 'border',
106
+ 'cellpadding', 'cellspacing', 'dir'];
107
+ formatAttributes.forEach(attr => {
108
+ if (element.hasAttribute(attr)) {
109
+ element.removeAttribute(attr);
110
+ }
111
+ });
112
+ // recursively process child elements
113
+ for (let child of Array.from(element.children)) {
114
+ this.removeAllStyles(child);
115
+ }
116
+ }
117
+ }
118
+ exports.FormatCleaner = FormatCleaner;
119
+ FormatCleaner.unwantedTags = ['style', 'script', 'link', 'meta', 'head', 'title', 'xml'];
37
120
  //# sourceMappingURL=utils.js.map
package/dist/utils.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":";;;AAAA,2CAA+C;AAE/C,MAAa,cAAc;IAIvB,YAAY,OAAoB;QAC5B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IAC3B,CAAC;IAEM,oBAAoB;QACvB,IAAI,KAAK,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACrC,IAAG,KAAK,EAAE,CAAC;YACP,IAAI,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC;YAChC,OAAM,IAAI,IAAI,IAAI,KAAK,IAAI,CAAC,OAAO,EAAE,CAAC;gBAClC,IAAG,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;oBACrC,IAAI,IAAI,GAAG,IAAmB,CAAC;oBAC/B,IAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,4BAAgB,CAAC,eAAe,CAAC,EAAE,CAAC;wBAC3D,OAAO,IAAI,CAAC;oBAChB,CAAC;gBACL,CAAC;gBACD,IAAI,GAAG,IAAI,CAAC,UAAkB,CAAC;YACnC,CAAC;QACL,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAEM,iBAAiB;QACpB,IAAI,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACtC,IAAG,SAAS,IAAI,SAAS,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;YACvC,IAAI,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACpC,IAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,uBAAuB,CAAC,EAAE,CAAC;gBACtD,OAAO,KAAK,CAAC;YACjB,CAAC;QACL,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ;AAnCD,wCAmCC"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"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"}
Binary file
Binary file
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cloudea/yang-editor",
3
- "version": "1.0.5",
3
+ "version": "1.0.7",
4
4
  "description": "a fast block editor",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.ts",
package/src/componets.ts CHANGED
@@ -1,5 +1,6 @@
1
1
  import { images } from "./images";
2
2
  import {YangEditor, YangEditorColor} from "./index";
3
+ import { FormatCleaner } from "./utils";
3
4
 
4
5
  export interface EditorElement {
5
6
  }
@@ -10,6 +11,8 @@ export interface EditorComponent extends EditorElement {
10
11
  onMounted(): void;
11
12
  }
12
13
 
14
+ export type EditorFunction = "insertCollapse" | "insertImage" | "insertCode"
15
+
13
16
  export class EditorBody implements EditorComponent {
14
17
  public readonly element: HTMLDivElement;
15
18
  public readonly context: YangEditor;
@@ -162,20 +165,38 @@ export class EditorContent implements EditorComponent {
162
165
  }
163
166
 
164
167
  this.element.onpaste = (e) => {
165
- // TODO: handle paste event
166
- //e.preventDefault();
167
- // let clipboardData = e.clipboardData;
168
- // if (clipboardData) {
169
- // let html = clipboardData.getData("text/html");
170
- // let text = clipboardData.getData("text/plain");
171
- // if (html) {
172
- // let div = document.createElement("div");
173
- // div.innerHTML = html;
174
- // this.element.appendChild(div);
175
- // } else if (text) {
176
- // this.element.appendChild(document.createTextNode(text));
177
- // }
178
- // }
168
+ e.preventDefault();
169
+
170
+ let clipboardData = e.clipboardData;
171
+ if (!clipboardData) return;
172
+
173
+ // get clipboard content
174
+ let html = clipboardData.getData("text/html");
175
+ let text = clipboardData.getData("text/plain");
176
+
177
+ let cleanedText = '';
178
+ if (html) {
179
+ cleanedText = FormatCleaner.cleanHTMLString(html);
180
+ } else if (text) {
181
+ cleanedText = text;
182
+ }
183
+ if (cleanedText) {
184
+ // insert content into selection range
185
+ const range = this.context.selectionUtils.getSelectionRange();
186
+ if (range) {
187
+ const lines = cleanedText.split('\n').filter(line => line.trim());
188
+ const fragment = document.createDocumentFragment();
189
+ lines.forEach((line, index) => {
190
+ fragment.appendChild(document.createTextNode(line));
191
+ if (index < lines.length - 1) {
192
+ fragment.appendChild(document.createElement('br'));
193
+ }
194
+ });
195
+ range.deleteContents();
196
+ range.insertNode(fragment);
197
+ range.collapse(false);
198
+ }
199
+ }
179
200
  }
180
201
 
181
202
  this.insertDefaultParagraph();
@@ -187,14 +208,14 @@ export class EditorContent implements EditorComponent {
187
208
  this.element.appendChild(document.createElement('p'));
188
209
  }
189
210
 
190
- insertCollapse() {
211
+ insertCollapse(args: {className?: string}) {
191
212
  let paragraphElement = this.context.selectionUtils.getSelectedParagraph();
192
213
  if(paragraphElement?.innerText.trim() === "") {
193
- paragraphElement.replaceWith(new EditorCollapse(this.context).onMount());
214
+ paragraphElement.replaceWith(new EditorCollapse(this.context, undefined, args.className).onMount());
194
215
  } else {
195
216
  for(let child of this.element.children) {
196
217
  if(child === paragraphElement) {
197
- child.after(new EditorCollapse(this.context).onMount());
218
+ child.after(new EditorCollapse(this.context, undefined, args.className).onMount());
198
219
  break;
199
220
  }
200
221
  }
@@ -272,11 +293,16 @@ class ButtonAdd implements EditorComponent {
272
293
  this.element.classList.add("yang-editor-button-add");
273
294
  this.element.innerText = "";
274
295
  this.element.style.backgroundImage = `url("${images.add2x}")`;
275
- this.element.title = "Add Collapsed Panel";
276
- this.element.onclick = () => this.context.body.content.insertCollapse();
296
+
297
+ let div = document.createElement("div");
298
+ div.classList.add("yang-editor-button-add-bridge");
299
+ this.element.appendChild(div)
300
+
301
+ //this.element.onclick = () => this.context.body.content.insertCollapse();
277
302
  }
278
303
 
279
304
  onMount(): HTMLElement {
305
+ this.element.appendChild(new EditorComponentMenu(this.context).onMount());
280
306
  return this.element;
281
307
  }
282
308
 
@@ -532,7 +558,7 @@ export class EditorCollapse implements EditorComponent {
532
558
  body: HTMLDivElement;
533
559
  container: HTMLDivElement;
534
560
 
535
- constructor(editor: YangEditor, element?: HTMLElement) {
561
+ constructor(editor: YangEditor, element?: HTMLElement, className?: string) {
536
562
  this.context = editor;
537
563
  if(element) {
538
564
  this.element = element;
@@ -568,6 +594,9 @@ export class EditorCollapse implements EditorComponent {
568
594
  this.container.contentEditable = "false";
569
595
  this.button.style.backgroundImage = `url("${images.down2x}")`;
570
596
  }
597
+ if (className) {
598
+ this.container.classList.add(className);
599
+ }
571
600
  }
572
601
 
573
602
  getElement(): HTMLElement {
@@ -620,6 +649,70 @@ export class EditorCollapse implements EditorComponent {
620
649
 
621
650
  }
622
651
 
652
+
653
+ export class EditorComponentMenu implements EditorComponent {
654
+ public readonly element: HTMLDivElement;
655
+ public readonly context: YangEditor;
656
+ public readonly functions: Map<EditorFunction, (args:any) => void> = new Map();
657
+
658
+ constructor(editor: YangEditor) {
659
+ this.context = editor;
660
+ this.element = document.createElement("div");
661
+ this.functions.set("insertCollapse", (args) => this.context.body.content.insertCollapse(args));
662
+ }
663
+
664
+ onMounted(): void {
665
+ throw new Error("Method not implemented.");
666
+ }
667
+
668
+ getElement(): HTMLElement {
669
+ return this.element;
670
+ }
671
+
672
+ onMount(): HTMLElement {
673
+ this.element.classList.add("yang-editor-component-menu");
674
+
675
+ if (this.context.options.menus) {
676
+
677
+ let ul = document.createElement("ul");
678
+ let lis = new Array<HTMLLIElement>();
679
+
680
+ for (let item of this.context.options.menus) {
681
+ let li = document.createElement("li");
682
+ let icon = document.createElement("button");
683
+ let text = document.createElement("p");
684
+ li.classList.add("yang-editor-component-menu-item");
685
+ icon.classList.add("yang-editor-component-menu-item-icon");
686
+ text.classList.add("yang-editor-component-menu-item-text");
687
+ let title = item.name;
688
+ icon.style.backgroundImage = `url("${item.icon}")`;
689
+ text.innerText = title;
690
+ if (item.className) {
691
+ li.classList.add(item.className);
692
+ }
693
+ if (item.callback) {
694
+ let func = this.functions.get(item.callback);
695
+ if (func) {
696
+ li.onclick = () => {
697
+ func(item.args)
698
+ };
699
+ }
700
+ }
701
+ li.appendChild(icon);
702
+ li.appendChild(text);
703
+ ul.appendChild(li);
704
+ lis.push(li);
705
+ }
706
+
707
+ this.element.appendChild(ul);
708
+ }
709
+ return this.getElement();
710
+ }
711
+
712
+
713
+ }
714
+
715
+
623
716
  export class EditorParagraphMenu implements EditorComponent {
624
717
  public readonly element: HTMLDivElement;
625
718
  public readonly context: YangEditor;
package/src/images.ts CHANGED
@@ -5,12 +5,15 @@ export const images = {
5
5
  add2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAGmSURBVFiFxVbJYcMgEJwlaSRV+Gn0slWEKzA9WOoBd5DUoPhl/HUVqQTyELqsA1bB8fxWAmZgYWcJHFRKgtypjQkSAOBg6phusDDItYldkqJJG7JoUImdLv4m4Pt45RPzhEwLWL1rvoixgEpJCHdNQxwW8fY/5AAAicOG8Hk3/Y9iMOR55B7uhIsqpgU8/AivBQNLGUAlW0Sl5FgAeu87BkQ35Npgp4u2DkTP7bhqAdzdAxhcKKIbTwBkcwr+BJi7TwF/CmLV7hNChIc8CT4NAs5tXyYCAOFydIsjLGUcdxvgoorF+2UpC6SAytXkAIJPVEAuC0iRnoChUdhyZypdvw5USkI8rOHcNuimlrL3xQH1SnM57AQIyNG4cKvjp3KrWErk2ghYZh1Phjq1Ark2bDNJiPoVvCIN/hKLNuCeQuMhlZJ8M+teVndXn9uOdXAw2J+zJux6wq/7Dw4bAlJ1wjPYnz/64bASrkkFB5ayx0/jUrw/r+jzIsknfGXaC3a6SCaiaV5nTC1cMEOWukTswm4aV7Fbs4kQEknMEzAryKMp5yt6h1+8AKTXUlzRcwAAAABJRU5ErkJggg==',
6
6
  bold2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAADcSURBVFiF7ZRrDoMgEISnTe9VejLxZMLJ7A/YoIllH80Gf/AlRg0Ph3V2gMlkMA9mfAMQhHslALk+R5ucawG74RILeCnErMz4G61aS33/KPa/hCqwGdbsEPy+p0lWn+OplxECgGJIEV4CqBvCKAFUes64LgI0hlW1YWTGj20IlNNza1isQSRqQcDPA4AuxrubaIIooJRdXAmNByQktAxgQ0iCJYoJqkB3racHUr2HUQKINEJARDt5/j3NR0DA2YCpN1naBQG6ViRWTgDHP0kYJR/wyIGMcx5MJvfmC0EdViqgG/sdAAAAAElFTkSuQmCC',
7
7
  clear2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAADoSURBVFiF7ZdLDsIwDESHm+VmhJOlN4MFjWRckoztGiTESF70E7/XqIla4J8v5xIcX/YCgG2vj6QAaADuqpoQSoVrsK40CQ3vT1wA1GwJDa9v7kmVWMHTJWTTVVIk2Bk4TaIoWD+OSJjh2j4q0TxwDfFI9E1rKcA2t0rIXXMaS1OLBPUeVAPcIkH3pafJIFFBPn1EYCSh4cUisLyZkDBvQrIBtV5JCQreI2fBI1Ej8KjEKXCvxKlwq0QKnJUIw5nP8qYa3/D8/L4Ozs+yuj6VGK1xS3mXN4DjdHvrJZ4/o+IYI7MFx/9YHqpw4/wia7QRAAAAAElFTkSuQmCC',
8
+ code2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAACNSURBVFiF7ZbBCYAwEAQXK7GElJKS0klKtAT9RJCA4XK3Zx7egL+VGcgjAYIgkLM7bUUkAAeAKtjWtk1s+dm+PNjmx44S0cuL4J/CitDIaREWuTmCIVdHMOXTER5ycYSnfBixOYjULD0Czwix3CNiWs6MUMsZEWa5JYImf4v49DruI5Y8SG52p20Q/JwLnf9zIcEOe6AAAAAASUVORK5CYII=',
9
+ collapse2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAABgSURBVFiF7ZSxDcAgEMRuZEbIBozAqKQIKUARCjwQItn92U+DBAAAm+MkecP+SA6TIEoKHduQtpYHZKKWI3o2w4TD4y3iafE3genxWmhZ/Cm4PF4e8Un8xuv6KwAA4L+cIcQlYuhEL/UAAAAASUVORK5CYII=',
8
10
  copy2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAADMSURBVFiF7ZZbEsIgDEVvHffVuDLpyqArqx8FrRiVhEd/cmYYZngklwwhAMbJTML1BOCu9LXG3in3wwHYGjQ6GpVEYIv9Taf/Gb2gtZFOoIXifn8cvFQYbIIJ4AR4vN9az6zpJsAhS5Pe5ALm2C/YU3SCPu1UAhKhp9MSAcMwASZgpADiBq8CAwGvilbD+msyPcPEzCXnNe3jWZdGQPqF+0uPO+AhKGCSCJRCksWnp+G3CNBIEbnjFl9vV+qQu9Vp88zMlbBgYDk3qnkARgpONsy9a0IAAAAASUVORK5CYII=',
9
11
  cut2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAADxSURBVFiF7ZZRDoMgDIZ/lx2sN1t3MrzZ9uDIutKCIOjD+BJjgtB+AYoAk39nKXynzxPhUSIWAcDLeE6RYJWQVRuNTE4iUU6shjiOe3SOS0OVyc2Y951BWgn4ij4tAQvCZhuc73uWgPC7iSnX2ROwpoyddm+8nIEqYqIYxCpJS0KPO4QM5smw09+Sa4aQTqNO5kkNRUo0H1C3rkqDIFy0BAR755+yCWUwrwypMO6QROkgytW4lGg6iGIAnVzL5SCkS2fSUgWrSJLrs2D7AQHAw5MYXYa8R0JDuPhCAqSlxkbbcBhp6XVPXnMtX9V7MunCG5oyltrXyXn1AAAAAElFTkSuQmCC',
10
12
  delete2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAADESURBVFiF7ZdhDoMgDIXflt1rvdnYyexO5n4I0URb4RHFBF9CTKptP4tgAXrXg/QTw65kvCIFAKMxhtJgLwJAAbyNe18i3vU0wC5x7VhN0fPQV6lUqoQcmaR5Bc4AGDEt3SYAEq/WsqUBJNO2KwYgYPpAlwkl2op3QgbALCejLlbBDXADXBuA6YhS16MLm0a7olBsS7aVKBCx2k/BWQA/BiA5fSoSy94D3sFEMP/dtBKAPQC5h5DcIXCUS+YGcaSkX0f6A9JRRH7yUeoDAAAAAElFTkSuQmCC',
11
13
  deleteline2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAADwSURBVFiF7VZtDsIgDH3THcSj1JNZTzY82fyzxa4gUFZM1L2k6TLa1xcoH8CBf8fQmEfKB+W7gQHMBaM3ubtAFYWlTd4CJlWAEwK5lwhZvERKBaERTkYx98J4qIjZoGYXzMZ44DVTDxRmoZeAapwrYgjARQgI3iJKYMTdTV7kckpzpKnuD4s3NZ3OlwLmdFw3DIB9G7pjFN/XHTy3xZP6H9C+RE0gxPfCx6FFUC64Rw8EbM+KrIAxN7gkrwSa2CKoGYy29ZQ3KO0RABivV2xFu7wJJGHuKOZEbCrORUSNuRVfQYifZiljC+nXPcsP/B6ekq1yptAqTwMAAAAASUVORK5CYII=',
12
14
  down2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAABiSURBVFiF7ZBBCoAwDARXX5an+bPiy+rFo5TYaSvIDuSWMEMkY4wxH7MlduKeXg5wqyKpwiktwU7qkpzkOMQ/ECSARmA5iRgm74kYLn8TMU2eiZgub0Uskz9FLJcbY8x/uAClcl7rtXA5XgAAAABJRU5ErkJggg==',
13
15
  fgcolor: 'data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="17" height="17" viewBox="0 0 17 17" fill="none"><path   fill="rgba(228, 73, 91, 1)"  d="M2.5 0L14.5 0C15.8807 0 17 1.11929 17 2.5L17 14.5C17 15.8807 15.8807 17 14.5 17L2.5 17C1.11929 17 0 15.8807 0 14.5L0 2.5C0 1.11929 1.11929 0 2.5 0ZM2.5 1C1.67157 1 1 1.67157 1 2.5L1 14.5C1 15.3284 1.67157 16 2.5 16L14.5 16C15.3284 16 16 15.3284 16 14.5L16 2.5C16 1.67157 15.3284 1 14.5 1L2.5 1Z"></path><g  clip-path="url(#clip-path-uDmpTaYBd-GAbvmU4kRSm)"><path d="M13.4686 10.3973C13.448 10.4179 13.4272 10.4381 13.4061 10.4581C13.385 10.4781 13.3637 10.4978 13.3421 10.5173C13.3206 10.5367 13.2988 10.556 13.2767 10.5749C13.2547 10.5938 13.2324 10.6125 13.2099 10.6309C13.1874 10.6492 13.1647 10.6673 13.1417 10.6851C13.1188 10.703 13.0956 10.7205 13.0722 10.7377C13.0489 10.755 13.0253 10.7719 13.0015 10.7886C12.9777 10.8052 12.9537 10.8216 12.9294 10.8377C12.9052 10.8538 12.8809 10.8695 12.8563 10.885C12.8317 10.9005 12.8069 10.9156 12.7819 10.9305C12.7569 10.9453 12.7318 10.9599 12.7065 10.9741C12.6811 10.9883 12.6556 11.0022 12.6299 11.0158C12.6043 11.0294 12.5784 11.0427 12.5524 11.0557C12.5264 11.0686 12.5003 11.0813 12.474 11.0936C12.4476 11.1059 12.4212 11.1179 12.3946 11.1296C12.3679 11.1412 12.3412 11.1525 12.3143 11.1636C12.2874 11.1746 12.2604 11.1852 12.2332 11.1955C12.2061 11.2059 12.1788 11.2159 12.1514 11.2255C12.124 11.2352 12.0965 11.2445 12.0689 11.2535C12.0412 11.2625 12.0135 11.2711 11.9856 11.2794C11.9578 11.2877 11.9299 11.2956 11.9018 11.3032C11.8738 11.3108 11.8456 11.3181 11.8174 11.325C11.7892 11.3319 11.7609 11.3385 11.7325 11.3447C11.7041 11.3509 11.6757 11.3567 11.6471 11.3622C11.6186 11.3677 11.59 11.3729 11.5614 11.3777C11.5327 11.3825 11.504 11.3869 11.4752 11.391C11.4465 11.3951 11.4177 11.3988 11.3888 11.4022C11.3599 11.4056 11.3311 11.4086 11.3021 11.4113C11.2732 11.4139 11.2442 11.4162 11.2152 11.4182C11.1863 11.4201 11.1572 11.4217 11.1282 11.4229C11.0992 11.4242 11.0702 11.425 11.0411 11.4255C11.0121 11.4261 10.983 11.4262 10.9539 11.426L9.84929 11.426C9.61728 11.426 9.39796 11.6447 9.39796 11.8773C9.39796 11.964 9.45329 12.0567 9.54396 12.194C9.78062 12.4447 9.89062 12.736 9.89062 13.1047C9.89062 13.4627 9.73996 13.82 9.47596 14.0846C9.46793 14.0927 9.45982 14.1007 9.45161 14.1085C9.44339 14.1164 9.43509 14.1241 9.42669 14.1318C9.41829 14.1395 9.40979 14.147 9.40121 14.1545C9.39263 14.1619 9.38395 14.1693 9.3752 14.1765C9.36643 14.1838 9.35759 14.1909 9.34866 14.1979C9.33972 14.2049 9.3307 14.2119 9.3216 14.2187C9.31249 14.2255 9.30332 14.2323 9.29405 14.2388C9.28479 14.2454 9.27545 14.2518 9.26603 14.2583C9.25661 14.2646 9.24711 14.2708 9.23754 14.277C9.22796 14.2831 9.21832 14.2891 9.20861 14.2951C9.19889 14.3009 9.18909 14.3067 9.17924 14.3124C9.16938 14.318 9.15947 14.3235 9.14947 14.3289C9.13948 14.3343 9.12942 14.3397 9.11931 14.3449C9.10918 14.35 9.099 14.3551 9.08876 14.36C9.07852 14.3649 9.06821 14.3697 9.05786 14.3744C9.04751 14.3791 9.03709 14.3837 9.02662 14.3881C9.01616 14.3926 9.00564 14.3968 8.99505 14.401C8.98448 14.4052 8.97387 14.4092 8.96319 14.4132C8.95252 14.4171 8.9418 14.4208 8.93105 14.4246C8.92028 14.4282 8.90947 14.4317 8.89863 14.4351C8.88778 14.4385 8.87689 14.4418 8.86597 14.445C8.85504 14.448 8.84408 14.451 8.83308 14.4539C8.82207 14.4567 8.81105 14.4595 8.79998 14.4621C8.78891 14.4646 8.77781 14.4672 8.76669 14.4696C8.75557 14.4718 8.74441 14.474 8.73323 14.4761C8.72207 14.4781 8.71086 14.48 8.69964 14.4819C8.68841 14.4836 8.67716 14.4853 8.6659 14.4869C8.65464 14.4883 8.64335 14.4897 8.63206 14.491C8.62076 14.4922 8.60945 14.4934 8.59812 14.4943C8.58679 14.4952 8.57545 14.4962 8.56411 14.4969C8.55277 14.4976 8.54141 14.498 8.53006 14.4985C8.5187 14.4989 8.50733 14.4991 8.49597 14.4993C8.39918 14.4998 8.30243 14.4979 8.20574 14.4937C8.10905 14.4895 8.01252 14.4828 7.91614 14.4739C7.81977 14.465 7.72366 14.4536 7.62784 14.44C7.53202 14.4264 7.43658 14.4105 7.34153 14.3922C7.24648 14.3739 7.15193 14.3534 7.05789 14.3306C6.96383 14.3077 6.8704 14.2826 6.77757 14.2552C6.68475 14.2278 6.59264 14.1981 6.50125 14.1662C6.40986 14.1344 6.31931 14.1003 6.22958 14.064C6.13985 14.0277 6.05106 13.9893 5.9632 13.9487C5.87535 13.9081 5.78852 13.8653 5.70274 13.8205C5.61696 13.7757 5.53233 13.7288 5.44883 13.6798C5.36534 13.6309 5.28307 13.58 5.20205 13.527C5.12102 13.4741 5.04134 13.4192 4.96299 13.3624C4.88464 13.3055 4.80772 13.2468 4.73222 13.1863C4.65673 13.1257 4.58275 13.0633 4.51028 12.9992C4.43782 12.935 4.36696 12.8691 4.2977 12.8015C4.22844 12.7339 4.16087 12.6647 4.09498 12.5938C4.02909 12.5229 3.96497 12.4504 3.9026 12.3764C3.84023 12.3024 3.77971 12.2269 3.72102 12.1499C3.66232 12.073 3.60553 11.9946 3.55065 11.9149C3.49577 11.8352 3.44286 11.7542 3.39192 11.6719C3.34098 11.5896 3.29206 11.5061 3.24518 11.4214C3.1983 11.3367 3.15351 11.251 3.1108 11.1641C3.06809 11.0773 3.02752 10.9894 2.98908 10.9006C2.95065 10.8118 2.91439 10.7221 2.88032 10.6315C2.84625 10.5409 2.8144 10.4495 2.78477 10.3574C2.75514 10.2652 2.72777 10.1724 2.70266 10.0789C2.67755 9.98548 2.65472 9.89145 2.63418 9.79686C2.61364 9.70228 2.59541 9.60727 2.57949 9.51179C2.56358 9.41632 2.54999 9.32052 2.53873 9.22439C2.52747 9.12826 2.51856 9.03191 2.51199 8.93535C2.50542 8.83879 2.5012 8.74212 2.49933 8.64536L2.49933 8.35535C2.50028 8.30702 2.50182 8.25872 2.50395 8.21043C2.50607 8.16213 2.50878 8.11387 2.51208 8.06565C2.51538 8.01743 2.51926 7.96925 2.52372 7.92112C2.52819 7.873 2.53323 7.82493 2.53887 7.77691C2.5445 7.7289 2.55071 7.68097 2.5575 7.63312C2.5643 7.58527 2.57167 7.5375 2.57962 7.48982C2.58758 7.44213 2.59611 7.39457 2.60521 7.34709C2.61432 7.29962 2.624 7.25227 2.63426 7.20503C2.64451 7.15779 2.65534 7.11069 2.66674 7.06372C2.67814 7.01674 2.6901 6.96991 2.70264 6.92324C2.71517 6.87655 2.72827 6.83003 2.74194 6.78366C2.7556 6.7373 2.76982 6.6911 2.78461 6.64508C2.79939 6.59906 2.81473 6.55322 2.83063 6.50757C2.84652 6.46193 2.86297 6.41648 2.87997 6.37124C2.89697 6.32599 2.91451 6.28095 2.9326 6.23612C2.95069 6.1913 2.96933 6.14671 2.9885 6.10233C3.00767 6.05796 3.02738 6.01383 3.04762 5.96993C3.06787 5.92604 3.08864 5.8824 3.10994 5.83901C3.13125 5.79561 3.15307 5.75249 3.17542 5.70963C3.19777 5.66678 3.22063 5.62419 3.24402 5.58189C3.2674 5.53958 3.29129 5.49757 3.31569 5.45584C3.34009 5.41411 3.365 5.3727 3.3904 5.33157C3.41581 5.29045 3.44171 5.24964 3.4681 5.20915C3.4945 5.16866 3.52138 5.12849 3.54875 5.08864C3.57612 5.04881 3.60397 5.00931 3.6323 4.97013C3.66063 4.93097 3.68944 4.89216 3.7187 4.8537C3.74797 4.81522 3.7777 4.77711 3.8079 4.73937C3.8381 4.70162 3.86875 4.66425 3.89985 4.62725C3.93095 4.59026 3.9625 4.55364 3.99449 4.51739C4.02647 4.48116 4.0589 4.44531 4.09175 4.40986C4.12461 4.37441 4.1579 4.33937 4.19161 4.30473C4.22532 4.27008 4.25945 4.23585 4.29398 4.20204C4.32861 4.16816 4.36365 4.13472 4.3991 4.10169C4.43455 4.06868 4.47039 4.03609 4.50663 4.00395C4.54288 3.97179 4.5795 3.94008 4.61651 3.90882C4.65352 3.87757 4.6909 3.84676 4.72867 3.81642C4.76643 3.78607 4.80455 3.75619 4.84303 3.72676C4.88153 3.69734 4.92036 3.66839 4.95955 3.63992C4.99875 3.61144 5.03828 3.58345 5.07816 3.55594C5.11802 3.52842 5.15822 3.5014 5.19875 3.47487C5.23929 3.44833 5.28013 3.42229 5.3213 3.39675C5.36246 3.37121 5.40394 3.34617 5.44571 3.32164C5.48749 3.29711 5.52955 3.27309 5.57191 3.24958C5.61428 3.22607 5.65691 3.20308 5.69982 3.18061C5.74274 3.15814 5.78592 3.1362 5.82938 3.11478C5.87283 3.09336 5.91654 3.07247 5.9605 3.05212C6.00445 3.03176 6.04866 3.01194 6.09311 2.99266C6.13754 2.97338 6.18222 2.95464 6.22711 2.93645C6.272 2.91826 6.31712 2.90061 6.36245 2.88352C6.40778 2.86642 6.45331 2.84988 6.49904 2.8339C6.54477 2.81791 6.59068 2.80248 6.6368 2.78761C6.6829 2.77274 6.72918 2.75843 6.77564 2.74469C6.82209 2.73095 6.86871 2.71777 6.91548 2.70516C6.96225 2.69255 7.00917 2.68051 7.05625 2.66905C7.10331 2.65758 7.15051 2.64669 7.19784 2.63637C7.24518 2.62605 7.29264 2.61631 7.3402 2.60714C7.38777 2.59798 7.43544 2.5894 7.48322 2.58139C7.531 2.57339 7.57887 2.56597 7.62683 2.55913C7.6748 2.55229 7.72283 2.54604 7.77094 2.54037C7.81904 2.5347 7.86722 2.52961 7.91545 2.52512C7.96369 2.52062 8.01197 2.51671 8.06031 2.51339C8.10864 2.51007 8.157 2.50733 8.2054 2.50519C8.2538 2.50304 8.30221 2.50149 8.35064 2.50052C8.39907 2.49955 8.44752 2.49917 8.49597 2.49939C10.0933 2.49939 11.5959 3.05538 12.7259 4.06272C12.7597 4.09242 12.7931 4.12254 12.8262 4.15309C12.8592 4.18364 12.8919 4.21461 12.9241 4.24599C12.9564 4.27736 12.9882 4.30914 13.0196 4.34132C13.0511 4.3735 13.0821 4.40606 13.1128 4.43903C13.1434 4.47199 13.1736 4.50534 13.2034 4.53907C13.2331 4.5728 13.2625 4.6069 13.2914 4.64136C13.3203 4.67583 13.3488 4.71064 13.3769 4.74584C13.4049 4.78103 13.4325 4.81656 13.4596 4.85245C13.4868 4.88834 13.5135 4.92456 13.5397 4.96111C13.5659 4.99767 13.5917 5.03455 13.617 5.07176C13.6423 5.10896 13.6671 5.14649 13.6915 5.18433C13.7158 5.22217 13.7397 5.2603 13.7631 5.29874C13.7865 5.33719 13.8094 5.37592 13.8318 5.41493C13.8542 5.45394 13.8761 5.49323 13.8975 5.53281C13.9189 5.57238 13.9398 5.61222 13.9602 5.65232C13.9806 5.69242 14.0005 5.73277 14.0199 5.77337C14.0396 5.81426 14.0586 5.85543 14.0771 5.89685C14.0956 5.93828 14.1135 5.97996 14.1308 6.02189C14.1481 6.06382 14.1648 6.10598 14.181 6.14838C14.1971 6.19077 14.2127 6.23339 14.2277 6.27622C14.2426 6.31906 14.2569 6.36209 14.2707 6.40532C14.2844 6.44855 14.2975 6.49197 14.3101 6.53556C14.3225 6.57916 14.3344 6.62293 14.3458 6.66687C14.3571 6.7108 14.3678 6.75488 14.3779 6.79911C14.3879 6.84334 14.3973 6.88771 14.4062 6.9322C14.415 6.9767 14.4232 7.0213 14.4309 7.06603C14.4384 7.11076 14.4454 7.15559 14.4517 7.2005C14.4581 7.24542 14.4637 7.29042 14.4689 7.3355C14.4738 7.38059 14.4782 7.42573 14.4821 7.47093C14.4859 7.51613 14.489 7.56137 14.4916 7.60666C14.4942 7.65196 14.496 7.69729 14.4973 7.74263C14.4986 7.78796 14.4993 7.83333 14.4993 7.87869C14.4993 8.83935 14.1326 9.73402 13.4686 10.3973ZM12.0973 4.76737C11.1406 3.91471 9.86129 3.44471 8.49597 3.44471C8.41445 3.44427 8.33298 3.4458 8.25155 3.44931C8.17011 3.45283 8.08881 3.45832 8.00763 3.46579C7.92647 3.47326 7.84553 3.4827 7.76482 3.49411C7.68411 3.50551 7.60372 3.51888 7.52367 3.5342C7.44361 3.54951 7.36397 3.56677 7.28475 3.58596C7.20553 3.60515 7.12683 3.62626 7.04863 3.64928C6.97044 3.67231 6.89285 3.69721 6.81587 3.72401C6.73889 3.75081 6.6626 3.77946 6.58702 3.80997C6.51143 3.84047 6.43663 3.87279 6.36261 3.90694C6.2886 3.94109 6.21546 3.97702 6.14319 4.01472C6.07092 4.05241 5.99961 4.09186 5.92927 4.13303C5.85892 4.1742 5.78961 4.21706 5.72135 4.26161C5.65309 4.30615 5.58594 4.35232 5.51993 4.40013C5.45392 4.44795 5.3891 4.49733 5.32548 4.54829C5.26186 4.59926 5.19953 4.65175 5.13846 4.70573C5.07741 4.75973 5.0177 4.81519 4.95933 4.87208C4.90096 4.92898 4.84402 4.98727 4.78849 5.04694C4.73296 5.10661 4.67891 5.16759 4.62635 5.2299C4.57379 5.2922 4.52277 5.35574 4.47331 5.42052C4.42384 5.48531 4.37597 5.55125 4.3297 5.61837C4.28345 5.68548 4.23885 5.75367 4.1959 5.82295C4.15295 5.89223 4.11171 5.96252 4.07218 6.03381C4.03266 6.10509 3.99489 6.17729 3.95888 6.25042C3.92286 6.32354 3.88866 6.3975 3.85623 6.47229C3.82382 6.54708 3.79324 6.62261 3.7645 6.69888C3.73576 6.77516 3.70889 6.85209 3.6839 6.92968C3.65889 7.00726 3.6358 7.0854 3.6146 7.16412C3.5934 7.24282 3.57413 7.32199 3.55679 7.40164C3.53944 7.48129 3.52404 7.5613 3.51059 7.6417C3.49714 7.72209 3.48565 7.80277 3.47612 7.88372C3.46659 7.96467 3.45904 8.04581 3.45346 8.12713C3.44788 8.20845 3.44428 8.28986 3.44266 8.37135L3.44266 8.62868C3.44428 8.71018 3.44788 8.79159 3.45346 8.87291C3.45904 8.95423 3.46659 9.03537 3.47612 9.11632C3.48565 9.19727 3.49714 9.27795 3.51059 9.35834C3.52404 9.43873 3.53944 9.51874 3.55679 9.59839C3.57413 9.67804 3.5934 9.75721 3.6146 9.83592C3.6358 9.91463 3.65889 9.99277 3.6839 10.0704C3.70889 10.1479 3.73576 10.2249 3.7645 10.3011C3.79324 10.3774 3.82382 10.453 3.85623 10.5278C3.88866 10.6025 3.92286 10.6765 3.95888 10.7496C3.99489 10.8227 4.03266 10.8949 4.07218 10.9662C4.11171 11.0375 4.15295 11.1078 4.1959 11.1771C4.23884 11.2464 4.28344 11.3146 4.3297 11.3817C4.37597 11.4488 4.42384 11.5147 4.47331 11.5795C4.52277 11.6443 4.57379 11.7078 4.62635 11.7701C4.67891 11.8324 4.73296 11.8934 4.78849 11.9531C4.84402 12.0128 4.90096 12.0711 4.95933 12.128C5.0177 12.1849 5.07741 12.2403 5.13846 12.2943C5.19953 12.3483 5.26186 12.4008 5.32548 12.4517C5.3891 12.5027 5.45392 12.5521 5.51993 12.5999C5.58594 12.6477 5.65309 12.6939 5.72135 12.7384C5.78961 12.783 5.85892 12.8258 5.92927 12.867C5.99961 12.9082 6.07092 12.9476 6.14319 12.9853C6.21546 13.023 6.2886 13.059 6.36261 13.0931C6.43663 13.1272 6.51143 13.1596 6.58702 13.1901C6.6626 13.2206 6.73889 13.2492 6.81587 13.276C6.89285 13.3028 6.97043 13.3277 7.04863 13.3507C7.12683 13.3738 7.20553 13.3949 7.28475 13.4141C7.36397 13.4333 7.44361 13.4505 7.52367 13.4658C7.60372 13.4812 7.68411 13.4945 7.76482 13.5059C7.84553 13.5173 7.92647 13.5268 8.00763 13.5342C8.08881 13.5417 8.17011 13.5472 8.25155 13.5507C8.33298 13.5542 8.41445 13.5558 8.49597 13.5553C8.72796 13.5553 8.94729 13.3367 8.94729 13.1047C8.94729 12.9567 8.91996 12.9033 8.84196 12.8253L8.80863 12.7913L8.77929 12.746C8.64263 12.542 8.4553 12.2613 8.4553 11.8773C8.4553 11.5187 8.60596 11.1613 8.87062 10.8967C8.87863 10.8886 8.88674 10.8806 8.89494 10.8728C8.90314 10.8649 8.91144 10.8571 8.91983 10.8494C8.92823 10.8418 8.93672 10.8342 8.94529 10.8267C8.95386 10.8193 8.96254 10.8119 8.97129 10.8047C8.98004 10.7974 8.98888 10.7903 8.99781 10.7832C9.00674 10.7762 9.01575 10.7692 9.02484 10.7624C9.03395 10.7556 9.04313 10.7489 9.05238 10.7423C9.06164 10.7357 9.07098 10.7292 9.08039 10.7229C9.08981 10.7165 9.0993 10.7102 9.10888 10.7041C9.11845 10.698 9.12809 10.6919 9.1378 10.686C9.14752 10.6801 9.15731 10.6743 9.16717 10.6687C9.17702 10.663 9.18694 10.6575 9.19693 10.652C9.20693 10.6466 9.21698 10.6413 9.2271 10.6361C9.23722 10.6309 9.24741 10.6259 9.25765 10.6209C9.26789 10.616 9.27819 10.6112 9.28855 10.6065C9.29891 10.6018 9.30933 10.5973 9.31979 10.5928C9.33026 10.5884 9.34078 10.5841 9.35136 10.5799C9.36195 10.5758 9.37256 10.5717 9.38324 10.5678C9.39391 10.5639 9.40462 10.5601 9.41539 10.5564C9.42616 10.5528 9.43697 10.5493 9.44782 10.5459C9.45867 10.5425 9.46956 10.5392 9.48049 10.5361C9.49143 10.533 9.50239 10.53 9.5134 10.5271C9.5244 10.5242 9.53543 10.5215 9.5465 10.5189C9.55758 10.5163 9.56868 10.5139 9.57981 10.5115C9.59093 10.5092 9.60209 10.507 9.61328 10.505C9.62446 10.5029 9.63566 10.501 9.64689 10.4992C9.65812 10.4974 9.66937 10.4958 9.68064 10.4943C9.6919 10.4928 9.70318 10.4914 9.71449 10.4902C9.7258 10.489 9.73711 10.4879 9.74844 10.4869C9.75977 10.4859 9.77111 10.4851 9.78246 10.4844C9.7938 10.4838 9.80516 10.4832 9.81653 10.4828C9.82788 10.4824 9.83925 10.4821 9.85062 10.482L10.9553 10.482C12.4146 10.482 13.5559 9.33935 13.5559 7.88068C13.5533 6.70869 13.0346 5.60404 12.0973 4.76737ZM11.9273 8.90535C11.4693 8.90535 11.0666 8.50401 11.0666 8.04402C11.0666 7.58603 11.4679 7.18336 11.9273 7.18336C12.3866 7.18336 12.7893 7.58603 12.7879 8.04402C12.7879 8.50268 12.3866 8.90535 11.9273 8.90535ZM10.2099 6.6107C9.75196 6.6107 9.34929 6.2087 9.34929 5.74937C9.34929 5.29137 9.75062 4.8887 10.2099 4.8887C10.6693 4.8887 11.0719 5.29137 11.0706 5.74937C11.0666 6.21336 10.6693 6.6107 10.2099 6.6107ZM6.80597 6.42336C6.79527 6.41448 6.78478 6.40534 6.77453 6.39595C6.76427 6.38657 6.75424 6.37693 6.74445 6.36705C6.73465 6.35718 6.7251 6.34707 6.71579 6.33673C6.70649 6.32639 6.69744 6.31583 6.68865 6.30506C6.67985 6.29428 6.67133 6.2833 6.66307 6.27211C6.65481 6.26092 6.64683 6.24953 6.63912 6.23796C6.63141 6.22638 6.62398 6.21463 6.61684 6.20269C6.6097 6.19075 6.60286 6.17865 6.59631 6.16638C6.58976 6.15411 6.5835 6.14169 6.57755 6.12912C6.57159 6.11654 6.56595 6.10384 6.56061 6.091C6.55528 6.07815 6.55025 6.06518 6.54554 6.05209C6.54084 6.039 6.53645 6.02582 6.53238 6.01252C6.52832 5.99922 6.52457 5.98582 6.52114 5.97234C6.51773 5.95886 6.51464 5.9453 6.51188 5.93167C6.50911 5.91804 6.50668 5.90434 6.50459 5.89059C6.50249 5.87685 6.50072 5.86306 6.49928 5.84922C6.49785 5.83538 6.49676 5.82152 6.496 5.80764C6.49523 5.79375 6.49481 5.77985 6.49472 5.76594C6.49464 5.75203 6.49488 5.73812 6.49547 5.72423C6.49605 5.71034 6.49698 5.69646 6.49825 5.68261C6.4995 5.66876 6.50109 5.65494 6.50302 5.64117C6.50495 5.6274 6.50721 5.61368 6.5098 5.6C6.51239 5.58634 6.51532 5.57275 6.51857 5.55922C6.52181 5.5457 6.5254 5.53226 6.5293 5.51891C6.5332 5.50556 6.53742 5.49232 6.54197 5.47917C6.5465 5.46602 6.55137 5.45299 6.55655 5.44009C6.56172 5.42718 6.5672 5.4144 6.573 5.40176C6.57879 5.38911 6.58488 5.37661 6.59128 5.36426C6.59769 5.35192 6.60438 5.33973 6.61137 5.3277C6.61836 5.31567 6.62564 5.30382 6.6332 5.29215C6.64076 5.28048 6.64861 5.269 6.65673 5.25771C6.66485 5.24641 6.67323 5.23533 6.68189 5.22444C6.69055 5.21355 6.69947 5.20288 6.70864 5.19243C6.71782 5.18197 6.72724 5.17174 6.73691 5.16175C6.74658 5.15175 6.75648 5.142 6.76663 5.13247C6.77677 5.12296 6.78714 5.11369 6.79772 5.10468C6.80831 5.09566 6.81912 5.08691 6.83013 5.07841C6.84115 5.06992 6.85236 5.0617 6.86378 5.05375C6.87519 5.0458 6.88679 5.03814 6.89857 5.03074C6.91036 5.02336 6.92231 5.01626 6.93444 5.00945C6.94657 5.00264 6.95886 4.99614 6.97131 4.98993C6.98375 4.9837 6.99634 4.9778 7.00907 4.9722C7.0218 4.96659 7.03466 4.96131 7.04764 4.95633C7.06063 4.95135 7.07373 4.94668 7.08695 4.94234C7.10016 4.93799 7.11347 4.93397 7.12688 4.93027C7.14028 4.92657 7.15377 4.9232 7.16734 4.92015C7.18091 4.91709 7.19455 4.91438 7.20825 4.912C7.22195 4.90962 7.23571 4.90755 7.24951 4.90583C7.26332 4.90411 7.27716 4.90273 7.29102 4.90168C7.30488 4.90063 7.31877 4.89991 7.33268 4.89954C7.34658 4.89916 7.36048 4.89913 7.37439 4.89942C7.3883 4.89972 7.40218 4.90035 7.41606 4.90132C7.42993 4.90229 7.44377 4.90359 7.45759 4.90523C7.47141 4.90688 7.48516 4.90884 7.49889 4.91115C7.51261 4.91346 7.52626 4.9161 7.53984 4.91906C7.55343 4.92203 7.56694 4.92533 7.58037 4.92895C7.5938 4.93257 7.60713 4.93652 7.62038 4.94079C7.63361 4.94506 7.64673 4.94964 7.65975 4.95455C7.67277 4.95946 7.68566 4.96467 7.69842 4.97019C7.71118 4.97572 7.7238 4.98156 7.73629 4.9877C7.74877 4.99384 7.76108 5.00027 7.77326 5.00701C7.78542 5.01375 7.79742 5.02078 7.80925 5.02811C7.82107 5.03542 7.83272 5.04301 7.84418 5.0509C7.85564 5.05879 7.8669 5.06694 7.87796 5.07537L7.87863 5.07604C7.88966 5.08481 7.90045 5.09385 7.91104 5.10315C7.92162 5.11245 7.93195 5.12201 7.94207 5.13182C7.95217 5.14163 7.96202 5.15168 7.97164 5.16198C7.98127 5.17227 7.99062 5.18279 7.99971 5.19355C8.00882 5.20431 8.01764 5.21528 8.0262 5.22647C8.03475 5.23766 8.04302 5.24905 8.05103 5.26064C8.05903 5.27223 8.06674 5.28402 8.07416 5.296C8.08158 5.30797 8.08869 5.32013 8.09551 5.33244C8.10234 5.34477 8.10886 5.35725 8.11506 5.36989C8.12127 5.38254 8.12716 5.39534 8.13274 5.40826C8.13833 5.4212 8.14359 5.43427 8.14853 5.44746C8.15346 5.46064 8.15808 5.47396 8.16236 5.48738C8.16663 5.50079 8.17059 5.51431 8.17422 5.52792C8.17784 5.54153 8.18112 5.55523 8.18406 5.56901C8.18701 5.58278 8.18962 5.59662 8.19189 5.61052C8.19415 5.62443 8.19608 5.63837 8.19766 5.65236C8.19925 5.66637 8.20048 5.6804 8.20137 5.69445C8.20227 5.70851 8.20281 5.72258 8.20301 5.73667C8.20321 5.75075 8.20307 5.76484 8.20257 5.77891C8.20208 5.79299 8.20125 5.80705 8.20007 5.82108C8.19888 5.83512 8.19736 5.84912 8.1955 5.86308C8.19362 5.87704 8.19141 5.89095 8.18886 5.9048C8.18631 5.91866 8.18341 5.93244 8.18018 5.94615C8.17696 5.95986 8.1734 5.97348 8.16949 5.98702C8.16559 6.00055 8.16136 6.01399 8.1568 6.02732C8.15224 6.04064 8.14736 6.05385 8.14215 6.06694C8.13694 6.08003 8.13142 6.09298 8.12557 6.1058C8.11972 6.11861 8.11357 6.13127 8.1071 6.14379C8.10063 6.15631 8.09386 6.16866 8.08678 6.18083C8.07971 6.19301 8.07234 6.20501 8.06468 6.21683C8.05702 6.22866 8.04907 6.24028 8.04083 6.25171C8.03259 6.26313 8.02409 6.27436 8.0153 6.28536C8.00654 6.29639 7.99752 6.30721 7.98823 6.3178C7.97893 6.32839 7.96938 6.33875 7.95959 6.34887C7.94978 6.35899 7.93973 6.36887 7.92946 6.37849C7.91917 6.38811 7.90866 6.39749 7.89791 6.40661C7.88716 6.41571 7.8762 6.42456 7.86502 6.43313C7.85384 6.44169 7.84246 6.44999 7.83087 6.458C7.81928 6.46602 7.8075 6.47374 7.79554 6.48117C7.78357 6.48861 7.77142 6.49575 7.7591 6.50258C7.74679 6.50941 7.73432 6.51595 7.72167 6.52218C7.70903 6.5284 7.69624 6.53432 7.68332 6.53991C7.67039 6.5455 7.65732 6.55077 7.64414 6.55573C7.63096 6.56068 7.61764 6.56531 7.60423 6.56961C7.59081 6.57391 7.5773 6.57788 7.56369 6.58152C7.55009 6.58515 7.53639 6.58845 7.52262 6.59141C7.50884 6.59438 7.495 6.597 7.4811 6.59929C7.4672 6.60157 7.45325 6.6035 7.43925 6.6051C7.42525 6.6067 7.41122 6.60796 7.39717 6.60886C7.38311 6.60976 7.36903 6.61032 7.35495 6.61055C7.34086 6.61077 7.32677 6.61064 7.31269 6.61016C7.29861 6.60968 7.28455 6.60886 7.27051 6.60769C7.25647 6.60653 7.24247 6.60502 7.2285 6.60315C7.21453 6.6013 7.20062 6.59911 7.18677 6.59657C7.17291 6.59402 7.15913 6.59115 7.1454 6.58793C7.13168 6.58472 7.11805 6.58117 7.10452 6.57728C7.09098 6.5734 7.07754 6.56918 7.0642 6.56463C7.05087 6.56009 7.03765 6.55521 7.02456 6.55002C7.01147 6.54483 6.99851 6.53931 6.98568 6.53347C6.97286 6.52764 6.96019 6.5215 6.94766 6.51504C6.93513 6.50858 6.92278 6.50182 6.91059 6.49475C6.89839 6.48769 6.88638 6.48034 6.87456 6.47269C6.86273 6.46504 6.8511 6.45709 6.83966 6.44886C6.82822 6.44064 6.817 6.43214 6.80597 6.42336ZM5.62532 8.90535C5.16731 8.90535 4.76464 8.50401 4.76464 8.04402C4.76464 7.58603 5.16532 7.18336 5.62532 7.18336C6.08331 7.18336 6.48598 7.58603 6.48598 8.04402C6.48598 8.50268 6.08464 8.90535 5.62532 8.90535Z"   fill="#E4495B" ></path></g><defs><clipPath id="clip-path-uDmpTaYBd-GAbvmU4kRSm"><path d="M2.5 14.5L14.5 14.5L14.5 2.5L2.5 2.5L2.5 14.5Z" fill="white"/></clipPath></defs></svg>',
16
+ image2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAGtSURBVFiF7ZbhUcJAEIU/Gf8TKjB2oB3ECtQKCBUoFYgVgBUQKlArgA7ECggVECvQH7vHHeEmCXCMM8qbyVwme7l9t/t27+CE/44zz7cYSIGLwL7mwDuQV026A1bA95GelfpYw41ABCx0zIDZHruswhXwiETgGijKExJlOQ3s2MVUfSTmQ8sxmpznRyRg1l7rq+Wft4EhkrsVMAjN6LzGPkDyZvAEtIF+KAJ1EXjQ8VIfkBINhiYpOCrqUpAhKVg4315q/kl0jJDmU+ApuaYE+sAXNhUZfiGmQNdxXsYMIR5VOesiNTquIeUiRqJT7nZT4FVtvs7aNQscooFUHcRIffcQoXaAG+AeK94USUcldolAit3NYAfSphOuI+DTQIwcGG3gE9ldUbIP9f15RwJ5ldFEwHeCDdUx2F3sc2aMaaCBHFHtm75H2FIcY5Xe24PAFnwEZmyKqAOM1JbqmBHo0GpSBQXSD3pYLUxCOIf6RuQiQ0opJuBlxSWw1DGumD+nQT1XwKxtfG1dyT500uhARz4kiIYKRFve8+FXL6UGMXCLXCJDYknA6jnh7+AHjaWWLLCZ8v4AAAAASUVORK5CYII=',
14
17
  italic2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAACtSURBVFiF7ZZhCoMwDIXj2L2Wmy03MzuZ+9NqkBVtXkoY9INSQZv3fDRaosnkz1iJaHMMbhV8DLV7g2fn858yzrzLrI372qnTBdMRtYwUaiHGQDcRe+AVUAMCih9NwIpqhgGLywAKvPuRBBhYG4IQ0H4VJIHafpplgMv869M73ICYa80wYIEMeAn7+XgSYFQURSig/SrLDbEzV4eP1jqXAe9bXtXdST8TTibpfAEImy7CCzNLkwAAAABJRU5ErkJggg==',
15
18
  link2x: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAEGSURBVFiF7VdbDsMgDPOk3Wu52dKTtT3Z9jGYsoiCA1T7qSWEqhLbJDxa4MKfcZvIJQCe5nlPvU7UKEIBvBrtFBMl4dU1/17OEtcKuR87bMLPjCGcaiKTrUEiwW+phqCdcTZ7IbFeQQ9BsAyK+FbSxliaz6aLrbcSApQBL86A3R1NA8q6TBDEDFe5e8QjR67lj7urkLEx9OzlBHFbpqYBlogxK4y4JT5aRJ6I2R2CQKYYA9PXyJ0gytgALIY8goWJUXRcFASnsIMFsRSX4oevWbvIJBCnGDP/hSC2yr34sIEIoaDv86zLRM5IbqV308Qz5EBsqjD7Z6Spf6R+x+dc2EbELwDAGwAuxWOeKuGGAAAAAElFTkSuQmCC',
16
19
  menu2: 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyB3aWR0aD0iMWVtIiBoZWlnaHQ9IjFlbSIgdmlld0JveD0iMCAwIDI1NiAyNTYiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgY2xhc3M9Imxhcmt1aS1pY29uIGxhcmt1aS1pY29uLWRyYWciIHN0eWxlPSJ3aWR0aDogMTZweDsgaGVpZ2h0OiAxNnB4OyI+PHBhdGggZD0iTTg4IDE4N2M5Ljk0MSAwIDE4IDguMDU5IDE4IDE4cy04LjA1OSAxOC0xOCAxOC0xOC04LjA1OS0xOC0xOCA4LjA1OS0xOCAxOC0xOFptODAgMGM5Ljk0MSAwIDE4IDguMDU5IDE4IDE4cy04LjA1OSAxOC0xOCAxOC0xOC04LjA1OS0xOC0xOCA4LjA1OS0xOCAxOC0xOFptLTgwLTc2YzkuOTQxIDAgMTggOC4wNTkgMTggMThzLTguMDU5IDE4LTE4IDE4LTE4LTguMDU5LTE4LTE4IDguMDU5LTE4IDE4LTE4Wm04MCAwYzkuOTQxIDAgMTggOC4wNTkgMTggMThzLTguMDU5IDE4LTE4IDE4LTE4LTguMDU5LTE4LTE4IDguMDU5LTE4IDE4LTE4Wk04OCAzNWM5Ljk0MSAwIDE4IDguMDU5IDE4IDE4cy04LjA1OSAxOC0xOCAxOC0xOC04LjA1OS0xOC0xOCA4LjA1OS0xOCAxOC0xOFptODAgMGM5Ljk0MSAwIDE4IDguMDU5IDE4IDE4cy04LjA1OSAxOC0xOCAxOC0xOC04LjA1OS0xOC0xOCA4LjA1OS0xOCAxOC0xOFoiIGZpbGw9ImN1cnJlbnRDb2xvciIgZmlsbC1ydWxlPSJub256ZXJvIj48L3BhdGg+PC9zdmc+',
package/src/index.ts CHANGED
@@ -1,5 +1,6 @@
1
- import {ComponentFactory, EditorBody, EditorComponent, EditorContent, EditorParagraph, EditorParagraphMenu, EditorToolbar} from "./componets";
1
+ import {ComponentFactory, EditorBody, EditorComponent, EditorToolbar, EditorFunction} from "./componets";
2
2
  import { SelectionUtils } from "./utils";
3
+ import {images} from "./images";
3
4
 
4
5
  export type YangEditorMode = "edit" | "readonly";
5
6
 
@@ -8,6 +9,14 @@ export interface YangEditorColor {
8
9
  name: string;
9
10
  }
10
11
 
12
+ export interface YangEditorMenuItem {
13
+ name: string;
14
+ icon: string;
15
+ className?: string;
16
+ callback?: EditorFunction;
17
+ args?: any
18
+ }
19
+
11
20
  export interface YangEditorOptions {
12
21
  elem: string;
13
22
  width: string;
@@ -16,6 +25,7 @@ export interface YangEditorOptions {
16
25
  events: {
17
26
  onContentChange?: (html: string) => void,
18
27
  },
28
+ menus?: YangEditorMenuItem[],
19
29
  components?: {
20
30
  foreColorStrip?: {
21
31
  colors?: YangEditorColor[]
@@ -29,6 +39,20 @@ export interface YangEditorOptions {
29
39
  }
30
40
  }
31
41
 
42
+ const defaultOptions : YangEditorOptions = {
43
+ menus: [
44
+ { name: "折叠面板", icon: images.collapse2x, className: 'gray', callback: "insertCollapse", args: {className: "gray"} },
45
+ { name: "图片", icon: images.image2x, args: null },
46
+ { name: "代码块", icon: images.code2x, args: null },
47
+ ],
48
+ components: {},
49
+ elem: "yang-editor",
50
+ events: {},
51
+ width: "100%",
52
+ height: "auto",
53
+ mode: 'edit'
54
+ }
55
+
32
56
  export class YangEditor {
33
57
 
34
58
  public readonly element: HTMLElement;
@@ -36,10 +60,13 @@ export class YangEditor {
36
60
  public readonly body: EditorBody;
37
61
  public readonly selectionUtils: SelectionUtils;
38
62
  public readonly componentFactory: ComponentFactory;
63
+ public readonly options: YangEditorOptions;
39
64
 
40
65
  private components: Array<EditorComponent> = new Array<EditorComponent>();
41
66
 
42
- constructor(public options: YangEditorOptions) {
67
+ constructor(options: YangEditorOptions) {
68
+ this.options = {...defaultOptions, ...options};
69
+
43
70
  let element = document.getElementById(options.elem);
44
71
  if(element === null ) {
45
72
  throw new Error(`Invalid Yang Editor option "${options.elem}"`);
package/src/style.css CHANGED
@@ -73,8 +73,24 @@
73
73
  background-size: contain;
74
74
  background-repeat: no-repeat;
75
75
  cursor: pointer;
76
+ position: relative;
77
+ }
78
+
79
+ .yang-editor-button-add .yang-editor-button-add-bridge {
80
+ width: 128px;
81
+ height: 40px;
82
+ position: absolute;
83
+ top: -4px;
84
+ left: -4px;
85
+ display: none;
86
+ }
87
+
88
+ .yang-editor .yang-editor-button-add:hover .yang-editor-button-add-bridge {
89
+ display: block;
90
+ z-index: 1;
76
91
  }
77
92
 
93
+
78
94
  .yang-editor .yang-editor-color-strip {
79
95
  padding-left: 19px;
80
96
  display: flex;
@@ -289,3 +305,54 @@
289
305
  border-radius: 6px;
290
306
  }
291
307
 
308
+ .yang-editor .yang-editor-button-add:hover .yang-editor-component-menu {
309
+ display: block;
310
+ }
311
+
312
+ .yang-editor .yang-editor-component-menu {
313
+ width: 180px;
314
+ padding: 4px 8px;
315
+ opacity: 1;
316
+ background: rgba(255, 255, 255, 1);
317
+ border: 1px solid rgba(217, 217, 217, 1);
318
+ box-shadow: 1px 1px 5px rgba(217, 217, 217, 0.3);
319
+ border-radius: 6px;
320
+ position: absolute;
321
+ left: 0;
322
+ top: 31px;
323
+ display: none;
324
+ z-index: 1;
325
+ }
326
+
327
+ .yang-editor .yang-editor-component-menu-item {
328
+ border-radius: 6px;
329
+ cursor: pointer;
330
+ padding: 8px;
331
+ display: flex;
332
+ align-items: center;
333
+ }
334
+
335
+ .yang-editor .yang-editor-component-menu-item:hover {
336
+ background: rgba(239, 240, 240, 1);
337
+ }
338
+
339
+ .yang-editor .yang-editor-component-menu-item-icon {
340
+ flex-shrink: 0;
341
+ background: transparent;
342
+ margin-right: 8px;
343
+ background-size: 16px 16px;
344
+ background-repeat: no-repeat;
345
+ background-position: center;
346
+ width: 20px;
347
+ height: 20px;
348
+ cursor: pointer;
349
+ border: none;
350
+ outline: none;
351
+
352
+ }
353
+
354
+ .yang-editor .yang-editor-component-menu-item-text {
355
+ flex-shrink: 1;
356
+ flex-grow: 1;
357
+ text-align: left;
358
+ }
package/src/utils.ts CHANGED
@@ -2,7 +2,7 @@ import { ComponentFactory } from "./componets";
2
2
 
3
3
  export class SelectionUtils {
4
4
 
5
- private element: HTMLElement;
5
+ private readonly element: HTMLElement;
6
6
 
7
7
  constructor(element: HTMLElement) {
8
8
  this.element = element;
@@ -35,4 +35,98 @@ export class SelectionUtils {
35
35
  }
36
36
  return null;
37
37
  }
38
+ }
39
+
40
+ /**
41
+ * utils for format cleaning
42
+ */
43
+ export class FormatCleaner {
44
+
45
+ private static unwantedTags = ['style', 'script', 'link', 'meta', 'head', 'title', 'xml'];
46
+
47
+ /**
48
+ * clean HTML string and return plain text
49
+ * @param htmlString html string
50
+ * @returns plain text
51
+ */
52
+ static cleanHTMLString(htmlString: string): string {
53
+ // remove Word XML namespace labels
54
+ htmlString = htmlString.replace(/<\/?[ovwm]:[^>]*>/gi, '');
55
+
56
+ // remove Word conditional comments
57
+ htmlString = htmlString.replace(/<!--\[if[\s\S]*?<!\[endif\]-->/gi, '');
58
+ htmlString = htmlString.replace(/<!--[\s\S]*?-->/g, '');
59
+
60
+ const tempDiv = document.createElement('div');
61
+ tempDiv.innerHTML = htmlString;
62
+
63
+ // remove all <style> tags (including @page, @font-face rules)
64
+ const styleTags = tempDiv.querySelectorAll('style');
65
+ styleTags.forEach(style => style.remove());
66
+
67
+ // remove other unwanted tags
68
+ FormatCleaner.unwantedTags.forEach(tag => {
69
+ const elements = tempDiv.querySelectorAll(tag);
70
+ elements.forEach(el => el.remove());
71
+ });
72
+
73
+ return this.extractPlainText(tempDiv);
74
+ }
75
+
76
+ /**
77
+ * extract plain text from node, remove all HTML tags and styles
78
+ * @param node DOM node
79
+ * @returns plain text content
80
+ */
81
+ static extractPlainText(node: Node): string {
82
+ if (node.nodeType === Node.TEXT_NODE) {
83
+ return node.textContent || '';
84
+ } else if (node.nodeType === Node.ELEMENT_NODE) {
85
+ const element = node as HTMLElement;
86
+ const tagName = element.tagName.toLowerCase();
87
+ if (FormatCleaner.unwantedTags.includes(tagName)) {
88
+ return '';
89
+ }
90
+ if (tagName === 'br') {
91
+ return '\n';
92
+ }
93
+ // block elements(p、div etc.)
94
+ const isBlock = ['p', 'div', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6',
95
+ 'li', 'tr', 'td', 'th', 'blockquote', 'pre'].includes(tagName);
96
+ let result = '';
97
+ for (let child of Array.from(element.childNodes)) {
98
+ result += this.extractPlainText(child);
99
+ }
100
+ if (isBlock && result.trim()) {
101
+ result += '\n';
102
+ }
103
+ return result;
104
+ }
105
+ return '';
106
+ }
107
+
108
+ /**
109
+ * remove all styles and other properties
110
+ * @param element HTML element
111
+ */
112
+ static removeAllStyles(element: HTMLElement): void {
113
+ // remove style attribute
114
+ element.removeAttribute('style');
115
+
116
+ // remove common format attributes
117
+ const formatAttributes = ['class', 'align', 'valign', 'bgcolor', 'color',
118
+ 'face', 'size', 'width', 'height', 'border',
119
+ 'cellpadding', 'cellspacing', 'dir'];
120
+
121
+ formatAttributes.forEach(attr => {
122
+ if (element.hasAttribute(attr)) {
123
+ element.removeAttribute(attr);
124
+ }
125
+ });
126
+
127
+ // recursively process child elements
128
+ for (let child of Array.from(element.children)) {
129
+ this.removeAllStyles(child as HTMLElement);
130
+ }
131
+ }
38
132
  }