@worktile/theia 2.2.10 → 2.3.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/worktile-theia.umd.js +464 -229
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/constants/default.d.ts +2 -0
- package/constants/node-types.d.ts +4 -0
- package/custom-types.d.ts +3 -1
- package/editor.component.d.ts +1 -1
- package/esm2015/constants/default.js +1 -1
- package/esm2015/constants/node-types.js +6 -1
- package/esm2015/custom-types.js +1 -1
- package/esm2015/editor.component.js +1 -2
- package/esm2015/interfaces/editor.js +1 -1
- package/esm2015/interfaces/image.js +1 -1
- package/esm2015/interfaces/valid-children-types.js +2 -1
- package/esm2015/plugins/align/align.editor.js +14 -2
- package/esm2015/plugins/align/options.js +3 -2
- package/esm2015/plugins/common/auto-insert-data..js +2 -18
- package/esm2015/plugins/image/image.component.js +168 -14
- package/esm2015/plugins/image/image.editor.js +4 -1
- package/esm2015/plugins/quick-insert/components/quick-insert.component.js +13 -2
- package/esm2015/services/context.service.js +5 -1
- package/esm2015/utils/dom.js +40 -2
- package/esm2015/utils/index.js +3 -1
- package/esm2015/utils/merge-element-options.js +20 -0
- package/fesm2015/worktile-theia.js +417 -197
- package/fesm2015/worktile-theia.js.map +1 -1
- package/interfaces/editor.d.ts +4 -1
- package/interfaces/image.d.ts +7 -1
- package/interfaces/valid-children-types.d.ts +1 -0
- package/package.json +1 -1
- package/plugins/align/align.editor.d.ts +1 -0
- package/plugins/image/image.component.d.ts +27 -3
- package/plugins/image/image.component.scss +12 -2
- package/plugins/image/image.editor.d.ts +6 -1
- package/plugins/quick-insert/components/quick-insert.component.d.ts +1 -0
- package/plugins/table/components/table.component.scss +3 -2
- package/services/context.service.d.ts +1 -0
- package/styles/editor.scss +11 -0
- package/styles/index.scss +1 -1
- package/styles/typo.scss +56 -1
- package/utils/dom.d.ts +5 -1
- package/utils/index.d.ts +2 -0
- package/utils/merge-element-options.d.ts +2 -0
package/esm2015/utils/dom.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { AngularEditor, EDITOR_TO_ELEMENT } from 'slate-angular';
|
|
1
2
|
import { Alignment } from '../constants';
|
|
2
3
|
/** Converts CSS pixel values to numbers, eg "123px" to 123. Returns NaN for non pixel values. */
|
|
3
4
|
export function coercePixelsFromCssValue(cssValue) {
|
|
4
|
-
const match = cssValue.match(/(\d+)px/);
|
|
5
|
+
const match = cssValue.match(/(\d+(\.\d+)?)px/);
|
|
5
6
|
if (match) {
|
|
6
7
|
return Number(match[1]);
|
|
7
8
|
}
|
|
@@ -44,4 +45,41 @@ export function getElementClassByPrefix(el, prefix) {
|
|
|
44
45
|
});
|
|
45
46
|
return matchClass;
|
|
46
47
|
}
|
|
47
|
-
|
|
48
|
+
export function findRelativeElementByPoint(editor, x, y, mode) {
|
|
49
|
+
const editableElement = EDITOR_TO_ELEMENT.get(editor);
|
|
50
|
+
const rectEditable = editableElement.getBoundingClientRect();
|
|
51
|
+
if (x > rectEditable.x && x < rectEditable.x + rectEditable.width) {
|
|
52
|
+
const centerX = rectEditable.x + rectEditable.width / 2;
|
|
53
|
+
let relativeElement = document.elementFromPoint(mode === 'highest' ? centerX : x, y);
|
|
54
|
+
return relativeElement;
|
|
55
|
+
}
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
export function findNodeEntryByPoint(editor, x, y, mode) {
|
|
59
|
+
const editableElement = EDITOR_TO_ELEMENT.get(editor);
|
|
60
|
+
let rootElement = null;
|
|
61
|
+
let relativeElement = findRelativeElementByPoint(editor, x, y, mode);
|
|
62
|
+
// 获取最顶层的DOM
|
|
63
|
+
if (mode === 'highest') {
|
|
64
|
+
while (relativeElement && editableElement.contains(relativeElement)) {
|
|
65
|
+
relativeElement = relativeElement.closest('[data-slate-node="element"]');
|
|
66
|
+
if (relativeElement) {
|
|
67
|
+
rootElement = relativeElement;
|
|
68
|
+
relativeElement = relativeElement.parentElement;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if (!mode) {
|
|
73
|
+
if (relativeElement && editableElement.contains(relativeElement)) {
|
|
74
|
+
relativeElement = relativeElement.closest('[data-slate-node="element"]');
|
|
75
|
+
rootElement = relativeElement;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
if (rootElement) {
|
|
79
|
+
const node = AngularEditor.toSlateNode(editor, rootElement);
|
|
80
|
+
const path = AngularEditor.findPath(editor, node);
|
|
81
|
+
return [node, path];
|
|
82
|
+
}
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../../packages/src/utils/dom.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Element, NodeEntry } from 'slate';\nimport { AngularEditor, DOMElement, EDITOR_TO_ELEMENT } from 'slate-angular';\nimport { TheEditor } from '../interfaces/editor';\nimport { Alignment, NodeLevel } from '../constants';\n\n/** Converts CSS pixel values to numbers, eg \"123px\" to 123. Returns NaN for non pixel values. */\nexport function coercePixelsFromCssValue(cssValue: string): number {\n    const match = cssValue.match(/(\\d+(\\.\\d+)?)px/);\n    if (match) {\n        return Number(match[1]);\n    }\n}\n\nexport function getElementWidth(element: HTMLElement) {\n    // Optimization: Check style.width first as we probably set it already before reading\n    // offsetWidth which triggers layout.\n    return coercePixelsFromCssValue(element.style.width) || element.offsetWidth;\n}\n\nexport function getElementHeight(element: HTMLElement) {\n    return Math.round(element.getBoundingClientRect().height);\n}\n\nexport function getColsTotalWidth(cols: HTMLTableColElement[]) {\n    return cols.reduce((total, col) => {\n        return total + getElementWidth(col);\n    }, 0);\n}\n\nexport function getRowsTotalHeight(rows: HTMLTableRowElement[]) {\n    return rows.reduce((total, row) => {\n        return total + getElementHeight(row);\n    }, 0);\n}\n\nexport function useElementStyle(el: HTMLElement, element: Element) {\n    if (element.align) {\n        el.style.textAlign = (element.align as string) || Alignment.left;\n    }\n\n    if (element.textIndent) {\n        el.style.textIndent = element.textIndent + 'em';\n    }\n\n    if (element.verticalAlign) {\n        el.style.verticalAlign = element.verticalAlign;\n    }\n}\n\nexport function getElementClassByPrefix(el: DOMElement, prefix: string) {\n    let matchClass = null;\n    el.classList.forEach((value, key) => {\n        if (value.includes(prefix)) {\n            matchClass = value;\n        }\n    });\n    return matchClass;\n}\n\nexport function findRelativeElementByPoint(editor: TheEditor, x: number, y: number, mode?: NodeLevel) {\n    const editableElement = EDITOR_TO_ELEMENT.get(editor);\n    const rectEditable = editableElement.getBoundingClientRect();\n    if (x > rectEditable.x && x < rectEditable.x + rectEditable.width) {\n        const centerX = rectEditable.x + rectEditable.width / 2;\n        let relativeElement = document.elementFromPoint(mode === 'highest' ? centerX : x, y);\n        return relativeElement;\n    }\n    return null;\n}\n\nexport function findNodeEntryByPoint(editor: TheEditor, x: number, y: number, mode?: NodeLevel): NodeEntry<Element> | null {\n    const editableElement = EDITOR_TO_ELEMENT.get(editor);\n    let rootElement: DOMElement = null;\n    let relativeElement = findRelativeElementByPoint(editor, x, y, mode);\n    // 获取最顶层的DOM\n    if (mode === 'highest') {\n        while (relativeElement && editableElement.contains(relativeElement)) {\n            relativeElement = relativeElement.closest('[data-slate-node=\"element\"]');\n            if (relativeElement) {\n                rootElement = relativeElement;\n                relativeElement = relativeElement.parentElement;\n            }\n        }\n    }\n\n    if (!mode) {\n        if (relativeElement && editableElement.contains(relativeElement)) {\n            relativeElement = relativeElement.closest('[data-slate-node=\"element\"]');\n            rootElement = relativeElement;\n        }\n    }\n\n    if (rootElement) {\n        const node = AngularEditor.toSlateNode(editor, rootElement) as Element;\n        const path = AngularEditor.findPath(editor, node);\n        return [node, path];\n    }\n    return null;\n}\n"]}
|
package/esm2015/utils/index.js
CHANGED
|
@@ -4,4 +4,6 @@ export * from './get-toolbar-class';
|
|
|
4
4
|
export * from './create-empty-paragraph';
|
|
5
5
|
export * from './common';
|
|
6
6
|
export * from './is-clean-empty-paragraph';
|
|
7
|
-
|
|
7
|
+
export * from './merge-element-options';
|
|
8
|
+
export * from './dom';
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsT0FBTyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kYXRhLXRyYW5zZm9ybSc7XG5leHBvcnQgKiBmcm9tICcuL3dlYWstbWFwcyc7XG5leHBvcnQgKiBmcm9tICcuL2dldC10b29sYmFyLWNsYXNzJztcbmV4cG9ydCAqIGZyb20gJy4vY3JlYXRlLWVtcHR5LXBhcmFncmFwaCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbic7XG5leHBvcnQgKiBmcm9tICcuL2lzLWNsZWFuLWVtcHR5LXBhcmFncmFwaCc7XG5leHBvcnQgKiBmcm9tICcuL21lcmdlLWVsZW1lbnQtb3B0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2RvbSc7XG4iXX0=
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { DefaultElementOptions } from '../interfaces';
|
|
2
|
+
export const mergeElementOptions = (elementOptions) => {
|
|
3
|
+
elementOptions = elementOptions.filter(item => item.inValidChildrenTypes.length > 0);
|
|
4
|
+
const combinationData = [...DefaultElementOptions, ...elementOptions];
|
|
5
|
+
const dataInfo = {};
|
|
6
|
+
combinationData.forEach(item => {
|
|
7
|
+
const { type, inValidChildrenTypes, isIndivisible, isSecondaryContainer } = item;
|
|
8
|
+
if (!dataInfo[type]) {
|
|
9
|
+
dataInfo[type] = {
|
|
10
|
+
type,
|
|
11
|
+
inValidChildrenTypes,
|
|
12
|
+
isIndivisible,
|
|
13
|
+
isSecondaryContainer
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
dataInfo[type].inValidChildrenTypes = Array.from(new Set([...inValidChildrenTypes, ...dataInfo[type].inValidChildrenTypes]));
|
|
17
|
+
});
|
|
18
|
+
return dataInfo;
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVyZ2UtZWxlbWVudC1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3V0aWxzL21lcmdlLWVsZW1lbnQtb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQXNCLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsY0FBb0MsRUFBRSxFQUFFO0lBQ3hFLGNBQWMsR0FBRyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUNyRixNQUFNLGVBQWUsR0FBRyxDQUFDLEdBQUcscUJBQXFCLEVBQUUsR0FBRyxjQUFjLENBQUMsQ0FBQztJQUN0RSxNQUFNLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDcEIsZUFBZSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUMzQixNQUFNLEVBQUUsSUFBSSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsRUFBRSxvQkFBb0IsRUFBRSxHQUFHLElBQUksQ0FBQztRQUNqRixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2pCLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRztnQkFDYixJQUFJO2dCQUNKLG9CQUFvQjtnQkFDcEIsYUFBYTtnQkFDYixvQkFBb0I7YUFDdkIsQ0FBQztTQUNMO1FBQ0QsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLG9CQUFvQixHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLENBQUMsQ0FBQyxHQUFHLG9CQUFvQixFQUFFLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2pJLENBQUMsQ0FBQyxDQUFDO0lBQ0gsT0FBTyxRQUFRLENBQUM7QUFDcEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVmYXVsdEVsZW1lbnRPcHRpb25zLCBFbGVtZW50T3B0aW9uc0luZm8gfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcblxuZXhwb3J0IGNvbnN0IG1lcmdlRWxlbWVudE9wdGlvbnMgPSAoZWxlbWVudE9wdGlvbnM6IEVsZW1lbnRPcHRpb25zSW5mb1tdKSA9PiB7XG4gICAgZWxlbWVudE9wdGlvbnMgPSBlbGVtZW50T3B0aW9ucy5maWx0ZXIoaXRlbSA9PiBpdGVtLmluVmFsaWRDaGlsZHJlblR5cGVzLmxlbmd0aCA+IDApO1xuICAgIGNvbnN0IGNvbWJpbmF0aW9uRGF0YSA9IFsuLi5EZWZhdWx0RWxlbWVudE9wdGlvbnMsIC4uLmVsZW1lbnRPcHRpb25zXTtcbiAgICBjb25zdCBkYXRhSW5mbyA9IHt9O1xuICAgIGNvbWJpbmF0aW9uRGF0YS5mb3JFYWNoKGl0ZW0gPT4ge1xuICAgICAgICBjb25zdCB7IHR5cGUsIGluVmFsaWRDaGlsZHJlblR5cGVzLCBpc0luZGl2aXNpYmxlLCBpc1NlY29uZGFyeUNvbnRhaW5lciB9ID0gaXRlbTtcbiAgICAgICAgaWYgKCFkYXRhSW5mb1t0eXBlXSkge1xuICAgICAgICAgICAgZGF0YUluZm9bdHlwZV0gPSB7XG4gICAgICAgICAgICAgICAgdHlwZSxcbiAgICAgICAgICAgICAgICBpblZhbGlkQ2hpbGRyZW5UeXBlcyxcbiAgICAgICAgICAgICAgICBpc0luZGl2aXNpYmxlLFxuICAgICAgICAgICAgICAgIGlzU2Vjb25kYXJ5Q29udGFpbmVyXG4gICAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICAgIGRhdGFJbmZvW3R5cGVdLmluVmFsaWRDaGlsZHJlblR5cGVzID0gQXJyYXkuZnJvbShuZXcgU2V0KFsuLi5pblZhbGlkQ2hpbGRyZW5UeXBlcywgLi4uZGF0YUluZm9bdHlwZV0uaW5WYWxpZENoaWxkcmVuVHlwZXNdKSk7XG4gICAgfSk7XG4gICAgcmV0dXJuIGRhdGFJbmZvO1xufTtcbiJdfQ==
|