@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.
@@ -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
- const centerX = rectEditable.x + rectEditable.width / 2;
53
- let relativeElement = document.elementFromPoint(mode === 'highest' ? centerX : x, y);
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,{"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"]}
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
- const centerX = rectEditable.x + rectEditable.width / 2;
2223
- let relativeElement = document.elementFromPoint(mode === 'highest' ? centerX : x, y);
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-image-toolbar'],
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() && !this.isRichMediaScope()) {
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
- const relativeElement = document.elementFromPoint(centerX, event.y);
12793
- const relativeBlockCardElement = relativeElement.closest('.slate-block-card');
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]) {