@joniras/ngx-editor2
Version:
WYSIWYG Editor for Angular 8+
258 lines • 29.7 kB
JavaScript
import { __decorate } from "tslib";
import { Component, OnInit, Input, Output, ViewChild, EventEmitter, Renderer2, forwardRef, ElementRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { CommandExecutorService } from '../common/services/command-executor.service';
import { MessageService } from '../common/services/message.service';
import { ngxTextEditorConfig } from '../common/ngx-text-editor.defaults';
import * as Utils from '../common/utils/ngx-text-editor.utils';
var NgxTextEditorComponent = /** @class */ (function () {
/**
* @param _messageService service to send message to the editor message component
* @param _commandExecutor executes command from the toolbar
* @param _renderer access and manipulate the dom element
*/
function NgxTextEditorComponent(_messageService, _commandExecutor, _renderer) {
this._messageService = _messageService;
this._commandExecutor = _commandExecutor;
this._renderer = _renderer;
/**
* The editor can be resized vertically.
*
* `basic` resizer enables the html5 reszier. Check here https://www.w3schools.com/cssref/css3_pr_resize.asp
*
* `stack` resizer enable a resizer that looks like as if in https://stackoverflow.com
*/
this.resizer = 'stack';
/**
* The config property is a JSON object
*
* All avaibale inputs inputs can be provided in the configuration as JSON
* inputs provided directly are considered as top priority
*/
this.config = ngxTextEditorConfig;
/** emits `blur` event when focused out from the textarea */
this.blur = new EventEmitter();
/** emits `focus` event when focused in to the textarea */
this.focus = new EventEmitter();
/** emits `uploadImage` event when image is selected */
this.uploadImage = new EventEmitter();
this.Utils = Utils;
}
NgxTextEditorComponent_1 = NgxTextEditorComponent;
/**
* events
*/
NgxTextEditorComponent.prototype.onTextAreaFocus = function () {
this.focus.emit('focus');
};
/** focus the text area when the editor is focussed */
NgxTextEditorComponent.prototype.onEditorFocus = function () {
this.textArea.nativeElement.focus();
};
/**
* Executed from the contentEditable section while the input property changes
* @param innerHTML html string from contentEditable
*/
NgxTextEditorComponent.prototype.onContentChange = function (innerHTML) {
if (typeof this.onChange === 'function') {
this.onChange(innerHTML);
this.togglePlaceholder(innerHTML);
}
};
NgxTextEditorComponent.prototype.onTextAreaBlur = function () {
/** save selection if focussed out */
this._commandExecutor.savedSelection = Utils.saveSelection();
if (typeof this.onTouched === 'function') {
this.onTouched();
}
this.blur.emit('blur');
};
/**
* Executed when the image from the disc is selected
* @param image uploaded file object
*/
NgxTextEditorComponent.prototype.onUploadImage = function (image) {
this.uploadImage.emit(image);
};
/**
* resizing text area
*
* @param offsetY vertical height of the eidtable portion of the editor
*/
NgxTextEditorComponent.prototype.resizeTextArea = function (offsetY) {
var newHeight = parseInt(this.height, 10);
newHeight += offsetY;
this.height = newHeight + 'px';
this.textArea.nativeElement.style.height = this.height;
};
/**
* editor actions, i.e., executes command from toolbar
*
* @param commandName name of the command to be executed
*/
NgxTextEditorComponent.prototype.executeCommand = function (commandName) {
try {
this._commandExecutor.execute(commandName);
}
catch (error) {
this._messageService.sendMessage(error.message);
}
};
/**
* Write a new value to the element.
*
* @param value value to be executed when there is a change in contenteditable
*/
NgxTextEditorComponent.prototype.writeValue = function (value) {
this.togglePlaceholder(value);
if (value === null || value === undefined || value === '' || value === '<br>') {
value = null;
}
this.refreshView(value);
};
/**
* Set the function to be called
* when the control receives a change event.
*
* @param fn a function
*/
NgxTextEditorComponent.prototype.registerOnChange = function (fn) {
this.onChange = fn;
};
/**
* Set the function to be called
* when the control receives a touch event.
*
* @param fn a function
*/
NgxTextEditorComponent.prototype.registerOnTouched = function (fn) {
this.onTouched = fn;
};
/**
* refresh view/HTML of the editor
*
* @param value html string from the editor
*/
NgxTextEditorComponent.prototype.refreshView = function (value) {
var normalizedValue = value === null ? '' : value;
this._renderer.setProperty(this.textArea.nativeElement, 'innerHTML', normalizedValue);
};
/**
* toggles placeholder based on input string
*
* @param value A HTML string from the editor
*/
NgxTextEditorComponent.prototype.togglePlaceholder = function (value) {
if (!value || value === '<br>' || value === '') {
this._renderer.addClass(this.ngxWrapper.nativeElement, 'show-placeholder');
}
else {
this._renderer.removeClass(this.ngxWrapper.nativeElement, 'show-placeholder');
}
};
/**
* returns a json containing input params
*/
NgxTextEditorComponent.prototype.getCollectiveParams = function () {
return {
editable: this.editable,
spellcheck: this.spellcheck,
placeholder: this.placeholder,
translate: this.translate,
height: this.height,
minHeight: this.minHeight,
width: this.width,
minWidth: this.minWidth,
enableToolbar: this.enableToolbar,
showToolbar: this.showToolbar,
imageEndPoint: this.imageEndPoint,
toolbar: this.toolbar
};
};
NgxTextEditorComponent.prototype.ngOnInit = function () {
/**
* set configuration
*/
this.config = this.Utils.getEditorConfiguration(this.config, ngxTextEditorConfig, this.getCollectiveParams());
this.height = this.height || this.textArea.nativeElement.offsetHeight;
this.executeCommand('enableObjectResizing');
};
var NgxTextEditorComponent_1;
NgxTextEditorComponent.ctorParameters = function () { return [
{ type: MessageService },
{ type: CommandExecutorService },
{ type: Renderer2 }
]; };
__decorate([
Input()
], NgxTextEditorComponent.prototype, "editable", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "spellcheck", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "placeholder", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "translate", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "height", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "minHeight", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "width", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "minWidth", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "toolbar", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "resizer", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "config", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "showToolbar", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "enableToolbar", void 0);
__decorate([
Input()
], NgxTextEditorComponent.prototype, "imageEndPoint", void 0);
__decorate([
Output()
], NgxTextEditorComponent.prototype, "blur", void 0);
__decorate([
Output()
], NgxTextEditorComponent.prototype, "focus", void 0);
__decorate([
Output()
], NgxTextEditorComponent.prototype, "uploadImage", void 0);
__decorate([
ViewChild('ngxTextArea', { static: true })
], NgxTextEditorComponent.prototype, "textArea", void 0);
__decorate([
ViewChild('ngxWrapper', { static: true })
], NgxTextEditorComponent.prototype, "ngxWrapper", void 0);
NgxTextEditorComponent = NgxTextEditorComponent_1 = __decorate([
Component({
selector: 'ngx-text-editor',
template: "<div class=\"ngx-text-editor\"\r\n id=\"ngxTextEditor\"\r\n [style.width]=\"config['width']\"\r\n [style.minWidth]=\"config['minWidth']\"\r\n tabindex=\"0\"\r\n (focus)=\"onEditorFocus()\">\r\n\r\n <ngx-text-editor-toolbar [config]=\"config\"\r\n (execute)=\"executeCommand($event)\"\r\n (uploadImage)=\"onUploadImage($event)\"></ngx-text-editor-toolbar>\r\n\r\n <!-- text area -->\r\n <div #ngxWrapper\r\n class=\"ngx-wrapper\">\r\n <div #ngxTextArea\r\n class=\"ngx-text-editor-textarea\"\r\n [attr.contenteditable]=\"config['editable']\"\r\n (input)=\"onContentChange($event.target.innerHTML)\"\r\n [attr.translate]=\"config['translate']\"\r\n [attr.spellcheck]=\"config['spellcheck']\"\r\n [style.height]=\"config['height']\"\r\n [style.minHeight]=\"config['minHeight']\"\r\n [style.resize]=\"Utils?.canResize(resizer)\"\r\n (focus)=\"onTextAreaFocus()\"\r\n (blur)=\"onTextAreaBlur()\"></div>\r\n\r\n <span class=\"ngx-text-editor-placeholder\">\r\n {{ placeholder || config['placeholder'] }}\r\n </span>\r\n </div>\r\n\r\n <ngx-text-editor-message></ngx-text-editor-message>\r\n\r\n <ngx-grippie *ngIf=\"resizer === 'stack'\"></ngx-grippie>\r\n</div>\r\n",
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return NgxTextEditorComponent_1; }),
multi: true
}],
styles: [".ngx-text-editor{position:relative}.ngx-text-editor ::ng-deep [contenteditable=true]:empty:before{content:attr(placeholder);display:block;color:#868e96;opacity:1}.ngx-text-editor .ngx-wrapper{position:relative}.ngx-text-editor .ngx-wrapper .ngx-text-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}.ngx-text-editor .ngx-wrapper .ngx-text-editor-textarea.focus,.ngx-text-editor .ngx-wrapper .ngx-text-editor-textarea:focus{outline:0}.ngx-text-editor .ngx-wrapper .ngx-text-editor-textarea ::ng-deep blockquote{margin-left:1rem;border-left:.2em solid #dfe2e5;padding-left:.5rem}.ngx-text-editor .ngx-wrapper .ngx-text-editor-textarea::before{content:normal!important}.ngx-text-editor .ngx-wrapper ::ng-deep p{margin-bottom:0}.ngx-text-editor .ngx-wrapper .ngx-text-editor-placeholder{display:none;position:absolute;top:0;padding:.5rem .8rem 1rem .9rem;z-index:1;color:#6c757d;opacity:1}.ngx-text-editor .ngx-wrapper.show-placeholder .ngx-text-editor-placeholder{display:block}"]
})
], NgxTextEditorComponent);
return NgxTextEditorComponent;
}());
export { NgxTextEditorComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-text-editor.component.js","sourceRoot":"ng://@joniras/ngx-editor2/","sources":["ngx-text-editor/ngx-text-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, Output, ViewChild, EventEmitter, Renderer2, forwardRef, ElementRef} from '@angular/core';\r\nimport {NG_VALUE_ACCESSOR, ControlValueAccessor} from '@angular/forms';\r\n\r\nimport {CommandExecutorService} from '../common/services/command-executor.service';\r\nimport {MessageService} from '../common/services/message.service';\r\n\r\nimport {ngxTextEditorConfig} from '../common/ngx-text-editor.defaults';\r\nimport * as Utils from '../common/utils/ngx-text-editor.utils';\r\n\r\n@Component({\r\n  selector:    'ngx-text-editor',\r\n  templateUrl: './ngx-text-editor.component.html',\r\n  styleUrls:[\r\n    './ngx-text-editor.component.scss'\r\n  ],\r\n  providers:[{\r\n    provide:     NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => NgxTextEditorComponent),\r\n    multi:       true\r\n  }]\r\n})\r\nexport class NgxTextEditorComponent implements OnInit, ControlValueAccessor {\r\n  /** Specifies weather the textarea to be editable or not */\r\n  @Input() editable:boolean;\r\n\r\n  /** The spellcheck property specifies whether the element is to have its spelling and grammar checked or not. */\r\n  @Input() spellcheck:boolean;\r\n\r\n  /** Placeholder for the textArea */\r\n  @Input() placeholder:string;\r\n\r\n  /**\r\n   * The translate property specifies whether the content of an element should be translated or not.\r\n   *\r\n   * Check https://www.w3schools.com/tags/att_global_translate.asp for more information and browser support\r\n   */\r\n  @Input() translate:string;\r\n\r\n  /** Sets height of the editor */\r\n  @Input() height:string;\r\n\r\n  /** Sets minimum height for the editor */\r\n  @Input() minHeight:string;\r\n\r\n  /** Sets Width of the editor */\r\n  @Input() width:string;\r\n\r\n  /** Sets minimum width of the editor */\r\n  @Input() minWidth:string;\r\n\r\n  /**\r\n   * Toolbar accepts an array which specifies the options to be enabled for the toolbar\r\n   *\r\n   * Check ngxTextEditorConfig for toolbar configuration\r\n   *\r\n   * Passing an empty array will enable all toolbar\r\n   */\r\n  @Input() toolbar:Object;\r\n\r\n  /**\r\n   * The editor can be resized vertically.\r\n   *\r\n   * `basic` resizer enables the html5 reszier. Check here https://www.w3schools.com/cssref/css3_pr_resize.asp\r\n   *\r\n   * `stack` resizer enable a resizer that looks like as if in https://stackoverflow.com\r\n   */\r\n  @Input() resizer = 'stack';\r\n\r\n  /**\r\n   * The config property is a JSON object\r\n   *\r\n   * All avaibale inputs inputs can be provided in the configuration as JSON\r\n   * inputs provided directly are considered as top priority\r\n   */\r\n  @Input() config = ngxTextEditorConfig;\r\n\r\n  /** Weather to show or hide toolbar */\r\n  @Input() showToolbar:boolean;\r\n\r\n  /** Weather to enable or disable the toolbar */\r\n  @Input() enableToolbar:boolean;\r\n\r\n  /** Endpoint for which the image to be uploaded */\r\n  @Input() imageEndPoint:string;\r\n\r\n  /** emits `blur` event when focused out from the textarea */\r\n  @Output() blur:EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  /** emits `focus` event when focused in to the textarea */\r\n  @Output() focus:EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  /** emits `uploadImage` event when image is selected */\r\n  @Output() uploadImage:EventEmitter<HTMLInputElement> = new EventEmitter<HTMLInputElement>();\r\n\r\n  @ViewChild('ngxTextArea', { static: true }) textArea:any;\r\n  @ViewChild('ngxWrapper', { static: true }) ngxWrapper:any;\r\n\r\n  public Utils:any = Utils;\r\n\r\n  private onChange:(value:string) => void;\r\n  private onTouched:() => void;\r\n\r\n  /**\r\n   * @param _messageService service to send message to the editor message component\r\n   * @param _commandExecutor executes command from the toolbar\r\n   * @param _renderer access and manipulate the dom element\r\n   */\r\n  constructor(\r\n    private _messageService:MessageService,\r\n    private _commandExecutor:CommandExecutorService,\r\n    private _renderer:Renderer2) { }\r\n\r\n  /**\r\n   * events\r\n   */\r\n  onTextAreaFocus():void {\r\n    this.focus.emit('focus');\r\n  }\r\n\r\n  /** focus the text area when the editor is focussed */\r\n  onEditorFocus() {\r\n    this.textArea.nativeElement.focus();\r\n  }\r\n\r\n  /**\r\n   * Executed from the contentEditable section while the input property changes\r\n   * @param innerHTML html string from contentEditable\r\n   */\r\n  onContentChange(innerHTML:string):void {\r\n    if (typeof this.onChange === 'function') {\r\n      this.onChange(innerHTML);\r\n      this.togglePlaceholder(innerHTML);\r\n    }\r\n  }\r\n\r\n  onTextAreaBlur():void {\r\n    /** save selection if focussed out */\r\n    this._commandExecutor.savedSelection = Utils.saveSelection();\r\n\r\n    if (typeof this.onTouched === 'function') {\r\n      this.onTouched();\r\n    }\r\n    this.blur.emit('blur');\r\n  }\r\n\r\n  /**\r\n   * Executed when the image from the disc is selected\r\n   * @param image uploaded file object\r\n   */\r\n  onUploadImage(image:HTMLInputElement):void {\r\n    this.uploadImage.emit(image);\r\n  }\r\n\r\n  /**\r\n   * resizing text area\r\n   *\r\n   * @param offsetY vertical height of the eidtable portion of the editor\r\n   */\r\n  resizeTextArea(offsetY:number):void {\r\n    let newHeight = parseInt(this.height, 10);\r\n    newHeight += offsetY;\r\n\r\n    this.height = newHeight + 'px';\r\n    this.textArea.nativeElement.style.height = this.height;\r\n  }\r\n\r\n  /**\r\n   * editor actions, i.e., executes command from toolbar\r\n   *\r\n   * @param commandName name of the command to be executed\r\n   */\r\n  executeCommand(commandName:string):void {\r\n    try {\r\n      this._commandExecutor.execute(commandName);\r\n    } catch (error) {\r\n      this._messageService.sendMessage(error.message);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Write a new value to the element.\r\n   *\r\n   * @param value value to be executed when there is a change in contenteditable\r\n   */\r\n  writeValue(value:any):void {\r\n    this.togglePlaceholder(value);\r\n\r\n    if (value === null || value === undefined || value === '' || value === '<br>') {\r\n      value = null;\r\n    }\r\n\r\n    this.refreshView(value);\r\n  }\r\n\r\n  /**\r\n   * Set the function to be called\r\n   * when the control receives a change event.\r\n   *\r\n   * @param fn a function\r\n   */\r\n  registerOnChange(fn:any):void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  /**\r\n   * Set the function to be called\r\n   * when the control receives a touch event.\r\n   *\r\n   * @param fn a function\r\n   */\r\n  registerOnTouched(fn:any):void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  /**\r\n   * refresh view/HTML of the editor\r\n   *\r\n   * @param value html string from the editor\r\n   */\r\n  refreshView(value:string):void {\r\n    const normalizedValue = value === null ? '' : value;\r\n\r\n    this._renderer.setProperty(this.textArea.nativeElement, 'innerHTML', normalizedValue);\r\n  }\r\n\r\n  /**\r\n   * toggles placeholder based on input string\r\n   *\r\n   * @param value A HTML string from the editor\r\n   */\r\n  togglePlaceholder(value:any):void {\r\n    if (!value || value === '<br>' || value === '') {\r\n      this._renderer.addClass(this.ngxWrapper.nativeElement, 'show-placeholder');\r\n    } else {\r\n      this._renderer.removeClass(this.ngxWrapper.nativeElement, 'show-placeholder');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * returns a json containing input params\r\n   */\r\n  getCollectiveParams():any {\r\n    return {\r\n      editable:this.editable,\r\n      spellcheck:this.spellcheck,\r\n      placeholder:this.placeholder,\r\n      translate:this.translate,\r\n      height:this.height,\r\n      minHeight:this.minHeight,\r\n      width:this.width,\r\n      minWidth:this.minWidth,\r\n      enableToolbar:this.enableToolbar,\r\n      showToolbar:this.showToolbar,\r\n      imageEndPoint:this.imageEndPoint,\r\n      toolbar:this.toolbar\r\n    };\r\n  }\r\n\r\n  ngOnInit() {\r\n    /**\r\n     * set configuration\r\n     */\r\n    this.config = this.Utils.getEditorConfiguration(this.config, ngxTextEditorConfig, this.getCollectiveParams());\r\n\r\n    this.height = this.height || this.textArea.nativeElement.offsetHeight;\r\n\r\n    this.executeCommand('enableObjectResizing');\r\n  }\r\n}\r\n"]}