1
0
Fork 0
mirror of https://github.com/mealie-recipes/mealie.git synced 2025-07-24 15:49:42 +02:00

feat: add peak toggle for seeing original ingredient txt (#1111)

* add peak toggle for seeing original ingredient txt

* add recent changes + format

* cleanup search view

* space out results
This commit is contained in:
Hayden 2022-03-29 09:38:23 -08:00 committed by GitHub
parent 1a23f867da
commit 1092e0ce7c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 91 additions and 50 deletions

View file

@ -89,28 +89,34 @@
<v-icon v-if="disableAmount" slot="prepend" class="mr-n1" color="error" @click="$emit('delete')">
{{ $globals.icons.delete }}
</v-icon>
<template slot="append">
<v-tooltip top nudge-right="10">
<template #activator="{ on, attrs }">
<v-btn icon small class="mt-n1" v-bind="attrs" v-on="on" @click="toggleTitle()">
<v-icon>{{ showTitle || value.title ? $globals.icons.minus : $globals.icons.createAlt }}</v-icon>
</v-btn>
</template>
<span>{{ showTitle ? $t("recipe.remove-section") : $t("recipe.insert-section") }}</span>
</v-tooltip>
</template>
<template slot="append-outer">
<v-icon class="handle mt-1">{{ $globals.icons.arrowUpDown }}</v-icon>
<BaseButtonGroup
:large="false"
class="handle my-auto"
:buttons="[
{
icon: $globals.icons.arrowUpDown,
text: '',
event: 'open',
children: contextMenuOptions,
},
]"
@toggle-section="toggleTitle"
@toggle-original="toggleOriginalText"
/>
</template>
</v-text-field>
</v-col>
</v-row>
<p v-if="showOriginalText" class="text-caption">Original Text: {{ value.originalText }}</p>
<v-divider v-if="!$vuetify.breakpoint.mdAndUp" class="my-4"></v-divider>
</div>
</template>
<script lang="ts">
import { defineComponent, reactive, ref, toRefs } from "@nuxtjs/composition-api";
import { computed, defineComponent, reactive, ref, toRefs } from "@nuxtjs/composition-api";
import { useFoods, useUnits } from "~/composables/recipes";
import { validators } from "~/composables/use-validators";
import { RecipeIngredient } from "~/types/api-types/recipe";
@ -153,6 +159,7 @@ export default defineComponent({
const state = reactive({
showTitle: false,
showOriginalText: false,
});
function toggleTitle() {
@ -165,6 +172,10 @@ export default defineComponent({
}
}
function toggleOriginalText() {
state.showOriginalText = !state.showOriginalText;
}
function handleUnitEnter() {
if (value.unit === undefined || value.unit === null || !value.unit.name.includes(unitSearch.value)) {
createAssignUnit();
@ -177,7 +188,35 @@ export default defineComponent({
}
}
const contextMenuOptions = computed(() => {
const options = [
{
text: "Toggle Section",
event: "toggle-section",
},
];
// FUTURE: add option to parse a single ingredient
// if (!value.food && !value.unit && value.note) {
// options.push({
// text: "Parse Ingredient",
// event: "parse-ingredient",
// });
// }
if (value.originalText) {
options.push({
text: "See Original Text",
event: "toggle-original",
});
}
return options;
});
return {
toggleOriginalText,
contextMenuOptions,
handleUnitEnter,
handleFoodEnter,
...toRefs(state),