<html>
<head>
<style>
.box {
position: relative;
left: 0;
height: 100px;
width: 100px;
margin: 10px;
background-color: blue;
transition-property: width, left, background-color, height, top;
transition-duration: 0.2s;
}
.box1 {
left: 50px;
}
.box2 {
background-color: red;
left: 100px;
}
</style>
<script src="transition-end-event-helpers.js"></script>
<script type="text/javascript">
var expectedEndEvents = [
// [property-name, element-id, elapsed-time, listen]
["left", "box1", 0.2, false],
];
function startTransition()
{
var box = document.getElementById("box1");
box.className = "box box2";
}
var firstTimeInHandleEndEvent = true;
function handleEndEvent(event)
{
recordTransitionEndEvent(event);
event.target.style.transitionProperty = "none";
if (firstTimeInHandleEndEvent) {
firstTimeInHandleEndEvent = false;
window.setTimeout(startTransition, 100);
}
}
function setupTest()
{
var box = document.getElementById("box1");
box.addEventListener("transitionend", handleEndEvent, false);
box.className = "box box1";
}
// We need to pass an explicit maxTime because we use two sequential
// transitions that each take 0.2s.
runTransitionTest(expectedEndEvents, setupTest);
</script>
</head>
<body>
<p>Initiating transitions on various properties of all boxes.</p>
<div id="container">
<div id="box1" class="box"></div>
</div>
<div id="result"></div>
</body>
</html>