2024-06-23 19:39:44 +08:00
|
|
|
import { computed, ref } from 'vue';
|
|
|
|
import { useRouter } from 'vue-router';
|
|
|
|
|
|
|
|
import { preferences } from '@vben-core/preferences';
|
|
|
|
|
|
|
|
function useContentSpinner() {
|
|
|
|
const spinning = ref(false);
|
|
|
|
const startTime = ref(0);
|
|
|
|
const router = useRouter();
|
|
|
|
const minShowTime = 500;
|
|
|
|
const enableLoading = computed(() => preferences.transition.loading);
|
|
|
|
|
|
|
|
const onEnd = () => {
|
|
|
|
if (!enableLoading.value) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const processTime = performance.now() - startTime.value;
|
|
|
|
if (processTime < minShowTime) {
|
|
|
|
setTimeout(() => {
|
|
|
|
spinning.value = false;
|
|
|
|
}, minShowTime - processTime);
|
|
|
|
} else {
|
|
|
|
spinning.value = false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
router.beforeEach((to) => {
|
2024-06-29 15:41:10 +08:00
|
|
|
if (to.meta.loaded || !enableLoading.value || to.meta.iframeSrc) {
|
2024-06-23 19:39:44 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
startTime.value = performance.now();
|
|
|
|
spinning.value = true;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
|
|
|
router.afterEach((to) => {
|
2024-06-29 15:41:10 +08:00
|
|
|
if (to.meta.loaded || !enableLoading.value || to.meta.iframeSrc) {
|
2024-06-23 19:39:44 +08:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2024-06-23 19:55:55 +08:00
|
|
|
// 关闭加载动画
|
|
|
|
onEnd();
|
2024-06-23 19:39:44 +08:00
|
|
|
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
2024-06-23 19:55:55 +08:00
|
|
|
return { spinning };
|
2024-06-23 19:39:44 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
export { useContentSpinner };
|