| <!DOCTYPE html> |
| <link href="resources/grid.css" rel="stylesheet"> |
| <link href="resources/grid-alignment.css" rel="stylesheet"> |
| <script src="../../resources/check-layout.js"></script> |
| <style> |
| body { |
| margin: 0; |
| } |
| |
| .grid { |
| -webkit-grid-template-columns: 100px 200px; |
| -webkit-grid-template-rows: 200px 200px; |
| padding: 10px 15px 20px 30px; |
| border-width: 5px 10px 15px 20px; |
| border-style: dotted; |
| border-color: blue; |
| width: -webkit-fit-content; |
| position: relative; |
| } |
| |
| .content { |
| width: 20px; |
| height: 40px; |
| } |
| |
| .cell { |
| margin: 4px 8px 12px 16px; |
| } |
| </style> |
| <body onload="checkLayout('.grid')"> |
| |
| <p>This test checks that the 'margin', 'border' and 'padding' properties are applied together correctly for 'align' and 'justify' properties.</p> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR | align-items: 'auto' | justify-items: 'auto'</p> |
| <div class="grid itemsStart" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="46" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="cell firstRowSecondColumn" data-offset-x="146" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="cell secondRowFirstColumn" data-offset-x="46" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="146" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR | align-items: 'center' | justify-items: 'center'</p> |
| <div class="grid itemsCenter" data-expected-width="375" data-expected-height="450"> |
| <div class="firstRowFirstColumn cell" data-offset-x="74" data-offset-y="86" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="224" data-offset-y="286" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR | align-items: 'end' | justify-items: 'end'</p> |
| <div class="grid itemsEnd" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="102" data-offset-y="158" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="302" data-offset-y="358" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR | align-items: 'left' | justify-items: 'left'</p> |
| <div class="grid itemsLeft" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="46" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="146" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR | align-items: 'right' | justify-items: 'right'</p> |
| <div class="grid itemsRight" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="102" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="302" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR (ortho) | align-items: 'self-start' | justify-items: 'self-start'</p> |
| <div class="grid directionLTR itemsSelfStart" data-expected-width="375" data-expected-height="450"> |
| <div class="directionRTL cell firstRowFirstColumn" data-offset-x="102" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionRTL stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL cell secondRowSecondColumn" data-offset-x="302" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR (ortho) | align-items: 'self-end' | justify-items: 'self-end'</p> |
| <div class="grid directionLTR itemsSelfEnd" data-expected-width="375" data-expected-height="450"> |
| <div class="directionRTL cell firstRowFirstColumn" data-offset-x="46" data-offset-y="158" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionRTL stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL cell secondRowSecondColumn" data-offset-x="146" data-offset-y="358" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR (parall) | align-items: 'self-start' | justify-items: 'self-start'</p> |
| <div class="grid directionLTR itemsSelfStart" data-expected-width="375" data-expected-height="450"> |
| <div class="directionLTR cell firstRowFirstColumn" data-offset-x="46" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionLTR stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR cell secondRowSecondColumn" data-offset-x="146" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: LTR - (parall) | align-items: 'self-end' | justify-items: 'self-end'</p> |
| <div class="grid directionLTR itemsSelfEnd" data-expected-width="375" data-expected-height="450"> |
| <div class="directionLTR cell firstRowFirstColumn" data-offset-x="102" data-offset-y="158" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionLTR stretch firstRowSecondColumn" data-offset-x="130" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR stretch secondRowFirstColumn" data-offset-x="30" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR cell secondRowSecondColumn" data-offset-x="302" data-offset-y="358" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <!-- RTL direction. --> |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL | align-items: 'auto' | justify-items: 'auto'</p> |
| <div class="grid directionRTL itemsStart" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="302" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="cell firstRowSecondColumn" data-offset-x="202" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="cell secondRowFirstColumn" data-offset-x="302" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="202" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL | align-items: 'center' | justify-items: 'center'</p> |
| <div class="grid directionRTL itemsCenter" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="274" data-offset-y="86" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="124" data-offset-y="286" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL | align-items: 'end' | justify-items: 'end'</p> |
| <div class="grid directionRTL itemsEnd" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="246" data-offset-y="158" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="46" data-offset-y="358" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL | align-items: 'left' | justify-items: 'left'</p> |
| <div class="grid directionRTL itemsLeft" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="246" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="46" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL | align-items: 'right' | justify-items: 'right'</p> |
| <div class="grid directionRTL itemsRight" data-expected-width="375" data-expected-height="450"> |
| <div class="cell firstRowFirstColumn" data-offset-x="302" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="cell secondRowSecondColumn" data-offset-x="202" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL (ortho) | align-items: 'self-start' | justify-items: 'self-start'</p> |
| <div class="grid directionRTL itemsSelfStart" data-expected-width="375" data-expected-height="450"> |
| <div class="directionLTR cell firstRowFirstColumn" data-offset-x="246" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionLTR stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR cell secondRowSecondColumn" data-offset-x="46" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL (ortho) | align-items: 'self-end' | justify-items: 'self-end'</p> |
| <div class="grid directionRTL itemsSelfEnd" data-expected-width="375" data-expected-height="450"> |
| <div class="directionLTR cell firstRowFirstColumn" data-offset-x="302" data-offset-y="158" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionLTR stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionLTR cell secondRowSecondColumn" data-offset-x="202" data-offset-y="358" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL (parall) | align-items: 'self-start' | justify-items: 'self-start'</p> |
| <div class="grid directionRTL itemsSelfStart" data-expected-width="375" data-expected-height="450"> |
| <div class="directionRTL cell firstRowFirstColumn" data-offset-x="302" data-offset-y="14" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionRTL stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL cell secondRowSecondColumn" data-offset-x="202" data-offset-y="214" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |
| |
| <div> |
| <p>border: 5px 10px 15px 20px | padding: 10px 15px 20px 30px | margin: 4px 8px 12px 16px<br> |
| direction: RTL (parall) | align-items: 'self-end' | justify-items: 'self-end'</p> |
| <div class="grid directionRTL itemsSelfEnd" data-expected-width="375" data-expected-height="450"> |
| <div class="directionRTL cell firstRowFirstColumn" data-offset-x="246" data-offset-y="158" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| <div class="directionRTL stretch firstRowSecondColumn" data-offset-x="30" data-offset-y="10" data-expected-width="200" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL stretch secondRowFirstColumn" data-offset-x="230" data-offset-y="210" data-expected-width="100" data-expected-height="200"><div class="content"></div></div> |
| <div class="directionRTL cell secondRowSecondColumn" data-offset-x="46" data-offset-y="358" data-expected-width="20" data-expected-height="40"><div class="content"></div></div> |
| </div> |
| </div> |