import type { NextApiHandler, NextApiRequest, NextApiResponse } from 'next' import { ReactionCommerceConfig, getConfig } from '..' export type ReactionCommerceApiHandler< T = any, H extends ReactionCommerceHandlers = {}, Options extends {} = {} > = ( req: NextApiRequest, res: NextApiResponse>, config: ReactionCommerceConfig, handlers: H, // Custom configs that may be used by a particular handler options: Options ) => void | Promise export type ReactionCommerceHandler = (options: { req: NextApiRequest res: NextApiResponse> config: ReactionCommerceConfig body: Body }) => void | Promise export type ReactionCommerceHandlers = { [k: string]: ReactionCommerceHandler } export type ReactionCommerceApiResponse = { data: T | null errors?: { message: string; code?: string }[] } export default function createApiHandler< T = any, H extends ReactionCommerceHandlers = {}, Options extends {} = {} >( handler: ReactionCommerceApiHandler, handlers: H, defaultOptions: Options ) { console.log('next api handler', defaultOptions) return function getApiHandler({ config, operations, options, }: { config?: ReactionCommerceConfig operations?: Partial options?: Options extends {} ? Partial : never } = {}): NextApiHandler { const ops = { ...operations, ...handlers } const opts = { ...defaultOptions, ...options } return function apiHandler(req, res) { return handler(req, res, getConfig(config), ops, opts) } } }