aboutsummaryrefslogtreecommitdiff
path: root/app/src/web/assets/js/context_a.ts
blob: 16ed33a9d1cd4564f2c7529431fb605672c5b937 (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
69
/**
 * Context menu for links
 * Largely mimics click_a.js
 */
(function () {
    let longClick = false;
    const _frostAContext = (e: Event) => {
        Frost.longClick(true);
        longClick = true;

        /*
         * Commonality; check for valid target
         */
        const target = e.target || e.currentTarget || e.srcElement;
        if (!(target instanceof Element)) {
            console.log("No element found");
            return
        }
        let element: Element = target;
        // Notifications are two layers under
        for (let i = 0; i < 2; i++) {
            if (element.tagName != 'A') {
                element = <Element>element.parentElement;
            }
        }
        if (element.tagName == 'A') {
            const url = element.getAttribute('href');
            if (!url || url == '#') {
                return
            }
            const text = (<HTMLElement>element.parentElement).innerText;
            // Check if image item exists, first in children and then in parent
            let image = element.querySelector("[style*=\"background-image: url(\"]");
            if (!image) {
                image = (<Element>element.parentElement).querySelector("[style*=\"background-image: url(\"]")
            }
            if (image) {
                const imageUrl = (<String>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
            const img = element.querySelector("img[src*=scontent]");
            if (img instanceof HTMLMediaElement) {
                const 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', () => {
        if (longClick) {
            Frost.longClick(false);
            longClick = false
        }
    }, true);
}).call(undefined);