mirror of
https://github.com/aaronpo97/the-biergarten-app.git
synced 2026-02-16 20:13:49 +00:00
Feat: add create brewery post, brewery image upload
Add address autocomplete, using MapBox
This commit is contained in:
34
src/requests/BreweryImage/sendUploadBreweryImageRequest.ts
Normal file
34
src/requests/BreweryImage/sendUploadBreweryImageRequest.ts
Normal file
@@ -0,0 +1,34 @@
|
||||
import BreweryPostQueryResult from '@/services/BreweryPost/types/BreweryPostQueryResult';
|
||||
import { z } from 'zod';
|
||||
|
||||
interface SendUploadBeerImagesRequestArgs {
|
||||
breweryPost: z.infer<typeof BreweryPostQueryResult>;
|
||||
images: FileList;
|
||||
}
|
||||
|
||||
const sendUploadBreweryImagesRequest = async ({
|
||||
breweryPost,
|
||||
images,
|
||||
}: SendUploadBeerImagesRequestArgs) => {
|
||||
const formData = new FormData();
|
||||
|
||||
[...images].forEach((file) => {
|
||||
formData.append('images', file);
|
||||
});
|
||||
|
||||
formData.append('caption', `Image of ${breweryPost.name}`);
|
||||
formData.append('alt', breweryPost.name);
|
||||
|
||||
const uploadResponse = await fetch(`/api/breweries/${breweryPost.id}/images`, {
|
||||
method: 'POST',
|
||||
body: formData,
|
||||
});
|
||||
|
||||
if (!uploadResponse.ok) {
|
||||
throw new Error('Failed to upload images');
|
||||
}
|
||||
|
||||
return uploadResponse.json();
|
||||
};
|
||||
|
||||
export default sendUploadBreweryImagesRequest;
|
||||
Reference in New Issue
Block a user