46 lines
1.5 KiB
TypeScript
46 lines
1.5 KiB
TypeScript
![]() |
import { httpBatchLink } from "@trpc/client";
|
||
|
import { createTRPCNext } from "@trpc/next";
|
||
|
|
||
|
import { SALEOR_API_URL_HEADER, SALEOR_AUTHORIZATION_BEARER_HEADER } from "@saleor/app-sdk/const";
|
||
|
|
||
|
import { AppRouter } from "./trpc-app-router";
|
||
|
import { appBridgeInstance } from "../../pages/_app";
|
||
|
|
||
|
function getBaseUrl() {
|
||
|
if (typeof window !== "undefined") return "";
|
||
|
if (process.env.VERCEL_URL) return `https://${process.env.VERCEL_URL}`;
|
||
|
|
||
|
return `http://localhost:${process.env.PORT ?? 3000}`;
|
||
|
}
|
||
|
|
||
|
export const trpcClient = createTRPCNext<AppRouter>({
|
||
|
config({ ctx }) {
|
||
|
return {
|
||
|
links: [
|
||
|
httpBatchLink({
|
||
|
url: `${getBaseUrl()}/api/trpc`,
|
||
|
headers() {
|
||
|
const { token, saleorApiUrl } = appBridgeInstance?.getState() || {};
|
||
|
|
||
|
if (!token || !saleorApiUrl) {
|
||
|
console.error(
|
||
|
"Can't initialize tRPC client before establishing the App Bridge connection",
|
||
|
);
|
||
|
throw new Error("Token and Saleor API URL unknown");
|
||
|
}
|
||
|
return {
|
||
|
/**
|
||
|
* Attach headers from app to client requests, so tRPC can add them to context
|
||
|
*/
|
||
|
[SALEOR_AUTHORIZATION_BEARER_HEADER]: appBridgeInstance?.getState().token,
|
||
|
[SALEOR_API_URL_HEADER]: appBridgeInstance?.getState().saleorApiUrl,
|
||
|
};
|
||
|
},
|
||
|
}),
|
||
|
],
|
||
|
queryClientConfig: { defaultOptions: { queries: { refetchOnWindowFocus: false } } },
|
||
|
};
|
||
|
},
|
||
|
ssr: false,
|
||
|
});
|