mirror of
https://github.com/uiverse-io/galaxy.git
synced 2025-11-28 05:00:22 +08:00
184 lines
3.3 KiB
HTML
184 lines
3.3 KiB
HTML
<button class="btn">
|
|
<span>Border ripple</span>
|
|
<div class="ripple-container">
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
</div>
|
|
</button>
|
|
<style>
|
|
/* From Uiverse.io by SelfMadeSystem - Tags: button, ripple, animated */
|
|
.btn {
|
|
font-size: larger;
|
|
height: 3em;
|
|
width: 8em;
|
|
position: relative;
|
|
border: none;
|
|
isolation: isolate;
|
|
}
|
|
|
|
.btn > span {
|
|
position: absolute;
|
|
border-radius: 0.5em;
|
|
pointer-events: none;
|
|
inset: 0;
|
|
background-color: hsl(218, 68%, 52%);
|
|
color: white;
|
|
box-shadow: 1px 2px 4px #0007;
|
|
z-index: 10;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
}
|
|
|
|
.ripple-container {
|
|
position: absolute;
|
|
inset: -0.3em;
|
|
display: grid;
|
|
grid-template-columns: repeat(16, 0.5em);
|
|
border-radius: 0.8em;
|
|
padding: 0.3em;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.ripple-container > span {
|
|
position: relative;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
}
|
|
|
|
.ripple-container > span::after {
|
|
content: "";
|
|
pointer-events: none;
|
|
position: absolute;
|
|
background-color: hsl(218, 68%, 65%);
|
|
transition: width 0.5s ease-out, height 0.5s ease-out, opacity 1s;
|
|
width: 18em;
|
|
height: 18em;
|
|
opacity: 0;
|
|
border-radius: 999em;
|
|
}
|
|
|
|
.ripple-container > span:active::after {
|
|
transition: 0s;
|
|
width: 0em;
|
|
height: 0em;
|
|
opacity: 1;
|
|
}
|
|
|
|
.ripple-container::before {
|
|
content: "";
|
|
pointer-events: none;
|
|
position: absolute;
|
|
background-color: hsla(218, 68%, 65%, 0.5);
|
|
width: 13em;
|
|
height: 13em;
|
|
border-radius: 999em;
|
|
transition: transform 0.25s ease-out;
|
|
transform: translate(-25%, -25%) scale(0);
|
|
}
|
|
|
|
.ripple-container:hover::before {
|
|
transform: translate(-25%, -25%) scale(1);
|
|
}
|
|
|
|
</style>
|