aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/render/Tooltip.tsx
blob: 7bb2e1f37f9f488118cb1241c30061737638a738 (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
70
71
72
73
import * as React from "react";
import * as ReactDOM from "react-dom";

export interface TooltipProps {
    text: string, 
    link?: string,
    referenceNode: HTMLElement,
    prependElement?: HTMLElement, // Element to append before
    bottomOffset?: string
    timeout?: number;
}

export class Tooltip {
    text: string;   
    container: HTMLDivElement;

    timer: NodeJS.Timeout;
    
    constructor(props: TooltipProps) {
        props.bottomOffset ??= "70px";
        this.text = props.text;

        this.container = document.createElement('div');
        this.container.id = "sponsorTooltip" + props.text;
        this.container.style.display = "relative";

        if (props.prependElement) {
            props.referenceNode.insertBefore(this.container, props.prependElement);
        } else {
            props.referenceNode.appendChild(this.container);
        }

        if (props.timeout) {
            this.timer = setTimeout(() => this.close(), props.timeout * 1000);
        }

        ReactDOM.render(
            <div style={{bottom: props.bottomOffset}} 
                className="sponsorBlockTooltip" >
                <div>
                    <img className="sponsorSkipLogo sponsorSkipObject"
                        src={chrome.extension.getURL("icons/IconSponsorBlocker256px.png")}>
                    </img>
                    <span className="sponsorSkipObject">
                        {this.text + (props.link ? ". " : "")}
                        {props.link ? 
                            <a style={{textDecoration: "underline"}} 
                                    target="_blank"
                                    rel="noopener noreferrer"
                                    href={props.link}>
                                {chrome.i18n.getMessage("LearnMore")}
                                </a> 
                        : null}
                    </span>
                </div>
                <button className="sponsorSkipObject sponsorSkipNoticeButton"
                    style ={{float: "right" }}
                    onClick={() => this.close()}>

                    {chrome.i18n.getMessage("GotIt")}
                </button>
            </div>,
            this.container
        )
    }

    close(): void {
        ReactDOM.unmountComponentAtNode(this.container);
        this.container.remove();

        if (this.timer) clearTimeout(this.timer);
    }
}