@plait/common 0.57.0 → 0.59.0
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/core/element-flavour.d.ts +13 -0
- package/core/group.component.d.ts +8 -11
- package/esm2022/core/element-flavour.mjs +33 -0
- package/esm2022/core/group.component.mjs +13 -27
- package/esm2022/plugins/with-resize.mjs +3 -2
- package/esm2022/public-api.mjs +2 -2
- package/esm2022/transforms/text.mjs +40 -34
- package/esm2022/types/resize.mjs +1 -1
- package/esm2022/utils/image.mjs +1 -1
- package/esm2022/utils/resize.mjs +1 -1
- package/esm2022/utils/text.mjs +35 -6
- package/fesm2022/plait-common.mjs +88 -69
- package/fesm2022/plait-common.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/with-resize.d.ts +2 -2
- package/public-api.d.ts +1 -1
- package/types/resize.d.ts +11 -7
- package/utils/resize.d.ts +3 -3
- package/utils/text.d.ts +3 -1
- package/core/plugin-element.d.ts +0 -16
- package/esm2022/core/plugin-element.mjs +0 -40
package/esm2022/utils/text.mjs
CHANGED
|
@@ -11,13 +11,13 @@ export const getFirstTextManage = (element) => {
|
|
|
11
11
|
}
|
|
12
12
|
return textManage;
|
|
13
13
|
};
|
|
14
|
-
export const
|
|
14
|
+
export const getTextEditorsByElement = (element) => {
|
|
15
15
|
return getTextManages(element).map(manage => {
|
|
16
16
|
return manage.componentRef.instance.editor;
|
|
17
17
|
});
|
|
18
18
|
};
|
|
19
19
|
export const getFirstTextEditor = (element) => {
|
|
20
|
-
const textEditor =
|
|
20
|
+
const textEditor = getTextEditorsByElement(element)[0];
|
|
21
21
|
if (!textEditor) {
|
|
22
22
|
console.warn('can not find textManage');
|
|
23
23
|
}
|
|
@@ -27,7 +27,7 @@ export const findFirstTextEditor = (board) => {
|
|
|
27
27
|
const selectedElements = getSelectedElements(board);
|
|
28
28
|
let firstEditor = null;
|
|
29
29
|
selectedElements.forEach(element => {
|
|
30
|
-
const editors =
|
|
30
|
+
const editors = getTextEditorsByElement(element);
|
|
31
31
|
if (!firstEditor && editors && editors.length > 0) {
|
|
32
32
|
firstEditor = editors[0];
|
|
33
33
|
}
|
|
@@ -35,7 +35,7 @@ export const findFirstTextEditor = (board) => {
|
|
|
35
35
|
return firstEditor;
|
|
36
36
|
};
|
|
37
37
|
export const getTextMarksByElement = (element) => {
|
|
38
|
-
const editors =
|
|
38
|
+
const editors = getTextEditorsByElement(element);
|
|
39
39
|
const editor = editors[0];
|
|
40
40
|
if (!editor) {
|
|
41
41
|
return {};
|
|
@@ -52,7 +52,7 @@ export const getElementsText = (elements) => {
|
|
|
52
52
|
return elements
|
|
53
53
|
.map(item => {
|
|
54
54
|
try {
|
|
55
|
-
const editors =
|
|
55
|
+
const editors = getTextEditorsByElement(item);
|
|
56
56
|
if (editors.length) {
|
|
57
57
|
return editors
|
|
58
58
|
.map(editor => {
|
|
@@ -70,5 +70,34 @@ export const getElementsText = (elements) => {
|
|
|
70
70
|
.filter(item => item)
|
|
71
71
|
.join(' ');
|
|
72
72
|
};
|
|
73
|
+
export const getTextEditors = (board, elements) => {
|
|
74
|
+
const selectedElements = elements || getSelectedElements(board);
|
|
75
|
+
if (selectedElements.length) {
|
|
76
|
+
const textManages = [];
|
|
77
|
+
selectedElements.forEach(item => {
|
|
78
|
+
textManages.push(...getTextManages(item));
|
|
79
|
+
});
|
|
80
|
+
const editingTextManage = textManages.find(textManage => textManage.isEditing);
|
|
81
|
+
if (editingTextManage) {
|
|
82
|
+
return [editingTextManage.componentRef.instance.editor];
|
|
83
|
+
}
|
|
84
|
+
return textManages.map(item => {
|
|
85
|
+
return item.componentRef.instance.editor;
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
return undefined;
|
|
89
|
+
};
|
|
90
|
+
export const getEditingTextEditor = (board, elements) => {
|
|
91
|
+
const selectedElements = elements || getSelectedElements(board);
|
|
92
|
+
const textManages = [];
|
|
93
|
+
selectedElements.forEach(item => {
|
|
94
|
+
textManages.push(...getTextManages(item));
|
|
95
|
+
});
|
|
96
|
+
const editingTextManage = textManages.find(textManage => textManage.isEditing);
|
|
97
|
+
if (editingTextManage) {
|
|
98
|
+
return editingTextManage.componentRef.instance.editor;
|
|
99
|
+
}
|
|
100
|
+
return undefined;
|
|
101
|
+
};
|
|
73
102
|
export const ELEMENT_TO_TEXT_MANAGES = new WeakMap();
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbW1vbi9zcmMvdXRpbHMvdGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRCLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzVFLE9BQU8sRUFBYyxlQUFlLEVBQWMsTUFBTSxhQUFhLENBQUM7QUFDdEUsT0FBTyxFQUFVLElBQUksRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUVyQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBQyxPQUFxQixFQUFFLEVBQUU7SUFDcEQsT0FBTyx1QkFBdUIsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0FBQ3RELENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQUMsT0FBcUIsRUFBRSxFQUFFO0lBQ3hELE1BQU0sVUFBVSxHQUFHLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5QyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDZCxPQUFPLENBQUMsSUFBSSxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUNELE9BQU8sVUFBVSxDQUFDO0FBQ3RCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLE9BQXFCLEVBQUUsRUFBRTtJQUNwRCxPQUFPLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDeEMsT0FBTyxNQUFNLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUM7SUFDL0MsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLE9BQXFCLEVBQUUsRUFBRTtJQUN4RCxNQUFNLFVBQVUsR0FBRyxjQUFjLENBQUMsT0FB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LENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUF3QyxJQUFJLE9BQU8sRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50LCBnZXRTZWxlY3RlZEVsZW1lbnRzIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgQ3VzdG9tVGV4dCwgUGxhaXRNYXJrRWRpdG9yLCBUZXh0TWFuYWdlIH0gZnJvbSAnQHBsYWl0L3RleHQnO1xuaW1wb3J0IHsgRWRpdG9yLCBOb2RlIH0gZnJvbSAnc2xhdGUnO1xuXG5leHBvcnQgY29uc3QgZ2V0VGV4dE1hbmFnZXMgPSAoZWxlbWVudDogUGxhaXRFbGVtZW50KSA9PiB7XG4gICAgcmV0dXJuIEVMRU1FTlRfVE9fVEVYVF9NQU5BR0VTLmdldChlbGVtZW50KSB8fCBbXTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRGaXJzdFRleHRNYW5hZ2UgPSAoZWxlbWVudDogUGxhaXRFbGVtZW50KSA9PiB7XG4gICAgY29uc3QgdGV4dE1hbmFnZSA9IGdldFRleHRNYW5hZ2VzKGVsZW1lbnQpWzBdO1xuICAgIGlmICghdGV4dE1hbmFnZSkge1xuICAgICAgICBjb25zb2xlLndhcm4oJ2NhbiBub3QgZmluZCB0ZXh0TWFuYWdlJyk7XG4gICAgfVxuICAgIHJldHVybiB0ZXh0TWFuYWdlO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFRleHRFZGl0b3JzID0gKGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgIHJldHVybiBnZXRUZXh0TWFuYWdlcyhlbGVtZW50KS5tYXAobWFuYWdlID0+IHtcbiAgICAgICAgcmV0dXJuIG1hbmFnZS5jb21wb25lbnRSZWYuaW5zdGFuY2UuZWRpdG9yO1xuICAgIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldEZpcnN0VGV4dEVkaXRvciA9IChlbGVtZW50OiBQbGFpdEVsZW1lbnQpID0+IHtcbiAgICBjb25zdCB0ZXh0RWRpdG9yID0gZ2V0VGV4dEVkaXRvcnMoZWxlbWVudClbMF07XG4gICAgaWYgKCF0ZXh0RWRpdG9yKSB7XG4gICAgICAgIGNvbnNvbGUud2FybignY2FuIG5vdCBmaW5kIHRleHRNYW5hZ2UnKTtcbiAgICB9XG4gICAgcmV0dXJuIHRleHRFZGl0b3I7XG59O1xuXG5leHBvcnQgY29uc3QgZmluZEZpcnN0VGV4dEVkaXRvciA9IChib2FyZDogUGxhaXRCb2FyZCkgPT4ge1xuICAgIGNvbnN0IHNlbGVjdGVkRWxlbWVudHMgPSBnZXRTZWxlY3RlZEVsZW1lbnRzKGJvYXJkKTtcbiAgICBsZXQgZmlyc3RFZGl0b3I6IEVkaXRvciB8IG51bGwgPSBudWxsO1xuICAgIHNlbGVjdGVkRWxlbWVudHMuZm9yRWFjaChlbGVtZW50ID0+IHtcbiAgICAgICAgY29uc3QgZWRpdG9ycyA9IGdldFRleHRFZGl0b3JzKGVsZW1lbnQpO1xuICAgICAgICBpZiAoIWZpcnN0RWRpdG9yICYmIGVkaXRvcnMgJiYgZWRpdG9ycy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICBmaXJzdEVkaXRvciA9IGVkaXRvcnNbMF07XG4gICAgICAgIH1cbiAgICB9KTtcbiAgICByZXR1cm4gZmlyc3RFZGl0b3I7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VGV4dE1hcmtzQnlFbGVtZW50ID0gKGVsZW1lbnQ6IFBsYWl0RWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IGVkaXRvcnMgPSBnZXRUZXh0RWRpdG9ycyhlbGVtZW50KTtcbiAgICBjb25zdCBlZGl0b3IgPSBlZGl0b3JzWzBdO1xuICAgIGlmICghZWRpdG9yKSB7XG4gICAgICAgIHJldHVybiB7fTtcbiAgICB9XG4gICAgaWYgKGVkaXRvci5jaGlsZHJlbi5sZW5ndGggPT09IDApIHtcbiAgICAgICAgY29uc3QgdGV4dE1hbmFnZSA9IGdldFRleHRNYW5hZ2VzKGVsZW1lbnQpWzBdO1xuICAgICAgICBjb25zdCBjdXJyZW50TWFya3M6IE9taXQ8Q3VzdG9tVGV4dCwgJ3RleHQnPiA9IFBsYWl0TWFya0VkaXRvci5nZXRNYXJrc0J5RWxlbWVudCh0ZXh0TWFuYWdlLmNvbXBvbmVudFJlZi5pbnN0YW5jZS5jaGlsZHJlblswXSk7XG4gICAgICAgIHJldHVybiBjdXJyZW50TWFya3M7XG4gICAgfVxuICAgIGNvbnN0IGN1cnJlbnRNYXJrczogT21pdDxDdXN0b21UZXh0LCAndGV4dCc+ID0gUGxhaXRNYXJrRWRpdG9yLmdldE1hcmtzKGVkaXRvcik7XG4gICAgcmV0dXJuIGN1cnJlbnRNYXJrcztcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRFbGVtZW50c1RleHQgPSAoZWxlbWVudHM6IFBsYWl0RWxlbWVudFtdKSA9PiB7XG4gICAgcmV0dXJuIGVsZW1lbnRzXG4gICAgICAgIC5tYXAoaXRlbSA9PiB7XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgIGNvbnN0IGVkaXRvcnMgPSBnZXRUZXh0RWRpdG9ycyhpdGVtKTtcbiAgICAgICAgICAgICAgICBpZiAoZWRpdG9ycy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGVkaXRvcnNcbiAgICAgICAgICAgICAgICAgICAgICAgIC5tYXAoZWRpdG9yID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb25zdCB0ZXh0c0VudHJ5ID0gTm9kZS50ZXh0cyhlZGl0b3IpO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBBcnJheS5mcm9tKHRleHRzRW50cnkpLnJlZHVjZSgodG90YWwsIHRleHQpID0+ICh0b3RhbCArPSB0ZXh0WzBdLnRleHQpLCAnJyk7XG4gICAgICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgICAgICAgICAgLmpvaW4oJyAnKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuICcnO1xuICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gJyc7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICAgIC5maWx0ZXIoaXRlbSA9PiBpdGVtKVxuICAgICAgICAuam9pbignICcpO1xufTtcblxuZXhwb3J0IGNvbnN0IEVMRU1FTlRfVE9fVEVYVF9NQU5BR0VTOiBXZWFrTWFwPFBsYWl0RWxlbWVudCwgVGV4dE1hbmFnZVtdPiA9IG5ldyBXZWFrTWFwKCk7XG4iXX0=
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.js","sourceRoot":"","sources":["../../../../packages/common/src/utils/text.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAC5E,OAAO,EAAc,eAAe,EAAc,MAAM,aAAa,CAAC;AACtE,OAAO,EAAU,IAAI,EAAE,MAAM,OAAO,CAAC;AAErC,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,OAAqB,EAAE,EAAE;IACpD,OAAO,uBAAuB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;AACtD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,OAAqB,EAAE,EAAE;IACxD,MAAM,UAAU,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9C,IAAI,CAAC,UAAU,EAAE,CAAC;QACd,OAAO,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IAC5C,CAAC;IACD,OAAO,UAAU,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,OAAqB,EAAE,EAAE;IAC7D,OAAO,cAAc,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;QACxC,OAAO,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC;IAC/C,CAAC,CAAC,CAAC;AACP,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,OAAqB,EAAE,EAAE;IACxD,MAAM,UAAU,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACvD,IAAI,CAAC,UAAU,EAAE,CAAC;QACd,OAAO,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IAC5C,CAAC;IACD,OAAO,UAAU,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,KAAiB,EAAE,EAAE;IACrD,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC;IACpD,IAAI,WAAW,GAAkB,IAAI,CAAC;IACtC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;QAC/B,MAAM,OAAO,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChD,WAAW,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QAC7B,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,WAAW,CAAC;AACvB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,OAAqB,EAAE,EAAE;IAC3D,MAAM,OAAO,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;IACjD,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IAC1B,IAAI,CAAC,MAAM,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;IACd,CAAC;IACD,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,MAAM,UAAU,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,YAAY,GAA6B,eAAe,CAAC,iBAAiB,CAAC,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/H,OAAO,YAAY,CAAC;IACxB,CAAC;IACD,MAAM,YAAY,GAA6B,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAChF,OAAO,YAAY,CAAC;AACxB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,QAAwB,EAAE,EAAE;IACxD,OAAO,QAAQ;SACV,GAAG,CAAC,IAAI,CAAC,EAAE;QACR,IAAI,CAAC;YACD,MAAM,OAAO,GAAG,uBAAuB,CAAC,IAAI,CAAC,CAAC;YAC9C,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;gBACjB,OAAO,OAAO;qBACT,GAAG,CAAC,MAAM,CAAC,EAAE;oBACV,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;oBACtC,OAAO,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;gBACvF,CAAC,CAAC;qBACD,IAAI,CAAC,GAAG,CAAC,CAAC;YACnB,CAAC;YACD,OAAO,EAAE,CAAC;QACd,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,OAAO,EAAE,CAAC;QACd,CAAC;IACL,CAAC,CAAC;SACD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC;SACpB,IAAI,CAAC,GAAG,CAAC,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAAiB,EAAE,QAAyB,EAAE,EAAE;IAC3E,MAAM,gBAAgB,GAAG,QAAQ,IAAI,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAChE,IAAI,gBAAgB,CAAC,MAAM,EAAE,CAAC;QAC1B,MAAM,WAAW,GAAiB,EAAE,CAAC;QACrC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC5B,WAAW,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QACH,MAAM,iBAAiB,GAAG,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QAC/E,IAAI,iBAAiB,EAAE,CAAC;YACpB,OAAO,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC5D,CAAC;QACD,OAAO,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAC1B,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC7C,CAAC,CAAC,CAAC;IACP,CAAC;IACD,OAAO,SAAS,CAAC;AACrB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,KAAiB,EAAE,QAAyB,EAAE,EAAE;IACjF,MAAM,gBAAgB,GAAG,QAAQ,IAAI,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAChE,MAAM,WAAW,GAAiB,EAAE,CAAC;IACrC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QAC5B,WAAW,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IACH,MAAM,iBAAiB,GAAG,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IAC/E,IAAI,iBAAiB,EAAE,CAAC;QACpB,OAAO,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC;IAC1D,CAAC;IACD,OAAO,SAAS,CAAC;AACrB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAwC,IAAI,OAAO,EAAE,CAAC","sourcesContent":["import { PlaitBoard, PlaitElement, getSelectedElements } from '@plait/core';\nimport { CustomText, PlaitMarkEditor, TextManage } from '@plait/text';\nimport { Editor, Node } from 'slate';\n\nexport const getTextManages = (element: PlaitElement) => {\n    return ELEMENT_TO_TEXT_MANAGES.get(element) || [];\n};\n\nexport const getFirstTextManage = (element: PlaitElement) => {\n    const textManage = getTextManages(element)[0];\n    if (!textManage) {\n        console.warn('can not find textManage');\n    }\n    return textManage;\n};\n\nexport const getTextEditorsByElement = (element: PlaitElement) => {\n    return getTextManages(element).map(manage => {\n        return manage.componentRef.instance.editor;\n    });\n};\n\nexport const getFirstTextEditor = (element: PlaitElement) => {\n    const textEditor = getTextEditorsByElement(element)[0];\n    if (!textEditor) {\n        console.warn('can not find textManage');\n    }\n    return textEditor;\n};\n\nexport const findFirstTextEditor = (board: PlaitBoard) => {\n    const selectedElements = getSelectedElements(board);\n    let firstEditor: Editor | null = null;\n    selectedElements.forEach(element => {\n        const editors = getTextEditorsByElement(element);\n        if (!firstEditor && editors && editors.length > 0) {\n            firstEditor = editors[0];\n        }\n    });\n    return firstEditor;\n};\n\nexport const getTextMarksByElement = (element: PlaitElement) => {\n    const editors = getTextEditorsByElement(element);\n    const editor = editors[0];\n    if (!editor) {\n        return {};\n    }\n    if (editor.children.length === 0) {\n        const textManage = getTextManages(element)[0];\n        const currentMarks: Omit<CustomText, 'text'> = PlaitMarkEditor.getMarksByElement(textManage.componentRef.instance.children[0]);\n        return currentMarks;\n    }\n    const currentMarks: Omit<CustomText, 'text'> = PlaitMarkEditor.getMarks(editor);\n    return currentMarks;\n};\n\nexport const getElementsText = (elements: PlaitElement[]) => {\n    return elements\n        .map(item => {\n            try {\n                const editors = getTextEditorsByElement(item);\n                if (editors.length) {\n                    return editors\n                        .map(editor => {\n                            const textsEntry = Node.texts(editor);\n                            return Array.from(textsEntry).reduce((total, text) => (total += text[0].text), '');\n                        })\n                        .join(' ');\n                }\n                return '';\n            } catch (error) {\n                return '';\n            }\n        })\n        .filter(item => item)\n        .join(' ');\n};\n\nexport const getTextEditors = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedElements = elements || getSelectedElements(board);\n    if (selectedElements.length) {\n        const textManages: TextManage[] = [];\n        selectedElements.forEach(item => {\n            textManages.push(...getTextManages(item));\n        });\n        const editingTextManage = textManages.find(textManage => textManage.isEditing);\n        if (editingTextManage) {\n            return [editingTextManage.componentRef.instance.editor];\n        }\n        return textManages.map(item => {\n            return item.componentRef.instance.editor;\n        });\n    }\n    return undefined;\n};\n\nexport const getEditingTextEditor = (board: PlaitBoard, elements?: PlaitElement[]) => {\n    const selectedElements = elements || getSelectedElements(board);\n    const textManages: TextManage[] = [];\n    selectedElements.forEach(item => {\n        textManages.push(...getTextManages(item));\n    });\n    const editingTextManage = textManages.find(textManage => textManage.isEditing);\n    if (editingTextManage) {\n        return editingTextManage.componentRef.instance.editor;\n    }\n    return undefined;\n};\n\nexport const ELEMENT_TO_TEXT_MANAGES: WeakMap<PlaitElement, TextManage[]> = new WeakMap();\n"]}
|
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
import { PlaitGroupElement, getSelectionAngle, getElementsInGroup, setAngleForG, RectangleClient, drawCircle, PlaitBoard, RESIZE_HANDLE_CLASS_NAME, createG, setStrokeLinecap, drawRectangle, SELECTION_RECTANGLE_CLASS_NAME, createForeignObject, updateForeignObject, ResizeCursorClass, RESIZE_CURSORS, setDragging, rotatePoints, isSelectionMoving, getSelectedElements, distanceBetweenPointAndPoint, Point, Direction, hotkeys, PlaitContextService, createDebugGenerator, Transforms, getHighestSelectedElements, getRectangleByElements, MERGING, PlaitPointerType, isMainPointer, toViewBoxPoint, toHostPoint, preventTouchMove, PRESS_AND_MOVE_BUFFER, isDragging, throttleRAF, handleTouchTarget, ACTIVE_STROKE_WIDTH, getRectangleByGroup,
|
|
1
|
+
import { PlaitGroupElement, getSelectionAngle, getElementsInGroup, setAngleForG, RectangleClient, drawCircle, PlaitBoard, RESIZE_HANDLE_CLASS_NAME, createG, setStrokeLinecap, drawRectangle, SELECTION_RECTANGLE_CLASS_NAME, createForeignObject, updateForeignObject, ResizeCursorClass, RESIZE_CURSORS, setDragging, rotatePoints, isSelectionMoving, getSelectedElements, distanceBetweenPointAndPoint, Point, Direction, hotkeys, PlaitContextService, createDebugGenerator, Transforms, getHighestSelectedElements, getRectangleByElements, MERGING, PlaitPointerType, isMainPointer, toViewBoxPoint, toHostPoint, preventTouchMove, PRESS_AND_MOVE_BUFFER, isDragging, throttleRAF, handleTouchTarget, ACTIVE_STROKE_WIDTH, getRectangleByGroup, ElementFlavour, isSelectedElementOrGroup, Selection, getHitElementsBySelection, createGroupRectangleG, getSelectedGroups, getHighestSelectedGroups, getSelectedIsolatedElements, idCreator, getSelectedIsolatedElementsCanAddToGroup, getGroupByElement } from '@plait/core';
|
|
2
2
|
import { isKeyHotkey } from 'is-hotkey';
|
|
3
3
|
import { PlaitMarkEditor, MarkTypes, AlignEditor } from '@plait/text';
|
|
4
4
|
import { Node, Transforms as Transforms$1, Editor } from 'slate';
|
|
5
5
|
import * as i0 from '@angular/core';
|
|
6
|
-
import { Directive,
|
|
7
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { Directive, Input } from '@angular/core';
|
|
8
7
|
|
|
9
8
|
const BASE = 4;
|
|
10
9
|
const PRIMARY_COLOR = '#6698FF';
|
|
@@ -748,13 +747,13 @@ const getFirstTextManage = (element) => {
|
|
|
748
747
|
}
|
|
749
748
|
return textManage;
|
|
750
749
|
};
|
|
751
|
-
const
|
|
750
|
+
const getTextEditorsByElement = (element) => {
|
|
752
751
|
return getTextManages(element).map(manage => {
|
|
753
752
|
return manage.componentRef.instance.editor;
|
|
754
753
|
});
|
|
755
754
|
};
|
|
756
755
|
const getFirstTextEditor = (element) => {
|
|
757
|
-
const textEditor =
|
|
756
|
+
const textEditor = getTextEditorsByElement(element)[0];
|
|
758
757
|
if (!textEditor) {
|
|
759
758
|
console.warn('can not find textManage');
|
|
760
759
|
}
|
|
@@ -764,7 +763,7 @@ const findFirstTextEditor = (board) => {
|
|
|
764
763
|
const selectedElements = getSelectedElements(board);
|
|
765
764
|
let firstEditor = null;
|
|
766
765
|
selectedElements.forEach(element => {
|
|
767
|
-
const editors =
|
|
766
|
+
const editors = getTextEditorsByElement(element);
|
|
768
767
|
if (!firstEditor && editors && editors.length > 0) {
|
|
769
768
|
firstEditor = editors[0];
|
|
770
769
|
}
|
|
@@ -772,7 +771,7 @@ const findFirstTextEditor = (board) => {
|
|
|
772
771
|
return firstEditor;
|
|
773
772
|
};
|
|
774
773
|
const getTextMarksByElement = (element) => {
|
|
775
|
-
const editors =
|
|
774
|
+
const editors = getTextEditorsByElement(element);
|
|
776
775
|
const editor = editors[0];
|
|
777
776
|
if (!editor) {
|
|
778
777
|
return {};
|
|
@@ -789,7 +788,7 @@ const getElementsText = (elements) => {
|
|
|
789
788
|
return elements
|
|
790
789
|
.map(item => {
|
|
791
790
|
try {
|
|
792
|
-
const editors =
|
|
791
|
+
const editors = getTextEditorsByElement(item);
|
|
793
792
|
if (editors.length) {
|
|
794
793
|
return editors
|
|
795
794
|
.map(editor => {
|
|
@@ -807,6 +806,35 @@ const getElementsText = (elements) => {
|
|
|
807
806
|
.filter(item => item)
|
|
808
807
|
.join(' ');
|
|
809
808
|
};
|
|
809
|
+
const getTextEditors = (board, elements) => {
|
|
810
|
+
const selectedElements = elements || getSelectedElements(board);
|
|
811
|
+
if (selectedElements.length) {
|
|
812
|
+
const textManages = [];
|
|
813
|
+
selectedElements.forEach(item => {
|
|
814
|
+
textManages.push(...getTextManages(item));
|
|
815
|
+
});
|
|
816
|
+
const editingTextManage = textManages.find(textManage => textManage.isEditing);
|
|
817
|
+
if (editingTextManage) {
|
|
818
|
+
return [editingTextManage.componentRef.instance.editor];
|
|
819
|
+
}
|
|
820
|
+
return textManages.map(item => {
|
|
821
|
+
return item.componentRef.instance.editor;
|
|
822
|
+
});
|
|
823
|
+
}
|
|
824
|
+
return undefined;
|
|
825
|
+
};
|
|
826
|
+
const getEditingTextEditor = (board, elements) => {
|
|
827
|
+
const selectedElements = elements || getSelectedElements(board);
|
|
828
|
+
const textManages = [];
|
|
829
|
+
selectedElements.forEach(item => {
|
|
830
|
+
textManages.push(...getTextManages(item));
|
|
831
|
+
});
|
|
832
|
+
const editingTextManage = textManages.find(textManage => textManage.isEditing);
|
|
833
|
+
if (editingTextManage) {
|
|
834
|
+
return editingTextManage.componentRef.instance.editor;
|
|
835
|
+
}
|
|
836
|
+
return undefined;
|
|
837
|
+
};
|
|
810
838
|
const ELEMENT_TO_TEXT_MANAGES = new WeakMap();
|
|
811
839
|
|
|
812
840
|
const selectImage = (board, defaultImageWidth, handle, acceptImageTypes = ['png', 'jpeg', 'gif', 'bmp']) => {
|
|
@@ -1414,54 +1442,60 @@ const setTextMarks = (board, mark) => {
|
|
|
1414
1442
|
}
|
|
1415
1443
|
const activeMarks = PlaitMarkEditor.getMarks(firstEditor);
|
|
1416
1444
|
const elements = selectedElements.filter(element => {
|
|
1417
|
-
const editors =
|
|
1445
|
+
const editors = getTextEditorsByElement(element);
|
|
1418
1446
|
return editors.some(editor => {
|
|
1419
1447
|
const elementMarks = PlaitMarkEditor.getMarks(editor);
|
|
1420
1448
|
return elementMarks[mark] === activeMarks[mark];
|
|
1421
1449
|
});
|
|
1422
1450
|
});
|
|
1423
|
-
|
|
1424
|
-
|
|
1425
|
-
editors.forEach(editor =>
|
|
1426
|
-
|
|
1451
|
+
const editors = getTextEditors(board, elements);
|
|
1452
|
+
if (editors && editors.length) {
|
|
1453
|
+
editors.forEach(editor => {
|
|
1454
|
+
PlaitMarkEditor.toggleMark(editor, mark);
|
|
1455
|
+
});
|
|
1456
|
+
}
|
|
1427
1457
|
}
|
|
1428
1458
|
};
|
|
1429
1459
|
const setFontSize = (board, size, defaultFontSize) => {
|
|
1430
|
-
const
|
|
1431
|
-
if (
|
|
1432
|
-
selectedElements
|
|
1433
|
-
|
|
1434
|
-
|
|
1435
|
-
|
|
1460
|
+
const editors = getTextEditors(board);
|
|
1461
|
+
if (editors && editors.length) {
|
|
1462
|
+
const selectedElements = getSelectedElements(board);
|
|
1463
|
+
editors.forEach(editor => {
|
|
1464
|
+
let finalDefaultFontSize;
|
|
1465
|
+
if (typeof defaultFontSize === 'function') {
|
|
1466
|
+
const element = selectedElements.find(element => {
|
|
1467
|
+
const textEditors = getTextEditorsByElement(element);
|
|
1468
|
+
return textEditors.includes(editor);
|
|
1469
|
+
});
|
|
1470
|
+
finalDefaultFontSize = defaultFontSize(element);
|
|
1471
|
+
}
|
|
1472
|
+
else {
|
|
1473
|
+
finalDefaultFontSize = defaultFontSize;
|
|
1474
|
+
}
|
|
1475
|
+
PlaitMarkEditor.setFontSizeMark(editor, size, finalDefaultFontSize);
|
|
1436
1476
|
});
|
|
1437
1477
|
}
|
|
1438
1478
|
};
|
|
1439
1479
|
const setTextColor = (board, color, textSelection) => {
|
|
1440
|
-
const
|
|
1441
|
-
if (
|
|
1442
|
-
|
|
1443
|
-
|
|
1444
|
-
|
|
1445
|
-
|
|
1446
|
-
|
|
1447
|
-
|
|
1448
|
-
|
|
1449
|
-
|
|
1450
|
-
|
|
1451
|
-
|
|
1452
|
-
PlaitMarkEditor.setColorMark(editor, color);
|
|
1453
|
-
}
|
|
1454
|
-
});
|
|
1480
|
+
const editors = getTextEditors(board);
|
|
1481
|
+
if (editors && editors.length) {
|
|
1482
|
+
editors.forEach(editor => {
|
|
1483
|
+
if (textSelection) {
|
|
1484
|
+
Transforms$1.select(editor, textSelection);
|
|
1485
|
+
}
|
|
1486
|
+
if (color === 'transparent') {
|
|
1487
|
+
Editor.removeMark(editor, MarkTypes.color);
|
|
1488
|
+
}
|
|
1489
|
+
else {
|
|
1490
|
+
PlaitMarkEditor.setColorMark(editor, color);
|
|
1491
|
+
}
|
|
1455
1492
|
});
|
|
1456
1493
|
}
|
|
1457
1494
|
};
|
|
1458
1495
|
const setTextAlign = (board, align) => {
|
|
1459
|
-
const
|
|
1460
|
-
if (
|
|
1461
|
-
|
|
1462
|
-
const editors = getTextEditors(element);
|
|
1463
|
-
editors.forEach(editor => AlignEditor.setAlign(editor, align));
|
|
1464
|
-
});
|
|
1496
|
+
const editors = getTextEditors(board);
|
|
1497
|
+
if (editors && editors.length) {
|
|
1498
|
+
editors.forEach(editor => AlignEditor.setAlign(editor, align));
|
|
1465
1499
|
}
|
|
1466
1500
|
};
|
|
1467
1501
|
const TextTransforms = { setTextAlign, setTextColor, setFontSize, setTextMarks };
|
|
@@ -1509,7 +1543,8 @@ const withResize = (board, options) => {
|
|
|
1509
1543
|
element: resizeHitTestRef.element,
|
|
1510
1544
|
handle: resizeHitTestRef.handle,
|
|
1511
1545
|
handleIndex: resizeHitTestRef.handleIndex,
|
|
1512
|
-
rectangle: resizeHitTestRef.rectangle
|
|
1546
|
+
rectangle: resizeHitTestRef.rectangle,
|
|
1547
|
+
options: resizeHitTestRef.options
|
|
1513
1548
|
};
|
|
1514
1549
|
preventTouchMove(board, event, true);
|
|
1515
1550
|
// prevent text from being selected when user pressed shift and pointer down
|
|
@@ -1626,7 +1661,7 @@ class PlaitCommonElementRef {
|
|
|
1626
1661
|
}
|
|
1627
1662
|
}
|
|
1628
1663
|
|
|
1629
|
-
class
|
|
1664
|
+
class CommonElementFlavour extends ElementFlavour {
|
|
1630
1665
|
constructor(elementRef = new PlaitCommonElementRef()) {
|
|
1631
1666
|
super(elementRef);
|
|
1632
1667
|
this.textManages = [];
|
|
@@ -1654,18 +1689,11 @@ class CommonPluginElement extends PlaitPluginElementComponent {
|
|
|
1654
1689
|
getTextManages() {
|
|
1655
1690
|
return this.textManages;
|
|
1656
1691
|
}
|
|
1657
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CommonPluginElement, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
|
1658
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.4", type: CommonPluginElement, usesInheritance: true, ngImport: i0 }); }
|
|
1659
1692
|
}
|
|
1660
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CommonPluginElement, decorators: [{
|
|
1661
|
-
type: Directive
|
|
1662
|
-
}], ctorParameters: () => [{ type: undefined }] });
|
|
1663
1693
|
|
|
1664
|
-
class GroupComponent extends
|
|
1665
|
-
constructor(
|
|
1694
|
+
class GroupComponent extends CommonElementFlavour {
|
|
1695
|
+
constructor() {
|
|
1666
1696
|
super();
|
|
1667
|
-
this.destroyRef = destroyRef;
|
|
1668
|
-
this.contextService = inject(PlaitContextService);
|
|
1669
1697
|
}
|
|
1670
1698
|
initializeGenerator() {
|
|
1671
1699
|
this.activeGenerator = new ActiveGenerator(this.board, {
|
|
@@ -1680,13 +1708,11 @@ class GroupComponent extends CommonPluginElement {
|
|
|
1680
1708
|
});
|
|
1681
1709
|
this.groupGenerator = new GroupGenerator(this.board);
|
|
1682
1710
|
}
|
|
1683
|
-
|
|
1684
|
-
super.
|
|
1711
|
+
initialize() {
|
|
1712
|
+
super.initialize();
|
|
1685
1713
|
this.initializeGenerator();
|
|
1686
|
-
this.
|
|
1687
|
-
|
|
1688
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
1689
|
-
.subscribe(() => {
|
|
1714
|
+
const contextService = PlaitBoard.getViewContainerRef(this.board).injector.get(PlaitContextService);
|
|
1715
|
+
this.onStableSubscription = contextService.onStable().subscribe(() => {
|
|
1690
1716
|
const elementsInGroup = getElementsInGroup(this.board, this.element, false, true);
|
|
1691
1717
|
const isPartialSelectGroup = elementsInGroup.some(item => isSelectedElementOrGroup(this.board, item)) &&
|
|
1692
1718
|
!elementsInGroup.every(item => isSelectedElementOrGroup(this.board, item));
|
|
@@ -1694,18 +1720,11 @@ class GroupComponent extends CommonPluginElement {
|
|
|
1694
1720
|
});
|
|
1695
1721
|
}
|
|
1696
1722
|
onContextChanged(value, previous) { }
|
|
1697
|
-
|
|
1698
|
-
|
|
1723
|
+
destroy() {
|
|
1724
|
+
super.destroy();
|
|
1725
|
+
this.onStableSubscription?.unsubscribe();
|
|
1726
|
+
}
|
|
1699
1727
|
}
|
|
1700
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: GroupComponent, decorators: [{
|
|
1701
|
-
type: Component,
|
|
1702
|
-
args: [{
|
|
1703
|
-
selector: 'plait-group',
|
|
1704
|
-
template: ``,
|
|
1705
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
1706
|
-
standalone: true
|
|
1707
|
-
}]
|
|
1708
|
-
}], ctorParameters: () => [{ type: i0.DestroyRef }] });
|
|
1709
1728
|
|
|
1710
1729
|
function withGroup(board) {
|
|
1711
1730
|
let groupRectangleG;
|
|
@@ -1997,5 +2016,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
1997
2016
|
* Generated bundle index. Do not edit.
|
|
1998
2017
|
*/
|
|
1999
2018
|
|
|
2000
|
-
export { AStar, ActiveGenerator, AlignTransform, BASE, BoardCreationMode,
|
|
2019
|
+
export { AStar, ActiveGenerator, AlignTransform, BASE, BoardCreationMode, CommonElementFlavour, DEFAULT_ROUTE_MARGIN, ELEMENT_TO_TEXT_MANAGES, Generator, IS_RESIZING, IS_ROTATING, ImageBaseComponent, ImageGenerator, MediaKeys, PICTURE_ACCEPTED_UPLOAD_SIZE, PRIMARY_COLOR, PlaitCommonElementRef, PointGraph, PointNode, PriorityQueue, PropertyTransforms, RESIZE_HANDLE_DIAMETER, ROTATE_HANDLE_DISTANCE_TO_ELEMENT, ROTATE_HANDLE_SIZE, ResizeHandle, TRANSPARENT, TextTransforms, WithCommonPluginKey, WithTextPluginKey, acceptImageTypes, addElementOfFocusedImage, addResizing, addRotating, alignBottom, alignHorizontalCenter, alignLeft, alignRight, alignTop, alignVerticalCenter, buildImage, calculatePolylineLength, canResize, createGraph, distributeHorizontal, distributeVertical, drawFillPrimaryHandle, drawHandle, drawPrimaryHandle, drawRotateHandle, findFirstTextEditor, generateElbowLineRoute, getCreationMode, getCrossingPointsBetweenPointAndSegment, getDirectionBetweenPointAndPoint, getDirectionByPointOfRectangle, getDirectionByVector, getDirectionFactor, getDirectionFactorByDirectionComponent, getEditingTextEditor, getElementOfFocusedImage, getElementsText, getExtendPoint, getFirstTextEditor, getFirstTextManage, getGraphPoints, getIndexByResizeHandle, getMemorizedLatest, getNextPoint, getOppositeDirection, getPointByVectorComponent, getPointByVectorDirectionComponent, getPointOnPolyline, getPoints, getRatioByPoint, getRectangleResizeHandleRefs, getResizeHandleByIndex, getResizeHandlePointByIndex, getRotatedResizeCursorClassByAngle, getSourceAndTargetOuterRectangle, getSymmetricHandleIndex, getTextEditors, getTextEditorsByElement, getTextManages, getTextMarksByElement, getUnitVectorByPointAndPoint, hasAfterDraw, isCornerHandle, isDelete, isDndMode, isDrawingMode, isEdgeHandle, isEnterHotkey, isExpandHotkey, isPointOnSegment, isResizing, isResizingByCondition, isRotating, isSourceAndTargetIntersect, isSpaceHotkey, isTabHotkey, isVirtualKey, memorizeLatest, normalizeShapePoints, reduceRouteMargin, removeDuplicatePoints, removeElementOfFocusedImage, removeResizing, removeRotating, resetPointsAfterResize, rotateVector, rotateVectorAnti90, routeAdjust, selectImage, setCreationMode, setProperty, simplifyOrthogonalPoints, withGroup, withResize };
|
|
2001
2020
|
//# sourceMappingURL=plait-common.mjs.map
|