<!DOCTYPE html>
<html>
<head>
<link href="resources/grid.css" rel="stylesheet">
<style>
.grid {
grid-auto-columns: 5px;
grid-auto-rows: 5px;
}
.gridWithoutRepeat {
grid-template-columns: [a] 50px [b] 100px [c] 200px [d];
grid-template-rows: [e] 50px [f] 100px [g] 200px [h];
}
.gridWithRepeat {
grid-template-columns: [b] 50px [b] 100px [b] 200px [b];
grid-template-rows: [g] 50px [g] 100px [g] 200px [g];
}
.gridFromSpecs {
grid-template-columns: [A] 10px [B] 20px [C] 30px [A] 40px [B] 50px [C] 60px [A] 70px [B] 80px [C];
grid-template-rows: 100px;
}
.gridItemBToD {
grid-column: b / d;
grid-row: 1;
}
.gridItemGToH {
grid-column: 1;
grid-row: g / h;
}
.gridItemInvalidNegativeGridLine {
grid-column: 1 / -1 nonexistent;
grid-row: span 2 / -10 nonexistent;
}
.gridItemAToSpanC {
grid-column: a / span c;
grid-row: 1;
}
.gridItemFToSpanH {
grid-column: 1;
grid-row: f span / h;
}
.gridItem2BSpan2B {
grid-column: 2 b / span 2 b;
grid-row: 1;
}
.gridItemSpan2GNegativeG {
grid-column: 1;
grid-row: span 2 g / -1 g;
}
</style>
<script src="../../resources/check-layout.js"></script>
</head>
<body onload="checkLayout('.grid')">
<p>This test checks that we resolve named grid line per the specification.</p>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<div class="sizedToGridArea gridItemBToD" data-offset-x="50" data-offset-y="0" data-expected-width="300" data-expected-height="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<div class="sizedToGridArea gridItemGToH" data-offset-x="0" data-offset-y="150" data-expected-width="50" data-expected-height="200"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithRepeat">
<div class="sizedToGridArea gridItemBToD" data-offset-x="0" data-offset-y="0" data-expected-width="355" data-expected-height="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithRepeat">
<div class="sizedToGridArea gridItemGToH" data-offset-x="0" data-offset-y="0" data-expected-width="50" data-expected-height="355"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<div class="sizedToGridArea gridItemInvalidNegativeGridLine" data-offset-x="0" data-offset-y="0" data-expected-width="5" data-expected-height="10"></div>
</div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<div class="sizedToGridArea gridItemAToSpanC" data-offset-x="0" data-offset-y="0" data-expected-width="150" data-expected-height="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<div class="sizedToGridArea gridItemFToSpanH" data-offset-x="0" data-offset-y="50" data-expected-width="50" data-expected-height="300"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<!-- Consider all the implicit lines to be called 'b' too. -->
<div class="sizedToGridArea gridItem2BSpan2B" data-offset-x="355" data-offset-y="0" data-expected-width="10" data-expected-height="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithoutRepeat">
<!-- Consider all the implicit lines to be called 'g' too. -->
<div class="sizedToGridArea gridItemSpan2GNegativeG" data-offset-x="0" data-offset-y="0" data-expected-width="50" data-expected-height="160"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithRepeat">
<!-- There is no 'a' or 'c' so all the implicit lines are considered to have those names. -->
<div class="sizedToGridArea gridItemAToSpanC" data-offset-x="355" data-offset-y="0" data-expected-width="5" data-expected-height="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithRepeat">
<!-- There is no 'f' or 'h' so all the implicit lines are considered to have those names. -->
<div class="sizedToGridArea gridItemFToSpanH" data-offset-x="0" data-offset-y="0" data-expected-width="50" data-expected-height="360"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithRepeat">
<div class="sizedToGridArea gridItem2BSpan2B" data-offset-x="50" data-offset-y="0" data-expected-width="300" data-expected-height="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridWithRepeat">
<div class="sizedToGridArea gridItemSpan2GNegativeG" data-offset-x="0" data-offset-y="50" data-expected-width="50" data-expected-height="300"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: 4 / auto;" data-offset-x="60" data-expected-width="40"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: auto / 6;" data-offset-x="100" data-expected-width="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: C / C -1;" data-offset-x="30" data-expected-width="330"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: C / span C;" data-offset-x="30" data-expected-width="120"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: span C / C -1;" data-offset-x="150" data-expected-width="210"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: span C / span C;" data-offset-x="0" data-expected-width="10"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: 5 / C -1;" data-offset-x="100" data-expected-width="260"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: 5 / span C;" data-offset-x="100" data-expected-width="50"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: 8 / 8;" data-offset-x="280" data-expected-width="80"></div>
</div>
</div>
<div style="position: relative">
<div class="grid gridFromSpecs">
<div class="sizedToGridArea" style="grid-column: B 2 / span 1;" data-offset-x="100" data-expected-width="50"></div>
</div>
</div>
</body>
</html>