ckeditor.component.js 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. var CKEditorComponent_1;
  2. import * as tslib_1 from "tslib";
  3. // Imports
  4. import { Component, Input, Output, ViewChild, EventEmitter, NgZone, forwardRef, QueryList, AfterViewInit, ContentChildren, SimpleChanges, OnChanges, } from '@angular/core';
  5. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  6. import { CKButtonDirective } from './ckbutton.directive';
  7. import { CKGroupDirective } from './ckgroup.directive';
  8. /**
  9. * CKEditor component
  10. * Usage :
  11. * <ckeditor [(ngModel)]="data" [config]="{...}" debounce="500"></ckeditor>
  12. */
  13. let CKEditorComponent = CKEditorComponent_1 = class CKEditorComponent {
  14. /**
  15. * Constructor
  16. */
  17. constructor(zone) {
  18. this.zone = zone;
  19. this.change = new EventEmitter();
  20. this.editorChange = new EventEmitter();
  21. this.ready = new EventEmitter();
  22. this.blur = new EventEmitter();
  23. this.focus = new EventEmitter();
  24. this.contentDom = new EventEmitter();
  25. this.fileUploadRequest = new EventEmitter();
  26. this.fileUploadResponse = new EventEmitter();
  27. this.paste = new EventEmitter();
  28. this.drop = new EventEmitter();
  29. this._value = '';
  30. }
  31. get value() {
  32. return this._value;
  33. }
  34. set value(v) {
  35. if (v !== this._value) {
  36. this._value = v;
  37. this.onChange(v);
  38. }
  39. }
  40. ngOnChanges(changes) {
  41. if (changes.readonly && this.instance) {
  42. this.instance.setReadOnly(changes.readonly.currentValue);
  43. }
  44. }
  45. /**
  46. * On component destroy
  47. */
  48. ngOnDestroy() {
  49. if (this.instance) {
  50. this.instance.removeAllListeners();
  51. CKEDITOR.instances[this.instance.name].destroy();
  52. this.instance.destroy();
  53. this.instance = null;
  54. }
  55. }
  56. /**
  57. * On component view init
  58. */
  59. ngAfterViewInit() {
  60. this.ckeditorInit(this.config || {});
  61. }
  62. /**
  63. * On component view checked
  64. */
  65. ngAfterViewChecked() {
  66. this.ckeditorInit(this.config || {});
  67. }
  68. /**
  69. * Value update process
  70. */
  71. updateValue(value) {
  72. this.zone.run(() => {
  73. this.value = value;
  74. this.onChange(value);
  75. this.onTouched();
  76. this.change.emit(value);
  77. });
  78. }
  79. /**
  80. * CKEditor init
  81. */
  82. ckeditorInit(config) {
  83. if (typeof CKEDITOR === 'undefined') {
  84. console.warn('CKEditor 4.x is missing (http://ckeditor.com/)');
  85. }
  86. else {
  87. // Check textarea exists
  88. if (this.instance || !this.documentContains(this.host.nativeElement)) {
  89. return;
  90. }
  91. if (this.readonly) {
  92. config.readOnly = this.readonly;
  93. }
  94. // CKEditor replace textarea
  95. this.instance = CKEDITOR.replace(this.host.nativeElement, config);
  96. // Set initial value
  97. this.instance.setData(this.value);
  98. // listen for instanceReady event
  99. this.instance.on('instanceReady', (evt) => {
  100. // if value has changed while instance loading
  101. // update instance with current component value
  102. if (this.instance.getData() !== this.value) {
  103. this.instance.setData(this.value);
  104. }
  105. // send the evt to the EventEmitter
  106. this.ready.emit(evt);
  107. });
  108. // CKEditor change event
  109. this.instance.on('change', (evt) => {
  110. this.onTouched();
  111. let value = this.instance.getData();
  112. if (this.value !== value) {
  113. // Debounce update
  114. if (this.debounce) {
  115. if (this.debounceTimeout)
  116. clearTimeout(this.debounceTimeout);
  117. this.debounceTimeout = setTimeout(() => {
  118. this.updateValue(value);
  119. this.debounceTimeout = null;
  120. }, parseInt(this.debounce));
  121. // Live update
  122. }
  123. else {
  124. this.updateValue(value);
  125. }
  126. }
  127. // Original ckeditor event dispatch
  128. this.editorChange.emit(evt);
  129. });
  130. // CKEditor blur event
  131. this.instance.on('blur', (evt) => {
  132. this.blur.emit(evt);
  133. });
  134. // CKEditor focus event
  135. this.instance.on('focus', (evt) => {
  136. this.focus.emit(evt);
  137. });
  138. // CKEditor contentDom event
  139. this.instance.on('contentDom', (evt) => {
  140. this.contentDom.emit(evt);
  141. });
  142. // CKEditor fileUploadRequest event
  143. this.instance.on('fileUploadRequest', (evt) => {
  144. this.fileUploadRequest.emit(evt);
  145. });
  146. // CKEditor fileUploadResponse event
  147. this.instance.on('fileUploadResponse', (evt) => {
  148. this.fileUploadResponse.emit(evt);
  149. });
  150. // CKEditor paste event
  151. this.instance.on('paste', (evt) => {
  152. this.paste.emit(evt);
  153. });
  154. // CKEditor drop event
  155. this.instance.on('drop', (evt) => {
  156. this.drop.emit(evt);
  157. });
  158. // Add Toolbar Groups to Editor. This will also add Buttons within groups.
  159. this.toolbarGroups.forEach(group => {
  160. group.initialize(this);
  161. });
  162. // Add Toolbar Buttons to Editor.
  163. this.toolbarButtons.forEach(button => {
  164. button.initialize(this);
  165. });
  166. }
  167. }
  168. /**
  169. * Implements ControlValueAccessor
  170. */
  171. writeValue(value) {
  172. this._value = value;
  173. if (this.instance)
  174. this.instance.setData(value);
  175. }
  176. onChange(_) { }
  177. onTouched() { }
  178. registerOnChange(fn) {
  179. this.onChange = fn;
  180. }
  181. registerOnTouched(fn) {
  182. this.onTouched = fn;
  183. }
  184. documentContains(node) {
  185. return document.contains ? document.contains(node) : document.body.contains(node);
  186. }
  187. };
  188. CKEditorComponent.ctorParameters = () => [
  189. { type: NgZone }
  190. ];
  191. tslib_1.__decorate([
  192. Input(),
  193. tslib_1.__metadata("design:type", Object)
  194. ], CKEditorComponent.prototype, "config", void 0);
  195. tslib_1.__decorate([
  196. Input(),
  197. tslib_1.__metadata("design:type", Boolean)
  198. ], CKEditorComponent.prototype, "readonly", void 0);
  199. tslib_1.__decorate([
  200. Input(),
  201. tslib_1.__metadata("design:type", String)
  202. ], CKEditorComponent.prototype, "debounce", void 0);
  203. tslib_1.__decorate([
  204. Output(),
  205. tslib_1.__metadata("design:type", Object)
  206. ], CKEditorComponent.prototype, "change", void 0);
  207. tslib_1.__decorate([
  208. Output(),
  209. tslib_1.__metadata("design:type", Object)
  210. ], CKEditorComponent.prototype, "editorChange", void 0);
  211. tslib_1.__decorate([
  212. Output(),
  213. tslib_1.__metadata("design:type", Object)
  214. ], CKEditorComponent.prototype, "ready", void 0);
  215. tslib_1.__decorate([
  216. Output(),
  217. tslib_1.__metadata("design:type", Object)
  218. ], CKEditorComponent.prototype, "blur", void 0);
  219. tslib_1.__decorate([
  220. Output(),
  221. tslib_1.__metadata("design:type", Object)
  222. ], CKEditorComponent.prototype, "focus", void 0);
  223. tslib_1.__decorate([
  224. Output(),
  225. tslib_1.__metadata("design:type", Object)
  226. ], CKEditorComponent.prototype, "contentDom", void 0);
  227. tslib_1.__decorate([
  228. Output(),
  229. tslib_1.__metadata("design:type", Object)
  230. ], CKEditorComponent.prototype, "fileUploadRequest", void 0);
  231. tslib_1.__decorate([
  232. Output(),
  233. tslib_1.__metadata("design:type", Object)
  234. ], CKEditorComponent.prototype, "fileUploadResponse", void 0);
  235. tslib_1.__decorate([
  236. Output(),
  237. tslib_1.__metadata("design:type", Object)
  238. ], CKEditorComponent.prototype, "paste", void 0);
  239. tslib_1.__decorate([
  240. Output(),
  241. tslib_1.__metadata("design:type", Object)
  242. ], CKEditorComponent.prototype, "drop", void 0);
  243. tslib_1.__decorate([
  244. ViewChild('host', { static: false }),
  245. tslib_1.__metadata("design:type", Object)
  246. ], CKEditorComponent.prototype, "host", void 0);
  247. tslib_1.__decorate([
  248. ContentChildren(CKButtonDirective),
  249. tslib_1.__metadata("design:type", QueryList)
  250. ], CKEditorComponent.prototype, "toolbarButtons", void 0);
  251. tslib_1.__decorate([
  252. ContentChildren(CKGroupDirective),
  253. tslib_1.__metadata("design:type", QueryList)
  254. ], CKEditorComponent.prototype, "toolbarGroups", void 0);
  255. tslib_1.__decorate([
  256. Input(),
  257. tslib_1.__metadata("design:type", Object),
  258. tslib_1.__metadata("design:paramtypes", [Object])
  259. ], CKEditorComponent.prototype, "value", null);
  260. CKEditorComponent = CKEditorComponent_1 = tslib_1.__decorate([
  261. Component({
  262. selector: 'ckeditor',
  263. providers: [
  264. {
  265. provide: NG_VALUE_ACCESSOR,
  266. useExisting: forwardRef(() => CKEditorComponent_1),
  267. multi: true,
  268. },
  269. ],
  270. template: `
  271. <textarea #host></textarea>
  272. `
  273. }),
  274. tslib_1.__metadata("design:paramtypes", [NgZone])
  275. ], CKEditorComponent);
  276. export { CKEditorComponent };
  277. //# 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"]}