@hellouxpavel/cssanimation
Version:
A Powerful CSS Animation Library for Advanced Motion Design.
151 lines (123 loc) • 2.82 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: Zoom Out
* Filename: ca__ZoomOut.ca__fx-css
*/
.ca__fx-zoomOut {
animation-name: zoomOut;
}
@keyframes zoomOut {
to {
transform: scale(10);
opacity: 0;
}
}
.ca__fx-zoomOutLeft {
animation-name: zoomOutLeft;
}
@keyframes zoomOutLeft {
to {
transform: scale(10) translateX(-50%);
opacity: 0;
}
}
.ca__fx-zoomOutRight {
animation-name: zoomOutRight;
}
@keyframes zoomOutRight {
to {
transform: scale(10) translateX(50%);
opacity: 0;
}
}
.ca__fx-zoomOutTop {
animation-name: zoomOutTop;
}
@keyframes zoomOutTop {
to {
transform: scale(10) translateY(-50%);
opacity: 0;
}
}
.ca__fx-zoomOutBottom {
animation-name: zoomOutBottom;
}
@keyframes zoomOutBottom {
to {
transform: scale(10) translateY(50%);
opacity: 0;
}
}
.ca__fx-zoomOutRotateUp {
animation-name: zoomOutRotateUp;
backface-visibility: var(--cssanimation-backface-visibility);
transform-style: var(--cssanimation-transform-style);
will-change: var(--cssanimation-will-change);
}
@keyframes zoomOutRotateUp {
0% {
transform: perspective(700px) rotateX(0deg) scale(1);
opacity: 1;
}
100% {
transform: perspective(700px) rotateX(80deg) scale(0.ca__fx-3) translateY(-80px);
opacity: 0;
}
}
.ca__fx-zoomPingExit {
animation-name: zoomPingExit;
animation-timing-function: ease-in-out;
}
@keyframes zoomPingExit {
0% {
transform: scale(1);
opacity: 1;
}
100% {
transform: scale(1.ca__fx-5);
opacity: 0;
}
}
.ca__fx-zoomToTarget {
animation: zoomToTarget 1.ca__fx-1s ease-out forwards;
transform-origin: center center;
}
@keyframes zoomToTarget {
0% {
transform: scale(1) translate(0, 0);
opacity: 1;
}
60% {
transform: scale(1.ca__fx-2) translate(0, -10px);
}
100% {
transform: scale(0.ca__fx-8) translate(10px, 20px);
opacity: 0;
}
}