111
This commit is contained in:
82
Web/src/components/PageLoading.vue
Normal file
82
Web/src/components/PageLoading.vue
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
<template>
|
||||||
|
<Transition name="page-loading-fade">
|
||||||
|
<div v-if="appStore.isLoading" class="page-loading" role="status" aria-live="polite" aria-busy="true">
|
||||||
|
<van-loading vertical>
|
||||||
|
<template #icon>
|
||||||
|
<van-icon name="star-o" size="30" />
|
||||||
|
</template>
|
||||||
|
<div>
|
||||||
|
加载中...
|
||||||
|
</div>
|
||||||
|
</van-loading>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</Transition>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
const appStore = useAppStore()
|
||||||
|
const defaultImage = '/images/page-loading-cover.png'
|
||||||
|
const fallbackImage = '/images/logo.png'
|
||||||
|
const loadingImage = ref(defaultImage)
|
||||||
|
|
||||||
|
const handleImageError = (): void => {
|
||||||
|
if (loadingImage.value !== fallbackImage) {
|
||||||
|
loadingImage.value = fallbackImage
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.page-loading {
|
||||||
|
position: fixed;
|
||||||
|
inset: 0;
|
||||||
|
z-index: 9999;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
padding: 24px;
|
||||||
|
background: #ffffff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-loading__panel {
|
||||||
|
width: min(100%, 280px);
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-loading__image {
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
aspect-ratio: 1 / 1;
|
||||||
|
object-fit: cover;
|
||||||
|
border-radius: 18px;
|
||||||
|
box-shadow: 0 16px 48px rgba(12, 40, 74, 0.18);
|
||||||
|
margin-bottom: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-loading__title {
|
||||||
|
color: #103b63;
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: 700;
|
||||||
|
line-height: 1.3;
|
||||||
|
letter-spacing: 0.08em;
|
||||||
|
margin-bottom: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-loading__text {
|
||||||
|
color: #4f6476;
|
||||||
|
font-size: 16px;
|
||||||
|
line-height: 1.6;
|
||||||
|
letter-spacing: 0.04em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-loading-fade-enter-active,
|
||||||
|
.page-loading-fade-leave-active {
|
||||||
|
transition: opacity 0.2s ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
.page-loading-fade-enter-from,
|
||||||
|
.page-loading-fade-leave-to {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
14
Web/src/composables/usePageLoading.ts
Normal file
14
Web/src/composables/usePageLoading.ts
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
export class PageLoading{
|
||||||
|
|
||||||
|
private static get PageLoading() {
|
||||||
|
return useAppStore()
|
||||||
|
}
|
||||||
|
public static Loading(): void {
|
||||||
|
this.PageLoading.startLoading("加载中...");
|
||||||
|
}
|
||||||
|
public static Close(): void {
|
||||||
|
|
||||||
|
this.PageLoading.endLoading();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
3
Web/src/middleware/page-loading.ts
Normal file
3
Web/src/middleware/page-loading.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
export default defineNuxtRouteMiddleware(() => {
|
||||||
|
PageLoading.Loading()
|
||||||
|
})
|
||||||
Reference in New Issue
Block a user