ngx-quill
Version:
An angular (>= v2) component for the easy use of the QuillJS richt text editor.
140 lines • 16.1 kB
JavaScript
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
var Quill = null;
var getFormat = function (format, configFormat) {
var passedFormat = format || configFormat;
return passedFormat || 'html';
};
var ɵ0 = getFormat;
var QuillViewComponent = /** @class */ (function () {
function QuillViewComponent(
// tslint:disable-next-line:ban-types
platformId, config, renderer, elementRef) {
var _this = this;
this.platformId = platformId;
this.config = config;
this.renderer = renderer;
this.elementRef = elementRef;
this.strict = true;
this.customOptions = [];
this.preserveWhitespace = false;
this.valueSetter = function (quillEditor, value) {
var format = getFormat(_this.format, _this.config.format);
var 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);
};
}
QuillViewComponent.prototype.ngOnChanges = function (changes) {
if (!this.quillEditor) {
return;
}
if (changes.content) {
this.valueSetter(this.quillEditor, changes.content.currentValue);
}
};
QuillViewComponent.prototype.ngAfterViewInit = function () {
if (isPlatformServer(this.platformId)) {
return;
}
if (!Quill) {
Quill = require('quill');
}
var modules = Object.assign({}, this.modules || (this.config.modules || defaultModules));
modules.toolbar = false;
this.customOptions.forEach(function (customOption) {
var newCustomOption = Quill.import(customOption.import);
newCustomOption.whitelist = customOption.whitelist;
Quill.register(newCustomOption, true);
});
var debug = this.debug;
if (!debug && debug !== false && this.config.debug) {
debug = this.config.debug;
}
var formats = this.formats;
if (!formats && formats === undefined) {
formats = this.config.formats ? Object.assign({}, this.config.formats) : (this.config.formats === null ? null : undefined);
}
var 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: debug,
formats: formats,
modules: modules,
readOnly: true,
strict: this.strict,
theme: 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: "\n",
styles: ["\n.ql-container.ngx-quill-view {\n border: 0;\n}\n"]
}),
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);
return 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"]}