mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
162 lines
6.3 KiB
JavaScript
162 lines
6.3 KiB
JavaScript
|
/* ***** BEGIN LICENSE BLOCK *****
|
||
|
* Distributed under the BSD license:
|
||
|
*
|
||
|
* Copyright (c) 2010, Ajax.org B.V.
|
||
|
* All rights reserved.
|
||
|
*
|
||
|
* Redistribution and use in source and binary forms, with or without
|
||
|
* modification, are permitted provided that the following conditions are met:
|
||
|
* * Redistributions of source code must retain the above copyright
|
||
|
* notice, this list of conditions and the following disclaimer.
|
||
|
* * Redistributions in binary form must reproduce the above copyright
|
||
|
* notice, this list of conditions and the following disclaimer in the
|
||
|
* documentation and/or other materials provided with the distribution.
|
||
|
* * Neither the name of Ajax.org B.V. nor the
|
||
|
* names of its contributors may be used to endorse or promote products
|
||
|
* derived from this software without specific prior written permission.
|
||
|
*
|
||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||
|
* DISCLAIMED. IN NO EVENT SHALL AJAX.ORG B.V. BE LIABLE FOR ANY
|
||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
*
|
||
|
* ***** END LICENSE BLOCK ***** */
|
||
|
|
||
|
define(function(require, exports, module) {
|
||
|
"use strict";
|
||
|
|
||
|
var event = require("../lib/event");
|
||
|
var useragent = require("../lib/useragent");
|
||
|
var DefaultHandlers = require("./default_handlers").DefaultHandlers;
|
||
|
var DefaultGutterHandler = require("./default_gutter_handler").GutterHandler;
|
||
|
var MouseEvent = require("./mouse_event").MouseEvent;
|
||
|
var DragdropHandler = require("./dragdrop_handler").DragdropHandler;
|
||
|
var config = require("../config");
|
||
|
|
||
|
var MouseHandler = function(editor) {
|
||
|
this.editor = editor;
|
||
|
|
||
|
new DefaultHandlers(this);
|
||
|
new DefaultGutterHandler(this);
|
||
|
new DragdropHandler(this);
|
||
|
|
||
|
var mouseTarget = editor.renderer.getMouseEventTarget();
|
||
|
event.addListener(mouseTarget, "click", this.onMouseEvent.bind(this, "click"));
|
||
|
event.addListener(mouseTarget, "mousemove", this.onMouseMove.bind(this, "mousemove"));
|
||
|
event.addMultiMouseDownListener(mouseTarget, [300, 300, 250], this, "onMouseEvent");
|
||
|
if (editor.renderer.scrollBarV) {
|
||
|
event.addMultiMouseDownListener(editor.renderer.scrollBarV.inner, [300, 300, 250], this, "onMouseEvent");
|
||
|
event.addMultiMouseDownListener(editor.renderer.scrollBarH.inner, [300, 300, 250], this, "onMouseEvent");
|
||
|
}
|
||
|
event.addMouseWheelListener(editor.container, this.onMouseWheel.bind(this, "mousewheel"));
|
||
|
|
||
|
var gutterEl = editor.renderer.$gutter;
|
||
|
event.addListener(gutterEl, "mousedown", this.onMouseEvent.bind(this, "guttermousedown"));
|
||
|
event.addListener(gutterEl, "click", this.onMouseEvent.bind(this, "gutterclick"));
|
||
|
event.addListener(gutterEl, "dblclick", this.onMouseEvent.bind(this, "gutterdblclick"));
|
||
|
event.addListener(gutterEl, "mousemove", this.onMouseEvent.bind(this, "guttermousemove"));
|
||
|
|
||
|
event.addListener(mouseTarget, "mousedown", function(e) {
|
||
|
editor.focus();
|
||
|
});
|
||
|
|
||
|
event.addListener(gutterEl, "mousedown", function(e) {
|
||
|
editor.focus();
|
||
|
return event.preventDefault(e);
|
||
|
});
|
||
|
};
|
||
|
|
||
|
(function() {
|
||
|
this.onMouseEvent = function(name, e) {
|
||
|
this.editor._emit(name, new MouseEvent(e, this.editor));
|
||
|
};
|
||
|
|
||
|
this.onMouseMove = function(name, e) {
|
||
|
// optimization, because mousemove doesn't have a default handler.
|
||
|
var listeners = this.editor._eventRegistry && this.editor._eventRegistry.mousemove;
|
||
|
if (!listeners || !listeners.length)
|
||
|
return;
|
||
|
|
||
|
this.editor._emit(name, new MouseEvent(e, this.editor));
|
||
|
};
|
||
|
|
||
|
this.onMouseWheel = function(name, e) {
|
||
|
var mouseEvent = new MouseEvent(e, this.editor);
|
||
|
mouseEvent.speed = this.$scrollSpeed * 2;
|
||
|
mouseEvent.wheelX = e.wheelX;
|
||
|
mouseEvent.wheelY = e.wheelY;
|
||
|
|
||
|
this.editor._emit(name, mouseEvent);
|
||
|
};
|
||
|
|
||
|
this.setState = function(state) {
|
||
|
this.state = state;
|
||
|
};
|
||
|
|
||
|
this.captureMouse = function(ev, mouseMoveHandler) {
|
||
|
this.x = ev.x;
|
||
|
this.y = ev.y;
|
||
|
|
||
|
this.isMousePressed = true;
|
||
|
|
||
|
// do not move textarea during selection
|
||
|
var renderer = this.editor.renderer;
|
||
|
if (renderer.$keepTextAreaAtCursor)
|
||
|
renderer.$keepTextAreaAtCursor = null;
|
||
|
|
||
|
var self = this;
|
||
|
var onMouseMove = function(e) {
|
||
|
self.x = e.clientX;
|
||
|
self.y = e.clientY;
|
||
|
mouseMoveHandler && mouseMoveHandler(e);
|
||
|
self.mouseEvent = new MouseEvent(e, self.editor);
|
||
|
self.$mouseMoved = true;
|
||
|
};
|
||
|
|
||
|
var onCaptureEnd = function(e) {
|
||
|
clearInterval(timerId);
|
||
|
onCaptureInterval();
|
||
|
self[self.state + "End"] && self[self.state + "End"](e);
|
||
|
self.$clickSelection = null;
|
||
|
if (renderer.$keepTextAreaAtCursor == null) {
|
||
|
renderer.$keepTextAreaAtCursor = true;
|
||
|
renderer.$moveTextAreaToCursor();
|
||
|
}
|
||
|
self.isMousePressed = false;
|
||
|
self.$onCaptureMouseMove = self.releaseMouse = null;
|
||
|
self.onMouseEvent("mouseup", e);
|
||
|
};
|
||
|
|
||
|
var onCaptureInterval = function() {
|
||
|
self[self.state] && self[self.state]();
|
||
|
self.$mouseMoved = false;
|
||
|
};
|
||
|
|
||
|
if (useragent.isOldIE && ev.domEvent.type == "dblclick") {
|
||
|
return setTimeout(function() {onCaptureEnd(ev);});
|
||
|
}
|
||
|
|
||
|
self.$onCaptureMouseMove = onMouseMove;
|
||
|
self.releaseMouse = event.capture(this.editor.container, onMouseMove, onCaptureEnd);
|
||
|
var timerId = setInterval(onCaptureInterval, 20);
|
||
|
};
|
||
|
this.releaseMouse = null;
|
||
|
}).call(MouseHandler.prototype);
|
||
|
|
||
|
config.defineOptions(MouseHandler.prototype, "mouseHandler", {
|
||
|
scrollSpeed: {initialValue: 2},
|
||
|
dragDelay: {initialValue: 150},
|
||
|
dragEnabled: {initialValue: true},
|
||
|
focusTimout: {initialValue: 0}
|
||
|
});
|
||
|
|
||
|
|
||
|
exports.MouseHandler = MouseHandler;
|
||
|
});
|