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;
|