UNPKG

@roochnetwork/rooch-sdk-kit

Version:
88 lines (83 loc) 3.15 kB
"use strict"; 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