ngx-tiptap
Advanced tools
Comparing version
@@ -588,29 +588,2 @@ (function (global, factory) { | ||
var AngularNodeViewComponent = /** @class */ (function () { | ||
function AngularNodeViewComponent() { | ||
} | ||
return AngularNodeViewComponent; | ||
}()); | ||
AngularNodeViewComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0__namespace, type: AngularNodeViewComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: AngularNodeViewComponent, selector: "ng-component", inputs: { editor: "editor", node: "node", decorations: "decorations", selected: "selected", extension: "extension", getPos: "getPos", updateAttributes: "updateAttributes", deleteNode: "deleteNode" }, ngImport: i0__namespace, template: '', isInline: true }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0__namespace, type: AngularNodeViewComponent, decorators: [{ | ||
type: i0.Component, | ||
args: [{ template: '' }] | ||
}], propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], node: [{ | ||
type: i0.Input | ||
}], decorations: [{ | ||
type: i0.Input | ||
}], selected: [{ | ||
type: i0.Input | ||
}], extension: [{ | ||
type: i0.Input | ||
}], getPos: [{ | ||
type: i0.Input | ||
}], updateAttributes: [{ | ||
type: i0.Input | ||
}], deleteNode: [{ | ||
type: i0.Input | ||
}] } }); | ||
var AngularRenderer = /** @class */ (function () { | ||
@@ -651,4 +624,4 @@ function AngularRenderer(component, injector, props) { | ||
Object.entries(props).forEach(function (_a) { | ||
var _b = __read(_a, 2), k = _b[0], v = _b[1]; | ||
_this.instance[k] = v; | ||
var _b = __read(_a, 2), key = _b[0], value = _b[1]; | ||
_this.instance[key] = value; | ||
}); | ||
@@ -665,2 +638,29 @@ }; | ||
var AngularNodeViewComponent = /** @class */ (function () { | ||
function AngularNodeViewComponent() { | ||
} | ||
return AngularNodeViewComponent; | ||
}()); | ||
AngularNodeViewComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0__namespace, type: AngularNodeViewComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: AngularNodeViewComponent, selector: "ng-component", inputs: { editor: "editor", node: "node", decorations: "decorations", selected: "selected", extension: "extension", getPos: "getPos", updateAttributes: "updateAttributes", deleteNode: "deleteNode" }, ngImport: i0__namespace, template: '', isInline: true }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0__namespace, type: AngularNodeViewComponent, decorators: [{ | ||
type: i0.Component, | ||
args: [{ template: '' }] | ||
}], propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], node: [{ | ||
type: i0.Input | ||
}], decorations: [{ | ||
type: i0.Input | ||
}], selected: [{ | ||
type: i0.Input | ||
}], extension: [{ | ||
type: i0.Input | ||
}], getPos: [{ | ||
type: i0.Input | ||
}], updateAttributes: [{ | ||
type: i0.Input | ||
}], deleteNode: [{ | ||
type: i0.Input | ||
}] } }); | ||
var AngularNodeView = /** @class */ (function (_super) { | ||
@@ -667,0 +667,0 @@ __extends(AngularNodeView, _super); |
@@ -16,2 +16,8 @@ # CHANGELOG | ||
## v3.0.1 (2021-07-18) | ||
#### Bug Fixes | ||
- make `AngularRenderer` more generic ([34d5c70](https://github.com/sibiraj-s/ngx-tiptap/commit/34d5c70)) | ||
## v3.0.0 (2021-07-17) | ||
@@ -18,0 +24,0 @@ |
@@ -1,27 +0,2 @@ | ||
import { ApplicationRef, Component, ComponentFactoryResolver, ElementRef, Input } from '@angular/core'; | ||
import * as i0 from "@angular/core"; | ||
export class AngularNodeViewComponent { | ||
} | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: AngularNodeViewComponent, selector: "ng-component", inputs: { editor: "editor", node: "node", decorations: "decorations", selected: "selected", extension: "extension", getPos: "getPos", updateAttributes: "updateAttributes", deleteNode: "deleteNode" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
type: Component, | ||
args: [{ template: '' }] | ||
}], propDecorators: { editor: [{ | ||
type: Input | ||
}], node: [{ | ||
type: Input | ||
}], decorations: [{ | ||
type: Input | ||
}], selected: [{ | ||
type: Input | ||
}], extension: [{ | ||
type: Input | ||
}], getPos: [{ | ||
type: Input | ||
}], updateAttributes: [{ | ||
type: Input | ||
}], deleteNode: [{ | ||
type: Input | ||
}] } }); | ||
import { ApplicationRef, ComponentFactoryResolver, ElementRef } from '@angular/core'; | ||
export class AngularRenderer { | ||
@@ -48,4 +23,4 @@ constructor(component, injector, props) { | ||
updateProps(props) { | ||
Object.entries(props).forEach(([k, v]) => { | ||
this.instance[k] = v; | ||
Object.entries(props).forEach(([key, value]) => { | ||
this.instance[key] = value; | ||
}); | ||
@@ -60,2 +35,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW5ndWxhclJlbmRlcmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXRpcHRhcC9zcmMvbGliL0FuZ3VsYXJSZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsY0FBYyxFQUFFLFNBQVMsRUFBRSx3QkFBd0IsRUFDbkQsVUFBVSxFQUFZLEtBQUssRUFDNUIsTUFBTSxlQUFlLENBQUM7O0FBSXZCLE1BQU0sT0FBTyx3QkFBd0I7O3FIQUF4Qix3QkFBd0I7eUdBQXhCLHdCQUF3Qiw0UEFEZCxFQUFFOzJGQUNaLHdCQUF3QjtrQkFEcEMsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7OEJBRWhCLE1BQU07c0JBQWQsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLOztBQUdSLE1BQU0sT0FBTyxlQUFlO0lBSTFCLFlBQVksU0FBa0IsRUFBRSxRQUFrQixFQUFFLEtBQW1CO1FBQ3JFLElBQUksQ0FBQyxjQUFjLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUVuRCxNQUFNLHdCQUF3QixHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUN4RSxNQUFNLE9BQU8sR0FBRyx3QkFBd0IsQ0FBQyx1QkFBdUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUU1RSxJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpELG1DQUFtQztRQUNuQyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFBO1FBRXZCLDhEQUE4RDtRQUM5RCxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFJLFVBQVU7UUFDWixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN2QyxDQUFDO0lBRUQsV0FBVyxDQUEwQixLQUFpQjtRQUNwRCxNQUFNLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDdkMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUF3QixDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzlDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGFBQWE7UUFDWCxJQUFJLENBQUMsWUFBWSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3RELENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM3RCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBcHBsaWNhdGlvblJlZiwgQ29tcG9uZW50LCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIENvbXBvbmVudFJlZixcbiAgRWxlbWVudFJlZiwgSW5qZWN0b3IsIElucHV0LCBUeXBlXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTm9kZVZpZXdQcm9wcyB9IGZyb20gJ0B0aXB0YXAvY29yZSc7XG5cbkBDb21wb25lbnQoeyB0ZW1wbGF0ZTogJycgfSlcbmV4cG9ydCBjbGFzcyBBbmd1bGFyTm9kZVZpZXdDb21wb25lbnQgaW1wbGVtZW50cyBOb2RlVmlld1Byb3BzIHtcbiAgQElucHV0KCkgZWRpdG9yITogTm9kZVZpZXdQcm9wc1snZWRpdG9yJ107XG4gIEBJbnB1dCgpIG5vZGUhOiBOb2RlVmlld1Byb3BzWydub2RlJ107XG4gIEBJbnB1dCgpIGRlY29yYXRpb25zITogTm9kZVZpZXdQcm9wc1snZGVjb3JhdGlvbnMnXTtcbiAgQElucHV0KCkgc2VsZWN0ZWQhOiBOb2RlVmlld1Byb3BzWydzZWxlY3RlZCddO1xuICBASW5wdXQoKSBleHRlbnNpb24hOiBOb2RlVmlld1Byb3BzWydleHRlbnNpb24nXTtcbiAgQElucHV0KCkgZ2V0UG9zITogTm9kZVZpZXdQcm9wc1snZ2V0UG9zJ107XG4gIEBJbnB1dCgpIHVwZGF0ZUF0dHJpYnV0ZXMhOiBOb2RlVmlld1Byb3BzWyd1cGRhdGVBdHRyaWJ1dGVzJ107XG4gIEBJbnB1dCgpIGRlbGV0ZU5vZGUhOiBOb2RlVmlld1Byb3BzWydkZWxldGVOb2RlJ107XG59XG5cbmV4cG9ydCBjbGFzcyBBbmd1bGFyUmVuZGVyZXI8QyBleHRlbmRzIEFuZ3VsYXJOb2RlVmlld0NvbXBvbmVudD4ge1xuICBwcml2YXRlIGFwcGxpY2F0aW9uUmVmOiBBcHBsaWNhdGlvblJlZlxuICBwcml2YXRlIGNvbXBvbmVudFJlZjogQ29tcG9uZW50UmVmPEM+XG5cbiAgY29uc3RydWN0b3IoY29tcG9uZW50OiBUeXBlPEM+LCBpbmplY3RvcjogSW5qZWN0b3IsIHByb3BzOk5vZGVWaWV3UHJvcHMpIHtcbiAgICB0aGlzLmFwcGxpY2F0aW9uUmVmID0gaW5qZWN0b3IuZ2V0KEFwcGxpY2F0aW9uUmVmKTtcblxuICAgIGNvbnN0IGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlciA9IGluamVjdG9yLmdldChDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIpO1xuICAgIGNvbnN0IGZhY3RvcnkgPSBjb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoY29tcG9uZW50KTtcblxuICAgIHRoaXMuY29tcG9uZW50UmVmID0gZmFjdG9yeS5jcmVhdGUoaW5qZWN0b3IsIFtdKTtcblxuICAgIC8vIHNldCBpbnB1dCBwcm9wcyB0byB0aGUgY29tcG9uZW50XG4gICAgdGhpcy51cGRhdGVQcm9wcyhwcm9wcylcblxuICAgIC8vIEF0dGFjaCB0byB0aGUgdmlldyBzbyB0aGF0IHRoZSBjaGFuZ2UgZGV0ZWN0b3Iga25vd3MgdG8gcnVuXG4gICAgdGhpcy5hcHBsaWNhdGlvblJlZi5hdHRhY2hWaWV3KHRoaXMuY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcbiAgfVxuXG4gIGdldCBpbnN0YW5jZSgpOiBDIHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2U7XG4gIH1cblxuICBnZXQgZWxlbWVudFJlZigpOiBFbGVtZW50UmVmIHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYuaW5qZWN0b3IuZ2V0KEVsZW1lbnRSZWYpO1xuICB9XG5cbiAgZ2V0IGRvbSgpOiBIVE1MRWxlbWVudCB7XG4gICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICB9XG5cbiAgdXBkYXRlUHJvcHM8VCBleHRlbmRzIE5vZGVWaWV3UHJvcHM+KHByb3BzOiBQYXJ0aWFsPFQ+KTogdm9pZCB7XG4gICAgT2JqZWN0LmVudHJpZXMocHJvcHMpLmZvckVhY2goKFtrLCB2XSkgPT4ge1xuICAgICAgdGhpcy5pbnN0YW5jZVtrIGFzIGtleW9mIE5vZGVWaWV3UHJvcHNdID0gdjtcbiAgICB9KTtcbiAgfVxuXG4gIGRldGVjdENoYW5nZXMoKTogdm9pZCB7XG4gICAgdGhpcy5jb21wb25lbnRSZWYuY2hhbmdlRGV0ZWN0b3JSZWYuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgZGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmFwcGxpY2F0aW9uUmVmLmRldGFjaFZpZXcodGhpcy5jb21wb25lbnRSZWYuaG9zdFZpZXcpO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW5ndWxhclJlbmRlcmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXRpcHRhcC9zcmMvbGliL0FuZ3VsYXJSZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsY0FBYyxFQUFFLHdCQUF3QixFQUN4QyxVQUFVLEVBQ1gsTUFBTSxlQUFlLENBQUM7QUFFdkIsTUFBTSxPQUFPLGVBQWU7SUFJMUIsWUFBWSxTQUFrQixFQUFFLFFBQWtCLEVBQUUsS0FBaUI7UUFDbkUsSUFBSSxDQUFDLGNBQWMsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRW5ELE1BQU0sd0JBQXdCLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBQ3hFLE1BQU0sT0FBTyxHQUFHLHdCQUF3QixDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRTVFLElBQUksQ0FBQyxZQUFZLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakQsbUNBQW1DO1FBQ25DLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUE7UUFFdkIsOERBQThEO1FBQzlELElBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVELElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQUksVUFBVTtRQUNaLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRCxJQUFJLEdBQUc7UUFDTCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO0lBQ3ZDLENBQUM7SUFFRCxXQUFXLENBQWMsS0FBaUI7UUFDeEMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFO1lBQzdDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBYyxDQUFDLEdBQUcsS0FBbUIsQ0FBQTtRQUNyRCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxhQUFhO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN0RCxDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDN0QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQXBwbGljYXRpb25SZWYsIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgQ29tcG9uZW50UmVmLFxuICBFbGVtZW50UmVmLCBJbmplY3RvciwgVHlwZVxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGNsYXNzIEFuZ3VsYXJSZW5kZXJlcjxDLCBQPiB7XG4gIHByaXZhdGUgYXBwbGljYXRpb25SZWY6IEFwcGxpY2F0aW9uUmVmXG4gIHByaXZhdGUgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8Qz5cblxuICBjb25zdHJ1Y3Rvcihjb21wb25lbnQ6IFR5cGU8Qz4sIGluamVjdG9yOiBJbmplY3RvciwgcHJvcHM6IFBhcnRpYWw8UD4pIHtcbiAgICB0aGlzLmFwcGxpY2F0aW9uUmVmID0gaW5qZWN0b3IuZ2V0KEFwcGxpY2F0aW9uUmVmKTtcblxuICAgIGNvbnN0IGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlciA9IGluamVjdG9yLmdldChDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIpO1xuICAgIGNvbnN0IGZhY3RvcnkgPSBjb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoY29tcG9uZW50KTtcblxuICAgIHRoaXMuY29tcG9uZW50UmVmID0gZmFjdG9yeS5jcmVhdGUoaW5qZWN0b3IsIFtdKTtcblxuICAgIC8vIHNldCBpbnB1dCBwcm9wcyB0byB0aGUgY29tcG9uZW50XG4gICAgdGhpcy51cGRhdGVQcm9wcyhwcm9wcylcblxuICAgIC8vIEF0dGFjaCB0byB0aGUgdmlldyBzbyB0aGF0IHRoZSBjaGFuZ2UgZGV0ZWN0b3Iga25vd3MgdG8gcnVuXG4gICAgdGhpcy5hcHBsaWNhdGlvblJlZi5hdHRhY2hWaWV3KHRoaXMuY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcbiAgfVxuXG4gIGdldCBpbnN0YW5jZSgpOiBDIHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2U7XG4gIH1cblxuICBnZXQgZWxlbWVudFJlZigpOiBFbGVtZW50UmVmIHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYuaW5qZWN0b3IuZ2V0KEVsZW1lbnRSZWYpO1xuICB9XG5cbiAgZ2V0IGRvbSgpOiBIVE1MRWxlbWVudCB7XG4gICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICB9XG5cbiAgdXBkYXRlUHJvcHM8VCBleHRlbmRzIFA+KHByb3BzOiBQYXJ0aWFsPFQ+KTogdm9pZCB7XG4gICAgT2JqZWN0LmVudHJpZXMocHJvcHMpLmZvckVhY2goKFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgdGhpcy5pbnN0YW5jZVtrZXkgYXMga2V5b2YgQ10gPSB2YWx1ZSBhcyBDW2tleW9mIENdXG4gICAgfSk7XG4gIH1cblxuICBkZXRlY3RDaGFuZ2VzKCk6IHZvaWQge1xuICAgIHRoaXMuY29tcG9uZW50UmVmLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIGRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5hcHBsaWNhdGlvblJlZi5kZXRhY2hWaWV3KHRoaXMuY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcbiAgfVxufVxuIl19 |
@@ -0,3 +1,29 @@ | ||
import { Component, Input } from '@angular/core'; | ||
import { NodeView } from '@tiptap/core'; | ||
import { AngularRenderer } from './AngularRenderer'; | ||
import * as i0 from "@angular/core"; | ||
export class AngularNodeViewComponent { | ||
} | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: AngularNodeViewComponent, selector: "ng-component", inputs: { editor: "editor", node: "node", decorations: "decorations", selected: "selected", extension: "extension", getPos: "getPos", updateAttributes: "updateAttributes", deleteNode: "deleteNode" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
type: Component, | ||
args: [{ template: '' }] | ||
}], propDecorators: { editor: [{ | ||
type: Input | ||
}], node: [{ | ||
type: Input | ||
}], decorations: [{ | ||
type: Input | ||
}], selected: [{ | ||
type: Input | ||
}], extension: [{ | ||
type: Input | ||
}], getPos: [{ | ||
type: Input | ||
}], updateAttributes: [{ | ||
type: Input | ||
}], deleteNode: [{ | ||
type: Input | ||
}] } }); | ||
class AngularNodeView extends NodeView { | ||
@@ -82,2 +108,2 @@ mount() { | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NodeViewRenderer.js","sourceRoot":"","sources":["../../../../projects/ngx-tiptap/src/lib/NodeViewRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injector, Type } from '@angular/core';\nimport { Editor, NodeView, NodeViewProps, NodeViewRenderer, NodeViewRendererProps } from '@tiptap/core';\nimport type { Decoration } from 'prosemirror-view';\nimport type { Node as ProseMirrorNode } from 'prosemirror-model';\n\nimport { AngularRenderer, AngularNodeViewComponent } from './AngularRenderer';\n\ninterface AngularNodeViewRendererOptions {\n  stopEvent?: ((event: Event) => boolean) | null,\n  update?: ((node: ProseMirrorNode, decorations: Decoration[]) => boolean) | null,\n  injector: Injector\n}\n\nclass AngularNodeView extends NodeView<Type<AngularNodeViewComponent>, Editor> {\n  renderer!: AngularRenderer<AngularNodeViewComponent>\n  contentDOMElement!: HTMLElement | null\n\n  mount() {\n    const injector = (this.options as AngularNodeViewRendererOptions).injector as Injector;\n\n    const props: NodeViewProps = {\n      editor: this.editor,\n      node: this.node,\n      decorations: this.decorations,\n      selected: false,\n      extension: this.extension,\n      getPos: () => this.getPos(),\n      updateAttributes: (attributes = {}) => this.updateAttributes(attributes),\n      deleteNode: () => this.deleteNode()\n    };\n\n    // create renderer\n    this.renderer = new AngularRenderer(this.component, injector, props);\n\n    // Register drag handler\n    if (this.extension.config.draggable) {\n      this.renderer.elementRef.nativeElement.ondragstart = (e: DragEvent) => {\n        this.onDragStart(e);\n      };\n    }\n\n    this.contentDOMElement = this.node.isLeaf ? null : document.createElement(this.node.isInline ? 'span' : 'div');\n\n    if (this.contentDOMElement) {\n      // For some reason the whiteSpace prop is not inherited properly in Chrome and Safari\n      // With this fix it seems to work fine\n      // See: https://github.com/ueberdosis/tiptap/issues/1197\n      this.contentDOMElement.style.whiteSpace = 'inherit';\n      this.renderer.detectChanges()\n    }\n  }\n\n  get dom() {\n    return this.renderer.dom;\n  }\n\n  get contentDOM() {\n    if (this.node.isLeaf) {\n      return null;\n    }\n\n    this.maybeMoveContentDOM();\n    return this.contentDOMElement;\n  }\n\n  private maybeMoveContentDOM(): void {\n    const contentElement = this.dom.querySelector('[data-node-view-content]');\n\n    if (\n      this.contentDOMElement\n      && contentElement\n      && !contentElement.contains(this.contentDOMElement)\n    ) {\n      contentElement.appendChild(this.contentDOMElement);\n    }\n  }\n\n  update(node: ProseMirrorNode, decorations: Decoration[]): boolean {\n    if (this.options.update) {\n      return this.options.update(node, decorations);\n    }\n\n    if (node.type !== this.node.type) {\n      return false;\n    }\n\n    if (node === this.node && this.decorations === decorations) {\n      return true;\n    }\n\n    this.node = node;\n    this.decorations = decorations;\n    this.renderer.updateProps({ node, decorations });\n    this.maybeMoveContentDOM();\n\n    return true;\n  }\n\n  selectNode() {\n    this.renderer.updateProps({ selected: true });\n  }\n\n  deselectNode() {\n    this.renderer.updateProps({ selected: false });\n  }\n\n  destroy() {\n    this.renderer.destroy();\n  }\n}\n\nexport const AngularNodeViewRenderer = (component: Type<AngularNodeViewComponent>, options: AngularNodeViewRendererOptions): NodeViewRenderer => {\n  return (props: NodeViewRendererProps) => {\n    return new AngularNodeView(component, props, options);\n  };\n};\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NodeViewRenderer.js","sourceRoot":"","sources":["../../../../projects/ngx-tiptap/src/lib/NodeViewRenderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, Input, Type } from '@angular/core';\nimport { Editor, NodeView, NodeViewProps, NodeViewRenderer, NodeViewRendererProps } from '@tiptap/core';\nimport type { Decoration } from 'prosemirror-view';\nimport type { Node as ProseMirrorNode } from 'prosemirror-model';\n\nimport { AngularRenderer } from './AngularRenderer';\n\n@Component({ template: '' })\nexport class AngularNodeViewComponent implements NodeViewProps {\n  @Input() editor!: NodeViewProps['editor'];\n  @Input() node!: NodeViewProps['node'];\n  @Input() decorations!: NodeViewProps['decorations'];\n  @Input() selected!: NodeViewProps['selected'];\n  @Input() extension!: NodeViewProps['extension'];\n  @Input() getPos!: NodeViewProps['getPos'];\n  @Input() updateAttributes!: NodeViewProps['updateAttributes'];\n  @Input() deleteNode!: NodeViewProps['deleteNode'];\n}\n\ninterface AngularNodeViewRendererOptions {\n  stopEvent?: ((event: Event) => boolean) | null,\n  update?: ((node: ProseMirrorNode, decorations: Decoration[]) => boolean) | null,\n  injector: Injector\n}\n\nclass AngularNodeView extends NodeView<Type<AngularNodeViewComponent>, Editor> {\n  renderer!: AngularRenderer<AngularNodeViewComponent, NodeViewProps>\n  contentDOMElement!: HTMLElement | null\n\n  mount() {\n    const injector = (this.options as AngularNodeViewRendererOptions).injector as Injector;\n\n    const props: NodeViewProps = {\n      editor: this.editor,\n      node: this.node,\n      decorations: this.decorations,\n      selected: false,\n      extension: this.extension,\n      getPos: () => this.getPos(),\n      updateAttributes: (attributes = {}) => this.updateAttributes(attributes),\n      deleteNode: () => this.deleteNode()\n    };\n\n    // create renderer\n    this.renderer = new AngularRenderer(this.component, injector, props);\n\n    // Register drag handler\n    if (this.extension.config.draggable) {\n      this.renderer.elementRef.nativeElement.ondragstart = (e: DragEvent) => {\n        this.onDragStart(e);\n      };\n    }\n\n    this.contentDOMElement = this.node.isLeaf ? null : document.createElement(this.node.isInline ? 'span' : 'div');\n\n    if (this.contentDOMElement) {\n      // For some reason the whiteSpace prop is not inherited properly in Chrome and Safari\n      // With this fix it seems to work fine\n      // See: https://github.com/ueberdosis/tiptap/issues/1197\n      this.contentDOMElement.style.whiteSpace = 'inherit';\n      this.renderer.detectChanges()\n    }\n  }\n\n  get dom() {\n    return this.renderer.dom;\n  }\n\n  get contentDOM() {\n    if (this.node.isLeaf) {\n      return null;\n    }\n\n    this.maybeMoveContentDOM();\n    return this.contentDOMElement;\n  }\n\n  private maybeMoveContentDOM(): void {\n    const contentElement = this.dom.querySelector('[data-node-view-content]');\n\n    if (\n      this.contentDOMElement\n      && contentElement\n      && !contentElement.contains(this.contentDOMElement)\n    ) {\n      contentElement.appendChild(this.contentDOMElement);\n    }\n  }\n\n  update(node: ProseMirrorNode, decorations: Decoration[]): boolean {\n    if (this.options.update) {\n      return this.options.update(node, decorations);\n    }\n\n    if (node.type !== this.node.type) {\n      return false;\n    }\n\n    if (node === this.node && this.decorations === decorations) {\n      return true;\n    }\n\n    this.node = node;\n    this.decorations = decorations;\n    this.renderer.updateProps({ node, decorations });\n    this.maybeMoveContentDOM();\n\n    return true;\n  }\n\n  selectNode() {\n    this.renderer.updateProps({ selected: true });\n  }\n\n  deselectNode() {\n    this.renderer.updateProps({ selected: false });\n  }\n\n  destroy() {\n    this.renderer.destroy();\n  }\n}\n\nexport const AngularNodeViewRenderer = (component: Type<AngularNodeViewComponent>, options: AngularNodeViewRendererOptions): NodeViewRenderer => {\n  return (props: NodeViewRendererProps) => {\n    return new AngularNodeView(component, props, options);\n  };\n};\n"]} |
import * as i0 from '@angular/core'; | ||
import { forwardRef, Directive, Input, HostBinding, NgModule, Component, ApplicationRef, ComponentFactoryResolver, ElementRef } from '@angular/core'; | ||
import { forwardRef, Directive, Input, HostBinding, NgModule, ApplicationRef, ComponentFactoryResolver, ElementRef, Component } from '@angular/core'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
@@ -237,26 +237,2 @@ import { FloatingMenuPlugin, FloatingMenuPluginKey } from '@tiptap/extension-floating-menu'; | ||
class AngularNodeViewComponent { | ||
} | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: AngularNodeViewComponent, selector: "ng-component", inputs: { editor: "editor", node: "node", decorations: "decorations", selected: "selected", extension: "extension", getPos: "getPos", updateAttributes: "updateAttributes", deleteNode: "deleteNode" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
type: Component, | ||
args: [{ template: '' }] | ||
}], propDecorators: { editor: [{ | ||
type: Input | ||
}], node: [{ | ||
type: Input | ||
}], decorations: [{ | ||
type: Input | ||
}], selected: [{ | ||
type: Input | ||
}], extension: [{ | ||
type: Input | ||
}], getPos: [{ | ||
type: Input | ||
}], updateAttributes: [{ | ||
type: Input | ||
}], deleteNode: [{ | ||
type: Input | ||
}] } }); | ||
class AngularRenderer { | ||
@@ -283,4 +259,4 @@ constructor(component, injector, props) { | ||
updateProps(props) { | ||
Object.entries(props).forEach(([k, v]) => { | ||
this.instance[k] = v; | ||
Object.entries(props).forEach(([key, value]) => { | ||
this.instance[key] = value; | ||
}); | ||
@@ -296,2 +272,26 @@ } | ||
class AngularNodeViewComponent { | ||
} | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.1", type: AngularNodeViewComponent, selector: "ng-component", inputs: { editor: "editor", node: "node", decorations: "decorations", selected: "selected", extension: "extension", getPos: "getPos", updateAttributes: "updateAttributes", deleteNode: "deleteNode" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.1", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
type: Component, | ||
args: [{ template: '' }] | ||
}], propDecorators: { editor: [{ | ||
type: Input | ||
}], node: [{ | ||
type: Input | ||
}], decorations: [{ | ||
type: Input | ||
}], selected: [{ | ||
type: Input | ||
}], extension: [{ | ||
type: Input | ||
}], getPos: [{ | ||
type: Input | ||
}], updateAttributes: [{ | ||
type: Input | ||
}], deleteNode: [{ | ||
type: Input | ||
}] } }); | ||
class AngularNodeView extends NodeView { | ||
@@ -298,0 +298,0 @@ mount() { |
import { ElementRef, Injector, Type } from '@angular/core'; | ||
import { NodeViewProps } from '@tiptap/core'; | ||
import * as i0 from "@angular/core"; | ||
export declare class AngularNodeViewComponent implements NodeViewProps { | ||
editor: NodeViewProps['editor']; | ||
node: NodeViewProps['node']; | ||
decorations: NodeViewProps['decorations']; | ||
selected: NodeViewProps['selected']; | ||
extension: NodeViewProps['extension']; | ||
getPos: NodeViewProps['getPos']; | ||
updateAttributes: NodeViewProps['updateAttributes']; | ||
deleteNode: NodeViewProps['deleteNode']; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<AngularNodeViewComponent, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<AngularNodeViewComponent, "ng-component", never, { "editor": "editor"; "node": "node"; "decorations": "decorations"; "selected": "selected"; "extension": "extension"; "getPos": "getPos"; "updateAttributes": "updateAttributes"; "deleteNode": "deleteNode"; }, {}, never, never>; | ||
} | ||
export declare class AngularRenderer<C extends AngularNodeViewComponent> { | ||
export declare class AngularRenderer<C, P> { | ||
private applicationRef; | ||
private componentRef; | ||
constructor(component: Type<C>, injector: Injector, props: NodeViewProps); | ||
constructor(component: Type<C>, injector: Injector, props: Partial<P>); | ||
get instance(): C; | ||
get elementRef(): ElementRef; | ||
get dom(): HTMLElement; | ||
updateProps<T extends NodeViewProps>(props: Partial<T>): void; | ||
updateProps<T extends P>(props: Partial<T>): void; | ||
detectChanges(): void; | ||
destroy(): void; | ||
} |
import { Injector, Type } from '@angular/core'; | ||
import { NodeViewRenderer } from '@tiptap/core'; | ||
import { NodeViewProps, NodeViewRenderer } from '@tiptap/core'; | ||
import type { Decoration } from 'prosemirror-view'; | ||
import type { Node as ProseMirrorNode } from 'prosemirror-model'; | ||
import { AngularNodeViewComponent } from './AngularRenderer'; | ||
import * as i0 from "@angular/core"; | ||
export declare class AngularNodeViewComponent implements NodeViewProps { | ||
editor: NodeViewProps['editor']; | ||
node: NodeViewProps['node']; | ||
decorations: NodeViewProps['decorations']; | ||
selected: NodeViewProps['selected']; | ||
extension: NodeViewProps['extension']; | ||
getPos: NodeViewProps['getPos']; | ||
updateAttributes: NodeViewProps['updateAttributes']; | ||
deleteNode: NodeViewProps['deleteNode']; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<AngularNodeViewComponent, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<AngularNodeViewComponent, "ng-component", never, { "editor": "editor"; "node": "node"; "decorations": "decorations"; "selected": "selected"; "extension": "extension"; "getPos": "getPos"; "updateAttributes": "updateAttributes"; "deleteNode": "deleteNode"; }, {}, never, never>; | ||
} | ||
interface AngularNodeViewRendererOptions { | ||
@@ -7,0 +19,0 @@ stopEvent?: ((event: Event) => boolean) | null; |
{ | ||
"name": "ngx-tiptap", | ||
"description": "Angular bindings for Tiptap v2", | ||
"version": "3.0.0", | ||
"version": "3.0.1", | ||
"license": "MIT", | ||
@@ -6,0 +6,0 @@ "repository": "https://github.com/sibiraj-s/ngx-tiptap.git", |
@@ -241,3 +241,3 @@ # NgxTiptap | ||
const renderer = new AngularRenderer(Component, injector); | ||
const renderer = new AngularRenderer(Component, injector, props); | ||
@@ -244,0 +244,0 @@ renderer.instance; // get the instance of the component, can be used to update `@Input` properties |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
194728
-0.09%1672
-0.06%