File: highlight-text-decorations.html

package info (click to toggle)
thunderbird 1%3A143.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 4,703,968 kB
  • sloc: cpp: 7,770,492; javascript: 5,943,842; ansic: 3,918,754; python: 1,418,263; xml: 653,354; asm: 474,045; java: 183,079; sh: 111,238; makefile: 20,410; perl: 14,359; objc: 13,059; yacc: 4,583; pascal: 3,405; lex: 1,720; ruby: 999; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 69; csh: 10
file content (63 lines) | stat: -rw-r--r-- 2,581 bytes parent folder | download | duplicates (7)
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
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Text decorations in custom highlight pseudo elements.</title>
    <link rel="help" href="https://drafts.csswg.org/css-highlight-api-1/#applicable-properties">
    <link rel="match" href="highlight-text-decorations-ref.html">
    <meta name="assert" content="Text decorations in highlights should be displayed.">
    <style>
        html {
            font-size: 24pt;
        }
        ::highlight(example-highlight1) {
            text-decoration: underline;
            text-decoration-color: red;
            color: blue;
        }
        ::highlight(example-highlight2) {
            text-decoration: line-through;
            text-decoration-color: violet;
            text-decoration-style: double;
        }
        ::highlight(example-highlight3) {
            text-decoration: overline;
            text-decoration-color: orange;
            text-decoration-style: dotted;
        }
        /* FIXME: There is a discrepency for how the underlines are displayed at the end of the line, leading to a pixel different in this text. Find a real fix, but in the meantime, obscure the offending pixel https://bugs.webkit.org/show_bug.cgi?id=207512 <rdar://problem/59327965> */
        .obscurer1 {
            position: absolute;
            top: 25px;
            left: 95px;
            width: 10px;
            height: 10px;
            background: grey;
        }
        .obscurer2 {
            position: absolute;
            top: 35px;
            left: 180px;
            width: 10px;
            height: 10px;
            background: grey;
        }
    </style>
</head>
<body>
    <span id="text1">One two three</span>
    <div class='obscurer1'></div>
    <div class='obscurer2'></div>

    <script>
        let textElement = document.getElementById('text1');
        let highlight1 = new Highlight(new StaticRange({startContainer: textElement.childNodes[0], startOffset: 1, endContainer: textElement.childNodes[0], endOffset: 2}));
        let highlight2 = new Highlight(new StaticRange({startContainer: textElement.childNodes[0], startOffset: 5, endContainer: textElement.childNodes[0], endOffset: 6}));
        let highlight3 = new Highlight(new StaticRange({startContainer: textElement.childNodes[0], startOffset: 10, endContainer: textElement.childNodes[0], endOffset: 13}));

        CSS.highlights.set("example-highlight1", highlight1);
        CSS.highlights.set("example-highlight2", highlight2);
        CSS.highlights.set("example-highlight3", highlight3);
    </script>
</body>
</html>