ng-miam 3.2.1 → 3.3.2
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 +6364 -5557
- 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/icon/icon.component.js +47 -5
- package/esm2015/lib/_models/groceries-entry.js +23 -2
- package/esm2015/lib/_models/groceries-list.js +5 -2
- package/esm2015/lib/_services/analytics.service.js +7 -1
- package/esm2015/lib/_services/baskets.service.js +6 -2
- package/esm2015/lib/_services/groceries-lists.service.js +23 -6
- package/esm2015/lib/_types/icon.enum.js +21 -18
- package/esm2015/lib/_web-components/{basket-preview-block → basket-preview/basket-preview-block}/basket-preview-block.component.js +15 -15
- package/esm2015/lib/_web-components/{basket-preview-disabled → basket-preview/basket-preview-disabled}/basket-preview-disabled.component.js +3 -3
- package/esm2015/lib/_web-components/{basket-preview-line → basket-preview/basket-preview-line}/basket-preview-line.component.js +22 -19
- package/esm2015/lib/_web-components/basket-preview/basket-preview.module.js +78 -0
- package/esm2015/lib/_web-components/basket-preview/index.js +7 -0
- package/esm2015/lib/_web-components/{replace-item → basket-preview/replace-item}/replace-item.component.js +8 -8
- package/esm2015/lib/_web-components/drawer/drawer.component.js +1 -1
- package/esm2015/lib/_web-components/index.js +4 -6
- package/esm2015/lib/_web-components/list-scan/basket-preview/basket-preview.component.js +145 -0
- package/esm2015/lib/_web-components/list-scan/index.js +3 -0
- package/esm2015/lib/_web-components/list-scan/ingredients-list/ingredients-list.component.js +150 -0
- package/esm2015/lib/_web-components/list-scan/list-scan.component.js +87 -0
- package/esm2015/lib/_web-components/list-scan/list-scan.module.js +60 -0
- package/esm2015/lib/_web-components/list-scan/overlay-button/overlay-button.component.js +104 -0
- package/esm2015/lib/_web-components/loader/index.js +3 -0
- package/esm2015/lib/_web-components/loader/loader.module.js +39 -0
- package/esm2015/lib/_web-components/recipe-card/recipe-card.component.js +1 -1
- package/esm2015/lib/_web-components/recipe-catalog/recipe-catalog.component.js +1 -1
- package/esm2015/lib/_web-components/recipe-modal/recipe-modal.component.js +1 -1
- package/esm2015/lib/_web-components/recipes-history/recipes-history.component.js +1 -1
- package/esm2015/lib/_web-components/web-components.module.js +24 -62
- package/esm2015/lib/environment.js +15 -5
- package/fesm2015/ng-miam.js +5545 -4851
- package/fesm2015/ng-miam.js.map +1 -1
- package/lib/_models/groceries-entry.d.ts +8 -1
- package/lib/_models/groceries-list.d.ts +4 -3
- package/lib/_services/groceries-lists.service.d.ts +4 -1
- package/lib/_types/icon.enum.d.ts +20 -17
- package/lib/_web-components/{basket-preview-block → basket-preview/basket-preview-block}/basket-preview-block.component.d.ts +6 -6
- package/lib/_web-components/{basket-preview-disabled → basket-preview/basket-preview-disabled}/basket-preview-disabled.component.d.ts +2 -2
- package/lib/_web-components/{basket-preview-line → basket-preview/basket-preview-line}/basket-preview-line.component.d.ts +7 -7
- package/lib/_web-components/basket-preview/basket-preview.module.d.ts +16 -0
- package/lib/_web-components/basket-preview/index.d.ts +5 -0
- package/lib/_web-components/{replace-item → basket-preview/replace-item}/replace-item.component.d.ts +5 -5
- package/lib/_web-components/index.d.ts +3 -5
- package/lib/_web-components/list-scan/basket-preview/basket-preview.component.d.ts +25 -0
- package/lib/_web-components/list-scan/index.d.ts +2 -0
- package/lib/_web-components/list-scan/ingredients-list/ingredients-list.component.d.ts +22 -0
- package/lib/_web-components/list-scan/list-scan.component.d.ts +17 -0
- package/lib/_web-components/list-scan/list-scan.module.d.ts +16 -0
- package/lib/_web-components/list-scan/overlay-button/overlay-button.component.d.ts +19 -0
- package/lib/_web-components/loader/index.d.ts +2 -0
- package/lib/_web-components/loader/loader.module.d.ts +10 -0
- package/lib/_web-components/web-components.module.d.ts +36 -65
- package/lib/environment.d.ts +3 -3
- package/miam-style.css +1 -1
- package/package.json +1 -1
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, Output, EventEmitter, ElementRef, ViewChild, ChangeDetectorRef } from '@angular/core';
|
|
2
|
-
import { BasketPreviewLine } from '
|
|
3
|
-
import { Icon } from '
|
|
4
|
-
import { BasketsService } from '
|
|
2
|
+
import { BasketPreviewLine } from '../../../_models/basket-preview-line';
|
|
3
|
+
import { Icon } from '../../../_types/icon.enum';
|
|
4
|
+
import { BasketsService } from '../../../_services';
|
|
5
5
|
import { switchMap, take } from 'rxjs/operators';
|
|
6
|
-
import { AnalyticsService } from '
|
|
6
|
+
import { AnalyticsService } from '../../../_services/analytics.service';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "
|
|
9
|
-
import * as i2 from "
|
|
10
|
-
import * as i3 from "
|
|
8
|
+
import * as i1 from "../../../_services";
|
|
9
|
+
import * as i2 from "../../../_services/analytics.service";
|
|
10
|
+
import * as i3 from "../../../_components/icon/icon.component";
|
|
11
11
|
import * as i4 from "@angular/common";
|
|
12
12
|
const _c0 = ["itemsList"];
|
|
13
13
|
function ReplaceItemComponent_div_24_Template(rf, ctx) { if (rf & 1) {
|
|
@@ -170,4 +170,4 @@ ReplaceItemComponent.ɵcmp = i0.ɵɵdefineComponent({ type: ReplaceItemComponent
|
|
|
170
170
|
type: ViewChild,
|
|
171
171
|
args: ['itemsList', { static: true }]
|
|
172
172
|
}] }); })();
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"replace-item.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/replace-item/replace-item.component.ts","lib/_web-components/replace-item/replace-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, OnInit, Input, Output, EventEmitter, ElementRef, ViewChild,\n  ChangeDetectorRef } from '@angular/core';\nimport { BasketPreviewLine } from '../../_models/basket-preview-line';\nimport { Item } from '../../_models/item';\nimport { Icon } from '../../_types/icon.enum';\nimport { BasketsService } from '../../_services';\nimport { switchMap, take } from 'rxjs/operators';\nimport { AnalyticsService } from '../../_services/analytics.service';\n\n@Component({\n  selector: 'ng-miam-replace-item',\n  templateUrl: './replace-item.component.html',\n  styleUrls: ['./replace-item.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ReplaceItemComponent implements OnInit {\n  @Input() line: BasketPreviewLine;\n  @Output() selected = new EventEmitter<string>();\n\n  public items: Array<Item>;\n  public currentItem: any;\n  public icon = Icon;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private basketsService: BasketsService,\n    private analyticsService: AnalyticsService\n  ) { }\n\n  @ViewChild('itemsList', { static: true }) itemsListElement: ElementRef;\n\n  ngOnInit(): void {\n    this.initLine();\n  }\n\n  onClose(): void {\n    this.selected.emit();\n  }\n\n  public onSelectItem(item: Item) {\n    this.line.record.selectItem(item.id);\n    this.analyticsService.sendEvent('replace-item');\n    this.line.record.save().pipe(\n      switchMap(() => this.basketsService.loadBasket()),\n      take(1)\n    ).subscribe();\n    this.selected.emit(this.line.id);\n  }\n\n  private initLine(): void {\n    this.currentItem = this.line.record.attributes['basket-entries-items'][0];\n    this.items = this.line.record.relationships.items.data.filter((item: Item) => item.id === this.currentItem.item_id);\n  }\n\n  priceIntegerPart(price: string ){\n    const values = price.split('.');\n    return values[0];\n  }\n\n  /**\n   * @param price item?.attributes[\"unit-price\"] is a string\n   * and we wan two decimal (not 0.8 or 0.800) \n   * @returns first two decimal\n   */\n  priceDecimalPart(price: string){\n    const values = price.split('.');\n    // force 2 decimals\n    return values?.length === 2 ? (values[1] + '00').slice(0, 2) : '00';\n  }\n}\n","<div class=\"miam-replace-item\">\n  <button class=\"m-button-secondary\" (click)=\"onClose()\">\n    <ng-miam-icon [iconName]='icon.ChevronDown' primaryColor='var(--m-color-primary)' ></ng-miam-icon>\n   <span>Retour</span> \n  </button>\n  <div class=\"miam-replace-item__selected\">\n    <img class=\"miam-replace-item__selected__picture\" [src]=\"line?.record?.selectedItem?.attributes?.image\" alt=\"Image non disponible\">\n    <div class=\"miam-replace-item__selected__column\">\n      <div class=\"miam-replace-item__description\">\n        {{ line?.record?.selectedItem.attributes.name }} |\n         {{ line?.record?.selectedItem.capacity }}\n      </div>\n      <div class=\"miam-replace-item__price\">\n        <span>{{ priceIntegerPart(line?.record?.totalPrice) }},</span>\n        <span>{{ priceDecimalPart(line?.record?.totalPrice) }}</span>   \n        <span> €</span>\n      </div>\n    </div>\n  </div>\n  <div class=\"miam-replace-item__choices\">\n    <div class=\"miam-replace-item__choices__action\">\n      <div>Remplacer cet article par :</div>\n    </div>\n    <div #itemsList class=\"miam-replace-item__choices\" >\n      <div class=\"miam-replace-item__choices__list\">\n      <div class=\"miam-replace-item__choice\" *ngFor=\"let item of line?.record?.candidateItems, let i = index\" (click)=\"onSelectItem(item)\">\n        <div class=\"miam-replace-item__choice__column\">\n          <ng-miam-icon \n          class=\"miam-replace-item__choice__swap\" \n          [height]='16' \n          [width]='16' \n          [iconName]='icon.Swap' >\n        </ng-miam-icon>\n          <img [src]=\"item?.attributes?.image\">\n        </div>\n        <div class=\"miam-replace-item__choice__column\">\n          <div class=\"miam-replace-item__choice__content\">\n            <div class=\"miam-replace-item__description\">\n               {{ item?.attributes?.name }} | {{item?.capacity}}\n            </div>\n          </div>\n        </div>\n        <div class=\"miam-replace-item__choice__column\">\n          <div class=\"miam-replace-item__price\">\n            <span>{{ priceIntegerPart(item?.attributes[\"unit-price\"]) }},</span>\n            <span>{{ priceDecimalPart(item?.attributes[\"unit-price\"]) }}</span>   \n            <span> €</span>\n          </div>\n        </div>\n      </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"replace-item.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/basket-preview/replace-item/replace-item.component.ts","lib/_web-components/basket-preview/replace-item/replace-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, OnInit, Input, Output, EventEmitter, ElementRef, ViewChild,\n  ChangeDetectorRef } from '@angular/core';\nimport { BasketPreviewLine } from '../../../_models/basket-preview-line';\nimport { Item } from '../../../_models/item';\nimport { Icon } from '../../../_types/icon.enum';\nimport { BasketsService } from '../../../_services';\nimport { switchMap, take } from 'rxjs/operators';\nimport { AnalyticsService } from '../../../_services/analytics.service';\n\n@Component({\n  selector: 'ng-miam-replace-item',\n  templateUrl: './replace-item.component.html',\n  styleUrls: ['./replace-item.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ReplaceItemComponent implements OnInit {\n  @Input() line: BasketPreviewLine;\n  @Output() selected = new EventEmitter<string>();\n\n  public items: Array<Item>;\n  public currentItem: any;\n  public icon = Icon;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private basketsService: BasketsService,\n    private analyticsService: AnalyticsService\n  ) { }\n\n  @ViewChild('itemsList', { static: true }) itemsListElement: ElementRef;\n\n  ngOnInit(): void {\n    this.initLine();\n  }\n\n  onClose(): void {\n    this.selected.emit();\n  }\n\n  public onSelectItem(item: Item) {\n    this.line.record.selectItem(item.id);\n    this.analyticsService.sendEvent('replace-item');\n    this.line.record.save().pipe(\n      switchMap(() => this.basketsService.loadBasket()),\n      take(1)\n    ).subscribe();\n    this.selected.emit(this.line.id);\n  }\n\n  private initLine(): void {\n    this.currentItem = this.line.record.attributes['basket-entries-items'][0];\n    this.items = this.line.record.relationships.items.data.filter((item: Item) => item.id === this.currentItem.item_id);\n  }\n\n  priceIntegerPart(price: string ){\n    const values = price.split('.');\n    return values[0];\n  }\n\n  /**\n   * @param price item?.attributes[\"unit-price\"] is a string\n   * and we wan two decimal (not 0.8 or 0.800) \n   * @returns first two decimal\n   */\n  priceDecimalPart(price: string){\n    const values = price.split('.');\n    // force 2 decimals\n    return values?.length === 2 ? (values[1] + '00').slice(0, 2) : '00';\n  }\n}\n","<div class=\"miam-replace-item\">\n  <button class=\"m-button-secondary\" (click)=\"onClose()\">\n    <ng-miam-icon [iconName]='icon.ChevronDown' primaryColor='var(--m-color-primary)' ></ng-miam-icon>\n   <span>Retour</span> \n  </button>\n  <div class=\"miam-replace-item__selected\">\n    <img class=\"miam-replace-item__selected__picture\" [src]=\"line?.record?.selectedItem?.attributes?.image\" alt=\"Image non disponible\">\n    <div class=\"miam-replace-item__selected__column\">\n      <div class=\"miam-replace-item__description\">\n        {{ line?.record?.selectedItem.attributes.name }} |\n         {{ line?.record?.selectedItem.capacity }}\n      </div>\n      <div class=\"miam-replace-item__price\">\n        <span>{{ priceIntegerPart(line?.record?.totalPrice) }},</span>\n        <span>{{ priceDecimalPart(line?.record?.totalPrice) }}</span>   \n        <span> €</span>\n      </div>\n    </div>\n  </div>\n  <div class=\"miam-replace-item__choices\">\n    <div class=\"miam-replace-item__choices__action\">\n      <div>Remplacer cet article par :</div>\n    </div>\n    <div #itemsList class=\"miam-replace-item__choices\" >\n      <div class=\"miam-replace-item__choices__list\">\n      <div class=\"miam-replace-item__choice\" *ngFor=\"let item of line?.record?.candidateItems, let i = index\" (click)=\"onSelectItem(item)\">\n        <div class=\"miam-replace-item__choice__column\">\n          <ng-miam-icon \n          class=\"miam-replace-item__choice__swap\" \n          [height]='16' \n          [width]='16' \n          [iconName]='icon.Swap' >\n        </ng-miam-icon>\n          <img [src]=\"item?.attributes?.image\">\n        </div>\n        <div class=\"miam-replace-item__choice__column\">\n          <div class=\"miam-replace-item__choice__content\">\n            <div class=\"miam-replace-item__description\">\n               {{ item?.attributes?.name }} | {{item?.capacity}}\n            </div>\n          </div>\n        </div>\n        <div class=\"miam-replace-item__choice__column\">\n          <div class=\"miam-replace-item__price\">\n            <span>{{ priceIntegerPart(item?.attributes[\"unit-price\"]) }},</span>\n            <span>{{ priceDecimalPart(item?.attributes[\"unit-price\"]) }}</span>   \n            <span> €</span>\n          </div>\n        </div>\n      </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -9,7 +9,7 @@ import * as i2 from "../../_services/point-of-sales.service";
|
|
|
9
9
|
import * as i3 from "../../_services/analytics.service";
|
|
10
10
|
import * as i4 from "@angular/common";
|
|
11
11
|
import * as i5 from "../pos-selection/pos-selection.component";
|
|
12
|
-
import * as i6 from "../basket-preview-block/basket-preview-block.component";
|
|
12
|
+
import * as i6 from "../basket-preview/basket-preview-block/basket-preview-block.component";
|
|
13
13
|
import * as i7 from "../loader/loader.component";
|
|
14
14
|
function DrawerComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
15
15
|
i0.ɵɵelement(0, "div", 11);
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
export * from './basket-preview-block/basket-preview-block.component';
|
|
2
|
-
export * from './basket-preview-disabled/basket-preview-disabled.component';
|
|
3
|
-
export * from './basket-preview-line/basket-preview-line.component';
|
|
4
1
|
export * from './catalog-category/catalog-category.component';
|
|
5
2
|
export * from './catalog-header/catalog-header.component';
|
|
6
3
|
export * from './catalog-list/catalog-list.component';
|
|
@@ -8,7 +5,6 @@ export * from './catalog-recipe-card/catalog-recipe-card.component';
|
|
|
8
5
|
export * from './drag-drop-input/drag-drop-input.component';
|
|
9
6
|
export * from './drawer/drawer.component';
|
|
10
7
|
export * from './favorite-page/favorite-page.component';
|
|
11
|
-
export * from './loader/loader.component';
|
|
12
8
|
export * from './modal/modal.component';
|
|
13
9
|
export * from './order-button/order-button.component';
|
|
14
10
|
export * from './personal-recipes/personal-recipes.component';
|
|
@@ -26,8 +22,10 @@ export * from './recipe-helper/recipe-helper.component';
|
|
|
26
22
|
export * from './recipe-stepper/recipe-stepper.component';
|
|
27
23
|
export * from './recipe-tags/recipe-tags.component';
|
|
28
24
|
export * from './recipes-history/recipes-history.component';
|
|
29
|
-
export * from './replace-item/replace-item.component';
|
|
30
25
|
export * from './recipe-modal/recipe-modal.component';
|
|
31
26
|
export * from './suggestion-card/suggestion-card.component';
|
|
32
27
|
export * from './web-components.module';
|
|
33
|
-
|
|
28
|
+
export * from './loader';
|
|
29
|
+
export * from './basket-preview';
|
|
30
|
+
export * from './list-scan';
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiL2J1aWxkcy9taWFtL25nLW1pYW0tc2RrL3Byb2plY3RzL25nLW1pYW0vc3JjLyIsInNvdXJjZXMiOlsibGliL193ZWItY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jYXRhbG9nLWNhdGVnb3J5L2NhdGFsb2ctY2F0ZWdvcnkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2F0YWxvZy1oZWFkZXIvY2F0YWxvZy1oZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2F0YWxvZy1saXN0L2NhdGFsb2ctbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXRhbG9nLXJlY2lwZS1jYXJkL2NhdGFsb2ctcmVjaXBlLWNhcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZHJhZy1kcm9wLWlucHV0L2RyYWctZHJvcC1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kcmF3ZXIvZHJhd2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Zhdm9yaXRlLXBhZ2UvZmF2b3JpdGUtcGFnZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RhbC9tb2RhbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9vcmRlci1idXR0b24vb3JkZXItYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BlcnNvbmFsLXJlY2lwZXMvcGVyc29uYWwtcmVjaXBlcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wbGFubmVyL3BsYW5uZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGxhbm5lci1jYWxlbmRhci9wbGFubmVyLWNhbGVuZGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BsYW5uZXItc2lkZS1tZW51L3BsYW5uZXItc2lkZS1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Bvcy1jYXJkL3Bvcy1jYXJkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Bvcy1zZWxlY3Rpb24vcG9zLXNlbGVjdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWNpcGUtYWRkb24vcmVjaXBlLWFkZG9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY2lwZS1jYXJkL3JlY2lwZS1jYXJkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY2lwZS1jYXRhbG9nL3JlY2lwZS1jYXRhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY2lwZS1kZXRhaWxzL3JlY2lwZS1kZXRhaWxzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY2lwZS1mb3JtL3JlY2lwZS1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY2lwZS1oZWxwZXIvcmVjaXBlLWhlbHBlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWNpcGUtc3RlcHBlci9yZWNpcGUtc3RlcHBlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWNpcGUtdGFncy9yZWNpcGUtdGFncy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWNpcGVzLWhpc3RvcnkvcmVjaXBlcy1oaXN0b3J5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlY2lwZS1tb2RhbC9yZWNpcGUtbW9kYWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3VnZ2VzdGlvbi1jYXJkL3N1Z2dlc3Rpb24tY2FyZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi93ZWItY29tcG9uZW50cy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2FkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9iYXNrZXQtcHJldmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2xpc3Qtc2Nhbic7XG4iXX0=
|
|
@@ -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==
|