All files / src/app/extensions/wishlists/pages/account-wishlist/account-wishlist-list account-wishlist-list.component.ts

64.28% Statements 9/14
50% Branches 3/6
33.33% Functions 2/6
69.23% Lines 9/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 662x                   2x 2x 2x                                 2x               2x       2x   2x                 1x                          
import {
  ChangeDetectionStrategy,
  Component,
  DestroyRef,
  EventEmitter,
  Input,
  OnChanges,
  Output,
  inject,
} from '@angular/core';
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
import { TranslateService } from '@ngx-translate/core';
import { take } from 'rxjs/operators';
 
import { ModalDialogComponent } from 'ish-shared/components/common/modal-dialog/modal-dialog.component';
 
import { Wishlist } from '../../../models/wishlist/wishlist.model';
 
/**
 * The Account Wishlist List Component show the customer an overview list over his wishlists.
 *
 * @example
 * <ish-account-wishlist-list [wishlists]="wishlists" (deleteWishlist)="deleteWishlist($event)"></ish-account-wishlist-list>
 */
@Component({
  selector: 'ish-account-wishlist-list',
  templateUrl: './account-wishlist-list.component.html',
  changeDetection: ChangeDetectionStrategy.OnPush,
})
export class AccountWishlistListComponent implements OnChanges {
  /**
   * The list of wishlists of the customer.
   */
  @Input() wishlists: Wishlist[];
  /**
   * Emits the id of the wishlist, which is to be deleted.
   */
  @Output() deleteWishlist = new EventEmitter<string>();
 
  preferredWishlist: Wishlist;
 
  private destroyRef = inject(DestroyRef);
 
  constructor(private translate: TranslateService) {}
 
  ngOnChanges() {
    // determine preferred wishlist
    this.preferredWishlist = this.wishlists?.length ? this.wishlists.find(wishlist => wishlist.preferred) : undefined;
  }
 
  /** Emits the id of the wishlist to delete. */
  delete(wishlistId: string) {
    this.deleteWishlist.emit(wishlistId);
  }
 
  /** Determine the heading of the delete modal and opens the modal. */
  openDeleteConfirmationDialog(wishlist: Wishlist, modal: ModalDialogComponent<string>) {
    this.translate
      .get('account.wishlists.delete_wishlist_dialog.header', { 0: wishlist.title })
      .pipe(take(1), takeUntilDestroyed(this.destroyRef))
      .subscribe(res => (modal.options.titleText = res));
 
    modal.show(wishlist.id);
  }
}