@worktile/theia 2.3.0-next.2 → 2.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/worktile-theia.umd.js +23 -7
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/constants/default.d.ts +0 -1
- package/esm2015/constants/default.js +1 -1
- package/esm2015/editor.component.js +13 -3
- package/esm2015/plugins/image/image.component.js +8 -4
- package/esm2015/plugins/quick-insert/components/quick-insert.component.js +2 -2
- package/esm2015/utils/dom.js +5 -3
- package/fesm2015/worktile-theia.js +23 -8
- package/fesm2015/worktile-theia.js.map +1 -1
- package/package.json +1 -1
- package/plugins/image/image.component.scss +0 -10
- package/styles/editor.scss +152 -133
- package/styles/typo.scss +6 -0
package/esm2015/utils/dom.js
CHANGED
|
@@ -49,8 +49,10 @@ export function findRelativeElementByPoint(editor, x, y, mode) {
|
|
|
49
49
|
const editableElement = EDITOR_TO_ELEMENT.get(editor);
|
|
50
50
|
const rectEditable = editableElement.getBoundingClientRect();
|
|
51
51
|
if (x > rectEditable.x && x < rectEditable.x + rectEditable.width) {
|
|
52
|
-
|
|
53
|
-
|
|
52
|
+
let { paddingLeft } = window.getComputedStyle(editableElement, null);
|
|
53
|
+
const paddingLeftPixels = coercePixelsFromCssValue(paddingLeft);
|
|
54
|
+
const startX = rectEditable.left + paddingLeftPixels;
|
|
55
|
+
let relativeElement = document.elementFromPoint(mode === 'highest' ? startX : x, y);
|
|
54
56
|
return relativeElement;
|
|
55
57
|
}
|
|
56
58
|
return null;
|
|
@@ -82,4 +84,4 @@ export function findNodeEntryByPoint(editor, x, y, mode) {
|
|
|
82
84
|
}
|
|
83
85
|
return null;
|
|
84
86
|
}
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# 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        let { paddingLeft } = window.getComputedStyle(editableElement, null);\n        const paddingLeftPixels = coercePixelsFromCssValue(paddingLeft);\n        const startX = rectEditable.left + paddingLeftPixels;\n        let relativeElement = document.elementFromPoint(mode === 'highest' ? startX : 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"]}
|
|
@@ -2219,8 +2219,10 @@ function findRelativeElementByPoint(editor, x, y, mode) {
|
|
|
2219
2219
|
const editableElement = EDITOR_TO_ELEMENT.get(editor);
|
|
2220
2220
|
const rectEditable = editableElement.getBoundingClientRect();
|
|
2221
2221
|
if (x > rectEditable.x && x < rectEditable.x + rectEditable.width) {
|
|
2222
|
-
|
|
2223
|
-
|
|
2222
|
+
let { paddingLeft } = window.getComputedStyle(editableElement, null);
|
|
2223
|
+
const paddingLeftPixels = coercePixelsFromCssValue(paddingLeft);
|
|
2224
|
+
const startX = rectEditable.left + paddingLeftPixels;
|
|
2225
|
+
let relativeElement = document.elementFromPoint(mode === 'highest' ? startX : x, y);
|
|
2224
2226
|
return relativeElement;
|
|
2225
2227
|
}
|
|
2226
2228
|
return null;
|
|
@@ -2688,13 +2690,13 @@ class TheImageComponent extends TheBaseElementComponent {
|
|
|
2688
2690
|
{
|
|
2689
2691
|
key: LayoutTypes.wrapLeft,
|
|
2690
2692
|
icon: 'wrap-left',
|
|
2691
|
-
name: '
|
|
2693
|
+
name: '图片居左',
|
|
2692
2694
|
handle: (e, key) => this.setImageNode(e, { layout: key })
|
|
2693
2695
|
},
|
|
2694
2696
|
{
|
|
2695
2697
|
key: LayoutTypes.wrapRight,
|
|
2696
2698
|
icon: 'wrap-right',
|
|
2697
|
-
name: '
|
|
2699
|
+
name: '图片居右',
|
|
2698
2700
|
handle: (e, key) => this.setImageNode(e, { layout: key })
|
|
2699
2701
|
},
|
|
2700
2702
|
{
|
|
@@ -2900,7 +2902,7 @@ class TheImageComponent extends TheBaseElementComponent {
|
|
|
2900
2902
|
var _a;
|
|
2901
2903
|
this.layoutToolbarRef = this.thyPopover.open(this.layoutToolbar, {
|
|
2902
2904
|
origin: this.imageContent,
|
|
2903
|
-
panelClass: ['the-
|
|
2905
|
+
panelClass: ['the-block-toolbar'],
|
|
2904
2906
|
placement: 'bottom',
|
|
2905
2907
|
insideClosable: false,
|
|
2906
2908
|
backdropClosable: true,
|
|
@@ -2910,6 +2912,10 @@ class TheImageComponent extends TheBaseElementComponent {
|
|
|
2910
2912
|
scrollStrategy: this.overlay.scrollStrategies.reposition()
|
|
2911
2913
|
});
|
|
2912
2914
|
(_a = this.layoutToolbarRef) === null || _a === void 0 ? void 0 : _a.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());
|
|
2915
|
+
setTimeout(() => {
|
|
2916
|
+
var _a;
|
|
2917
|
+
(_a = this.layoutToolbarRef) === null || _a === void 0 ? void 0 : _a.getOverlayRef().updatePosition();
|
|
2918
|
+
}, 150);
|
|
2913
2919
|
}
|
|
2914
2920
|
closeLayoutToolbar() {
|
|
2915
2921
|
var _a;
|
|
@@ -12339,7 +12345,7 @@ class TheQuickInsertComponent {
|
|
|
12339
12345
|
checkStatus() {
|
|
12340
12346
|
var _a;
|
|
12341
12347
|
const { editor } = this;
|
|
12342
|
-
if (this.isVisible && isCleanEmptyParagraph(editor) && !this.hasExcludeAttribute()
|
|
12348
|
+
if (this.isVisible && isCleanEmptyParagraph(editor) && !this.hasExcludeAttribute()) {
|
|
12343
12349
|
const block = Node.ancestor(editor, [(_a = editor === null || editor === void 0 ? void 0 : editor.selection) === null || _a === void 0 ? void 0 : _a.anchor.path[0]]);
|
|
12344
12350
|
const rootNode = AngularEditor.toDOMNode(editor, block);
|
|
12345
12351
|
this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);
|
|
@@ -12789,8 +12795,17 @@ class TheEditorComponent extends mixinUnsubscribe(MixinBase) {
|
|
|
12789
12795
|
if (event.target === editableElement) {
|
|
12790
12796
|
const rectEditable = editableElement.getBoundingClientRect();
|
|
12791
12797
|
const centerX = rectEditable.x + rectEditable.width / 2;
|
|
12792
|
-
|
|
12793
|
-
const
|
|
12798
|
+
let { paddingLeft, paddingRight } = window.getComputedStyle(editableElement, null);
|
|
12799
|
+
const paddingLeftPixels = coercePixelsFromCssValue(paddingLeft);
|
|
12800
|
+
const paddingRightPixels = coercePixelsFromCssValue(paddingRight);
|
|
12801
|
+
const fakeLeftX = rectEditable.x + paddingLeftPixels + 50;
|
|
12802
|
+
const fakeRightX = rectEditable.right - paddingRightPixels - 50;
|
|
12803
|
+
let relativeElement = document.elementFromPoint(fakeLeftX, event.y);
|
|
12804
|
+
let relativeBlockCardElement = relativeElement.closest('.slate-block-card');
|
|
12805
|
+
if (!relativeBlockCardElement) {
|
|
12806
|
+
relativeElement = document.elementFromPoint(fakeRightX, event.y);
|
|
12807
|
+
relativeBlockCardElement = relativeElement.closest('.slate-block-card');
|
|
12808
|
+
}
|
|
12794
12809
|
if (relativeBlockCardElement) {
|
|
12795
12810
|
const blockCardEntry = AngularEditor.toSlateCardEntry(this.editor, relativeBlockCardElement.firstElementChild);
|
|
12796
12811
|
if (blockCardEntry && blockCardEntry[1]) {
|