UNPKG

ngx-quill

Version:

An angular (>= v2) component for the easy use of the QuillJS richt text editor.

143 lines 15.7 kB
import * as tslib_1 from "tslib"; import { isPlatformServer } from '@angular/common'; import { QUILL_CONFIG_TOKEN } from './quill-editor.interfaces'; import { Component, ElementRef, Inject, Input, PLATFORM_ID, Renderer2, ViewEncapsulation } from '@angular/core'; import { defaultModules } from './quill-defaults'; // tslint:disable-next-line:variable-name let Quill = null; const getFormat = (format, configFormat) => { const passedFormat = format || configFormat; return passedFormat || 'html'; }; const ɵ0 = getFormat; let QuillViewComponent = class QuillViewComponent { constructor( // tslint:disable-next-line:ban-types platformId, config, renderer, elementRef) { this.platformId = platformId; this.config = config; this.renderer = renderer; this.elementRef = elementRef; this.strict = true; this.customOptions = []; this.preserveWhitespace = false; this.valueSetter = (quillEditor, value) => { const format = getFormat(this.format, this.config.format); let content = value; if (format === 'html' || format === 'text') { content = quillEditor.clipboard.convert(value); } else if (format === 'json') { try { content = JSON.parse(value); } catch (e) { content = [{ insert: value }]; } } quillEditor.setContents(content); }; } ngOnChanges(changes) { if (!this.quillEditor) { return; } if (changes.content) { this.valueSetter(this.quillEditor, changes.content.currentValue); } } ngAfterViewInit() { if (isPlatformServer(this.platformId)) { return; } if (!Quill) { Quill = require('quill'); } const modules = Object.assign({}, this.modules || (this.config.modules || defaultModules)); modules.toolbar = false; this.customOptions.forEach((customOption) => { const newCustomOption = Quill.import(customOption.import); newCustomOption.whitelist = customOption.whitelist; Quill.register(newCustomOption, true); }); let debug = this.debug; if (!debug && debug !== false && this.config.debug) { debug = this.config.debug; } let formats = this.formats; if (!formats && formats === undefined) { formats = this.config.formats ? Object.assign({}, this.config.formats) : (this.config.formats === null ? null : undefined); } const theme = this.theme || (this.config.theme ? this.config.theme : 'snow'); this.elementRef.nativeElement.insertAdjacentHTML('afterbegin', this.preserveWhitespace ? '<pre quill-view-element></pre>' : '<div quill-view-element></div>'); this.editorElem = this.elementRef.nativeElement.querySelector('[quill-view-element]'); this.quillEditor = new Quill(this.editorElem, { debug, formats, modules, readOnly: true, strict: this.strict, theme }); this.renderer.addClass(this.editorElem, 'ngx-quill-view'); if (this.content) { this.valueSetter(this.quillEditor, this.content); } } }; tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", String) ], QuillViewComponent.prototype, "format", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", String) ], QuillViewComponent.prototype, "theme", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Object) ], QuillViewComponent.prototype, "modules", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Object) ], QuillViewComponent.prototype, "debug", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Array) ], QuillViewComponent.prototype, "formats", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Boolean) ], QuillViewComponent.prototype, "strict", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Object) ], QuillViewComponent.prototype, "content", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Array) ], QuillViewComponent.prototype, "customOptions", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Boolean) ], QuillViewComponent.prototype, "preserveWhitespace", void 0); QuillViewComponent = tslib_1.__decorate([ Component({ encapsulation: ViewEncapsulation.None, selector: 'quill-view', template: ` `, styles: [` .ql-container.ngx-quill-view { border: 0; } `] }), tslib_1.__param(0, Inject(PLATFORM_ID)), tslib_1.__param(1, Inject(QUILL_CONFIG_TOKEN)), tslib_1.__metadata("design:paramtypes", [Object, Object, Renderer2, ElementRef]) ], QuillViewComponent); export { QuillViewComponent }; export { ɵ0 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-view.component.js","sourceRoot":"ng://ngx-quill/","sources":["src/quill-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common'\n\nimport { QUILL_CONFIG_TOKEN, QuillConfig, QuillFormat, QuillModules } from './quill-editor.interfaces'\n\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnChanges,\n  PLATFORM_ID,\n  Renderer2,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core'\n\nimport { defaultModules } from './quill-defaults'\nimport { CustomOption } from './quill-editor.component'\n\n// Because quill uses `document` directly, we cannot `import` during SSR\n// instead, we load dynamically via `require('quill')` in `ngAfterViewInit()`\ndeclare var require: any\n// tslint:disable-next-line:variable-name\nlet Quill: any = null\n\nconst getFormat = (format?: QuillFormat, configFormat?: QuillFormat): QuillFormat => {\n  const passedFormat = format || configFormat\n  return passedFormat || 'html'\n}\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  selector: 'quill-view',\n  styles: [`\n.ql-container.ngx-quill-view {\n  border: 0;\n}\n`],\n  template: `\n`\n})\nexport class QuillViewComponent implements AfterViewInit, OnChanges {\n  quillEditor: any\n  editorElem: HTMLElement | undefined\n\n  @Input() format?: 'object' | 'html' | 'text' | 'json'\n  @Input() theme?: string\n  @Input() modules?: QuillModules\n  @Input() debug?: 'warn' | 'log' | 'error' | false\n  @Input() formats?: string[] | null\n  @Input() strict: boolean = true\n  @Input() content: any\n  @Input() customOptions: CustomOption[] = []\n  @Input() preserveWhitespace: boolean = false\n\n  constructor(\n    // tslint:disable-next-line:ban-types\n    @Inject(PLATFORM_ID) private platformId: Object,\n    @Inject(QUILL_CONFIG_TOKEN) private config: QuillConfig,\n    private renderer: Renderer2,\n    private elementRef: ElementRef\n  ) {}\n\n  valueSetter = (quillEditor: any, value: any): any => {\n    const format = getFormat(this.format, this.config.format)\n    let content = value\n    if (format === 'html' || format === 'text') {\n      content = quillEditor.clipboard.convert(value)\n    } else if (format === 'json') {\n      try {\n        content = JSON.parse(value)\n      } catch (e) {\n        content = [{ insert: value }]\n      }\n    }\n    quillEditor.setContents(content)\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!this.quillEditor) {\n      return\n    }\n    if (changes.content) {\n      this.valueSetter(this.quillEditor, changes.content.currentValue)\n    }\n  }\n\n  ngAfterViewInit() {\n    if (isPlatformServer(this.platformId)) {\n      return\n    }\n    if (!Quill) {\n      Quill = require('quill')\n    }\n\n    const modules = Object.assign({}, this.modules || (this.config.modules || defaultModules))\n    modules.toolbar = false\n\n    this.customOptions.forEach((customOption) => {\n      const newCustomOption = Quill.import(customOption.import)\n      newCustomOption.whitelist = customOption.whitelist\n      Quill.register(newCustomOption, true)\n    })\n\n    let debug = this.debug\n    if (!debug && debug !== false && this.config.debug) {\n      debug = this.config.debug\n    }\n\n    let formats = this.formats\n    if (!formats && formats === undefined) {\n      formats = this.config.formats ? Object.assign({}, this.config.formats) : (this.config.formats === null ? null : undefined)\n    }\n    const theme = this.theme || (this.config.theme ? this.config.theme : 'snow')\n\n    this.elementRef.nativeElement.insertAdjacentHTML(\n      'afterbegin',\n      this.preserveWhitespace ? '<pre quill-view-element></pre>' : '<div quill-view-element></div>'\n    )\n\n    this.editorElem = this.elementRef.nativeElement.querySelector(\n      '[quill-view-element]'\n    )\n\n    this.quillEditor = new Quill(this.editorElem, {\n      debug,\n      formats,\n      modules,\n      readOnly: true,\n      strict: this.strict,\n      theme\n    })\n\n    this.renderer.addClass(this.editorElem, 'ngx-quill-view')\n\n    if (this.content) {\n      this.valueSetter(this.quillEditor, this.content)\n    }\n  }\n}\n"]}