ngx-firebase-cms
Version:
Angular Content Management System using Google Firebase (Authentication, Storage & Firestore)
388 lines • 33.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, ViewChild, EventEmitter, Renderer2, Inject, forwardRef } from '@angular/core';
import { DOCUMENT } from '@angular/common';
import { EditorService } from '../../service/editor.service';
import { EditorToolbarComponent } from '../editor-toolbar/editor-toolbar.component';
import { angularEditorConfig } from '../../interface/editor';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
var EditorComponent = /** @class */ (function () {
function EditorComponent(_renderer, editorService, _document) {
this._renderer = _renderer;
this.editorService = editorService;
this._document = _document;
this.modeVisual = true;
this.showPlaceholder = false;
this.id = '';
this.config = angularEditorConfig;
this.viewMode = new EventEmitter();
this.blur = new EventEmitter();
this.focus = new EventEmitter();
}
/**
* @return {?}
*/
EditorComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.editorToolbar.id = this.id;
this.editorToolbar.fonts = this.config.fonts ? this.config.fonts : angularEditorConfig.fonts;
this.editorToolbar.customClasses = this.config.customClasses;
this.editorService.uploadUrl = this.config.uploadUrl;
if (this.config.showToolbar !== undefined) {
this.editorToolbar.showToolbar = this.config.showToolbar;
}
if (this.config.defaultParagraphSeparator) {
this.editorService.setDefaultParagraphSeparator(this.config.defaultParagraphSeparator);
}
};
/**
* @return {?}
*/
EditorComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
if (this.config.defaultFontName) {
this.editorToolbar.defaultFontId = this.config.defaultFontName ? this.editorToolbar.fonts.findIndex((/**
* @param {?} x
* @return {?}
*/
function (x) {
return x.name === _this.config.defaultFontName;
})) : 0;
this.editorToolbar.fontId = this.editorToolbar.defaultFontId;
this.onEditorFocus();
this.editorService.setFontName(this.config.defaultFontName);
}
else {
this.editorToolbar.defaultFontId = 0;
this.editorToolbar.fontId = 0;
}
if (this.config.defaultFontSize) {
this.editorToolbar.fontSize = this.config.defaultFontSize;
this.onEditorFocus();
this.editorService.setFontSize(this.config.defaultFontSize);
}
};
/**
* @param {?} command
* @return {?}
*/
EditorComponent.prototype.executeCommand = /**
* @param {?} command
* @return {?}
*/
function (command) {
if (command === 'toggleEditorMode') {
this.toggleEditorMode(this.modeVisual);
}
else if (command !== '') {
this.editorService.executeCommand(command);
this.exec();
}
this.onEditorFocus();
};
/**
* @return {?}
*/
EditorComponent.prototype.onTextAreaFocus = /**
* @return {?}
*/
function () {
this.focus.emit('focus');
};
/**
* @param {?} event
* @return {?}
*/
EditorComponent.prototype.onTextAreaBlur = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.editorService.saveSelection();
if (typeof this.onTouched === 'function') {
this.onTouched();
}
if (event.relatedTarget != null && ((/** @type {?} */ (event.relatedTarget))).parentElement.className !== 'angular-editor-toolbar-set') {
this.blur.emit('blur');
}
};
/**
* @return {?}
*/
EditorComponent.prototype.onEditorFocus = /**
* @return {?}
*/
function () {
this.textArea.nativeElement.focus();
};
/**
* @param {?} html
* @return {?}
*/
EditorComponent.prototype.onContentChange = /**
* @param {?} html
* @return {?}
*/
function (html) {
if (typeof this.onChange === 'function') {
this.onChange(html);
if ((!html || html === '<br>' || html === '') !== this.showPlaceholder) {
this.togglePlaceholder(this.showPlaceholder);
}
}
};
/**
* @param {?} fn
* @return {?}
*/
EditorComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
EditorComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @param {?} value
* @return {?}
*/
EditorComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if ((!value || value === '<br>' || value === '') !== this.showPlaceholder) {
this.togglePlaceholder(this.showPlaceholder);
}
if (value === null || value === undefined || value === '' || value === '<br>') {
value = null;
}
this.refreshView(value);
};
/**
* @param {?} value
* @return {?}
*/
EditorComponent.prototype.refreshView = /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var normalizedValue = value === null ? '' : value;
this._renderer.setProperty(this.textArea.nativeElement, 'innerHTML', normalizedValue);
return;
};
/**
* @param {?} value
* @return {?}
*/
EditorComponent.prototype.togglePlaceholder = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (!value) {
this._renderer.addClass(this.editorWrapper.nativeElement, 'show-placeholder');
this.showPlaceholder = true;
}
else {
this._renderer.removeClass(this.editorWrapper.nativeElement, 'show-placeholder');
this.showPlaceholder = false;
}
};
/**
* @param {?} isDisabled
* @return {?}
*/
EditorComponent.prototype.setDisabledState = /**
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
/** @type {?} */
var div = this.textArea.nativeElement;
/** @type {?} */
var action = isDisabled ? 'addClass' : 'removeClass';
this._renderer[action](div, 'disabled');
};
/**
* @param {?} bToSource
* @return {?}
*/
EditorComponent.prototype.toggleEditorMode = /**
* @param {?} bToSource
* @return {?}
*/
function (bToSource) {
/** @type {?} */
var oContent;
/** @type {?} */
var editableElement = this.textArea.nativeElement;
if (bToSource) {
oContent = this._document.createTextNode(editableElement.innerHTML);
editableElement.innerHTML = '';
/** @type {?} */
var oPre = this._document.createElement('pre');
oPre.setAttribute("style", "margin: 0; outline: none;");
/** @type {?} */
var oCode = this._document.createElement('code');
editableElement.contentEditable = false;
oCode.id = "sourceText";
oCode.setAttribute("style", "white-space: pre-wrap; word-break: keep-all; margin: 0; outline: none; background-color: #fff5b9;");
oCode.contentEditable = 'true';
oCode.appendChild(oContent);
oPre.appendChild(oCode);
editableElement.appendChild(oPre);
this._document.execCommand("defaultParagraphSeparator", false, "div");
this.modeVisual = false;
this.viewMode.emit(false);
oCode.focus();
}
else {
if (this._document.all) {
editableElement.innerHTML = editableElement.innerText;
}
else {
oContent = this._document.createRange();
oContent.selectNodeContents(editableElement.firstChild);
editableElement.innerHTML = oContent.toString();
}
editableElement.contentEditable = true;
this.modeVisual = true;
this.viewMode.emit(true);
this.onContentChange(editableElement.innerHTML);
editableElement.focus();
}
this.editorToolbar.setEditorMode(!this.modeVisual);
};
/**
* @return {?}
*/
EditorComponent.prototype.exec = /**
* @return {?}
*/
function () {
this.editorToolbar.triggerButtons();
/** @type {?} */
var userSelection;
if (window.getSelection) {
userSelection = window.getSelection();
}
/** @type {?} */
var a = userSelection.focusNode;
/** @type {?} */
var els = [];
while (a && a.id !== 'editor') {
els.unshift(a);
a = a.parentNode;
}
this.editorToolbar.triggerBlocks(els);
};
EditorComponent.decorators = [
{ type: Component, args: [{
selector: 'aq-editor',
template: "<div (focus)=\"onEditorFocus()\" class=\"angular-editor\" id=\"angularEditor\" [style.width]=\"config.width\" [style.minWidth]=\"config.minWidth\">\n <aq-editor-toolbar #editorToolbar (execute)=\"executeCommand($event)\"></aq-editor-toolbar>\n <div class=\"angular-editor-wrapper\" #editorWrapper>\n <div #editor id=\"editor\" class=\"angular-editor-textarea\" [attr.contenteditable]=\"config.editable\"\n [attr.translate]=\"config.translate\" [attr.spellcheck]=\"config.spellcheck\" [style.height]=\"config.height\"\n [style.minHeight]=\"config.minHeight\" [style.maxHeight]=\"config.maxHeight\"\n (input)=\"onContentChange($event.target.innerHTML)\" (focus)=\"onTextAreaFocus()\" (blur)=\"onTextAreaBlur($event)\"\n (click)=\"exec()\" (keyup)=\"exec()\">\n </div>\n <span class=\"angular-editor-placeholder\">{{ placeholder || config['placeholder'] }}</span>\n </div>\n</div>",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return EditorComponent; })),
multi: true
}
],
styles: [".angular-editor{position:relative}.angular-editor ::ng-deep [contenteditable=true]:empty:before{content:attr(placeholder);color:#868e96;opacity:1}.angular-editor .angular-editor-wrapper{position:relative}.angular-editor .angular-editor-wrapper .angular-editor-textarea{min-height:5rem;padding:.5rem .8rem 1rem;border:1px solid #ddd;background-color:transparent;overflow-x:hidden;overflow-y:auto;z-index:2;position:relative}.angular-editor .angular-editor-wrapper .angular-editor-textarea.focus,.angular-editor .angular-editor-wrapper .angular-editor-textarea:focus{outline:0}.angular-editor .angular-editor-wrapper .angular-editor-textarea ::ng-deep blockquote{margin-left:1rem;border-left:.2em solid #dfe2e5;padding-left:.5rem}.angular-editor .angular-editor-wrapper ::ng-deep p{margin-bottom:0}.angular-editor .angular-editor-wrapper .angular-editor-placeholder{display:none;position:absolute;top:0;padding:.5rem .8rem 1rem .9rem;z-index:1;color:#6c757d;opacity:.75}.angular-editor .angular-editor-wrapper.show-placeholder .angular-editor-placeholder{display:block}.angular-editor .angular-editor-wrapper.disabled{cursor:not-allowed;opacity:.5;pointer-events:none}"]
}] }
];
/** @nocollapse */
EditorComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: EditorService },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
]; };
EditorComponent.propDecorators = {
id: [{ type: Input }],
config: [{ type: Input }],
textArea: [{ type: ViewChild, args: ['editor',] }],
editorWrapper: [{ type: ViewChild, args: ['editorWrapper',] }],
editorToolbar: [{ type: ViewChild, args: ['editorToolbar',] }],
html: [{ type: Output }],
viewMode: [{ type: Output }],
blur: [{ type: Output }],
focus: [{ type: Output }]
};
return EditorComponent;
}());
export { EditorComponent };
if (false) {
/**
* @type {?}
* @private
*/
EditorComponent.prototype.onChange;
/**
* @type {?}
* @private
*/
EditorComponent.prototype.onTouched;
/** @type {?} */
EditorComponent.prototype.placeholder;
/** @type {?} */
EditorComponent.prototype.modeVisual;
/** @type {?} */
EditorComponent.prototype.showPlaceholder;
/** @type {?} */
EditorComponent.prototype.id;
/** @type {?} */
EditorComponent.prototype.config;
/** @type {?} */
EditorComponent.prototype.textArea;
/** @type {?} */
EditorComponent.prototype.editorWrapper;
/** @type {?} */
EditorComponent.prototype.editorToolbar;
/** @type {?} */
EditorComponent.prototype.html;
/** @type {?} */
EditorComponent.prototype.viewMode;
/** @type {?} */
EditorComponent.prototype.blur;
/** @type {?} */
EditorComponent.prototype.focus;
/**
* @type {?}
* @private
*/
EditorComponent.prototype._renderer;
/**
* @type {?}
* @private
*/
EditorComponent.prototype.editorService;
/**
* @type {?}
* @private
*/
EditorComponent.prototype._document;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"ng://ngx-firebase-cms/","sources":["lib/directive/editor/editor.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAoB,MAAM,eAAe,CAAC;AAC3I,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAuB,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAClF,OAAO,EAAE,iBAAiB,EAAwB,MAAM,gBAAgB,CAAC;AAEzE;IA8BE,yBACU,SAAoB,EACpB,aAA4B,EACV,SAAc;QAFhC,cAAS,GAAT,SAAS,CAAW;QACpB,kBAAa,GAAb,aAAa,CAAe;QACV,cAAS,GAAT,SAAS,CAAK;QAf1C,eAAU,GAAG,IAAI,CAAA;QACjB,oBAAe,GAAG,KAAK,CAAA;QACd,OAAE,GAAG,EAAE,CAAA;QACP,WAAM,GAAwB,mBAAmB,CAAA;QAKhD,aAAQ,GAAG,IAAI,YAAY,EAAW,CAAA;QACtC,SAAI,GAAyB,IAAI,YAAY,EAAU,CAAA;QACvD,UAAK,GAAyB,IAAI,YAAY,EAAU,CAAA;IAMlE,CAAC;;;;IAED,kCAAQ;;;IAAR;QACE,IAAI,CAAC,aAAa,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,mBAAmB,CAAC,KAAK,CAAC;QAC7F,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC;QAC7D,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;QACrD,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,KAAK,SAAS,EAAE;YACzC,IAAI,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;SAC1D;QACD,IAAI,IAAI,CAAC,MAAM,CAAC,yBAAyB,EAAE;YACzC,IAAI,CAAC,aAAa,CAAC,4BAA4B,CAAC,IAAI,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAC;SACxF;IACH,CAAC;;;;IAED,4CAAkB;;;IAAlB;QAAA,iBAiBC;QAhBC,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE;YAC/B,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS;;;;YAAC,UAAA,CAAC;gBACnG,OAAO,CAAC,CAAC,IAAI,KAAK,KAAI,CAAC,MAAM,CAAC,eAAe,CAAC;YAChD,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACP,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;YAC7D,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;SAC7D;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,CAAC,CAAC;YACrC,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;SAC/B;QACD,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE;YAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC;YAC1D,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;SAC7D;IACH,CAAC;;;;;IAED,wCAAc;;;;IAAd,UAAe,OAAe;QAC5B,IAAI,OAAO,KAAK,kBAAkB,EAAE;YAClC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACxC;aAAM,IAAI,OAAO,KAAK,EAAE,EAAE;YACzB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YAC3C,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;;;;IAED,yCAAe;;;IAAf;QACE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC3B,CAAC;;;;;IAED,wCAAc;;;;IAAd,UAAe,KAAiB;QAC9B,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAA;QAClC,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,UAAU,EAAE;YACxC,IAAI,CAAC,SAAS,EAAE,CAAA;SACjB;QACD,IAAI,KAAK,CAAC,aAAa,IAAI,IAAI,IAAI,CAAC,mBAAA,KAAK,CAAC,aAAa,EAAe,CAAC,CAAC,aAAa,CAAC,SAAS,KAAK,4BAA4B,EAAE;YAChI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;SACvB;IACH,CAAC;;;;IAED,uCAAa;;;IAAb;QACE,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAA;IACrC,CAAC;;;;;IAED,yCAAe;;;;IAAf,UAAgB,IAAY;QAC1B,IAAI,OAAO,IAAI,CAAC,QAAQ,KAAK,UAAU,EAAE;YACvC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC,eAAe,EAAE;gBACtE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;aAC9C;SACF;IACH,CAAC;;;;;IAED,0CAAgB;;;;IAAhB,UAAiB,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;;;;;IAED,2CAAiB;;;;IAAjB,UAAkB,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;IAED,oCAAU;;;;IAAV,UAAW,KAAU;QACnB,IAAI,CAAC,CAAC,KAAK,IAAI,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC,eAAe,EAAE;YACzE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC9C;QACD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,EAAE,IAAI,KAAK,KAAK,MAAM,EAAE;YAC7E,KAAK,GAAG,IAAI,CAAC;SACd;QACD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;;;;;IAED,qCAAW;;;;IAAX,UAAY,KAAa;;YACjB,eAAe,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK;QACnD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,eAAe,CAAC,CAAA;QACrF,OAAM;IACR,CAAC;;;;;IAED,2CAAiB;;;;IAAjB,UAAkB,KAAc;QAC9B,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAC;YAC9E,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAC;YACjF,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;SAC9B;IACH,CAAC;;;;;IAED,0CAAgB;;;;IAAhB,UAAiB,UAAmB;;YAC5B,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa;;YACjC,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa;QACtD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;IAC1C,CAAC;;;;;IAED,0CAAgB;;;;IAAhB,UAAiB,SAAkB;;YAC7B,QAAa;;YACX,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa;QAEnD,IAAI,SAAS,EAAE;YACb,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;YACpE,eAAe,CAAC,SAAS,GAAG,EAAE,CAAC;;gBAEzB,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC;YAChD,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,2BAA2B,CAAC,CAAC;;gBAClD,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,CAAC;YAClD,eAAe,CAAC,eAAe,GAAG,KAAK,CAAC;YACxC,KAAK,CAAC,EAAE,GAAG,YAAY,CAAC;YACxB,KAAK,CAAC,YAAY,CAAC,OAAO,EAAE,mGAAmG,CAAC,CAAC;YACjI,KAAK,CAAC,eAAe,GAAG,MAAM,CAAC;YAC/B,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAC5B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACxB,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAElC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,2BAA2B,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;YAEtE,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,KAAK,CAAC,KAAK,EAAE,CAAC;SACf;aAAM;YACL,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE;gBACtB,eAAe,CAAC,SAAS,GAAG,eAAe,CAAC,SAAS,CAAC;aACvD;iBAAM;gBACL,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;gBACxC,QAAQ,CAAC,kBAAkB,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;gBACxD,eAAe,CAAC,SAAS,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;aACjD;YACD,eAAe,CAAC,eAAe,GAAG,IAAI,CAAC;YACvC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzB,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;YAChD,eAAe,CAAC,KAAK,EAAE,CAAC;SACzB;QACD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACrD,CAAC;;;;IAED,8BAAI;;;IAAJ;QACE,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;;YAEhC,aAAa;QACjB,IAAI,MAAM,CAAC,YAAY,EAAE;YACvB,aAAa,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;SACvC;;YAEG,CAAC,GAAG,aAAa,CAAC,SAAS;;YACzB,GAAG,GAAG,EAAE;QACd,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,QAAQ,EAAE;YAC7B,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACf,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC;SAClB;QACD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IACxC,CAAC;;gBA1MF,SAAS,SAAC;oBACT,QAAQ,EAAE,WAAW;oBACrB,y5BAAsC;oBAEtC,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU;;;4BAAC,cAAM,OAAA,eAAe,EAAf,CAAe,EAAC;4BAC9C,KAAK,EAAE,IAAI;yBACZ;qBACF;;iBACF;;;;gBAlBmE,SAAS;gBAEpE,aAAa;gDAsCjB,MAAM,SAAC,QAAQ;;;qBAbjB,KAAK;yBACL,KAAK;2BACL,SAAS,SAAC,QAAQ;gCAClB,SAAS,SAAC,eAAe;gCACzB,SAAS,SAAC,eAAe;uBACzB,MAAM;2BACN,MAAM;uBACN,MAAM;wBACN,MAAM;;IAgLT,sBAAC;CAAA,AA5MD,IA4MC;SAhMY,eAAe;;;;;;IAE1B,mCAAyC;;;;;IACzC,oCAA6B;;IAE7B,sCAAoB;;IACpB,qCAAiB;;IACjB,0CAAuB;;IACvB,6BAAgB;;IAChB,iCAA0D;;IAC1D,mCAAkC;;IAClC,wCAA8C;;IAC9C,wCAAiE;;IACjE,+BAAc;;IACd,mCAAgD;;IAChD,+BAAiE;;IACjE,gCAAkE;;;;;IAGhE,oCAA4B;;;;;IAC5B,wCAAoC;;;;;IACpC,oCAAwC","sourcesContent":["import { Component, OnInit, Input, Output, ViewChild, EventEmitter, Renderer2, Inject, forwardRef, AfterContentInit } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { EditorService } from '../../service/editor.service';\nimport { EditorToolbarComponent } from '../editor-toolbar/editor-toolbar.component';\nimport { AngularEditorConfig, angularEditorConfig } from '../../interface/editor';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\n\n@Component({\n  selector: 'aq-editor',\n  templateUrl: './editor.component.html',\n  styleUrls: ['./editor.component.css'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => EditorComponent),\n      multi: true\n    }\n  ]\n})\nexport class EditorComponent implements OnInit, ControlValueAccessor, AfterContentInit {\n\n  private onChange: (value: string) => void\n  private onTouched: () => void\n\n  placeholder: boolean\n  modeVisual = true\n  showPlaceholder = false\n  @Input() id = ''\n  @Input() config: AngularEditorConfig = angularEditorConfig\n  @ViewChild('editor') textArea: any\n  @ViewChild('editorWrapper') editorWrapper: any\n  @ViewChild('editorToolbar') editorToolbar: EditorToolbarComponent\n  @Output() html\n  @Output() viewMode = new EventEmitter<boolean>()\n  @Output() blur: EventEmitter<string> = new EventEmitter<string>()\n  @Output() focus: EventEmitter<string> = new EventEmitter<string>()\n\n  constructor(\n    private _renderer: Renderer2, \n    private editorService: EditorService, \n    @Inject(DOCUMENT) private _document: any) {\n  }\n\n  ngOnInit() {\n    this.editorToolbar.id = this.id;\n    this.editorToolbar.fonts = this.config.fonts ? this.config.fonts : angularEditorConfig.fonts;\n    this.editorToolbar.customClasses = this.config.customClasses;\n    this.editorService.uploadUrl = this.config.uploadUrl;\n    if (this.config.showToolbar !== undefined) {\n      this.editorToolbar.showToolbar = this.config.showToolbar;\n    }\n    if (this.config.defaultParagraphSeparator) {\n      this.editorService.setDefaultParagraphSeparator(this.config.defaultParagraphSeparator);\n    }\n  }\n\n  ngAfterContentInit() {\n    if (this.config.defaultFontName) {\n      this.editorToolbar.defaultFontId = this.config.defaultFontName ? this.editorToolbar.fonts.findIndex(x => {\n        return x.name === this.config.defaultFontName;\n      }) : 0;\n      this.editorToolbar.fontId = this.editorToolbar.defaultFontId;\n      this.onEditorFocus();\n      this.editorService.setFontName(this.config.defaultFontName);\n    } else {\n      this.editorToolbar.defaultFontId = 0;\n      this.editorToolbar.fontId = 0;\n    }\n    if (this.config.defaultFontSize) {\n      this.editorToolbar.fontSize = this.config.defaultFontSize;\n      this.onEditorFocus();\n      this.editorService.setFontSize(this.config.defaultFontSize);\n    }\n  }\n\n  executeCommand(command: string) {\n    if (command === 'toggleEditorMode') {\n      this.toggleEditorMode(this.modeVisual);\n    } else if (command !== '') {\n      this.editorService.executeCommand(command);\n      this.exec();\n    }\n\n    this.onEditorFocus();\n  }\n\n  onTextAreaFocus(): void {\n    this.focus.emit('focus');\n  }\n\n  onTextAreaBlur(event: FocusEvent) {\n    this.editorService.saveSelection()\n    if (typeof this.onTouched === 'function') {\n      this.onTouched()\n    }\n    if (event.relatedTarget != null && (event.relatedTarget as HTMLElement).parentElement.className !== 'angular-editor-toolbar-set') {\n      this.blur.emit('blur')\n    }\n  }\n\n  onEditorFocus() {\n    this.textArea.nativeElement.focus()\n  }\n\n  onContentChange(html: string): void {\n    if (typeof this.onChange === 'function') {\n      this.onChange(html);\n      if ((!html || html === '<br>' || html === '') !== this.showPlaceholder) {\n        this.togglePlaceholder(this.showPlaceholder);\n      }\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any): void {\n    if ((!value || value === '<br>' || value === '') !== this.showPlaceholder) {\n      this.togglePlaceholder(this.showPlaceholder);\n    }\n    if (value === null || value === undefined || value === '' || value === '<br>') {\n      value = null;\n    }\n    this.refreshView(value);\n  }\n\n  refreshView(value: string): void {\n    const normalizedValue = value === null ? '' : value\n    this._renderer.setProperty(this.textArea.nativeElement, 'innerHTML', normalizedValue)\n    return\n  }\n\n  togglePlaceholder(value: boolean): void {\n    if (!value) {\n      this._renderer.addClass(this.editorWrapper.nativeElement, 'show-placeholder');\n      this.showPlaceholder = true;\n    } else {\n      this._renderer.removeClass(this.editorWrapper.nativeElement, 'show-placeholder');\n      this.showPlaceholder = false;\n    }\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    const div = this.textArea.nativeElement;\n    const action = isDisabled ? 'addClass' : 'removeClass';\n    this._renderer[action](div, 'disabled');\n  }\n\n  toggleEditorMode(bToSource: boolean) {\n    let oContent: any;\n    const editableElement = this.textArea.nativeElement;\n\n    if (bToSource) {\n      oContent = this._document.createTextNode(editableElement.innerHTML);\n      editableElement.innerHTML = '';\n\n      const oPre = this._document.createElement('pre');\n      oPre.setAttribute(\"style\", \"margin: 0; outline: none;\");\n      const oCode = this._document.createElement('code');\n      editableElement.contentEditable = false;\n      oCode.id = \"sourceText\";\n      oCode.setAttribute(\"style\", \"white-space: pre-wrap; word-break: keep-all; margin: 0; outline: none; background-color: #fff5b9;\");\n      oCode.contentEditable = 'true';\n      oCode.appendChild(oContent);\n      oPre.appendChild(oCode);\n      editableElement.appendChild(oPre);\n\n      this._document.execCommand(\"defaultParagraphSeparator\", false, \"div\");\n\n      this.modeVisual = false;\n      this.viewMode.emit(false);\n      oCode.focus();\n    } else {\n      if (this._document.all) {\n        editableElement.innerHTML = editableElement.innerText;\n      } else {\n        oContent = this._document.createRange();\n        oContent.selectNodeContents(editableElement.firstChild);\n        editableElement.innerHTML = oContent.toString();\n      }\n      editableElement.contentEditable = true;\n      this.modeVisual = true;\n      this.viewMode.emit(true);\n      this.onContentChange(editableElement.innerHTML);\n      editableElement.focus();\n    }\n    this.editorToolbar.setEditorMode(!this.modeVisual);\n  }\n\n  exec() {\n    this.editorToolbar.triggerButtons();\n\n    let userSelection;\n    if (window.getSelection) {\n      userSelection = window.getSelection();\n    }\n\n    let a = userSelection.focusNode;\n    const els = [];\n    while (a && a.id !== 'editor') {\n      els.unshift(a);\n      a = a.parentNode;\n    }\n    this.editorToolbar.triggerBlocks(els);\n  }\n\n}"]}