ng-miam 3.2.2 → 3.4.0

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.
Files changed (120) hide show
  1. package/bundles/ng-miam.umd.js +7452 -5975
  2. package/bundles/ng-miam.umd.js.map +1 -1
  3. package/bundles/ng-miam.umd.min.js +2 -2
  4. package/bundles/ng-miam.umd.min.js.map +1 -1
  5. package/esm2015/lib/_components/abstracts/abstract-recipe-card.component.js +1 -1
  6. package/esm2015/lib/_components/icon/icon.component.js +65 -6
  7. package/esm2015/lib/_components/recipe-filters/recipe-filters.component.js +94 -40
  8. package/esm2015/lib/_components/recipe-type-chooser/recipe-type-chooser.component.js +23 -30
  9. package/esm2015/lib/_components/text-input/text-input.component.js +6 -4
  10. package/esm2015/lib/_models/article.js +43 -0
  11. package/esm2015/lib/_models/basket.js +2 -2
  12. package/esm2015/lib/_models/groceries-entry.js +23 -2
  13. package/esm2015/lib/_models/groceries-list.js +5 -2
  14. package/esm2015/lib/_models/index.js +4 -1
  15. package/esm2015/lib/_models/package.js +14 -3
  16. package/esm2015/lib/_models/recipe.js +4 -1
  17. package/esm2015/lib/_models/user.js +10 -1
  18. package/esm2015/lib/_services/analytics.service.js +7 -1
  19. package/esm2015/lib/_services/articles.service.js +21 -0
  20. package/esm2015/lib/_services/baskets.service.js +7 -3
  21. package/esm2015/lib/_services/context.service.js +15 -1
  22. package/esm2015/lib/_services/groceries-lists.service.js +23 -6
  23. package/esm2015/lib/_services/index.js +3 -1
  24. package/esm2015/lib/_services/ingredients.service.js +2 -2
  25. package/esm2015/lib/_services/interceptor.service.js +2 -3
  26. package/esm2015/lib/_services/package.service.js +32 -9
  27. package/esm2015/lib/_services/recipe-events.service.js +2 -2
  28. package/esm2015/lib/_services/recipe-likes.service.js +6 -2
  29. package/esm2015/lib/_services/recipe-share.service.js +2 -2
  30. package/esm2015/lib/_services/recipes.service.js +2 -2
  31. package/esm2015/lib/_services/suppliers.service.js +2 -2
  32. package/esm2015/lib/_services/toastr.service.js +52 -0
  33. package/esm2015/lib/_services/user.service.js +64 -21
  34. package/esm2015/lib/_types/icon.enum.js +22 -18
  35. package/esm2015/lib/_web-components/{basket-preview-block → basket-preview/basket-preview-block}/basket-preview-block.component.js +15 -15
  36. package/esm2015/lib/_web-components/{basket-preview-disabled → basket-preview/basket-preview-disabled}/basket-preview-disabled.component.js +3 -3
  37. package/esm2015/lib/_web-components/{basket-preview-line → basket-preview/basket-preview-line}/basket-preview-line.component.js +22 -19
  38. package/esm2015/lib/_web-components/basket-preview/basket-preview.module.js +78 -0
  39. package/esm2015/lib/_web-components/basket-preview/index.js +7 -0
  40. package/esm2015/lib/_web-components/{replace-item → basket-preview/replace-item}/replace-item.component.js +8 -8
  41. package/esm2015/lib/_web-components/catalog-article-card/catalog-article-card.component.js +71 -0
  42. package/esm2015/lib/_web-components/catalog-category/catalog-category.component.js +134 -92
  43. package/esm2015/lib/_web-components/catalog-header/catalog-header.component.js +51 -34
  44. package/esm2015/lib/_web-components/catalog-list/catalog-list.component.js +106 -61
  45. package/esm2015/lib/_web-components/catalog-recipe-card/catalog-recipe-card.component.js +65 -52
  46. package/esm2015/lib/_web-components/drawer/drawer.component.js +1 -1
  47. package/esm2015/lib/_web-components/favorite-page/favorite-page.component.js +8 -6
  48. package/esm2015/lib/_web-components/index.js +5 -6
  49. package/esm2015/lib/_web-components/list-scan/basket-preview/basket-preview.component.js +145 -0
  50. package/esm2015/lib/_web-components/list-scan/index.js +3 -0
  51. package/esm2015/lib/_web-components/list-scan/ingredients-list/ingredients-list.component.js +150 -0
  52. package/esm2015/lib/_web-components/list-scan/list-scan.component.js +87 -0
  53. package/esm2015/lib/_web-components/list-scan/list-scan.module.js +60 -0
  54. package/esm2015/lib/_web-components/list-scan/overlay-button/overlay-button.component.js +104 -0
  55. package/esm2015/lib/_web-components/loader/index.js +3 -0
  56. package/esm2015/lib/_web-components/loader/loader.module.js +39 -0
  57. package/esm2015/lib/_web-components/personal-recipes/personal-recipes.component.js +7 -5
  58. package/esm2015/lib/_web-components/recipe-card/recipe-card.component.js +73 -58
  59. package/esm2015/lib/_web-components/recipe-catalog/recipe-catalog.component.js +152 -92
  60. package/esm2015/lib/_web-components/recipe-details/recipe-details.component.js +307 -270
  61. package/esm2015/lib/_web-components/recipe-modal/recipe-modal.component.js +1 -1
  62. package/esm2015/lib/_web-components/recipe-stepper/recipe-stepper.component.js +1 -1
  63. package/esm2015/lib/_web-components/recipes-history/recipes-history.component.js +1 -1
  64. package/esm2015/lib/_web-components/suggestion-card/suggestion-card.component.js +3 -6
  65. package/esm2015/lib/_web-components/web-components.module.js +35 -65
  66. package/esm2015/lib/environments/environment.js +6 -0
  67. package/esm2015/lib/ng-miam.module.js +4 -4
  68. package/fesm2015/ng-miam.js +6540 -5287
  69. package/fesm2015/ng-miam.js.map +1 -1
  70. package/lib/_components/abstracts/abstract-recipe-card.component.d.ts +1 -1
  71. package/lib/_components/recipe-filters/recipe-filters.component.d.ts +14 -4
  72. package/lib/_components/recipe-type-chooser/recipe-type-chooser.component.d.ts +2 -2
  73. package/lib/_components/text-input/text-input.component.d.ts +2 -1
  74. package/lib/_models/article.d.ts +23 -0
  75. package/lib/_models/basket.d.ts +1 -2
  76. package/lib/_models/groceries-entry.d.ts +8 -1
  77. package/lib/_models/groceries-list.d.ts +4 -3
  78. package/lib/_models/index.d.ts +3 -0
  79. package/lib/_models/package.d.ts +10 -3
  80. package/lib/_models/recipe.d.ts +1 -0
  81. package/lib/_models/user.d.ts +16 -1
  82. package/lib/_services/articles.service.d.ts +10 -0
  83. package/lib/_services/context.service.d.ts +12 -6
  84. package/lib/_services/groceries-lists.service.d.ts +4 -1
  85. package/lib/_services/index.d.ts +2 -0
  86. package/lib/_services/package.service.d.ts +6 -1
  87. package/lib/_services/toastr.service.d.ts +10 -0
  88. package/lib/_services/user.service.d.ts +12 -6
  89. package/lib/_types/icon.enum.d.ts +21 -17
  90. package/lib/_web-components/{basket-preview-block → basket-preview/basket-preview-block}/basket-preview-block.component.d.ts +6 -6
  91. package/lib/_web-components/{basket-preview-disabled → basket-preview/basket-preview-disabled}/basket-preview-disabled.component.d.ts +2 -2
  92. package/lib/_web-components/{basket-preview-line → basket-preview/basket-preview-line}/basket-preview-line.component.d.ts +7 -7
  93. package/lib/_web-components/basket-preview/basket-preview.module.d.ts +16 -0
  94. package/lib/_web-components/basket-preview/index.d.ts +5 -0
  95. package/lib/_web-components/{replace-item → basket-preview/replace-item}/replace-item.component.d.ts +5 -5
  96. package/lib/_web-components/catalog-article-card/catalog-article-card.component.d.ts +8 -0
  97. package/lib/_web-components/catalog-category/catalog-category.component.d.ts +12 -7
  98. package/lib/_web-components/catalog-header/catalog-header.component.d.ts +5 -2
  99. package/lib/_web-components/catalog-list/catalog-list.component.d.ts +13 -6
  100. package/lib/_web-components/catalog-recipe-card/catalog-recipe-card.component.d.ts +1 -0
  101. package/lib/_web-components/favorite-page/favorite-page.component.d.ts +0 -1
  102. package/lib/_web-components/index.d.ts +4 -5
  103. package/lib/_web-components/list-scan/basket-preview/basket-preview.component.d.ts +25 -0
  104. package/lib/_web-components/list-scan/index.d.ts +2 -0
  105. package/lib/_web-components/list-scan/ingredients-list/ingredients-list.component.d.ts +22 -0
  106. package/lib/_web-components/list-scan/list-scan.component.d.ts +17 -0
  107. package/lib/_web-components/list-scan/list-scan.module.d.ts +16 -0
  108. package/lib/_web-components/list-scan/overlay-button/overlay-button.component.d.ts +19 -0
  109. package/lib/_web-components/loader/index.d.ts +2 -0
  110. package/lib/_web-components/loader/loader.module.d.ts +10 -0
  111. package/lib/_web-components/personal-recipes/personal-recipes.component.d.ts +0 -1
  112. package/lib/_web-components/recipe-card/recipe-card.component.d.ts +1 -0
  113. package/lib/_web-components/recipe-catalog/recipe-catalog.component.d.ts +13 -4
  114. package/lib/_web-components/recipe-details/recipe-details.component.d.ts +8 -3
  115. package/lib/_web-components/suggestion-card/suggestion-card.component.d.ts +0 -1
  116. package/lib/_web-components/web-components.module.d.ts +38 -65
  117. package/lib/{environment.d.ts → environments/environment.d.ts} +1 -1
  118. package/miam-style.css +1 -1
  119. package/package.json +1 -1
  120. package/esm2015/lib/environment.js +0 -8
@@ -0,0 +1,145 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { switchMap } from 'rxjs/operators';
3
+ import { BasketPreviewLine } from '../../../_models';
4
+ import { BasketsService } from '../../../_services';
5
+ import { Icon } from '../../../_types/icon.enum';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../_services";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "../../../_components/icon/icon.component";
10
+ import * as i4 from "../../basket-preview/basket-preview-line/basket-preview-line.component";
11
+ import * as i5 from "../../basket-preview/replace-item/replace-item.component";
12
+ import * as i6 from "../../basket-preview/basket-preview-disabled/basket-preview-disabled.component";
13
+ function ListScanBasketPreviewComponent_div_0_Template(rf, ctx) { if (rf & 1) {
14
+ const _r4 = i0.ɵɵgetCurrentView();
15
+ i0.ɵɵelementStart(0, "div", 7);
16
+ i0.ɵɵlistener("click", function ListScanBasketPreviewComponent_div_0_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r3 = i0.ɵɵnextContext(); return ctx_r3.close(); });
17
+ i0.ɵɵelement(1, "ng-miam-icon", 8);
18
+ i0.ɵɵelementEnd();
19
+ } if (rf & 2) {
20
+ const ctx_r0 = i0.ɵɵnextContext();
21
+ i0.ɵɵadvance(1);
22
+ i0.ɵɵproperty("iconName", ctx_r0.icon.DrawerHorizontalCloseBar);
23
+ } }
24
+ function ListScanBasketPreviewComponent_div_4_ng_miam_basket_preview_line_1_Template(rf, ctx) { if (rf & 1) {
25
+ const _r9 = i0.ɵɵgetCurrentView();
26
+ i0.ɵɵelementStart(0, "ng-miam-basket-preview-line", 11);
27
+ i0.ɵɵlistener("removed", function ListScanBasketPreviewComponent_div_4_ng_miam_basket_preview_line_1_Template_ng_miam_basket_preview_line_removed_0_listener($event) { i0.ɵɵrestoreView(_r9); const ctx_r8 = i0.ɵɵnextContext(2); return ctx_r8.deleteEntry($event); })("replaceItem", function ListScanBasketPreviewComponent_div_4_ng_miam_basket_preview_line_1_Template_ng_miam_basket_preview_line_replaceItem_0_listener() { i0.ɵɵrestoreView(_r9); const line_r5 = i0.ɵɵnextContext().$implicit; const ctx_r10 = i0.ɵɵnextContext(); return ctx_r10.toggleReplacing(line_r5); });
28
+ i0.ɵɵelementEnd();
29
+ } if (rf & 2) {
30
+ const line_r5 = i0.ɵɵnextContext().$implicit;
31
+ i0.ɵɵproperty("line", line_r5);
32
+ } }
33
+ function ListScanBasketPreviewComponent_div_4_ng_miam_replace_item_2_Template(rf, ctx) { if (rf & 1) {
34
+ const _r15 = i0.ɵɵgetCurrentView();
35
+ i0.ɵɵelementStart(0, "ng-miam-replace-item", 12);
36
+ i0.ɵɵlistener("selected", function ListScanBasketPreviewComponent_div_4_ng_miam_replace_item_2_Template_ng_miam_replace_item_selected_0_listener() { i0.ɵɵrestoreView(_r15); const line_r5 = i0.ɵɵnextContext().$implicit; const ctx_r13 = i0.ɵɵnextContext(); return ctx_r13.toggleReplacing(line_r5); });
37
+ i0.ɵɵelementEnd();
38
+ } if (rf & 2) {
39
+ const line_r5 = i0.ɵɵnextContext().$implicit;
40
+ i0.ɵɵproperty("line", line_r5);
41
+ } }
42
+ function ListScanBasketPreviewComponent_div_4_Template(rf, ctx) { if (rf & 1) {
43
+ i0.ɵɵelementStart(0, "div");
44
+ i0.ɵɵtemplate(1, ListScanBasketPreviewComponent_div_4_ng_miam_basket_preview_line_1_Template, 1, 1, "ng-miam-basket-preview-line", 9);
45
+ i0.ɵɵtemplate(2, ListScanBasketPreviewComponent_div_4_ng_miam_replace_item_2_Template, 1, 1, "ng-miam-replace-item", 10);
46
+ i0.ɵɵelementEnd();
47
+ } if (rf & 2) {
48
+ const line_r5 = ctx.$implicit;
49
+ i0.ɵɵadvance(1);
50
+ i0.ɵɵproperty("ngIf", !line_r5.replacing);
51
+ i0.ɵɵadvance(1);
52
+ i0.ɵɵproperty("ngIf", line_r5.replacing);
53
+ } }
54
+ function ListScanBasketPreviewComponent_ng_miam_basket_preview_disabled_5_Template(rf, ctx) { if (rf & 1) {
55
+ i0.ɵɵelement(0, "ng-miam-basket-preview-disabled", 13);
56
+ } if (rf & 2) {
57
+ const ctx_r2 = i0.ɵɵnextContext();
58
+ i0.ɵɵproperty("entries", ctx_r2.unavailable);
59
+ } }
60
+ export class ListScanBasketPreviewComponent {
61
+ constructor(cdr, basketsService) {
62
+ this.cdr = cdr;
63
+ this.basketsService = basketsService;
64
+ this.entries = [];
65
+ this.closed = new EventEmitter();
66
+ this.icon = Icon;
67
+ this.lines = [];
68
+ this.unavailable = [];
69
+ this.subscriptions = [];
70
+ }
71
+ ngOnInit() {
72
+ const entriesIds = this.entries.map(e => e.id.toString());
73
+ this.subscriptions.push(this.basketsService.basketEntries().subscribe((basketEntries) => {
74
+ this.lines = basketEntries
75
+ .filter(be => entriesIds.includes(be.groceriesEntry.id) && be.groceriesEntryStatus === 'active' && be.selectedItem)
76
+ .map(be => BasketPreviewLine.fromBasketEntry(be));
77
+ this.unavailable = basketEntries
78
+ .filter(be => entriesIds.includes(be.groceriesEntry.id) && (be.groceriesEntryStatus !== 'active' || !be.selectedItem));
79
+ this.cdr.detectChanges();
80
+ }));
81
+ }
82
+ ngOnDestroy() {
83
+ this.subscriptions.forEach(s => s.unsubscribe());
84
+ }
85
+ close() {
86
+ this.closed.emit();
87
+ }
88
+ // Remove groceries entry from entries array, and line from lines array
89
+ deleteEntry(line) {
90
+ this.lines.splice(this.lines.indexOf(line), 1);
91
+ this.cdr.detectChanges();
92
+ const e = line.record.groceriesEntry;
93
+ this.entries.splice(this.entries.indexOf(e), 1);
94
+ this.subscriptions.push(e.delete().pipe(switchMap(() => this.basketsService.loadBasket())).subscribe());
95
+ }
96
+ toggleReplacing(line) {
97
+ // Recalculate basket entry price to avoid JS errors...
98
+ line.record.updateTotalPrice();
99
+ line['replacing'] = !line['replacing'];
100
+ this.cdr.detectChanges();
101
+ }
102
+ }
103
+ ListScanBasketPreviewComponent.ɵfac = function ListScanBasketPreviewComponent_Factory(t) { return new (t || ListScanBasketPreviewComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.BasketsService)); };
104
+ ListScanBasketPreviewComponent.ɵcmp = i0.ɵɵdefineComponent({ type: ListScanBasketPreviewComponent, selectors: [["ng-miam-list-scan-basket-preview"]], inputs: { overlay: "overlay", entries: "entries" }, outputs: { closed: "closed" }, decls: 10, vars: 4, consts: [["class", "miam-list-scan__drawer-padding", 3, "click", 4, "ngIf"], [1, "miam-list-scan__drawer-content"], [4, "ngFor", "ngForOf"], [3, "entries", 4, "ngIf"], [1, "miam-list-scan__drawer-controls"], [1, "m-button-primary", 3, "click"], ["width", "24", "height", "24", 3, "iconName"], [1, "miam-list-scan__drawer-padding", 3, "click"], ["width", "64", "height", "1", 3, "iconName"], [3, "line", "removed", "replaceItem", 4, "ngIf"], [3, "line", "selected", 4, "ngIf"], [3, "line", "removed", "replaceItem"], [3, "line", "selected"], [3, "entries"]], template: function ListScanBasketPreviewComponent_Template(rf, ctx) { if (rf & 1) {
105
+ i0.ɵɵtemplate(0, ListScanBasketPreviewComponent_div_0_Template, 2, 1, "div", 0);
106
+ i0.ɵɵelementStart(1, "div", 1);
107
+ i0.ɵɵelementStart(2, "h3");
108
+ i0.ɵɵtext(3, "Produits ajout\u00E9s");
109
+ i0.ɵɵelementEnd();
110
+ i0.ɵɵtemplate(4, ListScanBasketPreviewComponent_div_4_Template, 3, 2, "div", 2);
111
+ i0.ɵɵtemplate(5, ListScanBasketPreviewComponent_ng_miam_basket_preview_disabled_5_Template, 1, 1, "ng-miam-basket-preview-disabled", 3);
112
+ i0.ɵɵelementEnd();
113
+ i0.ɵɵelementStart(6, "div", 4);
114
+ i0.ɵɵelementStart(7, "button", 5);
115
+ i0.ɵɵlistener("click", function ListScanBasketPreviewComponent_Template_button_click_7_listener() { return ctx.close(); });
116
+ i0.ɵɵelement(8, "ng-miam-icon", 6);
117
+ i0.ɵɵtext(9, " Continuer mes courses ");
118
+ i0.ɵɵelementEnd();
119
+ i0.ɵɵelementEnd();
120
+ } if (rf & 2) {
121
+ i0.ɵɵproperty("ngIf", ctx.overlay);
122
+ i0.ɵɵadvance(4);
123
+ i0.ɵɵproperty("ngForOf", ctx.lines);
124
+ i0.ɵɵadvance(1);
125
+ i0.ɵɵproperty("ngIf", ctx.unavailable.length > 0);
126
+ i0.ɵɵadvance(3);
127
+ i0.ɵɵproperty("iconName", ctx.icon.Cart);
128
+ } }, directives: [i2.NgIf, i2.NgForOf, i3.IconComponent, i4.BasketPreviewLineComponent, i5.ReplaceItemComponent, i6.BasketPreviewDisabledComponent], styles: [""], encapsulation: 2, changeDetection: 0 });
129
+ /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(ListScanBasketPreviewComponent, [{
130
+ type: Component,
131
+ args: [{
132
+ selector: 'ng-miam-list-scan-basket-preview',
133
+ templateUrl: './basket-preview.component.html',
134
+ styleUrls: ['./basket-preview.component.scss'],
135
+ encapsulation: ViewEncapsulation.None,
136
+ changeDetection: ChangeDetectionStrategy.OnPush
137
+ }]
138
+ }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.BasketsService }]; }, { overlay: [{
139
+ type: Input
140
+ }], entries: [{
141
+ type: Input
142
+ }], closed: [{
143
+ type: Output
144
+ }] }); })();
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basket-preview.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/list-scan/basket-preview/basket-preview.component.ts","lib/_web-components/list-scan/basket-preview/basket-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewEncapsulation } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { BasketEntry, BasketPreviewLine } from '../../../_models';\nimport { GroceriesEntry } from '../../../_models/groceries-entry';\nimport { BasketsService } from '../../../_services';\nimport { Icon } from '../../../_types/icon.enum';\n\n@Component({\n  selector: 'ng-miam-list-scan-basket-preview',\n  templateUrl: './basket-preview.component.html',\n  styleUrls: ['./basket-preview.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ListScanBasketPreviewComponent implements OnInit, OnDestroy {\n  @Input() overlay;\n  @Input() entries: GroceriesEntry[] = [];\n  @Output() closed = new EventEmitter<any>();\n  icon = Icon;\n  lines: BasketPreviewLine[] = [];\n  unavailable: BasketEntry[] = [];\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private basketsService: BasketsService\n  ) { }\n\n  ngOnInit() {\n    const entriesIds = this.entries.map(e => e.id.toString());\n    this.subscriptions.push(this.basketsService.basketEntries().subscribe((basketEntries: BasketEntry[]) => {\n      this.lines = basketEntries\n        .filter(be => entriesIds.includes(be.groceriesEntry.id) && be.groceriesEntryStatus === 'active' && be.selectedItem)\n        .map(be => BasketPreviewLine.fromBasketEntry(be));\n      this.unavailable = basketEntries\n        .filter(be => entriesIds.includes(be.groceriesEntry.id) && (be.groceriesEntryStatus !== 'active' || !be.selectedItem));\n      this.cdr.detectChanges();\n    }));\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(s => s.unsubscribe());\n  }\n\n  close() {\n    this.closed.emit();\n  }\n\n  // Remove groceries entry from entries array, and line from lines array\n  deleteEntry(line: BasketPreviewLine) {\n    this.lines.splice(this.lines.indexOf(line), 1);\n    this.cdr.detectChanges();\n\n    const e = line.record.groceriesEntry;\n    this.entries.splice(this.entries.indexOf(e), 1);\n    this.subscriptions.push(\n      e.delete().pipe(\n        switchMap(() => this.basketsService.loadBasket())\n      ).subscribe()\n    );\n  }\n\n  toggleReplacing(line: BasketPreviewLine) {\n    // Recalculate basket entry price to avoid JS errors...\n    line.record.updateTotalPrice();\n    line['replacing'] = !line['replacing'];\n    this.cdr.detectChanges();\n  }\n}\n","<div *ngIf=\"overlay\" class=\"miam-list-scan__drawer-padding\" (click)=\"close()\">\n  <ng-miam-icon [iconName]=\"icon.DrawerHorizontalCloseBar\" width=\"64\" height=\"1\"></ng-miam-icon>\n</div>\n<div class=\"miam-list-scan__drawer-content\">\n  <h3>Produits ajoutés</h3>\n  <div *ngFor=\"let line of lines\">\n    <ng-miam-basket-preview-line\n      *ngIf=\"!line.replacing\"\n      [line]=\"line\"\n      (removed)=\"deleteEntry($event)\"\n      (replaceItem)=\"toggleReplacing(line)\"\n    ></ng-miam-basket-preview-line>\n    <ng-miam-replace-item\n      *ngIf=\"line.replacing\"\n      [line]=\"line\"\n      (selected)=\"toggleReplacing(line)\"\n    ></ng-miam-replace-item>\n  </div>\n  <ng-miam-basket-preview-disabled *ngIf=\"unavailable.length > 0\" [entries]=\"unavailable\"></ng-miam-basket-preview-disabled>\n</div>\n<div class=\"miam-list-scan__drawer-controls\">\n  <button class=\"m-button-primary\" (click)=\"close()\">\n    <ng-miam-icon [iconName]=\"icon.Cart\" width=\"24\" height=\"24\"></ng-miam-icon>\n    Continuer mes courses\n  </button>\n</div>"]}
@@ -0,0 +1,3 @@
1
+ export * from './list-scan.module';
2
+ export * from './list-scan.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiL2J1aWxkcy9taWFtL25nLW1pYW0tc2RrL3Byb2plY3RzL25nLW1pYW0vc3JjLyIsInNvdXJjZXMiOlsibGliL193ZWItY29tcG9uZW50cy9saXN0LXNjYW4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saXN0LXNjYW4ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC1zY2FuLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,150 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
2
+ import { forkJoin } from 'rxjs';
3
+ import { switchMap } from 'rxjs/operators';
4
+ import { BasketsService } from '../../../_services/baskets.service';
5
+ import { Icon } from '../../../_types/icon.enum';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../_services/baskets.service";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "../../../_components/icon/icon.component";
10
+ import * as i4 from "@angular/forms";
11
+ function ListScanIngredientsListComponent_div_0_Template(rf, ctx) { if (rf & 1) {
12
+ const _r3 = i0.ɵɵgetCurrentView();
13
+ i0.ɵɵelementStart(0, "div", 7);
14
+ i0.ɵɵlistener("click", function ListScanIngredientsListComponent_div_0_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r3); const ctx_r2 = i0.ɵɵnextContext(); return ctx_r2.cancel(); });
15
+ i0.ɵɵelement(1, "ng-miam-icon", 8);
16
+ i0.ɵɵelementEnd();
17
+ } if (rf & 2) {
18
+ const ctx_r0 = i0.ɵɵnextContext();
19
+ i0.ɵɵadvance(1);
20
+ i0.ɵɵproperty("iconName", ctx_r0.icon.DrawerHorizontalCloseBar);
21
+ } }
22
+ const _c0 = function (a0) { return { overlay: a0 }; };
23
+ function ListScanIngredientsListComponent_div_4_Template(rf, ctx) { if (rf & 1) {
24
+ const _r6 = i0.ɵɵgetCurrentView();
25
+ i0.ɵɵelementStart(0, "div", 9);
26
+ i0.ɵɵelementStart(1, "div", 10);
27
+ i0.ɵɵlistener("click", function ListScanIngredientsListComponent_div_4_Template_div_click_1_listener() { i0.ɵɵrestoreView(_r6); const e_r4 = ctx.$implicit; const ctx_r5 = i0.ɵɵnextContext(); return ctx_r5.deleteEntry(e_r4); });
28
+ i0.ɵɵelement(2, "ng-miam-icon", 11);
29
+ i0.ɵɵelementEnd();
30
+ i0.ɵɵelementStart(3, "div");
31
+ i0.ɵɵelementStart(4, "div", 12);
32
+ i0.ɵɵtext(5, "Nom");
33
+ i0.ɵɵelementEnd();
34
+ i0.ɵɵelementStart(6, "input", 13);
35
+ i0.ɵɵlistener("ngModelChange", function ListScanIngredientsListComponent_div_4_Template_input_ngModelChange_6_listener($event) { i0.ɵɵrestoreView(_r6); const e_r4 = ctx.$implicit; return e_r4.name = $event; });
36
+ i0.ɵɵelementEnd();
37
+ i0.ɵɵelementEnd();
38
+ i0.ɵɵelementStart(7, "div");
39
+ i0.ɵɵelementStart(8, "div", 12);
40
+ i0.ɵɵtext(9, "Quantit\u00E9");
41
+ i0.ɵɵelementEnd();
42
+ i0.ɵɵelementStart(10, "input", 14);
43
+ i0.ɵɵlistener("ngModelChange", function ListScanIngredientsListComponent_div_4_Template_input_ngModelChange_10_listener($event) { i0.ɵɵrestoreView(_r6); const e_r4 = ctx.$implicit; return e_r4.volume = $event; });
44
+ i0.ɵɵelementEnd();
45
+ i0.ɵɵelementEnd();
46
+ i0.ɵɵelementStart(11, "div");
47
+ i0.ɵɵelementStart(12, "div", 12);
48
+ i0.ɵɵtext(13, "Unit\u00E9");
49
+ i0.ɵɵelementEnd();
50
+ i0.ɵɵelementStart(14, "input", 13);
51
+ i0.ɵɵlistener("ngModelChange", function ListScanIngredientsListComponent_div_4_Template_input_ngModelChange_14_listener($event) { i0.ɵɵrestoreView(_r6); const e_r4 = ctx.$implicit; return e_r4.unit = $event; });
52
+ i0.ɵɵelementEnd();
53
+ i0.ɵɵelementEnd();
54
+ i0.ɵɵelementEnd();
55
+ } if (rf & 2) {
56
+ const e_r4 = ctx.$implicit;
57
+ const ctx_r1 = i0.ɵɵnextContext();
58
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(5, _c0, ctx_r1.overlay));
59
+ i0.ɵɵadvance(2);
60
+ i0.ɵɵproperty("iconName", ctx_r1.icon.Trash);
61
+ i0.ɵɵadvance(4);
62
+ i0.ɵɵproperty("ngModel", e_r4.name);
63
+ i0.ɵɵadvance(4);
64
+ i0.ɵɵproperty("ngModel", e_r4.volume);
65
+ i0.ɵɵadvance(4);
66
+ i0.ɵɵproperty("ngModel", e_r4.unit);
67
+ } }
68
+ export class ListScanIngredientsListComponent {
69
+ constructor(cdr, basketsService) {
70
+ this.cdr = cdr;
71
+ this.basketsService = basketsService;
72
+ this.entries = [];
73
+ this.closed = new EventEmitter();
74
+ this.confirmed = new EventEmitter();
75
+ this.icon = Icon;
76
+ this.subscriptions = [];
77
+ }
78
+ ngOnDestroy() {
79
+ this.subscriptions.forEach(s => s.unsubscribe());
80
+ }
81
+ deleteEntry(e) {
82
+ this.entries.splice(this.entries.indexOf(e), 1);
83
+ this.cdr.detectChanges();
84
+ e.delete();
85
+ }
86
+ cancel() {
87
+ if (this.entries.length === 0) {
88
+ return this.closed.emit();
89
+ }
90
+ this.subscriptions.push(forkJoin(this.entries.map(e => e.delete())).pipe(
91
+ // Reload the basket to make sure the injector receives the update
92
+ switchMap(() => this.basketsService.loadBasket())).subscribe(() => this.closed.emit()));
93
+ }
94
+ // Save modified entries, reload basket, and move to next step
95
+ confirm() {
96
+ if (this.entries.length === 0) {
97
+ return this.closed.emit();
98
+ }
99
+ this.subscriptions.push(forkJoin(this.entries.map(e => {
100
+ e.status = 'active'; // force reactivation of entry in case the name has changed (and was unavailable before)
101
+ return e.save();
102
+ })).pipe(switchMap(() => this.basketsService.loadBasket())).subscribe(() => this.confirmed.emit()));
103
+ }
104
+ }
105
+ ListScanIngredientsListComponent.ɵfac = function ListScanIngredientsListComponent_Factory(t) { return new (t || ListScanIngredientsListComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.BasketsService)); };
106
+ ListScanIngredientsListComponent.ɵcmp = i0.ɵɵdefineComponent({ type: ListScanIngredientsListComponent, selectors: [["ng-miam-list-scan-ingredients-list"]], inputs: { overlay: "overlay", entries: "entries" }, outputs: { closed: "closed", confirmed: "confirmed" }, decls: 11, vars: 3, consts: [["class", "miam-list-scan__drawer-padding", 3, "click", 4, "ngIf"], [1, "miam-list-scan__drawer-content"], ["class", "miam-list-scan__ingredients-list__entry", 3, "ngClass", 4, "ngFor", "ngForOf"], [1, "miam-list-scan__drawer-controls"], [1, "m-button-grey", 3, "click"], [1, "m-button-primary", 3, "click"], ["width", "24", "height", "24", 3, "iconName"], [1, "miam-list-scan__drawer-padding", 3, "click"], ["width", "64", "height", "1", 3, "iconName"], [1, "miam-list-scan__ingredients-list__entry", 3, "ngClass"], [3, "click"], ["primaryColor", "var(--m-color-grey-text)", 3, "iconName"], [1, "entry-label"], ["type", "text", 3, "ngModel", "ngModelChange"], ["type", "number", 3, "ngModel", "ngModelChange"]], template: function ListScanIngredientsListComponent_Template(rf, ctx) { if (rf & 1) {
107
+ i0.ɵɵtemplate(0, ListScanIngredientsListComponent_div_0_Template, 2, 1, "div", 0);
108
+ i0.ɵɵelementStart(1, "div", 1);
109
+ i0.ɵɵelementStart(2, "h3");
110
+ i0.ɵɵtext(3, "Ingr\u00E9dients scann\u00E9s");
111
+ i0.ɵɵelementEnd();
112
+ i0.ɵɵtemplate(4, ListScanIngredientsListComponent_div_4_Template, 15, 7, "div", 2);
113
+ i0.ɵɵelementEnd();
114
+ i0.ɵɵelementStart(5, "div", 3);
115
+ i0.ɵɵelementStart(6, "button", 4);
116
+ i0.ɵɵlistener("click", function ListScanIngredientsListComponent_Template_button_click_6_listener() { return ctx.cancel(); });
117
+ i0.ɵɵtext(7, "Annuler");
118
+ i0.ɵɵelementEnd();
119
+ i0.ɵɵelementStart(8, "button", 5);
120
+ i0.ɵɵlistener("click", function ListScanIngredientsListComponent_Template_button_click_8_listener() { return ctx.confirm(); });
121
+ i0.ɵɵelement(9, "ng-miam-icon", 6);
122
+ i0.ɵɵtext(10, " Mettre au panier ");
123
+ i0.ɵɵelementEnd();
124
+ i0.ɵɵelementEnd();
125
+ } if (rf & 2) {
126
+ i0.ɵɵproperty("ngIf", ctx.overlay);
127
+ i0.ɵɵadvance(4);
128
+ i0.ɵɵproperty("ngForOf", ctx.entries);
129
+ i0.ɵɵadvance(5);
130
+ i0.ɵɵproperty("iconName", ctx.icon.CartPlus);
131
+ } }, directives: [i2.NgIf, i2.NgForOf, i3.IconComponent, i2.NgClass, i4.DefaultValueAccessor, i4.NgControlStatus, i4.NgModel, i4.NumberValueAccessor], styles: [".miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry{display:flex;margin-bottom:8px;width:100%}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry>*{display:flex;flex:1;flex-direction:column}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry>:first-child{cursor:pointer;display:flex;justify-content:center;padding-top:12px}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry>:nth-child(2){flex:6;margin-right:8px}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry>:last-child{flex:2;margin-left:8px}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry>* .entry-label{font-size:11px}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry>* input{border:1px solid #d3d3d3;border-radius:4px;color:var(--m-color-grey-text-dark);padding:8px;width:100%}.miam-list-scan__drawer-content .miam-list-scan__ingredients-list__entry.overlay>:first-child{align-items:flex-start}"], encapsulation: 2, changeDetection: 0 });
132
+ /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(ListScanIngredientsListComponent, [{
133
+ type: Component,
134
+ args: [{
135
+ selector: 'ng-miam-list-scan-ingredients-list',
136
+ templateUrl: './ingredients-list.component.html',
137
+ styleUrls: ['./ingredients-list.component.scss'],
138
+ encapsulation: ViewEncapsulation.None,
139
+ changeDetection: ChangeDetectionStrategy.OnPush
140
+ }]
141
+ }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.BasketsService }]; }, { overlay: [{
142
+ type: Input
143
+ }], entries: [{
144
+ type: Input
145
+ }], closed: [{
146
+ type: Output
147
+ }], confirmed: [{
148
+ type: Output
149
+ }] }); })();
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ingredients-list.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/list-scan/ingredients-list/ingredients-list.component.ts","lib/_web-components/list-scan/ingredients-list/ingredients-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewEncapsulation } from '@angular/core';\nimport { forkJoin, Subscription } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { GroceriesEntry } from '../../../_models/groceries-entry';\nimport { BasketsService } from '../../../_services/baskets.service';\nimport { Icon } from '../../../_types/icon.enum';\n\n@Component({\n  selector: 'ng-miam-list-scan-ingredients-list',\n  templateUrl: './ingredients-list.component.html',\n  styleUrls: ['./ingredients-list.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ListScanIngredientsListComponent implements OnDestroy {\n  @Input() overlay: boolean;\n  @Input() entries: GroceriesEntry[] = [];\n  @Output() closed = new EventEmitter<any>();\n  @Output() confirmed = new EventEmitter<any>();\n  icon = Icon;\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private basketsService: BasketsService\n  ) { }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(s => s.unsubscribe());\n  }\n\n  deleteEntry(e: GroceriesEntry) {\n    this.entries.splice(this.entries.indexOf(e), 1);\n    this.cdr.detectChanges();\n    e.delete();\n  }\n\n  cancel() {\n    if (this.entries.length === 0) {\n      return this.closed.emit();\n    }\n\n    this.subscriptions.push(\n      forkJoin(this.entries.map(e => e.delete())).pipe(\n        // Reload the basket to make sure the injector receives the update\n        switchMap(() => this.basketsService.loadBasket())\n      ).subscribe(\n        () => this.closed.emit()\n      )\n    );\n  }\n\n  // Save modified entries, reload basket, and move to next step\n  confirm() {\n    if (this.entries.length === 0) {\n      return this.closed.emit();\n    }\n\n    this.subscriptions.push(\n      forkJoin(this.entries.map(e => {\n        e.status = 'active'; // force reactivation of entry in case the name has changed (and was unavailable before)\n        return e.save();\n      })).pipe(\n        switchMap(() => this.basketsService.loadBasket())\n      ).subscribe(() => this.confirmed.emit())\n    );\n  }\n}\n","<div *ngIf=\"overlay\" class=\"miam-list-scan__drawer-padding\" (click)=\"cancel()\">\n  <ng-miam-icon [iconName]=\"icon.DrawerHorizontalCloseBar\" width=\"64\" height=\"1\"></ng-miam-icon>\n</div>\n<div class=\"miam-list-scan__drawer-content\">\n  <h3>Ingrédients scannés</h3>\n  <div *ngFor=\"let e of entries\" class=\"miam-list-scan__ingredients-list__entry\" [ngClass]=\"{ overlay: overlay }\">\n    <div (click)=\"deleteEntry(e)\">\n      <ng-miam-icon [iconName]=\"icon.Trash\" primaryColor=\"var(--m-color-grey-text)\"></ng-miam-icon>\n    </div>\n    <div>\n      <div class=\"entry-label\">Nom</div>\n      <input type=\"text\" [(ngModel)]=\"e.name\">\n    </div>\n    <div>\n      <div class=\"entry-label\">Quantité</div>\n      <input type=\"number\" [(ngModel)]=\"e.volume\">\n    </div>\n    <div>\n      <div class=\"entry-label\">Unité</div>\n      <input type=\"text\" [(ngModel)]=\"e.unit\">\n    </div>\n  </div>\n</div>\n\n<div class=\"miam-list-scan__drawer-controls\">\n  <button class=\"m-button-grey\" (click)=\"cancel()\">Annuler</button>\n  <button class=\"m-button-primary\" (click)=\"confirm()\">\n    <ng-miam-icon [iconName]=\"icon.CartPlus\" width=\"24\" height=\"24\"></ng-miam-icon>\n    Mettre au panier\n  </button>\n</div>"]}
@@ -0,0 +1,87 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "./overlay-button/overlay-button.component";
5
+ import * as i3 from "./ingredients-list/ingredients-list.component";
6
+ import * as i4 from "./basket-preview/basket-preview.component";
7
+ function ListScanComponent_ng_miam_list_scan_overlay_button_1_Template(rf, ctx) { if (rf & 1) {
8
+ const _r4 = i0.ɵɵgetCurrentView();
9
+ i0.ɵɵelementStart(0, "ng-miam-list-scan-overlay-button", 4);
10
+ i0.ɵɵlistener("entriesAdded", function ListScanComponent_ng_miam_list_scan_overlay_button_1_Template_ng_miam_list_scan_overlay_button_entriesAdded_0_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r3 = i0.ɵɵnextContext(); return ctx_r3.showIngredients($event); });
11
+ i0.ɵɵelementEnd();
12
+ } if (rf & 2) {
13
+ const ctx_r0 = i0.ɵɵnextContext();
14
+ i0.ɵɵproperty("overlay", ctx_r0.overlay);
15
+ } }
16
+ const _c0 = function (a0) { return { overlay: a0 }; };
17
+ function ListScanComponent_ng_miam_list_scan_ingredients_list_2_Template(rf, ctx) { if (rf & 1) {
18
+ const _r6 = i0.ɵɵgetCurrentView();
19
+ i0.ɵɵelementStart(0, "ng-miam-list-scan-ingredients-list", 5);
20
+ i0.ɵɵlistener("closed", function ListScanComponent_ng_miam_list_scan_ingredients_list_2_Template_ng_miam_list_scan_ingredients_list_closed_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r5 = i0.ɵɵnextContext(); return ctx_r5.hideIngredients(); })("confirmed", function ListScanComponent_ng_miam_list_scan_ingredients_list_2_Template_ng_miam_list_scan_ingredients_list_confirmed_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r7 = i0.ɵɵnextContext(); return ctx_r7.showBasketPreview(); });
21
+ i0.ɵɵelementEnd();
22
+ } if (rf & 2) {
23
+ const ctx_r1 = i0.ɵɵnextContext();
24
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c0, ctx_r1.overlay))("overlay", ctx_r1.overlay)("entries", ctx_r1.entries);
25
+ } }
26
+ function ListScanComponent_ng_miam_list_scan_basket_preview_3_Template(rf, ctx) { if (rf & 1) {
27
+ const _r9 = i0.ɵɵgetCurrentView();
28
+ i0.ɵɵelementStart(0, "ng-miam-list-scan-basket-preview", 6);
29
+ i0.ɵɵlistener("closed", function ListScanComponent_ng_miam_list_scan_basket_preview_3_Template_ng_miam_list_scan_basket_preview_closed_0_listener() { i0.ɵɵrestoreView(_r9); const ctx_r8 = i0.ɵɵnextContext(); return ctx_r8.hideBasketPreview(); });
30
+ i0.ɵɵelementEnd();
31
+ } if (rf & 2) {
32
+ const ctx_r2 = i0.ɵɵnextContext();
33
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c0, ctx_r2.overlay))("overlay", ctx_r2.overlay)("entries", ctx_r2.entries);
34
+ } }
35
+ export class ListScanComponent {
36
+ constructor(cdr) {
37
+ this.cdr = cdr;
38
+ this.overlay = true;
39
+ this.entries = [];
40
+ this.ingredientsShown = false;
41
+ this.basketPreviewShown = false;
42
+ }
43
+ showIngredients(newEntries) {
44
+ this.entries = newEntries;
45
+ this.ingredientsShown = true;
46
+ this.cdr.detectChanges();
47
+ }
48
+ hideIngredients() {
49
+ this.ingredientsShown = false;
50
+ this.cdr.detectChanges();
51
+ }
52
+ showBasketPreview() {
53
+ this.basketPreviewShown = true;
54
+ this.hideIngredients();
55
+ }
56
+ hideBasketPreview() {
57
+ this.basketPreviewShown = false;
58
+ this.cdr.detectChanges();
59
+ }
60
+ }
61
+ ListScanComponent.ɵfac = function ListScanComponent_Factory(t) { return new (t || ListScanComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
62
+ ListScanComponent.ɵcmp = i0.ɵɵdefineComponent({ type: ListScanComponent, selectors: [["ng-miam-list-scan"]], inputs: { overlay: "overlay" }, decls: 4, vars: 3, consts: [[1, "miam-list-scan"], [3, "overlay", "entriesAdded", 4, "ngIf"], ["class", "miam-list-scan__drawer", 3, "ngClass", "overlay", "entries", "closed", "confirmed", 4, "ngIf"], ["class", "miam-list-scan__drawer", 3, "ngClass", "overlay", "entries", "closed", 4, "ngIf"], [3, "overlay", "entriesAdded"], [1, "miam-list-scan__drawer", 3, "ngClass", "overlay", "entries", "closed", "confirmed"], [1, "miam-list-scan__drawer", 3, "ngClass", "overlay", "entries", "closed"]], template: function ListScanComponent_Template(rf, ctx) { if (rf & 1) {
63
+ i0.ɵɵelementStart(0, "div", 0);
64
+ i0.ɵɵtemplate(1, ListScanComponent_ng_miam_list_scan_overlay_button_1_Template, 1, 1, "ng-miam-list-scan-overlay-button", 1);
65
+ i0.ɵɵtemplate(2, ListScanComponent_ng_miam_list_scan_ingredients_list_2_Template, 1, 5, "ng-miam-list-scan-ingredients-list", 2);
66
+ i0.ɵɵtemplate(3, ListScanComponent_ng_miam_list_scan_basket_preview_3_Template, 1, 5, "ng-miam-list-scan-basket-preview", 3);
67
+ i0.ɵɵelementEnd();
68
+ } if (rf & 2) {
69
+ i0.ɵɵadvance(1);
70
+ i0.ɵɵproperty("ngIf", !ctx.ingredientsShown && !ctx.basketPreviewShown);
71
+ i0.ɵɵadvance(1);
72
+ i0.ɵɵproperty("ngIf", ctx.ingredientsShown);
73
+ i0.ɵɵadvance(1);
74
+ i0.ɵɵproperty("ngIf", ctx.basketPreviewShown);
75
+ } }, directives: [i1.NgIf, i2.ListScanOverlayButtonComponent, i3.ListScanIngredientsListComponent, i1.NgClass, i4.ListScanBasketPreviewComponent], styles: [".miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%]{border-top-left-radius:35px;border-top-right-radius:35px;position:relative;width:100%}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer.overlay[_ngcontent-%COMP%]{background-color:#fff;bottom:0;height:97%;left:0;position:fixed}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%] .miam-list-scan__drawer-padding{align-items:flex-end;display:flex;height:22px;justify-content:center;padding-bottom:6px}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%] .miam-list-scan__drawer-content{height:calc(100% - 71px);overflow-y:auto;padding:0 16px;width:100%}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%] .miam-list-scan__drawer-controls{display:flex;width:100%}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%] .miam-list-scan__drawer-controls>button{border:none;border-radius:0;flex:1;height:50px;padding:13px 8px}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%] .miam-list-scan__drawer-controls>button:first-child{border-top:1px solid #d3d3d3}.miam-list-scan[_ngcontent-%COMP%] .miam-list-scan__drawer[_ngcontent-%COMP%] .miam-list-scan__drawer-controls ng-miam-icon{margin-left:0;margin-right:6px}"], changeDetection: 0 });
76
+ /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(ListScanComponent, [{
77
+ type: Component,
78
+ args: [{
79
+ selector: 'ng-miam-list-scan',
80
+ templateUrl: './list-scan.component.html',
81
+ styleUrls: ['./list-scan.component.scss'],
82
+ changeDetection: ChangeDetectionStrategy.OnPush
83
+ }]
84
+ }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { overlay: [{
85
+ type: Input
86
+ }] }); })();
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1zY2FuLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIvYnVpbGRzL21pYW0vbmctbWlhbS1zZGsvcHJvamVjdHMvbmctbWlhbS9zcmMvIiwic291cmNlcyI6WyJsaWIvX3dlYi1jb21wb25lbnRzL2xpc3Qtc2Nhbi9saXN0LXNjYW4uY29tcG9uZW50LnRzIiwibGliL193ZWItY29tcG9uZW50cy9saXN0LXNjYW4vbGlzdC1zY2FuLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7OztJQ0MzRiwyREFDbUM7SUFEb0UsMlFBQXdDO0lBQy9JLGlCQUFtQzs7O0lBRGdELHdDQUFtQjs7Ozs7SUFHdEcsNkRBU3FDO0lBSG5DLHVQQUE0QixrUEFBQTtJQUc5QixpQkFBcUM7OztJQU5uQyxvRUFBZ0MsMkJBQUEsMkJBQUE7Ozs7SUFRbEMsMkRBUW1DO0lBRmpDLHFQQUE4QjtJQUVoQyxpQkFBbUM7OztJQUxqQyxvRUFBZ0MsMkJBQUEsMkJBQUE7O0FEVHBDLE1BQU0sT0FBTyxpQkFBaUI7SUFNNUIsWUFDVSxHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQU52QixZQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLFlBQU8sR0FBcUIsRUFBRSxDQUFDO1FBQy9CLHFCQUFnQixHQUFHLEtBQUssQ0FBQztRQUN6Qix1QkFBa0IsR0FBRyxLQUFLLENBQUM7SUFJdkIsQ0FBQztJQUVMLGVBQWUsQ0FBQyxVQUE0QjtRQUMxQyxJQUFJLENBQUMsT0FBTyxHQUFHLFVBQVUsQ0FBQztRQUMxQixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO1FBQzdCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsS0FBSyxDQUFDO1FBQzlCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELGlCQUFpQjtRQUNmLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUM7UUFDL0IsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxpQkFBaUI7UUFDZixJQUFJLENBQUMsa0JBQWtCLEdBQUcsS0FBSyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7a0ZBN0JVLGlCQUFpQjtzREFBakIsaUJBQWlCO1FDVDlCLDhCQUNFO1FBQUEsNEhBQ0E7UUFFQSxnSUFTQTtRQUVBLDRIQVFBO1FBQ0YsaUJBQU07O1FBdkI4QixlQUFnRDtRQUFoRCx1RUFBZ0Q7UUFJaEYsZUFBd0I7UUFBeEIsMkNBQXdCO1FBV3hCLGVBQTBCO1FBQTFCLDZDQUEwQjs7a0REUGpCLGlCQUFpQjtjQU43QixTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtnQkFDN0IsV0FBVyxFQUFFLDRCQUE0QjtnQkFDekMsU0FBUyxFQUFFLENBQUMsNEJBQTRCLENBQUM7Z0JBQ3pDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2FBQ2hEO29FQUVVLE9BQU87a0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgR3JvY2VyaWVzRW50cnkgfSBmcm9tICcuLi8uLi9fbW9kZWxzL2dyb2Nlcmllcy1lbnRyeSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25nLW1pYW0tbGlzdC1zY2FuJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2xpc3Qtc2Nhbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2xpc3Qtc2Nhbi5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBMaXN0U2NhbkNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIG92ZXJsYXkgPSB0cnVlO1xuICBlbnRyaWVzOiBHcm9jZXJpZXNFbnRyeVtdID0gW107XG4gIGluZ3JlZGllbnRzU2hvd24gPSBmYWxzZTtcbiAgYmFza2V0UHJldmlld1Nob3duID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmXG4gICkgeyB9XG5cbiAgc2hvd0luZ3JlZGllbnRzKG5ld0VudHJpZXM6IEdyb2Nlcmllc0VudHJ5W10pIHtcbiAgICB0aGlzLmVudHJpZXMgPSBuZXdFbnRyaWVzO1xuICAgIHRoaXMuaW5ncmVkaWVudHNTaG93biA9IHRydWU7XG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgaGlkZUluZ3JlZGllbnRzKCkge1xuICAgIHRoaXMuaW5ncmVkaWVudHNTaG93biA9IGZhbHNlO1xuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIHNob3dCYXNrZXRQcmV2aWV3KCkge1xuICAgIHRoaXMuYmFza2V0UHJldmlld1Nob3duID0gdHJ1ZTtcbiAgICB0aGlzLmhpZGVJbmdyZWRpZW50cygpO1xuICB9XG5cbiAgaGlkZUJhc2tldFByZXZpZXcoKSB7XG4gICAgdGhpcy5iYXNrZXRQcmV2aWV3U2hvd24gPSBmYWxzZTtcbiAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJtaWFtLWxpc3Qtc2NhblwiPlxuICA8bmctbWlhbS1saXN0LXNjYW4tb3ZlcmxheS1idXR0b24gKm5nSWY9XCIhaW5ncmVkaWVudHNTaG93biAmJiAhYmFza2V0UHJldmlld1Nob3duXCIgW292ZXJsYXldPVwib3ZlcmxheVwiIChlbnRyaWVzQWRkZWQpPVwic2hvd0luZ3JlZGllbnRzKCRldmVudClcIj5cbiAgPC9uZy1taWFtLWxpc3Qtc2Nhbi1vdmVybGF5LWJ1dHRvbj5cblxuICA8bmctbWlhbS1saXN0LXNjYW4taW5ncmVkaWVudHMtbGlzdFxuICAgICpuZ0lmPVwiaW5ncmVkaWVudHNTaG93blwiXG4gICAgY2xhc3M9XCJtaWFtLWxpc3Qtc2Nhbl9fZHJhd2VyXCJcbiAgICBbbmdDbGFzc109XCJ7IG92ZXJsYXk6IG92ZXJsYXkgfVwiXG4gICAgW292ZXJsYXldPVwib3ZlcmxheVwiXG4gICAgW2VudHJpZXNdPVwiZW50cmllc1wiXG4gICAgKGNsb3NlZCk9XCJoaWRlSW5ncmVkaWVudHMoKVwiXG4gICAgKGNvbmZpcm1lZCk9XCJzaG93QmFza2V0UHJldmlldygpXCJcbiAgPlxuICA8L25nLW1pYW0tbGlzdC1zY2FuLWluZ3JlZGllbnRzLWxpc3Q+XG5cbiAgPG5nLW1pYW0tbGlzdC1zY2FuLWJhc2tldC1wcmV2aWV3XG4gICAgKm5nSWY9XCJiYXNrZXRQcmV2aWV3U2hvd25cIlxuICAgIGNsYXNzPVwibWlhbS1saXN0LXNjYW5fX2RyYXdlclwiXG4gICAgW25nQ2xhc3NdPVwieyBvdmVybGF5OiBvdmVybGF5IH1cIlxuICAgIFtvdmVybGF5XT1cIm92ZXJsYXlcIlxuICAgIFtlbnRyaWVzXT1cImVudHJpZXNcIlxuICAgIChjbG9zZWQpPVwiaGlkZUJhc2tldFByZXZpZXcoKVwiXG4gID5cbiAgPC9uZy1taWFtLWxpc3Qtc2Nhbi1iYXNrZXQtcHJldmlldz5cbjwvZGl2PiJdfQ==
@@ -0,0 +1,60 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Injector, NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { createCustomElement } from '@angular/elements';
5
+ import { ComponentsModule } from '../../_components';
6
+ import { ListScanComponent } from './list-scan.component';
7
+ import { ListScanBasketPreviewComponent } from './basket-preview/basket-preview.component';
8
+ import { ListScanIngredientsListComponent } from './ingredients-list/ingredients-list.component';
9
+ import { ListScanOverlayButtonComponent } from './overlay-button/overlay-button.component';
10
+ import { BasketPreviewModule } from '../basket-preview/basket-preview.module';
11
+ import { LoaderModule } from '../../_web-components/loader/loader.module';
12
+ import * as i0 from "@angular/core";
13
+ export class ListScanModule {
14
+ // Create custom elements so the WebComponents can be interpreted by the browser regardless of the js framework used
15
+ constructor(injector) {
16
+ // Avoid duplicate error
17
+ if (!customElements.get('webc-miam-list-scan')) {
18
+ const ngElement = createCustomElement(ListScanComponent, { injector });
19
+ customElements.define('webc-miam-list-scan', ngElement);
20
+ }
21
+ }
22
+ }
23
+ ListScanModule.ɵmod = i0.ɵɵdefineNgModule({ type: ListScanModule });
24
+ ListScanModule.ɵinj = i0.ɵɵdefineInjector({ factory: function ListScanModule_Factory(t) { return new (t || ListScanModule)(i0.ɵɵinject(i0.Injector)); }, imports: [[
25
+ CommonModule,
26
+ FormsModule,
27
+ ComponentsModule,
28
+ BasketPreviewModule,
29
+ LoaderModule
30
+ ]] });
31
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(ListScanModule, { declarations: [ListScanComponent,
32
+ ListScanOverlayButtonComponent,
33
+ ListScanIngredientsListComponent,
34
+ ListScanBasketPreviewComponent], imports: [CommonModule,
35
+ FormsModule,
36
+ ComponentsModule,
37
+ BasketPreviewModule,
38
+ LoaderModule], exports: [ListScanComponent] }); })();
39
+ /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(ListScanModule, [{
40
+ type: NgModule,
41
+ args: [{
42
+ imports: [
43
+ CommonModule,
44
+ FormsModule,
45
+ ComponentsModule,
46
+ BasketPreviewModule,
47
+ LoaderModule
48
+ ],
49
+ declarations: [
50
+ ListScanComponent,
51
+ ListScanOverlayButtonComponent,
52
+ ListScanIngredientsListComponent,
53
+ ListScanBasketPreviewComponent
54
+ ],
55
+ exports: [
56
+ ListScanComponent
57
+ ]
58
+ }]
59
+ }], function () { return [{ type: i0.Injector }]; }, null); })();
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1zY2FuLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIvYnVpbGRzL21pYW0vbmctbWlhbS1zZGsvcHJvamVjdHMvbmctbWlhbS9zcmMvIiwic291cmNlcyI6WyJsaWIvX3dlYi1jb21wb25lbnRzL2xpc3Qtc2Nhbi9saXN0LXNjYW4ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDeEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDckQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDM0YsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDakcsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDM0YsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRDQUE0QyxDQUFDOztBQW9CMUUsTUFBTSxPQUFPLGNBQWM7SUFDekIsb0hBQW9IO0lBQ3BILFlBQ0UsUUFBa0I7UUFFbEIsd0JBQXdCO1FBQ3hCLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLHFCQUFxQixDQUFDLEVBQUU7WUFDOUMsTUFBTSxTQUFTLEdBQUcsbUJBQW1CLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQ3ZFLGNBQWMsQ0FBQyxNQUFNLENBQUMscUJBQXFCLEVBQUUsU0FBUyxDQUFDLENBQUM7U0FDekQ7SUFDSCxDQUFDOztrREFWVSxjQUFjOzJHQUFkLGNBQWMsMENBakJoQjtZQUNQLFlBQVk7WUFDWixXQUFXO1lBQ1gsZ0JBQWdCO1lBQ2hCLG1CQUFtQjtZQUNuQixZQUFZO1NBQ2I7d0ZBV1UsY0FBYyxtQkFUdkIsaUJBQWlCO1FBQ2pCLDhCQUE4QjtRQUM5QixnQ0FBZ0M7UUFDaEMsOEJBQThCLGFBVjlCLFlBQVk7UUFDWixXQUFXO1FBQ1gsZ0JBQWdCO1FBQ2hCLG1CQUFtQjtRQUNuQixZQUFZLGFBU1osaUJBQWlCO2tEQUdSLGNBQWM7Y0FsQjFCLFFBQVE7ZUFBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixXQUFXO29CQUNYLGdCQUFnQjtvQkFDaEIsbUJBQW1CO29CQUNuQixZQUFZO2lCQUNiO2dCQUNELFlBQVksRUFBRTtvQkFDWixpQkFBaUI7b0JBQ2pCLDhCQUE4QjtvQkFDOUIsZ0NBQWdDO29CQUNoQyw4QkFBOEI7aUJBQy9CO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxpQkFBaUI7aUJBQ2xCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgSW5qZWN0b3IsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IGNyZWF0ZUN1c3RvbUVsZW1lbnQgfSBmcm9tICdAYW5ndWxhci9lbGVtZW50cyc7XG5pbXBvcnQgeyBDb21wb25lbnRzTW9kdWxlIH0gZnJvbSAnLi4vLi4vX2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgTGlzdFNjYW5Db21wb25lbnQgfSBmcm9tICcuL2xpc3Qtc2Nhbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGlzdFNjYW5CYXNrZXRQcmV2aWV3Q29tcG9uZW50IH0gZnJvbSAnLi9iYXNrZXQtcHJldmlldy9iYXNrZXQtcHJldmlldy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGlzdFNjYW5JbmdyZWRpZW50c0xpc3RDb21wb25lbnQgfSBmcm9tICcuL2luZ3JlZGllbnRzLWxpc3QvaW5ncmVkaWVudHMtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGlzdFNjYW5PdmVybGF5QnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9vdmVybGF5LWJ1dHRvbi9vdmVybGF5LWJ1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFza2V0UHJldmlld01vZHVsZSB9IGZyb20gJy4uL2Jhc2tldC1wcmV2aWV3L2Jhc2tldC1wcmV2aWV3Lm1vZHVsZSc7XG5pbXBvcnQgeyBMb2FkZXJNb2R1bGUgfSBmcm9tICcuLi8uLi9fd2ViLWNvbXBvbmVudHMvbG9hZGVyL2xvYWRlci5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIENvbXBvbmVudHNNb2R1bGUsXG4gICAgQmFza2V0UHJldmlld01vZHVsZSxcbiAgICBMb2FkZXJNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgTGlzdFNjYW5Db21wb25lbnQsXG4gICAgTGlzdFNjYW5PdmVybGF5QnV0dG9uQ29tcG9uZW50LFxuICAgIExpc3RTY2FuSW5ncmVkaWVudHNMaXN0Q29tcG9uZW50LFxuICAgIExpc3RTY2FuQmFza2V0UHJldmlld0NvbXBvbmVudFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgTGlzdFNjYW5Db21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBMaXN0U2Nhbk1vZHVsZSB7XG4gIC8vIENyZWF0ZSBjdXN0b20gZWxlbWVudHMgc28gdGhlIFdlYkNvbXBvbmVudHMgY2FuIGJlIGludGVycHJldGVkIGJ5IHRoZSBicm93c2VyIHJlZ2FyZGxlc3Mgb2YgdGhlIGpzIGZyYW1ld29yayB1c2VkXG4gIGNvbnN0cnVjdG9yKFxuICAgIGluamVjdG9yOiBJbmplY3RvcixcbiAgKSB7XG4gICAgLy8gQXZvaWQgZHVwbGljYXRlIGVycm9yXG4gICAgaWYgKCFjdXN0b21FbGVtZW50cy5nZXQoJ3dlYmMtbWlhbS1saXN0LXNjYW4nKSkge1xuICAgICAgY29uc3QgbmdFbGVtZW50ID0gY3JlYXRlQ3VzdG9tRWxlbWVudChMaXN0U2NhbkNvbXBvbmVudCwgeyBpbmplY3RvciB9KTtcbiAgICAgIGN1c3RvbUVsZW1lbnRzLmRlZmluZSgnd2ViYy1taWFtLWxpc3Qtc2NhbicsIG5nRWxlbWVudCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -0,0 +1,104 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { GroceriesListsService } from '../../../_services';
3
+ import { Icon } from '../../../_types/icon.enum';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../../_services";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "../../../_components/icon/icon.component";
8
+ import * as i4 from "../../loader/loader.component";
9
+ function ListScanOverlayButtonComponent_ng_miam_icon_3_Template(rf, ctx) { if (rf & 1) {
10
+ i0.ɵɵelement(0, "ng-miam-icon", 9);
11
+ } if (rf & 2) {
12
+ const ctx_r0 = i0.ɵɵnextContext();
13
+ i0.ɵɵproperty("iconName", ctx_r0.icon.ListScanner);
14
+ } }
15
+ const _c0 = function (a0) { return { reduced: a0 }; };
16
+ function ListScanOverlayButtonComponent_div_4_Template(rf, ctx) { if (rf & 1) {
17
+ i0.ɵɵelementStart(0, "div", 10);
18
+ i0.ɵɵtext(1, "Scanner ma liste de courses");
19
+ i0.ɵɵelementEnd();
20
+ } if (rf & 2) {
21
+ const ctx_r1 = i0.ɵɵnextContext();
22
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(1, _c0, ctx_r1.reduced == "true"));
23
+ } }
24
+ function ListScanOverlayButtonComponent_ng_miam_loader_5_Template(rf, ctx) { if (rf & 1) {
25
+ i0.ɵɵelement(0, "ng-miam-loader");
26
+ } }
27
+ const _c1 = function (a0) { return { overlay: a0 }; };
28
+ export class ListScanOverlayButtonComponent {
29
+ constructor(cdr, listsService) {
30
+ this.cdr = cdr;
31
+ this.listsService = listsService;
32
+ this.entriesAdded = new EventEmitter();
33
+ this.icon = Icon;
34
+ this.reduced = localStorage.getItem('_miam/listScanner/button-reduced') || 'false';
35
+ this.loading = false;
36
+ }
37
+ toggleReduce(value) {
38
+ this.reduced = value;
39
+ localStorage.setItem('_miam/listScanner/button-reduced', this.reduced);
40
+ this.cdr.detectChanges();
41
+ }
42
+ // Pushes a picture file and refreshes list
43
+ // Finally, triggers entries added event, returning all entries not related to any recipe
44
+ sendFile(event) {
45
+ const file = event.target.files.item(0);
46
+ if (!file) {
47
+ return;
48
+ }
49
+ this.loading = true;
50
+ this.cdr.detectChanges();
51
+ this.listsService.addEntriesFromPicture(file, ['groceries-entries']).subscribe(list => {
52
+ const addedEntries = list.entries.data.filter(entry => !entry.recipesIds || entry.recipesIds.length === 0);
53
+ this.loading = false;
54
+ this.entriesAdded.emit(addedEntries);
55
+ });
56
+ }
57
+ }
58
+ ListScanOverlayButtonComponent.ɵfac = function ListScanOverlayButtonComponent_Factory(t) { return new (t || ListScanOverlayButtonComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.GroceriesListsService)); };
59
+ ListScanOverlayButtonComponent.ɵcmp = i0.ɵɵdefineComponent({ type: ListScanOverlayButtonComponent, selectors: [["ng-miam-list-scan-overlay-button"]], inputs: { overlay: "overlay" }, outputs: { entriesAdded: "entriesAdded" }, decls: 9, vars: 10, consts: [[1, "miam-list-scan__overlay-button", 3, "ngClass"], ["type", "file", "name", "file", "id", "file", "accept", "image/*", "capture", "environment", 1, "inputfile", 3, "disabled", "change"], ["for", "file", 1, "m-button", "m-button-primary", "miam-list-scan__overlay-button__label", 3, "click"], ["width", "24", 3, "iconName", 4, "ngIf"], ["class", "button-label", 3, "ngClass", 4, "ngIf"], [4, "ngIf"], [1, "miam-list-scan__overlay-button__reduce", 3, "ngClass", "click"], ["width", "24", "height", "24", "viewBox", "0 0 24 24", "fill", "none", "xmlns", "http://www.w3.org/2000/svg"], ["d", "M9.91957 12L5.95977 8.0402L7.93967 6.0603L11.8995 10.0201L15.8593 6.0603L17.8392 8.0402L13.8794 12L17.8392 15.9598L15.8593 17.9397L11.8995 13.9799L7.93967 17.9397L5.95977 15.9598L9.91957 12Z", "fill", "#676767"], ["width", "24", 3, "iconName"], [1, "button-label", 3, "ngClass"]], template: function ListScanOverlayButtonComponent_Template(rf, ctx) { if (rf & 1) {
60
+ i0.ɵɵelementStart(0, "div", 0);
61
+ i0.ɵɵelementStart(1, "input", 1);
62
+ i0.ɵɵlistener("change", function ListScanOverlayButtonComponent_Template_input_change_1_listener($event) { return ctx.sendFile($event); });
63
+ i0.ɵɵelementEnd();
64
+ i0.ɵɵelementStart(2, "label", 2);
65
+ i0.ɵɵlistener("click", function ListScanOverlayButtonComponent_Template_label_click_2_listener() { return ctx.toggleReduce("false"); });
66
+ i0.ɵɵtemplate(3, ListScanOverlayButtonComponent_ng_miam_icon_3_Template, 1, 1, "ng-miam-icon", 3);
67
+ i0.ɵɵtemplate(4, ListScanOverlayButtonComponent_div_4_Template, 2, 3, "div", 4);
68
+ i0.ɵɵtemplate(5, ListScanOverlayButtonComponent_ng_miam_loader_5_Template, 1, 0, "ng-miam-loader", 5);
69
+ i0.ɵɵelementEnd();
70
+ i0.ɵɵelementStart(6, "div", 6);
71
+ i0.ɵɵlistener("click", function ListScanOverlayButtonComponent_Template_div_click_6_listener() { return ctx.toggleReduce("true"); });
72
+ i0.ɵɵnamespaceSVG();
73
+ i0.ɵɵelementStart(7, "svg", 7);
74
+ i0.ɵɵelement(8, "path", 8);
75
+ i0.ɵɵelementEnd();
76
+ i0.ɵɵelementEnd();
77
+ i0.ɵɵelementEnd();
78
+ } if (rf & 2) {
79
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(6, _c1, ctx.overlay));
80
+ i0.ɵɵadvance(1);
81
+ i0.ɵɵproperty("disabled", ctx.loading);
82
+ i0.ɵɵadvance(2);
83
+ i0.ɵɵproperty("ngIf", !ctx.loading);
84
+ i0.ɵɵadvance(1);
85
+ i0.ɵɵproperty("ngIf", !ctx.loading);
86
+ i0.ɵɵadvance(1);
87
+ i0.ɵɵproperty("ngIf", ctx.loading);
88
+ i0.ɵɵadvance(1);
89
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(8, _c0, ctx.reduced == "true"));
90
+ } }, directives: [i2.NgClass, i2.NgIf, i3.IconComponent, i4.LoaderComponent], styles: [".miam-list-scan__overlay-button[_ngcontent-%COMP%]{display:inline-block;position:relative}.miam-list-scan__overlay-button.overlay[_ngcontent-%COMP%]{bottom:20px;position:fixed;right:20px}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .inputfile[_ngcontent-%COMP%]{height:.1px;opacity:0;overflow:hidden;position:absolute;width:.1px;z-index:-1}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .miam-list-scan__overlay-button__label[_ngcontent-%COMP%]{max-height:50px;min-width:0}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .miam-list-scan__overlay-button__label[_ngcontent-%COMP%] ng-miam-icon[_ngcontent-%COMP%]{margin:0}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .miam-list-scan__overlay-button__label[_ngcontent-%COMP%] .button-label[_ngcontent-%COMP%]{margin-left:10px}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .miam-list-scan__overlay-button__label[_ngcontent-%COMP%] .button-label.reduced[_ngcontent-%COMP%]{display:none}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .miam-list-scan__overlay-button__reduce[_ngcontent-%COMP%]{align-items:center;background-color:#fff;border-radius:12px;box-shadow:0 2px 5px rgba(0,0,0,.25);cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;position:absolute;right:-8px;top:-9px;width:24px}.miam-list-scan__overlay-button[_ngcontent-%COMP%] .miam-list-scan__overlay-button__reduce.reduced[_ngcontent-%COMP%]{display:none}"], changeDetection: 0 });
91
+ /*@__PURE__*/ (function () { i0.ɵsetClassMetadata(ListScanOverlayButtonComponent, [{
92
+ type: Component,
93
+ args: [{
94
+ selector: 'ng-miam-list-scan-overlay-button',
95
+ templateUrl: './overlay-button.component.html',
96
+ styleUrls: ['./overlay-button.component.scss'],
97
+ changeDetection: ChangeDetectionStrategy.OnPush
98
+ }]
99
+ }], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.GroceriesListsService }]; }, { overlay: [{
100
+ type: Input
101
+ }], entriesAdded: [{
102
+ type: Output
103
+ }] }); })();
104
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Ii9idWlsZHMvbWlhbS9uZy1taWFtLXNkay9wcm9qZWN0cy9uZy1taWFtL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9fd2ViLWNvbXBvbmVudHMvbGlzdC1zY2FuL292ZXJsYXktYnV0dG9uL292ZXJsYXktYnV0dG9uLmNvbXBvbmVudC50cyIsImxpYi9fd2ViLWNvbXBvbmVudHMvbGlzdC1zY2FuL292ZXJsYXktYnV0dG9uL292ZXJsYXktYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkgsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDM0QsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7Ozs7O0lDQzdDLGtDQUF1Rjs7O0lBQXhELGtEQUE2Qjs7OztJQUM1RCwrQkFBc0Y7SUFBQSwyQ0FBMkI7SUFBQSxpQkFBTTs7O0lBQTVFLDhFQUEwQzs7O0lBRXJGLGlDQUFpRDs7O0FESXJELE1BQU0sT0FBTyw4QkFBOEI7SUFPekMsWUFDVSxHQUFzQixFQUN0QixZQUFtQztRQURuQyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUN0QixpQkFBWSxHQUFaLFlBQVksQ0FBdUI7UUFQbkMsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBb0IsQ0FBQztRQUM5RCxTQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ1osWUFBTyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsa0NBQWtDLENBQUMsSUFBSSxPQUFPLENBQUM7UUFDOUUsWUFBTyxHQUFHLEtBQUssQ0FBQztJQUtiLENBQUM7SUFFSixZQUFZLENBQUMsS0FBSztRQUNoQixJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUNyQixZQUFZLENBQUMsT0FBTyxDQUFDLGtDQUFrQyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN2RSxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCwyQ0FBMkM7SUFDM0MseUZBQXlGO0lBQ3pGLFFBQVEsQ0FBQyxLQUFLO1FBQ1osTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFBRSxPQUFPO1NBQUU7UUFFdEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUV6QixJQUFJLENBQUMsWUFBWSxDQUFDLHFCQUFxQixDQUFDLElBQUksRUFBRSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxTQUFTLENBQzVFLElBQUksQ0FBQyxFQUFFO1lBQ0wsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsVUFBVSxJQUFJLEtBQUssQ0FBQyxVQUFVLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQzNHLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ3ZDLENBQUMsQ0FDRixDQUFDO0lBQ0osQ0FBQzs7NEdBbENVLDhCQUE4QjttRUFBOUIsOEJBQThCO1FDWDNDLDhCQUNFO1FBQUEsZ0NBRUE7UUFGa0csa0hBQVUsb0JBQWdCLElBQUM7UUFBN0gsaUJBRUE7UUFBQSxnQ0FDRTtRQURnQiwwR0FBUyxpQkFBYSxPQUFPLENBQUMsSUFBQztRQUMvQyxpR0FBd0U7UUFDeEUsK0VBQXNGO1FBRXRGLHFHQUFnQztRQUNsQyxpQkFBUTtRQUVSLDhCQUNFO1FBRGtELHdHQUFTLGlCQUFhLE1BQU0sQ0FBQyxJQUFDO1FBQ2hGLG1CQUNFO1FBREYsOEJBQ0U7UUFBQSwwQkFDRjtRQUFBLGlCQUFNO1FBQ1IsaUJBQU07UUFDUixpQkFBTTs7UUFmc0MsaUVBQWdDO1FBQ29ELGVBQW9CO1FBQXBCLHNDQUFvQjtRQUdsSSxlQUFnQjtRQUFoQixtQ0FBZ0I7UUFDekIsZUFBZ0I7UUFBaEIsbUNBQWdCO1FBRUwsZUFBZTtRQUFmLGtDQUFlO1FBR2tELGVBQTBDO1FBQTFDLDJFQUEwQzs7a0REQ2xILDhCQUE4QjtjQU4xQyxTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLGtDQUFrQztnQkFDNUMsV0FBVyxFQUFFLGlDQUFpQztnQkFDOUMsU0FBUyxFQUFFLENBQUMsaUNBQWlDLENBQUM7Z0JBQzlDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2FBQ2hEO3dHQUVVLE9BQU87a0JBQWYsS0FBSztZQUNJLFlBQVk7a0JBQXJCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHcm9jZXJpZXNFbnRyeSB9IGZyb20gJy4uLy4uLy4uL19tb2RlbHMvZ3JvY2VyaWVzLWVudHJ5JztcbmltcG9ydCB7IEdyb2Nlcmllc0xpc3RzU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL19zZXJ2aWNlcyc7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnLi4vLi4vLi4vX3R5cGVzL2ljb24uZW51bSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25nLW1pYW0tbGlzdC1zY2FuLW92ZXJsYXktYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL292ZXJsYXktYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vb3ZlcmxheS1idXR0b24uY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgTGlzdFNjYW5PdmVybGF5QnV0dG9uQ29tcG9uZW50IHtcbiAgQElucHV0KCkgb3ZlcmxheTogYm9vbGVhbjtcbiAgQE91dHB1dCgpIGVudHJpZXNBZGRlZCA9IG5ldyBFdmVudEVtaXR0ZXI8R3JvY2VyaWVzRW50cnlbXT4oKTtcbiAgaWNvbiA9IEljb247XG4gIHJlZHVjZWQgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnX21pYW0vbGlzdFNjYW5uZXIvYnV0dG9uLXJlZHVjZWQnKSB8fCAnZmFsc2UnO1xuICBsb2FkaW5nID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIHByaXZhdGUgbGlzdHNTZXJ2aWNlOiBHcm9jZXJpZXNMaXN0c1NlcnZpY2VcbiAgKSB7fVxuXG4gIHRvZ2dsZVJlZHVjZSh2YWx1ZSkge1xuICAgIHRoaXMucmVkdWNlZCA9IHZhbHVlO1xuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdfbWlhbS9saXN0U2Nhbm5lci9idXR0b24tcmVkdWNlZCcsIHRoaXMucmVkdWNlZCk7XG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgLy8gUHVzaGVzIGEgcGljdHVyZSBmaWxlIGFuZCByZWZyZXNoZXMgbGlzdFxuICAvLyBGaW5hbGx5LCB0cmlnZ2VycyBlbnRyaWVzIGFkZGVkIGV2ZW50LCByZXR1cm5pbmcgYWxsIGVudHJpZXMgbm90IHJlbGF0ZWQgdG8gYW55IHJlY2lwZVxuICBzZW5kRmlsZShldmVudCkge1xuICAgIGNvbnN0IGZpbGUgPSBldmVudC50YXJnZXQuZmlsZXMuaXRlbSgwKTtcbiAgICBpZiAoIWZpbGUpIHsgcmV0dXJuOyB9XG5cbiAgICB0aGlzLmxvYWRpbmcgPSB0cnVlO1xuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcblxuICAgIHRoaXMubGlzdHNTZXJ2aWNlLmFkZEVudHJpZXNGcm9tUGljdHVyZShmaWxlLCBbJ2dyb2Nlcmllcy1lbnRyaWVzJ10pLnN1YnNjcmliZShcbiAgICAgIGxpc3QgPT4ge1xuICAgICAgICBjb25zdCBhZGRlZEVudHJpZXMgPSBsaXN0LmVudHJpZXMuZGF0YS5maWx0ZXIoZW50cnkgPT4gIWVudHJ5LnJlY2lwZXNJZHMgfHwgZW50cnkucmVjaXBlc0lkcy5sZW5ndGggPT09IDApO1xuICAgICAgICB0aGlzLmxvYWRpbmcgPSBmYWxzZTtcbiAgICAgICAgdGhpcy5lbnRyaWVzQWRkZWQuZW1pdChhZGRlZEVudHJpZXMpO1xuICAgICAgfVxuICAgICk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJtaWFtLWxpc3Qtc2Nhbl9fb3ZlcmxheS1idXR0b25cIiBbbmdDbGFzc109XCJ7IG92ZXJsYXk6IG92ZXJsYXkgfVwiPlxuICA8aW5wdXQgdHlwZT1cImZpbGVcIiBuYW1lPVwiZmlsZVwiIGlkPVwiZmlsZVwiIGNsYXNzPVwiaW5wdXRmaWxlXCIgYWNjZXB0PVwiaW1hZ2UvKlwiIGNhcHR1cmU9XCJlbnZpcm9ubWVudFwiIChjaGFuZ2UpPVwic2VuZEZpbGUoJGV2ZW50KVwiIFtkaXNhYmxlZF09XCJsb2FkaW5nXCIgLz5cblxuICA8bGFiZWwgZm9yPVwiZmlsZVwiIChjbGljayk9XCJ0b2dnbGVSZWR1Y2UoJ2ZhbHNlJylcIiBjbGFzcz1cIm0tYnV0dG9uIG0tYnV0dG9uLXByaW1hcnkgbWlhbS1saXN0LXNjYW5fX292ZXJsYXktYnV0dG9uX19sYWJlbFwiPlxuICAgIDxuZy1taWFtLWljb24gKm5nSWY9XCIhbG9hZGluZ1wiIFtpY29uTmFtZV09XCJpY29uLkxpc3RTY2FubmVyXCIgd2lkdGg9XCIyNFwiPjwvbmctbWlhbS1pY29uPlxuICAgIDxkaXYgKm5nSWY9XCIhbG9hZGluZ1wiIGNsYXNzPVwiYnV0dG9uLWxhYmVsXCIgW25nQ2xhc3NdPVwieyByZWR1Y2VkOiByZWR1Y2VkID09ICd0cnVlJyB9XCI+U2Nhbm5lciBtYSBsaXN0ZSBkZSBjb3Vyc2VzPC9kaXY+XG5cbiAgICA8bmctbWlhbS1sb2FkZXIgKm5nSWY9XCJsb2FkaW5nXCI+PC9uZy1taWFtLWxvYWRlcj5cbiAgPC9sYWJlbD5cblxuICA8ZGl2IGNsYXNzPVwibWlhbS1saXN0LXNjYW5fX292ZXJsYXktYnV0dG9uX19yZWR1Y2VcIiAoY2xpY2spPVwidG9nZ2xlUmVkdWNlKCd0cnVlJylcIiBbbmdDbGFzc109XCJ7IHJlZHVjZWQ6IHJlZHVjZWQgPT0gJ3RydWUnIH1cIj5cbiAgICA8c3ZnIHdpZHRoPVwiMjRcIiBoZWlnaHQ9XCIyNFwiIHZpZXdCb3g9XCIwIDAgMjQgMjRcIiBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIj5cbiAgICAgIDxwYXRoIGQ9XCJNOS45MTk1NyAxMkw1Ljk1OTc3IDguMDQwMkw3LjkzOTY3IDYuMDYwM0wxMS44OTk1IDEwLjAyMDFMMTUuODU5MyA2LjA2MDNMMTcuODM5MiA4LjA0MDJMMTMuODc5NCAxMkwxNy44MzkyIDE1Ljk1OThMMTUuODU5MyAxNy45Mzk3TDExLjg5OTUgMTMuOTc5OUw3LjkzOTY3IDE3LjkzOTdMNS45NTk3NyAxNS45NTk4TDkuOTE5NTcgMTJaXCIgZmlsbD1cIiM2NzY3NjdcIi8+XG4gICAgPC9zdmc+ICAgICAgXG4gIDwvZGl2PlxuPC9kaXY+Il19