Files
web/lib/previewRequest.ts
2024-02-12 13:53:12 +01:00

44 lines
1.1 KiB
TypeScript

import "server-only";
import { request as graphqlRequest } from "graphql-request";
import { env } from "@/env/server.mjs";
import type { Data } from "@/types/request";
import type { DocumentNode } from "graphql";
import ContentstackLivePreview from "@contentstack/live-preview-utils";
export async function previewRequest<T>(
query: string | DocumentNode,
variables?: {}
): Promise<Data<T>> {
try {
const hash = ContentstackLivePreview.hash;
if (!env.CMS_PREVIEW_URL || !env.CMS_PREVIEW_TOKEN) {
throw new Error("No preview URL");
}
const headers = new Headers();
headers.append("access_token", env.CMS_ACCESS_TOKEN);
headers.append("Content-Type", "application/json");
headers.append("preview_token", env.CMS_PREVIEW_TOKEN);
headers.append("live_preview", hash);
const response = await fetch(env.CMS_PREVIEW_URL.toString(), {
method: "POST",
headers,
body: JSON.stringify({
query,
variables,
}),
});
const { data } = await response.json();
return data as Data<T>;
} catch (error) {
console.error(error);
throw new Error("Something went wrong");
}
}