ng-miam 3.3.2 → 3.4.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/ng-miam.umd.js +1844 -1111
- package/bundles/ng-miam.umd.js.map +1 -1
- package/bundles/ng-miam.umd.min.js +2 -2
- package/bundles/ng-miam.umd.min.js.map +1 -1
- package/esm2015/lib/_components/abstracts/abstract-recipe-card.component.js +1 -1
- package/esm2015/lib/_components/icon/icon.component.js +23 -6
- package/esm2015/lib/_components/recipe-filters/recipe-filters.component.js +94 -40
- package/esm2015/lib/_components/text-input/text-input.component.js +6 -4
- package/esm2015/lib/_models/article.js +43 -0
- package/esm2015/lib/_models/basket.js +2 -2
- package/esm2015/lib/_models/index.js +4 -1
- package/esm2015/lib/_models/ingredient.js +11 -7
- package/esm2015/lib/_models/package.js +14 -3
- package/esm2015/lib/_models/recipe.js +6 -2
- package/esm2015/lib/_models/user.js +10 -1
- package/esm2015/lib/_services/analytics.service.js +3 -3
- package/esm2015/lib/_services/articles.service.js +21 -0
- package/esm2015/lib/_services/baskets.service.js +2 -2
- package/esm2015/lib/_services/context.service.js +19 -1
- package/esm2015/lib/_services/groceries-lists.service.js +2 -2
- package/esm2015/lib/_services/index.js +3 -1
- package/esm2015/lib/_services/ingredients.service.js +2 -2
- package/esm2015/lib/_services/interceptor.service.js +2 -3
- package/esm2015/lib/_services/package.service.js +32 -9
- package/esm2015/lib/_services/recipe-events.service.js +2 -2
- package/esm2015/lib/_services/recipe-likes.service.js +6 -2
- package/esm2015/lib/_services/recipe-share.service.js +2 -2
- package/esm2015/lib/_services/recipes.service.js +2 -2
- package/esm2015/lib/_services/suppliers.service.js +2 -2
- package/esm2015/lib/_services/toastr.service.js +52 -0
- package/esm2015/lib/_services/user.service.js +64 -21
- package/esm2015/lib/_types/icon.enum.js +2 -1
- package/esm2015/lib/_web-components/catalog-article-card/catalog-article-card.component.js +71 -0
- package/esm2015/lib/_web-components/catalog-category/catalog-category.component.js +134 -92
- package/esm2015/lib/_web-components/catalog-header/catalog-header.component.js +51 -34
- package/esm2015/lib/_web-components/catalog-list/catalog-list.component.js +106 -61
- package/esm2015/lib/_web-components/catalog-recipe-card/catalog-recipe-card.component.js +65 -52
- package/esm2015/lib/_web-components/favorite-page/favorite-page.component.js +8 -6
- package/esm2015/lib/_web-components/index.js +2 -1
- package/esm2015/lib/_web-components/personal-recipes/personal-recipes.component.js +7 -5
- package/esm2015/lib/_web-components/recipe-card/recipe-card.component.js +73 -58
- package/esm2015/lib/_web-components/recipe-catalog/recipe-catalog.component.js +152 -92
- package/esm2015/lib/_web-components/recipe-details/recipe-details.component.js +355 -278
- package/esm2015/lib/_web-components/suggestion-card/suggestion-card.component.js +3 -6
- package/esm2015/lib/_web-components/web-components.module.js +17 -9
- package/esm2015/lib/environments/environment.js +6 -0
- package/esm2015/lib/ng-miam.module.js +4 -4
- package/fesm2015/ng-miam.js +1755 -1140
- package/fesm2015/ng-miam.js.map +1 -1
- package/lib/_components/abstracts/abstract-recipe-card.component.d.ts +1 -1
- package/lib/_components/recipe-filters/recipe-filters.component.d.ts +14 -4
- package/lib/_components/text-input/text-input.component.d.ts +2 -1
- package/lib/_models/article.d.ts +23 -0
- package/lib/_models/basket.d.ts +1 -2
- package/lib/_models/index.d.ts +3 -0
- package/lib/_models/ingredient.d.ts +2 -0
- package/lib/_models/package.d.ts +10 -3
- package/lib/_models/recipe.d.ts +2 -0
- package/lib/_models/user.d.ts +16 -1
- package/lib/_services/articles.service.d.ts +10 -0
- package/lib/_services/context.service.d.ts +14 -6
- package/lib/_services/index.d.ts +2 -0
- package/lib/_services/package.service.d.ts +6 -1
- package/lib/_services/toastr.service.d.ts +10 -0
- package/lib/_services/user.service.d.ts +12 -6
- package/lib/_types/icon.enum.d.ts +2 -1
- package/lib/_web-components/catalog-article-card/catalog-article-card.component.d.ts +8 -0
- package/lib/_web-components/catalog-category/catalog-category.component.d.ts +12 -7
- package/lib/_web-components/catalog-header/catalog-header.component.d.ts +5 -2
- package/lib/_web-components/catalog-list/catalog-list.component.d.ts +13 -6
- package/lib/_web-components/catalog-recipe-card/catalog-recipe-card.component.d.ts +1 -0
- package/lib/_web-components/favorite-page/favorite-page.component.d.ts +0 -1
- package/lib/_web-components/index.d.ts +1 -0
- package/lib/_web-components/personal-recipes/personal-recipes.component.d.ts +0 -1
- package/lib/_web-components/recipe-card/recipe-card.component.d.ts +1 -0
- package/lib/_web-components/recipe-catalog/recipe-catalog.component.d.ts +13 -4
- package/lib/_web-components/recipe-details/recipe-details.component.d.ts +19 -6
- package/lib/_web-components/suggestion-card/suggestion-card.component.d.ts +0 -1
- package/lib/_web-components/web-components.module.d.ts +13 -11
- package/lib/environments/environment.d.ts +5 -0
- package/miam-style.css +1 -1
- package/package.json +1 -1
- package/esm2015/lib/environment.js +0 -18
- package/lib/environment.d.ts +0 -5
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild, ChangeDetectorRef, ElementRef, ViewChildren, QueryList } from '@angular/core';
|
|
2
|
-
import { skipWhile, take } from 'rxjs/operators';
|
|
2
|
+
import { skipWhile, switchMap, take, tap } from 'rxjs/operators';
|
|
3
3
|
import { CatalogCategoryComponent } from '../catalog-category/catalog-category.component';
|
|
4
|
-
import { RecipeTypeService, SponsorService, PackageService, SuppliersService, RecipesService } from '../../_services';
|
|
4
|
+
import { RecipeTypeService, SponsorService, PackageService, SuppliersService, RecipesService, UserService } from '../../_services';
|
|
5
5
|
import { Icon } from '../../_types/icon.enum';
|
|
6
6
|
import { CatalogHeaderComponent } from '../catalog-header/catalog-header.component';
|
|
7
|
-
import { forkJoin } from 'rxjs';
|
|
7
|
+
import { combineLatest, forkJoin } from 'rxjs';
|
|
8
8
|
import { MediaMatcher } from '@angular/cdk/layout';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "../../_services";
|
|
@@ -18,94 +18,115 @@ import * as i8 from "../../_components/icon/icon.component";
|
|
|
18
18
|
import * as i9 from "../recipe-stepper/recipe-stepper.component";
|
|
19
19
|
const _c0 = ["miamCatalogTopAnchor"];
|
|
20
20
|
function RecipeCatalogComponent_div_2_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
21
|
-
const
|
|
22
|
-
i0.ɵɵelementStart(0, "div",
|
|
23
|
-
i0.ɵɵelementStart(1, "
|
|
24
|
-
i0.ɵɵ
|
|
21
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
|
22
|
+
i0.ɵɵelementStart(0, "div", 12);
|
|
23
|
+
i0.ɵɵelementStart(1, "span");
|
|
24
|
+
i0.ɵɵtext(2, "Une petite question : Avez-vous des enfants ?");
|
|
25
|
+
i0.ɵɵelementEnd();
|
|
26
|
+
i0.ɵɵelementStart(3, "div", 13);
|
|
27
|
+
i0.ɵɵelementStart(4, "button", 14);
|
|
28
|
+
i0.ɵɵlistener("click", function RecipeCatalogComponent_div_2_div_4_Template_button_click_4_listener() { i0.ɵɵrestoreView(_r10); const ctx_r9 = i0.ɵɵnextContext(2); return ctx_r9.setUserPreference("has_children", true); });
|
|
29
|
+
i0.ɵɵtext(5, "Oui");
|
|
30
|
+
i0.ɵɵelementEnd();
|
|
31
|
+
i0.ɵɵelementStart(6, "button", 14);
|
|
32
|
+
i0.ɵɵlistener("click", function RecipeCatalogComponent_div_2_div_4_Template_button_click_6_listener() { i0.ɵɵrestoreView(_r10); const ctx_r11 = i0.ɵɵnextContext(2); return ctx_r11.setUserPreference("has_children", false); });
|
|
33
|
+
i0.ɵɵtext(7, "Non");
|
|
34
|
+
i0.ɵɵelementEnd();
|
|
35
|
+
i0.ɵɵelementEnd();
|
|
36
|
+
i0.ɵɵelementEnd();
|
|
37
|
+
} }
|
|
38
|
+
function RecipeCatalogComponent_div_2_div_5_Template(rf, ctx) { if (rf & 1) {
|
|
39
|
+
const _r13 = i0.ɵɵgetCurrentView();
|
|
40
|
+
i0.ɵɵelementStart(0, "div", 15);
|
|
41
|
+
i0.ɵɵelementStart(1, "ng-miam-catalog-list", 16);
|
|
42
|
+
i0.ɵɵlistener("retrievedRecipes", function RecipeCatalogComponent_div_2_div_5_Template_ng_miam_catalog_list_retrievedRecipes_1_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r12 = i0.ɵɵnextContext(2); return ctx_r12.changeHeaderImage($event); })("filterRemoved", function RecipeCatalogComponent_div_2_div_5_Template_ng_miam_catalog_list_filterRemoved_1_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r14 = i0.ɵɵnextContext(2); return ctx_r14.removeFilter($event); })("recipeActionTriggered", function RecipeCatalogComponent_div_2_div_5_Template_ng_miam_catalog_list_recipeActionTriggered_1_listener($event) { i0.ɵɵrestoreView(_r13); const ctx_r15 = i0.ɵɵnextContext(2); return ctx_r15.manageRecipeAction($event); });
|
|
25
43
|
i0.ɵɵelementEnd();
|
|
26
44
|
i0.ɵɵelementEnd();
|
|
27
45
|
} if (rf & 2) {
|
|
28
|
-
const
|
|
46
|
+
const ctx_r5 = i0.ɵɵnextContext(2);
|
|
29
47
|
i0.ɵɵadvance(1);
|
|
30
|
-
i0.ɵɵproperty("filters",
|
|
48
|
+
i0.ɵɵproperty("filters", ctx_r5.filters)("randomMode", true);
|
|
31
49
|
} }
|
|
32
|
-
function
|
|
33
|
-
const
|
|
34
|
-
i0.ɵɵelementStart(0, "ng-miam-catalog-category",
|
|
35
|
-
i0.ɵɵlistener("displayList", function
|
|
50
|
+
function RecipeCatalogComponent_div_2_ng_template_6_div_0_ng_miam_catalog_category_1_Template(rf, ctx) { if (rf & 1) {
|
|
51
|
+
const _r20 = i0.ɵɵgetCurrentView();
|
|
52
|
+
i0.ɵɵelementStart(0, "ng-miam-catalog-category", 20);
|
|
53
|
+
i0.ɵɵlistener("displayList", function RecipeCatalogComponent_div_2_ng_template_6_div_0_ng_miam_catalog_category_1_Template_ng_miam_catalog_category_displayList_0_listener($event) { i0.ɵɵrestoreView(_r20); const ctx_r19 = i0.ɵɵnextContext(4); return ctx_r19.categoryTitleClicked($event); });
|
|
36
54
|
i0.ɵɵelementEnd();
|
|
37
55
|
} if (rf & 2) {
|
|
38
|
-
const
|
|
39
|
-
i0.ɵɵproperty("title",
|
|
56
|
+
const category_r18 = ctx.$implicit;
|
|
57
|
+
i0.ɵɵproperty("title", category_r18.title)("filters", category_r18.filters);
|
|
40
58
|
} }
|
|
41
|
-
function
|
|
42
|
-
i0.ɵɵelementStart(0, "div",
|
|
43
|
-
i0.ɵɵtemplate(1,
|
|
59
|
+
function RecipeCatalogComponent_div_2_ng_template_6_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
60
|
+
i0.ɵɵelementStart(0, "div", 18);
|
|
61
|
+
i0.ɵɵtemplate(1, RecipeCatalogComponent_div_2_ng_template_6_div_0_ng_miam_catalog_category_1_Template, 1, 2, "ng-miam-catalog-category", 19);
|
|
44
62
|
i0.ɵɵelementEnd();
|
|
45
63
|
} if (rf & 2) {
|
|
46
|
-
const
|
|
64
|
+
const ctx_r16 = i0.ɵɵnextContext(3);
|
|
47
65
|
i0.ɵɵadvance(1);
|
|
48
|
-
i0.ɵɵproperty("ngForOf",
|
|
66
|
+
i0.ɵɵproperty("ngForOf", ctx_r16.categories);
|
|
49
67
|
} }
|
|
50
|
-
function
|
|
51
|
-
i0.ɵɵtemplate(0,
|
|
68
|
+
function RecipeCatalogComponent_div_2_ng_template_6_Template(rf, ctx) { if (rf & 1) {
|
|
69
|
+
i0.ɵɵtemplate(0, RecipeCatalogComponent_div_2_ng_template_6_div_0_Template, 2, 1, "div", 17);
|
|
52
70
|
} if (rf & 2) {
|
|
53
|
-
const
|
|
54
|
-
i0.ɵɵproperty("ngIf",
|
|
71
|
+
const ctx_r7 = i0.ɵɵnextContext(2);
|
|
72
|
+
i0.ɵɵproperty("ngIf", ctx_r7.categories.length > 0);
|
|
55
73
|
} }
|
|
56
|
-
function
|
|
57
|
-
const
|
|
58
|
-
i0.ɵɵelementStart(0, "div",
|
|
59
|
-
i0.ɵɵlistener("click", function
|
|
60
|
-
i0.ɵɵelement(1, "ng-miam-icon",
|
|
74
|
+
function RecipeCatalogComponent_div_2_div_8_Template(rf, ctx) { if (rf & 1) {
|
|
75
|
+
const _r22 = i0.ɵɵgetCurrentView();
|
|
76
|
+
i0.ɵɵelementStart(0, "div", 21);
|
|
77
|
+
i0.ɵɵlistener("click", function RecipeCatalogComponent_div_2_div_8_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r22); const ctx_r21 = i0.ɵɵnextContext(2); return ctx_r21.returnToTop(); });
|
|
78
|
+
i0.ɵɵelement(1, "ng-miam-icon", 22);
|
|
61
79
|
i0.ɵɵelementEnd();
|
|
62
80
|
} if (rf & 2) {
|
|
63
|
-
const
|
|
81
|
+
const ctx_r8 = i0.ɵɵnextContext(2);
|
|
64
82
|
i0.ɵɵadvance(1);
|
|
65
|
-
i0.ɵɵproperty("iconName",
|
|
83
|
+
i0.ɵɵproperty("iconName", ctx_r8.icon.ChevronDown);
|
|
66
84
|
} }
|
|
67
85
|
const _c1 = function (a0) { return { "filter-collapsed": a0 }; };
|
|
68
86
|
function RecipeCatalogComponent_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
69
|
-
const
|
|
87
|
+
const _r24 = i0.ɵɵgetCurrentView();
|
|
70
88
|
i0.ɵɵelementStart(0, "div", 4);
|
|
71
|
-
i0.ɵɵlistener("scroll", function RecipeCatalogComponent_div_2_Template_div_scroll_0_listener() { i0.ɵɵrestoreView(
|
|
89
|
+
i0.ɵɵlistener("scroll", function RecipeCatalogComponent_div_2_Template_div_scroll_0_listener() { i0.ɵɵrestoreView(_r24); const ctx_r23 = i0.ɵɵnextContext(); return ctx_r23.displayReturnTopButton(); }, false, i0.ɵɵresolveWindow);
|
|
72
90
|
i0.ɵɵelementStart(1, "ng-miam-recipe-filters", 5);
|
|
73
|
-
i0.ɵɵlistener("filterReset", function RecipeCatalogComponent_div_2_Template_ng_miam_recipe_filters_filterReset_1_listener() { i0.ɵɵrestoreView(
|
|
91
|
+
i0.ɵɵlistener("filterReset", function RecipeCatalogComponent_div_2_Template_ng_miam_recipe_filters_filterReset_1_listener() { i0.ɵɵrestoreView(_r24); const ctx_r25 = i0.ɵɵnextContext(); return ctx_r25.resetFilters(); })("filterChanged", function RecipeCatalogComponent_div_2_Template_ng_miam_recipe_filters_filterChanged_1_listener($event) { i0.ɵɵrestoreView(_r24); const ctx_r26 = i0.ɵɵnextContext(); return ctx_r26.updateFilters($event); })("filterCollapsed", function RecipeCatalogComponent_div_2_Template_ng_miam_recipe_filters_filterCollapsed_1_listener() { i0.ɵɵrestoreView(_r24); const ctx_r27 = i0.ɵɵnextContext(); return ctx_r27.onFilterCollapsed(); })("preferencesChanged", function RecipeCatalogComponent_div_2_Template_ng_miam_recipe_filters_preferencesChanged_1_listener() { i0.ɵɵrestoreView(_r24); const ctx_r28 = i0.ɵɵnextContext(); return ctx_r28.reloadPackages(); });
|
|
74
92
|
i0.ɵɵelementEnd();
|
|
75
93
|
i0.ɵɵelementStart(2, "div", 6);
|
|
76
94
|
i0.ɵɵelementStart(3, "ng-miam-catalog-header", 7);
|
|
77
|
-
i0.ɵɵlistener("returnButtonPressed", function RecipeCatalogComponent_div_2_Template_ng_miam_catalog_header_returnButtonPressed_3_listener() { i0.ɵɵrestoreView(
|
|
95
|
+
i0.ɵɵlistener("returnButtonPressed", function RecipeCatalogComponent_div_2_Template_ng_miam_catalog_header_returnButtonPressed_3_listener() { i0.ɵɵrestoreView(_r24); const ctx_r29 = i0.ɵɵnextContext(); return ctx_r29.returnToHomePage(); })("searchStringChanged", function RecipeCatalogComponent_div_2_Template_ng_miam_catalog_header_searchStringChanged_3_listener($event) { i0.ɵɵrestoreView(_r24); const ctx_r30 = i0.ɵɵnextContext(); return ctx_r30.updateSearch($event); });
|
|
78
96
|
i0.ɵɵelementEnd();
|
|
79
|
-
i0.ɵɵtemplate(4, RecipeCatalogComponent_div_2_div_4_Template,
|
|
80
|
-
i0.ɵɵtemplate(5,
|
|
81
|
-
i0.ɵɵtemplate(
|
|
97
|
+
i0.ɵɵtemplate(4, RecipeCatalogComponent_div_2_div_4_Template, 8, 0, "div", 8);
|
|
98
|
+
i0.ɵɵtemplate(5, RecipeCatalogComponent_div_2_div_5_Template, 2, 2, "div", 9);
|
|
99
|
+
i0.ɵɵtemplate(6, RecipeCatalogComponent_div_2_ng_template_6_Template, 1, 1, "ng-template", null, 10, i0.ɵɵtemplateRefExtractor);
|
|
100
|
+
i0.ɵɵtemplate(8, RecipeCatalogComponent_div_2_div_8_Template, 2, 1, "div", 11);
|
|
82
101
|
i0.ɵɵelementEnd();
|
|
83
102
|
i0.ɵɵelementEnd();
|
|
84
103
|
} if (rf & 2) {
|
|
85
|
-
const
|
|
104
|
+
const _r6 = i0.ɵɵreference(7);
|
|
86
105
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
87
106
|
i0.ɵɵadvance(1);
|
|
88
107
|
i0.ɵɵproperty("filters", ctx_r1.filters)("mobileFixed", ctx_r1.returnTopButtonShouldBeDisplayed)("filterToRemove", ctx_r1.filterToRemove);
|
|
89
108
|
i0.ɵɵadvance(1);
|
|
90
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(
|
|
109
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(11, _c1, ctx_r1.isFilterCollapsed));
|
|
91
110
|
i0.ɵɵadvance(1);
|
|
92
111
|
i0.ɵɵproperty("displayReturnButton", !ctx_r1.displayHomePage)("forcedRecipe", ctx_r1.recipeInHeader)("title", ctx_r1.displayHomePage ? ctx_r1.homePageTitle : ctx_r1.filters.additionalFilters && ctx_r1.filters.additionalFilters.title !== "" ? ctx_r1.filters.additionalFilters.title : ctx_r1.titleInResearchMode);
|
|
93
112
|
i0.ɵɵadvance(1);
|
|
94
|
-
i0.ɵɵproperty("ngIf",
|
|
113
|
+
i0.ɵɵproperty("ngIf", ctx_r1.showUserFeedback);
|
|
114
|
+
i0.ɵɵadvance(1);
|
|
115
|
+
i0.ɵɵproperty("ngIf", !ctx_r1.displayHomePage)("ngIfElse", _r6);
|
|
95
116
|
i0.ɵɵadvance(3);
|
|
96
117
|
i0.ɵɵproperty("ngIf", ctx_r1.returnTopButtonShouldBeDisplayed);
|
|
97
118
|
} }
|
|
98
119
|
function RecipeCatalogComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
|
|
99
|
-
const
|
|
100
|
-
i0.ɵɵelementStart(0, "ng-miam-recipe-stepper",
|
|
101
|
-
i0.ɵɵlistener("recipeChange", function RecipeCatalogComponent_ng_template_3_Template_ng_miam_recipe_stepper_recipeChange_0_listener() { i0.ɵɵrestoreView(
|
|
120
|
+
const _r32 = i0.ɵɵgetCurrentView();
|
|
121
|
+
i0.ɵɵelementStart(0, "ng-miam-recipe-stepper", 23);
|
|
122
|
+
i0.ɵɵlistener("recipeChange", function RecipeCatalogComponent_ng_template_3_Template_ng_miam_recipe_stepper_recipeChange_0_listener() { i0.ɵɵrestoreView(_r32); const ctx_r31 = i0.ɵɵnextContext(); return ctx_r31.leaveCreatePage(); })("canceled", function RecipeCatalogComponent_ng_template_3_Template_ng_miam_recipe_stepper_canceled_0_listener() { i0.ɵɵrestoreView(_r32); const ctx_r33 = i0.ɵɵnextContext(); return ctx_r33.leaveCreatePage(); });
|
|
102
123
|
i0.ɵɵelementEnd();
|
|
103
124
|
} if (rf & 2) {
|
|
104
125
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
105
126
|
i0.ɵɵproperty("recipe", ctx_r3.recipeToUpdate);
|
|
106
127
|
} }
|
|
107
128
|
export class RecipeCatalogComponent {
|
|
108
|
-
constructor(cdr, recipeTypesService, sponsorService, supplierService, packageService, recipesService, mediaMatcher) {
|
|
129
|
+
constructor(cdr, recipeTypesService, sponsorService, supplierService, packageService, recipesService, mediaMatcher, usersService) {
|
|
109
130
|
this.cdr = cdr;
|
|
110
131
|
this.recipeTypesService = recipeTypesService;
|
|
111
132
|
this.sponsorService = sponsorService;
|
|
@@ -113,6 +134,7 @@ export class RecipeCatalogComponent {
|
|
|
113
134
|
this.packageService = packageService;
|
|
114
135
|
this.recipesService = recipesService;
|
|
115
136
|
this.mediaMatcher = mediaMatcher;
|
|
137
|
+
this.usersService = usersService;
|
|
116
138
|
this.homePageTitle = 'Qu\'est-ce qui vous ferait plaisir ?';
|
|
117
139
|
this.titleInResearchMode = 'Résultats de recherche';
|
|
118
140
|
this.displayHomePage = true;
|
|
@@ -123,35 +145,39 @@ export class RecipeCatalogComponent {
|
|
|
123
145
|
this.creatingRecipe = false;
|
|
124
146
|
this.isMobile = false;
|
|
125
147
|
this.listIsEmpty = false;
|
|
148
|
+
this.showUserFeedback = false;
|
|
149
|
+
this.subscriptions = [];
|
|
126
150
|
this.isMobile = mediaMatcher.matchMedia('(max-width: 1022px)').matches;
|
|
127
151
|
this.isFilterCollapsed = this.isMobile;
|
|
128
152
|
}
|
|
129
153
|
ngOnInit() {
|
|
130
154
|
this.resetFilters();
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
this.
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
});
|
|
155
|
+
this.subscriptions = [
|
|
156
|
+
forkJoin([
|
|
157
|
+
this.recipeTypesService.getTypes().pipe(skipWhile(types => types.length === 0),
|
|
158
|
+
// recipeTypesService.getTypes() comes from a behavior subject, it does not emit the complete() function
|
|
159
|
+
// you absolutly need a take(1) or call complete yourself to trigger the forkjoin subscribe
|
|
160
|
+
take(1)),
|
|
161
|
+
this.supplierService.supplier$.asObservable().pipe(skipWhile(supp => supp === undefined || supp == null), take(1))
|
|
162
|
+
]).pipe(switchMap(res => {
|
|
163
|
+
this.supplierId = res[1].id;
|
|
164
|
+
return this.loadPackages();
|
|
165
|
+
})).subscribe(),
|
|
166
|
+
this.assessShowUserFeedback()
|
|
167
|
+
];
|
|
145
168
|
}
|
|
146
169
|
ngAfterViewInit() {
|
|
147
170
|
this.cdr.detectChanges();
|
|
148
171
|
}
|
|
172
|
+
ngOnDestroy() {
|
|
173
|
+
this.subscriptions.forEach(s => s.unsubscribe());
|
|
174
|
+
}
|
|
149
175
|
initCategories(packages) {
|
|
150
|
-
this.categories
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
176
|
+
this.categories = [{
|
|
177
|
+
key: 'suggestions',
|
|
178
|
+
title: 'Suggestions de la semaine',
|
|
179
|
+
filters: { suggested: true }
|
|
180
|
+
}];
|
|
155
181
|
packages.data.forEach(categoryPackage => {
|
|
156
182
|
this.categories.push({
|
|
157
183
|
key: categoryPackage.title,
|
|
@@ -159,34 +185,43 @@ export class RecipeCatalogComponent {
|
|
|
159
185
|
filters: { packages: categoryPackage.id }
|
|
160
186
|
});
|
|
161
187
|
});
|
|
162
|
-
this.
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
188
|
+
const startersType = this.recipeTypesService.getTypeByName('entrée');
|
|
189
|
+
if (startersType) {
|
|
190
|
+
this.categories.push({
|
|
191
|
+
key: 'entrees',
|
|
192
|
+
title: 'Entrées',
|
|
193
|
+
filters: { recipe_type_id: startersType.id }
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
const mainType = this.recipeTypesService.getTypeByName('plat principal');
|
|
197
|
+
if (mainType) {
|
|
198
|
+
this.categories.push({
|
|
199
|
+
key: 'plats',
|
|
200
|
+
title: 'Plats',
|
|
201
|
+
filters: { recipe_type_id: mainType.id }
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
const dessertType = this.recipeTypesService.getTypeByName('dessert');
|
|
205
|
+
if (dessertType) {
|
|
206
|
+
this.categories.push({
|
|
207
|
+
key: 'desserts',
|
|
208
|
+
title: 'Desserts',
|
|
209
|
+
filters: { recipe_type_id: dessertType.id }
|
|
210
|
+
});
|
|
211
|
+
}
|
|
177
212
|
}
|
|
178
213
|
selectCategoryFromUrl() {
|
|
179
214
|
const paramsString = window.location.search;
|
|
180
215
|
const paramsArray = new URLSearchParams(paramsString);
|
|
181
|
-
const
|
|
182
|
-
if (!
|
|
216
|
+
const selectedCategoryKey = paramsArray.get('catalogCategory');
|
|
217
|
+
if (!selectedCategoryKey) {
|
|
183
218
|
return;
|
|
184
219
|
}
|
|
185
|
-
const
|
|
186
|
-
if (!
|
|
220
|
+
const selectedCategory = this.categories.find((cat) => cat.key === selectedCategoryKey);
|
|
221
|
+
if (!selectedCategory) {
|
|
187
222
|
return;
|
|
188
223
|
}
|
|
189
|
-
this.categoryTitleClicked(
|
|
224
|
+
this.categoryTitleClicked(selectedCategory);
|
|
190
225
|
}
|
|
191
226
|
// Used on load to build the filters attribute, and on click on the link to reset the filters
|
|
192
227
|
resetFilters() {
|
|
@@ -325,9 +360,9 @@ export class RecipeCatalogComponent {
|
|
|
325
360
|
}
|
|
326
361
|
case 'DELETE': {
|
|
327
362
|
if (((_a = event.recipe) === null || _a === void 0 ? void 0 : _a.id) && ((_b = event.recipe.relationships['recipe-provider']) === null || _b === void 0 ? void 0 : _b.data.id) === 'personal') {
|
|
328
|
-
this.recipesService.delete(event.recipe.id).subscribe(() => {
|
|
363
|
+
this.subscriptions.push(this.recipesService.delete(event.recipe.id).subscribe(() => {
|
|
329
364
|
this.reloadList();
|
|
330
|
-
});
|
|
365
|
+
}));
|
|
331
366
|
}
|
|
332
367
|
break;
|
|
333
368
|
}
|
|
@@ -337,8 +372,33 @@ export class RecipeCatalogComponent {
|
|
|
337
372
|
this.listIsEmpty = recipes.length === 0;
|
|
338
373
|
this.cdr.detectChanges();
|
|
339
374
|
}
|
|
375
|
+
setUserPreference(pref, state) {
|
|
376
|
+
this.subscriptions.push(this.usersService.setPreference(pref, state).pipe(switchMap(() => this.loadPackages())).subscribe());
|
|
377
|
+
}
|
|
378
|
+
reloadPackages() {
|
|
379
|
+
this.subscriptions.push(this.loadPackages().subscribe());
|
|
380
|
+
}
|
|
381
|
+
loadPackages() {
|
|
382
|
+
return this.packageService.categories_for([this.supplierId]).pipe(skipWhile(packages => packages.is_loading), tap((packages) => {
|
|
383
|
+
this.initCategories(packages);
|
|
384
|
+
this.selectCategoryFromUrl();
|
|
385
|
+
this.cdr.detectChanges();
|
|
386
|
+
}));
|
|
387
|
+
}
|
|
388
|
+
// Show feedback block only if user is logged and the children preference is unknown
|
|
389
|
+
assessShowUserFeedback() {
|
|
390
|
+
return combineLatest([
|
|
391
|
+
this.usersService.isLogged$,
|
|
392
|
+
this.usersService.preferenceDefined('has_children')
|
|
393
|
+
]).subscribe(results => {
|
|
394
|
+
const logged = results[0];
|
|
395
|
+
const preferenceDefined = results[1];
|
|
396
|
+
this.showUserFeedback = logged && !preferenceDefined;
|
|
397
|
+
this.cdr.detectChanges();
|
|
398
|
+
});
|
|
399
|
+
}
|
|
340
400
|
}
|
|
341
|
-
RecipeCatalogComponent.ɵfac = function RecipeCatalogComponent_Factory(t) { return new (t || RecipeCatalogComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.RecipeTypeService), i0.ɵɵdirectiveInject(i1.SponsorService), i0.ɵɵdirectiveInject(i1.SuppliersService), i0.ɵɵdirectiveInject(i1.PackageService), i0.ɵɵdirectiveInject(i1.RecipesService), i0.ɵɵdirectiveInject(i2.MediaMatcher)); };
|
|
401
|
+
RecipeCatalogComponent.ɵfac = function RecipeCatalogComponent_Factory(t) { return new (t || RecipeCatalogComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.RecipeTypeService), i0.ɵɵdirectiveInject(i1.SponsorService), i0.ɵɵdirectiveInject(i1.SuppliersService), i0.ɵɵdirectiveInject(i1.PackageService), i0.ɵɵdirectiveInject(i1.RecipesService), i0.ɵɵdirectiveInject(i2.MediaMatcher), i0.ɵɵdirectiveInject(i1.UserService)); };
|
|
342
402
|
RecipeCatalogComponent.ɵcmp = i0.ɵɵdefineComponent({ type: RecipeCatalogComponent, selectors: [["ng-miam-recipe-catalog"]], viewQuery: function RecipeCatalogComponent_Query(rf, ctx) { if (rf & 1) {
|
|
343
403
|
i0.ɵɵviewQuery(CatalogHeaderComponent, true);
|
|
344
404
|
i0.ɵɵviewQuery(_c0, true);
|
|
@@ -348,15 +408,15 @@ RecipeCatalogComponent.ɵcmp = i0.ɵɵdefineComponent({ type: RecipeCatalogCompo
|
|
|
348
408
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.catalogHeader = _t.first);
|
|
349
409
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.topAnchor = _t.first);
|
|
350
410
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.categoriesComp = _t);
|
|
351
|
-
} }, decls: 5, vars: 2, consts: [[1, "miam-catalog-anchor"], ["miamCatalogTopAnchor", ""], ["class", "miam-recipe-catalog", 3, "scroll", 4, "ngIf", "ngIfElse"], ["creationPage", ""], [1, "miam-recipe-catalog", 3, "scroll"], [3, "filters", "mobileFixed", "filterToRemove", "filterReset", "filterChanged", "filterCollapsed"], [1, "miam-recipe-catalog__content", 3, "ngClass"], [3, "displayReturnButton", "forcedRecipe", "title", "returnButtonPressed", "searchStringChanged"], ["class", "miam-recipe-catalog__list", 4, "ngIf", "ngIfElse"], ["categoriesComponents", ""], ["class", "miam-recipe-catalog__returnTop", 3, "click", 4, "ngIf"], [1, "miam-recipe-catalog__list"], [3, "filters", "randomMode", "retrievedRecipes", "filterRemoved", "recipeActionTriggered"], ["class", "miam-recipe-catalog__categories", 4, "ngIf"], [1, "miam-recipe-catalog__categories"], [3, "title", "filters", "displayList", 4, "ngFor", "ngForOf"], [3, "title", "filters", "displayList"], [1, "miam-recipe-catalog__returnTop", 3, "click"], ["height", "32", "width", "32", "primaryColor", "var(--m-color-white)", 3, "iconName"], [3, "recipe", "recipeChange", "canceled"]], template: function RecipeCatalogComponent_Template(rf, ctx) { if (rf & 1) {
|
|
411
|
+
} }, decls: 5, vars: 2, consts: [[1, "miam-catalog-anchor"], ["miamCatalogTopAnchor", ""], ["class", "miam-recipe-catalog", 3, "scroll", 4, "ngIf", "ngIfElse"], ["creationPage", ""], [1, "miam-recipe-catalog", 3, "scroll"], [3, "filters", "mobileFixed", "filterToRemove", "filterReset", "filterChanged", "filterCollapsed", "preferencesChanged"], [1, "miam-recipe-catalog__content", 3, "ngClass"], [3, "displayReturnButton", "forcedRecipe", "title", "returnButtonPressed", "searchStringChanged"], ["class", "miam-recipe-catalog__content__user-feedback", 4, "ngIf"], ["class", "miam-recipe-catalog__list", 4, "ngIf", "ngIfElse"], ["categoriesComponents", ""], ["class", "miam-recipe-catalog__returnTop", 3, "click", 4, "ngIf"], [1, "miam-recipe-catalog__content__user-feedback"], [1, "miam-recipe-catalog__content__user-feedback__actions"], [1, "m-button-grey", 3, "click"], [1, "miam-recipe-catalog__list"], [3, "filters", "randomMode", "retrievedRecipes", "filterRemoved", "recipeActionTriggered"], ["class", "miam-recipe-catalog__categories", 4, "ngIf"], [1, "miam-recipe-catalog__categories"], [3, "title", "filters", "displayList", 4, "ngFor", "ngForOf"], [3, "title", "filters", "displayList"], [1, "miam-recipe-catalog__returnTop", 3, "click"], ["height", "32", "width", "32", "primaryColor", "var(--m-color-white)", 3, "iconName"], [3, "recipe", "recipeChange", "canceled"]], template: function RecipeCatalogComponent_Template(rf, ctx) { if (rf & 1) {
|
|
352
412
|
i0.ɵɵelement(0, "div", 0, 1);
|
|
353
|
-
i0.ɵɵtemplate(2, RecipeCatalogComponent_div_2_Template,
|
|
413
|
+
i0.ɵɵtemplate(2, RecipeCatalogComponent_div_2_Template, 9, 13, "div", 2);
|
|
354
414
|
i0.ɵɵtemplate(3, RecipeCatalogComponent_ng_template_3_Template, 1, 1, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
|
|
355
415
|
} if (rf & 2) {
|
|
356
416
|
const _r2 = i0.ɵɵreference(4);
|
|
357
417
|
i0.ɵɵadvance(2);
|
|
358
418
|
i0.ɵɵproperty("ngIf", !ctx.creatingRecipe)("ngIfElse", _r2);
|
|
359
|
-
} }, directives: [i3.NgIf, i4.RecipeFiltersComponent, i3.NgClass, i5.CatalogHeaderComponent, i6.CatalogListComponent, i3.NgForOf, i7.CatalogCategoryComponent, i8.IconComponent, i9.RecipeStepperComponent], styles: [".miam-recipe-catalog{display:flex;justify-content:space-between;width:100%}.miam-recipe-catalog .miam-recipe-catalog__content{width:calc(100% - 216px)}.miam-recipe-catalog .miam-recipe-catalog__content.filter-collapsed{overflow-x:hidden;width:100%}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__categories{display:flex;flex-direction:column;margin-top:40px;width:100%}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__list{margin-top:40px;width:100%}.miam-recipe-catalog .miam-recipe-catalog__returnTop{-webkit-tap-highlight-color:transparent;background-color:var(--m-color-primary);border-radius:var(--m-border-radius-circle);bottom:24px;box-shadow:0 2px 10px -4px var(--m-color-grey-text-dark);cursor:pointer;padding:8px;position:fixed;right:56px;transform:rotate(-180deg);z-index:var(--m-z-index-position-absolute-high)}@media (max-width:1022px){.miam-recipe-catalog{max-width:100vw}.miam-recipe-catalog .miam-recipe-catalog__returnTop{bottom:72px;right:24px}.miam-recipe-catalog .miam-recipe-catalog__content{width:100%}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__categories,.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__list{margin-top:
|
|
419
|
+
} }, directives: [i3.NgIf, i4.RecipeFiltersComponent, i3.NgClass, i5.CatalogHeaderComponent, i6.CatalogListComponent, i3.NgForOf, i7.CatalogCategoryComponent, i8.IconComponent, i9.RecipeStepperComponent], styles: [".miam-recipe-catalog{display:flex;justify-content:space-between;width:100%}.miam-recipe-catalog .miam-recipe-catalog__content{width:calc(100% - 216px)}.miam-recipe-catalog .miam-recipe-catalog__content.filter-collapsed{overflow-x:hidden;width:100%}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__content__user-feedback{align-items:center;background-color:var(--m-color-secondary);color:#fff;display:flex;font-size:18px;font-weight:700;justify-content:center;padding:8px}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__content__user-feedback>span{margin-right:16px}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__content__user-feedback .miam-recipe-catalog__content__user-feedback__actions{display:flex}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__content__user-feedback .miam-recipe-catalog__content__user-feedback__actions>.m-button-grey{margin-left:4px;min-width:80px;padding:12px 16px}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__categories{display:flex;flex-direction:column;margin-top:40px;width:100%}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__list{margin-top:40px;width:100%}.miam-recipe-catalog .miam-recipe-catalog__returnTop{-webkit-tap-highlight-color:transparent;background-color:var(--m-color-primary);border-radius:var(--m-border-radius-circle);bottom:24px;box-shadow:0 2px 10px -4px var(--m-color-grey-text-dark);cursor:pointer;padding:8px;position:fixed;right:56px;transform:rotate(-180deg);z-index:var(--m-z-index-position-absolute-high)}@media (max-width:1022px){.miam-recipe-catalog{max-width:100vw}.miam-recipe-catalog .miam-recipe-catalog__returnTop{bottom:72px;right:24px}.miam-recipe-catalog .miam-recipe-catalog__content{width:100%}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__content__user-feedback{margin-top:55px}.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__categories,.miam-recipe-catalog .miam-recipe-catalog__content .miam-recipe-catalog__list{margin-top:60px}.miam-recipe-catalog .miam-recipe-catalog__content:not(.filter-collapsed){display:none}}"], encapsulation: 2, changeDetection: 0 });
|
|
360
420
|
/*@__PURE__*/ (function () { i0.ɵsetClassMetadata(RecipeCatalogComponent, [{
|
|
361
421
|
type: Component,
|
|
362
422
|
args: [{
|
|
@@ -366,7 +426,7 @@ RecipeCatalogComponent.ɵcmp = i0.ɵɵdefineComponent({ type: RecipeCatalogCompo
|
|
|
366
426
|
encapsulation: ViewEncapsulation.None,
|
|
367
427
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
368
428
|
}]
|
|
369
|
-
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.RecipeTypeService }, { type: i1.SponsorService }, { type: i1.SuppliersService }, { type: i1.PackageService }, { type: i1.RecipesService }, { type: i2.MediaMatcher }]; }, { catalogHeader: [{
|
|
429
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.RecipeTypeService }, { type: i1.SponsorService }, { type: i1.SuppliersService }, { type: i1.PackageService }, { type: i1.RecipesService }, { type: i2.MediaMatcher }, { type: i1.UserService }]; }, { catalogHeader: [{
|
|
370
430
|
type: ViewChild,
|
|
371
431
|
args: [CatalogHeaderComponent]
|
|
372
432
|
}], topAnchor: [{
|
|
@@ -376,4 +436,4 @@ RecipeCatalogComponent.ɵcmp = i0.ɵɵdefineComponent({ type: RecipeCatalogCompo
|
|
|
376
436
|
type: ViewChildren,
|
|
377
437
|
args: [CatalogCategoryComponent]
|
|
378
438
|
}] }); })();
|
|
379
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recipe-catalog.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/recipe-catalog/recipe-catalog.component.ts","lib/_web-components/recipe-catalog/recipe-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild, AfterViewInit, ChangeDetectorRef, OnInit, ElementRef,\n  ViewChildren, QueryList } from '@angular/core';\nimport { skipWhile, take } from 'rxjs/operators';\nimport { CatalogCategoryComponent } from '../catalog-category/catalog-category.component';\nimport { Recipe } from '../../_models';\nimport { RecipeTypeService, SponsorService, PackageService, SuppliersService, RecipesService } from '../../_services';\nimport { Icon } from '../../_types/icon.enum';\nimport { CatalogHeaderComponent } from '../catalog-header/catalog-header.component';\nimport { RecipeFilter, RecipeFilters } from '../../_types/recipe-filters';\nimport { forkJoin } from 'rxjs';\nimport { MediaMatcher } from '@angular/cdk/layout';\n\n\n@Component({\n  selector: 'ng-miam-recipe-catalog',\n  templateUrl: './recipe-catalog.component.html',\n  styleUrls: ['./recipe-catalog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RecipeCatalogComponent implements AfterViewInit, OnInit {\n  @ViewChild(CatalogHeaderComponent) catalogHeader: CatalogHeaderComponent;\n  @ViewChild('miamCatalogTopAnchor') topAnchor: ElementRef;\n\n  @ViewChildren(CatalogCategoryComponent)  categoriesComp!: QueryList<CatalogCategoryComponent>;\n\n  filters: RecipeFilters;\n  homePageTitle = 'Qu\\'est-ce qui vous ferait plaisir ?';\n  titleInResearchMode = 'Résultats de recherche';\n  displayHomePage = true;\n  isFilterCollapsed = false;\n  returnTopButtonShouldBeDisplayed = false;\n  icon = Icon;\n  categories = [];\n  recipeInHeader: Recipe;\n  creatingRecipe = false;\n  recipeToUpdate: Recipe;\n  filterToRemove: string;\n  isMobile = false;\n  listIsEmpty = false;\n\n  constructor(\n    public cdr: ChangeDetectorRef,\n    public recipeTypesService: RecipeTypeService,\n    public sponsorService: SponsorService,\n    public supplierService: SuppliersService,\n    public packageService: PackageService,\n    private recipesService: RecipesService,\n    public mediaMatcher: MediaMatcher) {\n    this.isMobile = mediaMatcher.matchMedia('(max-width: 1022px)').matches;\n    this.isFilterCollapsed = this.isMobile;\n  }\n\n  ngOnInit() {\n    this.resetFilters();\n\n    forkJoin([\n      this.recipeTypesService.getTypes().pipe(\n        skipWhile(types => types.length === 0),\n        // recipeTypesService.getTypes() comes from a behavior subject, it does not emit the complete() function\n        // you absolutly need a take(1) or call complete yourself to trigger the forkjoin subscribe\n        take(1)\n      ),\n      this.supplierService.supplier$.asObservable().pipe(\n        skipWhile(supp => supp === undefined || supp == null),\n        take(1)\n      )\n    ]).subscribe((res) => {\n      const supplier = res[1];\n      this.packageService.categories_for([supplier.id]).pipe(\n        skipWhile(packages => packages.is_loading)\n      ).subscribe((packages) => {\n        this.initCategories(packages);\n        this.selectCategoryFromUrl();\n        this.cdr.detectChanges();\n      })\n    });\n  }\n\n  ngAfterViewInit() {\n    this.cdr.detectChanges();\n  }\n\n  initCategories(packages) {\n    this.categories.push({\n      key: 'suggestions',\n      title: 'Suggestions de la semaine',\n      filters: { suggested: true }\n    });\n    packages.data.forEach(categoryPackage => {\n      this.categories.push({\n        key: categoryPackage.title,\n        title: categoryPackage.title,\n        filters: { packages: categoryPackage.id }\n      });\n    });\n    this.categories.push({\n      key: 'entrees',\n      title: 'Entrées',\n      filters: { recipe_type_id: this.recipeTypesService.getTypeByName('entrée').id }\n    });\n    this.categories.push({\n      key: 'plats',\n      title: 'Plats',\n      filters: { recipe_type_id: this.recipeTypesService.getTypeByName('plat principal').id }\n    });\n    this.categories.push({\n      key: 'desserts',\n      title: 'Desserts',\n      filters: { recipe_type_id: this.recipeTypesService.getTypeByName('dessert').id }\n    });\n  }\n\n  selectCategoryFromUrl() {\n    const paramsString = window.location.search;\n    const paramsArray = new URLSearchParams(paramsString);\n    const selected_category_key = paramsArray.get('catalogCategory');\n    if (!selected_category_key){\n      return;\n    }\n    const selected_category = this.categories.find((cat) => cat.key === selected_category_key);\n    if (!selected_category){\n      return;\n    }\n    this.categoryTitleClicked(selected_category);\n  }\n\n  // Used on load to build the filters attribute, and on click on the link to reset the filters\n  resetFilters() {\n    this.filters = {\n      // type: [\n      //   {name: recipeTypesService.getType(1).id, value: false, text: 'Entrées'},\n      //   {name: recipeTypesService.getType(2).id, value: false, text: 'Plats'},\n      //   {name: recipeTypesService.getType(3).id, value: false, text: 'Desserts'}\n      // ],\n      difficulty: [\n        {name: '1', value: false, text: 'Facile'},\n        {name: '2', value: false, text: 'Moyenne'},\n        {name: '3', value: false, text: 'Difficile'}\n      ],\n      cost: [\n        {name: '0-5', value: false, text: 'Bas (≈ ≤ 5€)'},\n        {name: '5-10', value: false, text: 'Moyen (≈ 5-10€) '},\n        {name: '10-1000', value: false, text: 'Élevé (≈ ≥ 10€) '}\n        // we set a limit at 1000€ max, if a recipe cost more should be non sense anyway\n      ],\n      time: [\n        {name: '15', value: false, text: '15m'},\n        {name: '30', value: false, text: '30m'},\n        {name: '60', value: false, text: '1h'},\n        {name: '120', value: false, text: '2h'}\n      ],\n    };\n    if (this.catalogHeader) { this.catalogHeader.resetSearchString(); }\n    this.filters.search = '';\n    this.listIsEmpty = false;\n    if (!this.displayHomePage){ this.returnToHomePage(); }\n  }\n\n  updateSearch(search: string) {\n    if (search !== this.filters.search) {\n      this.filters.search = search;\n      this.reloadList();\n    }\n  }\n\n  updateFilters(filters: RecipeFilters) {\n    this.filters = { ...filters }; // Necessary to trigger the ngOnChanges\n    this.filterToRemove = undefined;\n    this.listIsEmpty = false;\n    if (this.isMobile) {\n      this.returnToTop();\n    }\n    this.reloadList();\n  }\n\n  reloadList() {\n    // If there are no filters nor search, return to home page\n    if (this.areFiltersEmpty()) { this.returnToHomePage(); }\n    else { // Reload the list\n      this.filters = { ...this.filters }; // Necessary to trigger the ngOnChanges\n      this.displayHomePage = false;\n      this.cdr.detectChanges();\n    }\n  }\n\n  categoryTitleClicked(event: {title: string, filters: any}) {\n    this.returnToTop();\n    this.filters.additionalFilters = { filters: event.filters, title: event.title };\n    this.reloadList();\n  }\n\n  areFiltersEmpty(): boolean {\n    return this.isFieldEmpty(this.filters.difficulty) && this.isFieldEmpty(this.filters.cost) && this.isFieldEmpty(this.filters.time)\n      && this.filters.search === '' && !this.filters.additionalFilters?.filters;\n  }\n\n  isFieldEmpty(filter: RecipeFilter[]) {\n    for (const f of filter) {\n      if (f.value) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  removeFilter(filterText: string) {\n    this.filterToRemove = filterText;\n    this.cdr.detectChanges();\n  }\n\n  returnToTop() {\n    if (this.topAnchor) {\n      this.topAnchor.nativeElement.scrollIntoView();\n    }\n  }\n\n  displayReturnTopButton() {\n    this.returnTopButtonShouldBeDisplayed = this.topAnchor.nativeElement.getBoundingClientRect().bottom < -400;\n    this.cdr.detectChanges();\n  }\n\n  changeHeaderImage(recipes: Recipe[]) {\n    if (recipes.length > 0 && this.filters.additionalFilters?.filters && !this.recipeInHeader) {\n      this.recipeInHeader = recipes[0];\n      this.cdr.detectChanges();\n    }\n  }\n\n  returnToHomePage() {\n    this.displayHomePage = true;\n    this.recipeInHeader = undefined; // Don't force a recipe in header on homePage\n    this.resetFilters();\n    this.cdr.detectChanges();\n  }\n\n  onFilterCollapsed() {\n    this.isFilterCollapsed = !this.isFilterCollapsed;\n    this.cdr.detectChanges();\n    // to trigger after the detectChanges because we need to alread have the display change to update cards\n    this.categoriesComp.forEach( cat => {\n      cat.updateWidth();\n    });\n  }\n\n  goToCreatePage(recipe = null) {\n    this.creatingRecipe = true;\n    this.recipeToUpdate = recipe;\n    this.cdr.detectChanges();\n    this.returnToTop();\n  }\n\n  leaveCreatePage() {\n    this.creatingRecipe = false;\n    this.reloadList();\n    this.returnToTop();\n  }\n\n  manageRecipeAction(event: {action: string, recipe: Recipe}) {\n    switch (event.action) {\n      case 'CREATE': {\n        this.goToCreatePage();\n        break;\n      }\n\n      case 'EDIT': {\n        this.goToCreatePage(event.recipe);\n        break;\n      }\n\n      case 'DELETE': {\n        if (event.recipe?.id && event.recipe.relationships['recipe-provider']?.data.id === 'personal') {\n          this.recipesService.delete(event.recipe.id).subscribe(() => {\n            this.reloadList();\n          });\n        }\n        break;\n      }\n    }\n  }\n\n  isListEmpty(recipes: Recipe[]) {\n    this.listIsEmpty = recipes.length === 0;\n    this.cdr.detectChanges();\n  }\n}\n","<div #miamCatalogTopAnchor class=\"miam-catalog-anchor\"></div>\n<div *ngIf=\"!creatingRecipe else creationPage\" class=\"miam-recipe-catalog\" (window:scroll)=\"displayReturnTopButton()\">\n  <ng-miam-recipe-filters\n    [filters]=\"filters\"\n    [mobileFixed]=\"returnTopButtonShouldBeDisplayed\"\n    [filterToRemove]=\"filterToRemove\"\n    (filterReset)=\"resetFilters()\"\n    (filterChanged)=\"updateFilters($event)\"\n    (filterCollapsed)=\"onFilterCollapsed()\">\n  </ng-miam-recipe-filters>\n\n  <div class=\"miam-recipe-catalog__content\" [ngClass]=\"{'filter-collapsed': isFilterCollapsed}\">\n    <ng-miam-catalog-header \n      [displayReturnButton]=\"!displayHomePage\"\n      [forcedRecipe]=\"recipeInHeader\"\n      [title]=\"displayHomePage ? homePageTitle : \n        (filters.additionalFilters && filters.additionalFilters.title !== '' ? filters.additionalFilters.title : titleInResearchMode)\"\n      (returnButtonPressed)=\"returnToHomePage()\"\n      (searchStringChanged)=\"updateSearch($event)\">\n    </ng-miam-catalog-header>\n\n    <div *ngIf=\"!displayHomePage else categoriesComponents\" class=\"miam-recipe-catalog__list\">\n      <ng-miam-catalog-list\n        [filters]=\"filters\"\n        [randomMode]=\"true\"\n        (retrievedRecipes)=\"changeHeaderImage($event)\"\n        (filterRemoved)=\"removeFilter($event)\"\n        (recipeActionTriggered)=\"manageRecipeAction($event)\">\n      </ng-miam-catalog-list>\n    </div>\n\n    <ng-template #categoriesComponents>\n      <div *ngIf=\"categories.length > 0\" class=\"miam-recipe-catalog__categories\">\n        <ng-miam-catalog-category \n          *ngFor=\"let category of categories\" \n          [title]=\"category.title\"\n          [filters]=\"category.filters\" \n          (displayList)=\"categoryTitleClicked($event)\">\n        </ng-miam-catalog-category>\n      </div>\n    </ng-template>\n\n    <div *ngIf=\"returnTopButtonShouldBeDisplayed\" class=\"miam-recipe-catalog__returnTop\" (click)=\"returnToTop()\">\n      <ng-miam-icon height='32' width='32' primaryColor=\"var(--m-color-white)\" [iconName]=\"icon.ChevronDown\"></ng-miam-icon>\n    </div>\n  </div>\n</div>\n<ng-template #creationPage>\n  <ng-miam-recipe-stepper [recipe]=\"recipeToUpdate\" (recipeChange)=\"leaveCreatePage()\" (canceled)=\"leaveCreatePage()\"></ng-miam-recipe-stepper>\n</ng-template>"]}
|
|
439
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recipe-catalog.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/recipe-catalog/recipe-catalog.component.ts","lib/_web-components/recipe-catalog/recipe-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild, AfterViewInit, ChangeDetectorRef, OnInit, ElementRef,\n  ViewChildren, QueryList, OnDestroy } from '@angular/core';\nimport { map, skipWhile, switchMap, take, tap } from 'rxjs/operators';\nimport { CatalogCategoryComponent } from '../catalog-category/catalog-category.component';\nimport { Recipe } from '../../_models';\nimport { RecipeTypeService, SponsorService, PackageService, SuppliersService, RecipesService, UserService } from '../../_services';\nimport { Icon } from '../../_types/icon.enum';\nimport { CatalogHeaderComponent } from '../catalog-header/catalog-header.component';\nimport { RecipeFilter, RecipeFilters } from '../../_types/recipe-filters';\nimport { combineLatest, forkJoin, Observable, Subscription } from 'rxjs';\nimport { MediaMatcher } from '@angular/cdk/layout';\nimport { DocumentCollection } from 'ngx-jsonapi';\nimport { Package } from '../../_models/package';\n\n@Component({\n  selector: 'ng-miam-recipe-catalog',\n  templateUrl: './recipe-catalog.component.html',\n  styleUrls: ['./recipe-catalog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RecipeCatalogComponent implements AfterViewInit, OnInit, OnDestroy {\n  @ViewChild(CatalogHeaderComponent) catalogHeader: CatalogHeaderComponent;\n  @ViewChild('miamCatalogTopAnchor') topAnchor: ElementRef;\n  @ViewChildren(CatalogCategoryComponent)  categoriesComp!: QueryList<CatalogCategoryComponent>;\n\n  filters: RecipeFilters;\n  homePageTitle = 'Qu\\'est-ce qui vous ferait plaisir ?';\n  titleInResearchMode = 'Résultats de recherche';\n  displayHomePage = true;\n  isFilterCollapsed = false;\n  returnTopButtonShouldBeDisplayed = false;\n  icon = Icon;\n  categories = [];\n  recipeInHeader: Recipe;\n  creatingRecipe = false;\n  recipeToUpdate: Recipe;\n  filterToRemove: string;\n  isMobile = false;\n  listIsEmpty = false;\n  showUserFeedback = false;\n\n  private subscriptions: Subscription[] = [];\n  private supplierId;\n\n  constructor(\n    public cdr: ChangeDetectorRef,\n    public recipeTypesService: RecipeTypeService,\n    public sponsorService: SponsorService,\n    public supplierService: SuppliersService,\n    public packageService: PackageService,\n    private recipesService: RecipesService,\n    public mediaMatcher: MediaMatcher,\n    public usersService: UserService\n  ) {\n    this.isMobile = mediaMatcher.matchMedia('(max-width: 1022px)').matches;\n    this.isFilterCollapsed = this.isMobile;\n  }\n\n  ngOnInit() {\n    this.resetFilters();\n\n    this.subscriptions = [\n      forkJoin([\n        this.recipeTypesService.getTypes().pipe(\n          skipWhile(types => types.length === 0),\n          // recipeTypesService.getTypes() comes from a behavior subject, it does not emit the complete() function\n          // you absolutly need a take(1) or call complete yourself to trigger the forkjoin subscribe\n          take(1)\n        ),\n        this.supplierService.supplier$.asObservable().pipe(\n          skipWhile(supp => supp === undefined || supp == null),\n          take(1)\n        )\n      ]).pipe(\n        switchMap(res => {\n          this.supplierId = res[1].id;\n          return this.loadPackages();\n        })\n      ).subscribe(),\n      this.assessShowUserFeedback()\n    ];\n  }\n\n  ngAfterViewInit() {\n    this.cdr.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(s => s.unsubscribe());\n  }\n\n  initCategories(packages) {\n    this.categories = [{\n      key: 'suggestions',\n      title: 'Suggestions de la semaine',\n      filters: { suggested: true }\n    }];\n    packages.data.forEach(categoryPackage => {\n      this.categories.push({\n        key: categoryPackage.title,\n        title: categoryPackage.title,\n        filters: { packages: categoryPackage.id }\n      });\n    });\n\n    const startersType = this.recipeTypesService.getTypeByName('entrée');\n    if (startersType) {\n      this.categories.push({\n        key: 'entrees',\n        title: 'Entrées',\n        filters: { recipe_type_id: startersType.id }\n      });\n    }\n\n    const mainType = this.recipeTypesService.getTypeByName('plat principal');\n    if (mainType) {\n      this.categories.push({\n        key: 'plats',\n        title: 'Plats',\n        filters: { recipe_type_id: mainType.id }\n      });\n    }\n\n    const dessertType = this.recipeTypesService.getTypeByName('dessert');\n    if (dessertType) {\n      this.categories.push({\n        key: 'desserts',\n        title: 'Desserts',\n        filters: { recipe_type_id: dessertType.id }\n      });\n    }\n  }\n\n  selectCategoryFromUrl() {\n    const paramsString = window.location.search;\n    const paramsArray = new URLSearchParams(paramsString);\n    const selectedCategoryKey = paramsArray.get('catalogCategory');\n    if (!selectedCategoryKey){\n      return;\n    }\n    const selectedCategory = this.categories.find((cat) => cat.key === selectedCategoryKey);\n    if (!selectedCategory){\n      return;\n    }\n    this.categoryTitleClicked(selectedCategory);\n  }\n\n  // Used on load to build the filters attribute, and on click on the link to reset the filters\n  resetFilters() {\n    this.filters = {\n      // type: [\n      //   {name: recipeTypesService.getType(1).id, value: false, text: 'Entrées'},\n      //   {name: recipeTypesService.getType(2).id, value: false, text: 'Plats'},\n      //   {name: recipeTypesService.getType(3).id, value: false, text: 'Desserts'}\n      // ],\n      difficulty: [\n        {name: '1', value: false, text: 'Facile'},\n        {name: '2', value: false, text: 'Moyenne'},\n        {name: '3', value: false, text: 'Difficile'}\n      ],\n      cost: [\n        {name: '0-5', value: false, text: 'Bas (≈ ≤ 5€)'},\n        {name: '5-10', value: false, text: 'Moyen (≈ 5-10€) '},\n        {name: '10-1000', value: false, text: 'Élevé (≈ ≥ 10€) '}\n        // we set a limit at 1000€ max, if a recipe cost more should be non sense anyway\n      ],\n      time: [\n        {name: '15', value: false, text: '15m'},\n        {name: '30', value: false, text: '30m'},\n        {name: '60', value: false, text: '1h'},\n        {name: '120', value: false, text: '2h'}\n      ],\n    };\n    if (this.catalogHeader) { this.catalogHeader.resetSearchString(); }\n    this.filters.search = '';\n    this.listIsEmpty = false;\n    if (!this.displayHomePage){ this.returnToHomePage(); }\n  }\n\n  updateSearch(search: string) {\n    if (search !== this.filters.search) {\n      this.filters.search = search;\n      this.reloadList();\n    }\n  }\n\n  updateFilters(filters: RecipeFilters) {\n    this.filters = { ...filters }; // Necessary to trigger the ngOnChanges\n    this.filterToRemove = undefined;\n    this.listIsEmpty = false;\n    if (this.isMobile) {\n      this.returnToTop();\n    }\n    this.reloadList();\n  }\n\n  reloadList() {\n    // If there are no filters nor search, return to home page\n    if (this.areFiltersEmpty()) { this.returnToHomePage(); }\n    else { // Reload the list\n      this.filters = { ...this.filters }; // Necessary to trigger the ngOnChanges\n      this.displayHomePage = false;\n      this.cdr.detectChanges();\n    }\n  }\n\n  categoryTitleClicked(event: {title: string, filters: any}) {\n    this.returnToTop();\n    this.filters.additionalFilters = { filters: event.filters, title: event.title };\n    this.reloadList();\n  }\n\n  areFiltersEmpty(): boolean {\n    return this.isFieldEmpty(this.filters.difficulty) && this.isFieldEmpty(this.filters.cost) && this.isFieldEmpty(this.filters.time)\n      && this.filters.search === '' && !this.filters.additionalFilters?.filters;\n  }\n\n  isFieldEmpty(filter: RecipeFilter[]) {\n    for (const f of filter) {\n      if (f.value) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  removeFilter(filterText: string) {\n    this.filterToRemove = filterText;\n    this.cdr.detectChanges();\n  }\n\n  returnToTop() {\n    if (this.topAnchor) {\n      this.topAnchor.nativeElement.scrollIntoView();\n    }\n  }\n\n  displayReturnTopButton() {\n    this.returnTopButtonShouldBeDisplayed = this.topAnchor.nativeElement.getBoundingClientRect().bottom < -400;\n    this.cdr.detectChanges();\n  }\n\n  changeHeaderImage(recipes: Recipe[]) {\n    if (recipes.length > 0 && this.filters.additionalFilters?.filters && !this.recipeInHeader) {\n      this.recipeInHeader = recipes[0];\n      this.cdr.detectChanges();\n    }\n  }\n\n  returnToHomePage() {\n    this.displayHomePage = true;\n    this.recipeInHeader = undefined; // Don't force a recipe in header on homePage\n    this.resetFilters();\n    this.cdr.detectChanges();\n  }\n\n  onFilterCollapsed() {\n    this.isFilterCollapsed = !this.isFilterCollapsed;\n    this.cdr.detectChanges();\n    // to trigger after the detectChanges because we need to alread have the display change to update cards\n    this.categoriesComp.forEach( cat => {\n      cat.updateWidth();\n    });\n  }\n\n  goToCreatePage(recipe = null) {\n    this.creatingRecipe = true;\n    this.recipeToUpdate = recipe;\n    this.cdr.detectChanges();\n    this.returnToTop();\n  }\n\n  leaveCreatePage() {\n    this.creatingRecipe = false;\n    this.reloadList();\n    this.returnToTop();\n  }\n\n  manageRecipeAction(event: {action: string, recipe: Recipe}) {\n    switch (event.action) {\n      case 'CREATE': {\n        this.goToCreatePage();\n        break;\n      }\n\n      case 'EDIT': {\n        this.goToCreatePage(event.recipe);\n        break;\n      }\n\n      case 'DELETE': {\n        if (event.recipe?.id && event.recipe.relationships['recipe-provider']?.data.id === 'personal') {\n          this.subscriptions.push(\n            this.recipesService.delete(event.recipe.id).subscribe(() => {\n              this.reloadList();\n            })\n          );\n        }\n        break;\n      }\n    }\n  }\n\n  isListEmpty(recipes: Recipe[]) {\n    this.listIsEmpty = recipes.length === 0;\n    this.cdr.detectChanges();\n  }\n\n  setUserPreference(pref, state) {\n    this.subscriptions.push(\n      this.usersService.setPreference(pref, state).pipe(\n        switchMap(() => this.loadPackages())\n      ).subscribe()\n    );\n  }\n\n  reloadPackages() {\n    this.subscriptions.push(\n      this.loadPackages().subscribe()\n    );\n  }\n\n  private loadPackages(): Observable<DocumentCollection<Package>> {\n    return this.packageService.categories_for([this.supplierId]).pipe(\n      skipWhile(packages => packages.is_loading),\n      tap((packages: DocumentCollection<Package>) => {\n        this.initCategories(packages);\n        this.selectCategoryFromUrl();\n        this.cdr.detectChanges();\n      })\n    );\n  }\n\n  // Show feedback block only if user is logged and the children preference is unknown\n  private assessShowUserFeedback(): Subscription {\n    return combineLatest([\n      this.usersService.isLogged$,\n      this.usersService.preferenceDefined('has_children')\n    ]).subscribe(results => {\n      const logged = results[0];\n      const preferenceDefined = results[1];\n      this.showUserFeedback = logged && !preferenceDefined;\n      this.cdr.detectChanges();\n    });\n  }\n}\n","<div #miamCatalogTopAnchor class=\"miam-catalog-anchor\"></div>\n<div *ngIf=\"!creatingRecipe else creationPage\" class=\"miam-recipe-catalog\" (window:scroll)=\"displayReturnTopButton()\">\n\n  <ng-miam-recipe-filters\n    [filters]=\"filters\"\n    [mobileFixed]=\"returnTopButtonShouldBeDisplayed\"\n    [filterToRemove]=\"filterToRemove\"\n    (filterReset)=\"resetFilters()\"\n    (filterChanged)=\"updateFilters($event)\"\n    (filterCollapsed)=\"onFilterCollapsed()\"\n    (preferencesChanged)=\"reloadPackages()\"\n  >\n  </ng-miam-recipe-filters>\n\n  <div class=\"miam-recipe-catalog__content\" [ngClass]=\"{'filter-collapsed': isFilterCollapsed}\">\n    <ng-miam-catalog-header \n      [displayReturnButton]=\"!displayHomePage\"\n      [forcedRecipe]=\"recipeInHeader\"\n      [title]=\"displayHomePage ? homePageTitle : \n        (filters.additionalFilters && filters.additionalFilters.title !== '' ? filters.additionalFilters.title : titleInResearchMode)\"\n      (returnButtonPressed)=\"returnToHomePage()\"\n      (searchStringChanged)=\"updateSearch($event)\">\n    </ng-miam-catalog-header>\n\n    <div class=\"miam-recipe-catalog__content__user-feedback\" *ngIf=\"showUserFeedback\">\n      <span>Une petite question : Avez-vous des enfants ?</span>\n      <div class=\"miam-recipe-catalog__content__user-feedback__actions\">\n        <button class=\"m-button-grey\" (click)=\"setUserPreference('has_children', true)\">Oui</button>\n        <button class=\"m-button-grey\" (click)=\"setUserPreference('has_children', false)\">Non</button>\n      </div>\n    </div>\n\n    <div *ngIf=\"!displayHomePage else categoriesComponents\" class=\"miam-recipe-catalog__list\">\n      <ng-miam-catalog-list\n        [filters]=\"filters\"\n        [randomMode]=\"true\"\n        (retrievedRecipes)=\"changeHeaderImage($event)\"\n        (filterRemoved)=\"removeFilter($event)\"\n        (recipeActionTriggered)=\"manageRecipeAction($event)\">\n      </ng-miam-catalog-list>\n    </div>\n\n    <ng-template #categoriesComponents>\n      <div *ngIf=\"categories.length > 0\" class=\"miam-recipe-catalog__categories\">\n        <ng-miam-catalog-category \n          *ngFor=\"let category of categories\" \n          [title]=\"category.title\"\n          [filters]=\"category.filters\" \n          (displayList)=\"categoryTitleClicked($event)\">\n        </ng-miam-catalog-category>\n      </div>\n    </ng-template>\n\n    <div *ngIf=\"returnTopButtonShouldBeDisplayed\" class=\"miam-recipe-catalog__returnTop\" (click)=\"returnToTop()\">\n      <ng-miam-icon height='32' width='32' primaryColor=\"var(--m-color-white)\" [iconName]=\"icon.ChevronDown\"></ng-miam-icon>\n    </div>\n  </div>\n</div>\n<ng-template #creationPage>\n  <ng-miam-recipe-stepper [recipe]=\"recipeToUpdate\" (recipeChange)=\"leaveCreatePage()\" (canceled)=\"leaveCreatePage()\"></ng-miam-recipe-stepper>\n</ng-template>"]}
|