ngx-tiptap
Advanced tools
Comparing version
@@ -29,277 +29,2 @@ (function (global, factory) { | ||
var EditorDirective = /** @class */ (function () { | ||
function EditorDirective(el, _renderer) { | ||
var _this = this; | ||
this.el = el; | ||
this._renderer = _renderer; | ||
this.outputFormat = 'html'; | ||
this.onChange = function () { }; | ||
this.onTouched = function () { }; | ||
this.handleChange = function (_a) { | ||
var transaction = _a.transaction; | ||
if (!transaction.docChanged) { | ||
return; | ||
} | ||
if (_this.outputFormat === 'html') { | ||
_this.onChange(_this.editor.getHTML()); | ||
return; | ||
} | ||
_this.onChange(_this.editor.getJSON()); | ||
}; | ||
} | ||
// Writes a new value to the element. | ||
// This methods is called when programmatic changes from model to view are requested. | ||
EditorDirective.prototype.writeValue = function (value) { | ||
if (!value) { | ||
return; | ||
} | ||
if (!this.outputFormat && typeof value === 'string') { | ||
this.outputFormat = 'html'; | ||
} | ||
this.editor.chain().setContent(value, false).run(); | ||
}; | ||
// Registers a callback function that is called when the control's value changes in the UI. | ||
EditorDirective.prototype.registerOnChange = function (fn) { | ||
this.onChange = fn; | ||
}; | ||
// Registers a callback function that is called by the forms API on initialization to update the form model on blur. | ||
EditorDirective.prototype.registerOnTouched = function (fn) { | ||
this.onTouched = fn; | ||
}; | ||
// Called by the forms api to enable or disable the element | ||
EditorDirective.prototype.setDisabledState = function (isDisabled) { | ||
this.editor.setEditable(!isDisabled); | ||
this._renderer.setProperty(this.el.nativeElement, 'disabled', isDisabled); | ||
}; | ||
EditorDirective.prototype.ngOnInit = function () { | ||
var _this = this; | ||
if (!this.editor) { | ||
throw new Error('Required: Input `editor`'); | ||
} | ||
// take the inner contents and clear the block | ||
var innerHTML = this.el.nativeElement.innerHTML; | ||
this.el.nativeElement.innerHTML = ''; | ||
// insert the editor in the dom | ||
this.el.nativeElement.appendChild(this.editor.options.element.firstChild); | ||
// update the options for the editor | ||
this.editor.setOptions({ element: this.el.nativeElement }); | ||
// update content to the editor | ||
if (innerHTML) { | ||
this.editor.chain().setContent(innerHTML, false).run(); | ||
} | ||
// register blur handler to update `touched` property | ||
this.editor.on('blur', function () { | ||
_this.onTouched(); | ||
}); | ||
// register transaction handler to emit changes on update | ||
this.editor.on('transaction', this.handleChange); | ||
}; | ||
EditorDirective.prototype.ngOnDestroy = function () { | ||
this.editor.destroy(); | ||
}; | ||
return EditorDirective; | ||
}()); | ||
EditorDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: EditorDirective, deps: [{ token: i0__namespace.ElementRef }, { token: i0__namespace.Renderer2 }], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
EditorDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: EditorDirective, selector: "tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]", inputs: { editor: "editor", outputFormat: "outputFormat" }, providers: [{ | ||
provide: forms.NG_VALUE_ACCESSOR, | ||
useExisting: i0.forwardRef(function () { return EditorDirective; }), | ||
multi: true | ||
}], ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: EditorDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: 'tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]', | ||
providers: [{ | ||
provide: forms.NG_VALUE_ACCESSOR, | ||
useExisting: i0.forwardRef(function () { return EditorDirective; }), | ||
multi: true | ||
}] | ||
}] | ||
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }, { type: i0__namespace.Renderer2 }]; }, propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], outputFormat: [{ | ||
type: i0.Input | ||
}] } }); | ||
var FloatingMenuDirective = /** @class */ (function () { | ||
function FloatingMenuDirective(_el) { | ||
this._el = _el; | ||
this.tippyOptions = {}; | ||
} | ||
FloatingMenuDirective.prototype.ngOnInit = function () { | ||
if (!this.editor) { | ||
throw new Error('Required: Input `editor`'); | ||
} | ||
this.editor.registerPlugin(extensionFloatingMenu.FloatingMenuPlugin({ | ||
editor: this.editor, | ||
element: this._el.nativeElement, | ||
tippyOptions: this.tippyOptions | ||
})); | ||
}; | ||
FloatingMenuDirective.prototype.ngOnDestroy = function () { | ||
this.editor.unregisterPlugin(extensionFloatingMenu.FloatingMenuPluginKey); | ||
}; | ||
return FloatingMenuDirective; | ||
}()); | ||
FloatingMenuDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: FloatingMenuDirective, deps: [{ token: i0__namespace.ElementRef }], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
FloatingMenuDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: FloatingMenuDirective, selector: "tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: FloatingMenuDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: 'tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]' | ||
}] | ||
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }]; }, propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], tippyOptions: [{ | ||
type: i0.Input | ||
}] } }); | ||
var BubbleMenuDirective = /** @class */ (function () { | ||
function BubbleMenuDirective(_el) { | ||
this._el = _el; | ||
this.tippyOptions = {}; | ||
} | ||
BubbleMenuDirective.prototype.ngOnInit = function () { | ||
if (!this.editor) { | ||
throw new Error('Required: Input `editor`'); | ||
} | ||
this.editor.registerPlugin(extensionBubbleMenu.BubbleMenuPlugin({ | ||
editor: this.editor, | ||
element: this._el.nativeElement, | ||
tippyOptions: this.tippyOptions | ||
})); | ||
}; | ||
BubbleMenuDirective.prototype.ngOnDestroy = function () { | ||
this.editor.unregisterPlugin(extensionBubbleMenu.BubbleMenuPluginKey); | ||
}; | ||
return BubbleMenuDirective; | ||
}()); | ||
BubbleMenuDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: BubbleMenuDirective, deps: [{ token: i0__namespace.ElementRef }], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
BubbleMenuDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: BubbleMenuDirective, selector: "tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: BubbleMenuDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: 'tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]' | ||
}] | ||
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }]; }, propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], tippyOptions: [{ | ||
type: i0.Input | ||
}] } }); | ||
var DraggableDirective = /** @class */ (function () { | ||
function DraggableDirective() { | ||
this.draggable = true; | ||
this.handle = ''; | ||
} | ||
return DraggableDirective; | ||
}()); | ||
DraggableDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: DraggableDirective, deps: [], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
DraggableDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: DraggableDirective, selector: "[tiptapDraggable]", host: { properties: { "attr.draggable": "this.draggable", "attr.data-drag-handle": "this.handle" } }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: DraggableDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: '[tiptapDraggable]' | ||
}] | ||
}], propDecorators: { draggable: [{ | ||
type: i0.HostBinding, | ||
args: ['attr.draggable'] | ||
}], handle: [{ | ||
type: i0.HostBinding, | ||
args: ['attr.data-drag-handle'] | ||
}] } }); | ||
var NodeViewContentDirective = /** @class */ (function () { | ||
function NodeViewContentDirective() { | ||
this.handle = ''; | ||
} | ||
return NodeViewContentDirective; | ||
}()); | ||
NodeViewContentDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: NodeViewContentDirective, deps: [], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
NodeViewContentDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: NodeViewContentDirective, selector: "[tiptapNodeViewContent]", host: { properties: { "attr.data-node-view-content": "this.handle" } }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: NodeViewContentDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: '[tiptapNodeViewContent]' | ||
}] | ||
}], propDecorators: { handle: [{ | ||
type: i0.HostBinding, | ||
args: ['attr.data-node-view-content'] | ||
}] } }); | ||
var NgxTiptapModule = /** @class */ (function () { | ||
function NgxTiptapModule() { | ||
} | ||
return NgxTiptapModule; | ||
}()); | ||
NgxTiptapModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: NgxTiptapModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule }); | ||
NgxTiptapModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: NgxTiptapModule, declarations: [EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective], exports: [EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective] }); | ||
NgxTiptapModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: NgxTiptapModule }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: NgxTiptapModule, decorators: [{ | ||
type: i0.NgModule, | ||
args: [{ | ||
declarations: [ | ||
EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective, | ||
], | ||
exports: [ | ||
EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective | ||
] | ||
}] | ||
}] }); | ||
var AngularRenderer = /** @class */ (function () { | ||
function AngularRenderer(component, injector) { | ||
this.applicationRef = injector.get(i0.ApplicationRef); | ||
var componentFactoryResolver = injector.get(i0.ComponentFactoryResolver); | ||
var factory = componentFactoryResolver.resolveComponentFactory(component); | ||
this.componentRef = factory.create(injector, []); | ||
// Attach to the view so that the change detector knows to run | ||
this.applicationRef.attachView(this.componentRef.hostView); | ||
} | ||
Object.defineProperty(AngularRenderer.prototype, "instance", { | ||
get: function () { | ||
return this.componentRef.instance; | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
Object.defineProperty(AngularRenderer.prototype, "elementRef", { | ||
get: function () { | ||
return this.componentRef.injector.get(i0.ElementRef); | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
Object.defineProperty(AngularRenderer.prototype, "dom", { | ||
get: function () { | ||
return this.elementRef.nativeElement; | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
AngularRenderer.prototype.detectChanges = function () { | ||
this.componentRef.changeDetectorRef.detectChanges(); | ||
}; | ||
AngularRenderer.prototype.destroy = function () { | ||
this.applicationRef.detachView(this.componentRef.hostView); | ||
}; | ||
return AngularRenderer; | ||
}()); | ||
/*! ***************************************************************************** | ||
@@ -617,2 +342,278 @@ Copyright (c) Microsoft Corporation. | ||
var EditorDirective = /** @class */ (function () { | ||
function EditorDirective(el, _renderer) { | ||
var _this = this; | ||
this.el = el; | ||
this._renderer = _renderer; | ||
this.outputFormat = 'html'; | ||
this.onChange = function () { }; | ||
this.onTouched = function () { }; | ||
this.handleChange = function (_a) { | ||
var transaction = _a.transaction; | ||
if (!transaction.docChanged) { | ||
return; | ||
} | ||
if (_this.outputFormat === 'html') { | ||
_this.onChange(_this.editor.getHTML()); | ||
return; | ||
} | ||
_this.onChange(_this.editor.getJSON()); | ||
}; | ||
} | ||
// Writes a new value to the element. | ||
// This methods is called when programmatic changes from model to view are requested. | ||
EditorDirective.prototype.writeValue = function (value) { | ||
if (!value) { | ||
return; | ||
} | ||
if (!this.outputFormat && typeof value === 'string') { | ||
this.outputFormat = 'html'; | ||
} | ||
this.editor.chain().setContent(value, false).run(); | ||
}; | ||
// Registers a callback function that is called when the control's value changes in the UI. | ||
EditorDirective.prototype.registerOnChange = function (fn) { | ||
this.onChange = fn; | ||
}; | ||
// Registers a callback function that is called by the forms API on initialization to update the form model on blur. | ||
EditorDirective.prototype.registerOnTouched = function (fn) { | ||
this.onTouched = fn; | ||
}; | ||
// Called by the forms api to enable or disable the element | ||
EditorDirective.prototype.setDisabledState = function (isDisabled) { | ||
this.editor.setEditable(!isDisabled); | ||
this._renderer.setProperty(this.el.nativeElement, 'disabled', isDisabled); | ||
}; | ||
EditorDirective.prototype.ngOnInit = function () { | ||
var _a; | ||
var _this = this; | ||
if (!this.editor) { | ||
throw new Error('Required: Input `editor`'); | ||
} | ||
// take the inner contents and clear the block | ||
var innerHTML = this.el.nativeElement.innerHTML; | ||
this.el.nativeElement.innerHTML = ''; | ||
// insert the editor in the dom | ||
(_a = this.el.nativeElement).append.apply(_a, __spreadArray([], __read(Array.from(this.editor.options.element.childNodes)))); | ||
// update the options for the editor | ||
this.editor.setOptions({ element: this.el.nativeElement }); | ||
// update content to the editor | ||
if (innerHTML) { | ||
this.editor.chain().setContent(innerHTML, false).run(); | ||
} | ||
// register blur handler to update `touched` property | ||
this.editor.on('blur', function () { | ||
_this.onTouched(); | ||
}); | ||
// register transaction handler to emit changes on update | ||
this.editor.on('transaction', this.handleChange); | ||
}; | ||
EditorDirective.prototype.ngOnDestroy = function () { | ||
this.editor.destroy(); | ||
}; | ||
return EditorDirective; | ||
}()); | ||
EditorDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: EditorDirective, deps: [{ token: i0__namespace.ElementRef }, { token: i0__namespace.Renderer2 }], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
EditorDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: EditorDirective, selector: "tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]", inputs: { editor: "editor", outputFormat: "outputFormat" }, providers: [{ | ||
provide: forms.NG_VALUE_ACCESSOR, | ||
useExisting: i0.forwardRef(function () { return EditorDirective; }), | ||
multi: true | ||
}], ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: EditorDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: 'tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]', | ||
providers: [{ | ||
provide: forms.NG_VALUE_ACCESSOR, | ||
useExisting: i0.forwardRef(function () { return EditorDirective; }), | ||
multi: true | ||
}] | ||
}] | ||
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }, { type: i0__namespace.Renderer2 }]; }, propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], outputFormat: [{ | ||
type: i0.Input | ||
}] } }); | ||
var FloatingMenuDirective = /** @class */ (function () { | ||
function FloatingMenuDirective(_el) { | ||
this._el = _el; | ||
this.tippyOptions = {}; | ||
} | ||
FloatingMenuDirective.prototype.ngOnInit = function () { | ||
if (!this.editor) { | ||
throw new Error('Required: Input `editor`'); | ||
} | ||
this.editor.registerPlugin(extensionFloatingMenu.FloatingMenuPlugin({ | ||
editor: this.editor, | ||
element: this._el.nativeElement, | ||
tippyOptions: this.tippyOptions | ||
})); | ||
}; | ||
FloatingMenuDirective.prototype.ngOnDestroy = function () { | ||
this.editor.unregisterPlugin(extensionFloatingMenu.FloatingMenuPluginKey); | ||
}; | ||
return FloatingMenuDirective; | ||
}()); | ||
FloatingMenuDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: FloatingMenuDirective, deps: [{ token: i0__namespace.ElementRef }], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
FloatingMenuDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: FloatingMenuDirective, selector: "tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: FloatingMenuDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: 'tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]' | ||
}] | ||
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }]; }, propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], tippyOptions: [{ | ||
type: i0.Input | ||
}] } }); | ||
var BubbleMenuDirective = /** @class */ (function () { | ||
function BubbleMenuDirective(_el) { | ||
this._el = _el; | ||
this.tippyOptions = {}; | ||
} | ||
BubbleMenuDirective.prototype.ngOnInit = function () { | ||
if (!this.editor) { | ||
throw new Error('Required: Input `editor`'); | ||
} | ||
this.editor.registerPlugin(extensionBubbleMenu.BubbleMenuPlugin({ | ||
editor: this.editor, | ||
element: this._el.nativeElement, | ||
tippyOptions: this.tippyOptions | ||
})); | ||
}; | ||
BubbleMenuDirective.prototype.ngOnDestroy = function () { | ||
this.editor.unregisterPlugin(extensionBubbleMenu.BubbleMenuPluginKey); | ||
}; | ||
return BubbleMenuDirective; | ||
}()); | ||
BubbleMenuDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: BubbleMenuDirective, deps: [{ token: i0__namespace.ElementRef }], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
BubbleMenuDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: BubbleMenuDirective, selector: "tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: BubbleMenuDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: 'tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]' | ||
}] | ||
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }]; }, propDecorators: { editor: [{ | ||
type: i0.Input | ||
}], tippyOptions: [{ | ||
type: i0.Input | ||
}] } }); | ||
var DraggableDirective = /** @class */ (function () { | ||
function DraggableDirective() { | ||
this.draggable = true; | ||
this.handle = ''; | ||
} | ||
return DraggableDirective; | ||
}()); | ||
DraggableDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: DraggableDirective, deps: [], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
DraggableDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: DraggableDirective, selector: "[tiptapDraggable]", host: { properties: { "attr.draggable": "this.draggable", "attr.data-drag-handle": "this.handle" } }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: DraggableDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: '[tiptapDraggable]' | ||
}] | ||
}], propDecorators: { draggable: [{ | ||
type: i0.HostBinding, | ||
args: ['attr.draggable'] | ||
}], handle: [{ | ||
type: i0.HostBinding, | ||
args: ['attr.data-drag-handle'] | ||
}] } }); | ||
var NodeViewContentDirective = /** @class */ (function () { | ||
function NodeViewContentDirective() { | ||
this.handle = ''; | ||
} | ||
return NodeViewContentDirective; | ||
}()); | ||
NodeViewContentDirective.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: NodeViewContentDirective, deps: [], target: i0__namespace.ɵɵFactoryTarget.Directive }); | ||
NodeViewContentDirective.ɵdir = i0__namespace.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: NodeViewContentDirective, selector: "[tiptapNodeViewContent]", host: { properties: { "attr.data-node-view-content": "this.handle" } }, ngImport: i0__namespace }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: NodeViewContentDirective, decorators: [{ | ||
type: i0.Directive, | ||
args: [{ | ||
selector: '[tiptapNodeViewContent]' | ||
}] | ||
}], propDecorators: { handle: [{ | ||
type: i0.HostBinding, | ||
args: ['attr.data-node-view-content'] | ||
}] } }); | ||
var NgxTiptapModule = /** @class */ (function () { | ||
function NgxTiptapModule() { | ||
} | ||
return NgxTiptapModule; | ||
}()); | ||
NgxTiptapModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: NgxTiptapModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule }); | ||
NgxTiptapModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: NgxTiptapModule, declarations: [EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective], exports: [EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective] }); | ||
NgxTiptapModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: NgxTiptapModule }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: NgxTiptapModule, decorators: [{ | ||
type: i0.NgModule, | ||
args: [{ | ||
declarations: [ | ||
EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective, | ||
], | ||
exports: [ | ||
EditorDirective, | ||
FloatingMenuDirective, | ||
BubbleMenuDirective, | ||
DraggableDirective, | ||
NodeViewContentDirective | ||
] | ||
}] | ||
}] }); | ||
var AngularRenderer = /** @class */ (function () { | ||
function AngularRenderer(component, injector) { | ||
this.applicationRef = injector.get(i0.ApplicationRef); | ||
var componentFactoryResolver = injector.get(i0.ComponentFactoryResolver); | ||
var factory = componentFactoryResolver.resolveComponentFactory(component); | ||
this.componentRef = factory.create(injector, []); | ||
// Attach to the view so that the change detector knows to run | ||
this.applicationRef.attachView(this.componentRef.hostView); | ||
} | ||
Object.defineProperty(AngularRenderer.prototype, "instance", { | ||
get: function () { | ||
return this.componentRef.instance; | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
Object.defineProperty(AngularRenderer.prototype, "elementRef", { | ||
get: function () { | ||
return this.componentRef.injector.get(i0.ElementRef); | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
Object.defineProperty(AngularRenderer.prototype, "dom", { | ||
get: function () { | ||
return this.elementRef.nativeElement; | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
AngularRenderer.prototype.detectChanges = function () { | ||
this.componentRef.changeDetectorRef.detectChanges(); | ||
}; | ||
AngularRenderer.prototype.destroy = function () { | ||
this.applicationRef.detachView(this.componentRef.hostView); | ||
}; | ||
return AngularRenderer; | ||
}()); | ||
var AngularNodeViewComponent = /** @class */ (function () { | ||
@@ -623,5 +624,5 @@ function AngularNodeViewComponent() { | ||
}()); | ||
AngularNodeViewComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: AngularNodeViewComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.0", type: AngularNodeViewComponent, selector: "ng-component", inputs: { props: "props" }, ngImport: i0__namespace, template: '', isInline: true }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0__namespace, type: AngularNodeViewComponent, decorators: [{ | ||
AngularNodeViewComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: AngularNodeViewComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.2", type: AngularNodeViewComponent, selector: "ng-component", inputs: { props: "props" }, ngImport: i0__namespace, template: '', isInline: true }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0__namespace, type: AngularNodeViewComponent, decorators: [{ | ||
type: i0.Component, | ||
@@ -651,2 +652,3 @@ args: [{ template: '' }] | ||
}, | ||
deleteNode: function () { return _this.deleteNode(); } | ||
}; | ||
@@ -691,8 +693,3 @@ // create renderer | ||
} | ||
var contentElement = this.dom.querySelector('[data-node-view-content]'); | ||
if (this.contentDOMElement | ||
&& contentElement | ||
&& !contentElement.contains(this.contentDOMElement)) { | ||
contentElement.appendChild(this.contentDOMElement); | ||
} | ||
this.maybeMoveContentDOM(); | ||
return this.contentDOMElement; | ||
@@ -703,2 +700,10 @@ }, | ||
}); | ||
AngularNodeView.prototype.maybeMoveContentDOM = function () { | ||
var contentElement = this.dom.querySelector('[data-node-view-content]'); | ||
if (this.contentDOMElement | ||
&& contentElement | ||
&& !contentElement.contains(this.contentDOMElement)) { | ||
contentElement.appendChild(this.contentDOMElement); | ||
} | ||
}; | ||
AngularNodeView.prototype.update = function (node, decorations) { | ||
@@ -717,2 +722,3 @@ if (this.options.update) { | ||
this.updateProps({ node: node, decorations: decorations }); | ||
this.maybeMoveContentDOM(); | ||
return true; | ||
@@ -719,0 +725,0 @@ }; |
@@ -16,2 +16,19 @@ # CHANGELOG | ||
## v2.1.0 (2021-05-30) | ||
#### Features | ||
- add `deleteNode` method to component prop ([7a170a0](https://github.com/sibiraj-s/ngx-tiptap/commit/7a170a0)) | ||
#### Bug Fixes | ||
- set correct semver for tiptap packages ([5b08331](https://github.com/sibiraj-s/ngx-tiptap/commit/5b08331)) | ||
- move contentDOM on editor update ([c5f71d9](https://github.com/sibiraj-s/ngx-tiptap/commit/c5f71d9)) | ||
- move all child nodes within EditorContent ([883798e](https://github.com/sibiraj-s/ngx-tiptap/commit/883798e)) | ||
- add missing `@angular/forms` peerDependency ([467619e](https://github.com/sibiraj-s/ngx-tiptap/commit/467619e)) | ||
#### Dependency Updates | ||
- update peerDependencies ([52307d4](https://github.com/sibiraj-s/ngx-tiptap/commit/52307d4)) | ||
## v2.0.0 (2021-05-17) | ||
@@ -18,0 +35,0 @@ |
@@ -1,2 +0,2 @@ | ||
import { ApplicationRef, ComponentFactoryResolver, ElementRef } from "@angular/core"; | ||
import { ApplicationRef, ComponentFactoryResolver, ElementRef } from '@angular/core'; | ||
export class AngularRenderer { | ||
@@ -27,2 +27,2 @@ constructor(component, injector) { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW5ndWxhclJlbmRlcmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXRpcHRhcC9zcmMvbGliL0FuZ3VsYXJSZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsY0FBYyxFQUFFLHdCQUF3QixFQUN4QyxVQUFVLEVBQ1gsTUFBTSxlQUFlLENBQUM7QUFFdkIsTUFBTSxPQUFPLGVBQWU7SUFJMUIsWUFBWSxTQUFrQixFQUFFLFFBQWtCO1FBQ2hELElBQUksQ0FBQyxjQUFjLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUVuRCxNQUFNLHdCQUF3QixHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUN4RSxNQUFNLE9BQU8sR0FBRyx3QkFBd0IsQ0FBQyx1QkFBdUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUU1RSxJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpELDhEQUE4RDtRQUM5RCxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFJLFVBQVU7UUFDWixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN2QyxDQUFDO0lBRUQsYUFBYTtRQUNYLElBQUksQ0FBQyxZQUFZLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdEQsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzdELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIENvbXBvbmVudFJlZixcbiAgRWxlbWVudFJlZiwgSW5qZWN0b3IsIFR5cGVcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGNsYXNzIEFuZ3VsYXJSZW5kZXJlcjxDPiB7XG4gIHByaXZhdGUgYXBwbGljYXRpb25SZWY6IEFwcGxpY2F0aW9uUmVmXG4gIHByaXZhdGUgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8Qz5cblxuICBjb25zdHJ1Y3Rvcihjb21wb25lbnQ6IFR5cGU8Qz4sIGluamVjdG9yOiBJbmplY3Rvcikge1xuICAgIHRoaXMuYXBwbGljYXRpb25SZWYgPSBpbmplY3Rvci5nZXQoQXBwbGljYXRpb25SZWYpO1xuXG4gICAgY29uc3QgY29tcG9uZW50RmFjdG9yeVJlc29sdmVyID0gaW5qZWN0b3IuZ2V0KENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcik7XG4gICAgY29uc3QgZmFjdG9yeSA9IGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShjb21wb25lbnQpO1xuXG4gICAgdGhpcy5jb21wb25lbnRSZWYgPSBmYWN0b3J5LmNyZWF0ZShpbmplY3RvciwgW10pO1xuXG4gICAgLy8gQXR0YWNoIHRvIHRoZSB2aWV3IHNvIHRoYXQgdGhlIGNoYW5nZSBkZXRlY3RvciBrbm93cyB0byBydW5cbiAgICB0aGlzLmFwcGxpY2F0aW9uUmVmLmF0dGFjaFZpZXcodGhpcy5jb21wb25lbnRSZWYuaG9zdFZpZXcpO1xuICB9XG5cbiAgZ2V0IGluc3RhbmNlKCk6IEMge1xuICAgIHJldHVybiB0aGlzLmNvbXBvbmVudFJlZi5pbnN0YW5jZTtcbiAgfVxuXG4gIGdldCBlbGVtZW50UmVmKCk6IEVsZW1lbnRSZWYge1xuICAgIHJldHVybiB0aGlzLmNvbXBvbmVudFJlZi5pbmplY3Rvci5nZXQoRWxlbWVudFJlZik7XG4gIH1cblxuICBnZXQgZG9tKCk6IEhUTUxFbGVtZW50IHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gIH1cblxuICBkZXRlY3RDaGFuZ2VzKCk6dm9pZCB7XG4gICAgdGhpcy5jb21wb25lbnRSZWYuY2hhbmdlRGV0ZWN0b3JSZWYuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgZGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmFwcGxpY2F0aW9uUmVmLmRldGFjaFZpZXcodGhpcy5jb21wb25lbnRSZWYuaG9zdFZpZXcpO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQW5ndWxhclJlbmRlcmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXRpcHRhcC9zcmMvbGliL0FuZ3VsYXJSZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsY0FBYyxFQUFFLHdCQUF3QixFQUN4QyxVQUFVLEVBQ1gsTUFBTSxlQUFlLENBQUM7QUFFdkIsTUFBTSxPQUFPLGVBQWU7SUFJMUIsWUFBWSxTQUFrQixFQUFFLFFBQWtCO1FBQ2hELElBQUksQ0FBQyxjQUFjLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUVuRCxNQUFNLHdCQUF3QixHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUN4RSxNQUFNLE9BQU8sR0FBRyx3QkFBd0IsQ0FBQyx1QkFBdUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUU1RSxJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpELDhEQUE4RDtRQUM5RCxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFJLFVBQVU7UUFDWixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRUQsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN2QyxDQUFDO0lBRUQsYUFBYTtRQUNYLElBQUksQ0FBQyxZQUFZLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdEQsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzdELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIENvbXBvbmVudFJlZixcbiAgRWxlbWVudFJlZiwgSW5qZWN0b3IsIFR5cGVcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjbGFzcyBBbmd1bGFyUmVuZGVyZXI8Qz4ge1xuICBwcml2YXRlIGFwcGxpY2F0aW9uUmVmOiBBcHBsaWNhdGlvblJlZlxuICBwcml2YXRlIGNvbXBvbmVudFJlZjogQ29tcG9uZW50UmVmPEM+XG5cbiAgY29uc3RydWN0b3IoY29tcG9uZW50OiBUeXBlPEM+LCBpbmplY3RvcjogSW5qZWN0b3IpIHtcbiAgICB0aGlzLmFwcGxpY2F0aW9uUmVmID0gaW5qZWN0b3IuZ2V0KEFwcGxpY2F0aW9uUmVmKTtcblxuICAgIGNvbnN0IGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlciA9IGluamVjdG9yLmdldChDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIpO1xuICAgIGNvbnN0IGZhY3RvcnkgPSBjb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIucmVzb2x2ZUNvbXBvbmVudEZhY3RvcnkoY29tcG9uZW50KTtcblxuICAgIHRoaXMuY29tcG9uZW50UmVmID0gZmFjdG9yeS5jcmVhdGUoaW5qZWN0b3IsIFtdKTtcblxuICAgIC8vIEF0dGFjaCB0byB0aGUgdmlldyBzbyB0aGF0IHRoZSBjaGFuZ2UgZGV0ZWN0b3Iga25vd3MgdG8gcnVuXG4gICAgdGhpcy5hcHBsaWNhdGlvblJlZi5hdHRhY2hWaWV3KHRoaXMuY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcbiAgfVxuXG4gIGdldCBpbnN0YW5jZSgpOiBDIHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYuaW5zdGFuY2U7XG4gIH1cblxuICBnZXQgZWxlbWVudFJlZigpOiBFbGVtZW50UmVmIHtcbiAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWYuaW5qZWN0b3IuZ2V0KEVsZW1lbnRSZWYpO1xuICB9XG5cbiAgZ2V0IGRvbSgpOiBIVE1MRWxlbWVudCB7XG4gICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICB9XG5cbiAgZGV0ZWN0Q2hhbmdlcygpOnZvaWQge1xuICAgIHRoaXMuY29tcG9uZW50UmVmLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIGRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5hcHBsaWNhdGlvblJlZi5kZXRhY2hWaWV3KHRoaXMuY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcbiAgfVxufVxuIl19 |
@@ -23,5 +23,5 @@ import { Directive, Input } from '@angular/core'; | ||
} | ||
BubbleMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: BubbleMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
BubbleMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: BubbleMenuDirective, selector: "tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: BubbleMenuDirective, decorators: [{ | ||
BubbleMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: BubbleMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
BubbleMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: BubbleMenuDirective, selector: "tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: BubbleMenuDirective, decorators: [{ | ||
type: Directive, | ||
@@ -28,0 +28,0 @@ args: [{ |
@@ -9,5 +9,5 @@ import { Directive, HostBinding } from '@angular/core'; | ||
} | ||
DraggableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: DraggableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
DraggableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: DraggableDirective, selector: "[tiptapDraggable]", host: { properties: { "attr.draggable": "this.draggable", "attr.data-drag-handle": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: DraggableDirective, decorators: [{ | ||
DraggableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: DraggableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
DraggableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: DraggableDirective, selector: "[tiptapDraggable]", host: { properties: { "attr.draggable": "this.draggable", "attr.data-drag-handle": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: DraggableDirective, decorators: [{ | ||
type: Directive, | ||
@@ -14,0 +14,0 @@ args: [{ |
@@ -54,3 +54,3 @@ import { Directive, forwardRef, Input } from '@angular/core'; | ||
// insert the editor in the dom | ||
this.el.nativeElement.appendChild(this.editor.options.element.firstChild); | ||
this.el.nativeElement.append(...Array.from(this.editor.options.element.childNodes)); | ||
// update the options for the editor | ||
@@ -73,4 +73,4 @@ this.editor.setOptions({ element: this.el.nativeElement }); | ||
} | ||
EditorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: EditorDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); | ||
EditorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: EditorDirective, selector: "tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]", inputs: { editor: "editor", outputFormat: "outputFormat" }, providers: [{ | ||
EditorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: EditorDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); | ||
EditorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: EditorDirective, selector: "tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]", inputs: { editor: "editor", outputFormat: "outputFormat" }, providers: [{ | ||
provide: NG_VALUE_ACCESSOR, | ||
@@ -80,3 +80,3 @@ useExisting: forwardRef(() => EditorDirective), | ||
}], ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: EditorDirective, decorators: [{ | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: EditorDirective, decorators: [{ | ||
type: Directive, | ||
@@ -96,2 +96,2 @@ args: [{ | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10aXB0YXAvc3JjL2xpYi9lZGl0b3IuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsVUFBVSxFQUFFLEtBQUssRUFBZ0MsTUFBTSxlQUFlLENBQUM7QUFDdkcsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQWF6RSxNQUFNLE9BQU8sZUFBZTtJQUkxQixZQUFvQixFQUEyQixFQUFVLFNBQW9CO1FBQXpELE9BQUUsR0FBRixFQUFFLENBQXlCO1FBQVUsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUZwRSxpQkFBWSxHQUFvQixNQUFNLENBQUM7UUFJeEMsYUFBUSxHQUE2QixHQUFHLEVBQUUsR0FBUyxDQUFDLENBQUM7UUFDckQsY0FBUyxHQUFlLEdBQUcsRUFBRSxHQUFVLENBQUMsQ0FBQztRQWdDekMsaUJBQVksR0FBRyxDQUFDLEVBQUUsV0FBVyxFQUFnQyxFQUFRLEVBQUU7WUFDN0UsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVLEVBQUU7Z0JBQzNCLE9BQU87YUFDUjtZQUVELElBQUksSUFBSSxDQUFDLFlBQVksS0FBSyxNQUFNLEVBQUU7Z0JBQ2hDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUNyQyxPQUFPO2FBQ1I7WUFFRCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFpQixDQUFDLENBQUM7UUFDdEQsQ0FBQyxDQUFBO0lBOUNnRixDQUFDO0lBS2xGLHFDQUFxQztJQUNyQyxxRkFBcUY7SUFDckYsVUFBVSxDQUFDLEtBQWM7UUFDdkIsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNWLE9BQU87U0FDUjtRQUVELElBQUksQ0FBQyxJ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IEVsZW1lbnRSZWYsIGZvcndhcmRSZWYsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBDb250ZW50LCBFZGl0b3IsIEpTT05Db250ZW50IH0gZnJvbSAnQHRpcHRhcC9jb3JlJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAncHJvc2VtaXJyb3Itc3RhdGUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICd0aXB0YXBbZWRpdG9yXSwgW3RpcHRhcF1bZWRpdG9yXSwgdGlwdGFwLWVkaXRvcltlZGl0b3JdLCBbdGlwdGFwRWRpdG9yXVtlZGl0b3JdJyxcbiAgcHJvdmlkZXJzOiBbe1xuICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEVkaXRvckRpcmVjdGl2ZSksXG4gICAgbXVsdGk6IHRydWVcbiAgfV1cbn0pXG5cbmV4cG9ydCBjbGFzcyBFZGl0b3JEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBPbkRlc3Ryb3kge1xuICBASW5wdXQoKSBlZGl0b3IhOiBFZGl0b3I7XG4gIEBJbnB1dCgpIG91dHB1dEZvcm1hdDogJ2pzb24nIHwgJ2h0bWwnID0gJ2h0bWwnO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LCBwcml2YXRlIF9yZW5kZXJlcjogUmVuZGVyZXIyKSB7IH1cblxuICBwcml2YXRlIG9uQ2hhbmdlOiAodmFsdWU6IENvbnRlbnQpID0+IHZvaWQgPSAoKSA9PiB7LyoqICovIH07XG4gIHByaXZhdGUgb25Ub3VjaGVkOiAoKSA9PiB2b2lkID0gKCkgPT4geyAvKiogKi8gfTtcblxuICAvLyBXcml0ZXMgYSBuZXcgdmFsdWUgdG8gdGhlIGVsZW1lbnQuXG4gIC8vIFRoaXMgbWV0aG9kcyBpcyBjYWxsZWQgd2hlbiBwcm9ncmFtbWF0aWMgY2hhbmdlcyBmcm9tIG1vZGVsIHRvIHZpZXcgYXJlIHJlcXVlc3RlZC5cbiAgd3JpdGVWYWx1ZSh2YWx1ZTogQ29udGVudCk6IHZvaWQge1xuICAgIGlmICghdmFsdWUpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAoIXRoaXMub3V0cHV0Rm9ybWF0ICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHRoaXMub3V0cHV0Rm9ybWF0ID0gJ2h0bWwnO1xuICAgIH1cblxuICAgIHRoaXMuZWRpdG9yLmNoYWluKCkuc2V0Q29udGVudCh2YWx1ZSwgZmFsc2UpLnJ1bigpO1xuICB9XG5cbiAgLy8gUmVnaXN0ZXJzIGEgY2FsbGJhY2sgZnVuY3Rpb24gdGhhdCBpcyBjYWxsZWQgd2hlbiB0aGUgY29udHJvbCdzIHZhbHVlIGNoYW5nZXMgaW4gdGhlIFVJLlxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiAoKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICB9XG5cbiAgLy8gUmVnaXN0ZXJzIGEgY2FsbGJhY2sgZnVuY3Rpb24gdGhhdCBpcyBjYWxsZWQgYnkgdGhlIGZvcm1zIEFQSSBvbiBpbml0aWFsaXphdGlvbiB0byB1cGRhdGUgdGhlIGZvcm0gbW9kZWwgb24gYmx1ci5cbiAgcmVnaXN0ZXJPblRvdWNoZWQoZm46ICgpID0+IHZvaWQpOiB2b2lkIHtcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xuICB9XG5cbiAgLy8gQ2FsbGVkIGJ5IHRoZSBmb3JtcyBhcGkgdG8gZW5hYmxlIG9yIGRpc2FibGUgdGhlIGVsZW1lbnRcbiAgc2V0RGlzYWJsZWRTdGF0ZShpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XG4gICAgdGhpcy5lZGl0b3Iuc2V0RWRpdGFibGUoIWlzRGlzYWJsZWQpO1xuICAgIHRoaXMuX3JlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWwubmF0aXZlRWxlbWVudCwgJ2Rpc2FibGVkJywgaXNEaXNhYmxlZCk7XG4gIH1cblxuICBwcml2YXRlIGhhbmRsZUNoYW5nZSA9ICh7IHRyYW5zYWN0aW9uIH06IHsgdHJhbnNhY3Rpb246IFRyYW5zYWN0aW9uIH0pOiB2b2lkID0+IHtcbiAgICBpZiAoIXRyYW5zYWN0aW9uLmRvY0NoYW5nZWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5vdXRwdXRGb3JtYXQgPT09ICdodG1sJykge1xuICAgICAgdGhpcy5vbkNoYW5nZSh0aGlzLmVkaXRvci5nZXRIVE1MKCkpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMub25DaGFuZ2UodGhpcy5lZGl0b3IuZ2V0SlNPTigpIGFzIEpTT05Db250ZW50KTtcbiAgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5lZGl0b3IpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQ6IElucHV0IGBlZGl0b3JgJyk7XG4gICAgfVxuXG4gICAgLy8gdGFrZSB0aGUgaW5uZXIgY29udGVudHMgYW5kIGNsZWFyIHRoZSBibG9ja1xuICAgIGNvbnN0IGlubmVySFRNTCA9IHRoaXMuZWwubmF0aXZlRWxlbWVudC5pbm5lckhUTUw7XG4gICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LmlubmVySFRNTCA9ICcnO1xuXG4gICAgLy8gaW5zZXJ0IHRoZSBlZGl0b3IgaW4gdGhlIGRvbVxuICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5hcHBlbmRDaGlsZCh0aGlzLmVkaXRvci5vcHRpb25zLmVsZW1lbnQuZmlyc3RDaGlsZCBhcyBDaGlsZE5vZGUpO1xuXG4gICAgLy8gdXBkYXRlIHRoZSBvcHRpb25zIGZvciB0aGUgZWRpdG9yXG4gICAgdGhpcy5lZGl0b3Iuc2V0T3B0aW9ucyh7IGVsZW1lbnQ6IHRoaXMuZWwubmF0aXZlRWxlbWVudCB9KTtcblxuICAgIC8vIHVwZGF0ZSBjb250ZW50IHRvIHRoZSBlZGl0b3JcbiAgICBpZiAoaW5uZXJIVE1MKSB7XG4gICAgICB0aGlzLmVkaXRvci5jaGFpbigpLnNldENvbnRlbnQoaW5uZXJIVE1MLCBmYWxzZSkucnVuKCk7XG4gICAgfVxuXG4gICAgLy8gcmVnaXN0ZXIgYmx1ciBoYW5kbGVyIHRvIHVwZGF0ZSBgdG91Y2hlZGAgcHJvcGVydHlcbiAgICB0aGlzLmVkaXRvci5vbignYmx1cicsICgpID0+IHtcbiAgICAgIHRoaXMub25Ub3VjaGVkKCk7XG4gICAgfSk7XG5cbiAgICAvLyByZWdpc3RlciB0cmFuc2FjdGlvbiBoYW5kbGVyIHRvIGVtaXQgY2hhbmdlcyBvbiB1cGRhdGVcbiAgICB0aGlzLmVkaXRvci5vbigndHJhbnNhY3Rpb24nLCB0aGlzLmhhbmRsZUNoYW5nZSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmVkaXRvci5kZXN0cm95KCk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10aXB0YXAvc3JjL2xpYi9lZGl0b3IuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsVUFBVSxFQUFFLEtBQUssRUFBZ0MsTUFBTSxlQUFlLENBQUM7QUFDdkcsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQWF6RSxNQUFNLE9BQU8sZUFBZTtJQUkxQixZQUFvQixFQUEyQixFQUFVLFNBQW9CO1FBQXpELE9BQUUsR0FBRixFQUFFLENBQXlCO1FBQVUsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUZwRSxpQkFBWSxHQUFvQixNQUFNLENBQUM7UUFJeEMsYUFBUSxHQUE2QixHQUFHLEVBQUUsR0FBUyxDQUFDLENBQUM7UUFDckQsY0FBUyxHQUFlLEdBQUcsRUFBRSxHQUFVLENBQUMsQ0FBQztRQWdDekMsaUJBQVksR0FBRyxDQUFDLEVBQUUsV0FBVyxFQUFnQyxFQUFRLEVBQUU7WUFDN0UsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVLEVBQUU7Z0JBQzNCLE9BQU87YUFDUjtZQUVELElBQUksSUFBSSxDQUFDLFlBQVksS0FBSyxNQUFNLEVBQUU7Z0JBQ2hDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUNyQyxPQUFPO2FBQ1I7WUFFRCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFpQixDQUFDLENBQUM7UUFDdEQsQ0FBQyxDQUFBO0lBOUNnRixDQUFDO0lBS2xGLHFDQUFxQztJQUNyQyxxRkFBcUY7SUFDckYsVUFBVSxDQUFDLEtBQWM7UUFDdkIsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNWLE9BQU87U0FDUjtRQUVELElBQUksQ0FBQyxJ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b250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgZm9yd2FyZFJlZiwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0LCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbnRlbnQsIEVkaXRvciwgSlNPTkNvbnRlbnQgfSBmcm9tICdAdGlwdGFwL2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICdwcm9zZW1pcnJvci1zdGF0ZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RpcHRhcFtlZGl0b3JdLCBbdGlwdGFwXVtlZGl0b3JdLCB0aXB0YXAtZWRpdG9yW2VkaXRvcl0sIFt0aXB0YXBFZGl0b3JdW2VkaXRvcl0nLFxuICBwcm92aWRlcnM6IFt7XG4gICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gRWRpdG9yRGlyZWN0aXZlKSxcbiAgICBtdWx0aTogdHJ1ZVxuICB9XVxufSlcblxuZXhwb3J0IGNsYXNzIEVkaXRvckRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpIGVkaXRvciE6IEVkaXRvcjtcbiAgQElucHV0KCkgb3V0cHV0Rm9ybWF0OiAnanNvbicgfCAnaHRtbCcgPSAnaHRtbCc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sIHByaXZhdGUgX3JlbmRlcmVyOiBSZW5kZXJlcjIpIHsgfVxuXG4gIHByaXZhdGUgb25DaGFuZ2U6ICh2YWx1ZTogQ29udGVudCkgPT4gdm9pZCA9ICgpID0+IHsvKiogKi8gfTtcbiAgcHJpdmF0ZSBvblRvdWNoZWQ6ICgpID0+IHZvaWQgPSAoKSA9PiB7IC8qKiAqLyB9O1xuXG4gIC8vIFdyaXRlcyBhIG5ldyB2YWx1ZSB0byB0aGUgZWxlbWVudC5cbiAgLy8gVGhpcyBtZXRob2RzIGlzIGNhbGxlZCB3aGVuIHByb2dyYW1tYXRpYyBjaGFuZ2VzIGZyb20gbW9kZWwgdG8gdmlldyBhcmUgcmVxdWVzdGVkLlxuICB3cml0ZVZhbHVlKHZhbHVlOiBDb250ZW50KTogdm9pZCB7XG4gICAgaWYgKCF2YWx1ZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5vdXRwdXRGb3JtYXQgJiYgdHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgdGhpcy5vdXRwdXRGb3JtYXQgPSAnaHRtbCc7XG4gICAgfVxuXG4gICAgdGhpcy5lZGl0b3IuY2hhaW4oKS5zZXRDb250ZW50KHZhbHVlLCBmYWxzZSkucnVuKCk7XG4gIH1cblxuICAvLyBSZWdpc3RlcnMgYSBjYWxsYmFjayBmdW5jdGlvbiB0aGF0IGlzIGNhbGxlZCB3aGVuIHRoZSBjb250cm9sJ3MgdmFsdWUgY2hhbmdlcyBpbiB0aGUgVUkuXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46ICgpID0+IHZvaWQpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XG4gIH1cblxuICAvLyBSZWdpc3RlcnMgYSBjYWxsYmFjayBmdW5jdGlvbiB0aGF0IGlzIGNhbGxlZCBieSB0aGUgZm9ybXMgQVBJIG9uIGluaXRpYWxpemF0aW9uIHRvIHVwZGF0ZSB0aGUgZm9ybSBtb2RlbCBvbiBibHVyLlxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogKCkgPT4gdm9pZCk6IHZvaWQge1xuICAgIHRoaXMub25Ub3VjaGVkID0gZm47XG4gIH1cblxuICAvLyBDYWxsZWQgYnkgdGhlIGZvcm1zIGFwaSB0byBlbmFibGUgb3IgZGlzYWJsZSB0aGUgZWxlbWVudFxuICBzZXREaXNhYmxlZFN0YXRlKGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmVkaXRvci5zZXRFZGl0YWJsZSghaXNEaXNhYmxlZCk7XG4gICAgdGhpcy5fcmVuZGVyZXIuc2V0UHJvcGVydHkodGhpcy5lbC5uYXRpdmVFbGVtZW50LCAnZGlzYWJsZWQnLCBpc0Rpc2FibGVkKTtcbiAgfVxuXG4gIHByaXZhdGUgaGFuZGxlQ2hhbmdlID0gKHsgdHJhbnNhY3Rpb24gfTogeyB0cmFuc2FjdGlvbjogVHJhbnNhY3Rpb24gfSk6IHZvaWQgPT4ge1xuICAgIGlmICghdHJhbnNhY3Rpb24uZG9jQ2hhbmdlZCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGlmICh0aGlzLm91dHB1dEZvcm1hdCA9PT0gJ2h0bWwnKSB7XG4gICAgICB0aGlzLm9uQ2hhbmdlKHRoaXMuZWRpdG9yLmdldEhUTUwoKSk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdGhpcy5vbkNoYW5nZSh0aGlzLmVkaXRvci5nZXRKU09OKCkgYXMgSlNPTkNvbnRlbnQpO1xuICB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLmVkaXRvcikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZDogSW5wdXQgYGVkaXRvcmAnKTtcbiAgICB9XG5cbiAgICAvLyB0YWtlIHRoZSBpbm5lciBjb250ZW50cyBhbmQgY2xlYXIgdGhlIGJsb2NrXG4gICAgY29uc3QgaW5uZXJIVE1MID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LmlubmVySFRNTDtcbiAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQuaW5uZXJIVE1MID0gJyc7XG5cbiAgICAvLyBpbnNlcnQgdGhlIGVkaXRvciBpbiB0aGUgZG9tXG4gICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LmFwcGVuZCguLi5BcnJheS5mcm9tKHRoaXMuZWRpdG9yLm9wdGlvbnMuZWxlbWVudC5jaGlsZE5vZGVzKSk7XG5cbiAgICAvLyB1cGRhdGUgdGhlIG9wdGlvbnMgZm9yIHRoZSBlZGl0b3JcbiAgICB0aGlzLmVkaXRvci5zZXRPcHRpb25zKHsgZWxlbWVudDogdGhpcy5lbC5uYXRpdmVFbGVtZW50IH0pO1xuXG4gICAgLy8gdXBkYXRlIGNvbnRlbnQgdG8gdGhlIGVkaXRvclxuICAgIGlmIChpbm5lckhUTUwpIHtcbiAgICAgIHRoaXMuZWRpdG9yLmNoYWluKCkuc2V0Q29udGVudChpbm5lckhUTUwsIGZhbHNlKS5ydW4oKTtcbiAgICB9XG5cbiAgICAvLyByZWdpc3RlciBibHVyIGhhbmRsZXIgdG8gdXBkYXRlIGB0b3VjaGVkYCBwcm9wZXJ0eVxuICAgIHRoaXMuZWRpdG9yLm9uKCdibHVyJywgKCkgPT4ge1xuICAgICAgdGhpcy5vblRvdWNoZWQoKTtcbiAgICB9KTtcblxuICAgIC8vIHJlZ2lzdGVyIHRyYW5zYWN0aW9uIGhhbmRsZXIgdG8gZW1pdCBjaGFuZ2VzIG9uIHVwZGF0ZVxuICAgIHRoaXMuZWRpdG9yLm9uKCd0cmFuc2FjdGlvbicsIHRoaXMuaGFuZGxlQ2hhbmdlKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuZWRpdG9yLmRlc3Ryb3koKTtcbiAgfVxufVxuIl19 |
@@ -23,5 +23,5 @@ import { Directive, Input } from '@angular/core'; | ||
} | ||
FloatingMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: FloatingMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
FloatingMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: FloatingMenuDirective, selector: "tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: FloatingMenuDirective, decorators: [{ | ||
FloatingMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: FloatingMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
FloatingMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: FloatingMenuDirective, selector: "tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: FloatingMenuDirective, decorators: [{ | ||
type: Directive, | ||
@@ -28,0 +28,0 @@ args: [{ |
@@ -10,4 +10,4 @@ import { NgModule } from '@angular/core'; | ||
} | ||
NgxTiptapModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
NgxTiptapModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule, declarations: [EditorDirective, | ||
NgxTiptapModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
NgxTiptapModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule, declarations: [EditorDirective, | ||
FloatingMenuDirective, | ||
@@ -21,4 +21,4 @@ BubbleMenuDirective, | ||
NodeViewContentDirective] }); | ||
NgxTiptapModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule, decorators: [{ | ||
NgxTiptapModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule, decorators: [{ | ||
type: NgModule, | ||
@@ -25,0 +25,0 @@ args: [{ |
@@ -8,5 +8,5 @@ import { Directive, HostBinding } from '@angular/core'; | ||
} | ||
NodeViewContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NodeViewContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
NodeViewContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: NodeViewContentDirective, selector: "[tiptapNodeViewContent]", host: { properties: { "attr.data-node-view-content": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NodeViewContentDirective, decorators: [{ | ||
NodeViewContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NodeViewContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
NodeViewContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: NodeViewContentDirective, selector: "[tiptapNodeViewContent]", host: { properties: { "attr.data-node-view-content": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NodeViewContentDirective, decorators: [{ | ||
type: Directive, | ||
@@ -13,0 +13,0 @@ args: [{ |
@@ -1,10 +0,10 @@ | ||
import { Component, Input } from "@angular/core"; | ||
import { NodeView } from "@tiptap/core"; | ||
import { AngularRenderer } from "./AngularRenderer"; | ||
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.0.0", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.0", type: AngularNodeViewComponent, selector: "ng-component", inputs: { props: "props" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.2", type: AngularNodeViewComponent, selector: "ng-component", inputs: { props: "props" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
type: Component, | ||
@@ -26,2 +26,3 @@ args: [{ template: '' }] | ||
updateAttributes: (attributes = {}) => this.updateAttributes(attributes), | ||
deleteNode: () => this.deleteNode() | ||
}; | ||
@@ -61,2 +62,6 @@ // create renderer | ||
} | ||
this.maybeMoveContentDOM(); | ||
return this.contentDOMElement; | ||
} | ||
maybeMoveContentDOM() { | ||
const contentElement = this.dom.querySelector('[data-node-view-content]'); | ||
@@ -68,3 +73,2 @@ if (this.contentDOMElement | ||
} | ||
return this.contentDOMElement; | ||
} | ||
@@ -84,2 +88,3 @@ update(node, decorations) { | ||
this.updateProps({ node, decorations }); | ||
this.maybeMoveContentDOM(); | ||
return true; | ||
@@ -102,2 +107,2 @@ } | ||
}; | ||
//# 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 { Decoration, NodeView as ProseMirrorNodeView } from 'prosemirror-view';\nimport { Node as ProseMirrorNode } from 'prosemirror-model';\nimport { AngularRenderer } from \"./AngularRenderer\";\n\n@Component({ template: '' })\nexport class AngularNodeViewComponent {\n  @Input() props!: NodeViewProps\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> implements ProseMirrorNodeView {\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    };\n\n    // create renderer\n    this.renderer = new AngularRenderer(this.component, injector);\n\n    // Pass input props to the component\n    this.renderer.instance.props = props;\n\n    if (this.extension.config.draggable) {\n      // Register drag handler\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\n      this.renderer.detectChanges();\n    }\n\n    // attach stopEvent\n    if (this.options.stopEvent) {\n      this.stopEvent = this.options.stopEvent;\n    }\n  }\n\n  private updateProps(props: Partial<NodeViewProps>) {\n    this.renderer.instance.props = {\n      ...this.renderer.instance.props,\n      ...props\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    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    return this.contentDOMElement;\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.updateProps({ node, decorations });\n\n    return true;\n  }\n\n  selectNode() {\n    this.updateProps({ selected: true });\n  }\n\n  deselectNode() {\n    this.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) as ProseMirrorNodeView;\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 { Decoration, NodeView as ProseMirrorNodeView } from 'prosemirror-view';\nimport { Node as ProseMirrorNode } from 'prosemirror-model';\nimport { AngularRenderer } from './AngularRenderer';\n\n@Component({ template: '' })\nexport class AngularNodeViewComponent {\n  @Input() props!: NodeViewProps\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> implements ProseMirrorNodeView {\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);\n\n    // Pass input props to the component\n    this.renderer.instance.props = props;\n\n    if (this.extension.config.draggable) {\n      // Register drag handler\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\n      this.renderer.detectChanges();\n    }\n\n    // attach stopEvent\n    if (this.options.stopEvent) {\n      this.stopEvent = this.options.stopEvent;\n    }\n  }\n\n  private updateProps(props: Partial<NodeViewProps>) {\n    this.renderer.instance.props = {\n      ...this.renderer.instance.props,\n      ...props\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.updateProps({ node, decorations });\n    this.maybeMoveContentDOM();\n\n    return true;\n  }\n\n  selectNode() {\n    this.updateProps({ selected: true });\n  }\n\n  deselectNode() {\n    this.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) as ProseMirrorNodeView;\n  };\n};\n"]} |
@@ -58,3 +58,3 @@ import * as i0 from '@angular/core'; | ||
// insert the editor in the dom | ||
this.el.nativeElement.appendChild(this.editor.options.element.firstChild); | ||
this.el.nativeElement.append(...Array.from(this.editor.options.element.childNodes)); | ||
// update the options for the editor | ||
@@ -77,4 +77,4 @@ this.editor.setOptions({ element: this.el.nativeElement }); | ||
} | ||
EditorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: EditorDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); | ||
EditorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: EditorDirective, selector: "tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]", inputs: { editor: "editor", outputFormat: "outputFormat" }, providers: [{ | ||
EditorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: EditorDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); | ||
EditorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: EditorDirective, selector: "tiptap[editor], [tiptap][editor], tiptap-editor[editor], [tiptapEditor][editor]", inputs: { editor: "editor", outputFormat: "outputFormat" }, providers: [{ | ||
provide: NG_VALUE_ACCESSOR, | ||
@@ -84,3 +84,3 @@ useExisting: forwardRef(() => EditorDirective), | ||
}], ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: EditorDirective, decorators: [{ | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: EditorDirective, decorators: [{ | ||
type: Directive, | ||
@@ -120,5 +120,5 @@ args: [{ | ||
} | ||
FloatingMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: FloatingMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
FloatingMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: FloatingMenuDirective, selector: "tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: FloatingMenuDirective, decorators: [{ | ||
FloatingMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: FloatingMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
FloatingMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: FloatingMenuDirective, selector: "tiptap-floating-menu[editor], [tiptapFloatingMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: FloatingMenuDirective, decorators: [{ | ||
type: Directive, | ||
@@ -153,5 +153,5 @@ args: [{ | ||
} | ||
BubbleMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: BubbleMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
BubbleMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: BubbleMenuDirective, selector: "tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: BubbleMenuDirective, decorators: [{ | ||
BubbleMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: BubbleMenuDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); | ||
BubbleMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: BubbleMenuDirective, selector: "tiptap-bubble-menu[editor], [tiptapBubbleMenu][editor]", inputs: { editor: "editor", tippyOptions: "tippyOptions" }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: BubbleMenuDirective, decorators: [{ | ||
type: Directive, | ||
@@ -173,5 +173,5 @@ args: [{ | ||
} | ||
DraggableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: DraggableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
DraggableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: DraggableDirective, selector: "[tiptapDraggable]", host: { properties: { "attr.draggable": "this.draggable", "attr.data-drag-handle": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: DraggableDirective, decorators: [{ | ||
DraggableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: DraggableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
DraggableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: DraggableDirective, selector: "[tiptapDraggable]", host: { properties: { "attr.draggable": "this.draggable", "attr.data-drag-handle": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: DraggableDirective, decorators: [{ | ||
type: Directive, | ||
@@ -194,5 +194,5 @@ args: [{ | ||
} | ||
NodeViewContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NodeViewContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
NodeViewContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.0", type: NodeViewContentDirective, selector: "[tiptapNodeViewContent]", host: { properties: { "attr.data-node-view-content": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NodeViewContentDirective, decorators: [{ | ||
NodeViewContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NodeViewContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); | ||
NodeViewContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.0.2", type: NodeViewContentDirective, selector: "[tiptapNodeViewContent]", host: { properties: { "attr.data-node-view-content": "this.handle" } }, ngImport: i0 }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NodeViewContentDirective, decorators: [{ | ||
type: Directive, | ||
@@ -209,4 +209,4 @@ args: [{ | ||
} | ||
NgxTiptapModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
NgxTiptapModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule, declarations: [EditorDirective, | ||
NgxTiptapModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
NgxTiptapModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule, declarations: [EditorDirective, | ||
FloatingMenuDirective, | ||
@@ -220,4 +220,4 @@ BubbleMenuDirective, | ||
NodeViewContentDirective] }); | ||
NgxTiptapModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: NgxTiptapModule, decorators: [{ | ||
NgxTiptapModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: NgxTiptapModule, decorators: [{ | ||
type: NgModule, | ||
@@ -270,5 +270,5 @@ args: [{ | ||
} | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.0", type: AngularNodeViewComponent, selector: "ng-component", inputs: { props: "props" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
AngularNodeViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: AngularNodeViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AngularNodeViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.2", type: AngularNodeViewComponent, selector: "ng-component", inputs: { props: "props" }, ngImport: i0, template: '', isInline: true }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.2", ngImport: i0, type: AngularNodeViewComponent, decorators: [{ | ||
type: Component, | ||
@@ -290,2 +290,3 @@ args: [{ template: '' }] | ||
updateAttributes: (attributes = {}) => this.updateAttributes(attributes), | ||
deleteNode: () => this.deleteNode() | ||
}; | ||
@@ -325,2 +326,6 @@ // create renderer | ||
} | ||
this.maybeMoveContentDOM(); | ||
return this.contentDOMElement; | ||
} | ||
maybeMoveContentDOM() { | ||
const contentElement = this.dom.querySelector('[data-node-view-content]'); | ||
@@ -332,3 +337,2 @@ if (this.contentDOMElement | ||
} | ||
return this.contentDOMElement; | ||
} | ||
@@ -348,2 +352,3 @@ update(node, decorations) { | ||
this.updateProps({ node, decorations }); | ||
this.maybeMoveContentDOM(); | ||
return true; | ||
@@ -350,0 +355,0 @@ } |
@@ -1,2 +0,2 @@ | ||
import { ElementRef, Injector, Type } from "@angular/core"; | ||
import { ElementRef, Injector, Type } from '@angular/core'; | ||
export declare class AngularRenderer<C> { | ||
@@ -3,0 +3,0 @@ private applicationRef; |
@@ -1,3 +0,3 @@ | ||
import { Injector, Type } from "@angular/core"; | ||
import { NodeViewProps, NodeViewRenderer } from "@tiptap/core"; | ||
import { Injector, Type } from '@angular/core'; | ||
import { NodeViewProps, NodeViewRenderer } from '@tiptap/core'; | ||
import { Decoration } from 'prosemirror-view'; | ||
@@ -4,0 +4,0 @@ import { Node as ProseMirrorNode } from 'prosemirror-model'; |
{ | ||
"name": "ngx-tiptap", | ||
"description": "Angular bindings for Tiptap v2", | ||
"version": "2.0.0", | ||
"version": "2.1.0", | ||
"license": "MIT", | ||
@@ -18,9 +18,10 @@ "repository": "https://github.com/sibiraj-s/ngx-tiptap.git", | ||
"peerDependencies": { | ||
"@angular/common": "^12.0.0", | ||
"@angular/core": "^12.0.0", | ||
"@tiptap/core": "2.0.0-beta.61", | ||
"@tiptap/extension-bubble-menu": "2.0.0-beta.16", | ||
"@tiptap/extension-floating-menu": "2.0.0-beta.13", | ||
"@angular/common": ">=12.0.0", | ||
"@angular/core": ">=12.0.0", | ||
"@angular/forms": ">=12.0.0", | ||
"@tiptap/core": "^2.0.0-beta.73", | ||
"@tiptap/extension-bubble-menu": "^2.0.0-beta.20", | ||
"@tiptap/extension-floating-menu": "^2.0.0-beta.16", | ||
"prosemirror-model": "^1.14.1", | ||
"prosemirror-view": "^1.18.5" | ||
"prosemirror-view": "^1.18.7" | ||
}, | ||
@@ -27,0 +28,0 @@ "dependencies": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
188235
1.29%1601
1.01%9
12.5%