UNPKG

truly-ui

Version:

Web Components for Desktop Applications.

526 lines (524 loc) 81.5 kB
/* 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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