summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/mathml/relations/css-styling/dynamic-dir-1.html
blob: d97505eff101c41731d7559962ba532ab67670eb (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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
<!DOCTYPE html>
<html class="reftest-wait">
<head>
  <meta charset="utf-8">
  <title>Test dynamically changing dir attribute</title>
  <link rel="help" href="https://w3c.github.io/mathml-core/#css-styling">
  <link rel="help" href="https://w3c.github.io/mathml-core/#attributes-common-to-html-and-mathml-elements">
  <link rel="help" href="https://w3c.github.io/mathml-core/#dom-and-javascript">
  <meta name="assert" content="The dir attribute should update direction map to css properties dynamically">
  <link rel="match" href="dynamic-dir-1-ref.html">
  <script>
      window.addEventListener("load", () => {

        // force initial layout so we're sure what we're testing against
        document.documentElement.getBoundingClientRect();

        ["math", "mstyle", "mrow"].forEach((tag) => {
          let elements = document.getElementsByTagName(tag);

          // set an explicit rtl where there was none
          elements[0].setAttribute("dir", "rtl");

          // change explicit ltr to rtl
          elements[1].setAttribute("dir", "rtl");

          // remove an explicitly set dir="rtl"
          elements[2].removeAttribute("dir");

        })

        document.documentElement.classList.remove('reftest-wait');
      })
    </script>
</head>
<body>
    <p>
      math:
      <math>
        <mi>a</mi>
        <mi>b</mi>
        <mi>c</mi>
      </math>
      <math dir="ltr">
        <mi>a</mi>
        <mi>b</mi>
        <mi>c</mi>
      </math>
      <math dir="rtl">
        <mi>a</mi>
        <mi>b</mi>
        <mi>c</mi>
      </math>
    </p>
    <p>
      mstyle:
      <math>
        <mstyle>
          <mi>a</mi>
          <mi>b</mi>
          <mi>c</mi>
        </mstyle>
      </math>
      <math>
        <mstyle dir="ltr">
          <mi>a</mi>
          <mi>b</mi>
          <mi>c</mi>
        </mstyle>
      </math>
      <math>
        <mstyle dir="rtl">
          <mi>a</mi>
          <mi>b</mi>
          <mi>c</mi>
        </mstyle>
      </math>
    </p>
    <p>
      mrow:
      <math>
        <mrow>
          <mi>a</mi>
          <mi>b</mi>
          <mi>c</mi>
        </mrow>
      </math>
      <math>
        <mrow dir="ltr">
          <mi>a</mi>
          <mi>b</mi>
          <mi>c</mi>
        </mrow>
      </math>
      <math>
        <mrow dir="rtl">
          <mi>a</mi>
          <mi>b</mi>
          <mi>c</mi>
        </mrow>
      </math>
    </p>
    <script src="/mathml/support/feature-detection.js"></script>
    <script>MathMLFeatureDetection.ensure_for_match_reftest("has_dir");</script>
</body>
</html>