blob: 7e636cea3e194f125cf3ba06f5e4d7f0bc56634f (
plain)
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
|
"use strict";
/**
* Context menu for links
* Largely mimics click_a.js
*/
(function () {
var longClick = false;
var _frostAContext = function (e) {
Frost.longClick(true);
longClick = true;
/*
* Commonality; check for valid target
*/
var target = e.target || e.currentTarget || e.srcElement;
if (!(target instanceof Element)) {
console.log("No element found");
return;
}
var element = target;
// Notifications are two layers under
for (var i = 0; i < 2; i++) {
if (element.tagName != 'A') {
element = element.parentElement;
}
}
if (element.tagName == 'A') {
var url = element.getAttribute('href');
if (!url || url == '#') {
return;
}
var text = element.parentElement.innerText;
// Check if image item exists, first in children and then in parent
var image = element.querySelector("[style*=\"background-image: url(\"]");
if (!image) {
image = element.parentElement.querySelector("[style*=\"background-image: url(\"]");
}
if (image) {
var imageUrl = window.getComputedStyle(image, null).backgroundImage.trim().slice(4, -1);
console.log("Context image: " + imageUrl);
Frost.loadImage(imageUrl, text);
e.stopPropagation();
e.preventDefault();
return;
}
// Check if true img exists
var img = element.querySelector("img[src*=scontent]");
if (img instanceof HTMLMediaElement) {
var imgUrl = img.src;
console.log("Context img: " + imgUrl);
Frost.loadImage(imgUrl, text);
e.stopPropagation();
e.preventDefault();
return;
}
console.log("Context content " + url + " " + text);
Frost.contextMenu(url, text);
e.stopPropagation();
e.preventDefault();
}
};
document.addEventListener('contextmenu', _frostAContext, true);
document.addEventListener('touchend', function () {
if (longClick) {
Frost.longClick(false);
longClick = false;
}
}, true);
}).call(undefined);
|