-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontextmenu.js
128 lines (117 loc) · 3.5 KB
/
contextmenu.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
/**
* This part is responsible for the player context menu.
* Menu Options include:
* - Play / Pause
* - Mute / Unmute
* - Fill browser / Unfill browser
* - Speed
*
*/
/**
* Initialise player context menu with nested elements.
*/
domReady(function() {
var videoPlayer = document.getElementById("{{ video_player_id }}");
var dataSetup = JSON.parse(videoPlayer.getAttribute('data-setup'));
var playbackRates = dataSetup.playbackRates;
var docfrag = document.createDocumentFragment();
// VideoJS Player() object necessary for context menu creation
var player = videojs('{{ video_player_id }}');
/**
* Cross-browser wrapper for element.matchesSelector
* Source: https://gist.github.com/dalgard/7817372
*/
function matchesSelector(dom_element, selector) {
var matchesSelector =
dom_element.matches ||
dom_element.matchesSelector ||
dom_element.webkitMatchesSelector ||
dom_element.mozMatchesSelector ||
dom_element.msMatchesSelector ||
dom_element.oMatchesSelector;
return matchesSelector.call(dom_element, selector);
}
/**
* Create elements of nested context submenu.
*/
function createNestedContextSubMenu(e) {
var target = e.target;
// Generate nested submenu elements as document fragment
var ulSubMenu = document.createElement('ul');
ulSubMenu.className = 'vjs-contextmenu-ui-submenu';
playbackRates.forEach(function(rate) {
var liSubMenu = document.createElement('li');
liSubMenu.className = 'vjs-submenu-item';
liSubMenu.innerHTML = rate + 'x';
ulSubMenu.appendChild(liSubMenu);
liSubMenu.onclick = function() {
player.playbackRate(parseFloat(rate));
};
});
docfrag.appendChild(ulSubMenu);
// Create nested submenu
if (matchesSelector(target, "li.vjs-menu-item")
// if (target.matches("li.vjs-menu-item")
&& target.innerText == getItem('speed').label
&& !target.querySelector('.vjs-contextmenu-ui-submenu') ) {
target.appendChild(docfrag);
}
}
// Delegate creation of a nested submenu for a context menu
videoPlayer.addEventListener('mouseover', createNestedContextSubMenu);
// Create context menu options
var content = [{
id: "play",
label: 'Play',
listener: function () {
var item = getItem('play');
if (player.paused()) {
player.play();
item['label'] = 'Pause';
} else {
player.pause();
item['label'] = 'Play';
}
}}, {
id: "mute",
label: 'Mute',
listener: function () {
var item = getItem('mute');
if (player.muted()){
player.muted(false);
item['label'] = 'Mute';
} else {
player.muted(true);
item['label'] = 'Unmute';
}
}}, {
id: "fullscreen",
label: 'Fill browser',
listener: function () {
var item = getItem('fullscreen');
if (player.isFullscreen()){
player.exitFullscreen();
item['label'] = 'Fill browser';
} else {
player.requestFullscreen();
item['label'] = 'Unfill browser';
}
}}, {
// Nested submenu creation is delegated to the player
id: "speed",
label: 'Speed'
}
];
// Fire up vjs-contextmenu-ui plugin
player.contextmenuUI({content: content});
// Update context menu labels
var getItem = (function(contextmenuUI) {
var hash = {};
contextmenuUI.content.forEach(function(item) {
hash[item.id] = item;
});
return function(id) {
return hash[id];
};
}(player.contextmenuUI));
});