-
Notifications
You must be signed in to change notification settings - Fork 0
/
timeslidertooltipplugin.uncompressed.js
executable file
·161 lines (141 loc) · 9.31 KB
/
timeslidertooltipplugin.uncompressed.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
(function(jwplayer)
{
var template = function(player, config, div)
{
var _j = $(div);
var _ready = false;
var _rail = null;
var _controlbar = null;
function setup(evt)
{
// Parsing the config object
_parseConfig();
// Create the Tooltip
_createTooltip();
// Setting variables
_rail = $("#" + player.id + "_jwplayer_controlbar_timeSliderRail");
_controlbar = $("#" + player.id + "_jwplayer_controlbar_elements");
// If everything went fine...
if(1===_rail.length && 1===_controlbar.length)
{
_ready = true;
_controlbar.append(_j);
_controlbar.bind('mousemove', _mousemove);
_controlbar.bind('mouseout', _mouseout);
}
};
player.onReady(setup);
this.resize = function(width, height)
{
var map = {};
map.left = Math.round(width/2) + 'px';
var mb = isNaN(config.marginbottom) ? 0 : config.marginbottom;
var pos = _controlbar.offset().top;
_controlbar.append(_j);
map.bottom = (_j.height() - mb) + 'px';
_j.css(map);
};
function _parseConfig()
{
config.displayhours = ("true" == String(config.displayhours)) ? true : false;
var marginBottom = parseInt(config.marginbottom);
config.marginbottom = isNaN(marginBottom) ? 0 : marginBottom;
var labelHeight = parseInt(config.labelheight);
config.labelheight = (isNaN(labelHeight)) ? 17 : labelHeight;
config.font = (!config.font) ? "Arial,sans-serif" : config.font;
var fontSize = parseInt(config.fontsize);
config.fontsize = isNaN(fontSize) ? 11 : fontSize;
var fontColor = config.fontcolor;
config.fontcolor = (!fontColor) ? "#000" : fontColor;
var fontWeight = config.fontweight;
config.fontweight = (fontWeight!="normal" && fontWeight!="bold") ? "normal" : fontWeight;
var fontStyle = config.fontstyle;
config.fontstyle = (fontStyle!="normal" && fontStyle!="italic") ? "normal" : fontStyle;
config.defaultImage = "";
config.image = (null!=config.image) ? config.image : config.defaultImage;
};
function _createTooltip()
{
// Initialize tooltip
// ==================
var map = {};
div.innerHTML = "...";
_show(false);
// Background
// ==========
map.width = "41px";
map.height = "22px";
map.background = "url('" + config.defaultImage + "') left top no-repeat transparent";
var img = new Image();
img.onload = function()
{
div.style.background = "url('" + config.image + "') left top no-repeat transparent";
div.style.width = this.width + "px";
div.style.height = this.height + "px";
};
img.src = config.image;
// Applying
// ========
map.position = 'absolute';
map.color = config.fontcolor;
map.fontFamily = config.font;
map.fontSize = config.fontsize + "px";
map.fontWeight = config.fontweight;
map.color = config.fontcolor;
map.fontStyle = config.fontstyle;
map.textAlign = "center";
map.lineHeight = config.labelheight + "px";
map.pointerEvents = "none";
_j.css(map);
};
function _show(state)
{
div.style.display = (false===state) ? "none" : "block";
};
function _mousemove(event)
{
var dur = player.getDuration();
if(_ready && dur > 0)
{
var x_pos = event.pageX - _rail.offset().left;
var width = _rail.width();
var percent = x_pos/width;
var tooltip_x = event.pageX - _j.parent().offset().left;
div.innerHTML = _toTimeString(Math.round(percent*dur));
tooltip_x -= Math.ceil(_j.width()/2);
div.style.left = tooltip_x + "px";
_show(x_pos >= 0 && x_pos <= width);
}
else
{
_show(false)
}
};
function _mouseout(event)
{
_show(false)
};
function _toTimeString(n)
{
var time_str = "";
if (n >= 3600 && true===config.displayhours)
{ // Longer than one hour
var hours = Math.floor(n / 3600);
time_str += Math.floor(n / 3600) + ":";
n -= 3600 * hours;
}
time_str += _pad(Math.floor(n / 60), 2) + ":" + _pad(Math.floor(n % 60), 2);
return time_str;
};
function _pad(n, padLength)
{
var str = n.toString();
while ( str.length < padLength )
{
str = "0" + str;
}
return str;
};
};
jwplayer().registerPlugin('timeslidertooltipplugin', template, "timeslidertooltipplugin-1");
})(jwplayer);