@tinymce/tinymce-angular
Version:
Official TinyMCE Angular Component
253 lines • 32.7 kB
JavaScript
/* eslint-disable @typescript-eslint/no-parameter-properties */
import { isPlatformBrowser, CommonModule } from '@angular/common';
import { Component, forwardRef, Inject, Input, PLATFORM_ID, InjectionToken, Optional, ChangeDetectionStrategy } from '@angular/core';
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
import { Subject, takeUntil } from 'rxjs';
import { getTinymce } from '../TinyMCE';
import { listenTinyMCEEvent, bindHandlers, isTextarea, mergePlugins, uuid, noop, isNullOrUndefined, setMode } from '../utils/Utils';
import * as DisabledUtils from '../utils/DisabledUtils';
import { Events } from './Events';
import { ScriptLoader } from '../utils/ScriptLoader';
import * as i0 from "@angular/core";
export const TINYMCE_SCRIPT_SRC = new InjectionToken('TINYMCE_SCRIPT_SRC');
const EDITOR_COMPONENT_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => EditorComponent),
multi: true
};
/**
* @see {@link https://www.tiny.cloud/docs/tinymce/7/angular-ref/} for the TinyMCE Angular Technical Reference
*/
export class EditorComponent extends Events {
cdRef;
platformId;
tinymceScriptSrc;
cloudChannel = '8';
apiKey = 'no-api-key';
licenseKey = 'gpl';
init;
id = '';
initialValue;
outputFormat;
inline;
tagName;
plugins;
toolbar;
modelEvents = 'change input undo redo';
allowedEvents;
ignoreEvents;
set readonly(val) {
this._readonly = val;
if (this._editor) {
setMode(this._editor, val ? 'readonly' : 'design');
}
}
get readonly() {
return this._readonly;
}
set disabled(val) {
this._disabled = val;
if (this._editor) {
if (DisabledUtils.isDisabledOptionSupported(this._editor)) {
this._editor.options.set('disabled', val ?? false);
}
else {
setMode(this._editor, val ? 'readonly' : 'design');
}
}
}
get disabled() {
return this._disabled;
}
get editor() {
return this._editor;
}
ngZone;
_elementRef;
_element;
_disabled;
_readonly;
_editor;
onTouchedCallback = noop;
onChangeCallback;
destroy$ = new Subject();
constructor(elementRef, ngZone, cdRef, platformId, tinymceScriptSrc) {
super();
this.cdRef = cdRef;
this.platformId = platformId;
this.tinymceScriptSrc = tinymceScriptSrc;
this._elementRef = elementRef;
this.ngZone = ngZone;
}
writeValue(value) {
if (this._editor && this._editor.initialized) {
this._editor.setContent(isNullOrUndefined(value) ? '' : value);
}
else {
this.initialValue = value === null ? undefined : value;
}
}
registerOnChange(fn) {
this.onChangeCallback = fn;
}
registerOnTouched(fn) {
this.onTouchedCallback = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
ngAfterViewInit() {
if (isPlatformBrowser(this.platformId)) {
this.id = this.id || uuid('tiny-angular');
this.inline = this.inline !== undefined ? this.inline !== false : !!(this.init?.inline);
this.createElement();
if (getTinymce() !== null) {
this.initialise();
}
else if (this._element && this._element.ownerDocument) {
// Caretaker note: the component might be destroyed before the script is loaded and its code is executed.
// This will lead to runtime exceptions if `initialise` will be called when the component has been destroyed.
ScriptLoader.load(this._element.ownerDocument, this.getScriptSrc())
.pipe(takeUntil(this.destroy$))
.subscribe(this.initialise);
}
}
}
ngOnDestroy() {
this.destroy$.next();
if (getTinymce() !== null) {
getTinymce().remove(this._editor);
}
}
createElement() {
const tagName = typeof this.tagName === 'string' ? this.tagName : 'div';
this._element = document.createElement(this.inline ? tagName : 'textarea');
if (this._element) {
const existingElement = document.getElementById(this.id);
if (existingElement && existingElement !== this._elementRef.nativeElement) {
/* eslint no-console: ["error", { allow: ["warn"] }] */
console.warn(`TinyMCE-Angular: an element with id [${this.id}] already exists. Editors with duplicate Id will not be able to mount`);
}
this._element.id = this.id;
if (isTextarea(this._element)) {
this._element.style.visibility = 'hidden';
}
this._elementRef.nativeElement.appendChild(this._element);
}
}
initialise = () => {
const finalInit = {
...this.init,
selector: undefined,
target: this._element,
inline: this.inline,
disabled: this.disabled,
readonly: this.readonly,
license_key: this.licenseKey,
plugins: mergePlugins((this.init && this.init.plugins), this.plugins),
toolbar: this.toolbar || (this.init && this.init.toolbar),
setup: (editor) => {
this._editor = editor;
listenTinyMCEEvent(editor, 'init', this.destroy$).subscribe(() => {
this.initEditor(editor);
});
bindHandlers(this, editor, this.destroy$);
if (this.init && typeof this.init.setup === 'function') {
this.init.setup(editor);
}
if (this.disabled === true) {
if (DisabledUtils.isDisabledOptionSupported(editor)) {
this._editor.options.set('disabled', this.disabled);
}
else {
this._editor.mode.set('readonly');
}
}
}
};
if (isTextarea(this._element)) {
this._element.style.visibility = '';
}
this.ngZone.runOutsideAngular(() => {
getTinymce().init(finalInit);
});
};
getScriptSrc() {
return isNullOrUndefined(this.tinymceScriptSrc) ?
`https://cdn.tiny.cloud/1/${this.apiKey}/tinymce/${this.cloudChannel}/tinymce.min.js` :
this.tinymceScriptSrc;
}
initEditor(editor) {
listenTinyMCEEvent(editor, 'blur', this.destroy$).subscribe(() => {
this.cdRef.markForCheck();
this.ngZone.run(() => this.onTouchedCallback());
});
listenTinyMCEEvent(editor, this.modelEvents, this.destroy$).subscribe(() => {
this.cdRef.markForCheck();
this.ngZone.run(() => this.emitOnChange(editor));
});
if (typeof this.initialValue === 'string') {
this.ngZone.run(() => {
editor.setContent(this.initialValue);
if (editor.getContent() !== this.initialValue) {
this.emitOnChange(editor);
}
if (this.onInitNgModel !== undefined) {
this.onInitNgModel.emit(editor);
}
});
}
}
emitOnChange(editor) {
if (this.onChangeCallback) {
this.onChangeCallback(editor.getContent({ format: this.outputFormat }));
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: EditorComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: PLATFORM_ID }, { token: TINYMCE_SCRIPT_SRC, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: EditorComponent, isStandalone: true, selector: "editor", inputs: { cloudChannel: "cloudChannel", apiKey: "apiKey", licenseKey: "licenseKey", init: "init", id: "id", initialValue: "initialValue", outputFormat: "outputFormat", inline: "inline", tagName: "tagName", plugins: "plugins", toolbar: "toolbar", modelEvents: "modelEvents", allowedEvents: "allowedEvents", ignoreEvents: "ignoreEvents", readonly: "readonly", disabled: "disabled" }, providers: [EDITOR_COMPONENT_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0, template: '', isInline: true, styles: [":host{display:block}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: EditorComponent, decorators: [{
type: Component,
args: [{ selector: 'editor', template: '', providers: [EDITOR_COMPONENT_VALUE_ACCESSOR], standalone: true, imports: [CommonModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:block}\n"] }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: Object, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [TINYMCE_SCRIPT_SRC]
}] }], propDecorators: { cloudChannel: [{
type: Input
}], apiKey: [{
type: Input
}], licenseKey: [{
type: Input
}], init: [{
type: Input
}], id: [{
type: Input
}], initialValue: [{
type: Input
}], outputFormat: [{
type: Input
}], inline: [{
type: Input
}], tagName: [{
type: Input
}], plugins: [{
type: Input
}], toolbar: [{
type: Input
}], modelEvents: [{
type: Input
}], allowedEvents: [{
type: Input
}], ignoreEvents: [{
type: Input
}], readonly: [{
type: Input
}], disabled: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../tinymce-angular-component/src/main/ts/editor/editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-parameter-properties */\nimport { isPlatformBrowser, CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  forwardRef,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  PLATFORM_ID,\n  InjectionToken,\n  Optional,\n  ChangeDetectorRef,\n  ChangeDetectionStrategy\n} from '@angular/core';\nimport { FormsModule, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\nimport { getTinymce } from '../TinyMCE';\nimport { listenTinyMCEEvent, bindHandlers, isTextarea, mergePlugins, uuid, noop, isNullOrUndefined, setMode } from '../utils/Utils';\nimport * as DisabledUtils from '../utils/DisabledUtils';\nimport { EventObj, Events } from './Events';\nimport { ScriptLoader } from '../utils/ScriptLoader';\nimport type { Editor as TinyMCEEditor, TinyMCE } from 'tinymce';\n\ntype EditorOptions = Parameters<TinyMCE['init']>[0];\n\nexport const TINYMCE_SCRIPT_SRC = new InjectionToken<string>('TINYMCE_SCRIPT_SRC');\n\nconst EDITOR_COMPONENT_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => EditorComponent),\n  multi: true\n};\n\nexport type Version = `${'4' | '5' | '6' | '7' | '8'}${'' | '-dev' | '-testing' | `.${number}` | `.${number}.${number}`}`;\n\n@Component({\n  selector: 'editor',\n  template: '',\n  styles: [ ':host { display: block; }' ],\n  providers: [ EDITOR_COMPONENT_VALUE_ACCESSOR ],\n  standalone: true,\n  imports: [ CommonModule, FormsModule ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\n/**\n * @see {@link https://www.tiny.cloud/docs/tinymce/7/angular-ref/} for the TinyMCE Angular Technical Reference\n */\nexport class EditorComponent extends Events implements AfterViewInit, ControlValueAccessor, OnDestroy {\n\n  @Input() public cloudChannel: Version = '8';\n  @Input() public apiKey = 'no-api-key';\n  @Input() public licenseKey = 'gpl';\n  @Input() public init?: EditorOptions;\n  @Input() public id = '';\n  @Input() public initialValue?: string;\n  @Input() public outputFormat?: 'html' | 'text';\n  @Input() public inline?: boolean;\n  @Input() public tagName?: string;\n  @Input() public plugins?: string;\n  @Input() public toolbar?: string | string[];\n  @Input() public modelEvents = 'change input undo redo';\n  @Input() public allowedEvents?: string | string[];\n  @Input() public ignoreEvents?: string | string[];\n  @Input()\n  public set readonly(val) {\n    this._readonly = val;\n    if (this._editor) {\n      setMode(this._editor, val ? 'readonly' : 'design');\n    }\n  }\n\n  public get readonly() {\n    return this._readonly;\n  }\n\n  @Input()\n  public set disabled(val) {\n    this._disabled = val;\n    if (this._editor) {\n      if (DisabledUtils.isDisabledOptionSupported(this._editor)) {\n        this._editor.options.set('disabled', val ?? false);\n      } else {\n        setMode(this._editor, val ? 'readonly' : 'design');\n      }\n    }\n  }\n\n  public get disabled() {\n    return this._disabled;\n  }\n\n  public get editor() {\n    return this._editor;\n  }\n\n  public ngZone: NgZone;\n\n  private _elementRef: ElementRef;\n  private _element?: HTMLElement;\n  private _disabled?: boolean;\n  private _readonly?: boolean;\n  private _editor?: TinyMCEEditor;\n\n  private onTouchedCallback = noop;\n  private onChangeCallback: any;\n\n  private destroy$ = new Subject<void>();\n\n  public constructor(\n    elementRef: ElementRef,\n    ngZone: NgZone,\n    private cdRef: ChangeDetectorRef,\n    @Inject(PLATFORM_ID) private platformId: Object,\n    @Optional() @Inject(TINYMCE_SCRIPT_SRC) private tinymceScriptSrc?: string\n  ) {\n    super();\n    this._elementRef = elementRef;\n    this.ngZone = ngZone;\n  }\n\n  public writeValue(value: string | null): void {\n    if (this._editor && this._editor.initialized) {\n      this._editor.setContent(isNullOrUndefined(value) ? '' : value);\n    } else {\n      this.initialValue = value === null ? undefined : value;\n    }\n  }\n\n  public registerOnChange(fn: (_: any) => void): void {\n    this.onChangeCallback = fn;\n  }\n\n  public registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  public ngAfterViewInit() {\n    if (isPlatformBrowser(this.platformId)) {\n      this.id = this.id || uuid('tiny-angular');\n      this.inline = this.inline !== undefined ? this.inline !== false : !!(this.init?.inline);\n      this.createElement();\n      if (getTinymce() !== null) {\n        this.initialise();\n      } else if (this._element && this._element.ownerDocument) {\n        // Caretaker note: the component might be destroyed before the script is loaded and its code is executed.\n        // This will lead to runtime exceptions if `initialise` will be called when the component has been destroyed.\n        ScriptLoader.load(this._element.ownerDocument, this.getScriptSrc())\n          .pipe(takeUntil(this.destroy$))\n          .subscribe(this.initialise);\n      }\n    }\n  }\n\n  public ngOnDestroy() {\n    this.destroy$.next();\n\n    if (getTinymce() !== null) {\n      getTinymce().remove(this._editor);\n    }\n  }\n\n  public createElement() {\n    const tagName = typeof this.tagName === 'string' ? this.tagName : 'div';\n    this._element = document.createElement(this.inline ? tagName : 'textarea');\n    if (this._element) {\n      const existingElement = document.getElementById(this.id);\n      if (existingElement && existingElement !== this._elementRef.nativeElement) {\n        /* eslint no-console: [\"error\", { allow: [\"warn\"] }] */\n        console.warn(`TinyMCE-Angular: an element with id [${this.id}] already exists. Editors with duplicate Id will not be able to mount`);\n      }\n      this._element.id = this.id;\n      if (isTextarea(this._element)) {\n        this._element.style.visibility = 'hidden';\n      }\n      this._elementRef.nativeElement.appendChild(this._element);\n    }\n  }\n\n  public initialise = (): void => {\n    const finalInit: EditorOptions = {\n      ...this.init,\n      selector: undefined,\n      target: this._element,\n      inline: this.inline,\n      disabled: this.disabled,\n      readonly: this.readonly,\n      license_key: this.licenseKey,\n      plugins: mergePlugins((this.init && this.init.plugins) as string, this.plugins),\n      toolbar: this.toolbar || (this.init && this.init.toolbar),\n      setup: (editor: TinyMCEEditor) => {\n        this._editor = editor;\n\n        listenTinyMCEEvent(editor, 'init', this.destroy$).subscribe(() => {\n          this.initEditor(editor);\n        });\n\n        bindHandlers(this, editor, this.destroy$);\n\n        if (this.init && typeof this.init.setup === 'function') {\n          this.init.setup(editor);\n        }\n\n        if (this.disabled === true) {\n          if (DisabledUtils.isDisabledOptionSupported(editor)) {\n            this._editor.options.set('disabled', this.disabled);\n          } else {\n            this._editor.mode.set('readonly');\n          }\n        }\n      }\n    };\n\n    if (isTextarea(this._element)) {\n      this._element.style.visibility = '';\n    }\n\n    this.ngZone.runOutsideAngular(() => {\n      getTinymce().init(finalInit);\n    });\n  };\n\n  private getScriptSrc() {\n    return isNullOrUndefined(this.tinymceScriptSrc) ?\n      `https://cdn.tiny.cloud/1/${this.apiKey}/tinymce/${this.cloudChannel}/tinymce.min.js` :\n      this.tinymceScriptSrc;\n  }\n\n  private initEditor(editor: TinyMCEEditor) {\n    listenTinyMCEEvent(editor, 'blur', this.destroy$).subscribe(() => {\n      this.cdRef.markForCheck();\n      this.ngZone.run(() => this.onTouchedCallback());\n    });\n\n    listenTinyMCEEvent(editor, this.modelEvents, this.destroy$).subscribe(() => {\n      this.cdRef.markForCheck();\n      this.ngZone.run(() => this.emitOnChange(editor));\n    });\n\n    if (typeof this.initialValue === 'string') {\n      this.ngZone.run(() => {\n        editor.setContent(this.initialValue as string);\n        if (editor.getContent() !== this.initialValue) {\n          this.emitOnChange(editor);\n        }\n        if (this.onInitNgModel !== undefined) {\n          this.onInitNgModel.emit(editor as unknown as EventObj<any>);\n        }\n      });\n    }\n  }\n\n  private emitOnChange(editor: TinyMCEEditor) {\n    if (this.onChangeCallback) {\n      this.onChangeCallback(editor.getContent({ format: this.outputFormat }));\n    }\n  }\n}\n"]}