Skip to content

Instantly share code, notes, and snippets.

@xav76
Created October 24, 2012 16:49
Show Gist options
  • Save xav76/3947276 to your computer and use it in GitHub Desktop.
Save xav76/3947276 to your computer and use it in GitHub Desktop.
A CodePen by Denys Mishunov. Genie-like list items animation
<div id="wrapper">
<ul id="drops-wrapper">
<li><a href="#" class="toggle" data-genie-target="#target">Click me 1</a></li>
<li><a href="#" class="toggle" data-genie-target="#target">Click me 2</a></li>
<li><a href="#" class="toggle" data-genie-target="#target">Click me 3</a></li>
<li><a href="#" class="toggle" data-genie-target="#target">Click me 4</a></li>
<li><a href="#" class="toggle" data-genie-target="#target">Click me 5</a></li>
</ul>
<div id="target"><h2>Landing zone</h2></div>
</div>
<footer>
<a href="http://mishunov.me">Denys Mishunov</a>
<a href="http://twitter.com/mishunov">@mishunov</a>
</footer>
var t = 1000, // duration of the CSS genie animation, ms
targets = document.querySelectorAll('.toggle');
$.fn.getCenter = function () {
return {
x: this.offset().left + this[0].offsetWidth/2,
y: this.offset().top + this[0].offsetHeight/2
};
}
$('.toggle').bind('click', function (ev) {
ev.preventDefault();
var $this = $(this),
$target = $($this.attr('data-genie-target')),
toggleCenter = $this.getCenter(),
targetCenter = $target.getCenter();
$this
.width($this.width())
.height($this.height())
.addClass('genie')
.css('left', (targetCenter.x - toggleCenter.x) + 'px')
.css('top', (targetCenter.y - toggleCenter.y) + 'px');
_.delay(function (item) {
var $n = $(item).clone();
$n
.removeClass('genie')
.removeAttr('style')
.removeAttr('data-genie-target');
target.appendChild($n[0]);
_.defer(function(){
$n.addClass('in');
});
$(item).remove();
}, t, this);
});
.genie {
position: relative;
z-index: 1;
overflow: hidden;
padding: 10px;
zoom: 1;
transition:
left 1s ease-in,
top 1s cubic-bezier(.46,1.27,.7,1.94);
animation: lift 1s linear;
animation-fill-mode: forwards;
}
@keyframes lift {
0% {
box-shadow: 0 0 .5em rgba(0,0,0,.5);
}
50% {
box-shadow: 0 3em 2em rgba(0,0,0,.2);
padding: 10px;
width: 105%;
height: 105%;
font-size: 103%;
line-height: normal;
}
70% {
box-shadow: 0 2em .5em rgba(0,0,0,.3);
}
85% {
box-shadow: 0 1em .5em rgba(0,0,0,.4);
}
100% {
padding: 0;
height: 0;
font-size: 0;
line-height: 0;
width: 0;
border-width: 0;
zoom:.001;
box-shadow: 0 0 0 rgba(0,0,0,0);
}
}
/* PRETYFICATION */
@import url("http://fonts.googleapis.com/css?family=Give+You+Glory|Source+Sans+Pro:600");
body {
font-family: "Source Sans Pro", sans-serif;
padding: 2em;
height: 100%;
background: url() repeat;
}
footer {
font-family: 'Give You Glory', cursive;
position: absolute;
bottom: 1em;
left: 1em;
color: #999;
font-size: 1.2em;
a {
text-decoration: none;
color: #999;
border: none;
}
}
html, body, #wrapper {
height: 100%;
padding: 0;
margin: 0;
}
a {
text-decoration: none;
}
#drops-wrapper {
margin: 2em;
width: 300px;
margin: 2em 0 2em 2em;
padding: 0;
list-style: none;
background-image: linear-gradient(top, #BEA680, #7E6847);
border-radius: 5px;
position: relative;
box-shadow: 0 0 0 10px #333;
}
li a {
display: block;
padding: 10px;
text-shadow: 0 1px 0 rgba(255,255,255,.3);
color: #000;
border-top: 1px solid rgba(255,255,255,0.1);
border-bottom: 1px solid rgba(0,0,0,0.2);
font-size: 13px;
font-weight: 600;
background-image: linear-gradient(top, rgba(0,0,0,.05), rgba(255,255,255,.1));
background-color: transparent;
transition: background-color .1s ease;
}
li:first-child a {
border-radius: 5px 5px 0 0;
}
li:last-child a {
border-radius: 0 0 5px 5px;
}
li a:hover {
background-image: none;
background-color: #9EADBE;
cursor: pointer;
}
#toggle {
}
#target {
position: absolute;
font-weight: 600;
color: #BEA680;
text-shadow: 0 -1px 0 #000;
border-left: 10px solid rgba(0,0,0,.2);
top: 0;
right: 0;
width: 20%;
height: 100%;
background: #2B343E;
text-align: center;
h2 {
font-size: 2em;
color: #7E6847;
}
a {
color: #BEA680;
}
.toggle {
display: block;
padding: 10px;
border-top: 1px solid rgba(255,255,255,0.1);
border-bottom: 1px solid rgba(0,0,0,0.2);
font-size: 13px;
font-weight: 600;
background-image: linear-gradient(top, rgba(0,0,0,.05), rgba(255,255,255,.1));
background-color: transparent;
opacity: 0;
transition: opacity .15s linear;
&.in {
opacity: 1;
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment