import type { RecursivePartial, RecursiveRequired } from '../utils/types' import { BigcommerceConfig, getConfig } from '..' import { definitions } from '../definitions/store-content' export type Page = definitions['page_Full'] export type GetPageResult<T extends { page?: any } = { page?: Page }> = T export type PageVariables = { id: number } async function getPage(opts: { url?: string variables: PageVariables config?: BigcommerceConfig preview?: boolean }): Promise<GetPageResult> async function getPage<T extends { page?: any }, V = any>(opts: { url: string variables: V config?: BigcommerceConfig preview?: boolean }): Promise<GetPageResult<T>> async function getPage({ url, variables, config, preview, }: { url?: string variables: PageVariables config?: BigcommerceConfig preview?: boolean }): Promise<GetPageResult> { config = getConfig(config) // RecursivePartial forces the method to check for every prop in the data, which is // required in case there's a custom `url` const { data } = await config.storeApiFetch<RecursivePartial<{ data: Page[] }>>( url || `/v3/content/pages?id=${variables.id}&include=body` ) const firstPage = data?.[0] const page = firstPage as RecursiveRequired<typeof firstPage> if (preview || page?.is_visible) { return { page } } return {} } export default getPage