slate-angular 1.7.0 → 1.7.5
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/slate-angular.umd.js +64 -22
- package/bundles/slate-angular.umd.js.map +1 -1
- package/components/editable/editable.component.d.ts +1 -0
- package/components/leaf/default-leaf.component.d.ts +4 -1
- package/esm2015/components/editable/editable.component.js +29 -19
- package/esm2015/components/leaf/default-leaf.component.js +11 -12
- package/esm2015/view/base.js +27 -2
- package/fesm2015/slate-angular.js +64 -29
- package/fesm2015/slate-angular.js.map +1 -1
- package/package.json +7 -7
- package/styles/index.scss +20 -4
- package/view/base.d.ts +3 -0
|
@@ -2,28 +2,27 @@ import { ChangeDetectionStrategy, Component } from "@angular/core";
|
|
|
2
2
|
import { BaseLeafComponent } from "../../view/base";
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../string/string.component";
|
|
5
|
-
import * as i2 from "@angular/common";
|
|
6
5
|
export class SlateDefaultLeafComponent extends BaseLeafComponent {
|
|
6
|
+
onContextChange() {
|
|
7
|
+
super.onContextChange();
|
|
8
|
+
this.renderPlaceholder();
|
|
9
|
+
}
|
|
10
|
+
ngOnDestroy() {
|
|
11
|
+
// Because the placeholder span is not in the current component, it is destroyed along with the current component
|
|
12
|
+
this.destroyPlaceholder();
|
|
13
|
+
}
|
|
7
14
|
}
|
|
8
15
|
SlateDefaultLeafComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SlateDefaultLeafComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
-
SlateDefaultLeafComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: SlateDefaultLeafComponent, selector: "span[slateDefaultLeaf]", host: { attributes: { "data-slate-leaf": "true" } }, usesInheritance: true, ngImport: i0, template:
|
|
10
|
-
<ng-container *ngIf="context.leaf['placeholder']">
|
|
11
|
-
<span contenteditable="false" data-slate-placeholder="true" slate-placeholder="true">{{context.leaf['placeholder']}}</span>
|
|
12
|
-
</ng-container>
|
|
13
|
-
<span slateString [context]="context" [viewContext]="viewContext"><span>`, isInline: true, components: [{ type: i1.SlateStringComponent, selector: "span[slateString]", inputs: ["context"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
16
|
+
SlateDefaultLeafComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: SlateDefaultLeafComponent, selector: "span[slateDefaultLeaf]", host: { attributes: { "data-slate-leaf": "true" } }, usesInheritance: true, ngImport: i0, template: `<span slateString [context]="context" [viewContext]="viewContext"><span>`, isInline: true, components: [{ type: i1.SlateStringComponent, selector: "span[slateString]", inputs: ["context"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
14
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SlateDefaultLeafComponent, decorators: [{
|
|
15
18
|
type: Component,
|
|
16
19
|
args: [{
|
|
17
20
|
selector: 'span[slateDefaultLeaf]',
|
|
18
|
-
template:
|
|
19
|
-
<ng-container *ngIf="context.leaf['placeholder']">
|
|
20
|
-
<span contenteditable="false" data-slate-placeholder="true" slate-placeholder="true">{{context.leaf['placeholder']}}</span>
|
|
21
|
-
</ng-container>
|
|
22
|
-
<span slateString [context]="context" [viewContext]="viewContext"><span>`,
|
|
21
|
+
template: `<span slateString [context]="context" [viewContext]="viewContext"><span>`,
|
|
23
22
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
24
23
|
host: {
|
|
25
24
|
'data-slate-leaf': 'true'
|
|
26
25
|
}
|
|
27
26
|
}]
|
|
28
27
|
}] });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1sZWFmLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb21wb25lbnRzL2xlYWYvZGVmYXVsdC1sZWFmLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQzlFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFVcEQsTUFBTSxPQUFPLHlCQUEwQixTQUFRLGlCQUFpQjtJQUM1RCxlQUFlO1FBQ1gsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFDRCxXQUFXO1FBQ1AsaUhBQWlIO1FBQ2pILElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQzlCLENBQUM7O3NIQVJRLHlCQUF5QjswR0FBekIseUJBQXlCLDBJQU54QiwwRUFBMEU7MkZBTTNFLHlCQUF5QjtrQkFSckMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsd0JBQXdCO29CQUNsQyxRQUFRLEVBQUUsMEVBQTBFO29CQUNwRixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsSUFBSSxFQUFFO3dCQUNGLGlCQUFpQixFQUFFLE1BQU07cUJBQzVCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkRlc3Ryb3kgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQmFzZUxlYWZDb21wb25lbnQgfSBmcm9tIFwiLi4vLi4vdmlldy9iYXNlXCI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc3BhbltzbGF0ZURlZmF1bHRMZWFmXScsXG4gICAgdGVtcGxhdGU6IGA8c3BhbiBzbGF0ZVN0cmluZyBbY29udGV4dF09XCJjb250ZXh0XCIgW3ZpZXdDb250ZXh0XT1cInZpZXdDb250ZXh0XCI+PHNwYW4+YCxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0OiB7XG4gICAgICAgICdkYXRhLXNsYXRlLWxlYWYnOiAndHJ1ZSdcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFNsYXRlRGVmYXVsdExlYWZDb21wb25lbnQgZXh0ZW5kcyBCYXNlTGVhZkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gICAgb25Db250ZXh0Q2hhbmdlKCk6IHZvaWQge1xuICAgICAgICBzdXBlci5vbkNvbnRleHRDaGFuZ2UoKTtcbiAgICAgICAgdGhpcy5yZW5kZXJQbGFjZWhvbGRlcigpO1xuICAgIH1cbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgLy8gQmVjYXVzZSB0aGUgcGxhY2Vob2xkZXIgc3BhbiBpcyBub3QgaW4gdGhlIGN1cnJlbnQgY29tcG9uZW50LCBpdCBpcyBkZXN0cm95ZWQgYWxvbmcgd2l0aCB0aGUgY3VycmVudCBjb21wb25lbnRcbiAgICAgICAgdGhpcy5kZXN0cm95UGxhY2Vob2xkZXIoKTtcbiAgICB9XG59Il19
|
package/esm2015/view/base.js
CHANGED
|
@@ -61,6 +61,31 @@ export class BaseLeafComponent extends BaseComponent {
|
|
|
61
61
|
}
|
|
62
62
|
this.cdr.markForCheck();
|
|
63
63
|
}
|
|
64
|
+
renderPlaceholder() {
|
|
65
|
+
// issue-1: IME input was interrupted
|
|
66
|
+
// issue-2: IME input focus jumping
|
|
67
|
+
// Issue occurs when the span node of the placeholder is before the slateString span node
|
|
68
|
+
if (this.context.leaf['placeholder']) {
|
|
69
|
+
if (!this.placeholderElement) {
|
|
70
|
+
this.placeholderElement = document.createElement('span');
|
|
71
|
+
this.placeholderElement.innerText = this.context.leaf['placeholder'];
|
|
72
|
+
this.placeholderElement.contentEditable = 'false';
|
|
73
|
+
this.placeholderElement.setAttribute('data-slate-placeholder', 'true');
|
|
74
|
+
this.nativeElement.classList.add('leaf-with-placeholder');
|
|
75
|
+
this.nativeElement.appendChild(this.placeholderElement);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
this.destroyPlaceholder();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
destroyPlaceholder() {
|
|
83
|
+
if (this.placeholderElement) {
|
|
84
|
+
this.placeholderElement.remove();
|
|
85
|
+
this.placeholderElement = null;
|
|
86
|
+
this.nativeElement.classList.remove('leaf-with-placeholder');
|
|
87
|
+
}
|
|
88
|
+
}
|
|
64
89
|
}
|
|
65
90
|
BaseLeafComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: BaseLeafComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
66
91
|
BaseLeafComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.7", type: BaseLeafComponent, host: { properties: { "attr.data-slate-leaf": "this.isSlateLeaf" } }, usesInheritance: true, ngImport: i0 });
|
|
@@ -148,7 +173,7 @@ export class BaseTextComponent extends BaseComponent {
|
|
|
148
173
|
this.initialized = false;
|
|
149
174
|
}
|
|
150
175
|
get text() {
|
|
151
|
-
return this._context.text;
|
|
176
|
+
return this._context && this._context.text;
|
|
152
177
|
}
|
|
153
178
|
ngOnInit() {
|
|
154
179
|
this.updateWeakMap();
|
|
@@ -176,4 +201,4 @@ BaseTextComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", vers
|
|
|
176
201
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: BaseTextComponent, decorators: [{
|
|
177
202
|
type: Directive
|
|
178
203
|
}] });
|
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../packages/src/view/base.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Directive, ElementRef, HostBinding, Input, OnDestroy, OnInit } from \"@angular/core\";\nimport { AngularEditor } from \"../plugins/angular-editor\";\nimport { ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, NODE_TO_ELEMENT } from \"../utils/weak-maps\";\nimport { SlateViewContext, SlateElementContext, SlateTextContext, SlateLeafContext } from \"./context\";\nimport { Descendant, Element, Range, Text } from 'slate';\nimport { SlateChildrenContext } from \"./context\";\nimport { hasBeforeContextChange } from \"./before-context-change\";\n\n/**\n * base class for template\n */\nexport interface BaseEmbeddedView<T, K extends AngularEditor = AngularEditor> {\n    context: T;\n    viewContext: SlateViewContext<K>;\n}\n\n/**\n * base class for custom element component or text component\n */\n@Directive()\nexport abstract class BaseComponent<T = SlateTextContext | SlateLeafContext | SlateElementContext, K extends AngularEditor = AngularEditor> {\n    protected _context: T;\n\n    @Input()\n    set context(value: T) {\n        if (hasBeforeContextChange<T>(this)) {\n            this.beforeContextChange(value);\n        }\n        this._context = value;\n        this.onContextChange();\n    }\n\n    get context() {\n        return this._context;\n    }\n\n    @Input() viewContext: SlateViewContext<K>;\n\n    get editor() {\n        return this.viewContext && this.viewContext.editor;\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) { }\n\n    abstract onContextChange();\n}\n\n/**\n * base class for custom leaf component\n */\n@Directive()\nexport class BaseLeafComponent extends BaseComponent<SlateLeafContext> implements OnInit {\n    initialized = false;\n\n    @HostBinding('attr.data-slate-leaf')  isSlateLeaf = true\n\n    get text(): Text {\n        return this.context && this.context.text;\n    }\n\n    get leaf(): Text {\n        return this.context && this.context.leaf;\n    }\n\n    ngOnInit() {\n        this.initialized = true;\n    }\n\n    onContextChange() {\n        if (!this.initialized) {\n            return;\n        }\n        this.cdr.markForCheck();\n    }\n}\n\n/**\n * base class for custom element component\n */\n@Directive()\nexport class BaseElementComponent<T extends Element = Element, K extends AngularEditor = AngularEditor> extends BaseComponent<SlateElementContext<T>, K> implements OnInit, OnDestroy {\n    initialized = false;\n\n    childrenContext: SlateChildrenContext;\n\n    get element(): T {\n        return this._context && this._context.element;\n    }\n\n    get selection(): Range {\n        return this._context && this._context.selection;\n    }\n\n    get decorations(): Range[] {\n        return this._context && this._context.decorations;\n    }\n\n    get children(): Descendant[] {\n        return this._context && this._context.element.children;\n    }\n\n    get isCollapsed() {\n        return this.selection && Range.isCollapsed(this.editor.selection);\n    }\n\n    get readonly() {\n        return this._context && this._context.readonly;\n    }\n\n    ngOnInit() {\n        this.updateWeakMap();\n        for (const key in this._context.attributes) {\n            this.nativeElement.setAttribute(key, this._context.attributes[key]);\n        }\n        this.initialized = true;\n    }\n\n    updateWeakMap() {\n        NODE_TO_ELEMENT.set(this.element, this.nativeElement);\n        ELEMENT_TO_NODE.set(this.nativeElement, this.element);\n        ELEMENT_TO_COMPONENT.set(this.element, this);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.element) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.element);\n        }\n        if (ELEMENT_TO_COMPONENT.get(this.element) === this) {\n            ELEMENT_TO_COMPONENT.delete(this.element);\n        }\n    }\n\n    onContextChange() {\n        this.childrenContext = this.getChildrenContext();\n        if (!this.initialized) {\n            return;\n        }\n        this.cdr.markForCheck();\n        this.updateWeakMap();\n    }\n\n    getChildrenContext(): SlateChildrenContext {\n        return {\n            parent: this._context.element,\n            selection: this._context.selection,\n            decorations: this._context.decorations,\n            decorate: this._context.decorate,\n            readonly: this._context.readonly\n        };\n    }\n}\n\n/**\n * base class for custom text component\n */\n@Directive()\nexport class BaseTextComponent extends BaseComponent<SlateTextContext> implements OnInit, OnDestroy {\n    initialized = false;\n\n    get text(): Text {\n        return this._context.text;\n    }\n\n    ngOnInit() {\n        this.updateWeakMap();\n        this.initialized = true;\n    }\n\n    updateWeakMap() {\n        ELEMENT_TO_NODE.set(this.nativeElement, this.text);\n        NODE_TO_ELEMENT.set(this.text, this.nativeElement);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.text) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.text);\n        }\n    }\n\n    onContextChange() {\n        if (!this.initialized) {\n            return;\n        }\n\n        this.cdr.markForCheck();\n        this.updateWeakMap();\n    }\n}\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../packages/src/view/base.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Directive, ElementRef, HostBinding, Input, OnDestroy, OnInit } from \"@angular/core\";\nimport { AngularEditor } from \"../plugins/angular-editor\";\nimport { ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, NODE_TO_ELEMENT } from \"../utils/weak-maps\";\nimport { SlateViewContext, SlateElementContext, SlateTextContext, SlateLeafContext } from \"./context\";\nimport { Descendant, Element, Range, Text } from 'slate';\nimport { SlateChildrenContext } from \"./context\";\nimport { hasBeforeContextChange } from \"./before-context-change\";\n\n/**\n * base class for template\n */\nexport interface BaseEmbeddedView<T, K extends AngularEditor = AngularEditor> {\n    context: T;\n    viewContext: SlateViewContext<K>;\n}\n\n/**\n * base class for custom element component or text component\n */\n@Directive()\nexport abstract class BaseComponent<T = SlateTextContext | SlateLeafContext | SlateElementContext, K extends AngularEditor = AngularEditor> {\n    protected _context: T;\n\n    @Input()\n    set context(value: T) {\n        if (hasBeforeContextChange<T>(this)) {\n            this.beforeContextChange(value);\n        }\n        this._context = value;\n        this.onContextChange();\n    }\n\n    get context() {\n        return this._context;\n    }\n\n    @Input() viewContext: SlateViewContext<K>;\n\n    get editor() {\n        return this.viewContext && this.viewContext.editor;\n    }\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) { }\n\n    abstract onContextChange();\n}\n\n/**\n * base class for custom leaf component\n */\n@Directive()\nexport class BaseLeafComponent extends BaseComponent<SlateLeafContext> implements OnInit {\n    initialized = false;\n\n    placeholderElement: HTMLSpanElement;\n\n    @HostBinding('attr.data-slate-leaf') isSlateLeaf = true\n\n    get text(): Text {\n        return this.context && this.context.text;\n    }\n\n    get leaf(): Text {\n        return this.context && this.context.leaf;\n    }\n\n    ngOnInit() {\n        this.initialized = true;\n    }\n\n    onContextChange() {\n        if (!this.initialized) {\n            return;\n        }\n        this.cdr.markForCheck();\n    }\n\n    renderPlaceholder() {\n        // issue-1: IME input was interrupted\n        // issue-2: IME input focus jumping\n        // Issue occurs when the span node of the placeholder is before the slateString span node\n        if (this.context.leaf['placeholder']) {\n            if (!this.placeholderElement) {\n                this.placeholderElement = document.createElement('span');\n                this.placeholderElement.innerText = this.context.leaf['placeholder'];\n                this.placeholderElement.contentEditable = 'false';\n                this.placeholderElement.setAttribute('data-slate-placeholder', 'true');\n                this.nativeElement.classList.add('leaf-with-placeholder');\n                this.nativeElement.appendChild(this.placeholderElement);\n            }\n        } else {\n            this.destroyPlaceholder();\n        }\n    }\n\n    destroyPlaceholder() {\n        if (this.placeholderElement) {\n            this.placeholderElement.remove();\n            this.placeholderElement = null;\n            this.nativeElement.classList.remove('leaf-with-placeholder');\n        }\n    }\n}\n\n/**\n * base class for custom element component\n */\n@Directive()\nexport class BaseElementComponent<T extends Element = Element, K extends AngularEditor = AngularEditor> extends BaseComponent<SlateElementContext<T>, K> implements OnInit, OnDestroy {\n    initialized = false;\n\n    childrenContext: SlateChildrenContext;\n\n    get element(): T {\n        return this._context && this._context.element;\n    }\n\n    get selection(): Range {\n        return this._context && this._context.selection;\n    }\n\n    get decorations(): Range[] {\n        return this._context && this._context.decorations;\n    }\n\n    get children(): Descendant[] {\n        return this._context && this._context.element.children;\n    }\n\n    get isCollapsed() {\n        return this.selection && Range.isCollapsed(this.editor.selection);\n    }\n\n    get readonly() {\n        return this._context && this._context.readonly;\n    }\n\n    ngOnInit() {\n        this.updateWeakMap();\n        for (const key in this._context.attributes) {\n            this.nativeElement.setAttribute(key, this._context.attributes[key]);\n        }\n        this.initialized = true;\n    }\n\n    updateWeakMap() {\n        NODE_TO_ELEMENT.set(this.element, this.nativeElement);\n        ELEMENT_TO_NODE.set(this.nativeElement, this.element);\n        ELEMENT_TO_COMPONENT.set(this.element, this);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.element) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.element);\n        }\n        if (ELEMENT_TO_COMPONENT.get(this.element) === this) {\n            ELEMENT_TO_COMPONENT.delete(this.element);\n        }\n    }\n\n    onContextChange() {\n        this.childrenContext = this.getChildrenContext();\n        if (!this.initialized) {\n            return;\n        }\n        this.cdr.markForCheck();\n        this.updateWeakMap();\n    }\n\n    getChildrenContext(): SlateChildrenContext {\n        return {\n            parent: this._context.element,\n            selection: this._context.selection,\n            decorations: this._context.decorations,\n            decorate: this._context.decorate,\n            readonly: this._context.readonly\n        };\n    }\n}\n\n/**\n * base class for custom text component\n */\n@Directive()\nexport class BaseTextComponent extends BaseComponent<SlateTextContext> implements OnInit, OnDestroy {\n    initialized = false;\n\n    get text(): Text {\n        return this._context && this._context.text;\n    }\n\n    ngOnInit() {\n        this.updateWeakMap();\n        this.initialized = true;\n    }\n\n    updateWeakMap() {\n        ELEMENT_TO_NODE.set(this.nativeElement, this.text);\n        NODE_TO_ELEMENT.set(this.text, this.nativeElement);\n    }\n\n    ngOnDestroy() {\n        if (NODE_TO_ELEMENT.get(this.text) === this.nativeElement) {\n            NODE_TO_ELEMENT.delete(this.text);\n        }\n    }\n\n    onContextChange() {\n        if (!this.initialized) {\n            return;\n        }\n\n        this.cdr.markForCheck();\n        this.updateWeakMap();\n    }\n}\n"]}
|
|
@@ -1736,6 +1736,31 @@ class BaseLeafComponent extends BaseComponent {
|
|
|
1736
1736
|
}
|
|
1737
1737
|
this.cdr.markForCheck();
|
|
1738
1738
|
}
|
|
1739
|
+
renderPlaceholder() {
|
|
1740
|
+
// issue-1: IME input was interrupted
|
|
1741
|
+
// issue-2: IME input focus jumping
|
|
1742
|
+
// Issue occurs when the span node of the placeholder is before the slateString span node
|
|
1743
|
+
if (this.context.leaf['placeholder']) {
|
|
1744
|
+
if (!this.placeholderElement) {
|
|
1745
|
+
this.placeholderElement = document.createElement('span');
|
|
1746
|
+
this.placeholderElement.innerText = this.context.leaf['placeholder'];
|
|
1747
|
+
this.placeholderElement.contentEditable = 'false';
|
|
1748
|
+
this.placeholderElement.setAttribute('data-slate-placeholder', 'true');
|
|
1749
|
+
this.nativeElement.classList.add('leaf-with-placeholder');
|
|
1750
|
+
this.nativeElement.appendChild(this.placeholderElement);
|
|
1751
|
+
}
|
|
1752
|
+
}
|
|
1753
|
+
else {
|
|
1754
|
+
this.destroyPlaceholder();
|
|
1755
|
+
}
|
|
1756
|
+
}
|
|
1757
|
+
destroyPlaceholder() {
|
|
1758
|
+
if (this.placeholderElement) {
|
|
1759
|
+
this.placeholderElement.remove();
|
|
1760
|
+
this.placeholderElement = null;
|
|
1761
|
+
this.nativeElement.classList.remove('leaf-with-placeholder');
|
|
1762
|
+
}
|
|
1763
|
+
}
|
|
1739
1764
|
}
|
|
1740
1765
|
BaseLeafComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: BaseLeafComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
1741
1766
|
BaseLeafComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.7", type: BaseLeafComponent, host: { properties: { "attr.data-slate-leaf": "this.isSlateLeaf" } }, usesInheritance: true, ngImport: i0 });
|
|
@@ -1823,7 +1848,7 @@ class BaseTextComponent extends BaseComponent {
|
|
|
1823
1848
|
this.initialized = false;
|
|
1824
1849
|
}
|
|
1825
1850
|
get text() {
|
|
1826
|
-
return this._context.text;
|
|
1851
|
+
return this._context && this._context.text;
|
|
1827
1852
|
}
|
|
1828
1853
|
ngOnInit() {
|
|
1829
1854
|
this.updateWeakMap();
|
|
@@ -2018,22 +2043,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
|
|
|
2018
2043
|
}] } });
|
|
2019
2044
|
|
|
2020
2045
|
class SlateDefaultLeafComponent extends BaseLeafComponent {
|
|
2046
|
+
onContextChange() {
|
|
2047
|
+
super.onContextChange();
|
|
2048
|
+
this.renderPlaceholder();
|
|
2049
|
+
}
|
|
2050
|
+
ngOnDestroy() {
|
|
2051
|
+
// Because the placeholder span is not in the current component, it is destroyed along with the current component
|
|
2052
|
+
this.destroyPlaceholder();
|
|
2053
|
+
}
|
|
2021
2054
|
}
|
|
2022
2055
|
SlateDefaultLeafComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SlateDefaultLeafComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
2023
|
-
SlateDefaultLeafComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: SlateDefaultLeafComponent, selector: "span[slateDefaultLeaf]", host: { attributes: { "data-slate-leaf": "true" } }, usesInheritance: true, ngImport: i0, template:
|
|
2024
|
-
<ng-container *ngIf="context.leaf['placeholder']">
|
|
2025
|
-
<span contenteditable="false" data-slate-placeholder="true" slate-placeholder="true">{{context.leaf['placeholder']}}</span>
|
|
2026
|
-
</ng-container>
|
|
2027
|
-
<span slateString [context]="context" [viewContext]="viewContext"><span>`, isInline: true, components: [{ type: SlateStringComponent, selector: "span[slateString]", inputs: ["context"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2056
|
+
SlateDefaultLeafComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: SlateDefaultLeafComponent, selector: "span[slateDefaultLeaf]", host: { attributes: { "data-slate-leaf": "true" } }, usesInheritance: true, ngImport: i0, template: `<span slateString [context]="context" [viewContext]="viewContext"><span>`, isInline: true, components: [{ type: SlateStringComponent, selector: "span[slateString]", inputs: ["context"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2028
2057
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: SlateDefaultLeafComponent, decorators: [{
|
|
2029
2058
|
type: Component,
|
|
2030
2059
|
args: [{
|
|
2031
2060
|
selector: 'span[slateDefaultLeaf]',
|
|
2032
|
-
template:
|
|
2033
|
-
<ng-container *ngIf="context.leaf['placeholder']">
|
|
2034
|
-
<span contenteditable="false" data-slate-placeholder="true" slate-placeholder="true">{{context.leaf['placeholder']}}</span>
|
|
2035
|
-
</ng-container>
|
|
2036
|
-
<span slateString [context]="context" [viewContext]="viewContext"><span>`,
|
|
2061
|
+
template: `<span slateString [context]="context" [viewContext]="viewContext"><span>`,
|
|
2037
2062
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
2038
2063
|
host: {
|
|
2039
2064
|
'data-slate-leaf': 'true'
|
|
@@ -2443,22 +2468,6 @@ class SlateEditableComponent {
|
|
|
2443
2468
|
this.onTouchedCallback = () => { };
|
|
2444
2469
|
this.onChangeCallback = () => { };
|
|
2445
2470
|
this.decorate = () => [];
|
|
2446
|
-
this.placeholderDecorate = (editor) => {
|
|
2447
|
-
if (this.placeholder &&
|
|
2448
|
-
editor.children.length === 1 &&
|
|
2449
|
-
Array.from(Node.texts(editor)).length === 1 &&
|
|
2450
|
-
Node.string(editor) === '') {
|
|
2451
|
-
const start = Editor.start(editor, []);
|
|
2452
|
-
return [{
|
|
2453
|
-
placeholder: this.placeholder,
|
|
2454
|
-
anchor: start,
|
|
2455
|
-
focus: start
|
|
2456
|
-
}];
|
|
2457
|
-
}
|
|
2458
|
-
else {
|
|
2459
|
-
return [];
|
|
2460
|
-
}
|
|
2461
|
-
};
|
|
2462
2471
|
this.isStrictDecorate = true;
|
|
2463
2472
|
this.trackBy = () => null;
|
|
2464
2473
|
this.readonly = false;
|
|
@@ -2495,6 +2504,9 @@ class SlateEditableComponent {
|
|
|
2495
2504
|
this.initializeContext();
|
|
2496
2505
|
// remove unused DOM, just keep templateComponent instance
|
|
2497
2506
|
this.templateElementRef.nativeElement.remove();
|
|
2507
|
+
// add browser class
|
|
2508
|
+
let browserClass = IS_FIREFOX ? 'firefox' : (IS_SAFARI ? 'safari' : '');
|
|
2509
|
+
browserClass && this.elementRef.nativeElement.classList.add(browserClass);
|
|
2498
2510
|
}
|
|
2499
2511
|
ngOnChanges(simpleChanges) {
|
|
2500
2512
|
if (!this.initialized) {
|
|
@@ -2710,9 +2722,32 @@ class SlateEditableComponent {
|
|
|
2710
2722
|
};
|
|
2711
2723
|
}
|
|
2712
2724
|
}
|
|
2725
|
+
composePlaceholderDecorate(editor) {
|
|
2726
|
+
if (this.placeholderDecorate) {
|
|
2727
|
+
return this.placeholderDecorate(editor) || [];
|
|
2728
|
+
}
|
|
2729
|
+
if (this.placeholder &&
|
|
2730
|
+
editor.children.length === 1 &&
|
|
2731
|
+
Array.from(Node.texts(editor)).length === 1 &&
|
|
2732
|
+
Node.string(editor) === '') {
|
|
2733
|
+
const start = Editor.start(editor, []);
|
|
2734
|
+
return [
|
|
2735
|
+
{
|
|
2736
|
+
placeholder: this.placeholder,
|
|
2737
|
+
anchor: start,
|
|
2738
|
+
focus: start,
|
|
2739
|
+
},
|
|
2740
|
+
];
|
|
2741
|
+
}
|
|
2742
|
+
else {
|
|
2743
|
+
return [];
|
|
2744
|
+
}
|
|
2745
|
+
}
|
|
2713
2746
|
generateDecorations() {
|
|
2714
2747
|
const decorations = this.decorate([this.editor, []]);
|
|
2715
|
-
const placeholderDecorations = this.isComposing
|
|
2748
|
+
const placeholderDecorations = this.isComposing
|
|
2749
|
+
? []
|
|
2750
|
+
: this.composePlaceholderDecorate(this.editor);
|
|
2716
2751
|
decorations.push(...placeholderDecorations);
|
|
2717
2752
|
return decorations;
|
|
2718
2753
|
}
|
|
@@ -3273,7 +3308,7 @@ class SlateEditableComponent {
|
|
|
3273
3308
|
if (!Range.isCollapsed(this.editor.selection)) {
|
|
3274
3309
|
Editor.deleteFragment(this.editor);
|
|
3275
3310
|
}
|
|
3276
|
-
// just handle Non-IME input
|
|
3311
|
+
// just handle Non-IME input
|
|
3277
3312
|
if (!this.isComposing) {
|
|
3278
3313
|
Editor.insertText(this.editor, text);
|
|
3279
3314
|
}
|