64 lines
1.5 KiB
JavaScript
64 lines
1.5 KiB
JavaScript
|
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;
|