| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 | 
							- import EventEmitter from 'eventemitter3';
 
- import logger from './logger';
 
- let debug = logger('quill:events');
 
- const EVENTS = ['selectionchange', 'mousedown', 'mouseup', 'click'];
 
- EVENTS.forEach(function(eventName) {
 
-   document.addEventListener(eventName, (...args) => {
 
-     [].slice.call(document.querySelectorAll('.ql-container')).forEach((node) => {
 
-       // TODO use WeakMap
 
-       if (node.__quill && node.__quill.emitter) {
 
-         node.__quill.emitter.handleDOM(...args);
 
-       }
 
-     });
 
-   });
 
- });
 
- class Emitter extends EventEmitter {
 
-   constructor() {
 
-     super();
 
-     this.listeners = {};
 
-     this.on('error', debug.error);
 
-   }
 
-   emit() {
 
-     debug.log.apply(debug, arguments);
 
-     super.emit.apply(this, arguments);
 
-   }
 
-   handleDOM(event, ...args) {
 
-     (this.listeners[event.type] || []).forEach(function({ node, handler }) {
 
-       if (event.target === node || node.contains(event.target)) {
 
-         handler(event, ...args);
 
-       }
 
-     });
 
-   }
 
-   listenDOM(eventName, node, handler) {
 
-     if (!this.listeners[eventName]) {
 
-       this.listeners[eventName] = [];
 
-     }
 
-     this.listeners[eventName].push({ node, handler })
 
-   }
 
- }
 
- Emitter.events = {
 
-   EDITOR_CHANGE        : 'editor-change',
 
-   SCROLL_BEFORE_UPDATE : 'scroll-before-update',
 
-   SCROLL_OPTIMIZE      : 'scroll-optimize',
 
-   SCROLL_UPDATE        : 'scroll-update',
 
-   SELECTION_CHANGE     : 'selection-change',
 
-   TEXT_CHANGE          : 'text-change'
 
- };
 
- Emitter.sources = {
 
-   API    : 'api',
 
-   SILENT : 'silent',
 
-   USER   : 'user'
 
- };
 
- export default Emitter;
 
 
  |