ng2-ckeditor
Advanced tools
Comparing version 1.3.2 to 1.3.3
@@ -23,4 +23,4 @@ (function (global, factory) { | ||
editor.instance.addCommand(this.command, { | ||
exec: function (evt) { | ||
_this.click.emit(evt); | ||
exec: function (edit) { | ||
_this.click.emit(edit); | ||
return true; | ||
@@ -37,6 +37,8 @@ }, | ||
CKButtonDirective.prototype.ngOnInit = function () { | ||
if (!this.name) | ||
if (!this.name) { | ||
throw new Error('Attribute "name" is required on <ckbutton>'); | ||
if (!this.command) | ||
} | ||
if (!this.command) { | ||
throw new Error('Attribute "command" is required on <ckbutton>'); | ||
} | ||
}; | ||
@@ -219,4 +221,5 @@ return CKButtonDirective; | ||
if (_this.debounce) { | ||
if (_this.debounceTimeout) | ||
if (_this.debounceTimeout) { | ||
clearTimeout(_this.debounceTimeout); | ||
} | ||
_this.debounceTimeout = window.setTimeout(function () { | ||
@@ -281,4 +284,2 @@ _this.updateValue(value); | ||
}; | ||
CKEditorComponent.prototype.onChange = function (_) { }; | ||
CKEditorComponent.prototype.onTouched = function () { }; | ||
CKEditorComponent.prototype.registerOnChange = function (fn) { | ||
@@ -285,0 +286,0 @@ this.onChange = fn; |
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/forms"),require("@angular/common")):"function"==typeof define&&define.amd?define("ng2-ckeditor",["exports","@angular/core","@angular/forms","@angular/common"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["ng2-ckeditor"]={},t.ng.core,t.ng.forms,t.ng.common)}(this,(function(t,e,n,o){"use strict";var i=function(){function t(){this.click=new e.EventEmitter}return t.prototype.initialize=function(t){var e=this;t.instance.addCommand(this.command,{exec:function(t){return e.click.emit(t),!0}}),t.instance.ui.addButton(this.name,{label:this.label,command:this.command,toolbar:this.toolbar,icon:this.icon})},t.prototype.ngOnInit=function(){if(!this.name)throw new Error('Attribute "name" is required on <ckbutton>');if(!this.command)throw new Error('Attribute "command" is required on <ckbutton>')},t}();i.decorators=[{type:e.Directive,args:[{selector:"ckbutton"}]}],i.propDecorators={click:[{type:e.Output}],label:[{type:e.Input}],command:[{type:e.Input}],toolbar:[{type:e.Input}],name:[{type:e.Input}],icon:[{type:e.Input}]};var r=function(){function t(){}return t.prototype.ngAfterContentInit=function(){var t=this;this.toolbarButtons.forEach((function(e){return e.toolbar=t.name}))},t.prototype.initialize=function(t){t.instance.ui.addToolbarGroup(this.name,this.previous,this.subgroupOf),this.toolbarButtons.forEach((function(e){e.initialize(t)}))},t}();r.decorators=[{type:e.Directive,args:[{selector:"ckgroup"}]}],r.propDecorators={name:[{type:e.Input}],previous:[{type:e.Input}],subgroupOf:[{type:e.Input}],toolbarButtons:[{type:e.ContentChildren,args:[i]}]};var s=function(){function t(t){this.zone=t,this.change=new e.EventEmitter,this.editorChange=new e.EventEmitter,this.ready=new e.EventEmitter,this.blur=new e.EventEmitter,this.focus=new e.EventEmitter,this.contentDom=new e.EventEmitter,this.fileUploadRequest=new e.EventEmitter,this.fileUploadResponse=new e.EventEmitter,this.paste=new e.EventEmitter,this.drop=new e.EventEmitter,this._value="",this.destroyed=!1}return Object.defineProperty(t.prototype,"value",{get:function(){return this._value},set:function(t){t!==this._value&&(this._value=t,this.onChange(t))},enumerable:!1,configurable:!0}),t.prototype.ngOnChanges=function(t){t.readonly&&this.instance&&this.instance.setReadOnly(t.readonly.currentValue)},t.prototype.ngOnDestroy=function(){var t=this;this.destroyed=!0,this.zone.runOutsideAngular((function(){t.instance&&(CKEDITOR.removeAllListeners(),t.instance.destroy(),t.instance=null)}))},t.prototype.ngAfterViewInit=function(){this.destroyed||this.ckeditorInit(this.config||{})},t.prototype.ngAfterViewChecked=function(){this.ckeditorInit(this.config||{})},t.prototype.updateValue=function(t){var e=this;this.zone.run((function(){e.value=t,e.onChange(t),e.onTouched(),e.change.emit(t)}))},t.prototype.ckeditorInit=function(t){var e=this;if("undefined"==typeof CKEDITOR)console.warn("CKEditor 4.x is missing (http://ckeditor.com/)");else{if(this.instance||!this.documentContains(this.host.nativeElement))return;this.readonly&&(t.readOnly=this.readonly),this.instance=CKEDITOR.replace(this.host.nativeElement,t),this.instance.setData(this.value),this.instance.on("instanceReady",(function(t){e.instance.getData()!==e.value&&e.instance.setData(e.value),e.ready.emit(t)})),this.instance.on("change",(function(t){e.onTouched();var n=e.instance.getData();e.value!==n&&(e.debounce?(e.debounceTimeout&&clearTimeout(e.debounceTimeout),e.debounceTimeout=window.setTimeout((function(){e.updateValue(n),e.debounceTimeout=null}),parseInt(e.debounce))):e.updateValue(n)),e.editorChange.emit(t)})),this.instance.on("blur",(function(t){e.blur.emit(t)})),this.instance.on("focus",(function(t){e.focus.emit(t)})),this.instance.on("contentDom",(function(t){e.contentDom.emit(t)})),this.instance.on("fileUploadRequest",(function(t){e.fileUploadRequest.emit(t)})),this.instance.on("fileUploadResponse",(function(t){e.fileUploadResponse.emit(t)})),this.instance.on("paste",(function(t){e.paste.emit(t)})),this.instance.on("drop",(function(t){e.drop.emit(t)})),this.toolbarGroups.forEach((function(t){t.initialize(e)})),this.toolbarButtons.forEach((function(t){t.initialize(e)}))}},t.prototype.writeValue=function(t){this._value=t,this.instance&&this.instance.setData(t)},t.prototype.onChange=function(t){},t.prototype.onTouched=function(){},t.prototype.registerOnChange=function(t){this.onChange=t},t.prototype.registerOnTouched=function(t){this.onTouched=t},t.prototype.documentContains=function(t){return document.contains?document.contains(t):document.body.contains(t)},t}();s.decorators=[{type:e.Component,args:[{selector:"ckeditor",providers:[{provide:n.NG_VALUE_ACCESSOR,useExisting:e.forwardRef((function(){return s})),multi:!0}],template:"<textarea #host></textarea>"}]}],s.ctorParameters=function(){return[{type:e.NgZone}]},s.propDecorators={config:[{type:e.Input}],readonly:[{type:e.Input}],debounce:[{type:e.Input}],change:[{type:e.Output}],editorChange:[{type:e.Output}],ready:[{type:e.Output}],blur:[{type:e.Output}],focus:[{type:e.Output}],contentDom:[{type:e.Output}],fileUploadRequest:[{type:e.Output}],fileUploadResponse:[{type:e.Output}],paste:[{type:e.Output}],drop:[{type:e.Output}],host:[{type:e.ViewChild,args:["host",{static:!1}]}],toolbarButtons:[{type:e.ContentChildren,args:[i]}],toolbarGroups:[{type:e.ContentChildren,args:[r]}],value:[{type:e.Input}]};var u=function(){};u.decorators=[{type:e.NgModule,args:[{imports:[o.CommonModule],declarations:[s,i,r],exports:[s,i,r]}]}],t.CKEditorComponent=s,t.CKEditorModule=u,t.ɵa=i,t.ɵb=r,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/forms"),require("@angular/common")):"function"==typeof define&&define.amd?define("ng2-ckeditor",["exports","@angular/core","@angular/forms","@angular/common"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["ng2-ckeditor"]={},t.ng.core,t.ng.forms,t.ng.common)}(this,(function(t,e,n,o){"use strict";var i=function(){function t(){this.click=new e.EventEmitter}return t.prototype.initialize=function(t){var e=this;t.instance.addCommand(this.command,{exec:function(t){return e.click.emit(t),!0}}),t.instance.ui.addButton(this.name,{label:this.label,command:this.command,toolbar:this.toolbar,icon:this.icon})},t.prototype.ngOnInit=function(){if(!this.name)throw new Error('Attribute "name" is required on <ckbutton>');if(!this.command)throw new Error('Attribute "command" is required on <ckbutton>')},t}();i.decorators=[{type:e.Directive,args:[{selector:"ckbutton"}]}],i.propDecorators={click:[{type:e.Output}],label:[{type:e.Input}],command:[{type:e.Input}],toolbar:[{type:e.Input}],name:[{type:e.Input}],icon:[{type:e.Input}]};var r=function(){function t(){}return t.prototype.ngAfterContentInit=function(){var t=this;this.toolbarButtons.forEach((function(e){return e.toolbar=t.name}))},t.prototype.initialize=function(t){t.instance.ui.addToolbarGroup(this.name,this.previous,this.subgroupOf),this.toolbarButtons.forEach((function(e){e.initialize(t)}))},t}();r.decorators=[{type:e.Directive,args:[{selector:"ckgroup"}]}],r.propDecorators={name:[{type:e.Input}],previous:[{type:e.Input}],subgroupOf:[{type:e.Input}],toolbarButtons:[{type:e.ContentChildren,args:[i]}]};var s=function(){function t(t){this.zone=t,this.change=new e.EventEmitter,this.editorChange=new e.EventEmitter,this.ready=new e.EventEmitter,this.blur=new e.EventEmitter,this.focus=new e.EventEmitter,this.contentDom=new e.EventEmitter,this.fileUploadRequest=new e.EventEmitter,this.fileUploadResponse=new e.EventEmitter,this.paste=new e.EventEmitter,this.drop=new e.EventEmitter,this._value="",this.destroyed=!1}return Object.defineProperty(t.prototype,"value",{get:function(){return this._value},set:function(t){t!==this._value&&(this._value=t,this.onChange(t))},enumerable:!1,configurable:!0}),t.prototype.ngOnChanges=function(t){t.readonly&&this.instance&&this.instance.setReadOnly(t.readonly.currentValue)},t.prototype.ngOnDestroy=function(){var t=this;this.destroyed=!0,this.zone.runOutsideAngular((function(){t.instance&&(CKEDITOR.removeAllListeners(),t.instance.destroy(),t.instance=null)}))},t.prototype.ngAfterViewInit=function(){this.destroyed||this.ckeditorInit(this.config||{})},t.prototype.ngAfterViewChecked=function(){this.ckeditorInit(this.config||{})},t.prototype.updateValue=function(t){var e=this;this.zone.run((function(){e.value=t,e.onChange(t),e.onTouched(),e.change.emit(t)}))},t.prototype.ckeditorInit=function(t){var e=this;if("undefined"==typeof CKEDITOR)console.warn("CKEditor 4.x is missing (http://ckeditor.com/)");else{if(this.instance||!this.documentContains(this.host.nativeElement))return;this.readonly&&(t.readOnly=this.readonly),this.instance=CKEDITOR.replace(this.host.nativeElement,t),this.instance.setData(this.value),this.instance.on("instanceReady",(function(t){e.instance.getData()!==e.value&&e.instance.setData(e.value),e.ready.emit(t)})),this.instance.on("change",(function(t){e.onTouched();var n=e.instance.getData();e.value!==n&&(e.debounce?(e.debounceTimeout&&clearTimeout(e.debounceTimeout),e.debounceTimeout=window.setTimeout((function(){e.updateValue(n),e.debounceTimeout=null}),parseInt(e.debounce))):e.updateValue(n)),e.editorChange.emit(t)})),this.instance.on("blur",(function(t){e.blur.emit(t)})),this.instance.on("focus",(function(t){e.focus.emit(t)})),this.instance.on("contentDom",(function(t){e.contentDom.emit(t)})),this.instance.on("fileUploadRequest",(function(t){e.fileUploadRequest.emit(t)})),this.instance.on("fileUploadResponse",(function(t){e.fileUploadResponse.emit(t)})),this.instance.on("paste",(function(t){e.paste.emit(t)})),this.instance.on("drop",(function(t){e.drop.emit(t)})),this.toolbarGroups.forEach((function(t){t.initialize(e)})),this.toolbarButtons.forEach((function(t){t.initialize(e)}))}},t.prototype.writeValue=function(t){this._value=t,this.instance&&this.instance.setData(t)},t.prototype.registerOnChange=function(t){this.onChange=t},t.prototype.registerOnTouched=function(t){this.onTouched=t},t.prototype.documentContains=function(t){return document.contains?document.contains(t):document.body.contains(t)},t}();s.decorators=[{type:e.Component,args:[{selector:"ckeditor",providers:[{provide:n.NG_VALUE_ACCESSOR,useExisting:e.forwardRef((function(){return s})),multi:!0}],template:"<textarea #host></textarea>"}]}],s.ctorParameters=function(){return[{type:e.NgZone}]},s.propDecorators={config:[{type:e.Input}],readonly:[{type:e.Input}],debounce:[{type:e.Input}],change:[{type:e.Output}],editorChange:[{type:e.Output}],ready:[{type:e.Output}],blur:[{type:e.Output}],focus:[{type:e.Output}],contentDom:[{type:e.Output}],fileUploadRequest:[{type:e.Output}],fileUploadResponse:[{type:e.Output}],paste:[{type:e.Output}],drop:[{type:e.Output}],host:[{type:e.ViewChild,args:["host",{static:!1}]}],toolbarButtons:[{type:e.ContentChildren,args:[i]}],toolbarGroups:[{type:e.ContentChildren,args:[r]}],value:[{type:e.Input}]};var a=function(){};a.decorators=[{type:e.NgModule,args:[{imports:[o.CommonModule],declarations:[s,i,r],exports:[s,i,r]}]}],t.CKEditorComponent=s,t.CKEditorModule=a,t.ɵa=i,t.ɵb=r,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=ng2-ckeditor.umd.min.js.map |
@@ -0,1 +1,2 @@ | ||
/// <reference types="ckeditor" /> | ||
import { OnInit, EventEmitter } from '@angular/core'; | ||
@@ -13,3 +14,3 @@ import { CKEditorComponent } from './ckeditor.component'; | ||
export declare class CKButtonDirective implements OnInit { | ||
click: EventEmitter<any>; | ||
click: EventEmitter<CKEDITOR.editor>; | ||
label: string; | ||
@@ -16,0 +17,0 @@ command: string; |
@@ -36,4 +36,4 @@ /// <reference types="ckeditor" /> | ||
constructor(zone: NgZone); | ||
get value(): any; | ||
set value(v: any); | ||
get value(): string; | ||
set value(v: string); | ||
ngOnChanges(changes: SimpleChanges): void; | ||
@@ -63,8 +63,8 @@ /** | ||
*/ | ||
writeValue(value: any): void; | ||
onChange(_: any): void; | ||
onTouched(): void; | ||
registerOnChange(fn: any): void; | ||
registerOnTouched(fn: any): void; | ||
writeValue(value: string): void; | ||
onChange: (_: string) => void; | ||
onTouched: () => void; | ||
registerOnChange(fn: () => void): void; | ||
registerOnTouched(fn: () => void): void; | ||
private documentContains; | ||
} |
@@ -16,3 +16,3 @@ import { AfterContentInit, QueryList } from '@angular/core'; | ||
name: string; | ||
previous: any; | ||
previous: string | number; | ||
subgroupOf: string; | ||
@@ -19,0 +19,0 @@ toolbarButtons: QueryList<CKButtonDirective>; |
@@ -17,4 +17,4 @@ import { Directive, EventEmitter, Output, Input } from '@angular/core'; | ||
editor.instance.addCommand(this.command, { | ||
exec: (evt) => { | ||
this.click.emit(evt); | ||
exec: (edit) => { | ||
this.click.emit(edit); | ||
return true; | ||
@@ -31,6 +31,8 @@ }, | ||
ngOnInit() { | ||
if (!this.name) | ||
if (!this.name) { | ||
throw new Error('Attribute "name" is required on <ckbutton>'); | ||
if (!this.command) | ||
} | ||
if (!this.command) { | ||
throw new Error('Attribute "command" is required on <ckbutton>'); | ||
} | ||
} | ||
@@ -51,2 +53,2 @@ } | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tidXR0b24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uL3NyYy8iLCJzb3VyY2VzIjpbImNrYnV0dG9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9FOzs7Ozs7OztHQVFHO0FBSUgsTUFBTSxPQUFPLGlCQUFpQjtJQUg5QjtRQUlZLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBMkJ2QyxDQUFDO0lBcEJDLFVBQVUsQ0FBQyxNQUF5QjtRQUNsQyxNQUFNLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZDLElBQUksRUFBRSxDQUFDLEdBQVEsRUFBRSxFQUFFO2dCQUNqQixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDckIsT0FBTyxJQUFJLENBQUM7WUFDZCxDQUFDO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsTUFBTSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDdEMsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ2pCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87WUFDckIsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1NBQ2hCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO1lBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyw0Q0FBNEMsQ0FBQyxDQUFDO1FBQzlFLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTztZQUFFLE1BQU0sSUFBSSxLQUFLLENBQUMsK0NBQStDLENBQUMsQ0FBQztJQUN0RixDQUFDOzs7WUE5QkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxVQUFVO2FBQ3JCOzs7b0JBRUUsTUFBTTtvQkFDTixLQUFLO3NCQUNMLEtBQUs7c0JBQ0wsS0FBSzttQkFDTCxLQUFLO21CQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIE9uSW5pdCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDS0VkaXRvckNvbXBvbmVudCB9IGZyb20gJy4vY2tlZGl0b3IuY29tcG9uZW50JztcblxuLyoqXG4gKiBDS0dyb3VwIGNvbXBvbmVudFxuICogVXNhZ2UgOlxuICogIDxja2VkaXRvciBbKG5nTW9kZWwpXT1cImRhdGFcIiBbY29uZmlnXT1cInsuLi59XCIgZGVib3VuY2U9XCI1MDBcIj5cbiAqICAgICAgPGNrYnV0dG9uIFtuYW1lXT1cIidTYXZlQnV0dG9uJ1wiIFtjb21tYW5kXT1cIidzYXZlQ29tbWFuZCdcIiAoY2xpY2spPVwic2F2ZSgkZXZlbnQpXCJcbiAqICAgICAgICAgICAgICAgIFtpY29uXT1cIicvc2F2ZS5wbmcnXCIgW3Rvb2xiYXJdPVwiJ2N1c3RvbUdyb3VwLDEnXCIgW2xhYmVsXT1cIidTYXZlJ1wiPlxuICogICAgICA8L2NrYnV0dG9uPlxuICogICA8L2NrZWRpdG9yPlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdja2J1dHRvbicsXG59KVxuZXhwb3J0IGNsYXNzIENLQnV0dG9uRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgQE91dHB1dCgpIGNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICBASW5wdXQoKSBsYWJlbDogc3RyaW5nO1xuICBASW5wdXQoKSBjb21tYW5kOiBzdHJpbmc7XG4gIEBJbnB1dCgpIHRvb2xiYXI6IHN0cmluZztcbiAgQElucHV0KCkgbmFtZTogc3RyaW5nO1xuICBASW5wdXQoKSBpY29uOiBzdHJpbmc7XG5cbiAgaW5pdGlhbGl6ZShlZGl0b3I6IENLRWRpdG9yQ29tcG9uZW50KSB7XG4gICAgZWRpdG9yLmluc3RhbmNlLmFkZENvbW1hbmQodGhpcy5jb21tYW5kLCB7XG4gICAgICBleGVjOiAoZXZ0OiBhbnkpID0+IHtcbiAgICAgICAgdGhpcy5jbGljay5lbWl0KGV2dCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfSxcbiAgICB9KTtcblxuICAgIGVkaXRvci5pbnN0YW5jZS51aS5hZGRCdXR0b24odGhpcy5uYW1lLCB7XG4gICAgICBsYWJlbDogdGhpcy5sYWJlbCxcbiAgICAgIGNvbW1hbmQ6IHRoaXMuY29tbWFuZCxcbiAgICAgIHRvb2xiYXI6IHRoaXMudG9vbGJhcixcbiAgICAgIGljb246IHRoaXMuaWNvbixcbiAgICB9KTtcbiAgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5uYW1lKSB0aHJvdyBuZXcgRXJyb3IoJ0F0dHJpYnV0ZSBcIm5hbWVcIiBpcyByZXF1aXJlZCBvbiA8Y2tidXR0b24+Jyk7XG4gICAgaWYgKCF0aGlzLmNvbW1hbmQpIHRocm93IG5ldyBFcnJvcignQXR0cmlidXRlIFwiY29tbWFuZFwiIGlzIHJlcXVpcmVkIG9uIDxja2J1dHRvbj4nKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tidXR0b24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uL3NyYy8iLCJzb3VyY2VzIjpbImNrYnV0dG9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRy9FOzs7Ozs7OztHQVFHO0FBSUgsTUFBTSxPQUFPLGlCQUFpQjtJQUg5QjtRQUlZLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBbUIsQ0FBQztJQStCeEQsQ0FBQztJQXhCUSxVQUFVLENBQUMsTUFBeUI7UUFDekMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUN2QyxJQUFJLEVBQUUsQ0FBQyxJQUFxQixFQUFXLEVBQUU7Z0JBQ3ZDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUN0QixPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7U0FDRixDQUFDLENBQUM7UUFFSCxNQUFNLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUN0QyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDakIsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1lBQ3JCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsNENBQTRDLENBQUMsQ0FBQztTQUMvRDtRQUNELElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsK0NBQStDLENBQUMsQ0FBQztTQUNsRTtJQUNILENBQUM7OztZQWxDRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLFVBQVU7YUFDckI7OztvQkFFRSxNQUFNO29CQUNOLEtBQUs7c0JBQ0wsS0FBSztzQkFDTCxLQUFLO21CQUNMLEtBQUs7bUJBQ0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgT25Jbml0LCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENLRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuXG4vKipcbiAqIENLR3JvdXAgY29tcG9uZW50XG4gKiBVc2FnZSA6XG4gKiAgPGNrZWRpdG9yIFsobmdNb2RlbCldPVwiZGF0YVwiIFtjb25maWddPVwiey4uLn1cIiBkZWJvdW5jZT1cIjUwMFwiPlxuICogICAgICA8Y2tidXR0b24gW25hbWVdPVwiJ1NhdmVCdXR0b24nXCIgW2NvbW1hbmRdPVwiJ3NhdmVDb21tYW5kJ1wiIChjbGljayk9XCJzYXZlKCRldmVudClcIlxuICogICAgICAgICAgICAgICAgW2ljb25dPVwiJy9zYXZlLnBuZydcIiBbdG9vbGJhcl09XCInY3VzdG9tR3JvdXAsMSdcIiBbbGFiZWxdPVwiJ1NhdmUnXCI+XG4gKiAgICAgIDwvY2tidXR0b24+XG4gKiAgIDwvY2tlZGl0b3I+XG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2NrYnV0dG9uJyxcbn0pXG5leHBvcnQgY2xhc3MgQ0tCdXR0b25EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICBAT3V0cHV0KCkgY2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPENLRURJVE9SLmVkaXRvcj4oKTtcbiAgQElucHV0KCkgbGFiZWw6IHN0cmluZztcbiAgQElucHV0KCkgY29tbWFuZDogc3RyaW5nO1xuICBASW5wdXQoKSB0b29sYmFyOiBzdHJpbmc7XG4gIEBJbnB1dCgpIG5hbWU6IHN0cmluZztcbiAgQElucHV0KCkgaWNvbjogc3RyaW5nO1xuXG4gIHB1YmxpYyBpbml0aWFsaXplKGVkaXRvcjogQ0tFZGl0b3JDb21wb25lbnQpOiB2b2lkIHtcbiAgICBlZGl0b3IuaW5zdGFuY2UuYWRkQ29tbWFuZCh0aGlzLmNvbW1hbmQsIHtcbiAgICAgIGV4ZWM6IChlZGl0OiBDS0VESVRPUi5lZGl0b3IpOiBib29sZWFuID0+IHtcbiAgICAgICAgdGhpcy5jbGljay5lbWl0KGVkaXQpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICBlZGl0b3IuaW5zdGFuY2UudWkuYWRkQnV0dG9uKHRoaXMubmFtZSwge1xuICAgICAgbGFiZWw6IHRoaXMubGFiZWwsXG4gICAgICBjb21tYW5kOiB0aGlzLmNvbW1hbmQsXG4gICAgICB0b29sYmFyOiB0aGlzLnRvb2xiYXIsXG4gICAgICBpY29uOiB0aGlzLmljb24sXG4gICAgfSk7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMubmFtZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdBdHRyaWJ1dGUgXCJuYW1lXCIgaXMgcmVxdWlyZWQgb24gPGNrYnV0dG9uPicpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuY29tbWFuZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdBdHRyaWJ1dGUgXCJjb21tYW5kXCIgaXMgcmVxdWlyZWQgb24gPGNrYnV0dG9uPicpO1xuICAgIH1cbiAgfVxufVxuIl19 |
@@ -115,8 +115,9 @@ // Imports | ||
this.onTouched(); | ||
let value = this.instance.getData(); | ||
const value = this.instance.getData(); | ||
if (this.value !== value) { | ||
// Debounce update | ||
if (this.debounce) { | ||
if (this.debounceTimeout) | ||
if (this.debounceTimeout) { | ||
clearTimeout(this.debounceTimeout); | ||
} | ||
this.debounceTimeout = window.setTimeout(() => { | ||
@@ -181,4 +182,2 @@ this.updateValue(value); | ||
} | ||
onChange(_) { } | ||
onTouched() { } | ||
registerOnChange(fn) { | ||
@@ -229,2 +228,2 @@ this.onChange = fn; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"../../src/","sources":["ckeditor.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Imports\nimport {\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  EventEmitter,\n  NgZone,\n  forwardRef,\n  QueryList,\n  AfterViewInit,\n  ContentChildren,\n  SimpleChanges,\n  OnChanges,\n  OnDestroy,\n  ElementRef\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CKButtonDirective } from './ckbutton.directive';\nimport { CKGroupDirective } from './ckgroup.directive';\n\n/**\n * CKEditor component\n * Usage :\n *  <ckeditor [(ngModel)]=\"data\" [config]=\"{...}\" debounce=\"500\"></ckeditor>\n */\n@Component({\n  selector: 'ckeditor',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CKEditorComponent),\n      multi: true,\n    },\n  ],\n  template: `<textarea #host></textarea>`,\n})\nexport class CKEditorComponent implements OnChanges, AfterViewInit, OnDestroy {\n  @Input() config: CKEDITOR.config;\n  @Input() readonly: boolean;\n  @Input() debounce: string;\n\n  @Output() change = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() editorChange = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() ready = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() blur = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() focus = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() contentDom = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() fileUploadRequest = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() fileUploadResponse = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() paste = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() drop = new EventEmitter<CKEDITOR.eventInfo>();\n\n  @ViewChild('host', { static: false }) host: ElementRef<HTMLTextAreaElement>;\n\n  @ContentChildren(CKButtonDirective) toolbarButtons: QueryList<CKButtonDirective>;\n  @ContentChildren(CKGroupDirective) toolbarGroups: QueryList<CKGroupDirective>;\n\n  _value = '';\n  instance: CKEDITOR.editor;\n  debounceTimeout: number;\n  private destroyed = false;\n\n  /**\n   * Constructor\n   */\n  constructor(private zone: NgZone) {}\n\n  get value(): any {\n    return this._value;\n  }\n  @Input()\n  set value(v) {\n    if (v !== this._value) {\n      this._value = v;\n      this.onChange(v);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.readonly && this.instance) {\n      this.instance.setReadOnly(changes.readonly.currentValue);\n    }\n  }\n\n  /**\n   * On component destroy\n   */\n  ngOnDestroy() {\n    this.destroyed = true;\n    this.zone.runOutsideAngular( () => {\n      if (this.instance) {\n        CKEDITOR.removeAllListeners();\n        this.instance.destroy();\n        this.instance = null;\n      }\n    });\n  }\n\n  /**\n   * On component view init\n   */\n  ngAfterViewInit() {\n    if (this.destroyed) {\n      return;\n    }\n    this.ckeditorInit(this.config || {});\n  }\n\n  /**\n   * On component view checked\n   */\n  ngAfterViewChecked() {\n    this.ckeditorInit(this.config || {});\n  }\n\n  /**\n   * Value update process\n   */\n  updateValue(value: any) {\n    this.zone.run(() => {\n      this.value = value;\n\n      this.onChange(value);\n\n      this.onTouched();\n      this.change.emit(value);\n    });\n  }\n\n  /**\n   * CKEditor init\n   */\n  ckeditorInit(config: CKEDITOR.config) {\n    if (typeof CKEDITOR === 'undefined') {\n      console.warn('CKEditor 4.x is missing (http://ckeditor.com/)');\n    } else {\n      // Check textarea exists\n      if (this.instance || !this.documentContains(this.host.nativeElement)) {\n        return;\n      }\n\n      if (this.readonly) {\n        config.readOnly = this.readonly;\n      }\n      // CKEditor replace textarea\n      this.instance = CKEDITOR.replace(this.host.nativeElement, config);\n\n      // Set initial value\n      this.instance.setData(this.value);\n\n      // listen for instanceReady event\n      this.instance.on('instanceReady', (evt: CKEDITOR.eventInfo) => {\n        // if value has changed while instance loading\n        // update instance with current component value\n        if (this.instance.getData() !== this.value) {\n          this.instance.setData(this.value);\n        }\n\n        // send the evt to the EventEmitter\n        this.ready.emit(evt);\n      });\n\n      // CKEditor change event\n      this.instance.on('change', (evt: CKEDITOR.eventInfo) => {\n        this.onTouched();\n        let value = this.instance.getData();\n\n        if (this.value !== value) {\n          // Debounce update\n          if (this.debounce) {\n            if (this.debounceTimeout) clearTimeout(this.debounceTimeout);\n            this.debounceTimeout = window.setTimeout(() => {\n              this.updateValue(value);\n              this.debounceTimeout = null;\n            }, parseInt(this.debounce));\n\n            // Live update\n          } else {\n            this.updateValue(value);\n          }\n        }\n\n        // Original ckeditor event dispatch\n        this.editorChange.emit(evt);\n      });\n\n      // CKEditor blur event\n      this.instance.on('blur', (evt: CKEDITOR.eventInfo) => {\n        this.blur.emit(evt);\n      });\n\n      // CKEditor focus event\n      this.instance.on('focus', (evt: CKEDITOR.eventInfo) => {\n        this.focus.emit(evt);\n      });\n\n      // CKEditor contentDom event\n      this.instance.on('contentDom', (evt: CKEDITOR.eventInfo) => {\n        this.contentDom.emit(evt);\n      });\n\n      // CKEditor fileUploadRequest event\n      this.instance.on('fileUploadRequest', (evt: CKEDITOR.eventInfo) => {\n        this.fileUploadRequest.emit(evt);\n      });\n\n      // CKEditor fileUploadResponse event\n      this.instance.on('fileUploadResponse', (evt: CKEDITOR.eventInfo) => {\n        this.fileUploadResponse.emit(evt);\n      });\n\n      // CKEditor paste event\n      this.instance.on('paste', (evt: CKEDITOR.eventInfo) => {\n        this.paste.emit(evt);\n      });\n\n      // CKEditor drop event\n      this.instance.on('drop', (evt: CKEDITOR.eventInfo) => {\n        this.drop.emit(evt);\n      });\n\n      // Add Toolbar Groups to Editor. This will also add Buttons within groups.\n      this.toolbarGroups.forEach((group) => {\n        group.initialize(this);\n      });\n      // Add Toolbar Buttons to Editor.\n      this.toolbarButtons.forEach((button) => {\n        button.initialize(this);\n      });\n    }\n  }\n\n  /**\n   * Implements ControlValueAccessor\n   */\n  writeValue(value: any) {\n    this._value = value;\n    if (this.instance) this.instance.setData(value);\n  }\n  onChange(_: any) {}\n  onTouched() {}\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  private documentContains(node: Node) {\n    return document.contains ? document.contains(node) : document.body.contains(node);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"../../src/","sources":["ckeditor.component.ts"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,SAAS,EACT,YAAY,EACZ,MAAM,EACN,UAAU,EAGV,eAAe,EAKhB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD;;;;GAIG;AAYH,MAAM,OAAO,iBAAiB;IA0B5B;;OAEG;IACH,YAAoB,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;QAxBtB,WAAM,GAAG,IAAI,YAAY,EAAsB,CAAC;QAChD,iBAAY,GAAG,IAAI,YAAY,EAAsB,CAAC;QACtD,UAAK,GAAG,IAAI,YAAY,EAAsB,CAAC;QAC/C,SAAI,GAAG,IAAI,YAAY,EAAsB,CAAC;QAC9C,UAAK,GAAG,IAAI,YAAY,EAAsB,CAAC;QAC/C,eAAU,GAAG,IAAI,YAAY,EAAsB,CAAC;QACpD,sBAAiB,GAAG,IAAI,YAAY,EAAsB,CAAC;QAC3D,uBAAkB,GAAG,IAAI,YAAY,EAAsB,CAAC;QAC5D,UAAK,GAAG,IAAI,YAAY,EAAsB,CAAC;QAC/C,SAAI,GAAG,IAAI,YAAY,EAAsB,CAAC;QAOxD,WAAM,GAAG,EAAE,CAAC;QAGJ,cAAS,GAAG,KAAK,CAAC;IAKS,CAAC;IAEpC,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IACI,KAAK,CAAC,CAAS;QACjB,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,EAAE;YACrB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;SAClB;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACrC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;SAC1D;IACH,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,QAAQ,CAAC,kBAAkB,EAAE,CAAC;gBAC9B,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;gBACxB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,OAAO;SACR;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACH,kBAAkB;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,KAAU;QACpB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;YACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YAEnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAErB,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,MAAuB;QAClC,IAAI,OAAO,QAAQ,KAAK,WAAW,EAAE;YACnC,OAAO,CAAC,IAAI,CAAC,gDAAgD,CAAC,CAAC;SAChE;aAAM;YACL,wBAAwB;YACxB,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE;gBACpE,OAAO;aACR;YAED,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;aACjC;YACD,4BAA4B;YAC5B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;YAElE,oBAAoB;YACpB,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAElC,iCAAiC;YACjC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,GAAuB,EAAE,EAAE;gBAC5D,8CAA8C;gBAC9C,+CAA+C;gBAC/C,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,KAAK,EAAE;oBAC1C,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACnC;gBAED,mCAAmC;gBACnC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;YAEH,wBAAwB;YACxB,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACrD,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;gBAEtC,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;oBACxB,kBAAkB;oBAClB,IAAI,IAAI,CAAC,QAAQ,EAAE;wBACjB,IAAI,IAAI,CAAC,eAAe,EAAE;4BACxB,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;yBACpC;wBACD,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;4BAC5C,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;4BACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;wBAC9B,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;wBAE5B,cAAc;qBACf;yBAAM;wBACL,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;qBACzB;iBACF;gBAED,mCAAmC;gBACnC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC9B,CAAC,CAAC,CAAC;YAEH,sBAAsB;YACtB,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACnD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;YAEH,uBAAuB;YACvB,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACpD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;YAEH,4BAA4B;YAC5B,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACzD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC5B,CAAC,CAAC,CAAC;YAEH,mCAAmC;YACnC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,mBAAmB,EAAE,CAAC,GAAuB,EAAE,EAAE;gBAChE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;YAEH,oCAAoC;YACpC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,oBAAoB,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACjE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YAEH,uBAAuB;YACvB,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACpD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;YAEH,sBAAsB;YACtB,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,GAAuB,EAAE,EAAE;gBACnD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;YAEH,0EAA0E;YAC1E,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBACnC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;YACH,iCAAiC;YACjC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBACrC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC1B,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,KAAa;QACtB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,IAAI,CAAC,QAAQ;YAAE,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;IAMD,gBAAgB,CAAC,EAAc;QAC7B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAEO,gBAAgB,CAAC,IAAU;QACjC,OAAO,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACpF,CAAC;;;YAxOF,SAAS,SAAC;gBACT,QAAQ,EAAE,UAAU;gBACpB,SAAS,EAAE;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;wBAChD,KAAK,EAAE,IAAI;qBACZ;iBACF;gBACD,QAAQ,EAAE,6BAA6B;aACxC;;;YA7BC,MAAM;;;qBA+BL,KAAK;uBACL,KAAK;uBACL,KAAK;qBAEL,MAAM;2BACN,MAAM;oBACN,MAAM;mBACN,MAAM;oBACN,MAAM;yBACN,MAAM;gCACN,MAAM;iCACN,MAAM;oBACN,MAAM;mBACN,MAAM;mBAEN,SAAS,SAAC,MAAM,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;6BAEnC,eAAe,SAAC,iBAAiB;4BACjC,eAAe,SAAC,gBAAgB;oBAgBhC,KAAK","sourcesContent":["// Imports\nimport {\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  EventEmitter,\n  NgZone,\n  forwardRef,\n  QueryList,\n  AfterViewInit,\n  ContentChildren,\n  SimpleChanges,\n  OnChanges,\n  OnDestroy,\n  ElementRef\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CKButtonDirective } from './ckbutton.directive';\nimport { CKGroupDirective } from './ckgroup.directive';\n\n/**\n * CKEditor component\n * Usage :\n *  <ckeditor [(ngModel)]=\"data\" [config]=\"{...}\" debounce=\"500\"></ckeditor>\n */\n@Component({\n  selector: 'ckeditor',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CKEditorComponent),\n      multi: true,\n    },\n  ],\n  template: `<textarea #host></textarea>`,\n})\nexport class CKEditorComponent implements OnChanges, AfterViewInit, OnDestroy {\n  @Input() config: CKEDITOR.config;\n  @Input() readonly: boolean;\n  @Input() debounce: string;\n\n  @Output() change = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() editorChange = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() ready = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() blur = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() focus = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() contentDom = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() fileUploadRequest = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() fileUploadResponse = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() paste = new EventEmitter<CKEDITOR.eventInfo>();\n  @Output() drop = new EventEmitter<CKEDITOR.eventInfo>();\n\n  @ViewChild('host', { static: false }) host: ElementRef<HTMLTextAreaElement>;\n\n  @ContentChildren(CKButtonDirective) toolbarButtons: QueryList<CKButtonDirective>;\n  @ContentChildren(CKGroupDirective) toolbarGroups: QueryList<CKGroupDirective>;\n\n  _value = '';\n  instance: CKEDITOR.editor;\n  debounceTimeout: number;\n  private destroyed = false;\n\n  /**\n   * Constructor\n   */\n  constructor(private zone: NgZone) {}\n\n  get value(): string {\n    return this._value;\n  }\n\n  @Input()\n  set value(v: string) {\n    if (v !== this._value) {\n      this._value = v;\n      this.onChange(v);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.readonly && this.instance) {\n      this.instance.setReadOnly(changes.readonly.currentValue);\n    }\n  }\n\n  /**\n   * On component destroy\n   */\n  ngOnDestroy(): void {\n    this.destroyed = true;\n    this.zone.runOutsideAngular(() => {\n      if (this.instance) {\n        CKEDITOR.removeAllListeners();\n        this.instance.destroy();\n        this.instance = null;\n      }\n    });\n  }\n\n  /**\n   * On component view init\n   */\n  ngAfterViewInit(): void {\n    if (this.destroyed) {\n      return;\n    }\n    this.ckeditorInit(this.config || {});\n  }\n\n  /**\n   * On component view checked\n   */\n  ngAfterViewChecked(): void {\n    this.ckeditorInit(this.config || {});\n  }\n\n  /**\n   * Value update process\n   */\n  updateValue(value: any): void {\n    this.zone.run(() => {\n      this.value = value;\n\n      this.onChange(value);\n\n      this.onTouched();\n      this.change.emit(value);\n    });\n  }\n\n  /**\n   * CKEditor init\n   */\n  ckeditorInit(config: CKEDITOR.config): void {\n    if (typeof CKEDITOR === 'undefined') {\n      console.warn('CKEditor 4.x is missing (http://ckeditor.com/)');\n    } else {\n      // Check textarea exists\n      if (this.instance || !this.documentContains(this.host.nativeElement)) {\n        return;\n      }\n\n      if (this.readonly) {\n        config.readOnly = this.readonly;\n      }\n      // CKEditor replace textarea\n      this.instance = CKEDITOR.replace(this.host.nativeElement, config);\n\n      // Set initial value\n      this.instance.setData(this.value);\n\n      // listen for instanceReady event\n      this.instance.on('instanceReady', (evt: CKEDITOR.eventInfo) => {\n        // if value has changed while instance loading\n        // update instance with current component value\n        if (this.instance.getData() !== this.value) {\n          this.instance.setData(this.value);\n        }\n\n        // send the evt to the EventEmitter\n        this.ready.emit(evt);\n      });\n\n      // CKEditor change event\n      this.instance.on('change', (evt: CKEDITOR.eventInfo) => {\n        this.onTouched();\n        const value = this.instance.getData();\n\n        if (this.value !== value) {\n          // Debounce update\n          if (this.debounce) {\n            if (this.debounceTimeout) {\n              clearTimeout(this.debounceTimeout);\n            }\n            this.debounceTimeout = window.setTimeout(() => {\n              this.updateValue(value);\n              this.debounceTimeout = null;\n            }, parseInt(this.debounce));\n\n            // Live update\n          } else {\n            this.updateValue(value);\n          }\n        }\n\n        // Original ckeditor event dispatch\n        this.editorChange.emit(evt);\n      });\n\n      // CKEditor blur event\n      this.instance.on('blur', (evt: CKEDITOR.eventInfo) => {\n        this.blur.emit(evt);\n      });\n\n      // CKEditor focus event\n      this.instance.on('focus', (evt: CKEDITOR.eventInfo) => {\n        this.focus.emit(evt);\n      });\n\n      // CKEditor contentDom event\n      this.instance.on('contentDom', (evt: CKEDITOR.eventInfo) => {\n        this.contentDom.emit(evt);\n      });\n\n      // CKEditor fileUploadRequest event\n      this.instance.on('fileUploadRequest', (evt: CKEDITOR.eventInfo) => {\n        this.fileUploadRequest.emit(evt);\n      });\n\n      // CKEditor fileUploadResponse event\n      this.instance.on('fileUploadResponse', (evt: CKEDITOR.eventInfo) => {\n        this.fileUploadResponse.emit(evt);\n      });\n\n      // CKEditor paste event\n      this.instance.on('paste', (evt: CKEDITOR.eventInfo) => {\n        this.paste.emit(evt);\n      });\n\n      // CKEditor drop event\n      this.instance.on('drop', (evt: CKEDITOR.eventInfo) => {\n        this.drop.emit(evt);\n      });\n\n      // Add Toolbar Groups to Editor. This will also add Buttons within groups.\n      this.toolbarGroups.forEach((group) => {\n        group.initialize(this);\n      });\n      // Add Toolbar Buttons to Editor.\n      this.toolbarButtons.forEach((button) => {\n        button.initialize(this);\n      });\n    }\n  }\n\n  /**\n   * Implements ControlValueAccessor\n   */\n  writeValue(value: string): void {\n    this._value = value;\n    if (this.instance) this.instance.setData(value);\n  }\n\n  onChange: (_: string) => void;\n\n  onTouched: () => void;\n\n  registerOnChange(fn: () => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  private documentContains(node: Node) {\n    return document.contains ? document.contains(node) : document.body.contains(node);\n  }\n}\n"]} |
@@ -37,2 +37,2 @@ import { Directive, Input, ContentChildren } from '@angular/core'; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tncm91cC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vc3JjLyIsInNvdXJjZXMiOlsiY2tncm91cC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQW9CLGVBQWUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUUvRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV6RDs7Ozs7Ozs7O0dBU0c7QUFJSCxNQUFNLE9BQU8sZ0JBQWdCO0lBTTNCLGtCQUFrQjtRQUNoQixzRkFBc0Y7UUFDdEYsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRU0sVUFBVSxDQUFDLE1BQXlCO1FBQ3pDLE1BQU0sQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzlFLHdDQUF3QztRQUN4QyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQ3JDLE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOzs7WUFwQkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxTQUFTO2FBQ3BCOzs7bUJBRUUsS0FBSzt1QkFDTCxLQUFLO3lCQUNMLEtBQUs7NkJBQ0wsZUFBZSxTQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIEFmdGVyQ29udGVudEluaXQsIENvbnRlbnRDaGlsZHJlbiwgUXVlcnlMaXN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDS0VkaXRvckNvbXBvbmVudCB9IGZyb20gJy4vY2tlZGl0b3IuY29tcG9uZW50JztcbmltcG9ydCB7IENLQnV0dG9uRGlyZWN0aXZlIH0gZnJvbSAnLi9ja2J1dHRvbi5kaXJlY3RpdmUnO1xuXG4vKipcbiAqIENLR3JvdXAgY29tcG9uZW50XG4gKiBVc2FnZSA6XG4gKiAgPGNrZWRpdG9yIFsobmdNb2RlbCldPVwiZGF0YVwiIFtjb25maWddPVwiey4uLn1cIiBkZWJvdW5jZT1cIjUwMFwiPlxuICogICAgICA8Y2tncm91cCBbbmFtZV09XCInZXhhbXBsZUdyb3VwMidcIiBbcHJldmlvdXNdPVwiJzEnXCIgW3N1Ymdyb3VwT2ZdPVwiJ2V4YW1wbGVHcm91cDEnXCI+XG4gKiAgICAgICAgICAuXG4gKiAgICAgICAgICAuXG4gKiAgICAgIDwvY2tncm91cD5cbiAqICAgPC9ja2VkaXRvcj5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnY2tncm91cCcsXG59KVxuZXhwb3J0IGNsYXNzIENLR3JvdXBEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcbiAgQElucHV0KCkgbmFtZTogc3RyaW5nO1xuICBASW5wdXQoKSBwcmV2aW91czogYW55O1xuICBASW5wdXQoKSBzdWJncm91cE9mOiBzdHJpbmc7XG4gIEBDb250ZW50Q2hpbGRyZW4oQ0tCdXR0b25EaXJlY3RpdmUpIHRvb2xiYXJCdXR0b25zOiBRdWVyeUxpc3Q8Q0tCdXR0b25EaXJlY3RpdmU+O1xuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICAvLyBSZWNvbmZpZ3VyZSBlYWNoIGJ1dHRvbidzIHRvb2xiYXIgcHJvcGVydHkgd2l0aGluIGNrZ3JvdXAgdG8gaG9sZCBpdHMgcGFyZW50J3MgbmFtZVxuICAgIHRoaXMudG9vbGJhckJ1dHRvbnMuZm9yRWFjaCgoYnV0dG9uKSA9PiAoYnV0dG9uLnRvb2xiYXIgPSB0aGlzLm5hbWUpKTtcbiAgfVxuXG4gIHB1YmxpYyBpbml0aWFsaXplKGVkaXRvcjogQ0tFZGl0b3JDb21wb25lbnQpIHtcbiAgICBlZGl0b3IuaW5zdGFuY2UudWkuYWRkVG9vbGJhckdyb3VwKHRoaXMubmFtZSwgdGhpcy5wcmV2aW91cywgdGhpcy5zdWJncm91cE9mKTtcbiAgICAvLyBJbml0aWFsaXplIGVhY2ggYnV0dG9uIHdpdGhpbiBja2dyb3VwXG4gICAgdGhpcy50b29sYmFyQnV0dG9ucy5mb3JFYWNoKChidXR0b24pID0+IHtcbiAgICAgIGJ1dHRvbi5pbml0aWFsaXplKGVkaXRvcik7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tncm91cC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vc3JjLyIsInNvdXJjZXMiOlsiY2tncm91cC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQW9CLGVBQWUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUUvRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV6RDs7Ozs7Ozs7O0dBU0c7QUFJSCxNQUFNLE9BQU8sZ0JBQWdCO0lBTTNCLGtCQUFrQjtRQUNoQixzRkFBc0Y7UUFDdEYsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRU0sVUFBVSxDQUFDLE1BQXlCO1FBQ3pDLE1BQU0sQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzlFLHdDQUF3QztRQUN4QyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFO1lBQ3JDLE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOzs7WUFwQkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxTQUFTO2FBQ3BCOzs7bUJBRUUsS0FBSzt1QkFDTCxLQUFLO3lCQUNMLEtBQUs7NkJBQ0wsZUFBZSxTQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIEFmdGVyQ29udGVudEluaXQsIENvbnRlbnRDaGlsZHJlbiwgUXVlcnlMaXN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDS0VkaXRvckNvbXBvbmVudCB9IGZyb20gJy4vY2tlZGl0b3IuY29tcG9uZW50JztcbmltcG9ydCB7IENLQnV0dG9uRGlyZWN0aXZlIH0gZnJvbSAnLi9ja2J1dHRvbi5kaXJlY3RpdmUnO1xuXG4vKipcbiAqIENLR3JvdXAgY29tcG9uZW50XG4gKiBVc2FnZSA6XG4gKiAgPGNrZWRpdG9yIFsobmdNb2RlbCldPVwiZGF0YVwiIFtjb25maWddPVwiey4uLn1cIiBkZWJvdW5jZT1cIjUwMFwiPlxuICogICAgICA8Y2tncm91cCBbbmFtZV09XCInZXhhbXBsZUdyb3VwMidcIiBbcHJldmlvdXNdPVwiJzEnXCIgW3N1Ymdyb3VwT2ZdPVwiJ2V4YW1wbGVHcm91cDEnXCI+XG4gKiAgICAgICAgICAuXG4gKiAgICAgICAgICAuXG4gKiAgICAgIDwvY2tncm91cD5cbiAqICAgPC9ja2VkaXRvcj5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnY2tncm91cCcsXG59KVxuZXhwb3J0IGNsYXNzIENLR3JvdXBEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcbiAgQElucHV0KCkgbmFtZTogc3RyaW5nO1xuICBASW5wdXQoKSBwcmV2aW91czogc3RyaW5nIHwgbnVtYmVyO1xuICBASW5wdXQoKSBzdWJncm91cE9mOiBzdHJpbmc7XG4gIEBDb250ZW50Q2hpbGRyZW4oQ0tCdXR0b25EaXJlY3RpdmUpIHRvb2xiYXJCdXR0b25zOiBRdWVyeUxpc3Q8Q0tCdXR0b25EaXJlY3RpdmU+O1xuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICAvLyBSZWNvbmZpZ3VyZSBlYWNoIGJ1dHRvbidzIHRvb2xiYXIgcHJvcGVydHkgd2l0aGluIGNrZ3JvdXAgdG8gaG9sZCBpdHMgcGFyZW50J3MgbmFtZVxuICAgIHRoaXMudG9vbGJhckJ1dHRvbnMuZm9yRWFjaCgoYnV0dG9uKSA9PiAoYnV0dG9uLnRvb2xiYXIgPSB0aGlzLm5hbWUpKTtcbiAgfVxuXG4gIHB1YmxpYyBpbml0aWFsaXplKGVkaXRvcjogQ0tFZGl0b3JDb21wb25lbnQpOiB2b2lkIHtcbiAgICBlZGl0b3IuaW5zdGFuY2UudWkuYWRkVG9vbGJhckdyb3VwKHRoaXMubmFtZSwgdGhpcy5wcmV2aW91cywgdGhpcy5zdWJncm91cE9mKTtcbiAgICAvLyBJbml0aWFsaXplIGVhY2ggYnV0dG9uIHdpdGhpbiBja2dyb3VwXG4gICAgdGhpcy50b29sYmFyQnV0dG9ucy5mb3JFYWNoKChidXR0b24pID0+IHtcbiAgICAgIGJ1dHRvbi5pbml0aWFsaXplKGVkaXRvcik7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ== |
@@ -20,4 +20,4 @@ import { EventEmitter, Directive, Output, Input, ContentChildren, Component, forwardRef, NgZone, ViewChild, NgModule } from '@angular/core'; | ||
editor.instance.addCommand(this.command, { | ||
exec: (evt) => { | ||
this.click.emit(evt); | ||
exec: (edit) => { | ||
this.click.emit(edit); | ||
return true; | ||
@@ -34,6 +34,8 @@ }, | ||
ngOnInit() { | ||
if (!this.name) | ||
if (!this.name) { | ||
throw new Error('Attribute "name" is required on <ckbutton>'); | ||
if (!this.command) | ||
} | ||
if (!this.command) { | ||
throw new Error('Attribute "command" is required on <ckbutton>'); | ||
} | ||
} | ||
@@ -200,8 +202,9 @@ } | ||
this.onTouched(); | ||
let value = this.instance.getData(); | ||
const value = this.instance.getData(); | ||
if (this.value !== value) { | ||
// Debounce update | ||
if (this.debounce) { | ||
if (this.debounceTimeout) | ||
if (this.debounceTimeout) { | ||
clearTimeout(this.debounceTimeout); | ||
} | ||
this.debounceTimeout = window.setTimeout(() => { | ||
@@ -266,4 +269,2 @@ this.updateValue(value); | ||
} | ||
onChange(_) { } | ||
onTouched() { } | ||
registerOnChange(fn) { | ||
@@ -270,0 +271,0 @@ this.onChange = fn; |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"CKEditorComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":26,"character":1},"arguments":[{"selector":"ckeditor","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":30,"character":15},"useExisting":{"__symbolic":"reference","name":"CKEditorComponent"},"multi":true}],"template":"<textarea #host></textarea>"}]}],"members":{"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"readonly":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"debounce":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"change":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"editorChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":3}}]}],"ready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":44,"character":3}}]}],"blur":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":45,"character":3}}]}],"focus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":46,"character":3}}]}],"contentDom":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":47,"character":3}}]}],"fileUploadRequest":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":48,"character":3}}]}],"fileUploadResponse":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":49,"character":3}}]}],"paste":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":50,"character":3}}]}],"drop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":51,"character":3}}]}],"host":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":53,"character":3},"arguments":["host",{"static":false}]}]}],"toolbarButtons":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":55,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"}]}]}],"toolbarGroups":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":56,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":66,"character":28}]}],"value":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":71,"character":3}}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngAfterViewChecked":[{"__symbolic":"method"}],"updateValue":[{"__symbolic":"method"}],"ckeditorInit":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"onChange":[{"__symbolic":"method"}],"onTouched":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"documentContains":[{"__symbolic":"method"}]}},"CKEditorModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":10,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":11,"character":12}],"declarations":[{"__symbolic":"reference","name":"CKEditorComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"}],"exports":[{"__symbolic":"reference","name":"CKEditorComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":12,"character":1},"arguments":[{"selector":"ckbutton"}]}],"members":{"click":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":16,"character":3}}]}],"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"command":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"toolbar":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"name":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"icon":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"initialize":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":14,"character":1},"arguments":[{"selector":"ckgroup"}]}],"members":{"name":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"previous":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"subgroupOf":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"toolbarButtons":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":21,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"}]}]}],"ngAfterContentInit":[{"__symbolic":"method"}],"initialize":[{"__symbolic":"method"}]}}},"origins":{"CKEditorComponent":"./ckeditor.component","CKEditorModule":"./ckeditor.module","ɵa":"./ckbutton.directive","ɵb":"./ckgroup.directive"},"importAs":"ng2-ckeditor"} | ||
{"__symbolic":"module","version":4,"metadata":{"CKEditorComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":26,"character":1},"arguments":[{"selector":"ckeditor","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":30,"character":15},"useExisting":{"__symbolic":"reference","name":"CKEditorComponent"},"multi":true}],"template":"<textarea #host></textarea>"}]}],"members":{"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":38,"character":3}}]}],"readonly":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"debounce":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":40,"character":3}}]}],"change":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"editorChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":43,"character":3}}]}],"ready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":44,"character":3}}]}],"blur":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":45,"character":3}}]}],"focus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":46,"character":3}}]}],"contentDom":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":47,"character":3}}]}],"fileUploadRequest":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":48,"character":3}}]}],"fileUploadResponse":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":49,"character":3}}]}],"paste":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":50,"character":3}}]}],"drop":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":51,"character":3}}]}],"host":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":53,"character":3},"arguments":["host",{"static":false}]}]}],"toolbarButtons":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":55,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"}]}]}],"toolbarGroups":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":56,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵb"}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":66,"character":28}]}],"value":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":72,"character":3}}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngAfterViewChecked":[{"__symbolic":"method"}],"updateValue":[{"__symbolic":"method"}],"ckeditorInit":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"documentContains":[{"__symbolic":"method"}]}},"CKEditorModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":10,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":11,"character":12}],"declarations":[{"__symbolic":"reference","name":"CKEditorComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"}],"exports":[{"__symbolic":"reference","name":"CKEditorComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":12,"character":1},"arguments":[{"selector":"ckbutton"}]}],"members":{"click":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":16,"character":3}}]}],"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"command":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"toolbar":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"name":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"icon":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"initialize":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":14,"character":1},"arguments":[{"selector":"ckgroup"}]}],"members":{"name":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"previous":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"subgroupOf":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"toolbarButtons":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":21,"character":3},"arguments":[{"__symbolic":"reference","name":"ɵa"}]}]}],"ngAfterContentInit":[{"__symbolic":"method"}],"initialize":[{"__symbolic":"method"}]}}},"origins":{"CKEditorComponent":"./ckeditor.component","CKEditorModule":"./ckeditor.module","ɵa":"./ckbutton.directive","ɵb":"./ckgroup.directive"},"importAs":"ng2-ckeditor"} |
{ | ||
"name": "ng2-ckeditor", | ||
"version": "1.3.2", | ||
"version": "1.3.3", | ||
"description": "Angular CKEditor component", | ||
@@ -27,7 +27,5 @@ "main": "bundles/ng2-ckeditor.umd.js", | ||
"@angular/core": "^11.0.4", | ||
"@angular/forms": "^11.0.4" | ||
"@angular/forms": "^11.0.4", | ||
"@types/ckeditor": "^4.9.10" | ||
}, | ||
"dependencies": { | ||
"tslib": "^2.0.0" | ||
}, | ||
"module": "fesm2015/ng2-ckeditor.js", | ||
@@ -38,3 +36,6 @@ "es2015": "fesm2015/ng2-ckeditor.js", | ||
"metadata": "ng2-ckeditor.metadata.json", | ||
"sideEffects": false | ||
"sideEffects": false, | ||
"dependencies": { | ||
"tslib": "^2.0.0" | ||
} | ||
} |
@@ -12,3 +12,3 @@ # Angular - CKEditor component | ||
``` | ||
<script src="https://cdn.ckeditor.com/4.14.1/full/ckeditor.js"></script> | ||
<script src="https://cdn.ckeditor.com/4.16.0/full/ckeditor.js"></script> | ||
``` | ||
@@ -22,2 +22,8 @@ | ||
* Install @types/ckeditor | ||
* JSPM : `jspm install npm:@types/ckeditor` | ||
* NPM : `npm install --save @types/ckeditor` | ||
* YARN : `yarn add @types/ckeditor` | ||
* SystemJS Config : | ||
@@ -24,0 +30,0 @@ |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
134772
1154
140
5