mirror of
https://github.com/ragestudio/comty.git
synced 2025-06-09 10:34:17 +00:00
138 lines
2.7 KiB
Plaintext
138 lines
2.7 KiB
Plaintext
.loader {
|
|
--path: #2F3545;
|
|
// OLDDOT => --dot: #5628EE;
|
|
--dot: rgb(0, 254, 161);
|
|
--duration: 3s;
|
|
width: 44px;
|
|
height: 44px;
|
|
position: relative;
|
|
&:before {
|
|
content: '';
|
|
width: 6px;
|
|
height: 6px;
|
|
border-radius: 50%;
|
|
position: absolute;
|
|
display: block;
|
|
background: var(--dot);
|
|
top: 37px;
|
|
left: 19px;
|
|
transform: translate(-18px, -18px);
|
|
animation: dotRect var(--duration) cubic-bezier(0.785, 0.135, 0.15, 0.86) infinite;
|
|
}
|
|
svg {
|
|
display: block;
|
|
width: 100%;
|
|
height: 100%;
|
|
rect,
|
|
polygon,
|
|
circle {
|
|
fill: none;
|
|
stroke: var(--path);
|
|
stroke-width: 10px;
|
|
stroke-linejoin: round;
|
|
stroke-linecap: round;
|
|
}
|
|
polygon {
|
|
stroke-dasharray: 145 (221 - 145) 145 (221 - 145);
|
|
stroke-dashoffset: 0;
|
|
animation: pathTriangle var(--duration) cubic-bezier(0.785, 0.135, 0.15, 0.86) infinite;
|
|
}
|
|
rect {
|
|
stroke-dasharray: (256 / 4 * 3) (256 / 4) (256 / 4 * 3) (256 / 4);
|
|
stroke-dashoffset: 0;
|
|
animation: pathRect 3s cubic-bezier(0.785, 0.135, 0.15, 0.86) infinite;
|
|
}
|
|
circle {
|
|
stroke-dasharray: (200 / 4 * 3) (200 / 4) (200 / 4 * 3) (200 / 4);
|
|
stroke-dashoffset: 75;
|
|
animation: pathCircle var(--duration) cubic-bezier(0.785, 0.135, 0.15, 0.86) infinite;
|
|
}
|
|
}
|
|
}
|
|
|
|
@keyframes pathTriangle {
|
|
33% {
|
|
stroke-dashoffset: 74;
|
|
}
|
|
66% {
|
|
stroke-dashoffset: 147;
|
|
}
|
|
100% {
|
|
stroke-dashoffset: 221;
|
|
}
|
|
}
|
|
|
|
@keyframes dotTriangle {
|
|
33% {
|
|
transform: translate(0, 0);
|
|
}
|
|
66% {
|
|
transform: translate(10px, -18px);
|
|
}
|
|
100% {
|
|
transform: translate(-10px, -18px);
|
|
}
|
|
}
|
|
|
|
@keyframes pathRect {
|
|
25% {
|
|
stroke-dashoffset: 64;
|
|
}
|
|
50% {
|
|
stroke-dashoffset: 128;
|
|
}
|
|
75% {
|
|
stroke-dashoffset: 192;
|
|
}
|
|
100% {
|
|
stroke-dashoffset: 256;
|
|
}
|
|
}
|
|
|
|
@keyframes dotRect {
|
|
25% {
|
|
transform: translate(0, 0);
|
|
}
|
|
50% {
|
|
transform: translate(18px, -18px);
|
|
}
|
|
75% {
|
|
transform: translate(0, -36px);
|
|
}
|
|
100% {
|
|
transform: translate(-18px, -18px);
|
|
}
|
|
}
|
|
|
|
@keyframes pathCircle {
|
|
25% {
|
|
stroke-dashoffset: 125;
|
|
}
|
|
50% {
|
|
stroke-dashoffset: 175;
|
|
}
|
|
75% {
|
|
stroke-dashoffset: 225;
|
|
}
|
|
100% {
|
|
stroke-dashoffset: 275;
|
|
}
|
|
}
|
|
|
|
.loader {
|
|
display: inline-block;
|
|
margin: 0 16px;
|
|
}
|
|
|
|
html {
|
|
-webkit-font-smoothing: antialiased;
|
|
}
|
|
|
|
* {
|
|
box-sizing: border-box;
|
|
&:before,
|
|
&:after {
|
|
box-sizing: border-box;
|
|
}
|
|
}
|