import * as tslib_1 from "tslib";
// Imports
import { Component, Input, Output, ViewChild, EventEmitter, NgZone, forwardRef, QueryList, AfterViewInit, ContentChildren, SimpleChanges, OnChanges, } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { CKButtonDirective } from './ckbutton.directive';
import { CKGroupDirective } from './ckgroup.directive';
/**
* CKEditor component
* Usage :
*
*/
var CKEditorComponent = /** @class */ (function () {
/**
* Constructor
*/
function CKEditorComponent(zone) {
this.zone = zone;
this.change = new EventEmitter();
this.editorChange = new EventEmitter();
this.ready = new EventEmitter();
this.blur = new EventEmitter();
this.focus = new EventEmitter();
this.contentDom = new EventEmitter();
this.fileUploadRequest = new EventEmitter();
this.fileUploadResponse = new EventEmitter();
this.paste = new EventEmitter();
this.drop = new EventEmitter();
this._value = '';
}
CKEditorComponent_1 = CKEditorComponent;
Object.defineProperty(CKEditorComponent.prototype, "value", {
get: function () {
return this._value;
},
set: function (v) {
if (v !== this._value) {
this._value = v;
this.onChange(v);
}
},
enumerable: true,
configurable: true
});
CKEditorComponent.prototype.ngOnChanges = function (changes) {
if (changes.readonly && this.instance) {
this.instance.setReadOnly(changes.readonly.currentValue);
}
};
/**
* On component destroy
*/
CKEditorComponent.prototype.ngOnDestroy = function () {
if (this.instance) {
this.instance.removeAllListeners();
CKEDITOR.instances[this.instance.name].destroy();
this.instance.destroy();
this.instance = null;
}
};
/**
* On component view init
*/
CKEditorComponent.prototype.ngAfterViewInit = function () {
this.ckeditorInit(this.config || {});
};
/**
* On component view checked
*/
CKEditorComponent.prototype.ngAfterViewChecked = function () {
this.ckeditorInit(this.config || {});
};
/**
* Value update process
*/
CKEditorComponent.prototype.updateValue = function (value) {
var _this = this;
this.zone.run(function () {
_this.value = value;
_this.onChange(value);
_this.onTouched();
_this.change.emit(value);
});
};
/**
* CKEditor init
*/
CKEditorComponent.prototype.ckeditorInit = function (config) {
var _this = this;
if (typeof CKEDITOR === 'undefined') {
console.warn('CKEditor 4.x is missing (http://ckeditor.com/)');
}
else {
// Check textarea exists
if (this.instance || !this.documentContains(this.host.nativeElement)) {
return;
}
if (this.readonly) {
config.readOnly = this.readonly;
}
// CKEditor replace textarea
this.instance = CKEDITOR.replace(this.host.nativeElement, config);
// Set initial value
this.instance.setData(this.value);
// listen for instanceReady event
this.instance.on('instanceReady', function (evt) {
// if value has changed while instance loading
// update instance with current component value
if (_this.instance.getData() !== _this.value) {
_this.instance.setData(_this.value);
}
// send the evt to the EventEmitter
_this.ready.emit(evt);
});
// CKEditor change event
this.instance.on('change', function (evt) {
_this.onTouched();
var value = _this.instance.getData();
if (_this.value !== value) {
// Debounce update
if (_this.debounce) {
if (_this.debounceTimeout)
clearTimeout(_this.debounceTimeout);
_this.debounceTimeout = setTimeout(function () {
_this.updateValue(value);
_this.debounceTimeout = null;
}, parseInt(_this.debounce));
// Live update
}
else {
_this.updateValue(value);
}
}
// Original ckeditor event dispatch
_this.editorChange.emit(evt);
});
// CKEditor blur event
this.instance.on('blur', function (evt) {
_this.blur.emit(evt);
});
// CKEditor focus event
this.instance.on('focus', function (evt) {
_this.focus.emit(evt);
});
// CKEditor contentDom event
this.instance.on('contentDom', function (evt) {
_this.contentDom.emit(evt);
});
// CKEditor fileUploadRequest event
this.instance.on('fileUploadRequest', function (evt) {
_this.fileUploadRequest.emit(evt);
});
// CKEditor fileUploadResponse event
this.instance.on('fileUploadResponse', function (evt) {
_this.fileUploadResponse.emit(evt);
});
// CKEditor paste event
this.instance.on('paste', function (evt) {
_this.paste.emit(evt);
});
// CKEditor drop event
this.instance.on('drop', function (evt) {
_this.drop.emit(evt);
});
// Add Toolbar Groups to Editor. This will also add Buttons within groups.
this.toolbarGroups.forEach(function (group) {
group.initialize(_this);
});
// Add Toolbar Buttons to Editor.
this.toolbarButtons.forEach(function (button) {
button.initialize(_this);
});
}
};
/**
* Implements ControlValueAccessor
*/
CKEditorComponent.prototype.writeValue = function (value) {
this._value = value;
if (this.instance)
this.instance.setData(value);
};
CKEditorComponent.prototype.onChange = function (_) { };
CKEditorComponent.prototype.onTouched = function () { };
CKEditorComponent.prototype.registerOnChange = function (fn) {
this.onChange = fn;
};
CKEditorComponent.prototype.registerOnTouched = function (fn) {
this.onTouched = fn;
};
CKEditorComponent.prototype.documentContains = function (node) {
return document.contains ? document.contains(node) : document.body.contains(node);
};
var CKEditorComponent_1;
CKEditorComponent.ctorParameters = function () { return [
{ type: NgZone }
]; };
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "config", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Boolean)
], CKEditorComponent.prototype, "readonly", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", String)
], CKEditorComponent.prototype, "debounce", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "change", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "editorChange", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "ready", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "blur", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "focus", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "contentDom", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "fileUploadRequest", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "fileUploadResponse", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "paste", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "drop", void 0);
tslib_1.__decorate([
ViewChild('host', { static: false }),
tslib_1.__metadata("design:type", Object)
], CKEditorComponent.prototype, "host", void 0);
tslib_1.__decorate([
ContentChildren(CKButtonDirective),
tslib_1.__metadata("design:type", QueryList)
], CKEditorComponent.prototype, "toolbarButtons", void 0);
tslib_1.__decorate([
ContentChildren(CKGroupDirective),
tslib_1.__metadata("design:type", QueryList)
], CKEditorComponent.prototype, "toolbarGroups", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], CKEditorComponent.prototype, "value", null);
CKEditorComponent = CKEditorComponent_1 = tslib_1.__decorate([
Component({
selector: 'ckeditor',
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return CKEditorComponent_1; }),
multi: true,
},
],
template: "\n \n "
}),
tslib_1.__metadata("design:paramtypes", [NgZone])
], CKEditorComponent);
return CKEditorComponent;
}());
export { CKEditorComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"ng://ng2-ckeditor/","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} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { CKButtonDirective } from './ckbutton.directive';\nimport { CKGroupDirective } from './ckgroup.directive';\n\ndeclare var CKEDITOR: any;\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: `\n    <textarea #host></textarea>\n  `,\n})\nexport class CKEditorComponent implements OnChanges, AfterViewInit {\n  @Input() config: any;\n  @Input() readonly: boolean;\n  @Input() debounce: string;\n\n  @Output() change = new EventEmitter();\n  @Output() editorChange = new EventEmitter();\n  @Output() ready = new EventEmitter();\n  @Output() blur = new EventEmitter();\n  @Output() focus = new EventEmitter();\n  @Output() contentDom = new EventEmitter();\n  @Output() fileUploadRequest = new EventEmitter();\n  @Output() fileUploadResponse = new EventEmitter();\n  @Output() paste = new EventEmitter();\n  @Output() drop = new EventEmitter();\n\n  @ViewChild('host', { static: false }) host: any;\n\n  @ContentChildren(CKButtonDirective) toolbarButtons: QueryList<CKButtonDirective>;\n  @ContentChildren(CKGroupDirective) toolbarGroups: QueryList<CKGroupDirective>;\n\n  _value = '';\n  instance: any;\n  debounceTimeout: any;\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    if (this.instance) {\n      this.instance.removeAllListeners();\n      CKEDITOR.instances[this.instance.name].destroy();\n      this.instance.destroy();\n      this.instance = null;\n    }\n  }\n\n  /**\n   * On component view init\n   */\n  ngAfterViewInit() {\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: any) {\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: any) => {\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: any) => {\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 = 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: any) => {\n        this.blur.emit(evt);\n      });\n\n      // CKEditor focus event\n      this.instance.on('focus', (evt: any) => {\n        this.focus.emit(evt);\n      });\n\n      // CKEditor contentDom event\n      this.instance.on('contentDom', (evt: any) => {\n        this.contentDom.emit(evt);\n      });\n\n      // CKEditor fileUploadRequest event\n      this.instance.on('fileUploadRequest', (evt: any) => {\n        this.fileUploadRequest.emit(evt);\n      });\n\n      // CKEditor fileUploadResponse event\n      this.instance.on('fileUploadResponse', (evt: any) => {\n        this.fileUploadResponse.emit(evt);\n      });\n\n      // CKEditor paste event\n      this.instance.on('paste', (evt: any) => {\n        this.paste.emit(evt);\n      });\n\n      // CKEditor drop event\n      this.instance.on('drop', (evt: any) => {\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"]}