kopia lustrzana https://github.com/shoelace-style/shoelace
64 wiersze
1.2 KiB
TypeScript
64 wiersze
1.2 KiB
TypeScript
import { css } from 'lit';
|
|
import componentStyles from '~/styles/component.styles';
|
|
|
|
export default css`
|
|
${componentStyles}
|
|
|
|
:host {
|
|
--track-width: 2px;
|
|
--track-color: rgb(128 128 128 / 25%);
|
|
--indicator-color: var(--sl-color-primary-600);
|
|
--speed: 2s;
|
|
|
|
display: inline-flex;
|
|
width: 1em;
|
|
height: 1em;
|
|
}
|
|
|
|
.spinner {
|
|
flex: 1 1 auto;
|
|
height: 100%;
|
|
width: 100%;
|
|
}
|
|
|
|
.spinner__track,
|
|
.spinner__indicator {
|
|
fill: none;
|
|
stroke-width: var(--track-width);
|
|
r: calc(0.5em - var(--track-width) / 2);
|
|
cx: 0.5em;
|
|
cy: 0.5em;
|
|
transform-origin: 50% 50%;
|
|
}
|
|
|
|
.spinner__track {
|
|
stroke: var(--track-color);
|
|
transform-origin: 0% 0%;
|
|
mix-blend-mode: multiply;
|
|
}
|
|
|
|
.spinner__indicator {
|
|
stroke: var(--indicator-color);
|
|
stroke-linecap: round;
|
|
stroke-dasharray: 150% 75%;
|
|
animation: spin var(--speed) linear infinite;
|
|
}
|
|
|
|
@keyframes spin {
|
|
0% {
|
|
transform: rotate(0deg);
|
|
stroke-dasharray: 0.01em, 2.75em;
|
|
}
|
|
|
|
50% {
|
|
transform: rotate(450deg);
|
|
stroke-dasharray: 1.375em, 1.375em;
|
|
}
|
|
|
|
100% {
|
|
transform: rotate(1080deg);
|
|
stroke-dasharray: 0.01em, 2.75em;
|
|
}
|
|
}
|
|
`;
|