All files / src/app/shared/formly-address-forms/components/formly-customer-address-form formly-customer-address-form.component.ts

90% Statements 27/30
58.33% Branches 14/24
87.5% Functions 7/8
89.65% Lines 26/29

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 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 1164x                     4x   4x   4x 4x                                       4x     9x   9x   9x 9x     9x               9x     8x           4x                   4x                   2x   2x       2x 1x 1x         2x   1x 1x       1x     1x         1x      
import {
  ChangeDetectionStrategy,
  Component,
  EventEmitter,
  Input,
  OnChanges,
  OnInit,
  Output,
  SimpleChanges,
  ViewChild,
} from '@angular/core';
import { FormGroup, FormGroupDirective } from '@angular/forms';
import { Observable } from 'rxjs';
import { map, withLatestFrom } from 'rxjs/operators';
 
import { AccountFacade } from 'ish-core/facades/account.facade';
import { FeatureToggleService } from 'ish-core/feature-toggle.module';
import { Address } from 'ish-core/models/address/address.model';
 
/**
 * The Customer Address Form Component renders an address form with apply/cancel buttons so that the user can create or edit an address.
 * When the user submits the form the new/changed address will be sent to the parent component.
 *
 * @example
 * <ish-customer-address-form
      [address]="basket.invoiceToAddress"
      [resetForm]="resetForm"
      (save)="createCustomerInvoiceAddress($event)"
      (cancel)="cancelCreateCustomerInvoiceAddress()"
   ></ish-checkout-address-form>
 */
@Component({
  selector: 'ish-formly-customer-address-form',
  templateUrl: './formly-customer-address-form.component.html',
  changeDetection: ChangeDetectionStrategy.Default,
})
export class FormlyCustomerAddressFormComponent implements OnInit, OnChanges {
  @Input() address: Partial<Address>;
  // not-dead-code
  @Input() resetForm = false;
  // display address extension form fields
  @Input() extension = false;
 
  @Output() save = new EventEmitter<Address>();
  @Output() cancel = new EventEmitter();
 
  form: FormGroup;
  extensionForm: FormGroup = new FormGroup({});
 
  extensionModel: { email: string };
 
  businessCustomer$: Observable<boolean>;
 
  @ViewChild('addressForm') addressForm: FormGroupDirective;
 
  constructor(private accountFacade: AccountFacade, private featureToggleService: FeatureToggleService) {}
 
  get buttonLabel() {
    return Object.keys(this.address ?? {}).length > 0
      ? 'account.addresses.update_address.button.label'
      : 'account.addresses.create_address.button.label';
  }
 
  ngOnInit() {
    this.businessCustomer$ = this.accountFacade.isBusinessCustomer$.pipe(
      withLatestFrom(this.accountFacade.isLoggedIn$),
      map(([isBusinessCustomer, isLoggedIn]) =>
        isBusinessCustomer || isLoggedIn
          ? isBusinessCustomer
          : this.featureToggleService.enabled('businessCustomerRegistration')
      )
    );
 
    // create form for creating a new address
    this.form = new FormGroup({
      address: new FormGroup({}),
      additionalAddressAttributes: this.extensionForm,
    });
  }
 
  /**
   * Trigger reset form from parent.
   */
  ngOnChanges(c: SimpleChanges) {
    this.doResetForm(c.resetForm?.currentValue);
 
    this.extensionModel = this.address ? { email: this.address.email } : undefined;
  }
 
  private doResetForm(resetForm: boolean) {
    if (resetForm && this.form) {
      this.addressForm.resetForm();
      this.form.reset();
    }
  }
 
  submitForm() {
    if (this.form.valid) {
      // build address from form data and send it to the parent
      let formAddress: Address = this.form.value.address;
      Iif (this.address) {
        // update form values in the original address
        formAddress = { ...this.address, mainDivisionCode: '', ...formAddress };
      }
      Iif (this.extension) {
        formAddress = { ...formAddress, email: this.extensionForm.get('email')?.value };
      }
      this.save.emit(formAddress);
    }
  }
 
  cancelForm() {
    this.cancel.emit();
  }
}