grid-item-alignment-with-orthogonal-flows.html (7946B)
1 <!DOCTYPE html> 2 <meta charset="utf-8"> 3 <title>CSS Grid Layout test: item alignment with orthogonal flows</title> 4 <link rel="author" title="Rossana Monteriso" href="mailto:rmonteriso@igalia.com"> 5 <link rel="help" href="https://drafts.csswg.org/css-align-3/#alignment-values"> 6 <link rel="help" href="https://drafts.csswg.org/css-writing-modes-4/#orthogonal-flows"> 7 <meta name="assert" content="This test checks that grid item alignment works as expected with horizontal-tb and vertical-rl/vertical-lr orthogonal flows"> 8 <meta name="flags" content="ahem"> 9 <link rel="stylesheet" href="/css/support/grid.css"> 10 <link rel="stylesheet" href="/css/support/alignment.css"> 11 <link rel="stylesheet" href="/css/support/width-keyword-classes.css"> 12 <link rel="stylesheet" type="text/css" href="/fonts/ahem.css" /> 13 14 <style> 15 .container { 16 position: relative; 17 } 18 .grid { 19 grid-template-columns: 100px 100px; 20 grid-template-rows: 150px 150px 150px; 21 font-size: 10px; 22 } 23 .item { 24 width: 20px; 25 height: 50px; 26 } 27 </style> 28 29 <script src="/resources/testharness.js"></script> 30 <script src="/resources/testharnessreport.js"></script> 31 <script src="/resources/check-layout-th.js"></script> 32 <script type="text/javascript"> 33 setup({ explicit_done: true }); 34 </script> 35 36 <body onload="document.fonts.ready.then(() => { checkLayout('.grid'); })"> 37 38 <p>This test checks that grid items alignment works as expected with HORIZONTAL-TB vs VERTICAL-RL orthogonal flows.</p> 39 40 <p>Orthogonal flows: HORIZONTAL-TB vs VERTICAL-RL</p> 41 <p>Direction: LTR vs LTR</p> 42 <div class="container"> 43 <div class="grid fit-content directionLTR"> 44 <div class="item firstRowFirstColumn verticalRL selfEnd" data-offset-x="80" data-offset-y="100">end</div> 45 <div class="item firstRowSecondColumn verticalRL selfCenter" data-offset-x="140" data-offset-y="50">center</div> 46 <div class="item secondRowFirstColumn verticalRL selfStart" data-offset-x="0" data-offset-y="150">start</div> 47 <div class="item secondRowSecondColumn verticalRL selfSelfEnd" data-offset-x="100" data-offset-y="250">s-end</div> 48 <div class="item thirdRowFirstColumn verticalRL selfSelfStart" data-offset-x="80" data-offset-y="300">s-start</div> 49 <div class="item thirdRowSecondColumn verticalRL" data-offset-x= "100" data-offset-y="300">default</div> 50 </div> 51 </div> 52 53 <p>Direction: RTL vs LTR</p> 54 <div class="container"> 55 <div class="grid fit-content directionRTL"> 56 <div class="item firstRowFirstColumn directionLTR verticalRL selfEnd" data-offset-x="100" data-offset-y="100">end</div> 57 <div class="item firstRowSecondColumn directionLTR verticalRL selfCenter" data-offset-x="40" data-offset-y="50">center</div> 58 <div class="item secondRowFirstColumn directionLTR verticalRL selfStart" data-offset-x="180" data-offset-y="150">start</div> 59 <div class="item secondRowSecondColumn directionLTR verticalRL selfSelfEnd" data-offset-x="0" data-offset-y="250">s-end</div> 60 <div class="item thirdRowFirstColumn directionLTR verticalRL selfSelfStart" data-offset-x="180" data-offset-y="300">s-start</div> 61 <div class="item thirdRowSecondColumn directionLTR verticalRL" data-offset-x="80" data-offset-y="300">default</div> 62 63 </div> 64 </div> 65 66 <p>Direction: LTR vs RTL</p> 67 <div class="container"> 68 <div class="grid fit-content directionLTR"> 69 <div class="item firstRowFirstColumn directionRTL verticalRL selfEnd" data-offset-x="80" data-offset-y="100">end</div> 70 <div class="item firstRowSecondColumn directionRTL verticalRL selfCenter" data-offset-x="140" data-offset-y="50">center</div> 71 <div class="item secondRowFirstColumn directionRTL verticalRL selfStart" data-offset-x="0" data-offset-y="150">start</div> 72 <div class="item secondRowSecondColumn directionRTL verticalRL selfSelfEnd" data-offset-x="100" data-offset-y="150">s-end</div> 73 <div class="item thirdRowFirstColumn directionRTL verticalRL selfSelfStart" data-offset-x="80" data-offset-y="400">s-start</div> 74 <div class="item thirdRowSecondColumn directionRTL verticalRL" data-offset-x="100" data-offset-y="300">default</div> 75 </div> 76 </div> 77 78 <p>Direction: RTL vs RTL</p> 79 <div class="container"> 80 <div class="grid fit-content directionRTL"> 81 <div class="item firstRowFirstColumn verticalRL selfEnd" data-offset-x="100" data-offset-y="100">end</div> 82 <div class="item firstRowSecondColumn verticalRL selfCenter" data-offset-x="40" data-offset-y="50">center</div> 83 <div class="item secondRowFirstColumn verticalRL selfStart" data-offset-x="180" data-offset-y="150">start</div> 84 <div class="item secondRowSecondColumn verticalRL selfSelfEnd" data-offset-x="0" data-offset-y="150">s-end</div> 85 <div class="item thirdRowFirstColumn verticalRL selfSelfStart" data-offset-x="180" data-offset-y="400">s-start</div> 86 <div class="item thirdRowSecondColumn verticalRL" data-offset-x="80" data-offset-y="300">default</div> 87 </div> 88 </div> 89 90 <!-- HORIZONTAL-TB vs VERTICAL-LR --> 91 <p>Orthogonal flows: HORIZONTAL-TB vs VERTICAL-LR</p> 92 <p>Direction: LTR vs LTR</p> 93 <div class="container"> 94 <div class="grid fit-content drectionLTR"> 95 <div class="item firstRowFirstColumn verticalLR selfEnd" data-offset-x="80" data-offset-y="100">end</div> 96 <div class="item firstRowSecondColumn verticalLR selfCenter" data-offset-x="140" data-offset-y="50">center</div> 97 <div class="item secondRowFirstColumn verticalLR selfStart" data-offset-x="0" data-offset-y="150">start</div> 98 <div class="item secondRowSecondColumn verticalLR selfSelfEnd" data-offset-x="180" data-offset-y="250">s-end</div> 99 <div class="item thirdRowFirstColumn verticalLR selfSelfStart" data-offset-x="0" data-offset-y="300">s-start</div> 100 <div class="item thirdRowSecondColumn verticalLR" data-offset-x="100" data-offset-y="300">default</div> 101 </div> 102 </div> 103 104 <p>Direction: RTL vs LTR</p> 105 <div class="container"> 106 <div class="grid fit-content directionRTL"> 107 <div class="item firstRowFirstColumn directionLTR verticalLR selfEnd" data-offset-x="100" data-offset-y="100">end</div> 108 <div class="item firstRowSecondColumn directionLTR verticalLR selfCenter" data-offset-x="40" data-offset-y="50">center</div> 109 <div class="item secondRowFirstColumn directionLTR verticalLR selfStart" data-offset-x="180" data-offset-y="150">start</div> 110 <div class="item secondRowSecondColumn directionLTR verticalLR selfSelfEnd" data-offset-x="80" data-offset-y="250">s-end</div> 111 <div class="item thirdRowFirstColumn directionLTR verticalLR selfSelfStart" data-offset-x="100" data-offset-y="300">s-start</div> 112 <div class="item thirdRowSecondColumn directionLTR verticalLR" data-offset-x="80" data-offset-y="300">default</div> 113 </div> 114 </div> 115 116 <p>Direction: RTL vs RTL</p> 117 <div class="container"> 118 <div class="grid fit-content directionRTL"> 119 <div class="item firstRowFirstColumn verticalLR selfEnd" data-offset-x="100" data-offset-y="100">end</div> 120 <div class="item firstRowSecondColumn verticalLR selfCenter" data-offset-x="40" data-offset-y="50">center</div> 121 <div class="item secondRowFirstColumn verticalLR selfStart" data-offset-x="180" data-offset-y="150">start</div> 122 <div class="item secondRowSecondColumn verticalLR selfSelfEnd" data-offset-x="80" data-offset-y="150">s-end</div> 123 <div class="item thirdRowFirstColumn verticalLR selfSelfStart" data-offset-x="100" data-offset-y="400">s-start</div> 124 <div class="item thirdRowSecondColumn verticalLR" data-offset-x="80" data-offset-y="300">default</div> 125 </div> 126 </div> 127 128 </body>