Package Exports
- ngx-quill
- ngx-quill/src/quill-editor.component
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (ngx-quill) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
ngx-quill 
Angular (>=2) component for rich text editor Quill
- angular v4 - ngx-quill <=1.6.0
- angular v5 - ngx-quill > 1.6.0
- angular v6 - ngx-quill >= 3.0.0
ngx-quill is the new angular (>=2) implementation of ngQuill.
Examples
Installation
npm install ngx-quill- for projects using Angular < v5.0.0 install
npm install ngx-quill@1.6.0 - include theme stylings: bubble.css, snow.css of quilljs in your index.html
For standard webpack and tsc builds
- import
QuillModulefromngx-quill:
import { QuillModule } from 'ngx-quill'- add
QuillModuleto the imports of your NgModule:
@NgModule({
imports: [
...,
QuillModule
],
...
})
class YourModule { ... }- use
<quill-editor></quill-editor>in your templates to add a default quill editor - do not forget to include quill + theme css in your buildprocess, module or index.html!
For SystemJS builds (Config)
- add quill and ngx-quill to your
paths:
paths: {
...
'ngx-quill': 'node_modules/ngx-quill/bundles/ngx-quill.umd.js',
'quill': 'node_modules/quill/dist/quill.js'
}- set format and dependencies in
packages:
packages: {
'ngx-quill': {
format: 'cjs',
meta: {
deps: ['quill']
}
},
'quill': {
format: 'cjs'
}
}- follow the steps of For standard webpack and tsc builds
- for builds with angular-cli >=6 only add quilljs to your scripts!
Config
- ngModel - set initial value or allow two-way databinding
- readOnly (true | false) if user can edit content
- formats - array of allowed formats/groupings
- format - model format - default:
html, values:html | object | text | json, sets the model value type - html = html string, object = quill operation object, json = quill operation json, text = plain text - modules - configure/disable quill modules, e.g toolbar or add custom toolbar via html element default is
{
toolbar: [
['bold', 'italic', 'underline', 'strike'], // toggled buttons
['blockquote', 'code-block'],
[{ 'header': 1 }, { 'header': 2 }], // custom button values
[{ 'list': 'ordered'}, { 'list': 'bullet' }],
[{ 'script': 'sub'}, { 'script': 'super' }], // superscript/subscript
[{ 'indent': '-1'}, { 'indent': '+1' }], // outdent/indent
[{ 'direction': 'rtl' }], // text direction
[{ 'size': ['small', false, 'large', 'huge'] }], // custom dropdown
[{ 'header': [1, 2, 3, 4, 5, 6, false] }],
[{ 'color': [] }, { 'background': [] }], // dropdown with defaults from theme
[{ 'font': [] }],
[{ 'align': [] }],
['clean'], // remove formatting button
['link', 'image', 'video'] // link and image, video
]
};- theme - bubble/snow, default is
snow - style - set a style object, e.g.
[style]="{height: '250px'}" - placeholder - placeholder text, default is
Insert text here ... - bounds - boundary of the editor, default
document.body, pass 'self' to attach the editor element - maxLength - add validation for maxlength - set model state to
invalidand addng-invalidclass - minLength - add validation for minlength - set model state to
invalidand addng-invalidclass, only set invalid if editor text not empty --> if you want to check if text is required --> use the required attribute - required - add validation as a required field -
[required]="true"- default: false, boolean expected (no strings!) - strict - default: true, sets editor in strict mode
- scrollingContainer - default '.ql-editor', allows to set scrolling container
- use custom-options for adding for example custom font sizes --> this overwrites this options globally !!!
- possbility to create a custom toolbar via projection slot
[quill-editor-toolbar]:
<quill-editor>
<div quill-editor-toolbar>
<span class="ql-formats">
<button class="ql-bold" [title]="'Bold'"></button>
</span>
<span class="ql-formats">
<select class="ql-align" [title]="'Aligment'">
<option selected></option>
<option value="center"></option>
<option value="right"></option>
<option value="justify"></option>
</select>
<select class="ql-align" [title]="'Aligment2'">
<option selected></option>
<option value="center"></option>
<option value="right"></option>
<option value="justify"></option>
</select>
</span>
</div>
</quill-editor>Outputs
- onEditorCreated - editor instance
editor- onContentChanged - text is updated
{
editor: editorInstance,
html: html,
text: text,
content: content,
delta: delta,
oldDelta: oldDelta,
source: source
}- onSelectionChanged - selection is updated
{
editor: editorInstance,
range: range,
oldRange: oldRange,
source: source
}