iobroker.ebus 3.2.4 → 3.2.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/.eslintrc.json +34 -34
  2. package/.releaseconfig.json +3 -0
  3. package/LICENSE +20 -20
  4. package/README.md +147 -130
  5. package/admin/index_m.html +419 -419
  6. package/admin/style.css +18 -18
  7. package/admin/words.js +27 -27
  8. package/io-package.json +218 -192
  9. package/lib/support_tools.js +370 -370
  10. package/lib/tools.js +99 -99
  11. package/main.js +1232 -1232
  12. package/package.json +13 -11
  13. package/widgets/ebus/lib/js/flot/jquery.canvaswrapper.js +549 -549
  14. package/widgets/ebus/lib/js/flot/jquery.colorhelpers.js +199 -199
  15. package/widgets/ebus/lib/js/flot/jquery.flot.axislabels.js +212 -212
  16. package/widgets/ebus/lib/js/flot/jquery.flot.browser.js +98 -98
  17. package/widgets/ebus/lib/js/flot/jquery.flot.categories.js +202 -202
  18. package/widgets/ebus/lib/js/flot/jquery.flot.composeImages.js +330 -330
  19. package/widgets/ebus/lib/js/flot/jquery.flot.crosshair.js +202 -202
  20. package/widgets/ebus/lib/js/flot/jquery.flot.drawSeries.js +662 -662
  21. package/widgets/ebus/lib/js/flot/jquery.flot.errorbars.js +375 -375
  22. package/widgets/ebus/lib/js/flot/jquery.flot.fillbetween.js +254 -254
  23. package/widgets/ebus/lib/js/flot/jquery.flot.flatdata.js +47 -47
  24. package/widgets/ebus/lib/js/flot/jquery.flot.hover.js +361 -361
  25. package/widgets/ebus/lib/js/flot/jquery.flot.image.js +249 -249
  26. package/widgets/ebus/lib/js/flot/jquery.flot.js +2953 -2953
  27. package/widgets/ebus/lib/js/flot/jquery.flot.legend.js +437 -437
  28. package/widgets/ebus/lib/js/flot/jquery.flot.logaxis.js +298 -298
  29. package/widgets/ebus/lib/js/flot/jquery.flot.navigate.js +834 -834
  30. package/widgets/ebus/lib/js/flot/jquery.flot.pie.js +794 -794
  31. package/widgets/ebus/lib/js/flot/jquery.flot.resize.js +60 -60
  32. package/widgets/ebus/lib/js/flot/jquery.flot.saturated.js +43 -43
  33. package/widgets/ebus/lib/js/flot/jquery.flot.selection.js +527 -527
  34. package/widgets/ebus/lib/js/flot/jquery.flot.stack.js +220 -220
  35. package/widgets/ebus/lib/js/flot/jquery.flot.symbol.js +98 -98
  36. package/widgets/ebus/lib/js/flot/jquery.flot.threshold.js +143 -143
  37. package/widgets/ebus/lib/js/flot/jquery.flot.time.js +586 -586
  38. package/widgets/ebus/lib/js/flot/jquery.flot.touch.js +320 -320
  39. package/widgets/ebus/lib/js/flot/jquery.flot.touchNavigate.js +360 -360
  40. package/widgets/ebus/lib/js/flot/jquery.flot.uiConstants.js +10 -10
  41. package/widgets/ebus/lib/js/flot/jquery.js +9473 -9473
  42. package/widgets/ebus/lib/js/lib/globalize.culture.en-US.js +33 -33
  43. package/widgets/ebus/lib/js/lib/globalize.js +1601 -1601
  44. package/widgets/ebus/lib/js/lib/jquery.event.drag.js +145 -145
  45. package/widgets/ebus/lib/js/lib/jquery.mousewheel.js +86 -86
  46. package/widgets/ebus.html +2395 -2395
  47. package/readme.txt +0 -297
@@ -1,361 +1,361 @@
1
- /* global jQuery */
2
-
3
- /**
4
- ## jquery.flot.hover.js
5
-
6
- This plugin is used for mouse hover and tap on a point of plot series.
7
- It supports the following options:
8
- ```js
9
- grid: {
10
- hoverable: false, //to trigger plothover event on mouse hover or tap on a point
11
- clickable: false //to trigger plotclick event on mouse hover
12
- }
13
- ```
14
-
15
- It listens to native mouse move event or click, as well as artificial generated
16
- tap and touchevent.
17
-
18
- When the mouse is over a point or a tap on a point is performed, that point or
19
- the correscponding bar will be highlighted and a "plothover" event will be generated.
20
-
21
- Custom "touchevent" is triggered when any touch interaction is made. Hover plugin
22
- handles this events by unhighlighting all of the previously highlighted points and generates
23
- "plothovercleanup" event to notify any part that is handling plothover (for exemple to cleanup
24
- the tooltip from webcharts).
25
- */
26
-
27
- (function($) {
28
- 'use strict';
29
-
30
- var options = {
31
- grid: {
32
- hoverable: false,
33
- clickable: false
34
- }
35
- };
36
-
37
- var browser = $.plot.browser;
38
-
39
- var eventType = {
40
- click: 'click',
41
- hover: 'hover'
42
- }
43
-
44
- function init(plot) {
45
- var lastMouseMoveEvent;
46
- var highlights = [];
47
-
48
- console.log("hover init");
49
-
50
- function bindEvents(plot, eventHolder) {
51
- var o = plot.getOptions();
52
-
53
- if (o.grid.hoverable || o.grid.clickable) {
54
- eventHolder[0].addEventListener('touchevent', triggerCleanupEvent, false);
55
- eventHolder[0].addEventListener('tap', generatePlothoverEvent, false);
56
- }
57
-
58
- if (o.grid.clickable) {
59
- eventHolder.bind("click", onClick);
60
- }
61
-
62
- if (o.grid.hoverable) {
63
- eventHolder.bind("mousemove", onMouseMove);
64
-
65
- // Use bind, rather than .mouseleave, because we officially
66
- // still support jQuery 1.2.6, which doesn't define a shortcut
67
- // for mouseenter or mouseleave. This was a bug/oversight that
68
- // was fixed somewhere around 1.3.x. We can return to using
69
- // .mouseleave when we drop support for 1.2.6.
70
-
71
- eventHolder.bind("mouseleave", onMouseLeave);
72
- }
73
- }
74
-
75
- function shutdown(plot, eventHolder) {
76
- eventHolder[0].removeEventListener('tap', generatePlothoverEvent);
77
- eventHolder[0].removeEventListener('touchevent', triggerCleanupEvent);
78
- eventHolder.unbind("mousemove", onMouseMove);
79
- eventHolder.unbind("mouseleave", onMouseLeave);
80
- eventHolder.unbind("click", onClick);
81
- highlights = [];
82
- }
83
-
84
- function generatePlothoverEvent(e) {
85
- var o = plot.getOptions(),
86
- newEvent = new CustomEvent('mouseevent');
87
-
88
- //transform from touch event to mouse event format
89
- newEvent.pageX = e.detail.changedTouches[0].pageX;
90
- newEvent.pageY = e.detail.changedTouches[0].pageY;
91
- newEvent.clientX = e.detail.changedTouches[0].clientX;
92
- newEvent.clientY = e.detail.changedTouches[0].clientY;
93
-
94
- if (o.grid.hoverable) {
95
- doTriggerClickHoverEvent(newEvent, eventType.hover, 30);
96
- }
97
- return false;
98
- }
99
-
100
- function doTriggerClickHoverEvent(event, eventType, searchDistance) {
101
- var series = plot.getData();
102
- if (event !== undefined &&
103
- series.length > 0 &&
104
- series[0].xaxis.c2p !== undefined &&
105
- series[0].yaxis.c2p !== undefined) {
106
- var eventToTrigger = "plot" + eventType;
107
- var seriesFlag = eventType + "able";
108
- triggerClickHoverEvent(eventToTrigger, event,
109
- function(i) {
110
- return series[i][seriesFlag] !== false;
111
- }, searchDistance);
112
- }
113
- }
114
-
115
- function onMouseMove(e) {
116
- lastMouseMoveEvent = e;
117
- plot.getPlaceholder()[0].lastMouseMoveEvent = e;
118
- doTriggerClickHoverEvent(e, eventType.hover);
119
- }
120
-
121
- function onMouseLeave(e) {
122
- lastMouseMoveEvent = undefined;
123
- plot.getPlaceholder()[0].lastMouseMoveEvent = undefined;
124
- triggerClickHoverEvent("plothover", e,
125
- function(i) {
126
- return false;
127
- });
128
- }
129
-
130
- function onClick(e) {
131
- doTriggerClickHoverEvent(e, eventType.click);
132
- }
133
-
134
- function triggerCleanupEvent() {
135
- plot.unhighlight();
136
- plot.getPlaceholder().trigger('plothovercleanup');
137
- }
138
-
139
- // trigger click or hover event (they send the same parameters
140
- // so we share their code)
141
- function triggerClickHoverEvent(eventname, event, seriesFilter, searchDistance) {
142
- var options = plot.getOptions(),
143
- offset = plot.offset(),
144
- page = browser.getPageXY(event),
145
- canvasX = page.X - offset.left,
146
- canvasY = page.Y - offset.top,
147
- pos = plot.c2p({
148
- left: canvasX,
149
- top: canvasY
150
- }),
151
- distance = searchDistance !== undefined ? searchDistance : options.grid.mouseActiveRadius;
152
-
153
- pos.pageX = page.X;
154
- pos.pageY = page.Y;
155
-
156
- var items = plot.findNearbyItems(canvasX, canvasY, seriesFilter, distance);
157
- var item = items[0];
158
-
159
- for (let i = 1; i < items.length; ++i) {
160
- if (item.distance === undefined ||
161
- items[i].distance < item.distance) {
162
- item = items[i];
163
- }
164
- }
165
-
166
- if (item) {
167
- // fill in mouse pos for any listeners out there
168
- item.pageX = parseInt(item.series.xaxis.p2c(item.datapoint[0]) + offset.left, 10);
169
- item.pageY = parseInt(item.series.yaxis.p2c(item.datapoint[1]) + offset.top, 10);
170
- } else {
171
- item = null;
172
- }
173
-
174
- if (options.grid.autoHighlight) {
175
- // clear auto-highlights
176
- for (let i = 0; i < highlights.length; ++i) {
177
- var h = highlights[i];
178
- if ((h.auto === eventname &&
179
- !(item && h.series === item.series &&
180
- h.point[0] === item.datapoint[0] &&
181
- h.point[1] === item.datapoint[1])) || !item) {
182
- unhighlight(h.series, h.point);
183
- }
184
- }
185
-
186
- if (item) {
187
- highlight(item.series, item.datapoint, eventname);
188
- }
189
- }
190
-
191
- plot.getPlaceholder().trigger(eventname, [pos, item, items]);
192
- }
193
-
194
- function highlight(s, point, auto) {
195
- if (typeof s === "number") {
196
- s = plot.getData()[s];
197
- }
198
-
199
- if (typeof point === "number") {
200
- var ps = s.datapoints.pointsize;
201
- point = s.datapoints.points.slice(ps * point, ps * (point + 1));
202
- }
203
-
204
- var i = indexOfHighlight(s, point);
205
- if (i === -1) {
206
- highlights.push({
207
- series: s,
208
- point: point,
209
- auto: auto
210
- });
211
-
212
- plot.triggerRedrawOverlay();
213
- } else if (!auto) {
214
- highlights[i].auto = false;
215
- }
216
- }
217
-
218
- function unhighlight(s, point) {
219
- if (s == null && point == null) {
220
- highlights = [];
221
- plot.triggerRedrawOverlay();
222
- return;
223
- }
224
-
225
- if (typeof s === "number") {
226
- s = plot.getData()[s];
227
- }
228
-
229
- if (typeof point === "number") {
230
- var ps = s.datapoints.pointsize;
231
- point = s.datapoints.points.slice(ps * point, ps * (point + 1));
232
- }
233
-
234
- var i = indexOfHighlight(s, point);
235
- if (i !== -1) {
236
- highlights.splice(i, 1);
237
-
238
- plot.triggerRedrawOverlay();
239
- }
240
- }
241
-
242
- function indexOfHighlight(s, p) {
243
- for (var i = 0; i < highlights.length; ++i) {
244
- var h = highlights[i];
245
- if (h.series === s &&
246
- h.point[0] === p[0] &&
247
- h.point[1] === p[1]) {
248
- return i;
249
- }
250
- }
251
-
252
- return -1;
253
- }
254
-
255
- function processDatapoints() {
256
- triggerCleanupEvent();
257
- doTriggerClickHoverEvent(lastMouseMoveEvent, eventType.hover);
258
- }
259
-
260
- function setupGrid() {
261
- doTriggerClickHoverEvent(lastMouseMoveEvent, eventType.hover);
262
- }
263
-
264
- function drawOverlay(plot, octx, overlay) {
265
- var plotOffset = plot.getPlotOffset(),
266
- i, hi;
267
-
268
- octx.save();
269
- octx.translate(plotOffset.left, plotOffset.top);
270
- for (i = 0; i < highlights.length; ++i) {
271
- hi = highlights[i];
272
-
273
- if (hi.series.bars.show) drawBarHighlight(hi.series, hi.point, octx);
274
- else drawPointHighlight(hi.series, hi.point, octx, plot);
275
- }
276
- octx.restore();
277
- }
278
-
279
- function drawPointHighlight(series, point, octx, plot) {
280
- var x = point[0],
281
- y = point[1],
282
- axisx = series.xaxis,
283
- axisy = series.yaxis,
284
- highlightColor = (typeof series.highlightColor === "string") ? series.highlightColor : $.color.parse(series.color).scale('a', 0.5).toString();
285
-
286
- if (x < axisx.min || x > axisx.max || y < axisy.min || y > axisy.max) {
287
- return;
288
- }
289
-
290
- var pointRadius = series.points.radius + series.points.lineWidth / 2;
291
- octx.lineWidth = pointRadius;
292
- octx.strokeStyle = highlightColor;
293
- var radius = 1.5 * pointRadius;
294
- x = axisx.p2c(x);
295
- y = axisy.p2c(y);
296
-
297
- octx.beginPath();
298
- var symbol = series.points.symbol;
299
- if (symbol === 'circle') {
300
- octx.arc(x, y, radius, 0, 2 * Math.PI, false);
301
- } else if (typeof symbol === 'string' && plot.drawSymbol && plot.drawSymbol[symbol]) {
302
- plot.drawSymbol[symbol](octx, x, y, radius, false);
303
- }
304
-
305
- octx.closePath();
306
- octx.stroke();
307
- }
308
-
309
- function drawBarHighlight(series, point, octx) {
310
- var highlightColor = (typeof series.highlightColor === "string") ? series.highlightColor : $.color.parse(series.color).scale('a', 0.5).toString(),
311
- fillStyle = highlightColor,
312
- barLeft;
313
-
314
- var barWidth = series.bars.barWidth[0] || series.bars.barWidth;
315
- switch (series.bars.align) {
316
- case "left":
317
- barLeft = 0;
318
- break;
319
- case "right":
320
- barLeft = -barWidth;
321
- break;
322
- default:
323
- barLeft = -barWidth / 2;
324
- }
325
-
326
- octx.lineWidth = series.bars.lineWidth;
327
- octx.strokeStyle = highlightColor;
328
-
329
- var fillTowards = series.bars.fillTowards || 0,
330
- bottom = fillTowards > series.yaxis.min ? Math.min(series.yaxis.max, fillTowards) : series.yaxis.min;
331
-
332
- $.plot.drawSeries.drawBar(point[0], point[1], point[2] || bottom, barLeft, barLeft + barWidth,
333
- function() {
334
- return fillStyle;
335
- }, series.xaxis, series.yaxis, octx, series.bars.horizontal, series.bars.lineWidth);
336
- }
337
-
338
- function initHover(plot, options) {
339
- plot.highlight = highlight;
340
- plot.unhighlight = unhighlight;
341
- if (options.grid.hoverable || options.grid.clickable) {
342
- plot.hooks.drawOverlay.push(drawOverlay);
343
- plot.hooks.processDatapoints.push(processDatapoints);
344
- plot.hooks.setupGrid.push(setupGrid);
345
- }
346
-
347
- lastMouseMoveEvent = plot.getPlaceholder()[0].lastMouseMoveEvent;
348
- }
349
-
350
- plot.hooks.bindEvents.push(bindEvents);
351
- plot.hooks.shutdown.push(shutdown);
352
- plot.hooks.processOptions.push(initHover);
353
- }
354
-
355
- $.plot.plugins.push({
356
- init: init,
357
- options: options,
358
- name: 'hover',
359
- version: '0.1'
360
- });
361
- })(jQuery);
1
+ /* global jQuery */
2
+
3
+ /**
4
+ ## jquery.flot.hover.js
5
+
6
+ This plugin is used for mouse hover and tap on a point of plot series.
7
+ It supports the following options:
8
+ ```js
9
+ grid: {
10
+ hoverable: false, //to trigger plothover event on mouse hover or tap on a point
11
+ clickable: false //to trigger plotclick event on mouse hover
12
+ }
13
+ ```
14
+
15
+ It listens to native mouse move event or click, as well as artificial generated
16
+ tap and touchevent.
17
+
18
+ When the mouse is over a point or a tap on a point is performed, that point or
19
+ the correscponding bar will be highlighted and a "plothover" event will be generated.
20
+
21
+ Custom "touchevent" is triggered when any touch interaction is made. Hover plugin
22
+ handles this events by unhighlighting all of the previously highlighted points and generates
23
+ "plothovercleanup" event to notify any part that is handling plothover (for exemple to cleanup
24
+ the tooltip from webcharts).
25
+ */
26
+
27
+ (function($) {
28
+ 'use strict';
29
+
30
+ var options = {
31
+ grid: {
32
+ hoverable: false,
33
+ clickable: false
34
+ }
35
+ };
36
+
37
+ var browser = $.plot.browser;
38
+
39
+ var eventType = {
40
+ click: 'click',
41
+ hover: 'hover'
42
+ }
43
+
44
+ function init(plot) {
45
+ var lastMouseMoveEvent;
46
+ var highlights = [];
47
+
48
+ console.log("hover init");
49
+
50
+ function bindEvents(plot, eventHolder) {
51
+ var o = plot.getOptions();
52
+
53
+ if (o.grid.hoverable || o.grid.clickable) {
54
+ eventHolder[0].addEventListener('touchevent', triggerCleanupEvent, false);
55
+ eventHolder[0].addEventListener('tap', generatePlothoverEvent, false);
56
+ }
57
+
58
+ if (o.grid.clickable) {
59
+ eventHolder.bind("click", onClick);
60
+ }
61
+
62
+ if (o.grid.hoverable) {
63
+ eventHolder.bind("mousemove", onMouseMove);
64
+
65
+ // Use bind, rather than .mouseleave, because we officially
66
+ // still support jQuery 1.2.6, which doesn't define a shortcut
67
+ // for mouseenter or mouseleave. This was a bug/oversight that
68
+ // was fixed somewhere around 1.3.x. We can return to using
69
+ // .mouseleave when we drop support for 1.2.6.
70
+
71
+ eventHolder.bind("mouseleave", onMouseLeave);
72
+ }
73
+ }
74
+
75
+ function shutdown(plot, eventHolder) {
76
+ eventHolder[0].removeEventListener('tap', generatePlothoverEvent);
77
+ eventHolder[0].removeEventListener('touchevent', triggerCleanupEvent);
78
+ eventHolder.unbind("mousemove", onMouseMove);
79
+ eventHolder.unbind("mouseleave", onMouseLeave);
80
+ eventHolder.unbind("click", onClick);
81
+ highlights = [];
82
+ }
83
+
84
+ function generatePlothoverEvent(e) {
85
+ var o = plot.getOptions(),
86
+ newEvent = new CustomEvent('mouseevent');
87
+
88
+ //transform from touch event to mouse event format
89
+ newEvent.pageX = e.detail.changedTouches[0].pageX;
90
+ newEvent.pageY = e.detail.changedTouches[0].pageY;
91
+ newEvent.clientX = e.detail.changedTouches[0].clientX;
92
+ newEvent.clientY = e.detail.changedTouches[0].clientY;
93
+
94
+ if (o.grid.hoverable) {
95
+ doTriggerClickHoverEvent(newEvent, eventType.hover, 30);
96
+ }
97
+ return false;
98
+ }
99
+
100
+ function doTriggerClickHoverEvent(event, eventType, searchDistance) {
101
+ var series = plot.getData();
102
+ if (event !== undefined &&
103
+ series.length > 0 &&
104
+ series[0].xaxis.c2p !== undefined &&
105
+ series[0].yaxis.c2p !== undefined) {
106
+ var eventToTrigger = "plot" + eventType;
107
+ var seriesFlag = eventType + "able";
108
+ triggerClickHoverEvent(eventToTrigger, event,
109
+ function(i) {
110
+ return series[i][seriesFlag] !== false;
111
+ }, searchDistance);
112
+ }
113
+ }
114
+
115
+ function onMouseMove(e) {
116
+ lastMouseMoveEvent = e;
117
+ plot.getPlaceholder()[0].lastMouseMoveEvent = e;
118
+ doTriggerClickHoverEvent(e, eventType.hover);
119
+ }
120
+
121
+ function onMouseLeave(e) {
122
+ lastMouseMoveEvent = undefined;
123
+ plot.getPlaceholder()[0].lastMouseMoveEvent = undefined;
124
+ triggerClickHoverEvent("plothover", e,
125
+ function(i) {
126
+ return false;
127
+ });
128
+ }
129
+
130
+ function onClick(e) {
131
+ doTriggerClickHoverEvent(e, eventType.click);
132
+ }
133
+
134
+ function triggerCleanupEvent() {
135
+ plot.unhighlight();
136
+ plot.getPlaceholder().trigger('plothovercleanup');
137
+ }
138
+
139
+ // trigger click or hover event (they send the same parameters
140
+ // so we share their code)
141
+ function triggerClickHoverEvent(eventname, event, seriesFilter, searchDistance) {
142
+ var options = plot.getOptions(),
143
+ offset = plot.offset(),
144
+ page = browser.getPageXY(event),
145
+ canvasX = page.X - offset.left,
146
+ canvasY = page.Y - offset.top,
147
+ pos = plot.c2p({
148
+ left: canvasX,
149
+ top: canvasY
150
+ }),
151
+ distance = searchDistance !== undefined ? searchDistance : options.grid.mouseActiveRadius;
152
+
153
+ pos.pageX = page.X;
154
+ pos.pageY = page.Y;
155
+
156
+ var items = plot.findNearbyItems(canvasX, canvasY, seriesFilter, distance);
157
+ var item = items[0];
158
+
159
+ for (let i = 1; i < items.length; ++i) {
160
+ if (item.distance === undefined ||
161
+ items[i].distance < item.distance) {
162
+ item = items[i];
163
+ }
164
+ }
165
+
166
+ if (item) {
167
+ // fill in mouse pos for any listeners out there
168
+ item.pageX = parseInt(item.series.xaxis.p2c(item.datapoint[0]) + offset.left, 10);
169
+ item.pageY = parseInt(item.series.yaxis.p2c(item.datapoint[1]) + offset.top, 10);
170
+ } else {
171
+ item = null;
172
+ }
173
+
174
+ if (options.grid.autoHighlight) {
175
+ // clear auto-highlights
176
+ for (let i = 0; i < highlights.length; ++i) {
177
+ var h = highlights[i];
178
+ if ((h.auto === eventname &&
179
+ !(item && h.series === item.series &&
180
+ h.point[0] === item.datapoint[0] &&
181
+ h.point[1] === item.datapoint[1])) || !item) {
182
+ unhighlight(h.series, h.point);
183
+ }
184
+ }
185
+
186
+ if (item) {
187
+ highlight(item.series, item.datapoint, eventname);
188
+ }
189
+ }
190
+
191
+ plot.getPlaceholder().trigger(eventname, [pos, item, items]);
192
+ }
193
+
194
+ function highlight(s, point, auto) {
195
+ if (typeof s === "number") {
196
+ s = plot.getData()[s];
197
+ }
198
+
199
+ if (typeof point === "number") {
200
+ var ps = s.datapoints.pointsize;
201
+ point = s.datapoints.points.slice(ps * point, ps * (point + 1));
202
+ }
203
+
204
+ var i = indexOfHighlight(s, point);
205
+ if (i === -1) {
206
+ highlights.push({
207
+ series: s,
208
+ point: point,
209
+ auto: auto
210
+ });
211
+
212
+ plot.triggerRedrawOverlay();
213
+ } else if (!auto) {
214
+ highlights[i].auto = false;
215
+ }
216
+ }
217
+
218
+ function unhighlight(s, point) {
219
+ if (s == null && point == null) {
220
+ highlights = [];
221
+ plot.triggerRedrawOverlay();
222
+ return;
223
+ }
224
+
225
+ if (typeof s === "number") {
226
+ s = plot.getData()[s];
227
+ }
228
+
229
+ if (typeof point === "number") {
230
+ var ps = s.datapoints.pointsize;
231
+ point = s.datapoints.points.slice(ps * point, ps * (point + 1));
232
+ }
233
+
234
+ var i = indexOfHighlight(s, point);
235
+ if (i !== -1) {
236
+ highlights.splice(i, 1);
237
+
238
+ plot.triggerRedrawOverlay();
239
+ }
240
+ }
241
+
242
+ function indexOfHighlight(s, p) {
243
+ for (var i = 0; i < highlights.length; ++i) {
244
+ var h = highlights[i];
245
+ if (h.series === s &&
246
+ h.point[0] === p[0] &&
247
+ h.point[1] === p[1]) {
248
+ return i;
249
+ }
250
+ }
251
+
252
+ return -1;
253
+ }
254
+
255
+ function processDatapoints() {
256
+ triggerCleanupEvent();
257
+ doTriggerClickHoverEvent(lastMouseMoveEvent, eventType.hover);
258
+ }
259
+
260
+ function setupGrid() {
261
+ doTriggerClickHoverEvent(lastMouseMoveEvent, eventType.hover);
262
+ }
263
+
264
+ function drawOverlay(plot, octx, overlay) {
265
+ var plotOffset = plot.getPlotOffset(),
266
+ i, hi;
267
+
268
+ octx.save();
269
+ octx.translate(plotOffset.left, plotOffset.top);
270
+ for (i = 0; i < highlights.length; ++i) {
271
+ hi = highlights[i];
272
+
273
+ if (hi.series.bars.show) drawBarHighlight(hi.series, hi.point, octx);
274
+ else drawPointHighlight(hi.series, hi.point, octx, plot);
275
+ }
276
+ octx.restore();
277
+ }
278
+
279
+ function drawPointHighlight(series, point, octx, plot) {
280
+ var x = point[0],
281
+ y = point[1],
282
+ axisx = series.xaxis,
283
+ axisy = series.yaxis,
284
+ highlightColor = (typeof series.highlightColor === "string") ? series.highlightColor : $.color.parse(series.color).scale('a', 0.5).toString();
285
+
286
+ if (x < axisx.min || x > axisx.max || y < axisy.min || y > axisy.max) {
287
+ return;
288
+ }
289
+
290
+ var pointRadius = series.points.radius + series.points.lineWidth / 2;
291
+ octx.lineWidth = pointRadius;
292
+ octx.strokeStyle = highlightColor;
293
+ var radius = 1.5 * pointRadius;
294
+ x = axisx.p2c(x);
295
+ y = axisy.p2c(y);
296
+
297
+ octx.beginPath();
298
+ var symbol = series.points.symbol;
299
+ if (symbol === 'circle') {
300
+ octx.arc(x, y, radius, 0, 2 * Math.PI, false);
301
+ } else if (typeof symbol === 'string' && plot.drawSymbol && plot.drawSymbol[symbol]) {
302
+ plot.drawSymbol[symbol](octx, x, y, radius, false);
303
+ }
304
+
305
+ octx.closePath();
306
+ octx.stroke();
307
+ }
308
+
309
+ function drawBarHighlight(series, point, octx) {
310
+ var highlightColor = (typeof series.highlightColor === "string") ? series.highlightColor : $.color.parse(series.color).scale('a', 0.5).toString(),
311
+ fillStyle = highlightColor,
312
+ barLeft;
313
+
314
+ var barWidth = series.bars.barWidth[0] || series.bars.barWidth;
315
+ switch (series.bars.align) {
316
+ case "left":
317
+ barLeft = 0;
318
+ break;
319
+ case "right":
320
+ barLeft = -barWidth;
321
+ break;
322
+ default:
323
+ barLeft = -barWidth / 2;
324
+ }
325
+
326
+ octx.lineWidth = series.bars.lineWidth;
327
+ octx.strokeStyle = highlightColor;
328
+
329
+ var fillTowards = series.bars.fillTowards || 0,
330
+ bottom = fillTowards > series.yaxis.min ? Math.min(series.yaxis.max, fillTowards) : series.yaxis.min;
331
+
332
+ $.plot.drawSeries.drawBar(point[0], point[1], point[2] || bottom, barLeft, barLeft + barWidth,
333
+ function() {
334
+ return fillStyle;
335
+ }, series.xaxis, series.yaxis, octx, series.bars.horizontal, series.bars.lineWidth);
336
+ }
337
+
338
+ function initHover(plot, options) {
339
+ plot.highlight = highlight;
340
+ plot.unhighlight = unhighlight;
341
+ if (options.grid.hoverable || options.grid.clickable) {
342
+ plot.hooks.drawOverlay.push(drawOverlay);
343
+ plot.hooks.processDatapoints.push(processDatapoints);
344
+ plot.hooks.setupGrid.push(setupGrid);
345
+ }
346
+
347
+ lastMouseMoveEvent = plot.getPlaceholder()[0].lastMouseMoveEvent;
348
+ }
349
+
350
+ plot.hooks.bindEvents.push(bindEvents);
351
+ plot.hooks.shutdown.push(shutdown);
352
+ plot.hooks.processOptions.push(initHover);
353
+ }
354
+
355
+ $.plot.plugins.push({
356
+ init: init,
357
+ options: options,
358
+ name: 'hover',
359
+ version: '0.1'
360
+ });
361
+ })(jQuery);