mirror of
https://github.com/mealie-recipes/mealie.git
synced 2026-02-27 10:13:11 -05:00
* Translate missing items on About page * Localize import summary dialog * Make site menu translation reactive * Localize import options * Include semi colon in string * Move API texts to frontend + better status codes * Provide feedback to user when no meal is planned * Fix API tests after latest rework * Add warning for API changes in changelog * Refactor API texts handling * Refactor API texts handling #2 * Better API feedback * Rearrange strings hierarchy * Add messages upon recipe updated * Fix 'recipe effected' typo * Remove snackbar usage in backend * Translate toolbox * Provide feedback for tags CRUD * Fix messed up merge * Translate sign-up form * Better feedback for sign-up CRUD * Refactor log-in API texts handling * No error message when user is not authenticated * Remove unimportant console log
148 lines
4.2 KiB
JavaScript
148 lines
4.2 KiB
JavaScript
import { baseURL } from "./api-utils";
|
|
import { apiReq } from "./api-utils";
|
|
import { store } from "../store";
|
|
import i18n from '@/i18n.js';
|
|
|
|
const prefix = baseURL + "recipes/";
|
|
|
|
const recipeURLs = {
|
|
allRecipes: baseURL + "recipes",
|
|
summary: baseURL + "recipes" + "/summary",
|
|
allRecipesByCategory: prefix + "category",
|
|
create: prefix + "create",
|
|
createByURL: prefix + "create-url",
|
|
recipe: slug => prefix + slug,
|
|
update: slug => prefix + slug,
|
|
delete: slug => prefix + slug,
|
|
recipeImage: slug => `${prefix}${slug}/image`,
|
|
updateImage: slug => `${prefix}${slug}/image`,
|
|
createAsset: slug => `${prefix}${slug}/asset`,
|
|
};
|
|
|
|
export const recipeAPI = {
|
|
/**
|
|
* Create a Recipe by URL
|
|
* @param {string} recipeURL
|
|
* @returns {string} Recipe Slug
|
|
*/
|
|
async createByURL(recipeURL) {
|
|
const response = await apiReq.post(
|
|
recipeURLs.createByURL,
|
|
{ url: recipeURL },
|
|
function() { return i18n.t('recipe.recipe-creation-failed'); },
|
|
function() { return i18n.t('recipe.recipe-created'); }
|
|
);
|
|
|
|
store.dispatch("requestRecentRecipes");
|
|
return response;
|
|
},
|
|
|
|
async getAllByCategory(categories) {
|
|
let response = await apiReq.post(
|
|
recipeURLs.allRecipesByCategory,
|
|
categories
|
|
);
|
|
return response.data;
|
|
},
|
|
|
|
async create(recipeData) {
|
|
const response = await apiReq.post(
|
|
recipeURLs.create,
|
|
recipeData,
|
|
function() { return i18n.t('recipe.recipe-creation-failed'); },
|
|
function() { return i18n.t('recipe.recipe-created'); }
|
|
);
|
|
store.dispatch("requestRecentRecipes");
|
|
return response.data;
|
|
},
|
|
|
|
async requestDetails(recipeSlug) {
|
|
let response = await apiReq.get(recipeURLs.recipe(recipeSlug));
|
|
return response.data;
|
|
},
|
|
|
|
updateImage(recipeSlug, fileObject, overrideSuccessMsg = false) {
|
|
const formData = new FormData();
|
|
formData.append("image", fileObject);
|
|
formData.append("extension", fileObject.name.split(".").pop());
|
|
|
|
let successMessage = null;
|
|
if(!overrideSuccessMsg) {
|
|
successMessage = function() { return overrideSuccessMsg ? null : i18n.t('recipe.recipe-image-updated'); };
|
|
}
|
|
|
|
return apiReq.put(
|
|
recipeURLs.updateImage(recipeSlug),
|
|
formData,
|
|
function() { return i18n.t('general.image-upload-failed'); },
|
|
successMessage
|
|
);
|
|
},
|
|
|
|
async createAsset(recipeSlug, fileObject, name, icon) {
|
|
const fd = new FormData();
|
|
fd.append("file", fileObject);
|
|
fd.append("extension", fileObject.name.split(".").pop());
|
|
fd.append("name", name);
|
|
fd.append("icon", icon);
|
|
let response = apiReq.post(recipeURLs.createAsset(recipeSlug), fd);
|
|
return response;
|
|
},
|
|
|
|
updateImagebyURL(slug, url) {
|
|
return apiReq.post(
|
|
recipeURLs.updateImage(slug),
|
|
{ url: url },
|
|
function() { return i18n.t('general.image-upload-failed'); },
|
|
function() { return i18n.t('recipe.recipe-image-updated'); }
|
|
);
|
|
},
|
|
|
|
async update(data) {
|
|
let response = await apiReq.put(
|
|
recipeURLs.update(data.slug),
|
|
data,
|
|
function() { return i18n.t('recipe.recipe-update-failed'); },
|
|
function() { return i18n.t('recipe.recipe-updated'); }
|
|
);
|
|
if(response) {
|
|
store.dispatch("patchRecipe", response.data);
|
|
return response.data.slug; // ! Temporary until I rewrite to refresh page without additional request
|
|
}
|
|
},
|
|
|
|
async patch(data) {
|
|
let response = await apiReq.patch(recipeURLs.update(data.slug), data);
|
|
store.dispatch("patchRecipe", response.data);
|
|
return response.data;
|
|
},
|
|
|
|
delete(recipeSlug) {
|
|
return apiReq.delete(
|
|
recipeURLs.delete(recipeSlug),
|
|
null,
|
|
function() { return i18n.t('recipe.unable-to-delete-recipe'); },
|
|
function() { return i18n.t('recipe.recipe-deleted'); }
|
|
);
|
|
},
|
|
|
|
async allSummary(start = 0, limit = 9999) {
|
|
const response = await apiReq.get(recipeURLs.summary, {
|
|
params: { start: start, limit: limit },
|
|
});
|
|
return response.data;
|
|
},
|
|
|
|
recipeImage(recipeSlug) {
|
|
return `/api/recipes/${recipeSlug}/image?image_type=original`;
|
|
},
|
|
|
|
recipeSmallImage(recipeSlug) {
|
|
return `/api/recipes/${recipeSlug}/image?image_type=small`;
|
|
},
|
|
|
|
recipeTinyImage(recipeSlug) {
|
|
return `/api/recipes/${recipeSlug}/image?image_type=tiny`;
|
|
},
|
|
};
|