truly-ui
Version:
Web Components for Desktop Applications.
526 lines (524 loc) • 81.5 kB
JavaScript
/*
MIT License
Copyright (c) 2019 Temainfo Software
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
import { Component, ElementRef, EventEmitter, Input, Optional, Output, Self, ViewChild, } from '@angular/core';
import { trigger, transition, style, animate } from '@angular/animations';
import { ToolbarConfigModel } from './model/toolbar-config.model';
import { Subscription } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "../i18n/i18n.service";
import * as i2 from "./services/editor.service";
import * as i3 from "@angular/platform-browser";
import * as i4 from "@angular/forms";
import * as i5 from "@angular/common";
import * as i6 from "../internals/components/label/label";
import * as i7 from "./parts/editor-link-box/editor-link-box";
import * as i8 from "./parts/editor-image-box/editor-image-box";
import * as i9 from "./parts/editor-header/editor-header";
export class TlEditor {
constructor(i18n, renderer, editorService, sanitizer, cd, ngControl) {
this.i18n = i18n;
this.renderer = renderer;
this.editorService = editorService;
this.sanitizer = sanitizer;
this.cd = cd;
this.ngControl = ngControl;
this.color = 'basic';
this.tags = [];
this.fields = [];
this.height = '300px';
this.labelPlacement = 'top';
this.labelSize = '100px';
this.label = '';
this.editable = true;
this.disabled = false;
this.saveContent = new EventEmitter();
this.fontCollection = [];
this.fontSizeCollection = [];
this.font = 'Arial';
this.fontSize = '3pt';
this.toggleLink = false;
this.toggleImage = false;
this.saved = false;
this.descriptionLink = '';
this.linkItself = '';
this.colorSelected = '#000000';
this.cursorHighlight = false;
this.selectedContent = false;
this.activeTools = {
bold: false,
italic: false,
underline: false,
listUnordered: false,
listOrdered: false,
alignLeft: false,
alignCenter: false,
alignRight: false,
alignJustify: false,
blockQuote: false
};
this.image = { imageUrl: '' };
this.selection = { start: 0, end: 0, baseNode: null, extentNode: null };
this.listenerRegistered = false;
this.subscription = new Subscription();
this.labelAddField = this.i18n.getLocale().Editor.labelAddField;
this.onChange = () => { };
this.onTouched = () => { };
this.setControl();
this.fontCollection = [
{ description: 'Arial', value: 'Arial' },
{ description: 'Verdana', value: 'Verdana' },
{ description: 'Calibri', value: 'Calibri' },
{ description: 'Courier New', value: 'Courier New' },
{ description: 'Georgia', value: 'Georgia' },
{ description: 'Trebuchet MS', value: 'Trebuchet MS' },
{ description: 'Bookman', value: 'Bookman' }
];
this.fontSizeCollection = [
{ description: '10', value: '1pt' },
{ description: '20', value: '2pt' },
{ description: '30', value: '3pt' },
{ description: '40', value: '4pt' },
{ description: '50', value: '5pt' },
{ description: '60', value: '6pt' },
{ description: '70', value: '7pt' }
];
}
get control() {
return this.ngControl?.control;
}
setControl() {
if (this.ngControl) {
this.ngControl.valueAccessor = this;
}
}
ngAfterContentInit() {
this.setContentFocus();
this.toolbarConfig = Object.assign(new ToolbarConfigModel(this.i18n), this.toolbarConfig);
}
handleFieldsPropagation() {
setTimeout(() => {
const fields = this.contentEditor.nativeElement.querySelectorAll('.ui-field');
for (const item of fields) {
this.preventPropagation(item);
}
}, 100);
}
alignContent(align) {
this.setContentFocus();
const element = this.cursorSelection.baseNode.parentNode;
const alignment = align === 'justifyFull' ? 'justify' : align.replace('justify', '').toLocaleLowerCase();
this.renderer.setStyle(element, 'text-align', alignment);
this.setCursorSelection();
}
setBold() {
this.setContentFocus();
document.execCommand('bold', false, null);
this.setCursorSelection();
}
setQuote() {
this.setContentFocus();
this.activeTools.blockQuote = !this.activeTools.blockQuote;
document.execCommand('formatBlock', false, this.activeTools.blockQuote ? 'blockquote' : 'div');
this.setCursorSelection();
}
setItalic() {
this.setContentFocus();
document.execCommand('italic', false, null);
this.setCursorSelection();
}
setUnorderedList() {
this.setContentFocus();
document.execCommand('insertUnorderedList', false, null);
this.setCursorSelection();
}
setOrderedList() {
this.setContentFocus();
document.execCommand('insertOrderedList', false, null);
this.setCursorSelection();
}
setImage($event) {
this.setContentFocus();
this.image.imageUrl = $event.imageUrl;
this.cursorSelection.getRangeAt(0).insertNode(this.createImageElement());
this.toggleImageBox();
}
setDescriptionLink() {
if (this.selectedContent) {
this.descriptionLink = this.anchorNodeCursor.baseNode.nodeValue.substring(this.selection.start, this.selection.end);
return;
}
this.descriptionLink = '';
}
addField(idField) {
this.recoverSelection();
this.setContentFocus();
this.cursorSelection.getRangeAt(0).insertNode(this.createFieldText(idField).nativeElement);
window.getSelection().collapseToEnd();
this.change();
}
addTag(value) {
this.setContentFocus();
this.cursorSelection.getRangeAt(0).insertNode(this.createHashTag(value).nativeElement);
window.getSelection().collapseToEnd();
this.change();
}
setLink($event) {
this.linkItself = $event.link;
this.descriptionLink = $event.description;
this.setContentFocus();
this.recoverSelection();
this.createElementLink();
this.toggleLinkBox();
}
setUnderline() {
this.setContentFocus();
document.execCommand('underline', false, null);
this.setCursorSelection();
}
setHighlight() {
this.wrapper.nativeElement.style.cursor = 'grabbing';
this.cursorHighlight = true;
}
onChangeColor($event) {
document.execCommand('foreColor', false, $event.hex);
}
onChangeFontSize($event) {
this.recoverSelection();
this.setContentFocus();
this.fontSize = $event;
document.execCommand('fontSize', null, this.fontSize);
}
onChangeFont($event) {
this.recoverSelection();
this.setContentFocus();
this.font = $event;
document.execCommand('fontName', false, this.font);
}
onMouseUp() {
this.toggleLink = false;
this.touch();
this.setAnchorNode();
if (this.cursorHighlight) {
document.execCommand('hiliteColor', false, '#f0ef99');
this.cursorHighlight = false;
this.resetCursor();
}
}
onKeyDownSave(event) {
if (this.contentEditor.nativeElement.innerHTML.length === 0 || this.contentEditor.nativeElement.innerHTML === '<br>') {
this.writeValue('<div><br></div>');
}
if ((event.ctrlKey || event.metaKey) && event.which === 83) {
event.preventDefault();
this.save();
return false;
}
}
toggleLinkBox() {
this.toggleLink = !this.toggleLink;
}
toggleImageBox() {
this.toggleImage = !this.toggleImage;
}
save() {
this.saveContent.emit(this.contentEditor.nativeElement.innerHTML);
this.showSavedMessage();
}
setCursorSelection() {
this.cursorSelection = window.getSelection();
if (this.cursorSelection.baseNode) {
this.handleActiveTools();
}
}
showSavedMessage() {
this.saved = true;
clearInterval(this.interval);
this.interval = setInterval(() => {
this.saved = false;
}, 1000);
}
handleActiveTools() {
this.handleClosestBold();
this.handleClosestItalic();
this.handleClosestUnderline();
this.handleColorParent();
this.handleListUnordered();
this.handleListOrdered();
this.handleAlignLeft();
this.handleAlignCenter();
this.handleAlignRight();
this.handleAlignJustify();
this.handleFontSize();
this.handleFontName();
this.handleBlockQuote();
}
handleFontName() {
this.isClosestParentElement('font') && this.hasFontFace()
? this.setFontNodeSelected() : this.setDefaultFont();
}
hasFontFace() {
return this.cursorSelection.baseNode.parentNode.closest('font').getAttribute('face');
}
hasFontSize() {
return this.cursorSelection.baseNode.parentNode.closest('font').getAttribute('size');
}
setFontNodeSelected() {
this.font = this.cursorSelection.baseNode.parentNode.closest('font').getAttribute('face');
}
setDefaultFont() {
this.font = 'Arial';
}
setFontSizeNodeSelected() {
this.fontSize = this.cursorSelection.baseNode.parentNode.closest('font').getAttribute('size') + 'pt';
}
setDefaultFontSize() {
this.fontSize = '3pt';
}
setAnchorNode() {
this.anchorNodeCursor = document.getSelection();
this.selection['start'] = this.anchorNodeCursor.baseOffset;
this.selection['end'] = this.anchorNodeCursor.extentOffset;
this.selection['baseNode'] = this.anchorNodeCursor.baseNode;
this.selection['extentNode'] = this.anchorNodeCursor.extentNode;
this.handleNoSelection();
}
handleNoSelection() {
this.selectedContent = this.hasSelection();
}
hasSelection() {
return (this.selection.end > 0) && (this.selection.end > this.selection.start);
}
handleFontSize() {
this.isClosestParentElement('font') && this.hasFontSize()
? this.setFontSizeNodeSelected() : this.setDefaultFontSize();
}
handleAlignLeft() {
this.activeTools.alignLeft = this.hasStyleParentElement('left');
}
handleAlignCenter() {
this.activeTools.alignCenter = this.hasStyleParentElement('center');
}
handleAlignRight() {
this.activeTools.alignRight = this.hasStyleParentElement('right');
}
handleAlignJustify() {
this.activeTools.alignJustify = this.hasStyleParentElement('justify');
}
handleListOrdered() {
this.activeTools.listOrdered = this.isClosestParentElement('ol');
}
handleListUnordered() {
this.activeTools.listUnordered = this.isClosestParentElement('ul');
}
handleColorParent() {
const getElementFont = this.cursorSelection.baseNode.parentNode.closest('font');
getElementFont ? this.setColorWithColorElement(getElementFont) : this.colorSelected = '#000000';
}
setColorWithColorElement(getElementFont) {
this.colorSelected = getElementFont.getAttribute('color');
}
handleClosestBold() {
this.activeTools.bold = this.isClosestParentElement('b');
}
handleClosestUnderline() {
this.activeTools.underline = this.isClosestParentElement('u');
}
handleClosestItalic() {
this.activeTools.italic = this.isClosestParentElement('i');
}
handleBlockQuote() {
this.activeTools.blockQuote = this.isClosestParentElement('blockquote');
}
hasStyleParentElement(alignment) {
const element = this.cursorSelection.baseNode.parentNode;
if (element.attributes.length > 0) {
return element.attributes[0].value.includes(alignment);
}
return false;
}
isClosestParentElement(element) {
return !!this.cursorSelection.baseNode.parentNode.closest(element);
}
preventPropagation(fieldText) {
this.listenerRegistered = true;
fieldText.addEventListener('input', (e) => {
e.target.setAttribute('value', e.target.value);
});
fieldText.addEventListener('keydown', (e) => {
e.stopPropagation();
});
}
createFieldText(idField) {
const fieldText = new ElementRef(this.renderer.createElement('input'));
this.renderer.addClass(fieldText.nativeElement, 'ui-field');
this.preventPropagation(fieldText.nativeElement);
fieldText.nativeElement.setAttribute('id', idField);
fieldText.nativeElement.placeholder = '';
return fieldText;
}
createHashTag(value) {
const hashTag = new ElementRef(this.renderer.createElement('span'));
this.renderer.addClass(hashTag.nativeElement, 'ui-hashtag');
hashTag.nativeElement.innerText = value;
hashTag.nativeElement.setAttribute('id', value);
hashTag.nativeElement.setAttribute('contenteditable', false);
return hashTag;
}
createImageElement() {
const imageHTML = new ElementRef(this.renderer.createElement('img'));
this.renderer.addClass(imageHTML.nativeElement, 'ui-image-editor');
imageHTML.nativeElement.setAttribute('src', this.image.imageUrl);
return imageHTML.nativeElement;
}
createElementLink() {
const link = new ElementRef(this.renderer.createElement('a'));
this.renderer.addClass(link.nativeElement, 'ui-link');
link.nativeElement.setAttribute('src', this.linkItself);
link.nativeElement.setAttribute('text', this.descriptionLink);
link.nativeElement.setAttribute('target', '_blank');
this.handleAddElementRange(link);
}
handleAddElementRange(link) {
this.selectedContent ? window.getSelection().getRangeAt(0).surroundContents(link.nativeElement) :
window.getSelection().getRangeAt(0).insertNode(link.nativeElement);
}
recoverSelection() {
const selection = document.getSelection();
const range = document.createRange();
if (this.selection.baseNode) {
range.setStart(this.selection.baseNode, this.selection.start);
range.setEnd(this.selection.extentNode, this.selection.end);
selection.removeAllRanges();
selection.addRange(range);
}
}
recoverCursorPosition() {
setTimeout(() => {
const sel = document.getSelection();
const range = new Range();
if (this.selection.baseNode) {
range.selectNodeContents(this.contentEditor.nativeElement);
range.collapse(false);
sel.removeAllRanges();
sel.addRange(range);
}
}, 1);
}
resetCursor() {
this.wrapper.nativeElement.style.cursor = 'auto';
}
setContentFocus() {
this.contentEditor.nativeElement.focus();
}
clearContent() {
this.writeValue('');
this.save();
}
writeValue(value) {
this.content = this.sanitizer.bypassSecurityTrustHtml(value);
this.handleFieldsPropagation();
this.recoverCursorPosition();
this.cd.detectChanges();
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
touch() {
this.onTouched(this.contentEditor.nativeElement.innerHTML);
}
change() {
this.setCursorSelection();
this.onChange(this.contentEditor.nativeElement.innerHTML);
}
ngOnChanges(data) {
}
}
/** @nocollapse */ TlEditor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TlEditor, deps: [{ token: i1.I18nService }, { token: i0.Renderer2 }, { token: i2.EditorService }, { token: i3.DomSanitizer }, { token: i0.ChangeDetectorRef }, { token: i4.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TlEditor.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TlEditor, selector: "tl-editor", inputs: { content: "content", color: "color", tags: "tags", fields: "fields", toolbarConfig: "toolbarConfig", height: "height", labelPlacement: "labelPlacement", labelSize: "labelSize", label: "label", editable: "editable", disabled: "disabled" }, outputs: { saveContent: "saveContent" }, viewQueries: [{ propertyName: "contentEditor", first: true, predicate: ["contentEditor"], descendants: true, static: true }, { propertyName: "linkBox", first: true, predicate: ["linkBox"], descendants: true, static: true }, { propertyName: "wrapper", first: true, predicate: ["wrapper"], descendants: true, static: true }, { propertyName: "fieldTemplate", first: true, predicate: ["fieldTemplate"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"ui-editor\">\n <tl-label *ngIf=\"label\" [labelTitle]=\"label\" [labelSize]=\"labelSize\" [labelPlacement]=\"labelPlacement\"></tl-label>\n <div [class]=\"'ui-editor-wrapper ' + color\" #wrapper>\n <tl-editor-header [toolbarConfig]=\"toolbarConfig\"\n [activeTools]=\"activeTools\"\n [cursorHighlight]=\"cursorHighlight\"\n [labelAddField]=\"labelAddField\"\n [fields]=\"fields\"\n [color]=\"color\"\n [colorSelected]=\"colorSelected\"\n [fontSelected]=\"font\"\n [fontSizeSelected]=\"fontSize\"\n [fontCollection]=\"fontCollection\"\n [fontSizeCollection]=\"fontSizeCollection\"\n (changeColor)=\"onChangeColor($event)\"\n (changeFont)=\"onChangeFont($event)\"\n (changeFontSize)=\"onChangeFontSize($event)\"\n (clickBold)=\"setBold()\"\n (clickItalic)=\"setItalic()\"\n (clickHighlight)=\"setHighlight()\"\n (clickOrderedList)=\"setOrderedList()\"\n (clickAlignContent)=\"alignContent($event)\"\n (clickLink)=\"toggleLinkBox(); setDescriptionLink()\"\n (clickUnorderedList)=\"setUnorderedList()\"\n (clickUnderline)=\"setUnderline()\"\n (clickImage)=\"toggleImageBox()\"\n (clickField)=\"addField($event)\"\n (clickQuote)=\"setQuote()\"\n (clickSave)=\"save()\"\n (clickClear)=\"clearContent()\">\n </tl-editor-header>\n <div #contentEditor\n class=\"ui-editor-content\"\n [class.disabled]=\"disabled\"\n [style.height]=\"height\"\n (input)=\"change()\"\n (focusout)=\"setAnchorNode()\"\n (click)=\"setCursorSelection()\"\n (focus)=\"setCursorSelection()\"\n (keydown.enter)=\"$event.stopPropagation()\"\n (keydown.ArrowUp)=\"$event.stopPropagation()\"\n (keydown.ArrowDown)=\"$event.stopPropagation()\"\n (mouseup)=\"onMouseUp()\"\n [attr.contenteditable]=\"editable || !disabled\"\n [innerHTML]=\"content\">\n </div>\n <div class=\"ui-saved-content-message\" [@enterAnimation]=\"saved\" *ngIf=\"saved\">\n <i class=\"ion-ios-checkmark-outline\"></i>\n <span>Saved !</span>\n </div>\n <tl-editor-link-box [descriptionLink]=\"descriptionLink\"\n *ngIf=\"toggleLink && !toggleImage\"\n (onSetLink)=\"setLink($event)\"\n (onToggleLink)=\"toggleLinkBox()\">\n </tl-editor-link-box>\n <tl-editor-image-box *ngIf=\"toggleImage && !toggleLink\"\n [imageUrl]=\"image.imageUrl\"\n (onSetImage)=\"setImage($event)\"\n (onToggleImage)=\"toggleImageBox()\">\n </tl-editor-image-box>\n <div class=\"ui-editor-footer\" *ngIf=\"tags.length > 0\">\n <div *ngFor=\"let item of tags\" (click)=\"addTag(item)\" class=\"ui-hashtag\">{{ item }}</div>\n </div>\n </div>\n</div>\n", styles: ["*{box-sizing:border-box}:host{width:100%}.ui-editor-footer{display:flex;align-items:flex-start;height:auto;width:100%;background:#e9e9e9;overflow:auto}.ui-editor-footer::-webkit-scrollbar{height:4px;width:0}.ui-editor{width:100%}.ui-link{text-decoration:underline}.ui-editor-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.ui-image-editor{padding:10px;box-sizing:border-box}.ui-image-editor:hover{cursor:pointer}.ui-saved-content-message{position:absolute;top:0;right:0;background:#333;padding:10px;box-sizing:border-box;-webkit-user-select:none;user-select:none;display:grid;grid-template-columns:25px 1fr;text-align:center;border-top-left-radius:0;border-bottom-left-radius:20px}.ui-color-component{position:absolute;height:12px;border:0;top:25px}.ui-editor-content{height:300px;overflow:auto;padding:10px;box-sizing:border-box;outline:none;word-break:break-word;cursor:text}.ui-editor-content.disabled{pointer-events:none;opacity:.5}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.TlLabel, selector: "tl-label", inputs: ["labelPlacement", "required", "labelSize", "labelTitle"] }, { kind: "component", type: i7.TlEditorLinkBox, selector: "tl-editor-link-box", inputs: ["descriptionLink"], outputs: ["onSetLink", "onToggleLink"] }, { kind: "component", type: i8.TlEditorImageBox, selector: "tl-editor-image-box", inputs: ["imageUrl"], outputs: ["onSetImage", "onToggleImage"] }, { kind: "component", type: i9.TlEditorHeader, selector: "tl-editor-header", inputs: ["toolbarConfig", "cursorHighlight", "fontSizeCollection", "fontCollection", "fields", "color", "activeTools", "colorSelected", "fontSelected", "fontSizeSelected", "labelAddField"], outputs: ["changeColor", "changeFont", "changeFontSize", "clickUnderline", "clickItalic", "clickBold", "clickHighlight", "clickAlignContent", "clickUnorderedList", "clickOrderedList", "clickLink", "clickImage", "clickQuote", "clickClear", "clickSave", "clickField"] }], animations: [
trigger('enterAnimation', [
transition(':enter', [
style({ transform: 'translateX(100%)', opacity: 0 }),
animate('250ms', style({ transform: 'translateX(0)', opacity: 1 }))
]),
transition(':leave', [
style({ transform: 'translateX(0)', opacity: 1 }),
animate('250ms', style({ transform: 'translateX(100%)', opacity: 0 }))
])
])
] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TlEditor, decorators: [{
type: Component,
args: [{ selector: 'tl-editor', animations: [
trigger('enterAnimation', [
transition(':enter', [
style({ transform: 'translateX(100%)', opacity: 0 }),
animate('250ms', style({ transform: 'translateX(0)', opacity: 1 }))
]),
transition(':leave', [
style({ transform: 'translateX(0)', opacity: 1 }),
animate('250ms', style({ transform: 'translateX(100%)', opacity: 0 }))
])
])
], template: "<div class=\"ui-editor\">\n <tl-label *ngIf=\"label\" [labelTitle]=\"label\" [labelSize]=\"labelSize\" [labelPlacement]=\"labelPlacement\"></tl-label>\n <div [class]=\"'ui-editor-wrapper ' + color\" #wrapper>\n <tl-editor-header [toolbarConfig]=\"toolbarConfig\"\n [activeTools]=\"activeTools\"\n [cursorHighlight]=\"cursorHighlight\"\n [labelAddField]=\"labelAddField\"\n [fields]=\"fields\"\n [color]=\"color\"\n [colorSelected]=\"colorSelected\"\n [fontSelected]=\"font\"\n [fontSizeSelected]=\"fontSize\"\n [fontCollection]=\"fontCollection\"\n [fontSizeCollection]=\"fontSizeCollection\"\n (changeColor)=\"onChangeColor($event)\"\n (changeFont)=\"onChangeFont($event)\"\n (changeFontSize)=\"onChangeFontSize($event)\"\n (clickBold)=\"setBold()\"\n (clickItalic)=\"setItalic()\"\n (clickHighlight)=\"setHighlight()\"\n (clickOrderedList)=\"setOrderedList()\"\n (clickAlignContent)=\"alignContent($event)\"\n (clickLink)=\"toggleLinkBox(); setDescriptionLink()\"\n (clickUnorderedList)=\"setUnorderedList()\"\n (clickUnderline)=\"setUnderline()\"\n (clickImage)=\"toggleImageBox()\"\n (clickField)=\"addField($event)\"\n (clickQuote)=\"setQuote()\"\n (clickSave)=\"save()\"\n (clickClear)=\"clearContent()\">\n </tl-editor-header>\n <div #contentEditor\n class=\"ui-editor-content\"\n [class.disabled]=\"disabled\"\n [style.height]=\"height\"\n (input)=\"change()\"\n (focusout)=\"setAnchorNode()\"\n (click)=\"setCursorSelection()\"\n (focus)=\"setCursorSelection()\"\n (keydown.enter)=\"$event.stopPropagation()\"\n (keydown.ArrowUp)=\"$event.stopPropagation()\"\n (keydown.ArrowDown)=\"$event.stopPropagation()\"\n (mouseup)=\"onMouseUp()\"\n [attr.contenteditable]=\"editable || !disabled\"\n [innerHTML]=\"content\">\n </div>\n <div class=\"ui-saved-content-message\" [@enterAnimation]=\"saved\" *ngIf=\"saved\">\n <i class=\"ion-ios-checkmark-outline\"></i>\n <span>Saved !</span>\n </div>\n <tl-editor-link-box [descriptionLink]=\"descriptionLink\"\n *ngIf=\"toggleLink && !toggleImage\"\n (onSetLink)=\"setLink($event)\"\n (onToggleLink)=\"toggleLinkBox()\">\n </tl-editor-link-box>\n <tl-editor-image-box *ngIf=\"toggleImage && !toggleLink\"\n [imageUrl]=\"image.imageUrl\"\n (onSetImage)=\"setImage($event)\"\n (onToggleImage)=\"toggleImageBox()\">\n </tl-editor-image-box>\n <div class=\"ui-editor-footer\" *ngIf=\"tags.length > 0\">\n <div *ngFor=\"let item of tags\" (click)=\"addTag(item)\" class=\"ui-hashtag\">{{ item }}</div>\n </div>\n </div>\n</div>\n", styles: ["*{box-sizing:border-box}:host{width:100%}.ui-editor-footer{display:flex;align-items:flex-start;height:auto;width:100%;background:#e9e9e9;overflow:auto}.ui-editor-footer::-webkit-scrollbar{height:4px;width:0}.ui-editor{width:100%}.ui-link{text-decoration:underline}.ui-editor-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.ui-image-editor{padding:10px;box-sizing:border-box}.ui-image-editor:hover{cursor:pointer}.ui-saved-content-message{position:absolute;top:0;right:0;background:#333;padding:10px;box-sizing:border-box;-webkit-user-select:none;user-select:none;display:grid;grid-template-columns:25px 1fr;text-align:center;border-top-left-radius:0;border-bottom-left-radius:20px}.ui-color-component{position:absolute;height:12px;border:0;top:25px}.ui-editor-content{height:300px;overflow:auto;padding:10px;box-sizing:border-box;outline:none;word-break:break-word;cursor:text}.ui-editor-content.disabled{pointer-events:none;opacity:.5}\n"] }]
}], ctorParameters: function () { return [{ type: i1.I18nService }, { type: i0.Renderer2 }, { type: i2.EditorService }, { type: i3.DomSanitizer }, { type: i0.ChangeDetectorRef }, { type: i4.NgControl, decorators: [{
type: Optional
}, {
type: Self
}] }]; }, propDecorators: { content: [{
type: Input
}], color: [{
type: Input
}], tags: [{
type: Input
}], fields: [{
type: Input
}], toolbarConfig: [{
type: Input
}], height: [{
type: Input
}], labelPlacement: [{
type: Input
}], labelSize: [{
type: Input
}], label: [{
type: Input
}], editable: [{
type: Input
}], disabled: [{
type: Input
}], contentEditor: [{
type: ViewChild,
args: ['contentEditor', { static: true }]
}], linkBox: [{
type: ViewChild,
args: ['linkBox', { static: true }]
}], wrapper: [{
type: ViewChild,
args: ['wrapper', { static: true }]
}], fieldTemplate: [{
type: ViewChild,
args: ['fieldTemplate', { static: true }]
}], saveContent: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.js","sourceRoot":"","sources":["../../../../projects/truly-ui/src/components/editor/editor.ts","../../../../projects/truly-ui/src/components/editor/editor.html"],"names":[],"mappings":"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