From c8e10e7c9b57a88f9a8520f2f1bf3b533b4bb7de Mon Sep 17 00:00:00 2001 From: Kravets <57632712+kravetsone@users.noreply.github.com> Date: Thu, 8 Feb 2024 16:02:11 +0300 Subject: [PATCH] chore: rewrite types --- docs/types/index.md | 32 ++++++++++++++++++++++++++++---- 1 file changed, 28 insertions(+), 4 deletions(-) diff --git a/docs/types/index.md b/docs/types/index.md index 725d4b3..3033324 100644 --- a/docs/types/index.md +++ b/docs/types/index.md @@ -10,7 +10,7 @@ ## Usage as an [NPM package](https://www.npmjs.com/package/@gramio/types) -```ts +```ts twoslash import type { ApiMethods } from "@gramio/types"; type SendMessageReturn = ReturnType; @@ -31,7 +31,7 @@ If the github action failed, there are no changes in the bot api ### Write you own type-safe TBA API wrapper -```typescript +```ts twoslash import type { ApiMethods, TelegramAPIResponse } from "@gramio/types"; const TBA_BASE_URL = "https://api.telegram.org/bot"; @@ -40,7 +40,7 @@ const TOKEN = ""; const api = new Proxy({} as ApiMethods, { get: (_target: ApiMethods, method: T) => - (params: Parameters[0]) => { + async (params: Parameters[0]) => { const response = await fetch(`${TBA_BASE_URL}${TOKEN}/${method}`, { method: "POST", headers: { @@ -64,7 +64,31 @@ api.sendMessage({ #### Usage with [`@gramio/keyboards`](https://github.com/gramiojs/keyboards) -```typescript +```typescript twoslash +import type { ApiMethods, TelegramAPIResponse } from "@gramio/types"; + +const TBA_BASE_URL = "https://api.telegram.org/bot"; +const TOKEN = ""; + +const api = new Proxy({} as ApiMethods, { + get: + (_target: ApiMethods, method: T) => + async (params: Parameters[0]) => { + const response = await fetch(`${TBA_BASE_URL}${TOKEN}/${method}`, { + method: "POST", + headers: { + "Content-Type": "application/json", + }, + body: JSON.stringify(params), + }); + + const data = (await response.json()) as TelegramAPIResponse; + if (!data.ok) throw new Error(`Some error occurred in ${method}`); + + return data.result; + }, +}); +// ---cut--- import { Keyboard } from "@gramio/keyboards"; // the code from the example above