one
Version:
One is a new React Framework that makes Vite serve both native and web.
84 lines (83 loc) • 3.14 kB
JavaScript
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: !0 });
}, __copyProps = (to, from, except, desc) => {
if (from && typeof from == "object" || typeof from == "function")
for (let key of __getOwnPropNames(from))
!__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
var LoadProgressBar_exports = {};
__export(LoadProgressBar_exports, {
LoadProgressBar: () => LoadProgressBar
});
module.exports = __toCommonJS(LoadProgressBar_exports);
var import_react = require("react"), import_react_native = require("react-native-web"), import_imperative_api = require("../router/imperative-api"), import_jsx_runtime = require("react/jsx-runtime");
const LoadProgressBar = ({
startDelay = 500,
finishDelay = 50,
initialPercent = 20,
updateInterval = 300,
sporadicness = 3,
...props
}) => {
const [loaded, setLoaded] = (0, import_react.useState)(0), [width, setWidth] = (0, import_react.useState)(0);
return (0, import_react.useEffect)(() => {
let loadInterval;
const dispose = import_imperative_api.router.onLoadState((state) => {
switch (clearTimeout(loadInterval), state) {
case "loading": {
loadInterval = setTimeout(() => {
setLoaded(initialPercent);
let intervalCount = 0;
loadInterval = setInterval(() => {
intervalCount++, intervalCount % sporadicness !== 0 && setLoaded((prev) => {
const increment = (100 - prev) * (prev > 80 ? 0.05 : 0.1) * Math.random();
return Math.min(prev + increment, 100);
});
}, updateInterval);
}, startDelay);
break;
}
case "loaded": {
setLoaded(100), clearInterval(loadInterval), setTimeout(() => {
setLoaded(0);
}, finishDelay);
break;
}
}
});
return () => {
dispose(), clearInterval(loadInterval);
};
}, [finishDelay, initialPercent, sporadicness, startDelay, updateInterval]), /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
import_react_native.View,
{
...props,
onLayout: (e) => {
setWidth(e.nativeEvent.layout.width), props.onLayout?.(e);
},
style: [
{
display: loaded === 0 ? "none" : "flex",
height: 1,
position: "absolute",
top: 0,
left: 0,
right: 0,
backgroundColor: "rgba(60, 100, 200, 0.65)",
width: "100%",
transform: [{ translateX: -(1 - loaded * 0.01) * width }],
zIndex: Number.MAX_SAFE_INTEGER
},
props.style
]
}
);
};
//# sourceMappingURL=LoadProgressBar.js.map