mealie/frontend/src/pages/HomePage.vue
Hayden c1370afb16
Refactor/backend routers (#388)
* update router

* update caddy file

* setup depends in docker-fole

* make changes for serving on subpath

* set dev config

* fix router signups

* consolidate links

* backup-functionality to dashboard

* new user card

* consolidate theme into profile

* fix theme tests

* fix pg tests

* fix pg tests

* remove unused import

* mobile margin

Co-authored-by: hay-kot <hay-kot@pm.me>
2021-05-04 20:45:11 -08:00

73 lines
1.9 KiB
Vue

<template>
<v-container>
<CardSection
title-icon=""
v-if="siteSettings.showRecent"
:title="$t('page.recent')"
:recipes="recentRecipes"
:hard-limit="siteSettings.cardsPerSection"
/>
<CardSection
:sortable="true"
v-for="(section, index) in recipeByCategory"
:key="section.name + section.position"
:title="section.name"
:recipes="section.recipes"
:hard-limit="siteSettings.cardsPerSection"
@sort="sortAZ(index)"
@sort-recent="sortRecent(index)"
/>
</v-container>
</template>
<script>
import { api } from "@/api";
import CardSection from "../components/UI/CardSection";
export default {
components: {
CardSection,
},
data() {
return {
recipeByCategory: [],
};
},
computed: {
siteSettings() {
return this.$store.getters.getSiteSettings;
},
recentRecipes() {
return this.$store.getters.getRecentRecipes;
},
},
async mounted() {
await this.buildPage();
this.recipeByCategory.sort((a, b) => a.position - b.position);
},
methods: {
async buildPage() {
await this.$store.dispatch("requestSiteSettings");
this.siteSettings.categories.forEach(async element => {
let recipes = await this.getRecipeByCategory(element.slug);
if (recipes.recipes.length < 0) recipes.recipes = [];
this.recipeByCategory.push(recipes);
});
},
async getRecipeByCategory(category) {
return await api.categories.getRecipesInCategory(category);
},
getRecentRecipes() {
this.$store.dispatch("requestRecentRecipes");
},
sortAZ(index) {
this.recipeByCategory[index].recipes.sort((a, b) => (a.name > b.name ? 1 : -1));
},
sortRecent(index) {
this.recipeByCategory[index].recipes.sort((a, b) => (a.dateAdded > b.dateAdded ? -1 : 1));
},
},
};
</script>
<style></style>