Angular 2 Component for async loading of Trumbowyg wysiwyg editor Only few users on your app use text editor. This module let Angular app load jQuery, Trumbowyg js files and css file only for the users who write something.
Demo app with SystemJS (github)
Demo app with Angular-CLI (github)
npm install ng2-lazy-trumbowyg --save
import TrumbowygModule in app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import {TrumbowygModule} from 'ng2-lazy-trumbowyg';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
// If you want default version (2.9.4) and don't need plug-in, include this line.
//TrumbowygModule,
//emoji doesn't work yet due to its dependency. table plug-in and insertaudio don't have icons.
TrumbowygModule.forRoot({plugins: ['colors', 'noembed', 'preformatted', 'pasteimage', 'upload'], version: '2.9.4'}) //Optional config : plug-ins and version
],
bootstrap: [AppComponent]
})
export class AppModule { }
include in component template
import {Component, ChangeDetectionStrategy} from '@angular/core';
import {Subject} from 'rxjs/Subject';
@Component({
selector: 'app-root',
template: `
<h2>Angular 2 Trumbowyg Update with <strong>Observable</strong> Example </h2>
<p>Updated only when update button clicked</p>
<trumbowyg [initialContent]="initialContentOne"
[options]="options1"
[update]="update$"
(savedContent)="contentOne=$event">
</trumbowyg>
<button (click)="togglePreview()">Toggle Preview(with update)</button>
<button *ngIf="showPreview" (click)="update$.next()">Update</button>
<h2>Preview Mode {{showPreview ? 'On':'Off'}} </h2>
<div *ngIf="showPreview" [innerHTML]="contentOne"></div>
<br><br><br>
<h2>Angular 2 Trumbowyg <strong>Live Update</strong> Example</h2>
<trumbowyg liveUpdate="true"
[initialContent]="initialContentTwo"
[options]="options2"
(savedContent)="contentTwo=$event">
</trumbowyg>
<div [innerHTML]="contentTwo"></div>
`
})
export class AppComponent {
public showPreview: boolean = false;
public initialContentOne: string = `<h2>This is an initial title One.</h2><p>This is an initial content.</p><p><img src="https://angular.io/assets/images/logos/angular/angular.svg" alt=""><br></p><p><br></p>`
public initialContentTwo: string = `<h2>This is an initial title Two.</h2><p>This is an initial content.</p><p><img src="https://angular.io/generated/images/marketing/home/loved-by-millions.svg" alt=""><br></p><p><br></p>`
public contentOne: string;
public contentTwo: string;
public update$: Subject<any> = new Subject();
public options1: any = {
autogrow: true,
removeformatPasted: true,
semantic: false,
btns: [['bold', 'italic'], ['link'],['foreColor', 'backColor'], ['preformatted'], ['noembed']],
lang: 'fr'
};
public options2: any = {
lang: 'ru'
};
togglePreview() {
this.showPreview = !this.showPreview;
if(this.showPreview) this.update$.next();
}
constructor() {
//Initial content update.
setTimeout(() => {
this.initialContentOne = "<h1>Contents can be manually updated 2</h1>"
this.update$.next(); // this is needed only when you use ChangeDetectionStrategy.OnPush strategy
},2000);
}
}
cd example
npm install
ng serve
npm run build