From bcafa829da4b8f916b10d3aaa12bbadb12bd5f15 Mon Sep 17 00:00:00 2001 From: Syd Amir Date: Tue, 28 May 2024 15:09:02 +0330 Subject: [PATCH] :wheelchair: add lesanApi function while declaration creation --- src/types/mod.ts | 51 ++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 49 insertions(+), 2 deletions(-) diff --git a/src/types/mod.ts b/src/types/mod.ts index 267453d..a1f4d1d 100644 --- a/src/types/mod.ts +++ b/src/types/mod.ts @@ -33,7 +33,6 @@ export const generateSchemTypes = async ( const schemaStruct = createStruct(schemas, schema); str = str + ` - export const ${schema}Strutct = ${JSON.stringify(schemaStruct, null, 2)};\n export type ${schema}Schema = ${ generateTypesFromStruct({ schemaStruct }) };\n @@ -71,7 +70,55 @@ export const generateSchemTypes = async ( } } str = str + ` - }\n + };\n + `; + + str = str + ` +export const lesanApi = ( + { URL, settings, baseHeaders }: { + URL: string; + settings?: Record; + baseHeaders?: Record; + }, +) => { + const setting = { + method: "POST", + headers: { + "Content-Type": "application/json", + ...baseHeaders, + }, + ...settings, + }; + + const send = async < + TService extends keyof ReqType, + TModel extends keyof ReqType[TService], + TAct extends keyof ReqType[TService][TModel], + TSet extends Partial, + TGet extends Partial, + >(body: { + service?: TService; + model: TModel; + act: TAct; + details: { + set: TSet; + get: TGet; + }; + }, additionalHeaders?: Record) => { + const req = await fetch(URL, { + ...setting, + headers: { + ...setting.headers, + ...additionalHeaders, + }, + body: JSON.stringify(body), + }); + + return await req.json(); + }; + + return { send }; +};\n `; await ensureDir("./declarations");