UNPKG

@paykit-sdk/react

Version:

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

120 lines (111 loc) 4.22 kB
"use strict"; 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 __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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/index.ts var index_exports = {}; __export(index_exports, { PaykitProvider: () => PaykitProvider, useCheckout: () => useCheckout, useCustomer: () => useCustomer, usePaykitContext: () => usePaykitContext, useSubscription: () => useSubscription }); module.exports = __toCommonJS(index_exports); // src/core.tsx var React = __toESM(require("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 var import_jsx_runtime = require("react/jsx-runtime"); var PaykitContext = React.createContext(void 0); var PaykitProvider = ({ provider, children }) => { return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(PaykitContext.Provider, { value: { provider }, children }); }; var usePaykitContext = () => parseElementContext(React.useContext(PaykitContext), "PaykitContext"); // src/hooks/use-async-fn.ts var React2 = __toESM(require("react")); var import_core = require("@paykit-sdk/core"); var useAsyncFn = (fn) => { const [loading, setLoading] = React2.useState(false); const run = React2.useCallback( async (...args) => { setLoading(true); const [data, error] = await (0, import_core.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 }; }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { PaykitProvider, useCheckout, useCustomer, usePaykitContext, useSubscription });