@roochnetwork/rooch-sdk-kit
Version:
Rooch SDK Kit
88 lines (83 loc) • 3.15 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: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__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: true }), mod);
// src/components/ProgressProvider.tsx
var ProgressProvider_exports = {};
__export(ProgressProvider_exports, {
ProgressProvider: () => ProgressProvider,
useProgress: () => useProgress
});
module.exports = __toCommonJS(ProgressProvider_exports);
var import_react = require("react");
// src/components/fauct-modal/views/FaucetView.css.ts
var progressBar = "FaucetView_progressBar__1ff62y03";
// src/components/ui/Progress.tsx
var import_jsx_runtime = require("react/jsx-runtime");
function Progress() {
const { progress } = useProgress();
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: progressBar, style: { width: `${progress}%` } });
}
// src/components/ProgressProvider.tsx
var import_jsx_runtime2 = require("react/jsx-runtime");
var ProgressProviderContext = (0, import_react.createContext)(null);
var ProgressProvider = ({ children }) => {
const [progress, setProgress] = (0, import_react.useState)(0);
const [loading, setLoading] = (0, import_react.useState)(false);
const start = (0, import_react.useCallback)(() => {
setLoading(true);
setProgress(0);
const interval = setInterval(() => {
setProgress((prev) => {
const nextProgress = prev + 10;
if (nextProgress >= 70) {
clearInterval(interval);
}
return Math.min(nextProgress, 70);
});
}, 100);
}, []);
const finish = (0, import_react.useCallback)((callback) => {
const interval = setInterval(() => {
setProgress((prev) => {
const nextProgress = prev + 5;
if (nextProgress >= 100) {
clearInterval(interval);
setTimeout(() => {
setLoading(false);
if (callback) {
callback();
}
}, 300);
}
return Math.min(nextProgress, 100);
});
}, 50);
}, []);
return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(ProgressProviderContext.Provider, { value: { loading, progress, start, finish }, children: [
children,
loading && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(Progress, {})
] });
};
var useProgress = () => {
const ctx = (0, import_react.useContext)(ProgressProviderContext);
if (!ctx) {
throw new Error("useSubscribeToError must be used within a GlobalProvider");
}
return ctx;
};
//# sourceMappingURL=ProgressProvider.js.map