mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-01-30 14:52:58 -08:00
327da02fc8
Co-authored-by: Kuchenpirat <24235032+Kuchenpirat@users.noreply.github.com>
115 lines
2.6 KiB
Vue
115 lines
2.6 KiB
Vue
<template>
|
|
<div v-if="stacked">
|
|
<v-container>
|
|
<v-row v-for="(time, index) in allTimes" :key="`${index}-stacked`" no-gutters>
|
|
<v-col cols="12" :class="containerClass">
|
|
<v-chip
|
|
:small="$vuetify.breakpoint.smAndDown"
|
|
label
|
|
:color="color"
|
|
class="ma-1"
|
|
>
|
|
<v-icon left>
|
|
{{ $globals.icons.clockOutline }}
|
|
</v-icon>
|
|
{{ time.name }} |
|
|
{{ time.value }}
|
|
</v-chip>
|
|
</v-col>
|
|
</v-row>
|
|
</v-container>
|
|
</div>
|
|
<div v-else>
|
|
<v-container :class="containerClass">
|
|
<v-chip
|
|
v-for="(time, index) in allTimes"
|
|
:key="index"
|
|
:small="$vuetify.breakpoint.smAndDown"
|
|
label
|
|
:color="color"
|
|
class="ma-1"
|
|
>
|
|
<v-icon left>
|
|
{{ $globals.icons.clockOutline }}
|
|
</v-icon>
|
|
{{ time.name }} |
|
|
{{ time.value }}
|
|
</v-chip>
|
|
</v-container>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { computed, defineComponent, useContext } from "@nuxtjs/composition-api";
|
|
|
|
export default defineComponent({
|
|
props: {
|
|
stacked: {
|
|
type: Boolean,
|
|
default: false,
|
|
},
|
|
prepTime: {
|
|
type: String,
|
|
default: null,
|
|
},
|
|
totalTime: {
|
|
type: String,
|
|
default: null,
|
|
},
|
|
performTime: {
|
|
type: String,
|
|
default: null,
|
|
},
|
|
color: {
|
|
type: String,
|
|
default: "accent custom-transparent"
|
|
},
|
|
containerClass: {
|
|
type: String,
|
|
default: undefined,
|
|
},
|
|
},
|
|
setup(props) {
|
|
const { i18n } = useContext();
|
|
|
|
function isEmpty(str: string | null) {
|
|
return !str || str.length === 0;
|
|
}
|
|
|
|
const showCards = computed(() => {
|
|
return [props.prepTime, props.totalTime, props.performTime].some((x) => !isEmpty(x));
|
|
});
|
|
|
|
const validateTotalTime = computed(() => {
|
|
return !isEmpty(props.totalTime) ? { name: i18n.t("recipe.total-time"), value: props.totalTime } : null;
|
|
});
|
|
|
|
const validatePrepTime = computed(() => {
|
|
return !isEmpty(props.prepTime) ? { name: i18n.t("recipe.prep-time"), value: props.prepTime } : null;
|
|
});
|
|
|
|
const validatePerformTime = computed(() => {
|
|
return !isEmpty(props.performTime) ? { name: i18n.t("recipe.perform-time"), value: props.performTime } : null;
|
|
});
|
|
|
|
const allTimes = computed(() => {
|
|
return [validateTotalTime.value, validatePrepTime.value, validatePerformTime.value].filter((x) => x !== null);
|
|
});
|
|
|
|
return {
|
|
showCards,
|
|
allTimes,
|
|
};
|
|
},
|
|
});
|
|
</script>
|
|
|
|
<style scoped>
|
|
.time-card-flex {
|
|
width: fit-content;
|
|
}
|
|
.custom-transparent {
|
|
opacity: 0.7;
|
|
}
|
|
</style>
|