2024-01-07 01:54:25 +08:00

67 lines
1.2 KiB
Vue

<template>
<button class="switch-wrapper" type="button" role="switch">
<span class="check">
<span v-if="$slots.default" class="icon">
<slot />
</span>
</span>
</button>
</template>
<style scoped>
.switch-wrapper {
position: relative;
display: block;
flex-shrink: 0;
width: 40px;
height: 22px;
background-color: var(--vp-input-switch-bg-color);
border: 1px solid var(--vp-input-border-color);
border-radius: 11px;
transition:
border-color 0.25s ease,
background-color 0.25s ease;
}
.switch-wrapper:hover {
border-color: var(--vp-c-brand-1);
}
.check {
position: absolute;
top: 1px;
/* rtl:ignore */
left: 1px;
width: 18px;
height: 18px;
background-color: var(--vp-c-neutral-inverse);
border-radius: 50%;
box-shadow: var(--vp-shadow-1);
transition: transform 0.25s;
}
.icon {
position: relative;
display: block;
width: 18px;
height: 18px;
overflow: hidden;
border-radius: 50%;
}
.icon :deep(svg) {
position: absolute;
top: 3px;
left: 3px;
width: 12px;
height: 12px;
fill: var(--vp-c-text-2);
}
.dark .icon :deep(svg) {
fill: var(--vp-c-text-1);
transition: opacity 0.25s;
}
</style>