2020-10-15 01:02:32 +05:30
|
|
|
<template>
|
2021-04-01 16:25:35 +05:30
|
|
|
<Page @loaded="onPageLoad" @unloaded="onPageUnload" actionBarHidden="true">
|
|
|
|
<GridLayout rows="*, auto" columns="*">
|
|
|
|
<DockLayout stretchLastChild="true" rowSpan="2">
|
|
|
|
<GridLayout
|
|
|
|
dock="top"
|
|
|
|
rows="auto,auto"
|
|
|
|
columns="*, auto"
|
2021-04-12 23:39:48 +05:30
|
|
|
paddingBottom="24"
|
2021-04-01 16:25:35 +05:30
|
|
|
>
|
|
|
|
<StackLayout>
|
|
|
|
<Label class="pageTitle" paddingBottom="8" :text="recipe.title" />
|
|
|
|
<StackLayout marginLeft="12" orientation="horizontal">
|
|
|
|
<Button
|
|
|
|
class="ico rate"
|
|
|
|
:class="{ rated: recipe.rating >= n }"
|
|
|
|
v-for="n in 5"
|
|
|
|
:key="n"
|
|
|
|
:text="recipe.rating < n ? icon.star : icon.starred"
|
|
|
|
@tap="
|
|
|
|
recipe.rating == 1 && n == 1 ? setRating(0) : setRating(n)
|
|
|
|
"
|
|
|
|
@longPress="setRating(n)"
|
|
|
|
/>
|
|
|
|
</StackLayout>
|
|
|
|
</StackLayout>
|
|
|
|
<Image
|
|
|
|
col="1"
|
|
|
|
v-if="recipe.imageSrc"
|
|
|
|
:src="recipe.imageSrc"
|
|
|
|
stretch="aspectFit"
|
|
|
|
class="photo"
|
|
|
|
decodeWidth="96"
|
|
|
|
decodeHeight="96"
|
2021-04-12 23:39:48 +05:30
|
|
|
@tap="viewPhoto"
|
2021-02-28 20:40:26 +05:30
|
|
|
/>
|
2021-04-01 16:25:35 +05:30
|
|
|
</GridLayout>
|
2021-04-14 14:57:40 +05:30
|
|
|
<AbsoluteLayout dock="bottom">
|
|
|
|
<ScrollView
|
2021-04-21 16:01:49 +05:30
|
|
|
dock="bottom"
|
2021-04-14 14:57:40 +05:30
|
|
|
width="100%"
|
|
|
|
height="100%"
|
|
|
|
@loaded="onScrollLoad"
|
2021-04-21 16:01:49 +05:30
|
|
|
@scroll="onScroll($event)"
|
2021-04-14 14:57:40 +05:30
|
|
|
>
|
|
|
|
<StackLayout>
|
|
|
|
<GridLayout rows="auto" columns="*, *">
|
|
|
|
<StackLayout class="attribute">
|
|
|
|
<Label class="title sub" :text="'cui' | L" />
|
|
|
|
<Label class="value" :text="recipe.cuisine | L" />
|
|
|
|
</StackLayout>
|
|
|
|
<StackLayout class="attribute" col="1">
|
|
|
|
<Label class="title sub" :text="'cat' | L" />
|
|
|
|
<Label class="value" :text="recipe.category | L" />
|
|
|
|
</StackLayout>
|
|
|
|
</GridLayout>
|
|
|
|
<StackLayout :hidden="!recipe.tags.length" class="attribute">
|
|
|
|
<Label class="title sub" :text="'ts' | L" />
|
|
|
|
<Label class="value" :text="getTags(recipe.tags)" />
|
2021-02-28 20:40:26 +05:30
|
|
|
</StackLayout>
|
2021-04-14 14:57:40 +05:30
|
|
|
<GridLayout rows="auto" columns="*, *">
|
|
|
|
<StackLayout
|
|
|
|
class="attribute"
|
|
|
|
:hidden="!hasTime(recipe.prepTime)"
|
|
|
|
>
|
|
|
|
<Label class="title sub" :text="'prepT' | L" />
|
|
|
|
<Label class="value" :text="formattedTime(recipe.prepTime)" />
|
|
|
|
</StackLayout>
|
|
|
|
<StackLayout
|
|
|
|
:col="hasTime(recipe.prepTime) ? 1 : 0"
|
|
|
|
class="attribute"
|
|
|
|
:hidden="!hasTime(recipe.cookTime)"
|
|
|
|
>
|
|
|
|
<Label class="title sub" :text="'cookT' | L" />
|
|
|
|
<Label class="value" :text="formattedTime(recipe.cookTime)" />
|
|
|
|
</StackLayout>
|
|
|
|
</GridLayout>
|
|
|
|
<GridLayout rows="auto" columns="*, *">
|
|
|
|
<StackLayout class="attribute">
|
|
|
|
<Label class="title sub" :text="'yld' | L" />
|
|
|
|
<Label
|
|
|
|
@touch="touchYield"
|
|
|
|
class="value clickable"
|
|
|
|
:text="`${tempYieldQuantity} ${$options.filters.L(
|
|
|
|
recipe.yield.unit
|
|
|
|
)}`"
|
|
|
|
/>
|
|
|
|
</StackLayout>
|
|
|
|
<StackLayout class="attribute" col="1">
|
|
|
|
<Label class="title sub" :text="'Difficulty level' | L" />
|
|
|
|
<Label class="value" :text="recipe.difficulty | L" />
|
|
|
|
</StackLayout>
|
|
|
|
</GridLayout>
|
|
|
|
<StackLayout @loaded="onIngsLoad">
|
2021-04-12 23:39:48 +05:30
|
|
|
<Label
|
2021-04-14 14:57:40 +05:30
|
|
|
padding="0 16"
|
|
|
|
class="sectionTitle"
|
|
|
|
:hidden="!recipe.ingredients.length"
|
|
|
|
:text="getTitleCount('ings', 'ingredients')"
|
2021-04-12 23:39:48 +05:30
|
|
|
/>
|
2021-04-14 14:57:40 +05:30
|
|
|
<StackLayout
|
|
|
|
orientation="horizontal"
|
|
|
|
v-for="(item, index) in recipe.ingredients"
|
|
|
|
:key="index + 'ing'"
|
|
|
|
class="ingredient"
|
|
|
|
@touch="touchIngredient($event, index)"
|
|
|
|
>
|
|
|
|
<Button class="ico min" :text="icon.uncheck" />
|
|
|
|
<Label
|
|
|
|
class="value tw"
|
|
|
|
:text="`${
|
|
|
|
roundedQuantity(item.quantity)
|
|
|
|
? roundedQuantity(item.quantity) + ' '
|
|
|
|
: ''
|
|
|
|
}${
|
|
|
|
roundedQuantity(item.quantity)
|
|
|
|
? $options.filters.L(item.unit) + ' '
|
|
|
|
: ''
|
|
|
|
}${item.item}`"
|
|
|
|
/>
|
|
|
|
</StackLayout>
|
2021-04-12 23:39:48 +05:30
|
|
|
</StackLayout>
|
2021-04-14 14:57:40 +05:30
|
|
|
<StackLayout @loaded="onInsLoad">
|
2021-04-12 23:39:48 +05:30
|
|
|
<Label
|
2021-04-14 14:57:40 +05:30
|
|
|
padding="0 16"
|
|
|
|
:hidden="!recipe.instructions.length"
|
|
|
|
class="sectionTitle"
|
|
|
|
:text="getTitleCount('inss', 'instructions')"
|
2021-04-12 23:39:48 +05:30
|
|
|
/>
|
2021-04-14 14:57:40 +05:30
|
|
|
<StackLayout
|
|
|
|
orientation="horizontal"
|
|
|
|
@touch="touchInstruction"
|
|
|
|
v-for="(instruction, index) in recipe.instructions"
|
|
|
|
:key="index + 'ins'"
|
|
|
|
class="instruction"
|
|
|
|
>
|
|
|
|
<Button class="count ico min" :text="index + 1" />
|
|
|
|
<Label class="value tw" :text="instruction" />
|
|
|
|
</StackLayout>
|
|
|
|
</StackLayout>
|
|
|
|
<Label
|
|
|
|
@loaded="onCmbLoad"
|
|
|
|
padding="0 16"
|
|
|
|
:hidden="!recipe.combinations.length"
|
|
|
|
class="sectionTitle"
|
|
|
|
:text="getTitleCount('cmbs', 'combinations')"
|
|
|
|
/>
|
|
|
|
<Button
|
|
|
|
v-for="(combination, index) in recipe.combinations"
|
|
|
|
:key="index + 'comb'"
|
|
|
|
class="combination"
|
|
|
|
:text="getCombinationTitle(combination)"
|
|
|
|
@tap="viewCombination(combination)"
|
|
|
|
/>
|
|
|
|
<Label
|
|
|
|
@loaded="onNosTLoad"
|
|
|
|
padding="0 16"
|
|
|
|
:hidden="!recipe.notes.length"
|
|
|
|
class="sectionTitle"
|
|
|
|
:text="getTitleCount('nos', 'notes')"
|
|
|
|
/>
|
|
|
|
<StackLayout @loaded="onNosLoad" padding="0 16"> </StackLayout>
|
|
|
|
<Label
|
|
|
|
class="dateInfo sub tw"
|
|
|
|
:text="`${$options.filters.L('Last updated')}: ${formattedDate(
|
|
|
|
recipe.lastModified
|
|
|
|
)}\n${$options.filters.L('Created')}: ${formattedDate(
|
|
|
|
recipe.created
|
|
|
|
)}`"
|
|
|
|
/>
|
2021-04-12 23:39:48 +05:30
|
|
|
</StackLayout>
|
2021-04-14 14:57:40 +05:30
|
|
|
</ScrollView>
|
|
|
|
<Label
|
2021-04-21 16:01:49 +05:30
|
|
|
@loaded="onStickyLoad"
|
2021-04-14 14:57:40 +05:30
|
|
|
class="sectionTitle sticky"
|
2021-04-21 16:01:49 +05:30
|
|
|
:hidden="!stickyTitle"
|
|
|
|
:text="stickyTitle"
|
2021-04-14 14:57:40 +05:30
|
|
|
/>
|
|
|
|
</AbsoluteLayout>
|
2021-04-01 16:25:35 +05:30
|
|
|
</DockLayout>
|
|
|
|
<GridLayout
|
|
|
|
row="1"
|
|
|
|
@loaded="onAppBarLoad"
|
|
|
|
class="appbar"
|
|
|
|
v-show="!toast"
|
|
|
|
columns="auto, *, auto, auto, auto, auto"
|
|
|
|
>
|
2021-04-12 23:39:48 +05:30
|
|
|
<Button
|
|
|
|
class="ico"
|
|
|
|
:text="photoOpen ? icon.x : icon.back"
|
|
|
|
@tap="navigateBack"
|
|
|
|
/>
|
2021-04-01 16:25:35 +05:30
|
|
|
<Button
|
|
|
|
col="2"
|
|
|
|
v-if="!filterTrylater"
|
|
|
|
class="ico"
|
|
|
|
:text="recipe.tried ? icon.try : icon.tried"
|
2021-04-12 23:39:48 +05:30
|
|
|
@tap="toggle('tried')"
|
2021-04-01 16:25:35 +05:30
|
|
|
/>
|
|
|
|
<Button
|
|
|
|
col="2"
|
|
|
|
v-else
|
|
|
|
class="ico"
|
|
|
|
:text="icon.done"
|
|
|
|
@tap="recipeTried"
|
|
|
|
/>
|
|
|
|
<Button
|
|
|
|
col="3"
|
|
|
|
class="ico"
|
|
|
|
:text="recipe.isFavorite ? icon.faved : icon.fav"
|
2021-04-12 23:39:48 +05:30
|
|
|
@tap="toggle('isFavorite')"
|
2021-04-01 16:25:35 +05:30
|
|
|
/>
|
|
|
|
<Button
|
|
|
|
col="4"
|
|
|
|
v-if="!busy"
|
|
|
|
class="ico"
|
|
|
|
:text="icon.edit"
|
|
|
|
@tap="editRecipe"
|
|
|
|
/>
|
|
|
|
<ActivityIndicator col="4" v-else :busy="busy" />
|
|
|
|
<Button
|
|
|
|
class="ico fab"
|
|
|
|
:text="icon.share"
|
|
|
|
col="5"
|
|
|
|
@tap="shareHandler"
|
|
|
|
/>
|
2021-02-28 20:40:26 +05:30
|
|
|
</GridLayout>
|
2021-04-01 16:25:35 +05:30
|
|
|
<GridLayout
|
|
|
|
v-show="toast"
|
|
|
|
row="1"
|
2021-04-12 23:39:48 +05:30
|
|
|
class="appbar snackBar"
|
2021-04-01 16:25:35 +05:30
|
|
|
columns="*"
|
|
|
|
@tap="toast = null"
|
|
|
|
>
|
|
|
|
<FlexboxLayout minHeight="48" alignItems="center">
|
|
|
|
<Label class="title msg" :text="toast" />
|
|
|
|
</FlexboxLayout>
|
|
|
|
</GridLayout>
|
2021-04-12 23:39:48 +05:30
|
|
|
<AbsoluteLayout rowSpan="2">
|
2021-04-21 16:01:49 +05:30
|
|
|
<Image
|
|
|
|
@tap="({ object }) => (object.cancel = true)"
|
|
|
|
backgroundColor="black"
|
|
|
|
stretch="aspectFit"
|
|
|
|
@loaded="onImgViewLoad"
|
2021-04-12 23:39:48 +05:30
|
|
|
:src="recipe.imageSrc"
|
|
|
|
class="photoviewer"
|
2021-04-21 16:01:49 +05:30
|
|
|
/>
|
2021-04-12 23:39:48 +05:30
|
|
|
</AbsoluteLayout>
|
2021-04-01 16:25:35 +05:30
|
|
|
</GridLayout>
|
2021-02-28 20:40:26 +05:30
|
|
|
</Page>
|
2020-10-15 01:02:32 +05:30
|
|
|
</template>
|
|
|
|
|
2021-04-21 16:01:49 +05:30
|
|
|
<script lang="ts">
|
2020-11-02 17:06:53 +05:30
|
|
|
import {
|
2020-12-02 16:07:45 +05:30
|
|
|
Application,
|
2021-04-12 23:39:48 +05:30
|
|
|
AndroidApplication,
|
2020-11-10 23:58:48 +05:30
|
|
|
ImageSource,
|
|
|
|
Utils,
|
2020-12-02 15:16:25 +05:30
|
|
|
Span,
|
|
|
|
FormattedString,
|
|
|
|
Label,
|
2020-12-29 16:05:19 +05:30
|
|
|
Observable,
|
2021-04-01 16:25:35 +05:30
|
|
|
Screen,
|
2021-04-12 23:39:48 +05:30
|
|
|
CoreTypes,
|
2021-02-28 20:40:26 +05:30
|
|
|
} from "@nativescript/core";
|
|
|
|
import { localize } from "@nativescript/localize";
|
|
|
|
const intl = require("nativescript-intl");
|
|
|
|
import { mapActions, mapState } from "vuex";
|
|
|
|
import EditRecipe from "./EditRecipe.vue";
|
2021-04-01 16:25:35 +05:30
|
|
|
import ActionDialog from "./modal/ActionDialog.vue";
|
|
|
|
import PromptDialog from "./modal/PromptDialog.vue";
|
2021-04-12 23:39:48 +05:30
|
|
|
import * as utils from "~/shared/utils";
|
2020-10-15 01:02:32 +05:30
|
|
|
export default {
|
2021-02-28 20:40:26 +05:30
|
|
|
props: ["filterTrylater", "recipeID"],
|
2020-10-15 01:02:32 +05:30
|
|
|
data() {
|
|
|
|
return {
|
2020-10-21 23:24:45 +05:30
|
|
|
busy: false,
|
2020-11-02 17:06:53 +05:30
|
|
|
yieldMultiplier: 1,
|
2020-10-24 23:32:35 +05:30
|
|
|
recipe: null,
|
2020-11-15 16:21:10 +05:30
|
|
|
currentRecipeID: this.recipeID,
|
2021-04-01 16:25:35 +05:30
|
|
|
scrollview: null,
|
|
|
|
appbar: null,
|
|
|
|
ingcon: null,
|
|
|
|
inscon: null,
|
2021-04-14 14:57:40 +05:30
|
|
|
cmbcon: null,
|
2021-04-01 16:25:35 +05:30
|
|
|
notescon: null,
|
2021-04-14 14:57:40 +05:30
|
|
|
notesT: null,
|
2021-04-21 16:01:49 +05:30
|
|
|
imgView: null,
|
2021-01-13 10:32:48 +05:30
|
|
|
checks: [],
|
2021-04-12 23:39:48 +05:30
|
|
|
checked: 0,
|
|
|
|
stepsDid: 0,
|
2021-04-01 16:25:35 +05:30
|
|
|
toast: null,
|
2021-04-12 23:39:48 +05:30
|
|
|
photoOpen: false,
|
2021-04-14 14:57:40 +05:30
|
|
|
showTitleArr: [false, false, false, false],
|
2021-04-21 16:01:49 +05:30
|
|
|
sticky: null,
|
2021-02-28 20:40:26 +05:30
|
|
|
};
|
2020-10-15 01:02:32 +05:30
|
|
|
},
|
|
|
|
computed: {
|
2021-02-28 20:40:26 +05:30
|
|
|
...mapState(["icon", "recipes"]),
|
2021-04-12 23:39:48 +05:30
|
|
|
tempYieldQuantity() {
|
2021-02-28 20:40:26 +05:30
|
|
|
return Math.abs(this.yieldMultiplier) > 0
|
|
|
|
? Math.abs(parseFloat(this.yieldMultiplier))
|
|
|
|
: 1;
|
2020-10-15 01:02:32 +05:30
|
|
|
},
|
2021-04-21 16:01:49 +05:30
|
|
|
stickyTitle() {
|
|
|
|
let val = null;
|
|
|
|
switch (this.showTitleArr.lastIndexOf(true)) {
|
|
|
|
case 0:
|
|
|
|
val = this.getTitleCount("ings", "ingredients");
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
val = this.getTitleCount("inss", "instructions");
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
val = this.getTitleCount("cmbs", "combinations");
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
val = this.getTitleCount("nos", "notes");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return val;
|
|
|
|
},
|
2020-10-15 01:02:32 +05:30
|
|
|
},
|
|
|
|
methods: {
|
2021-02-28 20:40:26 +05:30
|
|
|
...mapActions([
|
|
|
|
"toggleStateAction",
|
2021-04-01 16:25:35 +05:30
|
|
|
"setComponent",
|
2021-02-28 20:40:26 +05:30
|
|
|
"overwriteRecipeAction",
|
|
|
|
"setRecipeAsTriedAction",
|
|
|
|
"setRatingAction",
|
|
|
|
"toggleCartAction",
|
|
|
|
]),
|
|
|
|
onPageLoad(args) {
|
2020-12-07 20:15:00 +05:30
|
|
|
const page = args.object;
|
|
|
|
page.bindingContext = new Observable();
|
2021-04-19 00:04:17 +05:30
|
|
|
this.busy = this.photoOpen = false;
|
2021-04-12 23:39:48 +05:30
|
|
|
this.setComponent("ViewRecipe");
|
2021-02-28 20:40:26 +05:30
|
|
|
if (this.yieldMultiplier == this.recipe.yield.quantity)
|
|
|
|
this.yieldMultiplier = this.recipe.yield.quantity;
|
|
|
|
this.keepScreenOn(true);
|
|
|
|
this.syncCombinations();
|
2020-10-30 01:42:53 +05:30
|
|
|
},
|
2020-11-10 23:58:48 +05:30
|
|
|
onPageUnload() {
|
2021-02-28 20:40:26 +05:30
|
|
|
this.keepScreenOn(false);
|
2020-11-10 23:58:48 +05:30
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
onAppBarLoad({ object }) {
|
|
|
|
this.appbar = object;
|
|
|
|
},
|
|
|
|
onIngsLoad({ object }) {
|
|
|
|
this.ingcon = object;
|
|
|
|
},
|
|
|
|
onInsLoad({ object }) {
|
|
|
|
this.inscon = object;
|
|
|
|
},
|
2021-04-14 14:57:40 +05:30
|
|
|
onCmbLoad({ object }) {
|
|
|
|
this.cmbcon = object;
|
|
|
|
},
|
|
|
|
onNosTLoad({ object }) {
|
|
|
|
this.notesT = object;
|
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
onNosLoad({ object }) {
|
|
|
|
this.notescon = object;
|
|
|
|
this.createNotes();
|
2021-01-13 10:32:48 +05:30
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
onScrollLoad(args) {
|
|
|
|
this.scrollview = args.object;
|
|
|
|
},
|
2021-04-21 16:01:49 +05:30
|
|
|
onImgViewLoad({ object }) {
|
|
|
|
this.imgView = object;
|
|
|
|
this.imgView.visibility = "collapsed";
|
|
|
|
this.imgView.top = 24;
|
|
|
|
this.imgView.left = Screen.mainScreen.widthDIPs - 112;
|
|
|
|
},
|
|
|
|
onStickyLoad({ object }) {
|
|
|
|
this.sticky = object;
|
2021-04-12 23:39:48 +05:30
|
|
|
},
|
2021-04-14 14:57:40 +05:30
|
|
|
// FIX: scroll not smooth
|
2021-04-21 16:01:49 +05:30
|
|
|
fixTitle({ object }, swipeUp: boolean): void {
|
|
|
|
let ingL = this.recipe.ingredients.length;
|
|
|
|
let insL = this.recipe.instructions.length;
|
|
|
|
let cmbL = this.recipe.combinations.length;
|
|
|
|
let notL = this.recipe.notes.length;
|
|
|
|
|
|
|
|
const isTop = (label): boolean => {
|
|
|
|
let pos = label.getLocationRelativeTo(object).y;
|
|
|
|
return label === this.cmbcon || label === this.notesT
|
|
|
|
? pos < 0
|
|
|
|
: pos + 32 < 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
const setVisibleTitle = (n: number): void => {
|
|
|
|
let arr = [ingL, insL, cmbL, notL];
|
|
|
|
this.showTitleArr = Array.from(
|
|
|
|
{ length: 4 },
|
|
|
|
(v, i) => (v = arr[i] ? i < n : false)
|
|
|
|
);
|
2021-04-23 20:00:50 +05:30
|
|
|
// this.sticky
|
|
|
|
// .animate({
|
|
|
|
// opacity: 0.5,
|
|
|
|
// duration: 0,
|
|
|
|
// })
|
|
|
|
// .then(() => {
|
|
|
|
// this.sticky.animate({
|
|
|
|
// opacity: 1,
|
|
|
|
// duration: 250,
|
|
|
|
// });
|
|
|
|
// });
|
2021-04-21 16:01:49 +05:30
|
|
|
};
|
|
|
|
|
|
|
|
if (swipeUp) {
|
|
|
|
if (ingL && !this.showTitleArr[0] && isTop(this.ingcon))
|
|
|
|
setVisibleTitle(1);
|
|
|
|
else if (insL && !this.showTitleArr[1] && isTop(this.inscon))
|
|
|
|
setVisibleTitle(2);
|
|
|
|
else if (cmbL && !this.showTitleArr[2] && isTop(this.cmbcon))
|
|
|
|
setVisibleTitle(3);
|
|
|
|
else if (notL && !this.showTitleArr[3] && isTop(this.notesT))
|
|
|
|
setVisibleTitle(4);
|
|
|
|
} else {
|
|
|
|
if (notL && this.showTitleArr[3] && !isTop(this.notesT))
|
|
|
|
setVisibleTitle(3);
|
|
|
|
else if (cmbL && this.showTitleArr[2] && !isTop(this.cmbcon))
|
|
|
|
setVisibleTitle(2);
|
|
|
|
else if (insL && this.showTitleArr[1] && !isTop(this.inscon))
|
|
|
|
setVisibleTitle(1);
|
|
|
|
else if (ingL && this.showTitleArr[0] && !isTop(this.ingcon))
|
|
|
|
setVisibleTitle(0);
|
|
|
|
}
|
2021-04-14 14:57:40 +05:30
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
onScroll(args) {
|
2021-04-21 16:01:49 +05:30
|
|
|
let swipeUp: boolean;
|
2021-04-01 16:25:35 +05:30
|
|
|
let y = args.scrollY;
|
|
|
|
if (y) {
|
2021-04-21 16:01:49 +05:30
|
|
|
swipeUp = y > this.scrollPos;
|
2021-04-01 16:25:35 +05:30
|
|
|
this.scrollPos = Math.abs(y);
|
2021-04-21 16:01:49 +05:30
|
|
|
this.fixTitle(args, swipeUp);
|
|
|
|
if (!this.toast) {
|
|
|
|
let ab = this.appbar.translateY;
|
|
|
|
if (swipeUp && ab == 0)
|
|
|
|
this.appbar.animate({
|
|
|
|
translate: { x: 0, y: 64 },
|
|
|
|
duration: 250,
|
|
|
|
curve: CoreTypes.AnimationCurve.ease,
|
|
|
|
});
|
|
|
|
else if (!swipeUp && ab == 64)
|
|
|
|
this.appbar.animate({
|
|
|
|
translate: { x: 0, y: 0 },
|
|
|
|
duration: 250,
|
|
|
|
curve: CoreTypes.AnimationCurve.ease,
|
|
|
|
});
|
|
|
|
}
|
2021-04-01 16:25:35 +05:30
|
|
|
}
|
|
|
|
},
|
2020-11-10 23:58:48 +05:30
|
|
|
// HELPERS
|
2021-04-12 23:39:48 +05:30
|
|
|
getTitleCount(title, type) {
|
|
|
|
let count = this.recipe[type].length;
|
|
|
|
let selected = null;
|
|
|
|
switch (title) {
|
|
|
|
case "ings":
|
|
|
|
selected = this.checked;
|
|
|
|
break;
|
|
|
|
case "inss":
|
|
|
|
selected = this.stepsDid;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
let text = selected ? ` (${selected}/${count})` : ` (${count})`;
|
|
|
|
return localize(title) + text;
|
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
changeYield() {
|
|
|
|
this.$showModal(PromptDialog, {
|
|
|
|
props: {
|
2021-04-16 10:20:04 +05:30
|
|
|
title: `${localize("req", localize(this.recipe.yield.unit))}`,
|
2021-04-01 16:25:35 +05:30
|
|
|
placeholder: Math.abs(parseFloat(this.yieldMultiplier)),
|
|
|
|
action: "SET",
|
|
|
|
},
|
|
|
|
}).then((item) => {
|
|
|
|
if (item) this.yieldMultiplier = item;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
hasTime(time) {
|
|
|
|
return time != "00:00";
|
|
|
|
},
|
2021-02-28 20:40:26 +05:30
|
|
|
niceDate(time) {
|
|
|
|
let lastTried = new Date(time).getTime();
|
|
|
|
let now = new Date().getTime();
|
|
|
|
let midnight = new Date().setHours(0, 0, 0, 0);
|
|
|
|
let diff = (now - lastTried) / 1000;
|
|
|
|
let dayDiff = Math.ceil(diff / 86400);
|
|
|
|
if (isNaN(dayDiff) || dayDiff < 0) return "";
|
2020-12-07 20:15:00 +05:30
|
|
|
|
2021-04-21 16:01:49 +05:30
|
|
|
function duration(value, number?) {
|
2021-04-17 21:54:47 +05:30
|
|
|
return number ? localize(value, number) : localize(value);
|
2020-12-07 20:15:00 +05:30
|
|
|
}
|
2020-10-30 01:42:53 +05:30
|
|
|
return (
|
2021-02-28 20:40:26 +05:30
|
|
|
(diff < 86400 && lastTried > midnight && duration("today")) ||
|
|
|
|
(dayDiff == 1 && "yesterday") ||
|
2021-04-17 21:54:47 +05:30
|
|
|
(dayDiff < 7 && duration("dAgo", dayDiff)) ||
|
|
|
|
(dayDiff < 31 && duration("wAgo", Math.round(dayDiff / 7))) ||
|
|
|
|
(dayDiff < 366 && duration("mAgo", Math.round(dayDiff / 30))) ||
|
2021-02-28 20:40:26 +05:30
|
|
|
(dayDiff > 365 && duration("ltAgo"))
|
|
|
|
);
|
2020-10-30 01:42:53 +05:30
|
|
|
},
|
2020-11-10 23:58:48 +05:30
|
|
|
showLastTried() {
|
2021-04-15 22:54:14 +05:30
|
|
|
this.toast = localize("triedInfo", this.niceDate(this.recipe.lastTried));
|
2021-04-17 21:54:47 +05:30
|
|
|
utils.timer(10, (val) => {
|
2021-04-12 23:39:48 +05:30
|
|
|
if (!val) this.toast = val;
|
|
|
|
});
|
2021-02-28 20:40:26 +05:30
|
|
|
},
|
2021-04-21 16:01:49 +05:30
|
|
|
// getMeasure(value: number, unit: string) {
|
|
|
|
// let vm = this;
|
|
|
|
// function roundedQ(val: number) {
|
|
|
|
// return Math.abs(
|
|
|
|
// Math.round(
|
|
|
|
// (val / vm.recipe.yield.quantity) * vm.tempYieldQuantity * 100
|
|
|
|
// ) / 100
|
|
|
|
// );
|
|
|
|
// }
|
|
|
|
// if (value) {
|
|
|
|
// let rounded = Math.abs(
|
|
|
|
// Math.round(
|
|
|
|
// (value / this.recipe.yield.quantity) * this.tempYieldQuantity * 100
|
|
|
|
// ) / 100
|
|
|
|
// );
|
|
|
|
// let lUnit = localize(unit);
|
|
|
|
|
|
|
|
// switch (unit) {
|
|
|
|
// //IMPERIAL
|
|
|
|
// case "g":
|
|
|
|
// return rounded < 1000
|
|
|
|
// ? `${rounded} ${lUnit} `
|
|
|
|
// : `${roundedQ(rounded / 1000)} ${localize("kg")} `;
|
|
|
|
// case "ml":
|
|
|
|
// return rounded < 1000
|
|
|
|
// ? `${rounded} ${lUnit} `
|
|
|
|
// : `${roundedQ(rounded / 1000)} ${localize("l")} `;
|
|
|
|
|
|
|
|
// //METRIC
|
|
|
|
// case "tsp":
|
|
|
|
// return rounded < 3
|
|
|
|
// ? `${rounded} ${lUnit} `
|
|
|
|
// : `${roundedQ(rounded / 3)} ${localize("tbsp")} `;
|
|
|
|
// case "in":
|
|
|
|
// return rounded < 12
|
|
|
|
// ? `${rounded} ${lUnit} `
|
|
|
|
// : `${roundedQ(rounded / 12)} ${localize("ft")} `;
|
|
|
|
// default:
|
|
|
|
// return `${rounded} ${lUnit} `;
|
|
|
|
// }
|
|
|
|
// } else return "";
|
|
|
|
// },
|
|
|
|
roundedQuantity(quantity: number) {
|
2021-02-28 20:40:26 +05:30
|
|
|
return Math.abs(
|
|
|
|
Math.round(
|
2021-04-12 23:39:48 +05:30
|
|
|
(quantity / this.recipe.yield.quantity) * this.tempYieldQuantity * 100
|
2021-02-28 20:40:26 +05:30
|
|
|
) / 100
|
|
|
|
);
|
|
|
|
},
|
|
|
|
keepScreenOn(boolean) {
|
|
|
|
let activity =
|
|
|
|
Application.android.foregroundActivity ||
|
|
|
|
Application.android.startActivity;
|
|
|
|
let window = activity.getWindow();
|
2021-04-01 16:25:35 +05:30
|
|
|
let flag = android.view.WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
|
|
|
|
boolean ? window.addFlags(flag) : window.clearFlags(flag);
|
2021-02-28 20:40:26 +05:30
|
|
|
},
|
|
|
|
formattedTime(time) {
|
|
|
|
let t = time.split(":");
|
|
|
|
let h = parseInt(t[0]);
|
|
|
|
let m = parseInt(t[1]);
|
|
|
|
let hr = localize("hr");
|
|
|
|
let min = localize("min");
|
|
|
|
return h ? (m ? `${h} ${hr} ${m} ${min}` : `${h} ${hr}`) : `${m} ${min}`;
|
|
|
|
},
|
|
|
|
formattedDate(date) {
|
|
|
|
let d = new Date(date);
|
|
|
|
var dateFormat = new intl.DateTimeFormat(null, {
|
|
|
|
year: "numeric",
|
|
|
|
month: "long",
|
|
|
|
day: "numeric",
|
|
|
|
hour: "numeric",
|
|
|
|
minute: "numeric",
|
|
|
|
}).format(d);
|
|
|
|
return `${dateFormat}`;
|
|
|
|
},
|
|
|
|
isValidURL(string) {
|
|
|
|
let pattern = new RegExp("^https?|^www", "ig");
|
|
|
|
return pattern.test(string);
|
|
|
|
},
|
|
|
|
getCombinationTitle(id) {
|
|
|
|
return this.recipes.filter((e) => e.id === id)[0].title;
|
2020-11-15 16:21:10 +05:30
|
|
|
},
|
|
|
|
syncCombinations() {
|
2021-02-28 20:40:26 +05:30
|
|
|
let combinationForOtherRecipes = this.recipes
|
|
|
|
.filter(
|
|
|
|
(e) =>
|
|
|
|
e.combinations.indexOf(this.currentRecipeID) >= 0 ||
|
|
|
|
this.recipe.combinations.includes(e.id)
|
|
|
|
)
|
|
|
|
.map((e) => e.id);
|
|
|
|
this.recipe.combinations = combinationForOtherRecipes;
|
|
|
|
this.overwriteRecipeAction({
|
2020-11-15 16:21:10 +05:30
|
|
|
id: this.currentRecipeID,
|
|
|
|
recipe: this.recipe,
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
2020-11-15 16:21:10 +05:30
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
touchIngredient({ object, action }, index) {
|
|
|
|
object.className = action.match(/down|move/)
|
|
|
|
? "ingredient fade"
|
|
|
|
: "ingredient";
|
|
|
|
if (action == "up") this.checkChange(object, index);
|
2021-01-23 22:50:15 +05:30
|
|
|
},
|
2021-04-12 23:39:48 +05:30
|
|
|
checkChange(obj, index) {
|
|
|
|
this.checks[index] = !this.checks[index];
|
|
|
|
if (this.checks[index]) {
|
|
|
|
this.checked++;
|
|
|
|
obj.getChildAt(0).text = this.icon.check;
|
|
|
|
} else {
|
|
|
|
this.checked--;
|
|
|
|
obj.getChildAt(0).text = this.icon.uncheck;
|
|
|
|
}
|
|
|
|
},
|
2021-01-23 22:50:15 +05:30
|
|
|
clearChecks() {
|
2021-04-12 23:39:48 +05:30
|
|
|
this.checked = 0;
|
|
|
|
this.checks = [];
|
2021-04-14 14:57:40 +05:30
|
|
|
for (let i = 1; i < this.ingcon.getChildrenCount(); i++) {
|
2021-04-12 23:39:48 +05:30
|
|
|
this.ingcon.getChildAt(i).getChildAt(0).text = this.icon.uncheck;
|
2021-04-01 16:25:35 +05:30
|
|
|
}
|
|
|
|
},
|
|
|
|
touchInstruction({ object, action }) {
|
|
|
|
let hasDone = object.className.includes("done");
|
|
|
|
object.className = action.match(/down|move/)
|
2021-04-12 23:39:48 +05:30
|
|
|
? `instruction ${hasDone ? "done" : "fade"}`
|
2021-04-01 16:25:35 +05:30
|
|
|
: `instruction ${hasDone ? "done" : ""}`;
|
|
|
|
if (action == "up") this.stepDone(object);
|
2020-11-29 00:51:57 +05:30
|
|
|
},
|
2021-04-12 23:39:48 +05:30
|
|
|
stepDone(object) {
|
|
|
|
let a = object;
|
|
|
|
if (a.className.includes("done")) {
|
|
|
|
a.className = "instruction";
|
|
|
|
this.stepsDid--;
|
|
|
|
} else {
|
|
|
|
a.className = "instruction done";
|
|
|
|
this.stepsDid++;
|
|
|
|
}
|
|
|
|
},
|
2021-01-23 22:50:15 +05:30
|
|
|
clearSteps() {
|
2021-04-12 23:39:48 +05:30
|
|
|
this.stepsDid = 0;
|
2021-04-14 14:57:40 +05:30
|
|
|
for (let i = 1; i < this.inscon.getChildrenCount(); i++) {
|
2021-04-01 16:25:35 +05:30
|
|
|
this.inscon.getChildAt(i).className = "instruction";
|
|
|
|
}
|
2021-01-23 22:50:15 +05:30
|
|
|
},
|
|
|
|
|
|
|
|
// NAVIGATION HANDLERS
|
2020-10-15 01:02:32 +05:30
|
|
|
editRecipe() {
|
2021-02-28 20:40:26 +05:30
|
|
|
this.busy = true;
|
|
|
|
this.$navigateTo(EditRecipe, {
|
2020-10-21 23:24:45 +05:30
|
|
|
props: {
|
2020-11-29 00:51:57 +05:30
|
|
|
navigationFromView: true,
|
|
|
|
filterTrylater: this.filterTrylater,
|
2020-11-15 16:21:10 +05:30
|
|
|
recipeID: this.currentRecipeID,
|
2020-10-21 23:24:45 +05:30
|
|
|
},
|
2021-04-01 16:25:35 +05:30
|
|
|
// backstackVisible: false,
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
|
|
|
},
|
|
|
|
viewCombination(combination) {
|
2021-04-01 16:25:35 +05:30
|
|
|
this.scrollview.scrollToVerticalOffset(0, true);
|
2021-02-28 20:40:26 +05:30
|
|
|
this.recipe = this.recipes.filter((e) => e.id === combination)[0];
|
2021-04-21 16:01:49 +05:30
|
|
|
this.showTitleArr = new Array(4).fill(false);
|
2021-04-01 16:25:35 +05:30
|
|
|
this.clearChecks();
|
2021-04-12 23:39:48 +05:30
|
|
|
this.clearSteps();
|
|
|
|
this.recipe.ingredients.forEach(() => this.checks.push(false));
|
2021-02-28 20:40:26 +05:30
|
|
|
this.currentRecipeID = combination;
|
|
|
|
this.syncCombinations();
|
2021-04-01 16:25:35 +05:30
|
|
|
this.createNotes();
|
2021-04-12 23:39:48 +05:30
|
|
|
this.yieldMultiplier = this.recipe.yield.quantity;
|
2021-04-01 16:25:35 +05:30
|
|
|
this.recipe.tried && this.recipe.lastTried && this.showLastTried();
|
2020-11-15 16:21:10 +05:30
|
|
|
},
|
2021-01-23 22:50:15 +05:30
|
|
|
|
2020-11-10 23:58:48 +05:30
|
|
|
// SHARE ACTION
|
|
|
|
shareHandler() {
|
2021-02-28 20:40:26 +05:30
|
|
|
if (this.recipe.imageSrc) {
|
2021-04-01 16:25:35 +05:30
|
|
|
this.$showModal(ActionDialog, {
|
2020-11-10 23:58:48 +05:30
|
|
|
props: {
|
2021-01-13 10:32:48 +05:30
|
|
|
title: "shr",
|
2021-04-18 18:58:25 +05:30
|
|
|
list: ["rec", "pht"],
|
2020-11-10 23:58:48 +05:30
|
|
|
},
|
2021-02-28 20:40:26 +05:30
|
|
|
}).then((result) => {
|
|
|
|
switch (result) {
|
2021-04-18 18:58:25 +05:30
|
|
|
case "rec":
|
|
|
|
this.shareRecipe();
|
|
|
|
break;
|
2021-04-01 16:25:35 +05:30
|
|
|
case "pht":
|
2021-04-13 00:55:14 +05:30
|
|
|
ImageSource.fromFile(this.recipe.imageSrc).then((res) =>
|
|
|
|
utils.shareImage(res, localize("srpu"))
|
|
|
|
);
|
2021-02-28 20:40:26 +05:30
|
|
|
break;
|
2020-11-10 23:58:48 +05:30
|
|
|
}
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
2020-12-29 16:05:19 +05:30
|
|
|
} else {
|
2021-02-28 20:40:26 +05:30
|
|
|
this.shareRecipe();
|
2020-11-10 23:58:48 +05:30
|
|
|
}
|
|
|
|
},
|
2020-10-30 01:42:53 +05:30
|
|
|
shareRecipe() {
|
2021-04-19 00:04:17 +05:30
|
|
|
let overview = `${this.recipe.title}\n\n`;
|
|
|
|
if (this.recipe.rating)
|
|
|
|
overview += `${localize("stars")}: ${this.recipe.rating}\n`;
|
|
|
|
overview += `${localize("cui")}: ${localize(
|
|
|
|
this.recipe.cuisine
|
|
|
|
)}\n${localize("cat")}: ${localize(this.recipe.category)}\n`;
|
|
|
|
if (this.recipe.tags.length)
|
|
|
|
overview += `${localize("ts")}: ${this.recipe.tags.join(", ")}\n`;
|
|
|
|
if (this.recipe.prepTime != "00:00")
|
|
|
|
overview += `${localize("prepT")}: ${this.formattedTime(
|
|
|
|
this.recipe.prepTime
|
|
|
|
)}\n`;
|
|
|
|
if (this.recipe.cookTime != "00:00")
|
|
|
|
overview += `${localize("cookT")}: ${this.formattedTime(
|
|
|
|
this.recipe.cookTime
|
|
|
|
)}\n`;
|
|
|
|
overview += `${localize("yld")}: ${this.tempYieldQuantity} ${localize(
|
|
|
|
this.recipe.yield.unit
|
|
|
|
)}\n${localize("Difficulty level")}: ${localize(
|
|
|
|
this.recipe.difficulty
|
|
|
|
)}\n`;
|
|
|
|
|
2021-02-28 20:40:26 +05:30
|
|
|
let shareContent = overview;
|
|
|
|
if (this.recipe.ingredients.length) {
|
2021-04-12 23:39:48 +05:30
|
|
|
let ingredients = `\n\n${localize("ings")}:\n\n`;
|
2021-02-28 20:40:26 +05:30
|
|
|
this.recipe.ingredients.forEach((e) => {
|
2020-11-10 23:58:48 +05:30
|
|
|
ingredients += `- ${
|
|
|
|
e.quantity
|
2021-02-28 20:40:26 +05:30
|
|
|
? this.roundedQuantity(e.quantity) +
|
|
|
|
" " +
|
|
|
|
this.$options.filters.L(e.unit) +
|
|
|
|
" "
|
2020-11-10 23:58:48 +05:30
|
|
|
: ""
|
2021-02-28 20:40:26 +05:30
|
|
|
}${e.item}\n`;
|
|
|
|
});
|
|
|
|
shareContent += ingredients;
|
2020-10-30 01:42:53 +05:30
|
|
|
}
|
2021-02-28 20:40:26 +05:30
|
|
|
if (this.recipe.instructions.length) {
|
2021-04-12 23:39:48 +05:30
|
|
|
let instructions = `\n\n${localize("inss")}:\n\n`;
|
2021-02-28 20:40:26 +05:30
|
|
|
this.recipe.instructions.forEach((e, i) => {
|
|
|
|
instructions += `${i + 1}. ${e}\n\n`;
|
|
|
|
});
|
|
|
|
shareContent += instructions;
|
2020-10-30 01:42:53 +05:30
|
|
|
}
|
2021-02-28 20:40:26 +05:30
|
|
|
if (this.recipe.combinations.length) {
|
|
|
|
let combinations = `\n${localize("cmbs")}:\n\n`;
|
|
|
|
this.recipe.combinations.forEach((e, i) => {
|
|
|
|
combinations += `${i + 1}. ${this.getCombinationTitle(e)}\n\n`;
|
|
|
|
});
|
|
|
|
shareContent += combinations;
|
2020-12-29 16:05:19 +05:30
|
|
|
}
|
2021-04-12 23:39:48 +05:30
|
|
|
if (this.recipe.notes.length) {
|
|
|
|
let notes = `\n${localize("nos")}:\n\n`;
|
|
|
|
this.recipe.notes.forEach((e, i) => {
|
|
|
|
notes += `${i + 1}. ${e}\n\n`;
|
|
|
|
});
|
|
|
|
shareContent += notes;
|
|
|
|
}
|
2021-02-28 20:40:26 +05:30
|
|
|
let sharenote = "\n" + localize("appCrd");
|
|
|
|
shareContent += sharenote;
|
2021-04-13 00:55:14 +05:30
|
|
|
utils.shareText(shareContent, localize("sru"));
|
2020-10-30 01:42:53 +05:30
|
|
|
},
|
2021-01-23 22:50:15 +05:30
|
|
|
|
2020-11-10 23:58:48 +05:30
|
|
|
// DATA HANDLERS
|
2021-02-28 20:40:26 +05:30
|
|
|
toggle(key, setDate) {
|
|
|
|
this.toggleStateAction({
|
2020-11-15 16:21:10 +05:30
|
|
|
id: this.currentRecipeID,
|
2020-10-27 02:19:54 +05:30
|
|
|
recipe: this.recipe,
|
|
|
|
key,
|
2020-11-02 17:06:53 +05:30
|
|
|
setDate,
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
2020-10-27 02:19:54 +05:30
|
|
|
},
|
2020-10-30 01:42:53 +05:30
|
|
|
recipeTried() {
|
2021-02-28 20:40:26 +05:30
|
|
|
this.setRecipeAsTriedAction({
|
2020-11-18 02:51:08 +05:30
|
|
|
id: this.currentRecipeID,
|
|
|
|
recipe: this.recipe,
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
|
|
|
this.$navigateBack();
|
2020-10-15 01:02:32 +05:30
|
|
|
},
|
2021-02-28 20:40:26 +05:30
|
|
|
setRating(rating) {
|
|
|
|
if (rating !== this.recipe.rating || rating === 1) {
|
|
|
|
this.setRatingAction({
|
2020-12-29 16:05:19 +05:30
|
|
|
id: this.currentRecipeID,
|
|
|
|
recipe: this.recipe,
|
|
|
|
rating,
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
2020-12-29 16:05:19 +05:30
|
|
|
}
|
|
|
|
},
|
2021-01-23 22:50:15 +05:30
|
|
|
|
2021-01-13 10:32:48 +05:30
|
|
|
// SHOPPINGLIST
|
|
|
|
toggleCart() {
|
2021-02-28 20:40:26 +05:30
|
|
|
if (!this.recipe.inBag) {
|
2021-01-13 10:32:48 +05:30
|
|
|
} else {
|
|
|
|
}
|
2021-02-28 20:40:26 +05:30
|
|
|
this.toggleCartAction({
|
2021-01-13 10:32:48 +05:30
|
|
|
id: this.currentRecipeID,
|
|
|
|
recipe: this.recipe,
|
2021-02-28 20:40:26 +05:30
|
|
|
});
|
2021-01-13 10:32:48 +05:30
|
|
|
},
|
2021-01-23 22:50:15 +05:30
|
|
|
|
2020-12-02 16:07:45 +05:30
|
|
|
// NOTES
|
2021-04-01 16:25:35 +05:30
|
|
|
createNote(note) {
|
2021-02-28 20:40:26 +05:30
|
|
|
let regex = /(https?:\/\/[^\s]+)/g;
|
2021-04-01 16:25:35 +05:30
|
|
|
const lbl = new Label();
|
2021-04-21 16:01:49 +05:30
|
|
|
lbl.className = "note";
|
2021-04-01 16:25:35 +05:30
|
|
|
lbl.textWrap = true;
|
|
|
|
let fString = new FormattedString();
|
|
|
|
let arr = note.split(regex);
|
2020-12-02 15:16:25 +05:30
|
|
|
|
2021-02-28 20:40:26 +05:30
|
|
|
function createSpan(text, isUrl) {
|
|
|
|
let span = new Span();
|
|
|
|
span.text = text;
|
|
|
|
span.fontSize = 14;
|
|
|
|
if (isUrl) {
|
|
|
|
span.textDecoration = "underline";
|
|
|
|
span.on("linkTap", () => Utils.openUrl(text));
|
2020-12-02 15:16:25 +05:30
|
|
|
}
|
2021-04-01 16:25:35 +05:30
|
|
|
fString.spans.push(span);
|
2020-12-02 15:16:25 +05:30
|
|
|
}
|
2021-04-01 16:25:35 +05:30
|
|
|
arr.forEach((text) => {
|
2021-02-28 20:40:26 +05:30
|
|
|
createSpan(text, regex.test(text));
|
|
|
|
});
|
2021-04-01 16:25:35 +05:30
|
|
|
lbl.formattedText = fString;
|
|
|
|
return lbl;
|
|
|
|
},
|
|
|
|
createNotes() {
|
|
|
|
const stack = this.notescon;
|
|
|
|
stack.removeChildren();
|
|
|
|
this.recipe.notes.forEach((note) =>
|
|
|
|
stack.addChild(this.createNote(note))
|
|
|
|
);
|
|
|
|
},
|
|
|
|
getTags(tags) {
|
|
|
|
return tags.join(" · ");
|
|
|
|
},
|
2021-04-12 23:39:48 +05:30
|
|
|
hijackBackEvent() {
|
2021-04-21 16:01:49 +05:30
|
|
|
Application.android.on(
|
2021-04-12 23:39:48 +05:30
|
|
|
AndroidApplication.activityBackPressedEvent,
|
|
|
|
this.backEvent
|
|
|
|
);
|
|
|
|
},
|
|
|
|
releaseBackEvent() {
|
2021-04-21 16:01:49 +05:30
|
|
|
Application.android.off(
|
2021-04-12 23:39:48 +05:30
|
|
|
AndroidApplication.activityBackPressedEvent,
|
|
|
|
this.backEvent
|
|
|
|
);
|
|
|
|
},
|
|
|
|
backEvent(args) {
|
|
|
|
if (this.photoOpen) {
|
|
|
|
args.cancel = true;
|
|
|
|
this.closePhoto();
|
|
|
|
} else this.$navigateBack();
|
|
|
|
},
|
|
|
|
viewPhoto() {
|
2021-04-21 16:01:49 +05:30
|
|
|
// this.imgView.initNativeView();
|
2021-04-12 23:39:48 +05:30
|
|
|
this.photoOpen = true;
|
|
|
|
this.hijackBackEvent();
|
2021-04-21 16:01:49 +05:30
|
|
|
let pv = this.imgView;
|
2021-04-12 23:39:48 +05:30
|
|
|
pv.visibility = "visible";
|
|
|
|
let sw = Screen.mainScreen.widthDIPs;
|
|
|
|
let sh = Screen.mainScreen.heightDIPs;
|
|
|
|
pv.animate({
|
|
|
|
opacity: 1,
|
|
|
|
duration: 50,
|
|
|
|
})
|
|
|
|
.then(() =>
|
|
|
|
pv.animate({
|
|
|
|
width: sw,
|
|
|
|
height: sw,
|
|
|
|
translate: { x: 112 - sw, y: (sh - sw) / 3 },
|
|
|
|
duration: 250,
|
|
|
|
curve: CoreTypes.AnimationCurve.ease,
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.then(() =>
|
|
|
|
pv.animate({
|
2021-04-21 16:01:49 +05:30
|
|
|
height: sh,
|
2021-04-12 23:39:48 +05:30
|
|
|
translate: { x: -sw + 112, y: -((sh - sw) / 6) },
|
|
|
|
duration: 250,
|
|
|
|
curve: CoreTypes.AnimationCurve.ease,
|
|
|
|
})
|
2021-04-01 16:25:35 +05:30
|
|
|
);
|
|
|
|
},
|
2021-04-12 23:39:48 +05:30
|
|
|
closePhoto() {
|
2021-04-21 16:01:49 +05:30
|
|
|
let pv = this.imgView;
|
2021-04-12 23:39:48 +05:30
|
|
|
let sw = Screen.mainScreen.widthDIPs;
|
|
|
|
let sh = Screen.mainScreen.heightDIPs;
|
|
|
|
pv.animate({
|
|
|
|
width: sw,
|
|
|
|
height: sw,
|
|
|
|
translate: { x: 112 - sw, y: (sh - sw) / 3 },
|
|
|
|
duration: 250,
|
|
|
|
curve: CoreTypes.AnimationCurve.ease,
|
|
|
|
})
|
|
|
|
.then(() =>
|
|
|
|
pv.animate({
|
|
|
|
width: 96,
|
|
|
|
height: 96,
|
|
|
|
translate: { x: 0, y: 0 },
|
|
|
|
duration: 250,
|
|
|
|
curve: CoreTypes.AnimationCurve.ease,
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.then(() =>
|
|
|
|
pv.animate({
|
|
|
|
opacity: 0,
|
|
|
|
duration: 50,
|
|
|
|
})
|
|
|
|
)
|
|
|
|
.then(() => {
|
|
|
|
pv.visibility = "collapsed";
|
|
|
|
this.photoOpen = false;
|
|
|
|
this.releaseBackEvent();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
navigateBack() {
|
|
|
|
this.photoOpen ? this.closePhoto() : this.$navigateBack();
|
|
|
|
},
|
|
|
|
|
|
|
|
//HELPERS
|
2021-04-01 16:25:35 +05:30
|
|
|
touchYield({ object, action }) {
|
|
|
|
object.className = action.match(/down|move/)
|
|
|
|
? "value clickable fade"
|
|
|
|
: "value clickable";
|
|
|
|
if (action == "up") this.changeYield();
|
2020-10-30 01:42:53 +05:30
|
|
|
},
|
2020-10-24 23:32:35 +05:30
|
|
|
},
|
|
|
|
created() {
|
2021-02-28 20:40:26 +05:30
|
|
|
this.recipe = this.recipes.filter((e) => e.id === this.currentRecipeID)[0];
|
|
|
|
this.recipe.ingredients.forEach((e) => this.checks.push(false));
|
2020-10-15 01:02:32 +05:30
|
|
|
},
|
2020-10-30 01:42:53 +05:30
|
|
|
mounted() {
|
2021-02-28 20:40:26 +05:30
|
|
|
this.yieldMultiplier = this.recipe.yield.quantity;
|
2021-04-01 16:25:35 +05:30
|
|
|
this.recipe.tried && this.recipe.lastTried && this.showLastTried();
|
2020-10-30 01:42:53 +05:30
|
|
|
},
|
2021-02-28 20:40:26 +05:30
|
|
|
};
|
2020-10-15 01:02:32 +05:30
|
|
|
</script>
|