0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-13 22:11:20 -05:00
astro/examples/ssr/src/api.ts
2022-02-14 17:50:16 +00:00

33 lines
881 B
TypeScript

interface Product {
id: number;
name: string;
price: number;
image: string;
}
//let origin: string;
const { mode } = import.meta.env;
const origin = mode === 'develeopment' ? `http://localhost:3000` : `http://localhost:8085`;
async function get<T>(endpoint: string, cb: (response: Response) => Promise<T>): Promise<T> {
const response = await fetch(`${origin}${endpoint}`);
if (!response.ok) {
// TODO make this better...
return null;
}
return cb(response);
}
export async function getProducts(): Promise<Product[]> {
return get<Product[]>('/api/products', async (response) => {
const products: Product[] = await response.json();
return products;
});
}
export async function getProduct(id: number): Promise<Product> {
return get<Product>(`/api/products/${id}`, async (response) => {
const product: Product = await response.json();
return product;
});
}