Add jsdoc for setAnnotations() and an example of how to use them with native-format...
[dygraphs.git] / auto_tests / tests / DygraphOps.js
CommitLineData
718ad8e2 1// Copyright (c) 2011 Google, Inc.
72a74f04
RK
2//
3// Permission is hereby granted, free of charge, to any person obtaining a copy
4// of this software and associated documentation files (the "Software"), to deal
5// in the Software without restriction, including without limitation the rights
6// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7// copies of the Software, and to permit persons to whom the Software is
8// furnished to do so, subject to the following conditions:
9//
10// The above copyright notice and this permission notice shall be included in
11// all copies or substantial portions of the Software.
12//
13// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19// THE SOFTWARE.
20
21
22/**
23 * @fileoverview Utility functions for Dygraphs.
24 *
25 * @author konigsberg@google.com (Robert Konigsberg)
26 */
27var DygraphOps = {};
28
a12f271c
RK
29DygraphOps.defaultEvent_ = {
30 type : '',
31 canBubble : true,
32 cancelable : true,
33 view : document.defaultView,
34 detail : 0,
35 screenX : 0,
36 screenY : 0,
37 clientX : 0,
38 clientY : 0,
39 ctrlKey : false,
40 altKey : false,
41 shiftKey : false,
42 metaKey : false,
43 button : 0,
44 relatedTarget : null
45};
46
21c079e5
RK
47/**
48 * Create an event. Sets default event values except for special ones
49 * overridden by the 'custom' parameter.
50 *
51 * @param command the command to create.
52 * @param custom an associative array of event attributes and their new values.
53 */
17aad8df 54DygraphOps.createEvent = function(command, custom) {
a12f271c
RK
55
56 var copy = function(from, to) {
57 if (from != null) {
58 for (var prop in from) {
59 if(from.hasOwnProperty(prop)) {
60 to[prop] = from[prop];
61 }
62 }
63 }
72a74f04 64 }
a12f271c
RK
65
66 var e = {};
67 copy(DygraphOps.defaultEvent_, e);
68 copy(command, e);
69 copy(custom, e);
70
71 var event = document.createEvent('MouseEvents');
72 event.initMouseEvent(
73 e.type,
74 e.canBubble,
75 e.cancelable,
76 e.view,
77 e.detail,
78 e.screenX,
79 e.screenY,
80 e.clientX,
81 e.clientY,
82 e.ctrlKey,
83 e.altKey,
84 e.shiftKey,
85 e.metaKey,
86 e.button,
87 e.relatedTarget);
88 return event;
89}
90
21c079e5
RK
91/**
92 * Dispatch an event onto the graph's canvas.
93 */
17aad8df 94DygraphOps.dispatchCanvasEvent = function(g, event) {
21c079e5
RK
95 g.canvas_.dispatchEvent(event);
96}
97
a12f271c
RK
98DygraphOps.dispatchDoubleClick = function(g, custom) {
99 var opts = {
100 type : 'dblclick',
101 detail : 2
102 };
914805d3 103 var event = DygraphOps.createEvent(opts, custom);
21c079e5 104 DygraphOps.dispatchCanvasEvent(g, event);
72a74f04
RK
105};
106
9c831431
RK
107DygraphOps.dispatchMouseDown_Point = function(g, x, y, custom) {
108 var pageX = Dygraph.findPosX(g.canvas_) + x;
109 var pageY = Dygraph.findPosY(g.canvas_) + y;
72a74f04 110
a12f271c
RK
111 var opts = {
112 type : 'mousedown',
113 detail : 1,
114 screenX : pageX,
115 screenY : pageY,
116 clientX : pageX,
117 clientY : pageY,
118 };
119
914805d3 120 var event = DygraphOps.createEvent(opts, custom);
21c079e5 121 DygraphOps.dispatchCanvasEvent(g, event);
9c831431 122}
72a74f04 123
9c831431
RK
124DygraphOps.dispatchMouseMove_Point = function(g, x, y, custom) {
125 var pageX = Dygraph.findPosX(g.canvas_) + x;
126 var pageY = Dygraph.findPosY(g.canvas_) + y;
72a74f04 127
a12f271c
RK
128 var opts = {
129 type : 'mousemove',
130 screenX : pageX,
131 screenY : pageY,
132 clientX : pageX,
133 clientY : pageY,
134 };
135
914805d3 136 var event = DygraphOps.createEvent(opts, custom);
21c079e5 137 DygraphOps.dispatchCanvasEvent(g, event);
72a74f04
RK
138};
139
9c831431
RK
140DygraphOps.dispatchMouseUp_Point = function(g, x, y, custom) {
141 var pageX = Dygraph.findPosX(g.canvas_) + x;
142 var pageY = Dygraph.findPosY(g.canvas_) + y;
72a74f04 143
a12f271c
RK
144 var opts = {
145 type : 'mouseup',
146 screenX : pageX,
147 screenY : pageY,
148 clientX : pageX,
149 clientY : pageY,
150 };
151
914805d3 152 var event = DygraphOps.createEvent(opts, custom);
21c079e5 153 DygraphOps.dispatchCanvasEvent(g, event);
72a74f04 154};
9c831431 155
6ace73a8
RK
156/**
157 * Dispatches a mouse down using the graph's data coordinate system.
158 * (The y value mapped to the first axis.)
159 */
9c831431
RK
160DygraphOps.dispatchMouseDown = function(g, x, y, custom) {
161 DygraphOps.dispatchMouseDown_Point(
162 g,
163 g.toDomXCoord(x),
164 g.toDomYCoord(y),
165 custom);
166};
167
6ace73a8
RK
168/**
169 * Dispatches a mouse move using the graph's data coordinate system.
170 * (The y value mapped to the first axis.)
171 */
9c831431
RK
172DygraphOps.dispatchMouseMove = function(g, x, y, custom) {
173 DygraphOps.dispatchMouseMove_Point(
174 g,
175 g.toDomXCoord(x),
176 g.toDomYCoord(y),
177 custom);
178};
179
6ace73a8
RK
180/**
181 * Dispatches a mouse up using the graph's data coordinate system.
182 * (The y value mapped to the first axis.)
183 */
9c831431
RK
184DygraphOps.dispatchMouseUp = function(g, x, y, custom) {
185 DygraphOps.dispatchMouseUp_Point(
186 g,
187 g.toDomXCoord(x),
188 g.toDomYCoord(y),
189 custom);
190};
191