@ckeditor/ckeditor5-angular
Advanced tools
Comparing version 1.1.2 to 1.2.0
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/forms')) : | ||
typeof define === 'function' && define.amd ? define('@ckeditor/ckeditor5-angular', ['exports', '@angular/core', '@angular/common', '@angular/forms'], factory) : | ||
(factory((global.ckeditor = global.ckeditor || {}, global.ckeditor['ckeditor5-angular'] = {}),global.ng.core,global.ng.common,global.ng.forms)); | ||
}(this, (function (exports,core,common,forms) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@ckeditor/ckeditor5-watchdog/src/editorwatchdog'), require('@angular/core'), require('@angular/common'), require('@angular/forms')) : | ||
typeof define === 'function' && define.amd ? define('@ckeditor/ckeditor5-angular', ['exports', '@ckeditor/ckeditor5-watchdog/src/editorwatchdog', '@angular/core', '@angular/common', '@angular/forms'], factory) : | ||
(factory((global.ckeditor = global.ckeditor || {}, global.ckeditor['ckeditor5-angular'] = {}),global.EditorWatchdog,global.ng.core,global.ng.common,global.ng.forms)); | ||
}(this, (function (exports,EditorWatchdog,core,common,forms) { 'use strict'; | ||
EditorWatchdog = EditorWatchdog && EditorWatchdog.hasOwnProperty('default') ? EditorWatchdog['default'] : EditorWatchdog; | ||
/*! ***************************************************************************** | ||
@@ -33,2 +35,89 @@ Copyright (c) Microsoft Corporation. All rights reserved. | ||
}; | ||
function __awaiter(thisArg, _arguments, P, generator) { | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { | ||
step(generator.next(value)); | ||
} | ||
catch (e) { | ||
reject(e); | ||
} } | ||
function rejected(value) { try { | ||
step(generator["throw"](value)); | ||
} | ||
catch (e) { | ||
reject(e); | ||
} } | ||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
} | ||
function __generator(thisArg, body) { | ||
var _ = { label: 0, sent: function () { if (t[0] & 1) | ||
throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; | ||
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function () { return this; }), g; | ||
function verb(n) { return function (v) { return step([n, v]); }; } | ||
function step(op) { | ||
if (f) | ||
throw new TypeError("Generator is already executing."); | ||
while (_) | ||
try { | ||
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) | ||
return t; | ||
if (y = 0, t) | ||
op = [op[0] & 2, t.value]; | ||
switch (op[0]) { | ||
case 0: | ||
case 1: | ||
t = op; | ||
break; | ||
case 4: | ||
_.label++; | ||
return { value: op[1], done: false }; | ||
case 5: | ||
_.label++; | ||
y = op[1]; | ||
op = [0]; | ||
continue; | ||
case 7: | ||
op = _.ops.pop(); | ||
_.trys.pop(); | ||
continue; | ||
default: | ||
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { | ||
_ = 0; | ||
continue; | ||
} | ||
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { | ||
_.label = op[1]; | ||
break; | ||
} | ||
if (op[0] === 6 && _.label < t[1]) { | ||
_.label = t[1]; | ||
t = op; | ||
break; | ||
} | ||
if (t && _.label < t[2]) { | ||
_.label = t[2]; | ||
_.ops.push(op); | ||
break; | ||
} | ||
if (t[2]) | ||
_.ops.pop(); | ||
_.trys.pop(); | ||
continue; | ||
} | ||
op = body.call(thisArg, _); | ||
} | ||
catch (e) { | ||
op = [6, e]; | ||
y = 0; | ||
} | ||
finally { | ||
f = t = 0; | ||
} | ||
if (op[0] & 5) | ||
throw op[1]; | ||
return { value: op[0] ? op[1] : void 0, done: true }; | ||
} | ||
} | ||
@@ -39,2 +128,70 @@ /** | ||
*/ | ||
/** | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license | ||
*/ | ||
// A copy of @ckeditor/ckeditor5-utils/src/uid.js | ||
// A hash table of hex numbers to avoid using toString() in uid() which is costly. | ||
// [ '00', '01', '02', ..., 'fe', 'ff' ] | ||
var ɵ0 = /** | ||
* @param {?} val | ||
* @param {?} index | ||
* @return {?} | ||
*/ function (val, index) { return ('0' + (index).toString(16)).slice(-2); }; | ||
/** @type {?} */ | ||
var HEX_NUMBERS = new Array(256).fill(0) | ||
.map((ɵ0)); | ||
/** | ||
* Returns a unique id. The id starts with an "e" character and a randomly generated string of | ||
* 32 alphanumeric characters. | ||
* | ||
* **Note**: The characters the unique id is built from correspond to the hex number notation | ||
* (from "0" to "9", from "a" to "f"). In other words, each id corresponds to an "e" followed | ||
* by 16 8-bit numbers next to each other. | ||
* | ||
* @return {?} An unique id string. | ||
*/ | ||
function uid() { | ||
// Let's create some positive random 32bit integers first. | ||
// | ||
// 1. Math.random() is a float between 0 and 1. | ||
// 2. 0x100000000 is 2^32 = 4294967296. | ||
// 3. >>> 0 enforces integer (in JS all numbers are floating point). | ||
// | ||
// For instance: | ||
// Math.random() * 0x100000000 = 3366450031.853859 | ||
// but | ||
// Math.random() * 0x100000000 >>> 0 = 3366450031. | ||
/** @type {?} */ | ||
var r1 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
var r2 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
var r3 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
var r4 = Math.random() * 0x100000000 >>> 0; | ||
// Make sure that id does not start with number. | ||
return 'e' + | ||
HEX_NUMBERS[r1 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 24 & 0xFF]; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var CKEditorComponent = /** @class */ (function () { | ||
@@ -84,5 +241,5 @@ function CKEditorComponent(elementRef, ngZone) { | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
*/ | ||
this.editorInstance = null; | ||
this.error = new core.EventEmitter(); | ||
/** | ||
@@ -97,2 +254,3 @@ * If the component is read–only before the editor instance is created, it remembers that state, | ||
this.isEditorSettingData = false; | ||
this.id = uid(); | ||
this.ngZone = ngZone; | ||
@@ -127,2 +285,21 @@ this.elementRef = elementRef; | ||
}); | ||
Object.defineProperty(CKEditorComponent.prototype, "editorInstance", { | ||
/** | ||
* The instance of the editor created by this component. | ||
*/ | ||
get: /** | ||
* The instance of the editor created by this component. | ||
* @return {?} | ||
*/ function () { | ||
if (this.editorWatchdog) { | ||
return this.editorWatchdog.editor; | ||
} | ||
if (this.watchdog) { | ||
return this.watchdog.getItem(this.id); | ||
} | ||
return null; | ||
}, | ||
enumerable: true, | ||
configurable: true | ||
}); | ||
// Implementing the AfterViewInit interface. | ||
@@ -139,8 +316,3 @@ // Implementing the AfterViewInit interface. | ||
function () { | ||
var _this = this; | ||
this.ngZone.runOutsideAngular(( /** | ||
* @return {?} | ||
*/function () { | ||
_this.createEditor(); | ||
})); | ||
this.attachToWatchdog(); | ||
}; | ||
@@ -158,6 +330,24 @@ // Implementing the OnDestroy interface. | ||
function () { | ||
if (this.editorInstance) { | ||
this.editorInstance.destroy(); | ||
this.editorInstance = null; | ||
} | ||
return __awaiter(this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!this.watchdog) | ||
return [3 /*break*/, 2]; | ||
return [4 /*yield*/, this.watchdog.remove(this.id)]; | ||
case 1: | ||
_a.sent(); | ||
return [3 /*break*/, 4]; | ||
case 2: | ||
if (!(this.editorWatchdog && this.editorWatchdog.editor)) | ||
return [3 /*break*/, 4]; | ||
return [4 /*yield*/, this.editorWatchdog.destroy()]; | ||
case 3: | ||
_a.sent(); | ||
this.editorWatchdog = undefined; | ||
_a.label = 4; | ||
case 4: return [2 /*return*/]; | ||
} | ||
}); | ||
}); | ||
}; | ||
@@ -243,10 +433,8 @@ // Implementing the ControlValueAccessor interface (only when binding to ngModel). | ||
function (isDisabled) { | ||
// If already initialized | ||
// If already initialized. | ||
if (this.editorInstance) { | ||
this.editorInstance.isReadOnly = isDisabled; | ||
} | ||
// If not, wait for it to be ready; store the state. | ||
else { | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
// Store the state anyway to use it once the editor is created. | ||
this.initialIsDisabled = isDisabled; | ||
}; | ||
@@ -265,3 +453,3 @@ /** | ||
*/ | ||
CKEditorComponent.prototype.createEditor = /** | ||
CKEditorComponent.prototype.attachToWatchdog = /** | ||
* Creates the editor instance, sets initial editor data, then integrates | ||
@@ -276,4 +464,114 @@ * the editor with the Angular component. This method does not use the `editor.setData()` | ||
/** @type {?} */ | ||
var creator = ( /** | ||
* @param {?} element | ||
* @param {?} config | ||
* @return {?} | ||
*/function (element, config) { | ||
return __awaiter(_this, void 0, void 0, function () { | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
return [2 /*return*/, this.ngZone.runOutsideAngular(( /** | ||
* @return {?} | ||
*/function () { | ||
return __awaiter(_this, void 0, void 0, function () { | ||
var editor; | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
this.elementRef.nativeElement.appendChild(element); | ||
return [4 /*yield*/, ( /** @type {?} */(this.editor)).create(element, config)]; | ||
case 1: | ||
editor = _a.sent(); | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
this.ngZone.run(( /** | ||
* @return {?} | ||
*/function () { | ||
_this.ready.emit(editor); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
return [2 /*return*/, editor]; | ||
} | ||
}); | ||
}); | ||
}))]; | ||
}); | ||
}); | ||
}); | ||
/** @type {?} */ | ||
var destructor = ( /** | ||
* @param {?} editor | ||
* @return {?} | ||
*/function (editor) { | ||
return __awaiter(_this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: return [4 /*yield*/, editor.destroy()]; | ||
case 1: | ||
_a.sent(); | ||
this.elementRef.nativeElement.removeChild(( /** @type {?} */(this.editorElement))); | ||
return [2 /*return*/]; | ||
} | ||
}); | ||
}); | ||
}); | ||
/** @type {?} */ | ||
var emitError = ( /** | ||
* @return {?} | ||
*/function () { | ||
_this.ngZone.run(( /** | ||
* @return {?} | ||
*/function () { | ||
_this.error.emit(); | ||
})); | ||
}); | ||
/** @type {?} */ | ||
var element = document.createElement(this.tagName); | ||
/** @type {?} */ | ||
var config = this.getConfig(); | ||
this.editorElement = element; | ||
// Based on the presence of the watchdog decide how to initialize the editor. | ||
if (this.watchdog) { | ||
// When the context watchdog is passed add the new item to it based on the passed configuration. | ||
this.watchdog.add({ | ||
id: this.id, | ||
type: 'editor', | ||
creator: creator, | ||
destructor: destructor, | ||
sourceElementOrData: element, | ||
config: config | ||
}); | ||
this.watchdog.on('itemError', ( /** | ||
* @param {?} _ | ||
* @param {?} __1 | ||
* @return {?} | ||
*/function (_, _a) { | ||
var itemId = _a.itemId; | ||
if (itemId === _this.id) { | ||
emitError(); | ||
} | ||
})); | ||
} | ||
else { | ||
// In the other case create the watchdog by hand to keep the editor running. | ||
/** @type {?} */ | ||
var editorWatchdog = new EditorWatchdog(this.editor); | ||
editorWatchdog.setCreator(creator); | ||
editorWatchdog.setDestructor(destructor); | ||
editorWatchdog.on('error', emitError); | ||
this.editorWatchdog = editorWatchdog; | ||
this.editorWatchdog.create(element, config); | ||
} | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
CKEditorComponent.prototype.getConfig = /** | ||
* @private | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (this.data && this.config.initialData) { | ||
@@ -283,27 +581,3 @@ throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
/** @type {?} */ | ||
var config = __assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
this.elementRef.nativeElement.appendChild(element); | ||
return ( /** @type {?} */(this.editor)).create(element, config) | ||
.then(( /** | ||
* @param {?} editor | ||
* @return {?} | ||
*/function (editor) { | ||
_this.editorInstance = editor; | ||
if (_this.initialIsDisabled) { | ||
editor.isReadOnly = _this.initialIsDisabled; | ||
} | ||
_this.ngZone.run(( /** | ||
* @return {?} | ||
*/function () { | ||
_this.ready.emit(editor); | ||
})); | ||
_this.setUpEditorEvents(editor); | ||
})) | ||
.catch(( /** | ||
* @param {?} err | ||
* @return {?} | ||
*/function (err) { | ||
console.error(err.stack); | ||
})); | ||
return __assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
}; | ||
@@ -399,2 +673,3 @@ /** | ||
tagName: [{ type: core.Input }], | ||
watchdog: [{ type: core.Input }], | ||
disabled: [{ type: core.Input }], | ||
@@ -404,3 +679,4 @@ ready: [{ type: core.Output }], | ||
blur: [{ type: core.Output }], | ||
focus: [{ type: core.Output }] | ||
focus: [{ type: core.Output }], | ||
error: [{ type: core.Output }] | ||
}; | ||
@@ -407,0 +683,0 @@ return CKEditorComponent; |
@@ -1,2 +0,6 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/common"),require("@angular/forms")):"function"==typeof define&&define.amd?define("@ckeditor/ckeditor5-angular",["exports","@angular/core","@angular/common","@angular/forms"],e):e((t.ckeditor=t.ckeditor||{},t.ckeditor["ckeditor5-angular"]={}),t.ng.core,t.ng.common,t.ng.forms)}(this,function(t,n,e,i){"use strict";var o=function(){return(o=Object.assign||function(t){for(var e,n=1,i=arguments.length;n<i;n++)for(var o in e=arguments[n])Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t}).apply(this,arguments)},r=(Object.defineProperty(a.prototype,"disabled",{get:function(){return this.editorInstance?this.editorInstance.isReadOnly:this.initialIsDisabled},set:function(t){this.setDisabledState(t)},enumerable:!0,configurable:!0}),a.prototype.ngAfterViewInit=function(){var t=this;this.ngZone.runOutsideAngular(function(){t.createEditor()})},a.prototype.ngOnDestroy=function(){this.editorInstance&&(this.editorInstance.destroy(),this.editorInstance=null)},a.prototype.writeValue=function(t){null===t&&(t=""),this.editorInstance?(this.isEditorSettingData=!0,this.editorInstance.setData(t),this.isEditorSettingData=!1):(this.data=t,this.editorElement&&(this.editorElement.innerHTML=this.data))},a.prototype.registerOnChange=function(t){this.cvaOnChange=t},a.prototype.registerOnTouched=function(t){this.cvaOnTouched=t},a.prototype.setDisabledState=function(t){this.editorInstance?this.editorInstance.isReadOnly=t:this.initialIsDisabled=t},a.prototype.createEditor=function(){var e=this,t=document.createElement(this.tagName);if(this.editorElement=t,this.data&&this.config.initialData)throw new Error("Editor data should be provided either using `config.initialData` or `data` properties.");var n=o({},this.config,{initialData:this.config.initialData||this.data||""});return this.elementRef.nativeElement.appendChild(t),this.editor.create(t,n).then(function(t){e.editorInstance=t,e.initialIsDisabled&&(t.isReadOnly=e.initialIsDisabled),e.ngZone.run(function(){e.ready.emit(t)}),e.setUpEditorEvents(t)})["catch"](function(t){console.error(t.stack)})},a.prototype.setUpEditorEvents=function(n){var i=this,t=n.model.document,e=n.editing.view.document;t.on("change:data",function(e){i.ngZone.run(function(){if(i.cvaOnChange&&!i.isEditorSettingData){var t=n.getData();i.cvaOnChange(t)}i.change.emit({event:e,editor:n})})}),e.on("focus",function(t){i.ngZone.run(function(){i.focus.emit({event:t,editor:n})})}),e.on("blur",function(t){i.ngZone.run(function(){i.cvaOnTouched&&i.cvaOnTouched(),i.blur.emit({event:t,editor:n})})})},a.decorators=[{type:n.Component,args:[{selector:"ckeditor",template:"<ng-template></ng-template>",providers:[{provide:i.NG_VALUE_ACCESSOR,useExisting:n.forwardRef(function(){return a}),multi:!0}]}]}],a.ctorParameters=function(){return[{type:n.ElementRef},{type:n.NgZone}]},a.propDecorators={editor:[{type:n.Input}],config:[{type:n.Input}],data:[{type:n.Input}],tagName:[{type:n.Input}],disabled:[{type:n.Input}],ready:[{type:n.Output}],change:[{type:n.Output}],blur:[{type:n.Output}],focus:[{type:n.Output}]},a);function a(t,e){this.config={},this.data="",this.tagName="div",this.ready=new n.EventEmitter,this.change=new n.EventEmitter,this.blur=new n.EventEmitter,this.focus=new n.EventEmitter,this.editorInstance=null,this.initialIsDisabled=!1,this.isEditorSettingData=!1,this.ngZone=e,this.elementRef=t}var s=(c.decorators=[{type:n.NgModule,args:[{imports:[i.FormsModule,e.CommonModule],declarations:[r],exports:[r]}]}],c);function c(){}t.CKEditorComponent=r,t.CKEditorModule=s,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@ckeditor/ckeditor5-watchdog/src/editorwatchdog"),require("@angular/core"),require("@angular/common"),require("@angular/forms")):"function"==typeof define&&define.amd?define("@ckeditor/ckeditor5-angular",["exports","@ckeditor/ckeditor5-watchdog/src/editorwatchdog","@angular/core","@angular/common","@angular/forms"],e):e((t.ckeditor=t.ckeditor||{},t.ckeditor["ckeditor5-angular"]={}),t.EditorWatchdog,t.ng.core,t.ng.common,t.ng.forms)}(this,function(t,s,n,e,i){"use strict";s=s&&s.hasOwnProperty("default")?s["default"]:s;var r=function(){return(r=Object.assign||function(t){for(var e,n=1,i=arguments.length;n<i;n++)for(var r in e=arguments[n])Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=e[r]);return t}).apply(this,arguments)};function c(e,a,s,c){return new(s=s||Promise)(function(t,n){function i(t){try{o(c.next(t))}catch(e){n(e)}}function r(t){try{o(c["throw"](t))}catch(e){n(e)}}function o(e){e.done?t(e.value):new s(function(t){t(e.value)}).then(i,r)}o((c=c.apply(e,a||[])).next())})}function u(i,r){var o,a,s,t,c={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]};return t={next:e(0),"throw":e(1),"return":e(2)},"function"==typeof Symbol&&(t[Symbol.iterator]=function(){return this}),t;function e(e){return function(t){return function n(t){if(o)throw new TypeError("Generator is already executing.");for(;c;)try{if(o=1,a&&(s=2&t[0]?a["return"]:t[0]?a["throw"]||((s=a["return"])&&s.call(a),0):a.next)&&!(s=s.call(a,t[1])).done)return s;switch(a=0,s&&(t=[2&t[0],s.value]),t[0]){case 0:case 1:s=t;break;case 4:return c.label++,{value:t[1],done:!1};case 5:c.label++,a=t[1],t=[0];continue;case 7:t=c.ops.pop(),c.trys.pop();continue;default:if(!(s=0<(s=c.trys).length&&s[s.length-1])&&(6===t[0]||2===t[0])){c=0;continue}if(3===t[0]&&(!s||t[1]>s[0]&&t[1]<s[3])){c.label=t[1];break}if(6===t[0]&&c.label<s[1]){c.label=s[1],s=t;break}if(s&&c.label<s[2]){c.label=s[2],c.ops.push(t);break}s[2]&&c.ops.pop(),c.trys.pop();continue}t=r.call(i,c)}catch(e){t=[6,e],a=0}finally{o=s=0}if(5&t[0])throw t[1];return{value:t[0]?t[1]:void 0,done:!0}}([e,t])}}} | ||
/** | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license | ||
*/var o=new Array(256).fill(0).map(function(t,e){return("0"+e.toString(16)).slice(-2)});var a=(Object.defineProperty(d.prototype,"disabled",{get:function(){return this.editorInstance?this.editorInstance.isReadOnly:this.initialIsDisabled},set:function(t){this.setDisabledState(t)},enumerable:!0,configurable:!0}),Object.defineProperty(d.prototype,"editorInstance",{get:function(){return this.editorWatchdog?this.editorWatchdog.editor:this.watchdog?this.watchdog.getItem(this.id):null},enumerable:!0,configurable:!0}),d.prototype.ngAfterViewInit=function(){this.attachToWatchdog()},d.prototype.ngOnDestroy=function(){return c(this,void 0,void 0,function(){return u(this,function(t){switch(t.label){case 0:return this.watchdog?[4,this.watchdog.remove(this.id)]:[3,2];case 1:return t.sent(),[3,4];case 2:return this.editorWatchdog&&this.editorWatchdog.editor?[4,this.editorWatchdog.destroy()]:[3,4];case 3:t.sent(),this.editorWatchdog=undefined,t.label=4;case 4:return[2]}})})},d.prototype.writeValue=function(t){null===t&&(t=""),this.editorInstance?(this.isEditorSettingData=!0,this.editorInstance.setData(t),this.isEditorSettingData=!1):(this.data=t,this.editorElement&&(this.editorElement.innerHTML=this.data))},d.prototype.registerOnChange=function(t){this.cvaOnChange=t},d.prototype.registerOnTouched=function(t){this.cvaOnTouched=t},d.prototype.setDisabledState=function(t){this.editorInstance&&(this.editorInstance.isReadOnly=t),this.initialIsDisabled=t},d.prototype.attachToWatchdog=function(){var n=this,t=function(i,r){return c(n,void 0,void 0,function(){var e=this;return u(this,function(t){return[2,this.ngZone.runOutsideAngular(function(){return c(e,void 0,void 0,function(){var e,n=this;return u(this,function(t){switch(t.label){case 0:return this.elementRef.nativeElement.appendChild(i),[4,this.editor.create(i,r)];case 1:return e=t.sent(),this.initialIsDisabled&&(e.isReadOnly=this.initialIsDisabled),this.ngZone.run(function(){n.ready.emit(e)}),this.setUpEditorEvents(e),[2,e]}})})})]})})},e=function(e){return c(n,void 0,void 0,function(){return u(this,function(t){switch(t.label){case 0:return[4,e.destroy()];case 1:return t.sent(),this.elementRef.nativeElement.removeChild(this.editorElement),[2]}})})},i=function(){n.ngZone.run(function(){n.error.emit()})},r=document.createElement(this.tagName),o=this.getConfig();if(this.editorElement=r,this.watchdog)this.watchdog.add({id:this.id,type:"editor",creator:t,destructor:e,sourceElementOrData:r,config:o}),this.watchdog.on("itemError",function(t,e){e.itemId===n.id&&i()});else{var a=new s(this.editor);a.setCreator(t),a.setDestructor(e),a.on("error",i),this.editorWatchdog=a,this.editorWatchdog.create(r,o)}},d.prototype.getConfig=function(){if(this.data&&this.config.initialData)throw new Error("Editor data should be provided either using `config.initialData` or `data` properties.");return r({},this.config,{initialData:this.config.initialData||this.data||""})},d.prototype.setUpEditorEvents=function(n){var i=this,t=n.model.document,e=n.editing.view.document;t.on("change:data",function(e){i.ngZone.run(function(){if(i.cvaOnChange&&!i.isEditorSettingData){var t=n.getData();i.cvaOnChange(t)}i.change.emit({event:e,editor:n})})}),e.on("focus",function(t){i.ngZone.run(function(){i.focus.emit({event:t,editor:n})})}),e.on("blur",function(t){i.ngZone.run(function(){i.cvaOnTouched&&i.cvaOnTouched(),i.blur.emit({event:t,editor:n})})})},d.decorators=[{type:n.Component,args:[{selector:"ckeditor",template:"<ng-template></ng-template>",providers:[{provide:i.NG_VALUE_ACCESSOR,useExisting:n.forwardRef(function(){return d}),multi:!0}]}]}],d.ctorParameters=function(){return[{type:n.ElementRef},{type:n.NgZone}]},d.propDecorators={editor:[{type:n.Input}],config:[{type:n.Input}],data:[{type:n.Input}],tagName:[{type:n.Input}],watchdog:[{type:n.Input}],disabled:[{type:n.Input}],ready:[{type:n.Output}],change:[{type:n.Output}],blur:[{type:n.Output}],focus:[{type:n.Output}],error:[{type:n.Output}]},d);function d(t,e){this.config={},this.data="",this.tagName="div",this.ready=new n.EventEmitter,this.change=new n.EventEmitter,this.blur=new n.EventEmitter,this.focus=new n.EventEmitter,this.error=new n.EventEmitter,this.initialIsDisabled=!1,this.isEditorSettingData=!1,this.id=function r(){var t=4294967296*Math.random()>>>0,e=4294967296*Math.random()>>>0,n=4294967296*Math.random()>>>0,i=4294967296*Math.random()>>>0;return"e"+o[t>>0&255]+o[t>>8&255]+o[t>>16&255]+o[t>>24&255]+o[e>>0&255]+o[e>>8&255]+o[e>>16&255]+o[e>>24&255]+o[n>>0&255]+o[n>>8&255]+o[n>>16&255]+o[n>>24&255]+o[i>>0&255]+o[i>>8&255]+o[i>>16&255]+o[i>>24&255]}(),this.ngZone=e,this.elementRef=t}var h=(l.decorators=[{type:n.NgModule,args:[{imports:[i.FormsModule,e.CommonModule],declarations:[a],exports:[a]}]}],l);function l(){}t.CKEditorComponent=a,t.CKEditorModule=h,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ckeditor-ckeditor5-angular.umd.min.js.map |
Changelog | ||
========= | ||
## [1.2.0](https://github.com/ckeditor/ckeditor5-angular/compare/v1.1.2...v1.2.0) (2020-02-27) | ||
### Features | ||
* Improved Angular integration to handle Context and ContextWatchdog. Closes [#165](https://github.com/ckeditor/ckeditor5-angular/issues/165). ([87a1c89](https://github.com/ckeditor/ckeditor5-angular/commit/87a1c89)) | ||
## [1.1.2](https://github.com/ckeditor/ckeditor5-angular/compare/v1.1.1...v1.1.2) (2019-11-04) | ||
@@ -5,0 +12,0 @@ |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"exports":[{"from":"./ckeditor"}],"metadata":{"CKEditorComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":23,"character":1},"arguments":[{"selector":"ckeditor","template":"<ng-template></ng-template>","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":30,"character":12},"useExisting":{"__symbolic":"reference","name":"CKEditorComponent"},"multi":true}]}]}],"members":{"editor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":47,"character":2}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":54,"character":2}}]}],"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":60,"character":2}}]}],"tagName":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":67,"character":2}}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":74,"character":2}}]}],"ready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":91,"character":2}}]}],"change":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":98,"character":2}}]}],"blur":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":105,"character":2}}]}],"focus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":112,"character":2}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":157,"character":33},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":157,"character":53}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"createEditor":[{"__symbolic":"method"}],"setUpEditorEvents":[{"__symbolic":"method"}]}},"BlurEvent":{"__symbolic":"interface"},"FocusEvent":{"__symbolic":"interface"},"ChangeEvent":{"__symbolic":"interface"},"CKEditorModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":10,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/forms","name":"FormsModule","line":11,"character":12},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":11,"character":25}],"declarations":[{"__symbolic":"reference","name":"CKEditorComponent"}],"exports":[{"__symbolic":"reference","name":"CKEditorComponent"}]}]}],"members":{}}},"origins":{"CKEditorComponent":"./ckeditor.component","BlurEvent":"./ckeditor.component","FocusEvent":"./ckeditor.component","ChangeEvent":"./ckeditor.component","CKEditorModule":"./ckeditor.module"},"importAs":"@ckeditor/ckeditor5-angular"} | ||
{"__symbolic":"module","version":4,"exports":[{"from":"./ckeditor"}],"metadata":{"CKEditorComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":27,"character":1},"arguments":[{"selector":"ckeditor","template":"<ng-template></ng-template>","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":34,"character":12},"useExisting":{"__symbolic":"reference","name":"CKEditorComponent"},"multi":true}]}]}],"members":{"editor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":51,"character":2}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":58,"character":2}}]}],"data":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":64,"character":2}}]}],"tagName":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":71,"character":2}}]}],"watchdog":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":76,"character":2}}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":83,"character":2}}]}],"ready":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":100,"character":2}}]}],"change":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":107,"character":2}}]}],"blur":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":114,"character":2}}]}],"focus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":121,"character":2}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":126,"character":2}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":189,"character":33},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":189,"character":53}]}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"attachToWatchdog":[{"__symbolic":"method"}],"getConfig":[{"__symbolic":"method"}],"setUpEditorEvents":[{"__symbolic":"method"}]}},"BlurEvent":{"__symbolic":"interface"},"FocusEvent":{"__symbolic":"interface"},"ChangeEvent":{"__symbolic":"interface"},"CKEditorModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":10,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/forms","name":"FormsModule","line":11,"character":12},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":11,"character":25}],"declarations":[{"__symbolic":"reference","name":"CKEditorComponent"}],"exports":[{"__symbolic":"reference","name":"CKEditorComponent"}]}]}],"members":{}}},"origins":{"CKEditorComponent":"./ckeditor.component","BlurEvent":"./ckeditor.component","FocusEvent":"./ckeditor.component","ChangeEvent":"./ckeditor.component","CKEditorModule":"./ckeditor.module"},"importAs":"@ckeditor/ckeditor5-angular"} |
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -36,2 +36,6 @@ */ | ||
/** | ||
* The context watchdog. | ||
*/ | ||
watchdog?: CKEditor5.ContextWatchdog; | ||
/** | ||
* When set `true`, the editor becomes read-only. | ||
@@ -67,6 +71,15 @@ * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#member-isReadOnly | ||
/** | ||
* Fires when the editor component crashes. | ||
*/ | ||
error: EventEmitter<void>; | ||
/** | ||
* The instance of the editor created by this component. | ||
*/ | ||
editorInstance: CKEditor5.Editor | null; | ||
readonly editorInstance: CKEditor5.Editor | null; | ||
/** | ||
* The editor watchdog. It is created when the context watchdog is not passed to the component. | ||
* It keeps the editor running. | ||
*/ | ||
private editorWatchdog?; | ||
/** | ||
* If the component is read–only before the editor instance is created, it remembers that state, | ||
@@ -103,5 +116,6 @@ * so the editor can become read–only once it is ready. | ||
private isEditorSettingData; | ||
private id; | ||
constructor(elementRef: ElementRef, ngZone: NgZone); | ||
ngAfterViewInit(): void; | ||
ngOnDestroy(): void; | ||
ngOnDestroy(): Promise<void>; | ||
writeValue(value: string | null): void; | ||
@@ -116,3 +130,4 @@ registerOnChange(callback: (data: string) => void): void; | ||
*/ | ||
private createEditor; | ||
private attachToWatchdog; | ||
private getConfig; | ||
/** | ||
@@ -119,0 +134,0 @@ * Integrates the editor with the component by attaching related event listeners. |
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -79,2 +79,19 @@ */ | ||
} | ||
interface ContextWatchdog extends Watchdog<any> { | ||
context: any; | ||
add(items: any): Promise<void>; | ||
remove(items: string | string[]): Promise<void>; | ||
getItem(itemId: string): Editor; | ||
addItemWatchdog(itemId: string, itemType: string, watchdog: Watchdog<any>): Promise<void>; | ||
} | ||
interface EditorWatchdog extends Watchdog<Editor> { | ||
editor: Editor; | ||
} | ||
interface Watchdog<T> { | ||
setCreator(creator: (...args: any[]) => Promise<T>): void; | ||
setDestructor(destructor: (item: T) => Promise<void>): void; | ||
on(event: string, callback: (...args: any) => any): void; | ||
destroy(): Promise<void>; | ||
create(...args: any[]): Promise<void>; | ||
} | ||
} |
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -4,0 +4,0 @@ */ |
@@ -5,7 +5,10 @@ /** | ||
*/ | ||
import * as tslib_1 from "tslib"; | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
*/ | ||
import { Component, Input, Output, NgZone, EventEmitter, forwardRef, ElementRef } from '@angular/core'; | ||
import EditorWatchdog from '@ckeditor/ckeditor5-watchdog/src/editorwatchdog'; | ||
import uid from './uid'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
@@ -60,5 +63,5 @@ export class CKEditorComponent { | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
*/ | ||
this.editorInstance = null; | ||
this.error = new EventEmitter(); | ||
/** | ||
@@ -73,2 +76,3 @@ * If the component is read–only before the editor instance is created, it remembers that state, | ||
this.isEditorSettingData = false; | ||
this.id = uid(); | ||
this.ngZone = ngZone; | ||
@@ -96,2 +100,15 @@ this.elementRef = elementRef; | ||
} | ||
/** | ||
* The instance of the editor created by this component. | ||
* @return {?} | ||
*/ | ||
get editorInstance() { | ||
if (this.editorWatchdog) { | ||
return this.editorWatchdog.editor; | ||
} | ||
if (this.watchdog) { | ||
return this.watchdog.getItem(this.id); | ||
} | ||
return null; | ||
} | ||
// Implementing the AfterViewInit interface. | ||
@@ -102,8 +119,3 @@ /** | ||
ngAfterViewInit() { | ||
this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.createEditor(); | ||
})); | ||
this.attachToWatchdog(); | ||
} | ||
@@ -115,6 +127,11 @@ // Implementing the OnDestroy interface. | ||
ngOnDestroy() { | ||
if (this.editorInstance) { | ||
this.editorInstance.destroy(); | ||
this.editorInstance = null; | ||
} | ||
return tslib_1.__awaiter(this, void 0, void 0, /** @this {!CKEditorComponent} */ function* () { | ||
if (this.watchdog) { | ||
yield this.watchdog.remove(this.id); | ||
} | ||
else if (this.editorWatchdog && this.editorWatchdog.editor) { | ||
yield this.editorWatchdog.destroy(); | ||
this.editorWatchdog = undefined; | ||
} | ||
}); | ||
} | ||
@@ -172,10 +189,8 @@ // Implementing the ControlValueAccessor interface (only when binding to ngModel). | ||
setDisabledState(isDisabled) { | ||
// If already initialized | ||
// If already initialized. | ||
if (this.editorInstance) { | ||
this.editorInstance.isReadOnly = isDisabled; | ||
} | ||
// If not, wait for it to be ready; store the state. | ||
else { | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
// Store the state anyway to use it once the editor is created. | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
@@ -189,23 +204,44 @@ /** | ||
*/ | ||
createEditor() { | ||
attachToWatchdog() { | ||
/** @type {?} */ | ||
const element = document.createElement(this.tagName); | ||
this.editorElement = element; | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
const creator = (/** | ||
* @param {?} element | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
(element, config) => tslib_1.__awaiter(this, void 0, void 0, function* () { | ||
return this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
() => tslib_1.__awaiter(this, void 0, void 0, function* () { | ||
this.elementRef.nativeElement.appendChild(element); | ||
/** @type {?} */ | ||
const editor = yield (/** @type {?} */ (this.editor)).create(element, config); | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
this.ngZone.run((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.ready.emit(editor); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
return editor; | ||
}))); | ||
})); | ||
/** @type {?} */ | ||
const config = Object.assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
this.elementRef.nativeElement.appendChild(element); | ||
return (/** @type {?} */ (this.editor)).create(element, config) | ||
.then((/** | ||
const destructor = (/** | ||
* @param {?} editor | ||
* @return {?} | ||
*/ | ||
editor => { | ||
this.editorInstance = editor; | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
(editor) => tslib_1.__awaiter(this, void 0, void 0, function* () { | ||
yield editor.destroy(); | ||
this.elementRef.nativeElement.removeChild((/** @type {?} */ (this.editorElement))); | ||
})); | ||
/** @type {?} */ | ||
const emitError = (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.ngZone.run((/** | ||
@@ -215,15 +251,55 @@ * @return {?} | ||
() => { | ||
this.ready.emit(editor); | ||
this.error.emit(); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
})) | ||
.catch((/** | ||
* @param {?} err | ||
* @return {?} | ||
*/ | ||
(err) => { | ||
console.error(err.stack); | ||
})); | ||
}); | ||
/** @type {?} */ | ||
const element = document.createElement(this.tagName); | ||
/** @type {?} */ | ||
const config = this.getConfig(); | ||
this.editorElement = element; | ||
// Based on the presence of the watchdog decide how to initialize the editor. | ||
if (this.watchdog) { | ||
// When the context watchdog is passed add the new item to it based on the passed configuration. | ||
this.watchdog.add({ | ||
id: this.id, | ||
type: 'editor', | ||
creator, | ||
destructor, | ||
sourceElementOrData: element, | ||
config | ||
}); | ||
this.watchdog.on('itemError', (/** | ||
* @param {?} _ | ||
* @param {?} __1 | ||
* @return {?} | ||
*/ | ||
(_, { itemId }) => { | ||
if (itemId === this.id) { | ||
emitError(); | ||
} | ||
})); | ||
} | ||
else { | ||
// In the other case create the watchdog by hand to keep the editor running. | ||
/** @type {?} */ | ||
const editorWatchdog = new EditorWatchdog(this.editor); | ||
editorWatchdog.setCreator(creator); | ||
editorWatchdog.setDestructor(destructor); | ||
editorWatchdog.on('error', emitError); | ||
this.editorWatchdog = editorWatchdog; | ||
this.editorWatchdog.create(element, config); | ||
} | ||
} | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
getConfig() { | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
return Object.assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
} | ||
/** | ||
* Integrates the editor with the component by attaching related event listeners. | ||
@@ -313,2 +389,3 @@ * @private | ||
tagName: [{ type: Input }], | ||
watchdog: [{ type: Input }], | ||
disabled: [{ type: Input }], | ||
@@ -318,3 +395,4 @@ ready: [{ type: Output }], | ||
blur: [{ type: Output }], | ||
focus: [{ type: Output }] | ||
focus: [{ type: Output }], | ||
error: [{ type: Output }] | ||
}; | ||
@@ -355,2 +433,7 @@ if (false) { | ||
/** | ||
* The context watchdog. | ||
* @type {?} | ||
*/ | ||
CKEditorComponent.prototype.watchdog; | ||
/** | ||
* Fires when the editor is ready. It corresponds with the `editor#ready` | ||
@@ -384,7 +467,14 @@ * https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#event-ready | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
* @type {?} | ||
*/ | ||
CKEditorComponent.prototype.editorInstance; | ||
CKEditorComponent.prototype.error; | ||
/** | ||
* The editor watchdog. It is created when the context watchdog is not passed to the component. | ||
* It keeps the editor running. | ||
* @type {?} | ||
* @private | ||
*/ | ||
CKEditorComponent.prototype.editorWatchdog; | ||
/** | ||
* If the component is read–only before the editor instance is created, it remembers that state, | ||
@@ -433,2 +523,7 @@ * so the editor can become read–only once it is ready. | ||
CKEditorComponent.prototype.isEditorSettingData; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
CKEditorComponent.prototype.id; | ||
} | ||
@@ -465,2 +560,2 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"ng://@ckeditor/ckeditor5-angular/","sources":["ckeditor.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved.\n * For licensing, see LICENSE.md.\n */\n\nimport {\n\tComponent,\n\tInput,\n\tOutput,\n\tNgZone,\n\tEventEmitter,\n\tforwardRef,\n\tAfterViewInit, OnDestroy,\n\tElementRef\n} from '@angular/core';\n\nimport {\n\tControlValueAccessor,\n\tNG_VALUE_ACCESSOR\n} from '@angular/forms';\n\nimport { CKEditor5 } from './ckeditor';\n\n@Component( {\n\tselector: 'ckeditor',\n\ttemplate: '<ng-template></ng-template>',\n\n\t// Integration with @angular/forms.\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\t\tuseExisting: forwardRef( () => CKEditorComponent ),\n\t\t\tmulti: true,\n\t\t}\n\t]\n} )\nexport class CKEditorComponent implements AfterViewInit, OnDestroy, ControlValueAccessor {\n\t/**\n\t * The reference to the DOM element created by the component.\n\t */\n\tprivate elementRef!: ElementRef<HTMLElement>;\n\n\t/**\n\t * The constructor of the editor to be used for the instance of the component.\n\t * It can be e.g. the `ClassicEditorBuild`, `InlineEditorBuild` or some custom editor.\n\t */\n\t@Input() public editor?: CKEditor5.EditorConstructor;\n\n\t/**\n\t * The configuration of the editor.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editorconfig-EditorConfig.html\n\t * to learn more.\n\t */\n\t@Input() public config: CKEditor5.Config = {};\n\n\t/**\n\t * The initial data of the editor. Useful when not using the ngModel.\n\t * See https://angular.io/api/forms/NgModel to learn more.\n\t */\n\t@Input() public data = '';\n\n\t/**\n\t * Tag name of the editor component.\n\t *\n\t * The default tag is 'div'.\n\t */\n\t@Input() public tagName = 'div';\n\n\t/**\n\t * When set `true`, the editor becomes read-only.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#member-isReadOnly\n\t * to learn more.\n\t */\n\t@Input() public set disabled( isDisabled: boolean ) {\n\t\tthis.setDisabledState( isDisabled );\n\t}\n\n\tpublic get disabled() {\n\t\tif ( this.editorInstance ) {\n\t\t\treturn this.editorInstance.isReadOnly;\n\t\t}\n\n\t\treturn this.initialIsDisabled;\n\t}\n\n\t/**\n\t * Fires when the editor is ready. It corresponds with the `editor#ready`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#event-ready\n\t * event.\n\t */\n\t@Output() public ready = new EventEmitter<CKEditor5.Editor>();\n\n\t/**\n\t * Fires when the content of the editor has changed. It corresponds with the `editor.model.document#change`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_model_document-Document.html#event-change\n\t * event.\n\t */\n\t@Output() public change: EventEmitter<ChangeEvent> = new EventEmitter<ChangeEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is blurred. It corresponds with the `editor.editing.view.document#blur`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:blur\n\t * event.\n\t */\n\t@Output() public blur: EventEmitter<BlurEvent> = new EventEmitter<BlurEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is focused. It corresponds with the `editor.editing.view.document#focus`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:focus\n\t * event.\n\t */\n\t@Output() public focus: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n\n\t/**\n\t * The instance of the editor created by this component.\n\t */\n\tpublic editorInstance: CKEditor5.Editor | null = null;\n\n\t/**\n\t * If the component is read–only before the editor instance is created, it remembers that state,\n\t * so the editor can become read–only once it is ready.\n\t */\n\tprivate initialIsDisabled = false;\n\n\t/**\n\t * An instance of https://angular.io/api/core/NgZone to allow the interaction with the editor\n\t * withing the Angular event loop.\n\t */\n\tprivate ngZone: NgZone;\n\n\t/**\n\t * A callback executed when the content of the editor changes. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnChange?: ( data: string ) => void;\n\n\t/**\n\t * A callback executed when the editor has been blurred. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnTouched?: () => void;\n\n\t/**\n\t * Reference to the source element used by the editor.\n\t */\n\tprivate editorElement?: HTMLElement;\n\n\t/**\n\t * A lock flag preventing from calling the `cvaOnChange()` during setting editor data.\n\t */\n\tprivate isEditorSettingData = false;\n\n\tpublic constructor( elementRef: ElementRef, ngZone: NgZone ) {\n\t\tthis.ngZone = ngZone;\n\t\tthis.elementRef = elementRef;\n\t}\n\n\t// Implementing the AfterViewInit interface.\n\tpublic ngAfterViewInit() {\n\t\tthis.ngZone.runOutsideAngular( () => {\n\t\t\tthis.createEditor();\n\t\t} );\n\t}\n\n\t// Implementing the OnDestroy interface.\n\tpublic ngOnDestroy() {\n\t\tif ( this.editorInstance ) {\n\t\t\tthis.editorInstance.destroy();\n\t\t\tthis.editorInstance = null;\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic writeValue( value: string | null ): void {\n\t\t// This method is called with the `null` value when the form resets.\n\t\t// A component's responsibility is to restore to the initial state.\n\t\tif ( value === null ) {\n\t\t\tvalue = '';\n\t\t}\n\n\t\t// If already initialized.\n\t\tif ( this.editorInstance ) {\n\t\t\t// The lock mechanism prevents from calling `cvaOnChange()` during changing\n\t\t\t// the editor state. See #139\n\t\t\tthis.isEditorSettingData = true;\n\t\t\tthis.editorInstance.setData( value );\n\t\t\tthis.isEditorSettingData = false;\n\t\t}\n\t\t// If not, wait for it to be ready; store the data.\n\t\telse {\n\t\t\tthis.data = value;\n\n\t\t\t// If the editor element is already available, then update its content.\n\t\t\t// If the ngModel is used then the editor element should be updated directly here.\n\t\t\tif ( this.editorElement ) {\n\t\t\t\tthis.editorElement.innerHTML = this.data;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnChange( callback: ( data: string ) => void ): void {\n\t\tthis.cvaOnChange = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnTouched( callback: () => void ): void {\n\t\tthis.cvaOnTouched = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic setDisabledState( isDisabled: boolean ): void {\n\t\t// If already initialized\n\t\tif ( this.editorInstance ) {\n\t\t\tthis.editorInstance.isReadOnly = isDisabled;\n\t\t}\n\t\t// If not, wait for it to be ready; store the state.\n\t\telse {\n\t\t\tthis.initialIsDisabled = isDisabled;\n\t\t}\n\t}\n\n\t/**\n\t * Creates the editor instance, sets initial editor data, then integrates\n\t * the editor with the Angular component. This method does not use the `editor.setData()`\n\t * because of the issue in the collaboration mode (#6).\n\t */\n\tprivate createEditor(): Promise<void> {\n\t\tconst element = document.createElement( this.tagName );\n\t\tthis.editorElement = element;\n\n\t\tif ( this.data && this.config.initialData ) {\n\t\t\tthrow new Error( 'Editor data should be provided either using `config.initialData` or `data` properties.' );\n\t\t}\n\n\t\t// Merge two possible ways of providing data into the `config.initialData` field.\n\t\tconst config = {\n\t\t\t...this.config,\n\t\t\tinitialData: this.config.initialData || this.data || ''\n\t\t};\n\n\t\tthis.elementRef.nativeElement.appendChild( element );\n\n\t\treturn this.editor!.create( element, config )\n\t\t\t.then( editor => {\n\t\t\t\tthis.editorInstance = editor;\n\n\t\t\t\tif ( this.initialIsDisabled ) {\n\t\t\t\t\teditor.isReadOnly = this.initialIsDisabled;\n\t\t\t\t}\n\n\t\t\t\tthis.ngZone.run( () => {\n\t\t\t\t\tthis.ready.emit( editor );\n\t\t\t\t} );\n\n\t\t\t\tthis.setUpEditorEvents( editor );\n\t\t\t} )\n\t\t\t.catch( ( err: Error ) => {\n\t\t\t\tconsole.error( err.stack );\n\t\t\t} );\n\t}\n\n\t/**\n\t * Integrates the editor with the component by attaching related event listeners.\n\t */\n\tprivate setUpEditorEvents( editor: CKEditor5.Editor ): void {\n\t\tconst modelDocument = editor.model.document;\n\t\tconst viewDocument = editor.editing.view.document;\n\n\t\tmodelDocument.on( 'change:data', ( evt: CKEditor5.EventInfo<'change:data'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnChange && !this.isEditorSettingData ) {\n\t\t\t\t\tconst data = editor.getData();\n\n\t\t\t\t\tthis.cvaOnChange( data );\n\t\t\t\t}\n\n\t\t\t\tthis.change.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'focus', ( evt: CKEditor5.EventInfo<'focus'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tthis.focus.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'blur', ( evt: CKEditor5.EventInfo<'blur'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnTouched ) {\n\t\t\t\t\tthis.cvaOnTouched();\n\t\t\t\t}\n\n\t\t\t\tthis.blur.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\t}\n}\n\nexport interface BlurEvent {\n\tevent: CKEditor5.EventInfo<'blur'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface FocusEvent {\n\tevent: CKEditor5.EventInfo<'focus'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface ChangeEvent {\n\tevent: CKEditor5.EventInfo<'change:data'>;\n\teditor: CKEditor5.Editor;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"ng://@ckeditor/ckeditor5-angular/","sources":["ckeditor.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved.\n * For licensing, see LICENSE.md.\n */\n\nimport {\n\tComponent,\n\tInput,\n\tOutput,\n\tNgZone,\n\tEventEmitter,\n\tforwardRef,\n\tAfterViewInit, OnDestroy,\n\tElementRef\n} from '@angular/core';\n\nimport EditorWatchdog from '@ckeditor/ckeditor5-watchdog/src/editorwatchdog';\n\nimport uid from './uid';\n\nimport {\n\tControlValueAccessor,\n\tNG_VALUE_ACCESSOR\n} from '@angular/forms';\n\nimport { CKEditor5 } from './ckeditor';\n\n@Component( {\n\tselector: 'ckeditor',\n\ttemplate: '<ng-template></ng-template>',\n\n\t// Integration with @angular/forms.\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\t\tuseExisting: forwardRef( () => CKEditorComponent ),\n\t\t\tmulti: true,\n\t\t}\n\t]\n} )\nexport class CKEditorComponent implements AfterViewInit, OnDestroy, ControlValueAccessor {\n\t/**\n\t * The reference to the DOM element created by the component.\n\t */\n\tprivate elementRef!: ElementRef<HTMLElement>;\n\n\t/**\n\t * The constructor of the editor to be used for the instance of the component.\n\t * It can be e.g. the `ClassicEditorBuild`, `InlineEditorBuild` or some custom editor.\n\t */\n\t@Input() public editor?: CKEditor5.EditorConstructor;\n\n\t/**\n\t * The configuration of the editor.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editorconfig-EditorConfig.html\n\t * to learn more.\n\t */\n\t@Input() public config: CKEditor5.Config = {};\n\n\t/**\n\t * The initial data of the editor. Useful when not using the ngModel.\n\t * See https://angular.io/api/forms/NgModel to learn more.\n\t */\n\t@Input() public data = '';\n\n\t/**\n\t * Tag name of the editor component.\n\t *\n\t * The default tag is 'div'.\n\t */\n\t@Input() public tagName = 'div';\n\n\t/**\n\t * The context watchdog.\n\t */\n\t@Input() public watchdog?: CKEditor5.ContextWatchdog;\n\n\t/**\n\t * When set `true`, the editor becomes read-only.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#member-isReadOnly\n\t * to learn more.\n\t */\n\t@Input() public set disabled( isDisabled: boolean ) {\n\t\tthis.setDisabledState( isDisabled );\n\t}\n\n\tpublic get disabled() {\n\t\tif ( this.editorInstance ) {\n\t\t\treturn this.editorInstance.isReadOnly;\n\t\t}\n\n\t\treturn this.initialIsDisabled;\n\t}\n\n\t/**\n\t * Fires when the editor is ready. It corresponds with the `editor#ready`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#event-ready\n\t * event.\n\t */\n\t@Output() public ready = new EventEmitter<CKEditor5.Editor>();\n\n\t/**\n\t * Fires when the content of the editor has changed. It corresponds with the `editor.model.document#change`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_model_document-Document.html#event-change\n\t * event.\n\t */\n\t@Output() public change: EventEmitter<ChangeEvent> = new EventEmitter<ChangeEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is blurred. It corresponds with the `editor.editing.view.document#blur`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:blur\n\t * event.\n\t */\n\t@Output() public blur: EventEmitter<BlurEvent> = new EventEmitter<BlurEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is focused. It corresponds with the `editor.editing.view.document#focus`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:focus\n\t * event.\n\t */\n\t@Output() public focus: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n\n\t/**\n\t * Fires when the editor component crashes.\n\t */\n\t@Output() public error: EventEmitter<void> = new EventEmitter<void>();\n\n\t/**\n\t * The instance of the editor created by this component.\n\t */\n\tpublic get editorInstance(): CKEditor5.Editor | null {\n\t\tif ( this.editorWatchdog ) {\n\t\t\treturn this.editorWatchdog.editor;\n\t\t}\n\n\t\tif ( this.watchdog ) {\n\t\t\treturn this.watchdog.getItem( this.id );\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t/**\n\t * The editor watchdog. It is created when the context watchdog is not passed to the component.\n\t * It keeps the editor running.\n\t */\n\tprivate editorWatchdog?: CKEditor5.EditorWatchdog;\n\n\t/**\n\t * If the component is read–only before the editor instance is created, it remembers that state,\n\t * so the editor can become read–only once it is ready.\n\t */\n\tprivate initialIsDisabled = false;\n\n\t/**\n\t * An instance of https://angular.io/api/core/NgZone to allow the interaction with the editor\n\t * withing the Angular event loop.\n\t */\n\tprivate ngZone: NgZone;\n\n\t/**\n\t * A callback executed when the content of the editor changes. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnChange?: ( data: string ) => void;\n\n\t/**\n\t * A callback executed when the editor has been blurred. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnTouched?: () => void;\n\n\t/**\n\t * Reference to the source element used by the editor.\n\t */\n\tprivate editorElement?: HTMLElement;\n\n\t/**\n\t * A lock flag preventing from calling the `cvaOnChange()` during setting editor data.\n\t */\n\tprivate isEditorSettingData = false;\n\n\tprivate id = uid();\n\n\tpublic constructor( elementRef: ElementRef, ngZone: NgZone ) {\n\t\tthis.ngZone = ngZone;\n\t\tthis.elementRef = elementRef;\n\t}\n\n\t// Implementing the AfterViewInit interface.\n\tpublic ngAfterViewInit() {\n\t\tthis.attachToWatchdog();\n\t}\n\n\t// Implementing the OnDestroy interface.\n\tpublic async ngOnDestroy() {\n\t\tif ( this.watchdog ) {\n\t\t\tawait this.watchdog.remove( this.id );\n\t\t} else if ( this.editorWatchdog && this.editorWatchdog.editor ) {\n\t\t\tawait this.editorWatchdog.destroy();\n\n\t\t\tthis.editorWatchdog = undefined;\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic writeValue( value: string | null ): void {\n\t\t// This method is called with the `null` value when the form resets.\n\t\t// A component's responsibility is to restore to the initial state.\n\t\tif ( value === null ) {\n\t\t\tvalue = '';\n\t\t}\n\n\t\t// If already initialized.\n\t\tif ( this.editorInstance ) {\n\t\t\t// The lock mechanism prevents from calling `cvaOnChange()` during changing\n\t\t\t// the editor state. See #139\n\t\t\tthis.isEditorSettingData = true;\n\t\t\tthis.editorInstance.setData( value );\n\t\t\tthis.isEditorSettingData = false;\n\t\t}\n\t\t// If not, wait for it to be ready; store the data.\n\t\telse {\n\t\t\tthis.data = value;\n\n\t\t\t// If the editor element is already available, then update its content.\n\t\t\t// If the ngModel is used then the editor element should be updated directly here.\n\t\t\tif ( this.editorElement ) {\n\t\t\t\tthis.editorElement.innerHTML = this.data;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnChange( callback: ( data: string ) => void ): void {\n\t\tthis.cvaOnChange = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnTouched( callback: () => void ): void {\n\t\tthis.cvaOnTouched = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic setDisabledState( isDisabled: boolean ): void {\n\t\t// If already initialized.\n\t\tif ( this.editorInstance ) {\n\t\t\tthis.editorInstance.isReadOnly = isDisabled;\n\t\t}\n\n\t\t// Store the state anyway to use it once the editor is created.\n\t\tthis.initialIsDisabled = isDisabled;\n\t}\n\n\t/**\n\t * Creates the editor instance, sets initial editor data, then integrates\n\t * the editor with the Angular component. This method does not use the `editor.setData()`\n\t * because of the issue in the collaboration mode (#6).\n\t */\n\tprivate attachToWatchdog() {\n\t\tconst creator = async ( element: HTMLElement, config: CKEditor5.Config ) => {\n\t\t\treturn this.ngZone.runOutsideAngular( async () => {\n\t\t\t\tthis.elementRef.nativeElement.appendChild( element );\n\n\t\t\t\tconst editor = await this.editor!.create( element, config );\n\n\t\t\t\tif ( this.initialIsDisabled ) {\n\t\t\t\t\teditor.isReadOnly = this.initialIsDisabled;\n\t\t\t\t}\n\n\t\t\t\tthis.ngZone.run( () => {\n\t\t\t\t\tthis.ready.emit( editor );\n\t\t\t\t} );\n\n\t\t\t\tthis.setUpEditorEvents( editor );\n\n\t\t\t\treturn editor;\n\t\t\t} );\n\t\t};\n\n\t\tconst destructor = async ( editor: CKEditor5.Editor ) => {\n\t\t\tawait editor.destroy();\n\n\t\t\tthis.elementRef.nativeElement.removeChild( this.editorElement! );\n\t\t};\n\n\t\tconst emitError = () => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tthis.error.emit();\n\t\t\t} );\n\t\t};\n\n\t\tconst element = document.createElement( this.tagName );\n\t\tconst config = this.getConfig();\n\n\t\tthis.editorElement = element;\n\n\t\t// Based on the presence of the watchdog decide how to initialize the editor.\n\t\tif ( this.watchdog ) {\n\t\t\t// When the context watchdog is passed add the new item to it based on the passed configuration.\n\t\t\tthis.watchdog.add( {\n\t\t\t\tid: this.id,\n\t\t\t\ttype: 'editor',\n\t\t\t\tcreator,\n\t\t\t\tdestructor,\n\t\t\t\tsourceElementOrData: element,\n\t\t\t\tconfig\n\t\t\t} );\n\n\t\t\tthis.watchdog.on( 'itemError', ( _, { itemId } ) => {\n\t\t\t\tif ( itemId === this.id ) {\n\t\t\t\t\temitError();\n\t\t\t\t}\n\t\t\t} );\n\t\t} else {\n\t\t\t// In the other case create the watchdog by hand to keep the editor running.\n\t\t\tconst editorWatchdog: CKEditor5.EditorWatchdog = new EditorWatchdog( this.editor );\n\n\t\t\teditorWatchdog.setCreator( creator );\n\t\t\teditorWatchdog.setDestructor( destructor );\n\t\t\teditorWatchdog.on( 'error', emitError );\n\n\t\t\tthis.editorWatchdog = editorWatchdog;\n\n\t\t\tthis.editorWatchdog.create( element, config );\n\t\t}\n\t}\n\n\tprivate getConfig() {\n\t\tif ( this.data && this.config.initialData ) {\n\t\t\tthrow new Error( 'Editor data should be provided either using `config.initialData` or `data` properties.' );\n\t\t}\n\n\t\t// Merge two possible ways of providing data into the `config.initialData` field.\n\t\treturn {\n\t\t\t...this.config,\n\t\t\tinitialData: this.config.initialData || this.data || ''\n\t\t};\n\t}\n\n\t/**\n\t * Integrates the editor with the component by attaching related event listeners.\n\t */\n\tprivate setUpEditorEvents( editor: CKEditor5.Editor ): void {\n\t\tconst modelDocument = editor.model.document;\n\t\tconst viewDocument = editor.editing.view.document;\n\n\t\tmodelDocument.on( 'change:data', ( evt: CKEditor5.EventInfo<'change:data'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnChange && !this.isEditorSettingData ) {\n\t\t\t\t\tconst data = editor.getData();\n\n\t\t\t\t\tthis.cvaOnChange( data );\n\t\t\t\t}\n\n\t\t\t\tthis.change.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'focus', ( evt: CKEditor5.EventInfo<'focus'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tthis.focus.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'blur', ( evt: CKEditor5.EventInfo<'blur'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnTouched ) {\n\t\t\t\t\tthis.cvaOnTouched();\n\t\t\t\t}\n\n\t\t\t\tthis.blur.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\t}\n}\n\nexport interface BlurEvent {\n\tevent: CKEditor5.EventInfo<'blur'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface FocusEvent {\n\tevent: CKEditor5.EventInfo<'focus'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface ChangeEvent {\n\tevent: CKEditor5.EventInfo<'change:data'>;\n\teditor: CKEditor5.Editor;\n}\n"]} |
@@ -6,3 +6,3 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -183,3 +183,76 @@ */ | ||
CKEditor5.Editor = Editor; | ||
/** | ||
* @record | ||
*/ | ||
function ContextWatchdog() { } | ||
CKEditor5.ContextWatchdog = ContextWatchdog; | ||
if (false) { | ||
/** @type {?} */ | ||
ContextWatchdog.prototype.context; | ||
/** | ||
* @param {?} items | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.add = function (items) { }; | ||
/** | ||
* @param {?} items | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.remove = function (items) { }; | ||
/** | ||
* @param {?} itemId | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.getItem = function (itemId) { }; | ||
/** | ||
* @param {?} itemId | ||
* @param {?} itemType | ||
* @param {?} watchdog | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.addItemWatchdog = function (itemId, itemType, watchdog) { }; | ||
} | ||
/** | ||
* @record | ||
*/ | ||
function EditorWatchdog() { } | ||
CKEditor5.EditorWatchdog = EditorWatchdog; | ||
if (false) { | ||
/** @type {?} */ | ||
EditorWatchdog.prototype.editor; | ||
} | ||
/** | ||
* @record | ||
* @template T | ||
*/ | ||
function Watchdog() { } | ||
CKEditor5.Watchdog = Watchdog; | ||
if (false) { | ||
/** | ||
* @param {?} creator | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.setCreator = function (creator) { }; | ||
/** | ||
* @param {?} destructor | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.setDestructor = function (destructor) { }; | ||
/** | ||
* @param {?} event | ||
* @param {?} callback | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.on = function (event, callback) { }; | ||
/** | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.destroy = function () { }; | ||
/** | ||
* @param {...?} args | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.create = function (args) { }; | ||
} | ||
})(CKEditor5 || (CKEditor5 = {})); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJja2VkaXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVFBLE1BQU0sS0FBVyxTQUFTLENBZ0Z6QjtBQWhGRCxXQUFpQixTQUFTOzs7OztJQUt6QixnQ0FFQzs7Ozs7Ozs7UUFEQSxnRkFBc0Y7Ozs7OztJQU12RixxQkFFQzs7Ozs7Ozs7O0lBT0Qsd0JBUUM7Ozs7UUFQQSx5QkFBeUI7O1FBQ3pCLHlCQUFxQjs7UUFDckIsMkJBQXFCOztRQUNyQiwyQkFBYTs7OztRQUViLDBDQUFZOzs7O1FBQ1osMkNBQWE7Ozs7Ozs7O0lBUWQseUJBMEJDOzs7O1FBekJBLDhCQUF1Qjs7UUFDdkIsNEJBQXFCOztRQUNyQixnQ0FBeUI7O1FBQ3pCLDBCQUFtQjs7UUFDbkIsNkJBQXNCOztRQUN0QixnQ0FBeUI7O1FBQ3pCLDRCQUFxQjs7UUFDckIsMkJBQW9COztRQUNwQiw2QkFBc0I7O1FBQ3RCLDJCQUF1RDs7UUFFdkQsZ0NBQW9COzs7Ozs7UUFFcEIsc0RBQWtDOzs7O1FBQ2xDLCtDQUF5Qjs7Ozs7O1FBQ3pCLGtFQUFzRDs7Ozs7O1FBQ3RELDJEQUEyQzs7Ozs7Ozs7UUFDM0MscUZBQXFGOzs7Ozs7UUFDckYsOERBQW1EOzs7Ozs7O1FBQ25ELHNFQUFpRTs7Ozs7OztRQUNqRSx3RUFBbUU7Ozs7Ozs7UUFDbkUsaUZBQTJFOzs7OztRQUMzRSw2Q0FBMEI7Ozs7Ozs7O0lBVTNCLHNCQUdDOzs7Ozs7UUFGQSw0Q0FBa0I7Ozs7O1FBQ2xCLGdEQUE4Qjs7Ozs7Ozs7SUFRL0IscUJBQXNEOztBQUN2RCxDQUFDLEVBaEZnQixTQUFTLEtBQVQsU0FBUyxRQWdGekIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlIENvcHlyaWdodCAoYykgMjAwMy0yMDE5LCBDS1NvdXJjZSAtIEZyZWRlcmljbyBLbmFiYmVuLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogRm9yIGxpY2Vuc2luZywgc2VlIExJQ0VOU0UubWQuXG4gKi9cblxuLyoqXG4gKiBCYXNpYyB0eXBpbmdzIGZvciB0aGUgQ0tFZGl0b3I1IGVsZW1lbnRzLlxuICovXG5leHBvcnQgbmFtZXNwYWNlIENLRWRpdG9yNSB7XG5cblx0LyoqXG5cdCAqIFRoZSBDS0VkaXRvcjUgZWRpdG9yIGNvbnN0cnVjdG9yLlxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBFZGl0b3JDb25zdHJ1Y3RvciB7XG5cdFx0Y3JlYXRlKCBzb3VyY2VFbGVtZW50T3JEYXRhOiBIVE1MRWxlbWVudCB8IHN0cmluZywgY29uZmlnPzogQ29uZmlnICk6IFByb21pc2U8RWRpdG9yPjtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgQ0tFZGl0b3I1IGVkaXRvciBjb25maWcuXG5cdCAqL1xuXHRleHBvcnQgaW50ZXJmYWNlIENvbmZpZyB7XG5cdFx0WyBrZXk6IHN0cmluZyBdOiBhbnk7XG5cdH1cblxuXHQvKipcblx0ICogVGhlIGV2ZW50IG9iamVjdCBwYXNzZWQgdG8gQ0tFZGl0b3I1IGV2ZW50IGNhbGxiYWNrcy5cblx0ICpcblx0ICogU2VlIGh0dHBzOi8vY2tlZGl0b3IuY29tL2RvY3MvY2tlZGl0b3I1L2xhdGVzdC9hcGkvbW9kdWxlX3V0aWxzX2V2ZW50aW5mby1FdmVudEluZm8uaHRtbFxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBFdmVudEluZm88RXZlbnROYW1lIGV4dGVuZHMgc3RyaW5nPiB7XG5cdFx0cmVhZG9ubHkgbmFtZTogRXZlbnROYW1lO1xuXHRcdHJlYWRvbmx5IHBhdGg6IGFueVtdO1xuXHRcdHJlYWRvbmx5IHNvdXJjZTogYW55O1xuXHRcdHJldHVybj86IGFueTtcblxuXHRcdG9mZigpOiB2b2lkO1xuXHRcdHN0b3AoKTogdm9pZDtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgYmFzZSBFZGl0b3IgY2xhc3MuXG5cdCAqXG5cdCAqIFNlZSBodHRwczovL2NrZWRpdG9yLmNvbS9kb2NzL2NrZWRpdG9yNS9sYXRlc3QvYXBpL21vZHVsZV9jb3JlX2VkaXRvcl9lZGl0b3ItRWRpdG9yLmh0bWxcblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgQmFzZUVkaXRvciB7XG5cdFx0cmVhZG9ubHkgY29tbWFuZHM6IGFueTtcblx0XHRyZWFkb25seSBjb25maWc6IGFueTtcblx0XHRyZWFkb25seSBjb252ZXJzaW9uOiBhbnk7XG5cdFx0cmVhZG9ubHkgZGF0YTogYW55O1xuXHRcdHJlYWRvbmx5IGVkaXRpbmc6IGFueTtcblx0XHRyZWFkb25seSBrZXlzdHJva2VzOiBhbnk7XG5cdFx0cmVhZG9ubHkgbG9jYWxlOiBhbnk7XG5cdFx0cmVhZG9ubHkgbW9kZWw6IGFueTtcblx0XHRyZWFkb25seSBwbHVnaW5zOiBhbnk7XG5cdFx0cmVhZG9ubHkgc3RhdGU6ICdpbml0aWFsaXppbmcnIHwgJ3JlYWR5JyB8ICdkZXN0cm95ZWQnO1xuXG5cdFx0aXNSZWFkT25seTogYm9vbGVhbjtcblxuXHRcdGRlbGVnYXRlKCBldmVudHM6IHN0cmluZ1tdICk6IGFueTtcblx0XHRkZXN0cm95KCk6IFByb21pc2U8dm9pZD47XG5cdFx0ZXhlY3V0ZSggY29tbWFuZE5hbWU6IHN0cmluZywgLi4ucGFyYW1zOiBhbnlbXSApOiBhbnk7XG5cdFx0ZmlyZSggZXZlbnROYW1lOiBzdHJpbmcsIGFyZ3M/OiBhbnkgKTogYW55O1xuXHRcdGxpc3RlblRvKCBlbWl0dGVyOiBhbnksIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24sIG9wdGlvbnM/OiBhbnkgKTogdm9pZDtcblx0XHRvZmYoIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24gKTogdm9pZDtcblx0XHRvbiggZXZlbnROYW1lOiBzdHJpbmcsIGNhbGxiYWNrOiBGdW5jdGlvbiwgb3B0aW9ucz86IGFueSApOiB2b2lkO1xuXHRcdG9uY2UoIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24sIG9wdGlvbnM/OiBhbnkgKTogdm9pZDtcblx0XHRzdG9wTGlzdGVuaW5nKCBlbWl0dGVyOiBhbnksIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24gKTogdm9pZDtcblx0XHR0KCAuLi5hcmdzOiBhbnlbXSApOiB2b2lkO1xuXG5cdFx0WyBwcm9wZXJ0eTogc3RyaW5nIF06IGFueTtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgQ0tFZGl0b3I1IERhdGFBcGkgaW50ZXJmYWNlLlxuXHQgKlxuXHQgKiBTZWUgaHR0cHM6Ly9ja2VkaXRvci5jb20vZG9jcy9ja2VkaXRvcjUvbGF0ZXN0L2FwaS9tb2R1bGVfY29yZV9lZGl0b3JfdXRpbHNfZGF0YWFwaW1peGluLURhdGFBcGkuaHRtbC5cblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRGF0YUFwaSB7XG5cdFx0Z2V0RGF0YSgpOiBzdHJpbmc7XG5cdFx0c2V0RGF0YSggZGF0YTogc3RyaW5nICk6IHZvaWQ7XG5cdH1cblxuXHQvKipcblx0ICogQSBDS0VkaXRvcjUgZWRpdG9yIHRoYXQgaW1wbGVtZW50cyB0aGVcblx0ICogW0RhdGFBcGkgaW50ZXJmYWNlXShodHRwczovL2NrZWRpdG9yLmNvbS9kb2NzL2NrZWRpdG9yNS9sYXRlc3QvYXBpL21vZHVsZV9jb3JlX2VkaXRvcl91dGlsc19kYXRhYXBpbWl4aW4tRGF0YUFwaS5odG1sKS5cblx0ICogRS5nLiB0aGUgYENsYXNzaWNFZGl0b3JgLCBgSW5saW5lRWRpdG9yYCwgZXRjLlxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBFZGl0b3IgZXh0ZW5kcyBCYXNlRWRpdG9yLCBEYXRhQXBpIHt9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJja2VkaXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVFBLE1BQU0sS0FBVyxTQUFTLENBb0d6QjtBQXBHRCxXQUFpQixTQUFTOzs7OztJQUt6QixnQ0FFQzs7Ozs7Ozs7UUFEQSxnRkFBc0Y7Ozs7OztJQU12RixxQkFFQzs7Ozs7Ozs7O0lBT0Qsd0JBUUM7Ozs7UUFQQSx5QkFBeUI7O1FBQ3pCLHlCQUFxQjs7UUFDckIsMkJBQXFCOztRQUNyQiwyQkFBYTs7OztRQUViLDBDQUFZOzs7O1FBQ1osMkNBQWE7Ozs7Ozs7O0lBUWQseUJBMEJDOzs7O1FBekJBLDhCQUF1Qjs7UUFDdkIsNEJBQXFCOztRQUNyQixnQ0FBeUI7O1FBQ3pCLDBCQUFtQjs7UUFDbkIsNkJBQXNCOztRQUN0QixnQ0FBeUI7O1FBQ3pCLDRCQUFxQjs7UUFDckIsMkJBQW9COztRQUNwQiw2QkFBc0I7O1FBQ3RCLDJCQUF1RDs7UUFFdkQsZ0NBQW9COzs7Ozs7UUFFcEIsc0RBQWtDOzs7O1FBQ2xDLCtDQUF5Qjs7Ozs7O1FBQ3pCLGtFQUFzRDs7Ozs7O1FBQ3RELDJEQUEyQzs7Ozs7Ozs7UUFDM0MscUZBQXFGOzs7Ozs7UUFDckYsOERBQW1EOzs7Ozs7O1FBQ25ELHNFQUFpRTs7Ozs7OztRQUNqRSx3RUFBbUU7Ozs7Ozs7UUFDbkUsaUZBQTJFOzs7OztRQUMzRSw2Q0FBMEI7Ozs7Ozs7O0lBVTNCLHNCQUdDOzs7Ozs7UUFGQSw0Q0FBa0I7Ozs7O1FBQ2xCLGdEQUE4Qjs7Ozs7Ozs7SUFRL0IscUJBQXNEOzs7OztJQUV0RCw4QkFNQzs7OztRQUxBLGtDQUFhOzs7OztRQUNiLHFEQUFpQzs7Ozs7UUFDakMsd0RBQWtEOzs7OztRQUNsRCwwREFBa0M7Ozs7Ozs7UUFDbEMsc0ZBQTRGOzs7OztJQUc3Riw2QkFFQzs7OztRQURBLGdDQUFlOzs7Ozs7SUFHaEIsdUJBTUM7Ozs7Ozs7UUFMQSx1REFBOEQ7Ozs7O1FBQzlELDZEQUFnRTs7Ozs7O1FBQ2hFLHVEQUE2RDs7OztRQUM3RCw2Q0FBeUI7Ozs7O1FBQ3pCLGdEQUF3Qzs7QUFFMUMsQ0FBQyxFQXBHZ0IsU0FBUyxLQUFULFNBQVMsUUFvR3pCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZSBDb3B5cmlnaHQgKGMpIDIwMDMtMjAyMCwgQ0tTb3VyY2UgLSBGcmVkZXJpY28gS25hYmJlbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIEZvciBsaWNlbnNpbmcsIHNlZSBMSUNFTlNFLm1kLlxuICovXG5cbi8qKlxuICogQmFzaWMgdHlwaW5ncyBmb3IgdGhlIENLRWRpdG9yNSBlbGVtZW50cy5cbiAqL1xuZXhwb3J0IG5hbWVzcGFjZSBDS0VkaXRvcjUge1xuXG5cdC8qKlxuXHQgKiBUaGUgQ0tFZGl0b3I1IGVkaXRvciBjb25zdHJ1Y3Rvci5cblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yQ29uc3RydWN0b3Ige1xuXHRcdGNyZWF0ZSggc291cmNlRWxlbWVudE9yRGF0YTogSFRNTEVsZW1lbnQgfCBzdHJpbmcsIGNvbmZpZz86IENvbmZpZyApOiBQcm9taXNlPEVkaXRvcj47XG5cdH1cblxuXHQvKipcblx0ICogVGhlIENLRWRpdG9yNSBlZGl0b3IgY29uZmlnLlxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuXHRcdFsga2V5OiBzdHJpbmcgXTogYW55O1xuXHR9XG5cblx0LyoqXG5cdCAqIFRoZSBldmVudCBvYmplY3QgcGFzc2VkIHRvIENLRWRpdG9yNSBldmVudCBjYWxsYmFja3MuXG5cdCAqXG5cdCAqIFNlZSBodHRwczovL2NrZWRpdG9yLmNvbS9kb2NzL2NrZWRpdG9yNS9sYXRlc3QvYXBpL21vZHVsZV91dGlsc19ldmVudGluZm8tRXZlbnRJbmZvLmh0bWxcblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRXZlbnRJbmZvPEV2ZW50TmFtZSBleHRlbmRzIHN0cmluZz4ge1xuXHRcdHJlYWRvbmx5IG5hbWU6IEV2ZW50TmFtZTtcblx0XHRyZWFkb25seSBwYXRoOiBhbnlbXTtcblx0XHRyZWFkb25seSBzb3VyY2U6IGFueTtcblx0XHRyZXR1cm4/OiBhbnk7XG5cblx0XHRvZmYoKTogdm9pZDtcblx0XHRzdG9wKCk6IHZvaWQ7XG5cdH1cblxuXHQvKipcblx0ICogVGhlIGJhc2UgRWRpdG9yIGNsYXNzLlxuXHQgKlxuXHQgKiBTZWUgaHR0cHM6Ly9ja2VkaXRvci5jb20vZG9jcy9ja2VkaXRvcjUvbGF0ZXN0L2FwaS9tb2R1bGVfY29yZV9lZGl0b3JfZWRpdG9yLUVkaXRvci5odG1sXG5cdCAqL1xuXHRleHBvcnQgaW50ZXJmYWNlIEJhc2VFZGl0b3Ige1xuXHRcdHJlYWRvbmx5IGNvbW1hbmRzOiBhbnk7XG5cdFx0cmVhZG9ubHkgY29uZmlnOiBhbnk7XG5cdFx0cmVhZG9ubHkgY29udmVyc2lvbjogYW55O1xuXHRcdHJlYWRvbmx5IGRhdGE6IGFueTtcblx0XHRyZWFkb25seSBlZGl0aW5nOiBhbnk7XG5cdFx0cmVhZG9ubHkga2V5c3Ryb2tlczogYW55O1xuXHRcdHJlYWRvbmx5IGxvY2FsZTogYW55O1xuXHRcdHJlYWRvbmx5IG1vZGVsOiBhbnk7XG5cdFx0cmVhZG9ubHkgcGx1Z2luczogYW55O1xuXHRcdHJlYWRvbmx5IHN0YXRlOiAnaW5pdGlhbGl6aW5nJyB8ICdyZWFkeScgfCAnZGVzdHJveWVkJztcblxuXHRcdGlzUmVhZE9ubHk6IGJvb2xlYW47XG5cblx0XHRkZWxlZ2F0ZSggZXZlbnRzOiBzdHJpbmdbXSApOiBhbnk7XG5cdFx0ZGVzdHJveSgpOiBQcm9taXNlPHZvaWQ+O1xuXHRcdGV4ZWN1dGUoIGNvbW1hbmROYW1lOiBzdHJpbmcsIC4uLnBhcmFtczogYW55W10gKTogYW55O1xuXHRcdGZpcmUoIGV2ZW50TmFtZTogc3RyaW5nLCBhcmdzPzogYW55ICk6IGFueTtcblx0XHRsaXN0ZW5UbyggZW1pdHRlcjogYW55LCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uLCBvcHRpb25zPzogYW55ICk6IHZvaWQ7XG5cdFx0b2ZmKCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uICk6IHZvaWQ7XG5cdFx0b24oIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24sIG9wdGlvbnM/OiBhbnkgKTogdm9pZDtcblx0XHRvbmNlKCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uLCBvcHRpb25zPzogYW55ICk6IHZvaWQ7XG5cdFx0c3RvcExpc3RlbmluZyggZW1pdHRlcjogYW55LCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uICk6IHZvaWQ7XG5cdFx0dCggLi4uYXJnczogYW55W10gKTogdm9pZDtcblxuXHRcdFsgcHJvcGVydHk6IHN0cmluZyBdOiBhbnk7XG5cdH1cblxuXHQvKipcblx0ICogVGhlIENLRWRpdG9yNSBEYXRhQXBpIGludGVyZmFjZS5cblx0ICpcblx0ICogU2VlIGh0dHBzOi8vY2tlZGl0b3IuY29tL2RvY3MvY2tlZGl0b3I1L2xhdGVzdC9hcGkvbW9kdWxlX2NvcmVfZWRpdG9yX3V0aWxzX2RhdGFhcGltaXhpbi1EYXRhQXBpLmh0bWwuXG5cdCAqL1xuXHRleHBvcnQgaW50ZXJmYWNlIERhdGFBcGkge1xuXHRcdGdldERhdGEoKTogc3RyaW5nO1xuXHRcdHNldERhdGEoIGRhdGE6IHN0cmluZyApOiB2b2lkO1xuXHR9XG5cblx0LyoqXG5cdCAqIEEgQ0tFZGl0b3I1IGVkaXRvciB0aGF0IGltcGxlbWVudHMgdGhlXG5cdCAqIFtEYXRhQXBpIGludGVyZmFjZV0oaHR0cHM6Ly9ja2VkaXRvci5jb20vZG9jcy9ja2VkaXRvcjUvbGF0ZXN0L2FwaS9tb2R1bGVfY29yZV9lZGl0b3JfdXRpbHNfZGF0YWFwaW1peGluLURhdGFBcGkuaHRtbCkuXG5cdCAqIEUuZy4gdGhlIGBDbGFzc2ljRWRpdG9yYCwgYElubGluZUVkaXRvcmAsIGV0Yy5cblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yIGV4dGVuZHMgQmFzZUVkaXRvciwgRGF0YUFwaSB7fVxuXG5cdGV4cG9ydCBpbnRlcmZhY2UgQ29udGV4dFdhdGNoZG9nIGV4dGVuZHMgV2F0Y2hkb2c8YW55Pntcblx0XHRjb250ZXh0OiBhbnk7XG5cdFx0YWRkKCBpdGVtczogYW55ICk6IFByb21pc2U8dm9pZD47XG5cdFx0cmVtb3ZlKCBpdGVtczogc3RyaW5nIHwgc3RyaW5nW10gKTogUHJvbWlzZTx2b2lkPjtcblx0XHRnZXRJdGVtKCBpdGVtSWQ6IHN0cmluZyApOiBFZGl0b3I7XG5cdFx0YWRkSXRlbVdhdGNoZG9nKCBpdGVtSWQ6IHN0cmluZywgaXRlbVR5cGU6IHN0cmluZywgd2F0Y2hkb2c6IFdhdGNoZG9nPGFueT4gKTogUHJvbWlzZTx2b2lkPjtcblx0fVxuXG5cdGV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yV2F0Y2hkb2cgZXh0ZW5kcyBXYXRjaGRvZzxFZGl0b3I+IHtcblx0XHRlZGl0b3I6IEVkaXRvcjtcblx0fVxuXG5cdGV4cG9ydCBpbnRlcmZhY2UgV2F0Y2hkb2c8VD4ge1xuXHRcdHNldENyZWF0b3IoIGNyZWF0b3I6ICggLi4uYXJnczogYW55W10gKSA9PiBQcm9taXNlPFQ+ICk6IHZvaWQ7XG5cdFx0c2V0RGVzdHJ1Y3RvciggZGVzdHJ1Y3RvcjogKCBpdGVtOiBUICkgPT4gUHJvbWlzZTx2b2lkPiApOiB2b2lkO1xuXHRcdG9uKCBldmVudDogc3RyaW5nLCBjYWxsYmFjazogKCAuLi5hcmdzOiBhbnkgKSA9PiBhbnkgKTogdm9pZDtcblx0XHRkZXN0cm95KCk6IFByb21pc2U8dm9pZD47XG5cdFx0Y3JlYXRlKCAuLi5hcmdzOiBhbnlbXSApOiBQcm9taXNlPHZvaWQ+O1xuXHR9XG59XG4iXX0= |
@@ -6,3 +6,3 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -23,2 +23,2 @@ */ | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGNrZWRpdG9yL2NrZWRpdG9yNS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiY2tlZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBS0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBT3pELE1BQU0sT0FBTyxjQUFjOzs7WUFMMUIsUUFBUSxTQUFFO2dCQUNWLE9BQU8sRUFBRSxDQUFFLFdBQVcsRUFBRSxZQUFZLENBQUU7Z0JBQ3RDLFlBQVksRUFBRSxDQUFFLGlCQUFpQixDQUFFO2dCQUNuQyxPQUFPLEVBQUUsQ0FBRSxpQkFBaUIsQ0FBRTthQUM5QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2UgQ29weXJpZ2h0IChjKSAyMDAzLTIwMTksIENLU291cmNlIC0gRnJlZGVyaWNvIEtuYWJiZW4uIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBGb3IgbGljZW5zaW5nLCBzZWUgTElDRU5TRS5tZC5cbiAqL1xuXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ0tFZGl0b3JDb21wb25lbnQgfSBmcm9tICcuL2NrZWRpdG9yLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSgge1xuXHRpbXBvcnRzOiBbIEZvcm1zTW9kdWxlLCBDb21tb25Nb2R1bGUgXSxcblx0ZGVjbGFyYXRpb25zOiBbIENLRWRpdG9yQ29tcG9uZW50IF0sXG5cdGV4cG9ydHM6IFsgQ0tFZGl0b3JDb21wb25lbnQgXVxufSApXG5leHBvcnQgY2xhc3MgQ0tFZGl0b3JNb2R1bGUge31cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGNrZWRpdG9yL2NrZWRpdG9yNS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiY2tlZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBS0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBT3pELE1BQU0sT0FBTyxjQUFjOzs7WUFMMUIsUUFBUSxTQUFFO2dCQUNWLE9BQU8sRUFBRSxDQUFFLFdBQVcsRUFBRSxZQUFZLENBQUU7Z0JBQ3RDLFlBQVksRUFBRSxDQUFFLGlCQUFpQixDQUFFO2dCQUNuQyxPQUFPLEVBQUUsQ0FBRSxpQkFBaUIsQ0FBRTthQUM5QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2UgQ29weXJpZ2h0IChjKSAyMDAzLTIwMjAsIENLU291cmNlIC0gRnJlZGVyaWNvIEtuYWJiZW4uIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBGb3IgbGljZW5zaW5nLCBzZWUgTElDRU5TRS5tZC5cbiAqL1xuXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ0tFZGl0b3JDb21wb25lbnQgfSBmcm9tICcuL2NrZWRpdG9yLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSgge1xuXHRpbXBvcnRzOiBbIEZvcm1zTW9kdWxlLCBDb21tb25Nb2R1bGUgXSxcblx0ZGVjbGFyYXRpb25zOiBbIENLRWRpdG9yQ29tcG9uZW50IF0sXG5cdGV4cG9ydHM6IFsgQ0tFZGl0b3JDb21wb25lbnQgXVxufSApXG5leHBvcnQgY2xhc3MgQ0tFZGl0b3JNb2R1bGUge31cbiJdfQ== |
@@ -6,3 +6,3 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -13,2 +13,2 @@ */ | ||
export { CKEditorModule } from './ckeditor.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUtBLGVBQWMsWUFBWSxDQUFDO0FBQzNCLGtDQUFjLHNCQUFzQixDQUFDO0FBQ3JDLCtCQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZSBDb3B5cmlnaHQgKGMpIDIwMDMtMjAxOSwgQ0tTb3VyY2UgLSBGcmVkZXJpY28gS25hYmJlbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIEZvciBsaWNlbnNpbmcsIHNlZSBMSUNFTlNFLm1kLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vY2tlZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5tb2R1bGUnO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUtBLGVBQWMsWUFBWSxDQUFDO0FBQzNCLGtDQUFjLHNCQUFzQixDQUFDO0FBQ3JDLCtCQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZSBDb3B5cmlnaHQgKGMpIDIwMDMtMjAyMCwgQ0tTb3VyY2UgLSBGcmVkZXJpY28gS25hYmJlbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIEZvciBsaWNlbnNpbmcsIHNlZSBMSUNFTlNFLm1kLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vY2tlZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5tb2R1bGUnO1xuIl19 |
@@ -7,6 +7,8 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
*/ | ||
import { Component, Input, Output, NgZone, EventEmitter, forwardRef, ElementRef } from '@angular/core'; | ||
import EditorWatchdog from '@ckeditor/ckeditor5-watchdog/src/editorwatchdog'; | ||
import uid from './uid'; | ||
import { NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
@@ -57,5 +59,5 @@ var CKEditorComponent = /** @class */ (function () { | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
*/ | ||
this.editorInstance = null; | ||
this.error = new EventEmitter(); | ||
/** | ||
@@ -70,2 +72,3 @@ * If the component is read–only before the editor instance is created, it remembers that state, | ||
this.isEditorSettingData = false; | ||
this.id = uid(); | ||
this.ngZone = ngZone; | ||
@@ -102,2 +105,22 @@ this.elementRef = elementRef; | ||
}); | ||
Object.defineProperty(CKEditorComponent.prototype, "editorInstance", { | ||
/** | ||
* The instance of the editor created by this component. | ||
*/ | ||
get: /** | ||
* The instance of the editor created by this component. | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (this.editorWatchdog) { | ||
return this.editorWatchdog.editor; | ||
} | ||
if (this.watchdog) { | ||
return this.watchdog.getItem(this.id); | ||
} | ||
return null; | ||
}, | ||
enumerable: true, | ||
configurable: true | ||
}); | ||
// Implementing the AfterViewInit interface. | ||
@@ -114,9 +137,3 @@ // Implementing the AfterViewInit interface. | ||
function () { | ||
var _this = this; | ||
this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.createEditor(); | ||
})); | ||
this.attachToWatchdog(); | ||
}; | ||
@@ -134,6 +151,22 @@ // Implementing the OnDestroy interface. | ||
function () { | ||
if (this.editorInstance) { | ||
this.editorInstance.destroy(); | ||
this.editorInstance = null; | ||
} | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
return tslib_1.__generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!this.watchdog) return [3 /*break*/, 2]; | ||
return [4 /*yield*/, this.watchdog.remove(this.id)]; | ||
case 1: | ||
_a.sent(); | ||
return [3 /*break*/, 4]; | ||
case 2: | ||
if (!(this.editorWatchdog && this.editorWatchdog.editor)) return [3 /*break*/, 4]; | ||
return [4 /*yield*/, this.editorWatchdog.destroy()]; | ||
case 3: | ||
_a.sent(); | ||
this.editorWatchdog = undefined; | ||
_a.label = 4; | ||
case 4: return [2 /*return*/]; | ||
} | ||
}); | ||
}); | ||
}; | ||
@@ -219,10 +252,8 @@ // Implementing the ControlValueAccessor interface (only when binding to ngModel). | ||
function (isDisabled) { | ||
// If already initialized | ||
// If already initialized. | ||
if (this.editorInstance) { | ||
this.editorInstance.isReadOnly = isDisabled; | ||
} | ||
// If not, wait for it to be ready; store the state. | ||
else { | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
// Store the state anyway to use it once the editor is created. | ||
this.initialIsDisabled = isDisabled; | ||
}; | ||
@@ -241,3 +272,3 @@ /** | ||
*/ | ||
CKEditorComponent.prototype.createEditor = /** | ||
CKEditorComponent.prototype.attachToWatchdog = /** | ||
* Creates the editor instance, sets initial editor data, then integrates | ||
@@ -252,21 +283,60 @@ * the editor with the Angular component. This method does not use the `editor.setData()` | ||
/** @type {?} */ | ||
var element = document.createElement(this.tagName); | ||
this.editorElement = element; | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
var creator = (/** | ||
* @param {?} element | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
function (element, config) { return tslib_1.__awaiter(_this, void 0, void 0, function () { | ||
var _this = this; | ||
return tslib_1.__generator(this, function (_a) { | ||
return [2 /*return*/, this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
function () { return tslib_1.__awaiter(_this, void 0, void 0, function () { | ||
var editor; | ||
var _this = this; | ||
return tslib_1.__generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
this.elementRef.nativeElement.appendChild(element); | ||
return [4 /*yield*/, (/** @type {?} */ (this.editor)).create(element, config)]; | ||
case 1: | ||
editor = _a.sent(); | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
this.ngZone.run((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.ready.emit(editor); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
return [2 /*return*/, editor]; | ||
} | ||
}); | ||
}); }))]; | ||
}); | ||
}); }); | ||
/** @type {?} */ | ||
var config = tslib_1.__assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
this.elementRef.nativeElement.appendChild(element); | ||
return (/** @type {?} */ (this.editor)).create(element, config) | ||
.then((/** | ||
var destructor = (/** | ||
* @param {?} editor | ||
* @return {?} | ||
*/ | ||
function (editor) { | ||
_this.editorInstance = editor; | ||
if (_this.initialIsDisabled) { | ||
editor.isReadOnly = _this.initialIsDisabled; | ||
} | ||
function (editor) { return tslib_1.__awaiter(_this, void 0, void 0, function () { | ||
return tslib_1.__generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: return [4 /*yield*/, editor.destroy()]; | ||
case 1: | ||
_a.sent(); | ||
this.elementRef.nativeElement.removeChild((/** @type {?} */ (this.editorElement))); | ||
return [2 /*return*/]; | ||
} | ||
}); | ||
}); }); | ||
/** @type {?} */ | ||
var emitError = (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.ngZone.run((/** | ||
@@ -276,15 +346,60 @@ * @return {?} | ||
function () { | ||
_this.ready.emit(editor); | ||
_this.error.emit(); | ||
})); | ||
_this.setUpEditorEvents(editor); | ||
})) | ||
.catch((/** | ||
* @param {?} err | ||
* @return {?} | ||
*/ | ||
function (err) { | ||
console.error(err.stack); | ||
})); | ||
}); | ||
/** @type {?} */ | ||
var element = document.createElement(this.tagName); | ||
/** @type {?} */ | ||
var config = this.getConfig(); | ||
this.editorElement = element; | ||
// Based on the presence of the watchdog decide how to initialize the editor. | ||
if (this.watchdog) { | ||
// When the context watchdog is passed add the new item to it based on the passed configuration. | ||
this.watchdog.add({ | ||
id: this.id, | ||
type: 'editor', | ||
creator: creator, | ||
destructor: destructor, | ||
sourceElementOrData: element, | ||
config: config | ||
}); | ||
this.watchdog.on('itemError', (/** | ||
* @param {?} _ | ||
* @param {?} __1 | ||
* @return {?} | ||
*/ | ||
function (_, _a) { | ||
var itemId = _a.itemId; | ||
if (itemId === _this.id) { | ||
emitError(); | ||
} | ||
})); | ||
} | ||
else { | ||
// In the other case create the watchdog by hand to keep the editor running. | ||
/** @type {?} */ | ||
var editorWatchdog = new EditorWatchdog(this.editor); | ||
editorWatchdog.setCreator(creator); | ||
editorWatchdog.setDestructor(destructor); | ||
editorWatchdog.on('error', emitError); | ||
this.editorWatchdog = editorWatchdog; | ||
this.editorWatchdog.create(element, config); | ||
} | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
CKEditorComponent.prototype.getConfig = /** | ||
* @private | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
return tslib_1.__assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
}; | ||
/** | ||
* Integrates the editor with the component by attaching related event listeners. | ||
@@ -383,2 +498,3 @@ */ | ||
tagName: [{ type: Input }], | ||
watchdog: [{ type: Input }], | ||
disabled: [{ type: Input }], | ||
@@ -388,3 +504,4 @@ ready: [{ type: Output }], | ||
blur: [{ type: Output }], | ||
focus: [{ type: Output }] | ||
focus: [{ type: Output }], | ||
error: [{ type: Output }] | ||
}; | ||
@@ -428,2 +545,7 @@ return CKEditorComponent; | ||
/** | ||
* The context watchdog. | ||
* @type {?} | ||
*/ | ||
CKEditorComponent.prototype.watchdog; | ||
/** | ||
* Fires when the editor is ready. It corresponds with the `editor#ready` | ||
@@ -457,7 +579,14 @@ * https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#event-ready | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
* @type {?} | ||
*/ | ||
CKEditorComponent.prototype.editorInstance; | ||
CKEditorComponent.prototype.error; | ||
/** | ||
* The editor watchdog. It is created when the context watchdog is not passed to the component. | ||
* It keeps the editor running. | ||
* @type {?} | ||
* @private | ||
*/ | ||
CKEditorComponent.prototype.editorWatchdog; | ||
/** | ||
* If the component is read–only before the editor instance is created, it remembers that state, | ||
@@ -506,2 +635,7 @@ * so the editor can become read–only once it is ready. | ||
CKEditorComponent.prototype.isEditorSettingData; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
CKEditorComponent.prototype.id; | ||
} | ||
@@ -538,2 +672,2 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"ng://@ckeditor/ckeditor5-angular/","sources":["ckeditor.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved.\n * For licensing, see LICENSE.md.\n */\n\nimport {\n\tComponent,\n\tInput,\n\tOutput,\n\tNgZone,\n\tEventEmitter,\n\tforwardRef,\n\tAfterViewInit, OnDestroy,\n\tElementRef\n} from '@angular/core';\n\nimport {\n\tControlValueAccessor,\n\tNG_VALUE_ACCESSOR\n} from '@angular/forms';\n\nimport { CKEditor5 } from './ckeditor';\n\n@Component( {\n\tselector: 'ckeditor',\n\ttemplate: '<ng-template></ng-template>',\n\n\t// Integration with @angular/forms.\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\t\tuseExisting: forwardRef( () => CKEditorComponent ),\n\t\t\tmulti: true,\n\t\t}\n\t]\n} )\nexport class CKEditorComponent implements AfterViewInit, OnDestroy, ControlValueAccessor {\n\t/**\n\t * The reference to the DOM element created by the component.\n\t */\n\tprivate elementRef!: ElementRef<HTMLElement>;\n\n\t/**\n\t * The constructor of the editor to be used for the instance of the component.\n\t * It can be e.g. the `ClassicEditorBuild`, `InlineEditorBuild` or some custom editor.\n\t */\n\t@Input() public editor?: CKEditor5.EditorConstructor;\n\n\t/**\n\t * The configuration of the editor.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editorconfig-EditorConfig.html\n\t * to learn more.\n\t */\n\t@Input() public config: CKEditor5.Config = {};\n\n\t/**\n\t * The initial data of the editor. Useful when not using the ngModel.\n\t * See https://angular.io/api/forms/NgModel to learn more.\n\t */\n\t@Input() public data = '';\n\n\t/**\n\t * Tag name of the editor component.\n\t *\n\t * The default tag is 'div'.\n\t */\n\t@Input() public tagName = 'div';\n\n\t/**\n\t * When set `true`, the editor becomes read-only.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#member-isReadOnly\n\t * to learn more.\n\t */\n\t@Input() public set disabled( isDisabled: boolean ) {\n\t\tthis.setDisabledState( isDisabled );\n\t}\n\n\tpublic get disabled() {\n\t\tif ( this.editorInstance ) {\n\t\t\treturn this.editorInstance.isReadOnly;\n\t\t}\n\n\t\treturn this.initialIsDisabled;\n\t}\n\n\t/**\n\t * Fires when the editor is ready. It corresponds with the `editor#ready`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#event-ready\n\t * event.\n\t */\n\t@Output() public ready = new EventEmitter<CKEditor5.Editor>();\n\n\t/**\n\t * Fires when the content of the editor has changed. It corresponds with the `editor.model.document#change`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_model_document-Document.html#event-change\n\t * event.\n\t */\n\t@Output() public change: EventEmitter<ChangeEvent> = new EventEmitter<ChangeEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is blurred. It corresponds with the `editor.editing.view.document#blur`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:blur\n\t * event.\n\t */\n\t@Output() public blur: EventEmitter<BlurEvent> = new EventEmitter<BlurEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is focused. It corresponds with the `editor.editing.view.document#focus`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:focus\n\t * event.\n\t */\n\t@Output() public focus: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n\n\t/**\n\t * The instance of the editor created by this component.\n\t */\n\tpublic editorInstance: CKEditor5.Editor | null = null;\n\n\t/**\n\t * If the component is read–only before the editor instance is created, it remembers that state,\n\t * so the editor can become read–only once it is ready.\n\t */\n\tprivate initialIsDisabled = false;\n\n\t/**\n\t * An instance of https://angular.io/api/core/NgZone to allow the interaction with the editor\n\t * withing the Angular event loop.\n\t */\n\tprivate ngZone: NgZone;\n\n\t/**\n\t * A callback executed when the content of the editor changes. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnChange?: ( data: string ) => void;\n\n\t/**\n\t * A callback executed when the editor has been blurred. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnTouched?: () => void;\n\n\t/**\n\t * Reference to the source element used by the editor.\n\t */\n\tprivate editorElement?: HTMLElement;\n\n\t/**\n\t * A lock flag preventing from calling the `cvaOnChange()` during setting editor data.\n\t */\n\tprivate isEditorSettingData = false;\n\n\tpublic constructor( elementRef: ElementRef, ngZone: NgZone ) {\n\t\tthis.ngZone = ngZone;\n\t\tthis.elementRef = elementRef;\n\t}\n\n\t// Implementing the AfterViewInit interface.\n\tpublic ngAfterViewInit() {\n\t\tthis.ngZone.runOutsideAngular( () => {\n\t\t\tthis.createEditor();\n\t\t} );\n\t}\n\n\t// Implementing the OnDestroy interface.\n\tpublic ngOnDestroy() {\n\t\tif ( this.editorInstance ) {\n\t\t\tthis.editorInstance.destroy();\n\t\t\tthis.editorInstance = null;\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic writeValue( value: string | null ): void {\n\t\t// This method is called with the `null` value when the form resets.\n\t\t// A component's responsibility is to restore to the initial state.\n\t\tif ( value === null ) {\n\t\t\tvalue = '';\n\t\t}\n\n\t\t// If already initialized.\n\t\tif ( this.editorInstance ) {\n\t\t\t// The lock mechanism prevents from calling `cvaOnChange()` during changing\n\t\t\t// the editor state. See #139\n\t\t\tthis.isEditorSettingData = true;\n\t\t\tthis.editorInstance.setData( value );\n\t\t\tthis.isEditorSettingData = false;\n\t\t}\n\t\t// If not, wait for it to be ready; store the data.\n\t\telse {\n\t\t\tthis.data = value;\n\n\t\t\t// If the editor element is already available, then update its content.\n\t\t\t// If the ngModel is used then the editor element should be updated directly here.\n\t\t\tif ( this.editorElement ) {\n\t\t\t\tthis.editorElement.innerHTML = this.data;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnChange( callback: ( data: string ) => void ): void {\n\t\tthis.cvaOnChange = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnTouched( callback: () => void ): void {\n\t\tthis.cvaOnTouched = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic setDisabledState( isDisabled: boolean ): void {\n\t\t// If already initialized\n\t\tif ( this.editorInstance ) {\n\t\t\tthis.editorInstance.isReadOnly = isDisabled;\n\t\t}\n\t\t// If not, wait for it to be ready; store the state.\n\t\telse {\n\t\t\tthis.initialIsDisabled = isDisabled;\n\t\t}\n\t}\n\n\t/**\n\t * Creates the editor instance, sets initial editor data, then integrates\n\t * the editor with the Angular component. This method does not use the `editor.setData()`\n\t * because of the issue in the collaboration mode (#6).\n\t */\n\tprivate createEditor(): Promise<void> {\n\t\tconst element = document.createElement( this.tagName );\n\t\tthis.editorElement = element;\n\n\t\tif ( this.data && this.config.initialData ) {\n\t\t\tthrow new Error( 'Editor data should be provided either using `config.initialData` or `data` properties.' );\n\t\t}\n\n\t\t// Merge two possible ways of providing data into the `config.initialData` field.\n\t\tconst config = {\n\t\t\t...this.config,\n\t\t\tinitialData: this.config.initialData || this.data || ''\n\t\t};\n\n\t\tthis.elementRef.nativeElement.appendChild( element );\n\n\t\treturn this.editor!.create( element, config )\n\t\t\t.then( editor => {\n\t\t\t\tthis.editorInstance = editor;\n\n\t\t\t\tif ( this.initialIsDisabled ) {\n\t\t\t\t\teditor.isReadOnly = this.initialIsDisabled;\n\t\t\t\t}\n\n\t\t\t\tthis.ngZone.run( () => {\n\t\t\t\t\tthis.ready.emit( editor );\n\t\t\t\t} );\n\n\t\t\t\tthis.setUpEditorEvents( editor );\n\t\t\t} )\n\t\t\t.catch( ( err: Error ) => {\n\t\t\t\tconsole.error( err.stack );\n\t\t\t} );\n\t}\n\n\t/**\n\t * Integrates the editor with the component by attaching related event listeners.\n\t */\n\tprivate setUpEditorEvents( editor: CKEditor5.Editor ): void {\n\t\tconst modelDocument = editor.model.document;\n\t\tconst viewDocument = editor.editing.view.document;\n\n\t\tmodelDocument.on( 'change:data', ( evt: CKEditor5.EventInfo<'change:data'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnChange && !this.isEditorSettingData ) {\n\t\t\t\t\tconst data = editor.getData();\n\n\t\t\t\t\tthis.cvaOnChange( data );\n\t\t\t\t}\n\n\t\t\t\tthis.change.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'focus', ( evt: CKEditor5.EventInfo<'focus'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tthis.focus.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'blur', ( evt: CKEditor5.EventInfo<'blur'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnTouched ) {\n\t\t\t\t\tthis.cvaOnTouched();\n\t\t\t\t}\n\n\t\t\t\tthis.blur.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\t}\n}\n\nexport interface BlurEvent {\n\tevent: CKEditor5.EventInfo<'blur'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface FocusEvent {\n\tevent: CKEditor5.EventInfo<'focus'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface ChangeEvent {\n\tevent: CKEditor5.EventInfo<'change:data'>;\n\teditor: CKEditor5.Editor;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ckeditor.component.js","sourceRoot":"ng://@ckeditor/ckeditor5-angular/","sources":["ckeditor.component.ts"],"names":[],"mappings":";;;;;;;;;AAKA,OAAO,EACN,SAAS,EACT,KAAK,EACL,MAAM,EACN,MAAM,EACN,YAAY,EACZ,UAAU,EAEV,UAAU,EACV,MAAM,eAAe,CAAC;AAEvB,OAAO,cAAc,MAAM,iDAAiD,CAAC;AAE7E,OAAO,GAAG,MAAM,OAAO,CAAC;AAExB,OAAO,EAEN,iBAAiB,EACjB,MAAM,gBAAgB,CAAC;AAIxB;IAkKC,2BAAoB,UAAsB,EAAE,MAAc;;;;;;QAnI1C,WAAM,GAAqB,EAAE,CAAC;;;;;QAM9B,SAAI,GAAG,EAAE,CAAC;;;;;;QAOV,YAAO,GAAG,KAAK,CAAC;;;;;;QA6Bf,UAAK,GAAG,IAAI,YAAY,EAAoB,CAAC;;;;;;QAO7C,WAAM,GAA8B,IAAI,YAAY,EAAe,CAAC;;;;;;QAOpE,SAAI,GAA4B,IAAI,YAAY,EAAa,CAAC;;;;;;QAO9D,UAAK,GAA6B,IAAI,YAAY,EAAc,CAAC;;;;QAKjE,UAAK,GAAuB,IAAI,YAAY,EAAQ,CAAC;;;;;QA2B9D,sBAAiB,GAAG,KAAK,CAAC;;;;QAgC1B,wBAAmB,GAAG,KAAK,CAAC;QAE5B,OAAE,GAAG,GAAG,EAAE,CAAC;QAGlB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC9B,CAAC;IA7GD,sBAAoB,uCAAQ;;;;QAI5B;YACC,IAAK,IAAI,CAAC,cAAc,EAAG;gBAC1B,OAAO,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC;aACtC;YAED,OAAO,IAAI,CAAC,iBAAiB,CAAC;QAC/B,CAAC;QAfD;;;;WAIG;;;;;;;;QACH,UAA8B,UAAmB;YAChD,IAAI,CAAC,gBAAgB,CAAE,UAAU,CAAE,CAAC;QACrC,CAAC;;;OAAA;IA8CD,sBAAW,6CAAc;QAHzB;;WAEG;;;;;QACH;YACC,IAAK,IAAI,CAAC,cAAc,EAAG;gBAC1B,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;aAClC;YAED,IAAK,IAAI,CAAC,QAAQ,EAAG;gBACpB,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAE,IAAI,CAAC,EAAE,CAAE,CAAC;aACxC;YAED,OAAO,IAAI,CAAC;QACb,CAAC;;;OAAA;IAqDD,4CAA4C;;;;;IACrC,2CAAe;;;;;IAAtB;QACC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IACzB,CAAC;IAED,wCAAwC;;;;;IAC3B,uCAAW;;;;;IAAxB;;;;;6BACM,IAAI,CAAC,QAAQ,EAAb,wBAAa;wBACjB,qBAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAE,IAAI,CAAC,EAAE,CAAE,EAAA;;wBAArC,SAAqC,CAAC;;;6BAC3B,CAAA,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,CAAA,EAAjD,wBAAiD;wBAC5D,qBAAM,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,EAAA;;wBAAnC,SAAmC,CAAC;wBAEpC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;;;;;;KAEjC;IAED,kFAAkF;;;;;;IAC3E,sCAAU;;;;;;IAAjB,UAAmB,KAAoB;QACtC,oEAAoE;QACpE,mEAAmE;QACnE,IAAK,KAAK,KAAK,IAAI,EAAG;YACrB,KAAK,GAAG,EAAE,CAAC;SACX;QAED,0BAA0B;QAC1B,IAAK,IAAI,CAAC,cAAc,EAAG;YAC1B,2EAA2E;YAC3E,6BAA6B;YAC7B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;YAChC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAE,KAAK,CAAE,CAAC;YACrC,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;SACjC;QACD,mDAAmD;aAC9C;YACJ,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;YAElB,uEAAuE;YACvE,kFAAkF;YAClF,IAAK,IAAI,CAAC,aAAa,EAAG;gBACzB,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;aACzC;SACD;IACF,CAAC;IAED,kFAAkF;;;;;;IAC3E,4CAAgB;;;;;;IAAvB,UAAyB,QAAkC;QAC1D,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;IAC7B,CAAC;IAED,kFAAkF;;;;;;IAC3E,6CAAiB;;;;;;IAAxB,UAA0B,QAAoB;QAC7C,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;IAC9B,CAAC;IAED,kFAAkF;;;;;;IAC3E,4CAAgB;;;;;;IAAvB,UAAyB,UAAmB;QAC3C,0BAA0B;QAC1B,IAAK,IAAI,CAAC,cAAc,EAAG;YAC1B,IAAI,CAAC,cAAc,CAAC,UAAU,GAAG,UAAU,CAAC;SAC5C;QAED,+DAA+D;QAC/D,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC;IACrC,CAAC;IAED;;;;OAIG;;;;;;;;IACK,4CAAgB;;;;;;;IAAxB;QAAA,iBAmEC;;YAlEM,OAAO;;;;;QAAG,UAAQ,OAAoB,EAAE,MAAwB;;;gBACrE,sBAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;oBAAE;;;;;;oCACrC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAE,OAAO,CAAE,CAAC;oCAEtC,qBAAM,mBAAA,IAAI,CAAC,MAAM,EAAC,CAAC,MAAM,CAAE,OAAO,EAAE,MAAM,CAAE,EAAA;;oCAArD,MAAM,GAAG,SAA4C;oCAE3D,IAAK,IAAI,CAAC,iBAAiB,EAAG;wCAC7B,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC;qCAC3C;oCAED,IAAI,CAAC,MAAM,CAAC,GAAG;;;oCAAE;wCAChB,KAAI,CAAC,KAAK,CAAC,IAAI,CAAE,MAAM,CAAE,CAAC;oCAC3B,CAAC,EAAE,CAAC;oCAEJ,IAAI,CAAC,iBAAiB,CAAE,MAAM,CAAE,CAAC;oCAEjC,sBAAO,MAAM,EAAC;;;yBACd,EAAE,EAAC;;aACJ,CAAA;;YAEK,UAAU;;;;QAAG,UAAQ,MAAwB;;;4BAClD,qBAAM,MAAM,CAAC,OAAO,EAAE,EAAA;;wBAAtB,SAAsB,CAAC;wBAEvB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAE,mBAAA,IAAI,CAAC,aAAa,EAAC,CAAE,CAAC;;;;aACjE,CAAA;;YAEK,SAAS;;;QAAG;YACjB,KAAI,CAAC,MAAM,CAAC,GAAG;;;YAAE;gBAChB,KAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,CAAC,EAAE,CAAC;QACL,CAAC,CAAA;;YAEK,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAE,IAAI,CAAC,OAAO,CAAE;;YAChD,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE;QAE/B,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAE7B,6EAA6E;QAC7E,IAAK,IAAI,CAAC,QAAQ,EAAG;YACpB,gGAAgG;YAChG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAE;gBAClB,EAAE,EAAE,IAAI,CAAC,EAAE;gBACX,IAAI,EAAE,QAAQ;gBACd,OAAO,SAAA;gBACP,UAAU,YAAA;gBACV,mBAAmB,EAAE,OAAO;gBAC5B,MAAM,QAAA;aACN,CAAE,CAAC;YAEJ,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAE,WAAW;;;;;YAAE,UAAE,CAAC,EAAE,EAAU;oBAAR,kBAAM;gBAC3C,IAAK,MAAM,KAAK,KAAI,CAAC,EAAE,EAAG;oBACzB,SAAS,EAAE,CAAC;iBACZ;YACF,CAAC,EAAE,CAAC;SACJ;aAAM;;;gBAEA,cAAc,GAA6B,IAAI,cAAc,CAAE,IAAI,CAAC,MAAM,CAAE;YAElF,cAAc,CAAC,UAAU,CAAE,OAAO,CAAE,CAAC;YACrC,cAAc,CAAC,aAAa,CAAE,UAAU,CAAE,CAAC;YAC3C,cAAc,CAAC,EAAE,CAAE,OAAO,EAAE,SAAS,CAAE,CAAC;YAExC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;YAErC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAE,OAAO,EAAE,MAAM,CAAE,CAAC;SAC9C;IACF,CAAC;;;;;IAEO,qCAAS;;;;IAAjB;QACC,IAAK,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAG;YAC3C,MAAM,IAAI,KAAK,CAAE,wFAAwF,CAAE,CAAC;SAC5G;QAED,iFAAiF;QACjF,4BACI,IAAI,CAAC,MAAM,IACd,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,IAAI,EAAE,IACtD;IACH,CAAC;IAED;;OAEG;;;;;;;IACK,6CAAiB;;;;;;IAAzB,UAA2B,MAAwB;QAAnD,iBA+BC;;YA9BM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ;;YACrC,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ;QAEjD,aAAa,CAAC,EAAE,CAAE,aAAa;;;;QAAE,UAAE,GAAuC;YACzE,KAAI,CAAC,MAAM,CAAC,GAAG;;;YAAE;gBAChB,IAAK,KAAI,CAAC,WAAW,IAAI,CAAC,KAAI,CAAC,mBAAmB,EAAG;;wBAC9C,IAAI,GAAG,MAAM,CAAC,OAAO,EAAE;oBAE7B,KAAI,CAAC,WAAW,CAAE,IAAI,CAAE,CAAC;iBACzB;gBAED,KAAI,CAAC,MAAM,CAAC,IAAI,CAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,QAAA,EAAE,CAAE,CAAC;YAC5C,CAAC,EAAE,CAAC;QACL,CAAC,EAAE,CAAC;QAEJ,YAAY,CAAC,EAAE,CAAE,OAAO;;;;QAAE,UAAE,GAAiC;YAC5D,KAAI,CAAC,MAAM,CAAC,GAAG;;;YAAE;gBAChB,KAAI,CAAC,KAAK,CAAC,IAAI,CAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,QAAA,EAAE,CAAE,CAAC;YAC3C,CAAC,EAAE,CAAC;QACL,CAAC,EAAE,CAAC;QAEJ,YAAY,CAAC,EAAE,CAAE,MAAM;;;;QAAE,UAAE,GAAgC;YAC1D,KAAI,CAAC,MAAM,CAAC,GAAG;;;YAAE;gBAChB,IAAK,KAAI,CAAC,YAAY,EAAG;oBACxB,KAAI,CAAC,YAAY,EAAE,CAAC;iBACpB;gBAED,KAAI,CAAC,IAAI,CAAC,IAAI,CAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,QAAA,EAAE,CAAE,CAAC;YAC1C,CAAC,EAAE,CAAC;QACL,CAAC,EAAE,CAAC;IACL,CAAC;;gBAhWD,SAAS,SAAE;oBACX,QAAQ,EAAE,UAAU;oBACpB,QAAQ,EAAE,6BAA6B;;oBAGvC,SAAS,EAAE;wBACV;4BACC,OAAO,EAAE,iBAAiB;;4BAE1B,WAAW,EAAE,UAAU;;;4BAAE,cAAM,OAAA,iBAAiB,EAAjB,CAAiB,EAAE;4BAClD,KAAK,EAAE,IAAI;yBACX;qBACD;iBACD;;;;gBA3BA,UAAU;gBAJV,MAAM;;;yBA0CL,KAAK;yBAOL,KAAK;uBAML,KAAK;0BAOL,KAAK;2BAKL,KAAK;2BAOL,KAAK;wBAiBL,MAAM;yBAON,MAAM;uBAON,MAAM;wBAON,MAAM;wBAKN,MAAM;;IA8PR,wBAAC;CAAA,AAjWD,IAiWC;SAnVY,iBAAiB;;;;;;;IAI7B,uCAA6C;;;;;;IAM7C,mCAAqD;;;;;;;IAOrD,mCAA8C;;;;;;IAM9C,iCAA0B;;;;;;;IAO1B,oCAAgC;;;;;IAKhC,qCAAqD;;;;;;;IAwBrD,kCAA8D;;;;;;;IAO9D,mCAAqF;;;;;;;IAOrF,iCAA+E;;;;;;;IAO/E,kCAAkF;;;;;IAKlF,kCAAsE;;;;;;;IAqBtE,2CAAkD;;;;;;;IAMlD,8CAAkC;;;;;;;IAMlC,mCAAuB;;;;;;;;;IAQvB,wCAA+C;;;;;;;;;IAQ/C,yCAAkC;;;;;;IAKlC,0CAAoC;;;;;;IAKpC,gDAAoC;;;;;IAEpC,+BAAmB;;;;;AAmMpB,+BAGC;;;IAFA,0BAAmC;;IACnC,2BAAyB;;;;;AAG1B,gCAGC;;;IAFA,2BAAoC;;IACpC,4BAAyB;;;;;AAG1B,iCAGC;;;IAFA,4BAA0C;;IAC1C,6BAAyB","sourcesContent":["/**\n * @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved.\n * For licensing, see LICENSE.md.\n */\n\nimport {\n\tComponent,\n\tInput,\n\tOutput,\n\tNgZone,\n\tEventEmitter,\n\tforwardRef,\n\tAfterViewInit, OnDestroy,\n\tElementRef\n} from '@angular/core';\n\nimport EditorWatchdog from '@ckeditor/ckeditor5-watchdog/src/editorwatchdog';\n\nimport uid from './uid';\n\nimport {\n\tControlValueAccessor,\n\tNG_VALUE_ACCESSOR\n} from '@angular/forms';\n\nimport { CKEditor5 } from './ckeditor';\n\n@Component( {\n\tselector: 'ckeditor',\n\ttemplate: '<ng-template></ng-template>',\n\n\t// Integration with @angular/forms.\n\tproviders: [\n\t\t{\n\t\t\tprovide: NG_VALUE_ACCESSOR,\n\t\t\t// eslint-disable-next-line @typescript-eslint/no-use-before-define\n\t\t\tuseExisting: forwardRef( () => CKEditorComponent ),\n\t\t\tmulti: true,\n\t\t}\n\t]\n} )\nexport class CKEditorComponent implements AfterViewInit, OnDestroy, ControlValueAccessor {\n\t/**\n\t * The reference to the DOM element created by the component.\n\t */\n\tprivate elementRef!: ElementRef<HTMLElement>;\n\n\t/**\n\t * The constructor of the editor to be used for the instance of the component.\n\t * It can be e.g. the `ClassicEditorBuild`, `InlineEditorBuild` or some custom editor.\n\t */\n\t@Input() public editor?: CKEditor5.EditorConstructor;\n\n\t/**\n\t * The configuration of the editor.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editorconfig-EditorConfig.html\n\t * to learn more.\n\t */\n\t@Input() public config: CKEditor5.Config = {};\n\n\t/**\n\t * The initial data of the editor. Useful when not using the ngModel.\n\t * See https://angular.io/api/forms/NgModel to learn more.\n\t */\n\t@Input() public data = '';\n\n\t/**\n\t * Tag name of the editor component.\n\t *\n\t * The default tag is 'div'.\n\t */\n\t@Input() public tagName = 'div';\n\n\t/**\n\t * The context watchdog.\n\t */\n\t@Input() public watchdog?: CKEditor5.ContextWatchdog;\n\n\t/**\n\t * When set `true`, the editor becomes read-only.\n\t * See https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#member-isReadOnly\n\t * to learn more.\n\t */\n\t@Input() public set disabled( isDisabled: boolean ) {\n\t\tthis.setDisabledState( isDisabled );\n\t}\n\n\tpublic get disabled() {\n\t\tif ( this.editorInstance ) {\n\t\t\treturn this.editorInstance.isReadOnly;\n\t\t}\n\n\t\treturn this.initialIsDisabled;\n\t}\n\n\t/**\n\t * Fires when the editor is ready. It corresponds with the `editor#ready`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_core_editor_editor-Editor.html#event-ready\n\t * event.\n\t */\n\t@Output() public ready = new EventEmitter<CKEditor5.Editor>();\n\n\t/**\n\t * Fires when the content of the editor has changed. It corresponds with the `editor.model.document#change`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_model_document-Document.html#event-change\n\t * event.\n\t */\n\t@Output() public change: EventEmitter<ChangeEvent> = new EventEmitter<ChangeEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is blurred. It corresponds with the `editor.editing.view.document#blur`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:blur\n\t * event.\n\t */\n\t@Output() public blur: EventEmitter<BlurEvent> = new EventEmitter<BlurEvent>();\n\n\t/**\n\t * Fires when the editing view of the editor is focused. It corresponds with the `editor.editing.view.document#focus`\n\t * https://ckeditor.com/docs/ckeditor5/latest/api/module_engine_view_document-Document.html#event-event:focus\n\t * event.\n\t */\n\t@Output() public focus: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n\n\t/**\n\t * Fires when the editor component crashes.\n\t */\n\t@Output() public error: EventEmitter<void> = new EventEmitter<void>();\n\n\t/**\n\t * The instance of the editor created by this component.\n\t */\n\tpublic get editorInstance(): CKEditor5.Editor | null {\n\t\tif ( this.editorWatchdog ) {\n\t\t\treturn this.editorWatchdog.editor;\n\t\t}\n\n\t\tif ( this.watchdog ) {\n\t\t\treturn this.watchdog.getItem( this.id );\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t/**\n\t * The editor watchdog. It is created when the context watchdog is not passed to the component.\n\t * It keeps the editor running.\n\t */\n\tprivate editorWatchdog?: CKEditor5.EditorWatchdog;\n\n\t/**\n\t * If the component is read–only before the editor instance is created, it remembers that state,\n\t * so the editor can become read–only once it is ready.\n\t */\n\tprivate initialIsDisabled = false;\n\n\t/**\n\t * An instance of https://angular.io/api/core/NgZone to allow the interaction with the editor\n\t * withing the Angular event loop.\n\t */\n\tprivate ngZone: NgZone;\n\n\t/**\n\t * A callback executed when the content of the editor changes. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnChange?: ( data: string ) => void;\n\n\t/**\n\t * A callback executed when the editor has been blurred. Part of the\n\t * `ControlValueAccessor` (https://angular.io/api/forms/ControlValueAccessor) interface.\n\t *\n\t * Note: Unset unless the component uses the `ngModel`.\n\t */\n\tprivate cvaOnTouched?: () => void;\n\n\t/**\n\t * Reference to the source element used by the editor.\n\t */\n\tprivate editorElement?: HTMLElement;\n\n\t/**\n\t * A lock flag preventing from calling the `cvaOnChange()` during setting editor data.\n\t */\n\tprivate isEditorSettingData = false;\n\n\tprivate id = uid();\n\n\tpublic constructor( elementRef: ElementRef, ngZone: NgZone ) {\n\t\tthis.ngZone = ngZone;\n\t\tthis.elementRef = elementRef;\n\t}\n\n\t// Implementing the AfterViewInit interface.\n\tpublic ngAfterViewInit() {\n\t\tthis.attachToWatchdog();\n\t}\n\n\t// Implementing the OnDestroy interface.\n\tpublic async ngOnDestroy() {\n\t\tif ( this.watchdog ) {\n\t\t\tawait this.watchdog.remove( this.id );\n\t\t} else if ( this.editorWatchdog && this.editorWatchdog.editor ) {\n\t\t\tawait this.editorWatchdog.destroy();\n\n\t\t\tthis.editorWatchdog = undefined;\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic writeValue( value: string | null ): void {\n\t\t// This method is called with the `null` value when the form resets.\n\t\t// A component's responsibility is to restore to the initial state.\n\t\tif ( value === null ) {\n\t\t\tvalue = '';\n\t\t}\n\n\t\t// If already initialized.\n\t\tif ( this.editorInstance ) {\n\t\t\t// The lock mechanism prevents from calling `cvaOnChange()` during changing\n\t\t\t// the editor state. See #139\n\t\t\tthis.isEditorSettingData = true;\n\t\t\tthis.editorInstance.setData( value );\n\t\t\tthis.isEditorSettingData = false;\n\t\t}\n\t\t// If not, wait for it to be ready; store the data.\n\t\telse {\n\t\t\tthis.data = value;\n\n\t\t\t// If the editor element is already available, then update its content.\n\t\t\t// If the ngModel is used then the editor element should be updated directly here.\n\t\t\tif ( this.editorElement ) {\n\t\t\t\tthis.editorElement.innerHTML = this.data;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnChange( callback: ( data: string ) => void ): void {\n\t\tthis.cvaOnChange = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic registerOnTouched( callback: () => void ): void {\n\t\tthis.cvaOnTouched = callback;\n\t}\n\n\t// Implementing the ControlValueAccessor interface (only when binding to ngModel).\n\tpublic setDisabledState( isDisabled: boolean ): void {\n\t\t// If already initialized.\n\t\tif ( this.editorInstance ) {\n\t\t\tthis.editorInstance.isReadOnly = isDisabled;\n\t\t}\n\n\t\t// Store the state anyway to use it once the editor is created.\n\t\tthis.initialIsDisabled = isDisabled;\n\t}\n\n\t/**\n\t * Creates the editor instance, sets initial editor data, then integrates\n\t * the editor with the Angular component. This method does not use the `editor.setData()`\n\t * because of the issue in the collaboration mode (#6).\n\t */\n\tprivate attachToWatchdog() {\n\t\tconst creator = async ( element: HTMLElement, config: CKEditor5.Config ) => {\n\t\t\treturn this.ngZone.runOutsideAngular( async () => {\n\t\t\t\tthis.elementRef.nativeElement.appendChild( element );\n\n\t\t\t\tconst editor = await this.editor!.create( element, config );\n\n\t\t\t\tif ( this.initialIsDisabled ) {\n\t\t\t\t\teditor.isReadOnly = this.initialIsDisabled;\n\t\t\t\t}\n\n\t\t\t\tthis.ngZone.run( () => {\n\t\t\t\t\tthis.ready.emit( editor );\n\t\t\t\t} );\n\n\t\t\t\tthis.setUpEditorEvents( editor );\n\n\t\t\t\treturn editor;\n\t\t\t} );\n\t\t};\n\n\t\tconst destructor = async ( editor: CKEditor5.Editor ) => {\n\t\t\tawait editor.destroy();\n\n\t\t\tthis.elementRef.nativeElement.removeChild( this.editorElement! );\n\t\t};\n\n\t\tconst emitError = () => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tthis.error.emit();\n\t\t\t} );\n\t\t};\n\n\t\tconst element = document.createElement( this.tagName );\n\t\tconst config = this.getConfig();\n\n\t\tthis.editorElement = element;\n\n\t\t// Based on the presence of the watchdog decide how to initialize the editor.\n\t\tif ( this.watchdog ) {\n\t\t\t// When the context watchdog is passed add the new item to it based on the passed configuration.\n\t\t\tthis.watchdog.add( {\n\t\t\t\tid: this.id,\n\t\t\t\ttype: 'editor',\n\t\t\t\tcreator,\n\t\t\t\tdestructor,\n\t\t\t\tsourceElementOrData: element,\n\t\t\t\tconfig\n\t\t\t} );\n\n\t\t\tthis.watchdog.on( 'itemError', ( _, { itemId } ) => {\n\t\t\t\tif ( itemId === this.id ) {\n\t\t\t\t\temitError();\n\t\t\t\t}\n\t\t\t} );\n\t\t} else {\n\t\t\t// In the other case create the watchdog by hand to keep the editor running.\n\t\t\tconst editorWatchdog: CKEditor5.EditorWatchdog = new EditorWatchdog( this.editor );\n\n\t\t\teditorWatchdog.setCreator( creator );\n\t\t\teditorWatchdog.setDestructor( destructor );\n\t\t\teditorWatchdog.on( 'error', emitError );\n\n\t\t\tthis.editorWatchdog = editorWatchdog;\n\n\t\t\tthis.editorWatchdog.create( element, config );\n\t\t}\n\t}\n\n\tprivate getConfig() {\n\t\tif ( this.data && this.config.initialData ) {\n\t\t\tthrow new Error( 'Editor data should be provided either using `config.initialData` or `data` properties.' );\n\t\t}\n\n\t\t// Merge two possible ways of providing data into the `config.initialData` field.\n\t\treturn {\n\t\t\t...this.config,\n\t\t\tinitialData: this.config.initialData || this.data || ''\n\t\t};\n\t}\n\n\t/**\n\t * Integrates the editor with the component by attaching related event listeners.\n\t */\n\tprivate setUpEditorEvents( editor: CKEditor5.Editor ): void {\n\t\tconst modelDocument = editor.model.document;\n\t\tconst viewDocument = editor.editing.view.document;\n\n\t\tmodelDocument.on( 'change:data', ( evt: CKEditor5.EventInfo<'change:data'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnChange && !this.isEditorSettingData ) {\n\t\t\t\t\tconst data = editor.getData();\n\n\t\t\t\t\tthis.cvaOnChange( data );\n\t\t\t\t}\n\n\t\t\t\tthis.change.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'focus', ( evt: CKEditor5.EventInfo<'focus'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tthis.focus.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\n\t\tviewDocument.on( 'blur', ( evt: CKEditor5.EventInfo<'blur'> ) => {\n\t\t\tthis.ngZone.run( () => {\n\t\t\t\tif ( this.cvaOnTouched ) {\n\t\t\t\t\tthis.cvaOnTouched();\n\t\t\t\t}\n\n\t\t\t\tthis.blur.emit( { event: evt, editor } );\n\t\t\t} );\n\t\t} );\n\t}\n}\n\nexport interface BlurEvent {\n\tevent: CKEditor5.EventInfo<'blur'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface FocusEvent {\n\tevent: CKEditor5.EventInfo<'focus'>;\n\teditor: CKEditor5.Editor;\n}\n\nexport interface ChangeEvent {\n\tevent: CKEditor5.EventInfo<'change:data'>;\n\teditor: CKEditor5.Editor;\n}\n"]} |
@@ -6,3 +6,3 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -183,3 +183,76 @@ */ | ||
CKEditor5.Editor = Editor; | ||
/** | ||
* @record | ||
*/ | ||
function ContextWatchdog() { } | ||
CKEditor5.ContextWatchdog = ContextWatchdog; | ||
if (false) { | ||
/** @type {?} */ | ||
ContextWatchdog.prototype.context; | ||
/** | ||
* @param {?} items | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.add = function (items) { }; | ||
/** | ||
* @param {?} items | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.remove = function (items) { }; | ||
/** | ||
* @param {?} itemId | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.getItem = function (itemId) { }; | ||
/** | ||
* @param {?} itemId | ||
* @param {?} itemType | ||
* @param {?} watchdog | ||
* @return {?} | ||
*/ | ||
ContextWatchdog.prototype.addItemWatchdog = function (itemId, itemType, watchdog) { }; | ||
} | ||
/** | ||
* @record | ||
*/ | ||
function EditorWatchdog() { } | ||
CKEditor5.EditorWatchdog = EditorWatchdog; | ||
if (false) { | ||
/** @type {?} */ | ||
EditorWatchdog.prototype.editor; | ||
} | ||
/** | ||
* @record | ||
* @template T | ||
*/ | ||
function Watchdog() { } | ||
CKEditor5.Watchdog = Watchdog; | ||
if (false) { | ||
/** | ||
* @param {?} creator | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.setCreator = function (creator) { }; | ||
/** | ||
* @param {?} destructor | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.setDestructor = function (destructor) { }; | ||
/** | ||
* @param {?} event | ||
* @param {?} callback | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.on = function (event, callback) { }; | ||
/** | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.destroy = function () { }; | ||
/** | ||
* @param {...?} args | ||
* @return {?} | ||
*/ | ||
Watchdog.prototype.create = function (args) { }; | ||
} | ||
})(CKEditor5 || (CKEditor5 = {})); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJja2VkaXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVFBLE1BQU0sS0FBVyxTQUFTLENBZ0Z6QjtBQWhGRCxXQUFpQixTQUFTOzs7OztJQUt6QixnQ0FFQzs7Ozs7Ozs7UUFEQSxnRkFBc0Y7Ozs7OztJQU12RixxQkFFQzs7Ozs7Ozs7O0lBT0Qsd0JBUUM7Ozs7UUFQQSx5QkFBeUI7O1FBQ3pCLHlCQUFxQjs7UUFDckIsMkJBQXFCOztRQUNyQiwyQkFBYTs7OztRQUViLDBDQUFZOzs7O1FBQ1osMkNBQWE7Ozs7Ozs7O0lBUWQseUJBMEJDOzs7O1FBekJBLDhCQUF1Qjs7UUFDdkIsNEJBQXFCOztRQUNyQixnQ0FBeUI7O1FBQ3pCLDBCQUFtQjs7UUFDbkIsNkJBQXNCOztRQUN0QixnQ0FBeUI7O1FBQ3pCLDRCQUFxQjs7UUFDckIsMkJBQW9COztRQUNwQiw2QkFBc0I7O1FBQ3RCLDJCQUF1RDs7UUFFdkQsZ0NBQW9COzs7Ozs7UUFFcEIsc0RBQWtDOzs7O1FBQ2xDLCtDQUF5Qjs7Ozs7O1FBQ3pCLGtFQUFzRDs7Ozs7O1FBQ3RELDJEQUEyQzs7Ozs7Ozs7UUFDM0MscUZBQXFGOzs7Ozs7UUFDckYsOERBQW1EOzs7Ozs7O1FBQ25ELHNFQUFpRTs7Ozs7OztRQUNqRSx3RUFBbUU7Ozs7Ozs7UUFDbkUsaUZBQTJFOzs7OztRQUMzRSw2Q0FBMEI7Ozs7Ozs7O0lBVTNCLHNCQUdDOzs7Ozs7UUFGQSw0Q0FBa0I7Ozs7O1FBQ2xCLGdEQUE4Qjs7Ozs7Ozs7SUFRL0IscUJBQXNEOztBQUN2RCxDQUFDLEVBaEZnQixTQUFTLEtBQVQsU0FBUyxRQWdGekIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlIENvcHlyaWdodCAoYykgMjAwMy0yMDE5LCBDS1NvdXJjZSAtIEZyZWRlcmljbyBLbmFiYmVuLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogRm9yIGxpY2Vuc2luZywgc2VlIExJQ0VOU0UubWQuXG4gKi9cblxuLyoqXG4gKiBCYXNpYyB0eXBpbmdzIGZvciB0aGUgQ0tFZGl0b3I1IGVsZW1lbnRzLlxuICovXG5leHBvcnQgbmFtZXNwYWNlIENLRWRpdG9yNSB7XG5cblx0LyoqXG5cdCAqIFRoZSBDS0VkaXRvcjUgZWRpdG9yIGNvbnN0cnVjdG9yLlxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBFZGl0b3JDb25zdHJ1Y3RvciB7XG5cdFx0Y3JlYXRlKCBzb3VyY2VFbGVtZW50T3JEYXRhOiBIVE1MRWxlbWVudCB8IHN0cmluZywgY29uZmlnPzogQ29uZmlnICk6IFByb21pc2U8RWRpdG9yPjtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgQ0tFZGl0b3I1IGVkaXRvciBjb25maWcuXG5cdCAqL1xuXHRleHBvcnQgaW50ZXJmYWNlIENvbmZpZyB7XG5cdFx0WyBrZXk6IHN0cmluZyBdOiBhbnk7XG5cdH1cblxuXHQvKipcblx0ICogVGhlIGV2ZW50IG9iamVjdCBwYXNzZWQgdG8gQ0tFZGl0b3I1IGV2ZW50IGNhbGxiYWNrcy5cblx0ICpcblx0ICogU2VlIGh0dHBzOi8vY2tlZGl0b3IuY29tL2RvY3MvY2tlZGl0b3I1L2xhdGVzdC9hcGkvbW9kdWxlX3V0aWxzX2V2ZW50aW5mby1FdmVudEluZm8uaHRtbFxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBFdmVudEluZm88RXZlbnROYW1lIGV4dGVuZHMgc3RyaW5nPiB7XG5cdFx0cmVhZG9ubHkgbmFtZTogRXZlbnROYW1lO1xuXHRcdHJlYWRvbmx5IHBhdGg6IGFueVtdO1xuXHRcdHJlYWRvbmx5IHNvdXJjZTogYW55O1xuXHRcdHJldHVybj86IGFueTtcblxuXHRcdG9mZigpOiB2b2lkO1xuXHRcdHN0b3AoKTogdm9pZDtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgYmFzZSBFZGl0b3IgY2xhc3MuXG5cdCAqXG5cdCAqIFNlZSBodHRwczovL2NrZWRpdG9yLmNvbS9kb2NzL2NrZWRpdG9yNS9sYXRlc3QvYXBpL21vZHVsZV9jb3JlX2VkaXRvcl9lZGl0b3ItRWRpdG9yLmh0bWxcblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgQmFzZUVkaXRvciB7XG5cdFx0cmVhZG9ubHkgY29tbWFuZHM6IGFueTtcblx0XHRyZWFkb25seSBjb25maWc6IGFueTtcblx0XHRyZWFkb25seSBjb252ZXJzaW9uOiBhbnk7XG5cdFx0cmVhZG9ubHkgZGF0YTogYW55O1xuXHRcdHJlYWRvbmx5IGVkaXRpbmc6IGFueTtcblx0XHRyZWFkb25seSBrZXlzdHJva2VzOiBhbnk7XG5cdFx0cmVhZG9ubHkgbG9jYWxlOiBhbnk7XG5cdFx0cmVhZG9ubHkgbW9kZWw6IGFueTtcblx0XHRyZWFkb25seSBwbHVnaW5zOiBhbnk7XG5cdFx0cmVhZG9ubHkgc3RhdGU6ICdpbml0aWFsaXppbmcnIHwgJ3JlYWR5JyB8ICdkZXN0cm95ZWQnO1xuXG5cdFx0aXNSZWFkT25seTogYm9vbGVhbjtcblxuXHRcdGRlbGVnYXRlKCBldmVudHM6IHN0cmluZ1tdICk6IGFueTtcblx0XHRkZXN0cm95KCk6IFByb21pc2U8dm9pZD47XG5cdFx0ZXhlY3V0ZSggY29tbWFuZE5hbWU6IHN0cmluZywgLi4ucGFyYW1zOiBhbnlbXSApOiBhbnk7XG5cdFx0ZmlyZSggZXZlbnROYW1lOiBzdHJpbmcsIGFyZ3M/OiBhbnkgKTogYW55O1xuXHRcdGxpc3RlblRvKCBlbWl0dGVyOiBhbnksIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24sIG9wdGlvbnM/OiBhbnkgKTogdm9pZDtcblx0XHRvZmYoIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24gKTogdm9pZDtcblx0XHRvbiggZXZlbnROYW1lOiBzdHJpbmcsIGNhbGxiYWNrOiBGdW5jdGlvbiwgb3B0aW9ucz86IGFueSApOiB2b2lkO1xuXHRcdG9uY2UoIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24sIG9wdGlvbnM/OiBhbnkgKTogdm9pZDtcblx0XHRzdG9wTGlzdGVuaW5nKCBlbWl0dGVyOiBhbnksIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24gKTogdm9pZDtcblx0XHR0KCAuLi5hcmdzOiBhbnlbXSApOiB2b2lkO1xuXG5cdFx0WyBwcm9wZXJ0eTogc3RyaW5nIF06IGFueTtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgQ0tFZGl0b3I1IERhdGFBcGkgaW50ZXJmYWNlLlxuXHQgKlxuXHQgKiBTZWUgaHR0cHM6Ly9ja2VkaXRvci5jb20vZG9jcy9ja2VkaXRvcjUvbGF0ZXN0L2FwaS9tb2R1bGVfY29yZV9lZGl0b3JfdXRpbHNfZGF0YWFwaW1peGluLURhdGFBcGkuaHRtbC5cblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRGF0YUFwaSB7XG5cdFx0Z2V0RGF0YSgpOiBzdHJpbmc7XG5cdFx0c2V0RGF0YSggZGF0YTogc3RyaW5nICk6IHZvaWQ7XG5cdH1cblxuXHQvKipcblx0ICogQSBDS0VkaXRvcjUgZWRpdG9yIHRoYXQgaW1wbGVtZW50cyB0aGVcblx0ICogW0RhdGFBcGkgaW50ZXJmYWNlXShodHRwczovL2NrZWRpdG9yLmNvbS9kb2NzL2NrZWRpdG9yNS9sYXRlc3QvYXBpL21vZHVsZV9jb3JlX2VkaXRvcl91dGlsc19kYXRhYXBpbWl4aW4tRGF0YUFwaS5odG1sKS5cblx0ICogRS5nLiB0aGUgYENsYXNzaWNFZGl0b3JgLCBgSW5saW5lRWRpdG9yYCwgZXRjLlxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBFZGl0b3IgZXh0ZW5kcyBCYXNlRWRpdG9yLCBEYXRhQXBpIHt9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJja2VkaXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQVFBLE1BQU0sS0FBVyxTQUFTLENBb0d6QjtBQXBHRCxXQUFpQixTQUFTOzs7OztJQUt6QixnQ0FFQzs7Ozs7Ozs7UUFEQSxnRkFBc0Y7Ozs7OztJQU12RixxQkFFQzs7Ozs7Ozs7O0lBT0Qsd0JBUUM7Ozs7UUFQQSx5QkFBeUI7O1FBQ3pCLHlCQUFxQjs7UUFDckIsMkJBQXFCOztRQUNyQiwyQkFBYTs7OztRQUViLDBDQUFZOzs7O1FBQ1osMkNBQWE7Ozs7Ozs7O0lBUWQseUJBMEJDOzs7O1FBekJBLDhCQUF1Qjs7UUFDdkIsNEJBQXFCOztRQUNyQixnQ0FBeUI7O1FBQ3pCLDBCQUFtQjs7UUFDbkIsNkJBQXNCOztRQUN0QixnQ0FBeUI7O1FBQ3pCLDRCQUFxQjs7UUFDckIsMkJBQW9COztRQUNwQiw2QkFBc0I7O1FBQ3RCLDJCQUF1RDs7UUFFdkQsZ0NBQW9COzs7Ozs7UUFFcEIsc0RBQWtDOzs7O1FBQ2xDLCtDQUF5Qjs7Ozs7O1FBQ3pCLGtFQUFzRDs7Ozs7O1FBQ3RELDJEQUEyQzs7Ozs7Ozs7UUFDM0MscUZBQXFGOzs7Ozs7UUFDckYsOERBQW1EOzs7Ozs7O1FBQ25ELHNFQUFpRTs7Ozs7OztRQUNqRSx3RUFBbUU7Ozs7Ozs7UUFDbkUsaUZBQTJFOzs7OztRQUMzRSw2Q0FBMEI7Ozs7Ozs7O0lBVTNCLHNCQUdDOzs7Ozs7UUFGQSw0Q0FBa0I7Ozs7O1FBQ2xCLGdEQUE4Qjs7Ozs7Ozs7SUFRL0IscUJBQXNEOzs7OztJQUV0RCw4QkFNQzs7OztRQUxBLGtDQUFhOzs7OztRQUNiLHFEQUFpQzs7Ozs7UUFDakMsd0RBQWtEOzs7OztRQUNsRCwwREFBa0M7Ozs7Ozs7UUFDbEMsc0ZBQTRGOzs7OztJQUc3Riw2QkFFQzs7OztRQURBLGdDQUFlOzs7Ozs7SUFHaEIsdUJBTUM7Ozs7Ozs7UUFMQSx1REFBOEQ7Ozs7O1FBQzlELDZEQUFnRTs7Ozs7O1FBQ2hFLHVEQUE2RDs7OztRQUM3RCw2Q0FBeUI7Ozs7O1FBQ3pCLGdEQUF3Qzs7QUFFMUMsQ0FBQyxFQXBHZ0IsU0FBUyxLQUFULFNBQVMsUUFvR3pCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZSBDb3B5cmlnaHQgKGMpIDIwMDMtMjAyMCwgQ0tTb3VyY2UgLSBGcmVkZXJpY28gS25hYmJlbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIEZvciBsaWNlbnNpbmcsIHNlZSBMSUNFTlNFLm1kLlxuICovXG5cbi8qKlxuICogQmFzaWMgdHlwaW5ncyBmb3IgdGhlIENLRWRpdG9yNSBlbGVtZW50cy5cbiAqL1xuZXhwb3J0IG5hbWVzcGFjZSBDS0VkaXRvcjUge1xuXG5cdC8qKlxuXHQgKiBUaGUgQ0tFZGl0b3I1IGVkaXRvciBjb25zdHJ1Y3Rvci5cblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yQ29uc3RydWN0b3Ige1xuXHRcdGNyZWF0ZSggc291cmNlRWxlbWVudE9yRGF0YTogSFRNTEVsZW1lbnQgfCBzdHJpbmcsIGNvbmZpZz86IENvbmZpZyApOiBQcm9taXNlPEVkaXRvcj47XG5cdH1cblxuXHQvKipcblx0ICogVGhlIENLRWRpdG9yNSBlZGl0b3IgY29uZmlnLlxuXHQgKi9cblx0ZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xuXHRcdFsga2V5OiBzdHJpbmcgXTogYW55O1xuXHR9XG5cblx0LyoqXG5cdCAqIFRoZSBldmVudCBvYmplY3QgcGFzc2VkIHRvIENLRWRpdG9yNSBldmVudCBjYWxsYmFja3MuXG5cdCAqXG5cdCAqIFNlZSBodHRwczovL2NrZWRpdG9yLmNvbS9kb2NzL2NrZWRpdG9yNS9sYXRlc3QvYXBpL21vZHVsZV91dGlsc19ldmVudGluZm8tRXZlbnRJbmZvLmh0bWxcblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRXZlbnRJbmZvPEV2ZW50TmFtZSBleHRlbmRzIHN0cmluZz4ge1xuXHRcdHJlYWRvbmx5IG5hbWU6IEV2ZW50TmFtZTtcblx0XHRyZWFkb25seSBwYXRoOiBhbnlbXTtcblx0XHRyZWFkb25seSBzb3VyY2U6IGFueTtcblx0XHRyZXR1cm4/OiBhbnk7XG5cblx0XHRvZmYoKTogdm9pZDtcblx0XHRzdG9wKCk6IHZvaWQ7XG5cdH1cblxuXHQvKipcblx0ICogVGhlIGJhc2UgRWRpdG9yIGNsYXNzLlxuXHQgKlxuXHQgKiBTZWUgaHR0cHM6Ly9ja2VkaXRvci5jb20vZG9jcy9ja2VkaXRvcjUvbGF0ZXN0L2FwaS9tb2R1bGVfY29yZV9lZGl0b3JfZWRpdG9yLUVkaXRvci5odG1sXG5cdCAqL1xuXHRleHBvcnQgaW50ZXJmYWNlIEJhc2VFZGl0b3Ige1xuXHRcdHJlYWRvbmx5IGNvbW1hbmRzOiBhbnk7XG5cdFx0cmVhZG9ubHkgY29uZmlnOiBhbnk7XG5cdFx0cmVhZG9ubHkgY29udmVyc2lvbjogYW55O1xuXHRcdHJlYWRvbmx5IGRhdGE6IGFueTtcblx0XHRyZWFkb25seSBlZGl0aW5nOiBhbnk7XG5cdFx0cmVhZG9ubHkga2V5c3Ryb2tlczogYW55O1xuXHRcdHJlYWRvbmx5IGxvY2FsZTogYW55O1xuXHRcdHJlYWRvbmx5IG1vZGVsOiBhbnk7XG5cdFx0cmVhZG9ubHkgcGx1Z2luczogYW55O1xuXHRcdHJlYWRvbmx5IHN0YXRlOiAnaW5pdGlhbGl6aW5nJyB8ICdyZWFkeScgfCAnZGVzdHJveWVkJztcblxuXHRcdGlzUmVhZE9ubHk6IGJvb2xlYW47XG5cblx0XHRkZWxlZ2F0ZSggZXZlbnRzOiBzdHJpbmdbXSApOiBhbnk7XG5cdFx0ZGVzdHJveSgpOiBQcm9taXNlPHZvaWQ+O1xuXHRcdGV4ZWN1dGUoIGNvbW1hbmROYW1lOiBzdHJpbmcsIC4uLnBhcmFtczogYW55W10gKTogYW55O1xuXHRcdGZpcmUoIGV2ZW50TmFtZTogc3RyaW5nLCBhcmdzPzogYW55ICk6IGFueTtcblx0XHRsaXN0ZW5UbyggZW1pdHRlcjogYW55LCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uLCBvcHRpb25zPzogYW55ICk6IHZvaWQ7XG5cdFx0b2ZmKCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uICk6IHZvaWQ7XG5cdFx0b24oIGV2ZW50TmFtZTogc3RyaW5nLCBjYWxsYmFjazogRnVuY3Rpb24sIG9wdGlvbnM/OiBhbnkgKTogdm9pZDtcblx0XHRvbmNlKCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uLCBvcHRpb25zPzogYW55ICk6IHZvaWQ7XG5cdFx0c3RvcExpc3RlbmluZyggZW1pdHRlcjogYW55LCBldmVudE5hbWU6IHN0cmluZywgY2FsbGJhY2s6IEZ1bmN0aW9uICk6IHZvaWQ7XG5cdFx0dCggLi4uYXJnczogYW55W10gKTogdm9pZDtcblxuXHRcdFsgcHJvcGVydHk6IHN0cmluZyBdOiBhbnk7XG5cdH1cblxuXHQvKipcblx0ICogVGhlIENLRWRpdG9yNSBEYXRhQXBpIGludGVyZmFjZS5cblx0ICpcblx0ICogU2VlIGh0dHBzOi8vY2tlZGl0b3IuY29tL2RvY3MvY2tlZGl0b3I1L2xhdGVzdC9hcGkvbW9kdWxlX2NvcmVfZWRpdG9yX3V0aWxzX2RhdGFhcGltaXhpbi1EYXRhQXBpLmh0bWwuXG5cdCAqL1xuXHRleHBvcnQgaW50ZXJmYWNlIERhdGFBcGkge1xuXHRcdGdldERhdGEoKTogc3RyaW5nO1xuXHRcdHNldERhdGEoIGRhdGE6IHN0cmluZyApOiB2b2lkO1xuXHR9XG5cblx0LyoqXG5cdCAqIEEgQ0tFZGl0b3I1IGVkaXRvciB0aGF0IGltcGxlbWVudHMgdGhlXG5cdCAqIFtEYXRhQXBpIGludGVyZmFjZV0oaHR0cHM6Ly9ja2VkaXRvci5jb20vZG9jcy9ja2VkaXRvcjUvbGF0ZXN0L2FwaS9tb2R1bGVfY29yZV9lZGl0b3JfdXRpbHNfZGF0YWFwaW1peGluLURhdGFBcGkuaHRtbCkuXG5cdCAqIEUuZy4gdGhlIGBDbGFzc2ljRWRpdG9yYCwgYElubGluZUVkaXRvcmAsIGV0Yy5cblx0ICovXG5cdGV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yIGV4dGVuZHMgQmFzZUVkaXRvciwgRGF0YUFwaSB7fVxuXG5cdGV4cG9ydCBpbnRlcmZhY2UgQ29udGV4dFdhdGNoZG9nIGV4dGVuZHMgV2F0Y2hkb2c8YW55Pntcblx0XHRjb250ZXh0OiBhbnk7XG5cdFx0YWRkKCBpdGVtczogYW55ICk6IFByb21pc2U8dm9pZD47XG5cdFx0cmVtb3ZlKCBpdGVtczogc3RyaW5nIHwgc3RyaW5nW10gKTogUHJvbWlzZTx2b2lkPjtcblx0XHRnZXRJdGVtKCBpdGVtSWQ6IHN0cmluZyApOiBFZGl0b3I7XG5cdFx0YWRkSXRlbVdhdGNoZG9nKCBpdGVtSWQ6IHN0cmluZywgaXRlbVR5cGU6IHN0cmluZywgd2F0Y2hkb2c6IFdhdGNoZG9nPGFueT4gKTogUHJvbWlzZTx2b2lkPjtcblx0fVxuXG5cdGV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yV2F0Y2hkb2cgZXh0ZW5kcyBXYXRjaGRvZzxFZGl0b3I+IHtcblx0XHRlZGl0b3I6IEVkaXRvcjtcblx0fVxuXG5cdGV4cG9ydCBpbnRlcmZhY2UgV2F0Y2hkb2c8VD4ge1xuXHRcdHNldENyZWF0b3IoIGNyZWF0b3I6ICggLi4uYXJnczogYW55W10gKSA9PiBQcm9taXNlPFQ+ICk6IHZvaWQ7XG5cdFx0c2V0RGVzdHJ1Y3RvciggZGVzdHJ1Y3RvcjogKCBpdGVtOiBUICkgPT4gUHJvbWlzZTx2b2lkPiApOiB2b2lkO1xuXHRcdG9uKCBldmVudDogc3RyaW5nLCBjYWxsYmFjazogKCAuLi5hcmdzOiBhbnkgKSA9PiBhbnkgKTogdm9pZDtcblx0XHRkZXN0cm95KCk6IFByb21pc2U8dm9pZD47XG5cdFx0Y3JlYXRlKCAuLi5hcmdzOiBhbnlbXSApOiBQcm9taXNlPHZvaWQ+O1xuXHR9XG59XG4iXX0= |
@@ -6,3 +6,3 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -27,2 +27,2 @@ */ | ||
export { CKEditorModule }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGNrZWRpdG9yL2NrZWRpdG9yNS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiY2tlZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBS0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXpEO0lBQUE7SUFLNkIsQ0FBQzs7Z0JBTDdCLFFBQVEsU0FBRTtvQkFDVixPQUFPLEVBQUUsQ0FBRSxXQUFXLEVBQUUsWUFBWSxDQUFFO29CQUN0QyxZQUFZLEVBQUUsQ0FBRSxpQkFBaUIsQ0FBRTtvQkFDbkMsT0FBTyxFQUFFLENBQUUsaUJBQWlCLENBQUU7aUJBQzlCOztJQUM0QixxQkFBQztDQUFBLEFBTDlCLElBSzhCO1NBQWpCLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlIENvcHlyaWdodCAoYykgMjAwMy0yMDE5LCBDS1NvdXJjZSAtIEZyZWRlcmljbyBLbmFiYmVuLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogRm9yIGxpY2Vuc2luZywgc2VlIExJQ0VOU0UubWQuXG4gKi9cblxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENLRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoIHtcblx0aW1wb3J0czogWyBGb3Jtc01vZHVsZSwgQ29tbW9uTW9kdWxlIF0sXG5cdGRlY2xhcmF0aW9uczogWyBDS0VkaXRvckNvbXBvbmVudCBdLFxuXHRleHBvcnRzOiBbIENLRWRpdG9yQ29tcG9uZW50IF1cbn0gKVxuZXhwb3J0IGNsYXNzIENLRWRpdG9yTW9kdWxlIHt9XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2tlZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGNrZWRpdG9yL2NrZWRpdG9yNS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiY2tlZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBS0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXpEO0lBQUE7SUFLNkIsQ0FBQzs7Z0JBTDdCLFFBQVEsU0FBRTtvQkFDVixPQUFPLEVBQUUsQ0FBRSxXQUFXLEVBQUUsWUFBWSxDQUFFO29CQUN0QyxZQUFZLEVBQUUsQ0FBRSxpQkFBaUIsQ0FBRTtvQkFDbkMsT0FBTyxFQUFFLENBQUUsaUJBQWlCLENBQUU7aUJBQzlCOztJQUM0QixxQkFBQztDQUFBLEFBTDlCLElBSzhCO1NBQWpCLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlIENvcHlyaWdodCAoYykgMjAwMy0yMDIwLCBDS1NvdXJjZSAtIEZyZWRlcmljbyBLbmFiYmVuLiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICogRm9yIGxpY2Vuc2luZywgc2VlIExJQ0VOU0UubWQuXG4gKi9cblxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENLRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoIHtcblx0aW1wb3J0czogWyBGb3Jtc01vZHVsZSwgQ29tbW9uTW9kdWxlIF0sXG5cdGRlY2xhcmF0aW9uczogWyBDS0VkaXRvckNvbXBvbmVudCBdLFxuXHRleHBvcnRzOiBbIENLRWRpdG9yQ29tcG9uZW50IF1cbn0gKVxuZXhwb3J0IGNsYXNzIENLRWRpdG9yTW9kdWxlIHt9XG4iXX0= |
@@ -6,3 +6,3 @@ /** | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -13,2 +13,2 @@ */ | ||
export { CKEditorModule } from './ckeditor.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUtBLGVBQWMsWUFBWSxDQUFDO0FBQzNCLGtDQUFjLHNCQUFzQixDQUFDO0FBQ3JDLCtCQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZSBDb3B5cmlnaHQgKGMpIDIwMDMtMjAxOSwgQ0tTb3VyY2UgLSBGcmVkZXJpY28gS25hYmJlbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIEZvciBsaWNlbnNpbmcsIHNlZSBMSUNFTlNFLm1kLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vY2tlZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5tb2R1bGUnO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AY2tlZGl0b3IvY2tlZGl0b3I1LWFuZ3VsYXIvIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUtBLGVBQWMsWUFBWSxDQUFDO0FBQzNCLGtDQUFjLHNCQUFzQixDQUFDO0FBQ3JDLCtCQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZSBDb3B5cmlnaHQgKGMpIDIwMDMtMjAyMCwgQ0tTb3VyY2UgLSBGcmVkZXJpY28gS25hYmJlbi4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqIEZvciBsaWNlbnNpbmcsIHNlZSBMSUNFTlNFLm1kLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vY2tlZGl0b3InO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ja2VkaXRvci5tb2R1bGUnO1xuIl19 |
@@ -0,1 +1,3 @@ | ||
import { __awaiter } from 'tslib'; | ||
import EditorWatchdog from '@ckeditor/ckeditor5-watchdog/src/editorwatchdog'; | ||
import { Component, Input, Output, NgZone, EventEmitter, forwardRef, ElementRef, NgModule } from '@angular/core'; | ||
@@ -10,3 +12,3 @@ import { CommonModule } from '@angular/common'; | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -64,2 +66,18 @@ */ | ||
CKEditor5.Editor = Editor; | ||
/** | ||
* @record | ||
*/ | ||
function ContextWatchdog() { } | ||
CKEditor5.ContextWatchdog = ContextWatchdog; | ||
/** | ||
* @record | ||
*/ | ||
function EditorWatchdog$$1() { } | ||
CKEditor5.EditorWatchdog = EditorWatchdog$$1; | ||
/** | ||
* @record | ||
* @template T | ||
*/ | ||
function Watchdog() { } | ||
CKEditor5.Watchdog = Watchdog; | ||
})(CKEditor5 || (CKEditor5 = {})); | ||
@@ -71,2 +89,71 @@ | ||
*/ | ||
/** | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license | ||
*/ | ||
// A copy of @ckeditor/ckeditor5-utils/src/uid.js | ||
// A hash table of hex numbers to avoid using toString() in uid() which is costly. | ||
// [ '00', '01', '02', ..., 'fe', 'ff' ] | ||
const ɵ0 = /** | ||
* @param {?} val | ||
* @param {?} index | ||
* @return {?} | ||
*/ | ||
(val, index) => ('0' + (index).toString(16)).slice(-2); | ||
/** @type {?} */ | ||
const HEX_NUMBERS = new Array(256).fill(0) | ||
.map((ɵ0)); | ||
/** | ||
* Returns a unique id. The id starts with an "e" character and a randomly generated string of | ||
* 32 alphanumeric characters. | ||
* | ||
* **Note**: The characters the unique id is built from correspond to the hex number notation | ||
* (from "0" to "9", from "a" to "f"). In other words, each id corresponds to an "e" followed | ||
* by 16 8-bit numbers next to each other. | ||
* | ||
* @return {?} An unique id string. | ||
*/ | ||
function uid() { | ||
// Let's create some positive random 32bit integers first. | ||
// | ||
// 1. Math.random() is a float between 0 and 1. | ||
// 2. 0x100000000 is 2^32 = 4294967296. | ||
// 3. >>> 0 enforces integer (in JS all numbers are floating point). | ||
// | ||
// For instance: | ||
// Math.random() * 0x100000000 = 3366450031.853859 | ||
// but | ||
// Math.random() * 0x100000000 >>> 0 = 3366450031. | ||
/** @type {?} */ | ||
const r1 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
const r2 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
const r3 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
const r4 = Math.random() * 0x100000000 >>> 0; | ||
// Make sure that id does not start with number. | ||
return 'e' + | ||
HEX_NUMBERS[r1 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 24 & 0xFF]; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
class CKEditorComponent { | ||
@@ -120,5 +207,5 @@ /** | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
*/ | ||
this.editorInstance = null; | ||
this.error = new EventEmitter(); | ||
/** | ||
@@ -133,2 +220,3 @@ * If the component is read–only before the editor instance is created, it remembers that state, | ||
this.isEditorSettingData = false; | ||
this.id = uid(); | ||
this.ngZone = ngZone; | ||
@@ -156,2 +244,15 @@ this.elementRef = elementRef; | ||
} | ||
/** | ||
* The instance of the editor created by this component. | ||
* @return {?} | ||
*/ | ||
get editorInstance() { | ||
if (this.editorWatchdog) { | ||
return this.editorWatchdog.editor; | ||
} | ||
if (this.watchdog) { | ||
return this.watchdog.getItem(this.id); | ||
} | ||
return null; | ||
} | ||
// Implementing the AfterViewInit interface. | ||
@@ -162,8 +263,3 @@ /** | ||
ngAfterViewInit() { | ||
this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.createEditor(); | ||
})); | ||
this.attachToWatchdog(); | ||
} | ||
@@ -175,6 +271,11 @@ // Implementing the OnDestroy interface. | ||
ngOnDestroy() { | ||
if (this.editorInstance) { | ||
this.editorInstance.destroy(); | ||
this.editorInstance = null; | ||
} | ||
return __awaiter(this, void 0, void 0, /** @this {!CKEditorComponent} */ function* () { | ||
if (this.watchdog) { | ||
yield this.watchdog.remove(this.id); | ||
} | ||
else if (this.editorWatchdog && this.editorWatchdog.editor) { | ||
yield this.editorWatchdog.destroy(); | ||
this.editorWatchdog = undefined; | ||
} | ||
}); | ||
} | ||
@@ -232,10 +333,8 @@ // Implementing the ControlValueAccessor interface (only when binding to ngModel). | ||
setDisabledState(isDisabled) { | ||
// If already initialized | ||
// If already initialized. | ||
if (this.editorInstance) { | ||
this.editorInstance.isReadOnly = isDisabled; | ||
} | ||
// If not, wait for it to be ready; store the state. | ||
else { | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
// Store the state anyway to use it once the editor is created. | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
@@ -249,23 +348,44 @@ /** | ||
*/ | ||
createEditor() { | ||
attachToWatchdog() { | ||
/** @type {?} */ | ||
const element = document.createElement(this.tagName); | ||
this.editorElement = element; | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
const creator = (/** | ||
* @param {?} element | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
(element, config) => __awaiter(this, void 0, void 0, function* () { | ||
return this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
() => __awaiter(this, void 0, void 0, function* () { | ||
this.elementRef.nativeElement.appendChild(element); | ||
/** @type {?} */ | ||
const editor = yield (/** @type {?} */ (this.editor)).create(element, config); | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
this.ngZone.run((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.ready.emit(editor); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
return editor; | ||
}))); | ||
})); | ||
/** @type {?} */ | ||
const config = Object.assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
this.elementRef.nativeElement.appendChild(element); | ||
return (/** @type {?} */ (this.editor)).create(element, config) | ||
.then((/** | ||
const destructor = (/** | ||
* @param {?} editor | ||
* @return {?} | ||
*/ | ||
editor => { | ||
this.editorInstance = editor; | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
(editor) => __awaiter(this, void 0, void 0, function* () { | ||
yield editor.destroy(); | ||
this.elementRef.nativeElement.removeChild((/** @type {?} */ (this.editorElement))); | ||
})); | ||
/** @type {?} */ | ||
const emitError = (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.ngZone.run((/** | ||
@@ -275,15 +395,55 @@ * @return {?} | ||
() => { | ||
this.ready.emit(editor); | ||
this.error.emit(); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
})) | ||
.catch((/** | ||
* @param {?} err | ||
* @return {?} | ||
*/ | ||
(err) => { | ||
console.error(err.stack); | ||
})); | ||
}); | ||
/** @type {?} */ | ||
const element = document.createElement(this.tagName); | ||
/** @type {?} */ | ||
const config = this.getConfig(); | ||
this.editorElement = element; | ||
// Based on the presence of the watchdog decide how to initialize the editor. | ||
if (this.watchdog) { | ||
// When the context watchdog is passed add the new item to it based on the passed configuration. | ||
this.watchdog.add({ | ||
id: this.id, | ||
type: 'editor', | ||
creator, | ||
destructor, | ||
sourceElementOrData: element, | ||
config | ||
}); | ||
this.watchdog.on('itemError', (/** | ||
* @param {?} _ | ||
* @param {?} __1 | ||
* @return {?} | ||
*/ | ||
(_, { itemId }) => { | ||
if (itemId === this.id) { | ||
emitError(); | ||
} | ||
})); | ||
} | ||
else { | ||
// In the other case create the watchdog by hand to keep the editor running. | ||
/** @type {?} */ | ||
const editorWatchdog = new EditorWatchdog(this.editor); | ||
editorWatchdog.setCreator(creator); | ||
editorWatchdog.setDestructor(destructor); | ||
editorWatchdog.on('error', emitError); | ||
this.editorWatchdog = editorWatchdog; | ||
this.editorWatchdog.create(element, config); | ||
} | ||
} | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
getConfig() { | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
return Object.assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
} | ||
/** | ||
* Integrates the editor with the component by attaching related event listeners. | ||
@@ -373,2 +533,3 @@ * @private | ||
tagName: [{ type: Input }], | ||
watchdog: [{ type: Input }], | ||
disabled: [{ type: Input }], | ||
@@ -378,3 +539,4 @@ ready: [{ type: Output }], | ||
blur: [{ type: Output }], | ||
focus: [{ type: Output }] | ||
focus: [{ type: Output }], | ||
error: [{ type: Output }] | ||
}; | ||
@@ -381,0 +543,0 @@ |
@@ -1,2 +0,3 @@ | ||
import { __assign } from 'tslib'; | ||
import { __awaiter, __generator, __assign } from 'tslib'; | ||
import EditorWatchdog from '@ckeditor/ckeditor5-watchdog/src/editorwatchdog'; | ||
import { Component, Input, Output, NgZone, EventEmitter, forwardRef, ElementRef, NgModule } from '@angular/core'; | ||
@@ -11,3 +12,3 @@ import { CommonModule } from '@angular/common'; | ||
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -65,2 +66,18 @@ */ | ||
CKEditor5.Editor = Editor; | ||
/** | ||
* @record | ||
*/ | ||
function ContextWatchdog() { } | ||
CKEditor5.ContextWatchdog = ContextWatchdog; | ||
/** | ||
* @record | ||
*/ | ||
function EditorWatchdog$$1() { } | ||
CKEditor5.EditorWatchdog = EditorWatchdog$$1; | ||
/** | ||
* @record | ||
* @template T | ||
*/ | ||
function Watchdog() { } | ||
CKEditor5.Watchdog = Watchdog; | ||
})(CKEditor5 || (CKEditor5 = {})); | ||
@@ -72,2 +89,71 @@ | ||
*/ | ||
/** | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license | ||
*/ | ||
// A copy of @ckeditor/ckeditor5-utils/src/uid.js | ||
// A hash table of hex numbers to avoid using toString() in uid() which is costly. | ||
// [ '00', '01', '02', ..., 'fe', 'ff' ] | ||
var ɵ0 = /** | ||
* @param {?} val | ||
* @param {?} index | ||
* @return {?} | ||
*/ | ||
function (val, index) { return ('0' + (index).toString(16)).slice(-2); }; | ||
/** @type {?} */ | ||
var HEX_NUMBERS = new Array(256).fill(0) | ||
.map((ɵ0)); | ||
/** | ||
* Returns a unique id. The id starts with an "e" character and a randomly generated string of | ||
* 32 alphanumeric characters. | ||
* | ||
* **Note**: The characters the unique id is built from correspond to the hex number notation | ||
* (from "0" to "9", from "a" to "f"). In other words, each id corresponds to an "e" followed | ||
* by 16 8-bit numbers next to each other. | ||
* | ||
* @return {?} An unique id string. | ||
*/ | ||
function uid() { | ||
// Let's create some positive random 32bit integers first. | ||
// | ||
// 1. Math.random() is a float between 0 and 1. | ||
// 2. 0x100000000 is 2^32 = 4294967296. | ||
// 3. >>> 0 enforces integer (in JS all numbers are floating point). | ||
// | ||
// For instance: | ||
// Math.random() * 0x100000000 = 3366450031.853859 | ||
// but | ||
// Math.random() * 0x100000000 >>> 0 = 3366450031. | ||
/** @type {?} */ | ||
var r1 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
var r2 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
var r3 = Math.random() * 0x100000000 >>> 0; | ||
/** @type {?} */ | ||
var r4 = Math.random() * 0x100000000 >>> 0; | ||
// Make sure that id does not start with number. | ||
return 'e' + | ||
HEX_NUMBERS[r1 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r1 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r2 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r3 >> 24 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 0 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 8 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 16 & 0xFF] + | ||
HEX_NUMBERS[r4 >> 24 & 0xFF]; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var CKEditorComponent = /** @class */ (function () { | ||
@@ -117,5 +203,5 @@ function CKEditorComponent(elementRef, ngZone) { | ||
/** | ||
* The instance of the editor created by this component. | ||
* Fires when the editor component crashes. | ||
*/ | ||
this.editorInstance = null; | ||
this.error = new EventEmitter(); | ||
/** | ||
@@ -130,2 +216,3 @@ * If the component is read–only before the editor instance is created, it remembers that state, | ||
this.isEditorSettingData = false; | ||
this.id = uid(); | ||
this.ngZone = ngZone; | ||
@@ -162,2 +249,22 @@ this.elementRef = elementRef; | ||
}); | ||
Object.defineProperty(CKEditorComponent.prototype, "editorInstance", { | ||
/** | ||
* The instance of the editor created by this component. | ||
*/ | ||
get: /** | ||
* The instance of the editor created by this component. | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (this.editorWatchdog) { | ||
return this.editorWatchdog.editor; | ||
} | ||
if (this.watchdog) { | ||
return this.watchdog.getItem(this.id); | ||
} | ||
return null; | ||
}, | ||
enumerable: true, | ||
configurable: true | ||
}); | ||
// Implementing the AfterViewInit interface. | ||
@@ -174,9 +281,3 @@ // Implementing the AfterViewInit interface. | ||
function () { | ||
var _this = this; | ||
this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.createEditor(); | ||
})); | ||
this.attachToWatchdog(); | ||
}; | ||
@@ -194,6 +295,22 @@ // Implementing the OnDestroy interface. | ||
function () { | ||
if (this.editorInstance) { | ||
this.editorInstance.destroy(); | ||
this.editorInstance = null; | ||
} | ||
return __awaiter(this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
if (!this.watchdog) return [3 /*break*/, 2]; | ||
return [4 /*yield*/, this.watchdog.remove(this.id)]; | ||
case 1: | ||
_a.sent(); | ||
return [3 /*break*/, 4]; | ||
case 2: | ||
if (!(this.editorWatchdog && this.editorWatchdog.editor)) return [3 /*break*/, 4]; | ||
return [4 /*yield*/, this.editorWatchdog.destroy()]; | ||
case 3: | ||
_a.sent(); | ||
this.editorWatchdog = undefined; | ||
_a.label = 4; | ||
case 4: return [2 /*return*/]; | ||
} | ||
}); | ||
}); | ||
}; | ||
@@ -279,10 +396,8 @@ // Implementing the ControlValueAccessor interface (only when binding to ngModel). | ||
function (isDisabled) { | ||
// If already initialized | ||
// If already initialized. | ||
if (this.editorInstance) { | ||
this.editorInstance.isReadOnly = isDisabled; | ||
} | ||
// If not, wait for it to be ready; store the state. | ||
else { | ||
this.initialIsDisabled = isDisabled; | ||
} | ||
// Store the state anyway to use it once the editor is created. | ||
this.initialIsDisabled = isDisabled; | ||
}; | ||
@@ -301,3 +416,3 @@ /** | ||
*/ | ||
CKEditorComponent.prototype.createEditor = /** | ||
CKEditorComponent.prototype.attachToWatchdog = /** | ||
* Creates the editor instance, sets initial editor data, then integrates | ||
@@ -312,21 +427,60 @@ * the editor with the Angular component. This method does not use the `editor.setData()` | ||
/** @type {?} */ | ||
var element = document.createElement(this.tagName); | ||
this.editorElement = element; | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
var creator = (/** | ||
* @param {?} element | ||
* @param {?} config | ||
* @return {?} | ||
*/ | ||
function (element, config) { return __awaiter(_this, void 0, void 0, function () { | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
return [2 /*return*/, this.ngZone.runOutsideAngular((/** | ||
* @return {?} | ||
*/ | ||
function () { return __awaiter(_this, void 0, void 0, function () { | ||
var editor; | ||
var _this = this; | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: | ||
this.elementRef.nativeElement.appendChild(element); | ||
return [4 /*yield*/, (/** @type {?} */ (this.editor)).create(element, config)]; | ||
case 1: | ||
editor = _a.sent(); | ||
if (this.initialIsDisabled) { | ||
editor.isReadOnly = this.initialIsDisabled; | ||
} | ||
this.ngZone.run((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.ready.emit(editor); | ||
})); | ||
this.setUpEditorEvents(editor); | ||
return [2 /*return*/, editor]; | ||
} | ||
}); | ||
}); }))]; | ||
}); | ||
}); }); | ||
/** @type {?} */ | ||
var config = __assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
this.elementRef.nativeElement.appendChild(element); | ||
return (/** @type {?} */ (this.editor)).create(element, config) | ||
.then((/** | ||
var destructor = (/** | ||
* @param {?} editor | ||
* @return {?} | ||
*/ | ||
function (editor) { | ||
_this.editorInstance = editor; | ||
if (_this.initialIsDisabled) { | ||
editor.isReadOnly = _this.initialIsDisabled; | ||
} | ||
function (editor) { return __awaiter(_this, void 0, void 0, function () { | ||
return __generator(this, function (_a) { | ||
switch (_a.label) { | ||
case 0: return [4 /*yield*/, editor.destroy()]; | ||
case 1: | ||
_a.sent(); | ||
this.elementRef.nativeElement.removeChild((/** @type {?} */ (this.editorElement))); | ||
return [2 /*return*/]; | ||
} | ||
}); | ||
}); }); | ||
/** @type {?} */ | ||
var emitError = (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.ngZone.run((/** | ||
@@ -336,15 +490,60 @@ * @return {?} | ||
function () { | ||
_this.ready.emit(editor); | ||
_this.error.emit(); | ||
})); | ||
_this.setUpEditorEvents(editor); | ||
})) | ||
.catch((/** | ||
* @param {?} err | ||
* @return {?} | ||
*/ | ||
function (err) { | ||
console.error(err.stack); | ||
})); | ||
}); | ||
/** @type {?} */ | ||
var element = document.createElement(this.tagName); | ||
/** @type {?} */ | ||
var config = this.getConfig(); | ||
this.editorElement = element; | ||
// Based on the presence of the watchdog decide how to initialize the editor. | ||
if (this.watchdog) { | ||
// When the context watchdog is passed add the new item to it based on the passed configuration. | ||
this.watchdog.add({ | ||
id: this.id, | ||
type: 'editor', | ||
creator: creator, | ||
destructor: destructor, | ||
sourceElementOrData: element, | ||
config: config | ||
}); | ||
this.watchdog.on('itemError', (/** | ||
* @param {?} _ | ||
* @param {?} __1 | ||
* @return {?} | ||
*/ | ||
function (_, _a) { | ||
var itemId = _a.itemId; | ||
if (itemId === _this.id) { | ||
emitError(); | ||
} | ||
})); | ||
} | ||
else { | ||
// In the other case create the watchdog by hand to keep the editor running. | ||
/** @type {?} */ | ||
var editorWatchdog = new EditorWatchdog(this.editor); | ||
editorWatchdog.setCreator(creator); | ||
editorWatchdog.setDestructor(destructor); | ||
editorWatchdog.on('error', emitError); | ||
this.editorWatchdog = editorWatchdog; | ||
this.editorWatchdog.create(element, config); | ||
} | ||
}; | ||
/** | ||
* @private | ||
* @return {?} | ||
*/ | ||
CKEditorComponent.prototype.getConfig = /** | ||
* @private | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (this.data && this.config.initialData) { | ||
throw new Error('Editor data should be provided either using `config.initialData` or `data` properties.'); | ||
} | ||
// Merge two possible ways of providing data into the `config.initialData` field. | ||
return __assign({}, this.config, { initialData: this.config.initialData || this.data || '' }); | ||
}; | ||
/** | ||
* Integrates the editor with the component by attaching related event listeners. | ||
@@ -443,2 +642,3 @@ */ | ||
tagName: [{ type: Input }], | ||
watchdog: [{ type: Input }], | ||
disabled: [{ type: Input }], | ||
@@ -448,3 +648,4 @@ ready: [{ type: Output }], | ||
blur: [{ type: Output }], | ||
focus: [{ type: Output }] | ||
focus: [{ type: Output }], | ||
error: [{ type: Output }] | ||
}; | ||
@@ -451,0 +652,0 @@ return CKEditorComponent; |
/** | ||
* @license Copyright (c) 2003-2019, CKSource - Frederico Knabben. All rights reserved. | ||
* @license Copyright (c) 2003-2020, CKSource - Frederico Knabben. All rights reserved. | ||
* For licensing, see LICENSE.md. | ||
@@ -4,0 +4,0 @@ */ |
@@ -5,3 +5,3 @@ Software License Agreement | ||
**CKEditor 5 component for Angular** – https://github.com/ckeditor/ckeditor5-angular <br> | ||
Copyright (c) 2003-2019, [CKSource](http://cksource.com) Frederico Knabben. All rights reserved. | ||
Copyright (c) 2003-2020, [CKSource](http://cksource.com) Frederico Knabben. All rights reserved. | ||
@@ -8,0 +8,0 @@ Licensed under the terms of [GNU General Public License Version 2 or later](http://www.gnu.org/licenses/gpl.html). |
{ | ||
"name": "@ckeditor/ckeditor5-angular", | ||
"version": "1.1.2", | ||
"version": "1.2.0", | ||
"description": "Official Angular component for CKEditor 5 – the best browser-based rich text editor.", | ||
@@ -5,0 +5,0 @@ "keywords": [ |
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
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
369540
32
4135
0