<!DOCTYPE html>
<title>CSS Flexbox: flex factors less than one</title>
<link href="support/flexbox.css" rel="stylesheet">
<link rel="help" href="https://www.w3.org/TR/css-flexbox-1/#propdef-flex-grow">
<link rel="help" href="https://www.w3.org/TR/css-flexbox-1/#propdef-flex-shrink">
<meta name="assert" content="flex-grow and flex-shrink factors less than 1 work">
<style>
html, body {
margin: 0;
padding: 0;
}
.container {
height: 100px;
width: 100px;
border: 1px solid black;
}
.child-flex-grow-0-75 {
background-color: lime;
flex-grow: 0.75;
}
.child-flex-grow-0-5 {
background-color: green;
flex-grow: 0.5;
}
.child-flex-grow-0-25 {
background-color: red;
flex-grow: 0.25;
}
.child-flex-shrink-0-5 {
background-color: green;
flex-shrink: 0.5;
width: 200px;
height: 200px;
}
.child-flex-shrink-0-25 {
background-color: red;
flex-shrink: 0.25;
width: 200px;
height: 200px;
}
.basis-0 {
flex-basis: 0;
}
.basis {
flex-basis: 30px;
}
.basis-big {
flex-basis: 100px;
}
.vertical {
writing-mode: vertical-rl;
}
</style>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/check-layout-th.js"></script>
<body onload="checkLayout('.flexbox');">
<div id=log></div>
<div class="flexbox container">
<div class="child-flex-grow-0-5" data-expected-width="50"></div>
</div>
<div class="flexbox container">
<div class="child-flex-grow-0-5" data-expected-width="50"></div>
<div class="child-flex-grow-0-25" data-expected-width="25"></div>
</div>
<div class="flexbox container column">
<div class="child-flex-grow-0-5" data-expected-height="50"></div>
<div class="child-flex-grow-0-25" data-expected-height="25"></div>
</div>
<div class="flexbox container column vertical">
<div class="child-flex-grow-0-5 " data-expected-width="50"></div>
<div class="child-flex-grow-0-25 " data-expected-width="25"></div>
</div>
<div class="flexbox container vertical">
<div class="child-flex-grow-0-5 " data-expected-height="50"></div>
<div class="child-flex-grow-0-25 " data-expected-height="25"></div>
</div>
<div class="flexbox container">
<div class="child-flex-grow-0-5 basis" data-expected-width="50"></div>
<div class="child-flex-grow-0-25 basis" data-expected-width="40"></div>
</div>
<div class="flexbox container column">
<div class="child-flex-grow-0-5 basis" data-expected-height="50"></div>
<div class="child-flex-grow-0-25 basis" data-expected-height="40"></div>
</div>
<div class="flexbox container vertical">
<div class="child-flex-grow-0-5 basis" data-expected-height="50"></div>
<div class="child-flex-grow-0-25 basis" data-expected-height="40"></div>
</div>
<div class="flexbox container column vertical">
<div class="child-flex-grow-0-5 basis" data-expected-width="50"></div>
<div class="child-flex-grow-0-25 basis" data-expected-width="40"></div>
</div>
<!-- And now, the shrink cases -->
<div class="flexbox container">
<div class="child-flex-shrink-0-5" data-expected-width="150"></div>
</div>
<div class="flexbox container">
<div class="child-flex-shrink-0-5" data-expected-width="50"></div>
<div class="child-flex-shrink-0-25" data-expected-width="125"></div>
</div>
<div class="flexbox container column">
<div class="child-flex-shrink-0-5" data-expected-height="50"></div>
<div class="child-flex-shrink-0-25" data-expected-height="125"></div>
</div>
<div class="flexbox container column vertical">
<div class="child-flex-shrink-0-5 " data-expected-width="50"></div>
<div class="child-flex-shrink-0-25 " data-expected-width="125"></div>
</div>
<div class="flexbox container vertical">
<div class="child-flex-shrink-0-5 " data-expected-height="50"></div>
<div class="child-flex-shrink-0-25 " data-expected-height="125"></div>
</div>
<div class="flexbox container">
<div class="child-flex-shrink-0-5 basis-big" data-expected-width="50"></div>
<div class="child-flex-shrink-0-25 basis-big" data-expected-width="75"></div>
</div>
<div class="flexbox container column">
<div class="child-flex-shrink-0-5 basis-big" data-expected-height="50"></div>
<div class="child-flex-shrink-0-25 basis-big" data-expected-height="75"></div>
</div>
<div class="flexbox container vertical">
<div class="child-flex-shrink-0-5 basis-big" data-expected-height="50"></div>
<div class="child-flex-shrink-0-25 basis-big" data-expected-height="75"></div>
</div>
<div class="flexbox container column vertical">
<div class="child-flex-shrink-0-5 basis-big" data-expected-width="50"></div>
<div class="child-flex-shrink-0-25 basis-big" data-expected-width="75"></div>
</div>
<!-- Interaction of min-width: auto with fractional flex basis -->
<div class="flexbox container" style="background-color: red;">
<div class="child-flex-grow-0-25 basis-0" style="background-color: green;" data-expected-width="10"></div>
<div class="child-flex-grow-0-75 basis-0" data-expected-width="90">
<div style="width: 90px;"></div>
</div>
</div>
<!-- centering should still center; same for other justify-content values -->
<div class="flexbox container justify-content-center">
<div class="child-flex-grow-0-5" data-expected-width="50" data-offset-x="26"></div>
</div>
<div class="flexbox container justify-content-space-around">
<div class="child-flex-grow-0-5" data-expected-width="50" data-offset-x="26"></div>
</div>
<div class="flexbox container justify-content-flex-end">
<div class="child-flex-grow-0-5" data-expected-width="50" data-offset-x="51"></div>
</div>
</body>