vitepress-plugin-bprogress
Version:
A beautiful loading progress bar plugin for VitePress that integrates seamlessly with VitePress themes
81 lines (78 loc) • 2.66 kB
JavaScript
//#region rolldown:runtime
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
key = keys[i];
if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
get: ((k) => from[k]).bind(null, key),
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
});
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
value: mod,
enumerable: true
}) : target, mod));
//#endregion
const __bprogress_core = __toESM(require("@bprogress/core"));
//#region src/index.ts
const vitepressBprogress = (ctx) => {
if (typeof window === "undefined") return;
const { router } = ctx;
const initProgress = () => {
const layout = document.querySelector(".Layout");
if (layout) {
setupProgressBar(layout);
return;
}
const observer = new MutationObserver((mutations) => {
for (const mutation of mutations) if (mutation.type === "childList") {
const layout$1 = document.querySelector(".Layout");
if (layout$1) {
observer.disconnect();
setupProgressBar(layout$1);
return;
}
}
});
observer.observe(document.body, {
childList: true,
subtree: true
});
};
const setupProgressBar = (parent) => {
__bprogress_core.BProgress.configure({
showSpinner: false,
speed: 400,
easing: "linear",
parent
});
const r = router;
const cacheBeforeRouteChange = r.onBeforeRouteChange;
const cacheAfterRouteChange = r.onAfterRouteChange;
const cacheAfterRouteChanged = r.onAfterRouteChanged;
r.onBeforeRouteChange = (to) => {
__bprogress_core.BProgress.start();
cacheBeforeRouteChange?.(to);
};
const afterRouteHandler = (to) => {
__bprogress_core.BProgress.done();
cacheAfterRouteChange?.(to);
cacheAfterRouteChanged?.(to);
};
r.onAfterRouteChange = afterRouteHandler;
if (r.onAfterRouteChanged) r.onAfterRouteChanged = afterRouteHandler;
};
if (document.readyState === "loading") document.addEventListener("DOMContentLoaded", initProgress);
else initProgress();
return __bprogress_core.BProgress;
};
var src_default = vitepressBprogress;
//#endregion
module.exports = src_default;