@worktile/theia 16.1.6 → 16.1.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/esm2020/plugins/quick-insert/components/quick-insert.component.mjs +14 -18
- package/fesm2015/worktile-theia.mjs +13 -17
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +13 -17
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/quick-insert/components/quick-insert.component.d.ts +1 -2
|
@@ -29,34 +29,30 @@ export class TheQuickInsertComponent {
|
|
|
29
29
|
if (this.editor && this.editor.options && !this.editor.options.readonly) {
|
|
30
30
|
// wait isOpenedMenu is updated
|
|
31
31
|
setTimeout(() => {
|
|
32
|
-
this.
|
|
32
|
+
this.updateIconDisplay();
|
|
33
33
|
}, 0);
|
|
34
34
|
}
|
|
35
35
|
};
|
|
36
|
-
this.
|
|
36
|
+
this.updateIconDisplay();
|
|
37
37
|
}
|
|
38
38
|
ngOnChanges(changes) {
|
|
39
39
|
if (changes.isVisible && !changes.isVisible.firstChange) {
|
|
40
|
-
this.
|
|
40
|
+
this.updateIconDisplay();
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
|
-
|
|
43
|
+
updateIconDisplay() {
|
|
44
44
|
const { editor } = this;
|
|
45
|
-
|
|
45
|
+
if (this.isVisible &&
|
|
46
46
|
!QuickInsertEditor.isOpenedMenu(editor) &&
|
|
47
47
|
isCleanEmptyParagraph(editor) &&
|
|
48
48
|
!this.hasExcludeAttribute() &&
|
|
49
|
-
!this.isRichMediaScope()
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
const rootNode = AngularEditor.toDOMNode(editor, block);
|
|
55
|
-
this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
this.addHiddenClass();
|
|
49
|
+
!this.isRichMediaScope()) {
|
|
50
|
+
const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);
|
|
51
|
+
const rootNode = AngularEditor.toDOMNode(editor, block);
|
|
52
|
+
this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);
|
|
53
|
+
return;
|
|
59
54
|
}
|
|
55
|
+
this.addHiddenClass();
|
|
60
56
|
}
|
|
61
57
|
addHiddenClass() {
|
|
62
58
|
this.elementRef.nativeElement.classList.add('d-none');
|
|
@@ -102,9 +98,9 @@ export class TheQuickInsertComponent {
|
|
|
102
98
|
QuickInsertEditor.openMenu(this.editor)
|
|
103
99
|
.afterClosed()
|
|
104
100
|
.subscribe(() => {
|
|
105
|
-
this.
|
|
101
|
+
this.updateIconDisplay();
|
|
106
102
|
});
|
|
107
|
-
this.
|
|
103
|
+
this.updateIconDisplay();
|
|
108
104
|
}, 100);
|
|
109
105
|
}
|
|
110
106
|
}
|
|
@@ -127,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
127
123
|
type: HostListener,
|
|
128
124
|
args: ['mousedown', ['$event']]
|
|
129
125
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-insert.component.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.ts","../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    Input,\n    HostListener,\n    Renderer2,\n    ChangeDetectorRef,\n    ViewChild,\n    OnInit,\n    HostBinding,\n    OnChanges,\n    SimpleChanges\n} from '@angular/core';\nimport { Editor, Node } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { MarkTypes } from '../../../constants/node-types';\nimport { isCleanEmptyParagraph } from '../../../utils/is-clean-empty-paragraph';\nimport { QuickInsertEditor } from '../quick-insert.editor';\nimport * as TheQueries from '../../../queries';\nimport { ToolbarItem } from '../../../interfaces/toolbar';\n\n@Component({\n    selector: '[theQuickInsert]',\n    templateUrl: './quick-insert.component.html'\n})\nexport class TheQuickInsertComponent implements OnInit, OnChanges {\n    @HostBinding('class')\n    className = 'the-quick-insert';\n\n    @Input() editor: Editor;\n\n    @Input() isVisible = false;\n\n    defaultIconName = 'plus-circle-thin';\n\n    iconNameFill = 'plus-circle-thin-fill';\n\n    displayIconName = this.defaultIconName;\n\n    showPlusIcon: boolean;\n\n    @ViewChild('iconElement', { read: ElementRef, static: false })\n    iconElement: ElementRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    handleMousedownNativeElement(event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    constructor(private renderer: Renderer2, private elementRef: ElementRef<HTMLElement>, private cdr: ChangeDetectorRef) {}\n\n    ngOnInit(): void {\n        const { onChange } = this.editor;\n        this.editor.onChange = () => {\n            onChange();\n\n            if (this.editor && this.editor.options && !this.editor.options.readonly) {\n                // wait isOpenedMenu is updated\n                setTimeout(() => {\n                    this.checkStatus();\n                }, 0);\n            }\n        };\n        this.checkStatus();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.isVisible && !changes.isVisible.firstChange) {\n            this.checkStatus();\n        }\n    }\n\n    public checkStatus() {\n        const { editor } = this;\n        const showPlusIcon =\n            this.isVisible &&\n            !QuickInsertEditor.isOpenedMenu(editor) &&\n            isCleanEmptyParagraph(editor) &&\n            !this.hasExcludeAttribute() &&\n            !this.isRichMediaScope();\n        if (showPlusIcon !== this.showPlusIcon) {\n            this.showPlusIcon = showPlusIcon;\n            if (this.showPlusIcon) {\n                const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n                const rootNode: HTMLElement = AngularEditor.toDOMNode(editor, block);\n                this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);\n                return;\n            }\n            this.addHiddenClass();\n        }\n    }\n\n    private addHiddenClass() {\n        this.elementRef.nativeElement.classList.add('d-none');\n    }\n\n    private removeHiddenClass() {\n        this.elementRef.nativeElement.classList.remove('d-none');\n    }\n\n    private isRichMediaScope() {\n        const { editor } = this;\n        if (editor?.selection) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootElement = AngularEditor.toDOMNode(editor, block);\n            const leafElement = rootElement.querySelector('[data-slate-leaf=\"true\"]');\n            const rootElementRect = rootElement.getBoundingClientRect();\n            const leafElementRect = leafElement.getBoundingClientRect();\n            return leafElementRect?.x !== rootElementRect?.x;\n        }\n        return false;\n    }\n\n    private hasExcludeAttribute() {\n        const marks = TheQueries.getSelectionMarks(this.editor);\n        const fontSizeMark: number = marks[MarkTypes.fontSize];\n\n        return fontSizeMark;\n    }\n\n    private updatePosition(left: number, top?: number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${top}px`);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${left}px`);\n        this.removeHiddenClass();\n    }\n\n    mouseEnter(event: MouseEvent) {\n        this.displayIconName = this.iconNameFill;\n        this.cdr.markForCheck();\n    }\n\n    mouseLeave(event: MouseEvent) {\n        this.displayIconName = this.defaultIconName;\n        this.cdr.markForCheck();\n    }\n\n    handleClick(event: MouseEvent) {\n        event.stopPropagation();\n        event.preventDefault();\n        // avoid popover is closed immediately\n        setTimeout(() => {\n            QuickInsertEditor.openMenu(this.editor)\n                .afterClosed()\n                .subscribe(() => {\n                    this.checkStatus();\n                });\n            this.checkStatus();\n        }, 100);\n    }\n}\n","<thy-icon\n  #iconElement\n  [thyIconName]=\"displayIconName\"\n  class=\"quick-insert-icon text-desc font-size-xlg\"\n  (mouseenter)=\"mouseEnter($event)\"\n  (mouseleave)=\"mouseLeave($event)\"\n  (mousedown)=\"handleClick($event)\"\n></thy-icon>\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-insert.component.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.ts","../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    Input,\n    HostListener,\n    Renderer2,\n    ChangeDetectorRef,\n    ViewChild,\n    OnInit,\n    HostBinding,\n    OnChanges,\n    SimpleChanges\n} from '@angular/core';\nimport { Editor, Node } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { MarkTypes } from '../../../constants/node-types';\nimport { isCleanEmptyParagraph } from '../../../utils/is-clean-empty-paragraph';\nimport { QuickInsertEditor } from '../quick-insert.editor';\nimport * as TheQueries from '../../../queries';\n\n@Component({\n    selector: '[theQuickInsert]',\n    templateUrl: './quick-insert.component.html'\n})\nexport class TheQuickInsertComponent implements OnInit, OnChanges {\n    @HostBinding('class')\n    className = 'the-quick-insert';\n\n    @Input() editor: Editor;\n\n    @Input() isVisible = false;\n\n    defaultIconName = 'plus-circle-thin';\n\n    iconNameFill = 'plus-circle-thin-fill';\n\n    displayIconName = this.defaultIconName;\n\n    @ViewChild('iconElement', { read: ElementRef, static: false })\n    iconElement: ElementRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    handleMousedownNativeElement(event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    constructor(private renderer: Renderer2, private elementRef: ElementRef<HTMLElement>, private cdr: ChangeDetectorRef) {}\n\n    ngOnInit(): void {\n        const { onChange } = this.editor;\n        this.editor.onChange = () => {\n            onChange();\n\n            if (this.editor && this.editor.options && !this.editor.options.readonly) {\n                // wait isOpenedMenu is updated\n                setTimeout(() => {\n                    this.updateIconDisplay();\n                }, 0);\n            }\n        };\n        this.updateIconDisplay();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.isVisible && !changes.isVisible.firstChange) {\n            this.updateIconDisplay();\n        }\n    }\n\n    public updateIconDisplay() {\n        const { editor } = this;\n        if (\n            this.isVisible &&\n            !QuickInsertEditor.isOpenedMenu(editor) &&\n            isCleanEmptyParagraph(editor) &&\n            !this.hasExcludeAttribute() &&\n            !this.isRichMediaScope()\n        ) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootNode: HTMLElement = AngularEditor.toDOMNode(editor, block);\n            this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);\n            return;\n        }\n        this.addHiddenClass();\n    }\n\n    private addHiddenClass() {\n        this.elementRef.nativeElement.classList.add('d-none');\n    }\n\n    private removeHiddenClass() {\n        this.elementRef.nativeElement.classList.remove('d-none');\n    }\n\n    private isRichMediaScope() {\n        const { editor } = this;\n        if (editor?.selection) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootElement = AngularEditor.toDOMNode(editor, block);\n            const leafElement = rootElement.querySelector('[data-slate-leaf=\"true\"]');\n            const rootElementRect = rootElement.getBoundingClientRect();\n            const leafElementRect = leafElement.getBoundingClientRect();\n            return leafElementRect?.x !== rootElementRect?.x;\n        }\n        return false;\n    }\n\n    private hasExcludeAttribute() {\n        const marks = TheQueries.getSelectionMarks(this.editor);\n        const fontSizeMark: number = marks[MarkTypes.fontSize];\n\n        return fontSizeMark;\n    }\n\n    private updatePosition(left: number, top?: number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${top}px`);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${left}px`);\n        this.removeHiddenClass();\n    }\n\n    mouseEnter(event: MouseEvent) {\n        this.displayIconName = this.iconNameFill;\n        this.cdr.markForCheck();\n    }\n\n    mouseLeave(event: MouseEvent) {\n        this.displayIconName = this.defaultIconName;\n        this.cdr.markForCheck();\n    }\n\n    handleClick(event: MouseEvent) {\n        event.stopPropagation();\n        event.preventDefault();\n        // avoid popover is closed immediately\n        setTimeout(() => {\n            QuickInsertEditor.openMenu(this.editor)\n                .afterClosed()\n                .subscribe(() => {\n                    this.updateIconDisplay();\n                });\n            this.updateIconDisplay();\n        }, 100);\n    }\n}\n","<thy-icon\n  #iconElement\n  [thyIconName]=\"displayIconName\"\n  class=\"quick-insert-icon text-desc font-size-xlg\"\n  (mouseenter)=\"mouseEnter($event)\"\n  (mouseleave)=\"mouseLeave($event)\"\n  (mousedown)=\"handleClick($event)\"\n></thy-icon>\n"]}
|
|
@@ -15924,35 +15924,31 @@ class TheQuickInsertComponent {
|
|
|
15924
15924
|
if (this.editor && this.editor.options && !this.editor.options.readonly) {
|
|
15925
15925
|
// wait isOpenedMenu is updated
|
|
15926
15926
|
setTimeout(() => {
|
|
15927
|
-
this.
|
|
15927
|
+
this.updateIconDisplay();
|
|
15928
15928
|
}, 0);
|
|
15929
15929
|
}
|
|
15930
15930
|
};
|
|
15931
|
-
this.
|
|
15931
|
+
this.updateIconDisplay();
|
|
15932
15932
|
}
|
|
15933
15933
|
ngOnChanges(changes) {
|
|
15934
15934
|
if (changes.isVisible && !changes.isVisible.firstChange) {
|
|
15935
|
-
this.
|
|
15935
|
+
this.updateIconDisplay();
|
|
15936
15936
|
}
|
|
15937
15937
|
}
|
|
15938
|
-
|
|
15938
|
+
updateIconDisplay() {
|
|
15939
15939
|
var _a;
|
|
15940
15940
|
const { editor } = this;
|
|
15941
|
-
|
|
15941
|
+
if (this.isVisible &&
|
|
15942
15942
|
!QuickInsertEditor.isOpenedMenu(editor) &&
|
|
15943
15943
|
isCleanEmptyParagraph(editor) &&
|
|
15944
15944
|
!this.hasExcludeAttribute() &&
|
|
15945
|
-
!this.isRichMediaScope()
|
|
15946
|
-
|
|
15947
|
-
|
|
15948
|
-
|
|
15949
|
-
|
|
15950
|
-
const rootNode = AngularEditor.toDOMNode(editor, block);
|
|
15951
|
-
this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);
|
|
15952
|
-
return;
|
|
15953
|
-
}
|
|
15954
|
-
this.addHiddenClass();
|
|
15945
|
+
!this.isRichMediaScope()) {
|
|
15946
|
+
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]]);
|
|
15947
|
+
const rootNode = AngularEditor.toDOMNode(editor, block);
|
|
15948
|
+
this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);
|
|
15949
|
+
return;
|
|
15955
15950
|
}
|
|
15951
|
+
this.addHiddenClass();
|
|
15956
15952
|
}
|
|
15957
15953
|
addHiddenClass() {
|
|
15958
15954
|
this.elementRef.nativeElement.classList.add('d-none');
|
|
@@ -15999,9 +15995,9 @@ class TheQuickInsertComponent {
|
|
|
15999
15995
|
QuickInsertEditor.openMenu(this.editor)
|
|
16000
15996
|
.afterClosed()
|
|
16001
15997
|
.subscribe(() => {
|
|
16002
|
-
this.
|
|
15998
|
+
this.updateIconDisplay();
|
|
16003
15999
|
});
|
|
16004
|
-
this.
|
|
16000
|
+
this.updateIconDisplay();
|
|
16005
16001
|
}, 100);
|
|
16006
16002
|
}
|
|
16007
16003
|
}
|