mirror of
				https://github.com/mealie-recipes/mealie.git
				synced 2025-11-03 18:53:17 -05:00 
			
		
		
		
	* add groupSlug to most routes * fixed more routing issues * fixed jank and incorrect routes * remove public explore links * remove unused groupSlug and explore routes * nuked explore pages * fixed public toolstore bug * fixed various routes missing group slug * restored public app header menu * fix janky login redirect * 404 recipe API call returns to login * removed unused explore layout * force redirect when using the wrong group slug * fixed dead admin links * removed unused middleware from earlier attempt * 🧹 * improve cookbooks sidebar fixed sidebar link not working fixed sidebar link target hide cookbooks header when there are none * added group slug to user * fix $auth typehints * vastly simplified groupSlug logic * allow logged-in users to view other groups * fixed some edgecases that bypassed isOwnGroup * fixed static home ref * 🧹 * fixed redirect logic * lint warning * removed group slug from group and user pages refactored all components to use route groupSlug or user group slug moved some group pages to recipe pages * fixed some bad types * 🧹 * moved groupSlug routes under /g/groupSlug * move /recipe/ to /r/ * fix backend url generation and metadata injection * moved shopping lists to root/other route fixes * changed shared from /recipes/ to /r/ * fixed 404 redirect not awaiting * removed unused import * fix doc links * fix public recipe setting not affecting public API * fixed backend tests * fix nuxt-generate command --------- Co-authored-by: Hayden <64056131+hay-kot@users.noreply.github.com>
		
			
				
	
	
		
			133 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { useAsync, useRouter, ref } from "@nuxtjs/composition-api";
 | 
						|
import { useAsyncKey } from "../use-utils";
 | 
						|
import { usePublicExploreApi } from "~/composables/api/api-client";
 | 
						|
import { useUserApi } from "~/composables/api";
 | 
						|
import { Recipe } from "~/lib/api/types/recipe";
 | 
						|
import { RecipeSearchQuery } from "~/lib/api/user/recipes/recipe";
 | 
						|
 | 
						|
export const allRecipes = ref<Recipe[]>([]);
 | 
						|
export const recentRecipes = ref<Recipe[]>([]);
 | 
						|
 | 
						|
export const useLazyRecipes = function (publicGroupSlug: string | null = null) {
 | 
						|
  const router = useRouter();
 | 
						|
 | 
						|
  // passing the group slug switches to using the public API
 | 
						|
  const api = publicGroupSlug ? usePublicExploreApi(publicGroupSlug).explore : useUserApi();
 | 
						|
 | 
						|
  const recipes = ref<Recipe[]>([]);
 | 
						|
 | 
						|
  async function fetchMore(
 | 
						|
    page: number,
 | 
						|
    perPage: number,
 | 
						|
    orderBy: string | null = null,
 | 
						|
    orderDirection = "desc",
 | 
						|
    query: RecipeSearchQuery | null = null,
 | 
						|
    queryFilter: string | null = null,
 | 
						|
  ) {
 | 
						|
 | 
						|
    const { data, error } = await api.recipes.getAll(page, perPage, {
 | 
						|
      orderBy,
 | 
						|
      orderDirection,
 | 
						|
      paginationSeed: query?._searchSeed, // propagate searchSeed to stabilize random order pagination
 | 
						|
      searchSeed: query?._searchSeed, // unused, but pass it along for completeness of data
 | 
						|
      search: query?.search,
 | 
						|
      cookbook: query?.cookbook,
 | 
						|
      categories: query?.categories,
 | 
						|
      requireAllCategories: query?.requireAllCategories,
 | 
						|
      tags: query?.tags,
 | 
						|
      requireAllTags: query?.requireAllTags,
 | 
						|
      tools: query?.tools,
 | 
						|
      requireAllTools: query?.requireAllTools,
 | 
						|
      foods: query?.foods,
 | 
						|
      requireAllFoods: query?.requireAllFoods,
 | 
						|
      queryFilter,
 | 
						|
    });
 | 
						|
 | 
						|
    if (error?.response?.status === 404) {
 | 
						|
      router.push("/login");
 | 
						|
    }
 | 
						|
 | 
						|
    return data ? data.items : [];
 | 
						|
  }
 | 
						|
 | 
						|
  function appendRecipes(val: Array<Recipe>) {
 | 
						|
    val.forEach((recipe) => {
 | 
						|
      recipes.value.push(recipe);
 | 
						|
    });
 | 
						|
  }
 | 
						|
 | 
						|
  function assignSorted(val: Array<Recipe>) {
 | 
						|
    recipes.value = val;
 | 
						|
  }
 | 
						|
 | 
						|
  function removeRecipe(slug: string) {
 | 
						|
    for (let i = 0; i < recipes?.value?.length; i++) {
 | 
						|
      if (recipes?.value[i].slug === slug) {
 | 
						|
        recipes?.value.splice(i, 1);
 | 
						|
        break;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  function replaceRecipes(val: Array<Recipe>) {
 | 
						|
    recipes.value = val;
 | 
						|
  }
 | 
						|
 | 
						|
  return {
 | 
						|
    recipes,
 | 
						|
    fetchMore,
 | 
						|
    appendRecipes,
 | 
						|
    assignSorted,
 | 
						|
    removeRecipe,
 | 
						|
    replaceRecipes,
 | 
						|
  };
 | 
						|
};
 | 
						|
 | 
						|
export const useRecipes = (
 | 
						|
  all = false, fetchRecipes = true,
 | 
						|
  loadFood = false,
 | 
						|
  publicGroupSlug: string | null = null
 | 
						|
) => {
 | 
						|
  const api = publicGroupSlug ? usePublicExploreApi(publicGroupSlug).explore : useUserApi();
 | 
						|
 | 
						|
  // recipes is non-reactive!!
 | 
						|
  const { recipes, page, perPage } = (() => {
 | 
						|
    if (all) {
 | 
						|
      return {
 | 
						|
        recipes: allRecipes,
 | 
						|
        page: 1,
 | 
						|
        perPage: -1,
 | 
						|
      };
 | 
						|
    } else {
 | 
						|
      return {
 | 
						|
        recipes: recentRecipes,
 | 
						|
        page: 1,
 | 
						|
        perPage: 30,
 | 
						|
      };
 | 
						|
    }
 | 
						|
  })();
 | 
						|
 | 
						|
  async function refreshRecipes() {
 | 
						|
    const { data } = await api.recipes.getAll(page, perPage, { loadFood, orderBy: "created_at" });
 | 
						|
    if (data) {
 | 
						|
      recipes.value = data.items;
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  function getAllRecipes() {
 | 
						|
    useAsync(async () => {
 | 
						|
      await refreshRecipes();
 | 
						|
    }, useAsyncKey());
 | 
						|
  }
 | 
						|
 | 
						|
  function assignSorted(val: Array<Recipe>) {
 | 
						|
    recipes.value = val;
 | 
						|
  }
 | 
						|
 | 
						|
  if (fetchRecipes) {
 | 
						|
    getAllRecipes();
 | 
						|
  }
 | 
						|
 | 
						|
  return { getAllRecipes, assignSorted, refreshRecipes };
 | 
						|
};
 |