UNPKG

@paykit-sdk/react

Version:

React hooks and components for PayKit SDK - Universal payment processing with Stripe, Polar, and more

79 lines (72 loc) 2.37 kB
// src/core.tsx import * as React from "react"; // src/util.ts var parseElementContext = (ctx, name) => { if (!ctx) throw new Error(`${name}Context must be used within the ${name}Provider`); return ctx; }; // src/core.tsx import { jsx } from "react/jsx-runtime"; var PaykitContext = React.createContext(void 0); var PaykitProvider = ({ provider, children }) => { return /* @__PURE__ */ jsx(PaykitContext.Provider, { value: { provider }, children }); }; var usePaykitContext = () => parseElementContext(React.useContext(PaykitContext), "PaykitContext"); // src/hooks/use-async-fn.ts import * as React2 from "react"; import { tryCatchAsync } from "@paykit-sdk/core"; var useAsyncFn = (fn) => { const [loading, setLoading] = React2.useState(false); const run = React2.useCallback( async (...args) => { setLoading(true); const [data, error] = await tryCatchAsync(fn(...args)); setLoading(false); if (error) { return [void 0, error]; } return [data, void 0]; }, [fn] ); return { run, loading }; }; // src/resources/customer.ts var useCustomer = () => { const ctx = usePaykitContext(); if (!ctx) { throw new Error("Your app must be wrapped in PayKitProvider to use PayKit hooks."); } const retrieve = useAsyncFn(ctx.provider.retrieveCustomer); const create = useAsyncFn(ctx.provider.createCustomer); const update = useAsyncFn(ctx.provider.updateCustomer); return { retrieve, create, update }; }; // src/resources/subscription.ts var useSubscription = () => { const ctx = usePaykitContext(); if (!ctx) { throw new Error("Your app must be wrapped in PayKitProvider to use PayKit hooks."); } const retrieve = useAsyncFn(ctx.provider.retrieveSubscription); const update = useAsyncFn(ctx.provider.updateSubscription); const cancel = useAsyncFn(ctx.provider.cancelSubscription); return { retrieve, update, cancel }; }; // src/resources/checkout.ts var useCheckout = () => { const ctx = usePaykitContext(); if (!ctx) { throw new Error("Your app must be wrapped in PayKitProvider to use PayKit hooks."); } const create = useAsyncFn(ctx.provider.createCheckout); const retrieve = useAsyncFn(ctx.provider.retrieveCheckout); return { create, retrieve }; }; export { PaykitProvider, useCheckout, useCustomer, usePaykitContext, useSubscription };