mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-07-24 15:49:42 +02:00
Previously, the recipe-ratings component would not sync to the v-modeled value when doing it's own updating. This PR fixes that issue and ensures that the value is pushed up to the parent whether in emit only mode or not.
101 lines
2.7 KiB
Vue
101 lines
2.7 KiB
Vue
<template>
|
|
<div class="d-flex justify-space-between align-center pt-2 pb-3">
|
|
<v-tooltip v-if="!isEditMode && recipe.recipeYield" small top color="secondary darken-1">
|
|
<template #activator="{ on, attrs }">
|
|
<RecipeScaleEditButton
|
|
v-model.number="scaleValue"
|
|
v-bind="attrs"
|
|
:recipe-yield="recipe.recipeYield"
|
|
:basic-yield="basicYield"
|
|
:scaled-yield="scaledYield"
|
|
:edit-scale="!recipe.settings.disableAmount && !isEditMode"
|
|
v-on="on"
|
|
/>
|
|
</template>
|
|
<span> {{ $t("recipe.edit-scale") }} </span>
|
|
</v-tooltip>
|
|
<v-spacer></v-spacer>
|
|
|
|
<RecipeRating
|
|
v-if="landscape && $vuetify.breakpoint.smAndUp"
|
|
:key="recipe.slug"
|
|
:v-model="recipe.rating"
|
|
:name="recipe.name"
|
|
:slug="recipe.slug"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { computed, defineComponent } from "@nuxtjs/composition-api";
|
|
import RecipeScaleEditButton from "~/components/Domain/Recipe/RecipeScaleEditButton.vue";
|
|
import RecipeRating from "~/components/Domain/Recipe/RecipeRating.vue";
|
|
import { NoUndefinedField } from "~/lib/api/types/non-generated";
|
|
import { Recipe } from "~/lib/api/types/recipe";
|
|
import { usePageState } from "~/composables/recipe-page/shared-state";
|
|
export default defineComponent({
|
|
components: {
|
|
RecipeScaleEditButton,
|
|
RecipeRating,
|
|
},
|
|
props: {
|
|
recipe: {
|
|
type: Object as () => NoUndefinedField<Recipe>,
|
|
required: true,
|
|
},
|
|
landscape: {
|
|
type: Boolean,
|
|
default: false,
|
|
},
|
|
scale: {
|
|
type: Number,
|
|
default: 1,
|
|
},
|
|
},
|
|
setup(props, { emit }) {
|
|
const { isEditMode } = usePageState(props.recipe.slug);
|
|
|
|
const scaleValue = computed<number>({
|
|
get() {
|
|
return props.scale;
|
|
},
|
|
set(val) {
|
|
emit("update:scale", val);
|
|
},
|
|
});
|
|
|
|
const scaledYield = computed(() => {
|
|
const regMatchNum = /\d+/;
|
|
const yieldString = props.recipe.recipeYield;
|
|
const num = yieldString?.match(regMatchNum);
|
|
|
|
if (num && num?.length > 0) {
|
|
const yieldAsInt = parseInt(num[0]);
|
|
return yieldString?.replace(num[0], String(yieldAsInt * scaleValue.value));
|
|
}
|
|
|
|
return props.recipe.recipeYield;
|
|
});
|
|
|
|
const basicYield = computed(() => {
|
|
const regMatchNum = /\d+/;
|
|
const yieldString = props.recipe.recipeYield;
|
|
const num = yieldString?.match(regMatchNum);
|
|
|
|
if (num && num?.length > 0) {
|
|
const yieldAsInt = parseInt(num[0]);
|
|
return yieldString?.replace(num[0], String(yieldAsInt));
|
|
}
|
|
|
|
return props.recipe.recipeYield;
|
|
});
|
|
|
|
return {
|
|
scaleValue,
|
|
basicYield,
|
|
scaledYield,
|
|
isEditMode,
|
|
};
|
|
},
|
|
});
|
|
</script>
|