Files
Piped/src/components/LoadingIndicatorPage.vue
2026-03-27 11:47:27 +05:30

59 lines
1019 B
Vue

<template>
<div v-if="!showContent" class="grid min-h-[75vh] w-full place-items-center">
<span id="spinner" />
</div>
<div v-else v-bind="$attrs">
<slot />
</div>
</template>
<script setup>
defineOptions({
inheritAttrs: false,
});
defineProps({
showContent: {
type: Boolean,
required: true,
},
});
</script>
<style>
#spinner:after {
--spinner-color: #000;
}
.dark #spinner:after {
--spinner-color: #fff;
}
#spinner {
display: inline-block;
width: 70px;
height: 70px;
margin-inline: auto;
}
#spinner:after {
content: " ";
display: block;
width: 54px;
height: 54px;
margin: 8px;
border-radius: 50%;
border: 4px solid var(--spinner-color);
border-color: var(--spinner-color) transparent var(--spinner-color) transparent;
animation: spinner 1.2s linear infinite;
}
@keyframes spinner {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
</style>