ng-miam 4.7.2 → 4.7.4

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.
@@ -511,4 +511,4 @@ RecipeDetailsComponent.ɵcmp = i0.ɵɵdefineComponent({ type: RecipeDetailsCompo
511
511
  type: ViewChild,
512
512
  args: ['topContainerImg']
513
513
  }] }); })();
514
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recipe-details.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/recipe-details/recipe-details.component.ts","lib/_web-components/recipe-details/recipe-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  ChangeDetectionStrategy,\n  Input,\n  ChangeDetectorRef,\n  Output,\n  EventEmitter,\n  OnChanges,\n  ViewChild,\n  ElementRef,\n  SimpleChanges,\n  OnInit\n} from '@angular/core';\nimport { Recipe } from '../../_models/recipe';\nimport { Icon } from '../../_types/icon.enum';\nimport { ContextService, GroceriesListsService, PointOfSalesService, RecipeEventsService, RecipesService, ToastrService, UserService } from '../../_services';\nimport { forkJoin, Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\nimport { MediaMatcher } from '@angular/cdk/layout';\nimport { AnalyticsService, CustomProperties } from '../../_services/analytics.service';\nimport { EventTracerComponent } from '../../_components/abstracts/event-tracer.component';\n\n@Component({\n  selector: 'ng-miam-recipe-details',\n  templateUrl: './recipe-details.component.html',\n  styleUrls: ['./recipe-details.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RecipeDetailsComponent extends EventTracerComponent implements OnInit, OnChanges {\n  @Input() recipe: Recipe;\n  @Input() previewAllowed = true;\n  @Input() ingredientsPictures = false;\n  @Input() forceDisplayTags; // Override global setting if necesary\n  @Input() displayTagsIcons = false;\n  @Input() displayPricing = true;\n  @Input() displayAddedOnPicture = true;\n  @Input() stepsOnLeftSide = false; // If true, display the detail in 4 quarters instead of 2 halves\n  @Input() cookingTimeAsPrimaryInfo = false; // If true, display the cooking time next to total time\n  @Input() moreRecipesImageURL: string;\n  @Input() pricingGuestsText = 'par personne';\n  @Input() recipeAddedToastText: string;\n  @Output() recipeAdded: EventEmitter<void> = new EventEmitter();\n  @Output() recipeError: EventEmitter<void> = new EventEmitter();\n  primaryButtonClicked$ = new EventEmitter<boolean>();\n\n  @ViewChild('topContainerImg') topContainerImg: ElementRef;\n\n  tab = 0;\n  isMobile = false;\n  displayTags = false;\n  showDetail = true;\n  icon = Icon;\n  playerWidth;\n  playerHeight;\n  showVideo;\n  addButtonLoading = false;\n  titleInHeader = false;\n  title: HTMLElement;\n  content: HTMLElement;\n  private intersectionObserver: IntersectionObserver;\n  protected subscriptions: Subscription[];\n\n  constructor(\n    public cdr: ChangeDetectorRef,\n    public recipeService: RecipesService,\n    public groceriesListsService: GroceriesListsService,\n    public userService: UserService,\n    protected posService: PointOfSalesService,\n    private recipeEventsService: RecipeEventsService,\n    private mediaMatcher: MediaMatcher,\n    public contextService: ContextService,\n    protected toastr: ToastrService,\n    protected analyticsService: AnalyticsService\n  ) {\n    super(analyticsService);\n    this.subscriptions = [];\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.contextService.miam.user.isSmallScreen$.subscribe(isSmall => {\n        this.isMobile = isSmall;\n        this.cdr.detectChanges();\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.recipe && changes['recipe']) {\n      this.analyticsService.sendEventWhenReady(this.analyticsService.EVENT_RECIPE_DISPLAY, this.originTrace.originPath, this.props());\n      this.pageview();\n    }\n    if (this.forceDisplayTags !== undefined && this.forceDisplayTags !== this.displayTags) {\n      this.displayTags = this.forceDisplayTags;\n    }\n    else {\n      this.displayTags = this.contextService.tagsOnRecipesEnabled;\n    }\n    if (this.stepsOnLeftSide) {\n      this.cookingTimeAsPrimaryInfo = true;\n    }\n    this.showVideo = false; // force reload video player\n    this.cdr.detectChanges();\n    this.showVideo = this.contextService.videoRecipesEnabled && this.recipe?.videoId;\n    if (this.showVideo) {\n      this.setupYoutubePlayer();\n    }\n    setTimeout(() => {\n      this.initScrollListenerOnTitle();\n    });\n  }\n\n  setupYoutubePlayer() {\n    setTimeout(() => {\n      if (window.YT?.Player) {\n        this.playerWidth = this.topContainerImg?.nativeElement?.offsetWidth;\n        this.playerHeight =  Math.min(window.innerHeight * 0.48, this.playerWidth * 390 / 640);\n        this.cdr.detectChanges();\n      }\n      else {\n        this.setupYoutubePlayer();\n      }\n    }, 50);\n  }\n\n  currentPath(): string {\n    return 'detail';\n  }\n\n  protected currentProps(): CustomProperties {\n    return { recipe_id: this.recipe.id };\n  }\n\n  /**\n   * Init the listener on scroll so the modal can hide the close icon\n   */\n  initScrollListenerOnTitle() {\n    if (!this.title) {\n      this.title = document.getElementById('miam-recipe-details__title');\n    }\n    if (!this.content) {\n      this.content = document.getElementById('miam-recipe-details__content');\n    }\n    if (this.isMobile && !this.intersectionObserver && this.content && this.title) {\n      // For more precision on title scroll detection, we want to trigger an event each time the user scrolls 5% of the content\n      const threshold = [...Array(20).keys()].map(x => x / 20)\n      // Receive an event each time the title enters/leaves the viewport\n      this.intersectionObserver = new IntersectionObserver(([entry]) => { this.toggleTitleInHeader(); },\n      { threshold });\n      this.intersectionObserver.observe(this.content);\n    }\n  }\n\n  toggleTitleInHeader() {\n    this.titleInHeader = this.title.getBoundingClientRect().top <= 40;\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * Add recipe to list on primary button click and emit true if the recipe is added, false if recipe is not added\n   * so lib users can decide that primaryButtonClicked$.emit(false) removes the recipe for example\n   */\n  clickPrimary(): void {\n    if (!this.addButtonLoading) {\n      this.subscriptions.push(\n        this.groceriesListsService.recipeIsInList(this.recipe.id).subscribe(recipeIsInList => {\n          this.addRecipe();\n          this.primaryButtonClicked$.emit(!recipeIsInList); // !recipeIsInList = add action, so we emit true\n        })\n      );\n    }\n  }\n\n  addRecipe(): void {\n    this.toggleButtonLoader(true);\n    forkJoin([\n      this.userService.isLogged$.asObservable().pipe(take(1)),\n      this.posService.isPosValid().pipe(take(1))\n    ]).subscribe(res => {\n      const isHookOk = this.contextService.hookCallback(res[0], res[1]);\n      if (isHookOk) {\n        this.addRecipeActionOK();\n      } else {\n        this.addRecipeActionKO();\n      }\n    });\n  }\n\n  addRecipeActionOK(): void {\n    this.subscriptions.push(\n      this.groceriesListsService.recipeIsInList(this.recipe.id).subscribe(recipeIsInList => {\n        const recipeWasAdded = !recipeIsInList;\n        if (recipeWasAdded){\n          this.recipeEventsService.sendEvent(this.recipe, this.recipeEventsService.ACTION_ADDED);\n          this.subscriptions.push(\n            this.groceriesListsService.appendRecipeToList(this.recipe.id, this.recipe.modifiedGuests, this.eventTrace())\n            .pipe(take(1))\n            .subscribe(l => {\n              this.toggleButtonLoader(false);\n              if (recipeWasAdded && this.recipeAddedToastText && this.recipeAddedToastText.length > 0) {\n                this.toastr.info(this.recipeAddedToastText, null, { closeButton: true, progressBar: true });\n              }\n            })\n          );\n        }\n      })\n    );\n    this.recipeAdded.emit();\n  }\n\n  addRecipeActionKO(): void {\n    sessionStorage.setItem('_miam/cached-recipe', JSON.stringify(this.recipe));\n    this.recipeError.emit();\n  }\n\n  // If the recipe is already in basket, update the number of guests (= append recipe to list again)\n  updateGuests() {\n    this.groceriesListsService.recipeIsInList(this.recipe.id).subscribe(recipeIsInList => {\n      if (recipeIsInList) {\n        this.groceriesListsService.appendRecipeToList(this.recipe.id, this.recipe.modifiedGuests, this.eventTrace()).subscribe();\n      } else {\n        // Mean we send an event even if receipe is not in basket\n        this.sendEvent(this.analyticsService.EVENT_RECIPE_CHANGEGUESTS);\n      }\n    });\n    this.recipeService.displayedRecipeChanged.emit();\n    this.cdr.detectChanges();\n  }\n\n  print() {\n    this.sendEvent(this.analyticsService.EVENT_RECIPE_PRINT);\n    window.print();\n  }\n\n  toggleAddon(){\n    this.showDetail =  !this.showDetail;\n    this.cdr.detectChanges();\n  }\n\n  toggleHelper() {\n    this.recipeService.toggleHelper();\n    this.cdr.detectChanges();\n  }\n\n  toggleButtonLoader(value: boolean): void {\n    this.addButtonLoading = value;\n    this.cdr.detectChanges();\n  }\n}\n","<div *ngIf=\"showDetail else addon\" class=\"miam-recipe-details\" #mainContainer >\n  <!-- HEADER -->\n  <div class=\"miam-recipe-details__header\">\n    <!-- BOOKMARK -->\n    <div class=\"miam-recipe-details__bookmark\">\n      <img *ngIf=\"!isMobile else stamp\" src=\"https://storage.googleapis.com/assets.miam.tech/generic/recipe-details/recipe-details-bookmark.svg\">\n      <ng-template #stamp>\n        <img src=\"https://storage.googleapis.com/assets.miam.tech/generic/recipe-details/recipe-details-stamp.svg\">\n      </ng-template>\n    </div>\n    <!-- TITLE - DESKTOP -->\n    <div class=\"miam-recipe-details__title\">\n      <span *ngIf=\"!isMobile || titleInHeader\">\n        {{recipe?.attributes['title']}}\n      </span>\n    </div>\n    <!-- HEADER LINK -->\n    <a class=\"miam-recipe-details__header__link\" [href]=\"contextService.miam.router.catalog\">\n      Voir plus d'idées repas\n    </a>\n  </div>\n\n  <div class=\"miam-recipe-details__container\">\n    <!-- LEFT PART (TOP PART ON MOBILE) -->\n    <div #topContainerImg class=\"miam-recipe-details__summary\">\n      <div class=\"miam-recipe-details__summary__container\">\n        <!-- SPONSOR -->\n        <div class=\"miam-recipe-details__sponsor\">\n          <ng-miam-addon-link *ngIf=\"recipe?.sponsors?.length > 0 || recipe.informationalSentence\"\n            [recipe]='recipe' (showAddon)='toggleAddon()'></ng-miam-addon-link>\n        </div>\n        <!-- PICTURE / VIDEO -->\n        <div class=\"miam-recipe-details__picture\">\n          <img\n            *ngIf=\"!showVideo\"\n            [src]=\"recipe?.attributes['media-url']\"\n            [ngClass]=\"{ 'sponsor': recipe?.sponsors?.length > 0, 'tags': displayTags && recipe.relationships.tags.data.length > 0 }\">\n          <youtube-player\n            *ngIf=\"showVideo && playerWidth\"\n            [videoId]=\"recipe.videoId\"\n            [width]=\"playerWidth\"\n            [height]=\"playerHeight\"\n          ></youtube-player>\n        </div>\n        <!-- ACTIONS ICONS -->\n        <div class=\"miam-recipe-details__actionbar\">\n          <div class=\"miam-recipe-details__actionbar__group\">\n            <ng-miam-like-button *ngIf=\"userService.isLogged$ | async\" class=\"miam-recipe-details__actions__icon like\"\n              [recipe]='recipe' [originTrace]=\"eventTrace()\" [width]=\"24\" [height]=\"24\">\n            </ng-miam-like-button>\n            <ng-miam-icon (click)=\"print()\" class=\"miam-recipe-details__actions__icon print\" [width]=\"24\" [height]=\"24\"\n              primaryColor='var(--m-color-primary)' [iconName]=\"icon.Print\">\n            </ng-miam-icon>\n          </div>\n          <div class=\"miam-recipe-details__actionbar__group\">\n            <ng-miam-icon class=\"miam-recipe-details__actions__icon help\" (click)=\"toggleHelper()\" [width]=\"40\" [height]=\"40\"\n              primaryColor='var(--m-color-grey02)' secondaryColor='var(--m-color-grey07)' [iconName]=\"icon.Help\">\n            </ng-miam-icon>\n          </div>\n        </div>\n        <!-- TIMES, DIFFICULTY & TAGS - DESKTOP -->\n        <ng-miam-recipe-details-infos\n          *ngIf=\"!isMobile\" [recipe]=\"recipe\" [displayTags]=\"displayTags\" [displayTagsIcons]=\"displayTagsIcons\" [reduced]=\"cookingTimeAsPrimaryInfo\">\n        </ng-miam-recipe-details-infos>\n        <!-- STEPS WHEN QUARTER DISPLAY -->\n        <ng-miam-recipe-details-steps *ngIf=\"!isMobile && stepsOnLeftSide\" [recipe]=\"recipe\"></ng-miam-recipe-details-steps>\n\n        <!-- PRICE & PRIMARY CTA -->\n        <div class=\"miam-recipe-details__action__container\">\n          <!-- PRICE -->\n          <div class=\"miam-recipe-details__price\">\n            <ng-miam-recipe-pricing\n              *ngIf=\"recipe && displayPricing\" [recipe]=\"recipe\" [serves]=\"recipe?.modifiedGuests\" [guestsText]=\"pricingGuestsText\">\n            </ng-miam-recipe-pricing>\n          </div>\n          <!-- PRIMARY CTA -->\n          <div *ngIf=\"previewAllowed\"  class=\"miam-recipe-details__addbasket\" (click)=\"clickPrimary()\"\n            [ngClass]=\"{ 'in-basket': (groceriesListsService.recipeIsInList(recipe?.id) | async), 'loading': addButtonLoading}\">\n            <div *ngIf=\"!addButtonLoading else addLoader\" class=\"miam-recipe-details__addbasket__cta\">\n              <span>\n                {{(groceriesListsService.recipeIsInList(recipe?.id) | async) ? 'Voir les produits' : 'Ajouter les ingrédients'}}\n              </span>\n              <ng-miam-icon\n                *ngIf=\"!(groceriesListsService.recipeIsInList(recipe?.id) | async)\" [width]=\"24\" [height]=\"24\" primaryColor='#fff'\n                [iconName]=\"icon.Cart\">\n              </ng-miam-icon>\n            </div>\n            <ng-template #addLoader>\n              <ng-miam-loader></ng-miam-loader>\n            </ng-template>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!-- RIGHT PART (BOTTOM PART ON MOBILE) -->\n    <div class=\"miam-recipe-details__content\" id=\"miam-recipe-details__content\">\n      <!-- TITLE - MOBILE -->\n      <div>\n        <div *ngIf=\"isMobile\" class=\"miam-recipe-details__title\" id=\"miam-recipe-details__title\">\n          {{recipe?.attributes['title']}}\n        </div>\n      </div>\n      <!-- DESCRIPTION -->\n      <div *ngIf=\"recipe?.attributes.description\" class=\"miam-recipe-details__content__description\">\n        {{ recipe?.attributes.description }}\n      </div>\n      <!-- TIMES, DIFFICULTY & TAGS - MOBILE -->\n      <ng-miam-recipe-details-infos\n        *ngIf=\"isMobile\" [recipe]=\"recipe\" [displayTags]=\"displayTags\" [displayTagsIcons]=\"displayTagsIcons\" [reduced]=\"cookingTimeAsPrimaryInfo\">\n      </ng-miam-recipe-details-infos>\n      <!-- INGREDIENTS -->\n      <ng-miam-recipe-details-ingredients [recipe]=\"recipe\" [ingredientsPictures]=\"ingredientsPictures\" (guestsUpdated)=\"updateGuests()\"></ng-miam-recipe-details-ingredients>\n      <!-- STEPS -->\n      <ng-miam-recipe-details-steps\n        *ngIf=\"!(!isMobile && stepsOnLeftSide)\" [recipe]=\"recipe\">\n      </ng-miam-recipe-details-steps>\n      <!-- LINK IMAGE -->\n      <a class=\"miam-recipe-details__content__image\" [href]=\"contextService.miam.router.catalog\">\n        <img [src]=\"moreRecipesImageURL\">\n      </a>\n    </div>\n  </div>\n</div>\n<!-- ADDON -->\n<ng-template #addon>\n  <ng-miam-recipe-addon [recipe]='recipe' (hideAddon)=\"toggleAddon()\"></ng-miam-recipe-addon>\n</ng-template>"]}
514
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recipe-details.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/recipe-details/recipe-details.component.ts","lib/_web-components/recipe-details/recipe-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  ChangeDetectionStrategy,\n  Input,\n  ChangeDetectorRef,\n  Output,\n  EventEmitter,\n  OnChanges,\n  ViewChild,\n  ElementRef,\n  SimpleChanges,\n  OnInit\n} from '@angular/core';\nimport { Recipe } from '../../_models/recipe';\nimport { Icon } from '../../_types/icon.enum';\nimport { ContextService, GroceriesListsService, PointOfSalesService, RecipeEventsService, RecipesService, ToastrService, UserService } from '../../_services';\nimport { forkJoin, Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\nimport { MediaMatcher } from '@angular/cdk/layout';\nimport { AnalyticsService, CustomProperties } from '../../_services/analytics.service';\nimport { EventTracerComponent } from '../../_components/abstracts/event-tracer.component';\n\n@Component({\n  selector: 'ng-miam-recipe-details',\n  templateUrl: './recipe-details.component.html',\n  styleUrls: ['./recipe-details.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RecipeDetailsComponent extends EventTracerComponent implements OnInit, OnChanges {\n  @Input() recipe: Recipe;\n  @Input() previewAllowed = true;\n  @Input() ingredientsPictures = false;\n  @Input() forceDisplayTags; // Override global setting if necesary\n  @Input() displayTagsIcons = false;\n  @Input() displayPricing = true;\n  @Input() displayAddedOnPicture = true;\n  @Input() stepsOnLeftSide = false; // If true, display the detail in 4 quarters instead of 2 halves\n  @Input() cookingTimeAsPrimaryInfo = false; // If true, display the cooking time next to total time\n  @Input() moreRecipesImageURL: string;\n  @Input() pricingGuestsText = 'par personne';\n  @Input() recipeAddedToastText: string;\n  @Output() recipeAdded: EventEmitter<void> = new EventEmitter();\n  @Output() recipeError: EventEmitter<void> = new EventEmitter();\n  primaryButtonClicked$ = new EventEmitter<boolean>();\n\n  @ViewChild('topContainerImg') topContainerImg: ElementRef;\n\n  tab = 0;\n  isMobile = false;\n  displayTags = false;\n  showDetail = true;\n  icon = Icon;\n  playerWidth;\n  playerHeight;\n  showVideo;\n  addButtonLoading = false;\n  titleInHeader = false;\n  title: HTMLElement;\n  content: HTMLElement;\n  private intersectionObserver: IntersectionObserver;\n  protected subscriptions: Subscription[];\n\n  constructor(\n    public cdr: ChangeDetectorRef,\n    public recipeService: RecipesService,\n    public groceriesListsService: GroceriesListsService,\n    public userService: UserService,\n    protected posService: PointOfSalesService,\n    private recipeEventsService: RecipeEventsService,\n    private mediaMatcher: MediaMatcher,\n    public contextService: ContextService,\n    protected toastr: ToastrService,\n    protected analyticsService: AnalyticsService\n  ) {\n    super(analyticsService);\n    this.subscriptions = [];\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.push(\n      this.contextService.miam.user.isSmallScreen$.subscribe(isSmall => {\n        this.isMobile = isSmall;\n        this.cdr.detectChanges();\n      })\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.recipe && changes['recipe']) {\n      this.analyticsService.sendEventWhenReady(this.analyticsService.EVENT_RECIPE_DISPLAY, this.originTrace.originPath, this.props());\n      this.pageview();\n    }\n    if (this.forceDisplayTags !== undefined && this.forceDisplayTags !== this.displayTags) {\n      this.displayTags = this.forceDisplayTags;\n    }\n    else {\n      this.displayTags = this.contextService.tagsOnRecipesEnabled;\n    }\n    if (this.stepsOnLeftSide) {\n      this.cookingTimeAsPrimaryInfo = true;\n    }\n    this.showVideo = false; // force reload video player\n    this.cdr.detectChanges();\n    this.showVideo = this.contextService.videoRecipesEnabled && this.recipe?.videoId;\n    if (this.showVideo) {\n      this.setupYoutubePlayer();\n    }\n    setTimeout(() => {\n      this.initScrollListenerOnTitle();\n    });\n  }\n\n  setupYoutubePlayer() {\n    setTimeout(() => {\n      if (window.YT?.Player) {\n        this.playerWidth = this.topContainerImg?.nativeElement?.offsetWidth;\n        this.playerHeight =  Math.min(window.innerHeight * 0.48, this.playerWidth * 390 / 640);\n        this.cdr.detectChanges();\n      }\n      else {\n        this.setupYoutubePlayer();\n      }\n    }, 50);\n  }\n\n  currentPath(): string {\n    return 'detail';\n  }\n\n  protected currentProps(): CustomProperties {\n    return { recipe_id: this.recipe.id };\n  }\n\n  /**\n   * Init the listener on scroll so the modal can hide the close icon\n   */\n  initScrollListenerOnTitle() {\n    if (!this.title) {\n      this.title = document.getElementById('miam-recipe-details__title');\n    }\n    if (!this.content) {\n      this.content = document.getElementById('miam-recipe-details__content');\n    }\n    if (this.isMobile && !this.intersectionObserver && this.content && this.title) {\n      // For more precision on title scroll detection, we want to trigger an event each time the user scrolls 5% of the content\n      const threshold = [...Array(20).keys()].map(x => x / 20)\n      // Receive an event each time the title enters/leaves the viewport\n      this.intersectionObserver = new IntersectionObserver(([entry]) => { this.toggleTitleInHeader(); },\n      { threshold });\n      this.intersectionObserver.observe(this.content);\n    }\n  }\n\n  toggleTitleInHeader() {\n    this.titleInHeader = this.title.getBoundingClientRect().top <= 40;\n    this.cdr.detectChanges();\n  }\n\n  /**\n   * Add recipe to list on primary button click and emit true if the recipe is added, false if recipe is not added\n   * so lib users can decide that primaryButtonClicked$.emit(false) removes the recipe for example\n   */\n  clickPrimary(): void {\n    if (!this.addButtonLoading) {\n      this.subscriptions.push(\n        this.groceriesListsService.recipeIsInList(this.recipe.id).subscribe(recipeIsInList => {\n          this.addRecipe();\n          this.primaryButtonClicked$.emit(!recipeIsInList); // !recipeIsInList = add action, so we emit true\n        })\n      );\n    }\n  }\n\n  addRecipe(): void {\n    this.toggleButtonLoader(true);\n    forkJoin([\n      this.userService.isLogged$.asObservable().pipe(take(1)),\n      this.posService.isPosValid().pipe(take(1))\n    ]).subscribe(res => {\n      const isHookOk = this.contextService.hookCallback(res[0], res[1]);\n      if (isHookOk) {\n        this.addRecipeActionOK();\n      } else {\n        this.addRecipeActionKO();\n      }\n    });\n  }\n\n  addRecipeActionOK(): void {\n    this.subscriptions.push(\n      this.groceriesListsService.recipeIsInList(this.recipe.id).subscribe(recipeIsInList => {\n        const recipeWasAdded = !recipeIsInList;\n        if (recipeWasAdded){\n          this.recipeEventsService.sendEvent(this.recipe, this.recipeEventsService.ACTION_ADDED);\n          this.subscriptions.push(\n            this.groceriesListsService.appendRecipeToList(this.recipe.id, this.recipe.modifiedGuests, this.eventTrace())\n            .pipe(take(1))\n            .subscribe(l => {\n              this.toggleButtonLoader(false);\n              if (recipeWasAdded && this.recipeAddedToastText && this.recipeAddedToastText.length > 0) {\n                this.toastr.info(this.recipeAddedToastText, null, { closeButton: true, progressBar: true });\n              }\n            })\n          );\n        }\n      })\n    );\n    this.recipeAdded.emit();\n  }\n  addRecipeActionKO(): void {\n    sessionStorage.setItem('_miam/cached-recipe', JSON.stringify(this.recipe));\n    this.recipeError.emit();\n  }\n\n  // If the recipe is already in basket, update the number of guests (= append recipe to list again)\n  updateGuests() {\n    this.groceriesListsService.recipeIsInList(this.recipe.id).subscribe(recipeIsInList => {\n      if (recipeIsInList) {\n        this.groceriesListsService.appendRecipeToList(this.recipe.id, this.recipe.modifiedGuests, this.eventTrace()).subscribe();\n      } else {\n        // Mean we send an event even if receipe is not in basket\n        this.sendEvent(this.analyticsService.EVENT_RECIPE_CHANGEGUESTS);\n      }\n    });\n    this.recipeService.displayedRecipeChanged.emit();\n    this.cdr.detectChanges();\n  }\n\n  print() {\n    this.sendEvent(this.analyticsService.EVENT_RECIPE_PRINT);\n    window.print();\n  }\n\n  toggleAddon(){\n    this.showDetail =  !this.showDetail;\n    this.cdr.detectChanges();\n  }\n\n  toggleHelper() {\n    this.recipeService.toggleHelper();\n    this.cdr.detectChanges();\n  }\n\n  toggleButtonLoader(value: boolean): void {\n    this.addButtonLoading = value;\n    this.cdr.detectChanges();\n  }\n}\n","<div *ngIf=\"showDetail else addon\" class=\"miam-recipe-details\" #mainContainer >\n  <!-- HEADER -->\n  <div class=\"miam-recipe-details__header\">\n    <!-- BOOKMARK -->\n    <div class=\"miam-recipe-details__bookmark\">\n      <img *ngIf=\"!isMobile else stamp\" src=\"https://storage.googleapis.com/assets.miam.tech/generic/recipe-details/recipe-details-bookmark.svg\">\n      <ng-template #stamp>\n        <img src=\"https://storage.googleapis.com/assets.miam.tech/generic/recipe-details/recipe-details-stamp.svg\">\n      </ng-template>\n    </div>\n    <!-- TITLE - DESKTOP -->\n    <div class=\"miam-recipe-details__title\">\n      <span *ngIf=\"!isMobile || titleInHeader\">\n        {{recipe?.attributes['title']}}\n      </span>\n    </div>\n    <!-- HEADER LINK -->\n    <a class=\"miam-recipe-details__header__link\" [href]=\"contextService.miam.router.catalog\">\n      Voir plus d'idées repas\n    </a>\n  </div>\n\n  <div class=\"miam-recipe-details__container\">\n    <!-- LEFT PART (TOP PART ON MOBILE) -->\n    <div #topContainerImg class=\"miam-recipe-details__summary\">\n      <div class=\"miam-recipe-details__summary__container\">\n        <!-- SPONSOR -->\n        <div class=\"miam-recipe-details__sponsor\">\n          <ng-miam-addon-link *ngIf=\"recipe?.sponsors?.length > 0 || recipe.informationalSentence\"\n            [recipe]='recipe' (showAddon)='toggleAddon()'></ng-miam-addon-link>\n        </div>\n        <!-- PICTURE / VIDEO -->\n        <div class=\"miam-recipe-details__picture\">\n          <img\n            *ngIf=\"!showVideo\"\n            [src]=\"recipe?.attributes['media-url']\"\n            [ngClass]=\"{ 'sponsor': recipe?.sponsors?.length > 0, 'tags': displayTags && recipe.relationships.tags.data.length > 0 }\">\n          <youtube-player\n            *ngIf=\"showVideo && playerWidth\"\n            [videoId]=\"recipe.videoId\"\n            [width]=\"playerWidth\"\n            [height]=\"playerHeight\"\n          ></youtube-player>\n        </div>\n        <!-- ACTIONS ICONS -->\n        <div class=\"miam-recipe-details__actionbar\">\n          <div class=\"miam-recipe-details__actionbar__group\">\n            <ng-miam-like-button *ngIf=\"userService.isLogged$ | async\" class=\"miam-recipe-details__actions__icon like\"\n              [recipe]='recipe' [originTrace]=\"eventTrace()\" [width]=\"24\" [height]=\"24\">\n            </ng-miam-like-button>\n            <ng-miam-icon (click)=\"print()\" class=\"miam-recipe-details__actions__icon print\" [width]=\"24\" [height]=\"24\"\n              primaryColor='var(--m-color-primary)' [iconName]=\"icon.Print\">\n            </ng-miam-icon>\n          </div>\n          <div class=\"miam-recipe-details__actionbar__group\">\n            <ng-miam-icon class=\"miam-recipe-details__actions__icon help\" (click)=\"toggleHelper()\" [width]=\"40\" [height]=\"40\"\n              primaryColor='var(--m-color-grey02)' secondaryColor='var(--m-color-grey07)' [iconName]=\"icon.Help\">\n            </ng-miam-icon>\n          </div>\n        </div>\n        <!-- TIMES, DIFFICULTY & TAGS - DESKTOP -->\n        <ng-miam-recipe-details-infos\n          *ngIf=\"!isMobile\" [recipe]=\"recipe\" [displayTags]=\"displayTags\" [displayTagsIcons]=\"displayTagsIcons\" [reduced]=\"cookingTimeAsPrimaryInfo\">\n        </ng-miam-recipe-details-infos>\n        <!-- STEPS WHEN QUARTER DISPLAY -->\n        <ng-miam-recipe-details-steps *ngIf=\"!isMobile && stepsOnLeftSide\" [recipe]=\"recipe\"></ng-miam-recipe-details-steps>\n\n        <!-- PRICE & PRIMARY CTA -->\n        <div class=\"miam-recipe-details__action__container\">\n          <!-- PRICE -->\n          <div class=\"miam-recipe-details__price\">\n            <ng-miam-recipe-pricing\n              *ngIf=\"recipe && displayPricing\" [recipe]=\"recipe\" [serves]=\"recipe?.modifiedGuests\" [guestsText]=\"pricingGuestsText\">\n            </ng-miam-recipe-pricing>\n          </div>\n          <!-- PRIMARY CTA -->\n          <div *ngIf=\"previewAllowed\"  class=\"miam-recipe-details__addbasket\" (click)=\"clickPrimary()\"\n            [ngClass]=\"{ 'in-basket': (groceriesListsService.recipeIsInList(recipe?.id) | async), 'loading': addButtonLoading}\">\n            <div *ngIf=\"!addButtonLoading else addLoader\" class=\"miam-recipe-details__addbasket__cta\">\n              <span>\n                {{(groceriesListsService.recipeIsInList(recipe?.id) | async) ? 'Voir les produits' : 'Ajouter les ingrédients'}}\n              </span>\n              <ng-miam-icon\n                *ngIf=\"!(groceriesListsService.recipeIsInList(recipe?.id) | async)\" [width]=\"24\" [height]=\"24\" primaryColor='#fff'\n                [iconName]=\"icon.Cart\">\n              </ng-miam-icon>\n            </div>\n            <ng-template #addLoader>\n              <ng-miam-loader></ng-miam-loader>\n            </ng-template>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!-- RIGHT PART (BOTTOM PART ON MOBILE) -->\n    <div class=\"miam-recipe-details__content\" id=\"miam-recipe-details__content\">\n      <!-- TITLE - MOBILE -->\n      <div>\n        <div *ngIf=\"isMobile\" class=\"miam-recipe-details__title\" id=\"miam-recipe-details__title\">\n          {{recipe?.attributes['title']}}\n        </div>\n      </div>\n      <!-- DESCRIPTION -->\n      <div *ngIf=\"recipe?.attributes.description\" class=\"miam-recipe-details__content__description\">\n        {{ recipe?.attributes.description }}\n      </div>\n      <!-- TIMES, DIFFICULTY & TAGS - MOBILE -->\n      <ng-miam-recipe-details-infos\n        *ngIf=\"isMobile\" [recipe]=\"recipe\" [displayTags]=\"displayTags\" [displayTagsIcons]=\"displayTagsIcons\" [reduced]=\"cookingTimeAsPrimaryInfo\">\n      </ng-miam-recipe-details-infos>\n      <!-- INGREDIENTS -->\n      <ng-miam-recipe-details-ingredients [recipe]=\"recipe\" [ingredientsPictures]=\"ingredientsPictures\" (guestsUpdated)=\"updateGuests()\"></ng-miam-recipe-details-ingredients>\n      <!-- STEPS -->\n      <ng-miam-recipe-details-steps\n        *ngIf=\"!(!isMobile && stepsOnLeftSide)\" [recipe]=\"recipe\">\n      </ng-miam-recipe-details-steps>\n      <!-- LINK IMAGE -->\n      <a class=\"miam-recipe-details__content__image\" [href]=\"contextService.miam.router.catalog\">\n        <img [src]=\"moreRecipesImageURL\">\n      </a>\n    </div>\n  </div>\n</div>\n<!-- ADDON -->\n<ng-template #addon>\n  <ng-miam-recipe-addon [recipe]='recipe' (hideAddon)=\"toggleAddon()\"></ng-miam-recipe-addon>\n</ng-template>"]}
@@ -152,15 +152,12 @@ export class RecipeTagsComponent extends EventTracerComponent {
152
152
  return bpl.entries.found.find(entry => entry.selectedItem.attributes['ext-id'] === this.extId);
153
153
  });
154
154
  this.cdr.detectChanges();
155
+ this.detectWrappedTags(this.tags);
155
156
  }
156
157
  }));
157
158
  }
158
159
  this.cdr.detectChanges();
159
160
  }
160
- ngAfterViewInit() {
161
- // Call each time list of recipe-tags change
162
- this.subscriptions.push(this.tags.changes.subscribe(queryList => this.detectWrappedTags(queryList)));
163
- }
164
161
  ngOnDestroy() {
165
162
  this.subscriptions.forEach(sub => sub.unsubscribe());
166
163
  }
@@ -235,4 +232,4 @@ RecipeTagsComponent.ɵcmp = i0.ɵɵdefineComponent({ type: RecipeTagsComponent,
235
232
  type: ViewChildren,
236
233
  args: ['tag']
237
234
  }] }); })();
238
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recipe-tags.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/recipe-tags/recipe-tags.component.ts","lib/_web-components/recipe-tags/recipe-tags.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, ChangeDetectionStrategy, ViewEncapsulation, ChangeDetectorRef,\n  OnDestroy, Input, ViewChildren, ElementRef, QueryList, AfterViewInit, SimpleChanges, OnChanges\n} from '@angular/core';\nimport { BasketsService } from '../../_services/baskets.service';\nimport { Subscription } from 'rxjs';\nimport { Icon } from '../../_types/icon.enum';\nimport { BasketPreviewLine } from '../../_models';\nimport { ContextService } from '../../_services';\nimport groupBy from 'lodash-es/groupBy';\nimport { EventTracerComponent } from '../../_components/abstracts/event-tracer.component';\nimport { AnalyticsService } from '../../_services/analytics.service';\n\n\n@Component({\n  selector: 'ng-miam-recipe-tags',\n  templateUrl: './recipe-tags.component.html',\n  styleUrls: ['./recipe-tags.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RecipeTagsComponent extends EventTracerComponent implements OnChanges, AfterViewInit, OnDestroy {\n  @Input() extId: string;\n  @Input() recipeDetailPreviewAllowed = true;\n  @Input() reduce = false;\n  @ViewChildren('tag') tags: QueryList<ElementRef>;\n\n  icon = Icon;\n  recipePreviewLines: BasketPreviewLine[];\n  wrappedItemsCount: number;\n  rowCount: number;\n  lastItemIndexOfFirstRow: number;\n  isListOpen: boolean;\n  modalTitle: string;\n  modalIsOpened = false;\n\n  protected subscriptions: Subscription[];\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private basketService: BasketsService,\n    private contexteservice: ContextService,\n    protected analyticsService: AnalyticsService\n  ) {\n    super(analyticsService);\n    this.subscriptions = [];\n  }\n\n  currentPath(): string {\n    return '';\n  }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    if (simpleChanges.hasOwnProperty('extId') && simpleChanges.extId.firstChange) {\n      this.subscriptions.push(this.basketService.basketPreview$.subscribe(basketPreviewLines => {\n        if (basketPreviewLines) {\n          // we get the list of basketPreviewLines (at recipe level) witch have items link with given extId\n          this.recipePreviewLines = basketPreviewLines.filter(bpl => {\n            return bpl.entries.found.find(entry => entry.selectedItem.attributes['ext-id'] === this.extId);\n          });\n          this.cdr.detectChanges();\n        }\n      }\n      ));\n    }\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n    // Call each time list of recipe-tags change\n    this.subscriptions.push(this.tags.changes.subscribe(queryList => this.detectWrappedTags(queryList)));\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n\n  /**\n   * This function detect and count wrapped item below the fist row\n   * items and container can have various width so row number can differ\n   * base on absolute position in window we are able to find element witch belongs\n   * to the first row and other and then count hidden elements and number of rows\n   * @param tags  QueryList<ElementRef>\n   */\n  detectWrappedTags(tags: QueryList<ElementRef>) {\n\n    if (tags.length === 0){ return; }\n\n    // get for each element his absolute position from top of window\n    const tagsPosition = tags.map(tag => tag.nativeElement.getBoundingClientRect());\n\n    // group by top , element that share the same top position are in the same line\n    const tagsGroupByRow = groupBy(tagsPosition, 'top');\n\n    // get list of distinct hight\n    const tagsDistinctHight = Object.keys(tagsGroupByRow);\n\n    this.rowCount = tagsDistinctHight.length;\n\n    // get size of first row 'll help us to get last item of this row\n    this.lastItemIndexOfFirstRow = tagsGroupByRow[tagsDistinctHight[0]].length - 1;\n\n    // wrapped items count is length - tags count in first row\n    this.wrappedItemsCount = tags.toArray().length - (this.lastItemIndexOfFirstRow + 1);\n    this.cdr.detectChanges();\n  }\n\n  toggleRecipe(id: string) {\n    this.contexteservice.miam.recipes.display(id, this.recipeDetailPreviewAllowed, false, this.eventTrace());\n  }\n\n  toggleList() {\n    this.isListOpen = !this.isListOpen;\n    this.cdr.detectChanges();\n  }\n\n  toggleModal() {\n    if (!this.modalIsOpened) {\n      this.modalTitle = 'Utilisé dans ' + this.recipePreviewLines.length + ' repas';\n    }\n    this.modalIsOpened = !this.modalIsOpened;\n    this.cdr.detectChanges();\n  }\n}\n","<ng-container *ngIf=\"!reduce else reduced\">\n  <div class=\"miam-recipe-tags__container\" *ngIf=\"recipePreviewLines?.length > 0\" [ngStyle]=\"{'height.px': isListOpen ? 32 * rowCount : 24  }\">\n    <div class=\"miam-recipe-tags__container__list\" >\n      <div #tag class=\"miam-recipe-tags__list__badge\" *ngFor=\"let recipeLine of recipePreviewLines, let i = index\">\n        <ng-miam-icon class=\"miam-recipe-tags__badge__icon\" [iconName]='icon.Meal' (click)='toggleRecipe(recipeLine.id)'\n          primaryColor='var(--m-color-white)'></ng-miam-icon>\n        <span class=\"miam-recipe-tag__badge__text\" (click)='toggleRecipe(recipeLine.id)'>{{recipeLine.title | ellipsis : 6}}</span>\n      </div>\n    </div>\n    <div [ngClass]=\"{'miam-recipe-tags__container__toggle__hidden': !rowCount || wrappedItemsCount === 0 }\" class=\"miam-recipe-tags__container__toggle\" >\n      <span  class=\"miam-recipe-tags__toggle__open\" (click)='toggleList()'>\n        {{ isListOpen ? '  ' : '+' +wrappedItemsCount}}</span>\n        <div class=\"miam-recipe-tags__toggle__ligne\"></div>\n        <span class=\"miam-recipe-tags__toggle__close\" [ngStyle]=\"{'opacity': isListOpen ? 1 : 0}\" (click)='toggleList()'> \n          <ng-miam-icon [iconName]='icon.ChevronDown' width='24' height='24'  primaryColor='var(--m-color-white)'></ng-miam-icon>\n        </span>\n    </div>\n  </div>\n</ng-container>\n<ng-template #reduced>\n  <div class=\"miam-recipe-tags__recipes\" *ngIf=\"recipePreviewLines?.length > 0\" (click)=\"toggleModal()\">\n    <span>{{recipePreviewLines.length}} repas</span>\n  </div>\n\n  <ng-miam-modal \n    [isAngularComponent]=\"true\" \n    [expanded]=\"modalIsOpened\"\n    [noHeaderMode]=\"false\" \n    [title]=\"modalTitle\"\n    (close)=\"toggleModal()\"\n    class=\"miam-recipe-tags__modal\"\n  >\n    <div class=\"miam-recipe-tags__container__list\" >\n      <div #tag class=\"miam-recipe-tags__list__badge\" *ngFor=\"let recipeLine of recipePreviewLines, let i = index\">\n        <ng-miam-icon class=\"miam-recipe-tags__badge__icon\" [iconName]='icon.Meal' (click)='toggleRecipe(recipeLine.id)'\n          primaryColor='var(--m-color-white)'></ng-miam-icon>\n        <span class=\"miam-recipe-tag__badge__text\" (click)='toggleRecipe(recipeLine.id)'>{{recipeLine.title}}</span>\n      </div>\n    </div>\n  </ng-miam-modal>\n</ng-template>\n\n"]}
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recipe-tags.component.js","sourceRoot":"/builds/miam/ng-miam-sdk/projects/ng-miam/src/","sources":["lib/_web-components/recipe-tags/recipe-tags.component.ts","lib/_web-components/recipe-tags/recipe-tags.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, ChangeDetectionStrategy, ViewEncapsulation, ChangeDetectorRef,\n  OnDestroy, Input, ViewChildren, ElementRef, QueryList, AfterViewInit, SimpleChanges, OnChanges\n} from '@angular/core';\nimport { BasketsService } from '../../_services/baskets.service';\nimport { Subscription } from 'rxjs';\nimport { Icon } from '../../_types/icon.enum';\nimport { BasketPreviewLine } from '../../_models';\nimport { ContextService } from '../../_services';\nimport groupBy from 'lodash-es/groupBy';\nimport { EventTracerComponent } from '../../_components/abstracts/event-tracer.component';\nimport { AnalyticsService } from '../../_services/analytics.service';\n\n\n@Component({\n  selector: 'ng-miam-recipe-tags',\n  templateUrl: './recipe-tags.component.html',\n  styleUrls: ['./recipe-tags.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class RecipeTagsComponent extends EventTracerComponent implements OnChanges, OnDestroy {\n  @Input() extId: string;\n  @Input() recipeDetailPreviewAllowed = true;\n  @Input() reduce = false;\n  @ViewChildren('tag') tags: QueryList<ElementRef>;\n\n  icon = Icon;\n  recipePreviewLines: BasketPreviewLine[];\n  wrappedItemsCount: number;\n  rowCount: number;\n  lastItemIndexOfFirstRow: number;\n  isListOpen: boolean;\n  modalTitle: string;\n  modalIsOpened = false;\n\n  protected subscriptions: Subscription[];\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private basketService: BasketsService,\n    private contexteservice: ContextService,\n    protected analyticsService: AnalyticsService\n  ) {\n    super(analyticsService);\n    this.subscriptions = [];\n  }\n\n  currentPath(): string {\n    return '';\n  }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    if (simpleChanges.hasOwnProperty('extId') && simpleChanges.extId.firstChange) {\n      this.subscriptions.push(this.basketService.basketPreview$.subscribe(basketPreviewLines => {\n        if (basketPreviewLines) {\n          // we get the list of basketPreviewLines (at recipe level) witch have items link with given extId\n          this.recipePreviewLines = basketPreviewLines.filter(bpl => {\n            return bpl.entries.found.find(entry => entry.selectedItem.attributes['ext-id'] === this.extId);\n          });\n          this.cdr.detectChanges();\n          this.detectWrappedTags(this.tags);\n        }\n      }\n      ));\n    }\n    this.cdr.detectChanges();\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n\n  /**\n   * This function detect and count wrapped item below the fist row\n   * items and container can have various width so row number can differ\n   * base on absolute position in window we are able to find element witch belongs\n   * to the first row and other and then count hidden elements and number of rows\n   * @param tags  QueryList<ElementRef>\n   */\n  detectWrappedTags(tags: QueryList<ElementRef>) {\n    if (tags.length === 0){ return; }\n\n    // get for each element his absolute position from top of window\n    const tagsPosition = tags.map(tag => tag.nativeElement.getBoundingClientRect());\n\n    // group by top , element that share the same top position are in the same line\n    const tagsGroupByRow = groupBy(tagsPosition, 'top');\n\n    // get list of distinct hight\n    const tagsDistinctHight = Object.keys(tagsGroupByRow);\n\n    this.rowCount = tagsDistinctHight.length;\n\n    // get size of first row 'll help us to get last item of this row\n    this.lastItemIndexOfFirstRow = tagsGroupByRow[tagsDistinctHight[0]].length - 1;\n\n    // wrapped items count is length - tags count in first row\n    this.wrappedItemsCount = tags.toArray().length - (this.lastItemIndexOfFirstRow + 1);\n    this.cdr.detectChanges();\n  }\n\n  toggleRecipe(id: string) {\n    this.contexteservice.miam.recipes.display(id, this.recipeDetailPreviewAllowed, false, this.eventTrace());\n  }\n\n  toggleList() {\n    this.isListOpen = !this.isListOpen;\n    this.cdr.detectChanges();\n  }\n\n  toggleModal() {\n    if (!this.modalIsOpened) {\n      this.modalTitle = 'Utilisé dans ' + this.recipePreviewLines.length + ' repas';\n    }\n    this.modalIsOpened = !this.modalIsOpened;\n    this.cdr.detectChanges();\n  }\n}\n","<ng-container *ngIf=\"!reduce else reduced\">\n  <div class=\"miam-recipe-tags__container\" *ngIf=\"recipePreviewLines?.length > 0\" [ngStyle]=\"{'height.px': isListOpen ? 32 * rowCount : 24  }\">\n    <div class=\"miam-recipe-tags__container__list\" >\n      <div #tag class=\"miam-recipe-tags__list__badge\" *ngFor=\"let recipeLine of recipePreviewLines, let i = index\">\n        <ng-miam-icon class=\"miam-recipe-tags__badge__icon\" [iconName]='icon.Meal' (click)='toggleRecipe(recipeLine.id)'\n          primaryColor='var(--m-color-white)'></ng-miam-icon>\n        <span class=\"miam-recipe-tag__badge__text\" (click)='toggleRecipe(recipeLine.id)'>{{recipeLine.title | ellipsis : 6}}</span>\n      </div>\n    </div>\n    <div [ngClass]=\"{'miam-recipe-tags__container__toggle__hidden': !rowCount || wrappedItemsCount === 0 }\" class=\"miam-recipe-tags__container__toggle\" >\n      <span  class=\"miam-recipe-tags__toggle__open\" (click)='toggleList()'>\n        {{ isListOpen ? '  ' : '+' +wrappedItemsCount}}</span>\n        <div class=\"miam-recipe-tags__toggle__ligne\"></div>\n        <span class=\"miam-recipe-tags__toggle__close\" [ngStyle]=\"{'opacity': isListOpen ? 1 : 0}\" (click)='toggleList()'> \n          <ng-miam-icon [iconName]='icon.ChevronDown' width='24' height='24'  primaryColor='var(--m-color-white)'></ng-miam-icon>\n        </span>\n    </div>\n  </div>\n</ng-container>\n<ng-template #reduced>\n  <div class=\"miam-recipe-tags__recipes\" *ngIf=\"recipePreviewLines?.length > 0\" (click)=\"toggleModal()\">\n    <span>{{recipePreviewLines.length}} repas</span>\n  </div>\n\n  <ng-miam-modal \n    [isAngularComponent]=\"true\" \n    [expanded]=\"modalIsOpened\"\n    [noHeaderMode]=\"false\" \n    [title]=\"modalTitle\"\n    (close)=\"toggleModal()\"\n    class=\"miam-recipe-tags__modal\"\n  >\n    <div class=\"miam-recipe-tags__container__list\" >\n      <div #tag class=\"miam-recipe-tags__list__badge\" *ngFor=\"let recipeLine of recipePreviewLines, let i = index\">\n        <ng-miam-icon class=\"miam-recipe-tags__badge__icon\" [iconName]='icon.Meal' (click)='toggleRecipe(recipeLine.id)'\n          primaryColor='var(--m-color-white)'></ng-miam-icon>\n        <span class=\"miam-recipe-tag__badge__text\" (click)='toggleRecipe(recipeLine.id)'>{{recipeLine.title}}</span>\n      </div>\n    </div>\n  </ng-miam-modal>\n</ng-template>\n\n"]}
@@ -1634,15 +1634,15 @@ class RecipeLikesService extends Service {
1634
1634
  return this.isCleaning.asObservable().pipe(skipWhile(isCleaning => isCleaning), take(1), switchMap(_ => this.afterCLeanAddLikesToRecipes(recipes)));
1635
1635
  }
1636
1636
  afterCLeanAddLikesToRecipes(recipes) {
1637
- const recipeIds = recipes.map(r => r.id).filter(rid => !this.activeRecipeLikes.has(rid));
1638
- if (recipeIds.length == 0) {
1637
+ recipes = recipes.filter(recipe => !this.activeRecipeLikes.has(recipe.id));
1638
+ if (recipes.length == 0) {
1639
1639
  return of(null);
1640
1640
  }
1641
1641
  ;
1642
1642
  return this.all({
1643
1643
  page: { size: 20, number: 1 },
1644
1644
  remotefilter: {
1645
- recipe_id: recipeIds.join(),
1645
+ recipe_id: recipes.map(r => r.id).join(),
1646
1646
  is_past: 'true,false'
1647
1647
  }
1648
1648
  }).pipe(skipWhile(resp => resp.is_loading), tap(result => {
@@ -7950,9 +7950,9 @@ class LoaderComponent {
7950
7950
  constructor() { }
7951
7951
  }
7952
7952
  LoaderComponent.ɵfac = function LoaderComponent_Factory(t) { return new (t || LoaderComponent)(); };
7953
- LoaderComponent.ɵcmp = ɵɵdefineComponent({ type: LoaderComponent, selectors: [["ng-miam-loader"]], decls: 1, vars: 0, consts: [[1, "loader"]], template: function LoaderComponent_Template(rf, ctx) { if (rf & 1) {
7953
+ LoaderComponent.ɵcmp = ɵɵdefineComponent({ type: LoaderComponent, selectors: [["ng-miam-loader"]], decls: 1, vars: 0, consts: [[1, "miam-loader"]], template: function LoaderComponent_Template(rf, ctx) { if (rf & 1) {
7954
7954
  ɵɵelement(0, "div", 0);
7955
- } }, styles: [".loader{-webkit-animation:spin .5s linear infinite;animation:spin .5s linear infinite;border:var(--m-loader-thickness) solid var(--m-color-grey);border-radius:var(--m-border-radius-circle);border-top:var(--m-loader-thickness) solid var(--m-color-ternary);height:var(--m-loader-size);width:var(--m-loader-size)}@-webkit-keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}"], encapsulation: 2 });
7955
+ } }, styles: [".miam-loader{-webkit-animation:miam-loader-spin .5s linear infinite;animation:miam-loader-spin .5s linear infinite;border:var(--m-loader-thickness) solid var(--m-color-grey);border-radius:var(--m-border-radius-circle);border-top:var(--m-loader-thickness) solid var(--m-color-ternary);height:var(--m-loader-size);width:var(--m-loader-size)}@-webkit-keyframes miam-loader-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes miam-loader-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}"], encapsulation: 2 });
7956
7956
  /*@__PURE__*/ (function () { ɵsetClassMetadata(LoaderComponent, [{
7957
7957
  type: Component,
7958
7958
  args: [{
@@ -9286,6 +9286,7 @@ class AbstractRecipeCardComponent extends EventTracerComponent {
9286
9286
  ngAfterViewInit() {
9287
9287
  this.sendShowEvent();
9288
9288
  this.displayPrice();
9289
+ this.subscriptions.push(this.groceriesListsService.list$.subscribe(() => this.cdr.detectChanges()));
9289
9290
  }
9290
9291
  ngOnDestroy() {
9291
9292
  this.subscriptions.forEach(sub => sub.unsubscribe());
@@ -13769,7 +13770,7 @@ class RecipeCatalogComponent extends EventTracerComponent {
13769
13770
  }
13770
13771
  const selectedCategory = this.categories.find((cat) => cat.key === paramsArray.get('catalogCategory'));
13771
13772
  if (selectedCategory) {
13772
- return this.categoryTitleClicked(selectedCategory);
13773
+ return this.categoryTitleClicked({ title: selectedCategory.title, filters: selectedCategory.filters.additionalFilters.filters });
13773
13774
  }
13774
13775
  }
13775
13776
  // Show feedback block only if user is logged and the children preference is unknown
@@ -16276,15 +16277,12 @@ class RecipeTagsComponent extends EventTracerComponent {
16276
16277
  return bpl.entries.found.find(entry => entry.selectedItem.attributes['ext-id'] === this.extId);
16277
16278
  });
16278
16279
  this.cdr.detectChanges();
16280
+ this.detectWrappedTags(this.tags);
16279
16281
  }
16280
16282
  }));
16281
16283
  }
16282
16284
  this.cdr.detectChanges();
16283
16285
  }
16284
- ngAfterViewInit() {
16285
- // Call each time list of recipe-tags change
16286
- this.subscriptions.push(this.tags.changes.subscribe(queryList => this.detectWrappedTags(queryList)));
16287
- }
16288
16286
  ngOnDestroy() {
16289
16287
  this.subscriptions.forEach(sub => sub.unsubscribe());
16290
16288
  }