aboutsummaryrefslogtreecommitdiff
path: root/app/src/web/ts/media.ts
blob: 5b9b1a54b8b98d91827890e31ecb4a5669b9886a (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
// Handles media events
(function () {
    const _frostMediaClick = (e: Event) => {
        const target = e.target || e.srcElement;
        if (!(target instanceof HTMLElement)) {
            return
        }
        let element: HTMLElement = target;
        const dataset = element.dataset;
        if (!dataset || !dataset.sigil || dataset.sigil.toLowerCase().indexOf('inlinevideo') == -1) {
            return
        }
        let i = 0;
        while (!element.hasAttribute('data-store')) {
            if (++i > 2) {
                return
            }
            element = <HTMLElement>element.parentNode;
        }
        const store = element.dataset.store;
        if (!store) {
            return
        }

        let dataStore;

        try {
            dataStore = JSON.parse(store)
        } catch (e) {
            return
        }

        const url = dataStore.src;

        // !startsWith; see https://stackoverflow.com/a/36876507/4407321
        if (!url || url.lastIndexOf('http', 0) !== 0) {
            return
        }

        console.log(`Inline video ${url}`);
        if (Frost.loadVideo(url, dataStore.animatedGifVideo || false)) {
            e.stopPropagation()
        }
    };

    document.addEventListener('click', _frostMediaClick, true);
}).call(undefined);