@hellouxpavel/cssanimation
Version:
A Powerful CSS Animation Library for Advanced Motion Design.
128 lines (103 loc) • 2.2 kB
CSS
.cssanimation {
animation-duration: var(--cssanimation-duration, 1s);
animation-fill-mode: var(--cssanimation-fill-mode, both);
}
.cssanimation span {
display: var(--cssanimation-display, inline-block);
}
.infinite {
animation-iteration-count: var(--cssanimation-infinite, infinite) ;
}
@media (prefers-reduced-motion: reduce) {
.cssanimation,
.cssanimation span {
animation: none ;
transition: none ;
}
}
:root {
--cssanimation-duration: 1s;
--cssanimation-fill-mode: both;
--cssanimation-infinite: infinite;
--cssanimation-backface-visibility: hidden;
--cssanimation-transform-style: preserve-3d;
--cssanimation-will-change: transform, opacity;
--cssanimation-display: inline-block;
--move-distance: -800px;
}
/**
* Module: Fade Out
* Filename: ca__FadeOut.ca__fx-css
*/
.ca__fx-fadeOut {
animation-name: fadeOut;
}
@keyframes fadeOut {
to {
opacity: 0;
}
}
.ca__fx-fadeOutLeft {
animation-name: fadeOutLeft;
}
@keyframes fadeOutLeft {
from {
opacity: 1;
}
to {
opacity: 0;
transform: translateX(-100%);
}
}
.ca__fx-fadeOutRight {
animation-name: fadeOutRight;
}
@keyframes fadeOutRight {
from {
opacity: 1;
}
to {
opacity: 0;
transform: translateX(100%);
}
}
.ca__fx-fadeOutTop {
animation-name: fadeOutTop;
}
@keyframes fadeOutTop {
from {
opacity: 1;
}
to {
opacity: 0;
transform: translateY(-100%);
}
}
.ca__fx-fadeOutBottom {
animation-name: fadeOutBottom;
}
@keyframes fadeOutBottom {
from {
opacity: 1;
}
to {
opacity: 0;
transform: translateY(100%);
}
}
.ca__fx-tiltFadeBack {
animation: tiltFadeBack 1s cubic-bezier(0.ca__fx-45, 0, 0.ca__fx-55, 1) forwards;
transform-style: preserve-3d;
backface-visibility: hidden;
will-change: transform, opacity;
}
@keyframes tiltFadeBack {
0% {
transform: perspective(800px) rotateX(0deg) translateZ(0);
opacity: 1;
}
100% {
transform: perspective(800px) rotateX(40deg) translateZ(-100px);
opacity: 0;
}
}