Warp/node_modules/@vueuse/integrations/useNProgress.cjs

38 lines
1,017 B
JavaScript
Raw Normal View History

2024-01-05 12:14:38 +00:00
'use strict';
var nprogress = require('nprogress');
var shared = require('@vueuse/shared');
var vueDemi = require('vue-demi');
function useNProgress(currentProgress = null, options) {
const progress = vueDemi.ref(currentProgress);
const isLoading = vueDemi.computed({
set: (load) => load ? nprogress.start() : nprogress.done(),
get: () => typeof progress.value === "number" && progress.value < 1
});
if (options)
nprogress.configure(options);
const setProgress = nprogress.set;
nprogress.set = (n) => {
progress.value = n;
return setProgress.call(nprogress, n);
};
vueDemi.watchEffect(() => {
if (typeof progress.value === "number" && shared.isClient)
setProgress.call(nprogress, progress.value);
});
shared.tryOnScopeDispose(nprogress.remove);
return {
isLoading,
progress,
start: nprogress.start,
done: nprogress.done,
remove: () => {
progress.value = null;
nprogress.remove();
}
};
}
exports.useNProgress = useNProgress;