• This repository has been archived on 20/Aug/2021
  • Stars
    star
    222
  • Rank 178,063 (Top 4 %)
  • Language
    JavaScript
  • License
    MIT License
  • Created almost 10 years ago
  • Updated about 3 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

AngularJS Component for Quill rich text editor

PROJECT IS NO LONGER MAINTAINED - angularjs lts period ends on 2021/12/31


ng-quill Build Status

NPM

ng-quill is an Angular.js component for Quill rich text editor.

Donate/Support

If you like my work, feel free to support it. Donations to the project are always welcomed :)

PayPal: PayPal.Me/bengtler

Buy Me A Coffee

BTC Wallet Address: 3QVyr2tpRLBCw1kBQ59sTDraV6DTswq8Li

ETH Wallet Address: 0x394d44f3b6e3a4f7b4d44991e7654b0cab4af68f

LTC Wallet Address: MFif769WSZ1g7ReAzzDE7TJVqtkFpmoTyT

Examples

Installation

The new version is complete rewritten and is using QuillJS 1.x. For the latest old version (0.20.1) checkout the special branch for it.

Usage

  • load angular, quill, ngquill scripts in your index.html
  • original sources are in src-folder, build files are in dist-folder
  • add dependency to your app module var myAppModule = angular.module('quillTest', ['ngQuill']);
  • use ngQuillConfigProvider to overwrite global settings in your config-Block
  • use ngquill directive in your html <ng-quill-editor ng-model="message"></ng-quill-editor>
  • add this line to your css [ng-quill-editor] { display: block; }
  • if you use it in a form and you are resetting it via $setPristine() -> you have to set editor.setText('') -> it will add the error class only, if the model has ng-dirty class
  • add a custom toolbar using ng-quill-toolbar - it uses transclusion to add toolbar, avoids flickering and sets the modules toolbar config to the custom toolbar automatically:

Recommended Usage

<ng-quill-editor ng-model="title">
    <ng-quill-toolbar>
        <div>
            <span class="ql-formats">
                <button class="ql-bold" ng-attr-title="{{'Bold'}}"></button>
            </span>
            <span class="ql-formats">
                <select class="ql-align" ng-attr-title="{{'Aligment'}}">
                    <option selected></option>
                    <option value="center"></option>
                    <option value="right"></option>
                    <option value="justify"></option>
                </select>
                <select class="ql-align">
                    <option selected></option>
                    <option value="center"></option>
                    <option value="right"></option>
                    <option value="justify"></option>
                </select>
            </span>
        </div>
    </ng-quill-toolbar>
</ng-quill-editor>
  • customToolbarPosition - if you are working with a custom toolbar you can switch the position :). - default: top, possible values top, bottom

Full Quill Toolbar HTML

Alternative Usage

let app = angular.module('app', [ 'ngQuill' ])

app.constant('NG_QUILL_CONFIG', {
  /*
   * @NOTE: this config/output is not localizable.
   */
  modules: {
    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: 'snow',
  debug: 'warn',
  placeholder: '',
  readOnly: false,
  bounds: document.body,
  scrollContainer: null
})

app.config([
  'ngQuillConfigProvider',
  'NG_QUILL_CONFIG',

  function (ngQuillConfigProvider, NG_QUILL_CONFIG) {
    ngQuillConfigProvider.set(NG_QUILL_CONFIG)
  }
])

*see: ./src/ng-quill/app.provider('ngQuillConfig').config

Configuration

  • use ngQuillConfigProvider.set({modules: { ... }, theme: 'snow', placeholder: 'placeholder', formats: { ... }, bounds: document.body, readyOnly: false) to config toolbar module, other modules, default theme, allowed formats, ...
  • set theme name: theme="snow" (default: 'snow')
  • set readOnly: read-only="" (default: false) - requires true or false
  • overwrite global config for each editor: modules="modulesConfig"
  • set placeholder: placeholder="'Inser your text here'" or placeholder="''" for empty string
  • set bounds: bounds="...", change the default boundary element of the editor (document.body) - set it to 'self' and the editor element is used
  • override formats: formats="formatsArray", per default all quill formats are allowed
  • set max-length: max-length="5", adds validation for maxlength (sets model state to invalid and adds ng-invalid-maxlength class)
  • set min-length: min-length="5", adds validation for minlength (sets model state to invalid and adds ng-invalid-minlength class), only works for values > 1, if you only want to check if there is a value --> use required/ng-required
  • set strict: activate/deactivate strict editor mode (default: true)
  • set scrollingContainer: set html element or css selector that gets the scrollbars
  • use custom-options for adding for example custom font sizes (see example in demo.html) --> this overwrites this options globally !!!
  • format - default 'html', possible values 'json' | 'object' | 'html' | 'text', so you are able to set quill operation object, html or plain text to your model
  • styles - set dynamic inline editor styles - styles="{ backgroundColor: 'red' }"
  • sanitize - santize the model content if format is html (default: false)
  • debug - set debug level, allowed 'error', 'warn', 'log', true, false (default: 'warn')
  • trackChanges - check if only user (quill source user) or all change should be trigger model update, default user. Using all is not recommended, it cause some unexpected sideeffects. But useful for 3rd Party modules and blots to keep your model up to date
  • preserveWhitespace - default: false - possbility to use a pre-tag instead of a div-tag for the contenteditable area to preserve duplicated whitespaces |ย caution if used with syntax plugin Related issue

Callback/Outputs

  • onEditorCreated: triggered after editor is created and provides editor-object on-editor-created="myCallback(editor)"
  • onContentChanged: triggered after changes in the editor. Provides editor-object, html representation and text representation on-content-changed="myCallback(editor, html, text, content, delta, oldDelta, source)"
  • onSelectionChanged: triggered after text selection changed on-selection-changed="myCallback(editor, range, oldRange, source)" - content = quill editor content object, text = content as plain text, html = content as html string
  • onFocus: triggered if editor gets focus on-focus="myCallback(editor, source)"
  • onBlur: triggered if editor gets focus on-blur="myCallback(editor, source)"

Security Hint

Angular templates provide some assurance against XSS in the form of client side sanitizing of all inputs.

Ng-quill provides the config paramter sanitize to sanitize html-strings passed as ngModel to the component.

It is deactivated per default to avoid stripping content or styling, which is not expected.

But it is recommended to activate this option, if you are working with html strings as model values.

Advanced Usage and Configuration

After editor creation you can use everything from the ordinary quill editor -> listen to editorCreated and work with the editor instance in your controller like you want ;). Add modules, use the quill API or listen to Events. Keep in mind to use $timeout if you are listening / working with quill-Events and updating some $scope stuff to notify angular about it ;). Quill Documentation

More Repositories

1

ngx-quill

Angular (>=2) components for the Quill Rich Text Editor
TypeScript
1,764
star
2

ngx-quill-example

demo app for the advanced usage of ngx-quill module
TypeScript
213
star
3

ionic-starter-eventmaps

little test app to search through events
JavaScript
42
star
4

stencil-quill

Native web components for the Quill Rich Text Editor built with stencil
TypeScript
36
star
5

ngx-quill-ionic

example of ngx-quill and ionic
TypeScript
30
star
6

ionic-process-spinner

Angular and Ionic Framework extension. It provides the ionProcessSpinner to show a loading spinner until a process has finished. It replaces the child content with a loading spinner while processing.
HTML
21
star
7

ionic-starter-requirejs

A starter template for ionic with requirejs
JavaScript
20
star
8

ionic-starter-eventmaps-tablet

An possible starter template for the eventmaps starter project
JavaScript
12
star
9

ionicScroller

scroll-buttons for ionic framework
JavaScript
9
star
10

angularjs-electron-app

A little playground for electron and angularjs
JavaScript
7
star
11

ngx-quill-universal-example

ngx-quill-universal-example
TypeScript
6
star
12

ngx-quill-ionic-v3

example of ngx-quill and ionic v3
CSS
6
star
13

reactjs-redux-chartjs

A little example of ReactJS, React-Redux and Chart.JS
JavaScript
5
star
14

ngx-media-query-watcher

An angular directive to easy listen and handle media query changes.
TypeScript
4
star
15

iBeacon-nfc

Test with ibeacon + nfc ionic, cordova, phonegap
Java
4
star
16

ionic-starter-eventmaps-combined

Combined ionic-starter-eventmaps and ionic-starter-eventmaps-tablet in one projekt/app
JavaScript
3
star
17

ng-loading-overlay

AngularJS module to show customizable loading overlay
JavaScript
2
star
18

ionic-starter-tabs-native-transitions

The starter tab ionic template with native transitions
JavaScript
2
star
19

websms

Custom nodejs sdk for websms.com services
JavaScript
2
star
20

ngx-quill-angular-cli

example of ngx-quill and angular cli
TypeScript
2
star
21

nogo

rest api with nodejs and mongodb
JavaScript
2
star
22

datetime-periods

Generates a valid list of years down to seconds for a date and min/max date
TypeScript
2
star
23

NodeJS-RestAPI

RestAPI with NodeJS, MongoDB, Token authentication and Multi Database support, Mocha tests, Endpoint Documentation
JavaScript
2
star
24

angular-ngx-quill-ssr

angular ssr example with ssr
HTML
2
star
25

CMS

PHP
1
star
26

ngx-element-life

An angular directive to easy listen when elements get initalised or destroyed.
TypeScript
1
star
27

baqend-blog

Playground for BaaS baqend.com
TypeScript
1
star
28

Sublime2ForEPages

sublime text 2 epages plugins
Python
1
star
29

humane-ionic2

litte ionic2 app
TypeScript
1
star
30

NodeJS_UserAdministration

Experiments with Node.js, Express.js, Backbone,js, Underscore.js
JavaScript
1
star
31

ng-browse

unified browse service for angularjs projects
JavaScript
1
star