UNPKG

@vendasta/store

Version:

Components and data for Store

208 lines 18.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, EventEmitter, Input, Output, ChangeDetectorRef } from '@angular/core'; import { isNullOrUndefined } from 'util'; import { BillingService, buildBilledProductFromProductPricingAndAddon } from '@vendasta/core/billing'; export class VaAddonListComponent { /** * @param {?} billingService * @param {?} cdr */ constructor(billingService, cdr) { this.billingService = billingService; this.cdr = cdr; this.showPricing = true; this._hasVerifiedContract = null; this._canAccessContractPricing = null; this.addonSelected = new EventEmitter(); this.billedProductsMap = new Map(); this.billedProductLoaded = new Map(); this.subscriptions = []; } /** * @param {?} addons * @return {?} */ set addons(addons) { this._addons = addons; this.populateBilledProduct(); } /** * @param {?} value * @return {?} */ set hasVerifiedContract(value) { this._hasVerifiedContract = value; this.populateBilledProduct(); } /** * @param {?} value * @return {?} */ set canAccessContractPricing(value) { this._canAccessContractPricing = value; this.populateBilledProduct(); } /** * @return {?} */ ngOnInit() { this.populateBilledProduct(); } /** * @return {?} */ populateBilledProduct() { if (this.displayContractPricing()) { /** @type {?} */ const billingIDs = this._addons.map(a => { this.billedProductsMap.set(a.addonId, null); this.billedProductLoaded.set(a.addonId, false); return a.billingId; }); this.subscriptions.push(this.billingService.getMultiProductPricing(this.partnerID, billingIDs).subscribe(pricing => { this._addons.forEach(addon => { /** @type {?} */ const addonPricing = pricing[addon.billingId]; if (!addonPricing) { return; } /** @type {?} */ const billedProduct = buildBilledProductFromProductPricingAndAddon(addon, addonPricing); this.billedProductsMap.set(addon.addonId, billedProduct); this.billedProductLoaded.set(addon.addonId, true); }); this.cdr.detectChanges(); })); } } /** * @param {?} addonId * @return {?} */ onClick(addonId) { this.addonSelected.emit(addonId); } /** * @param {?} object * @return {?} */ instanceOfPricing(object) { if (typeof object === 'number') { return false; } return object.currency !== undefined && object.prices !== undefined; } /** * @param {?} addon * @return {?} */ getDisplayPricing(addon) { /** @type {?} */ const price = addon.price; if (price && this.instanceOfPricing(price)) { return price; } return { currency: addon.currency, prices: [ { price: addon.price, frequency: addon.billingFrequency ? addon.billingFrequency : 'Monthly' } ] }; } /** * @return {?} */ noData() { return isNullOrUndefined(this._hasVerifiedContract) || isNullOrUndefined(this._canAccessContractPricing); } /** * @return {?} */ displayContractPricing() { return this._canAccessContractPricing && this._hasVerifiedContract; } /** * @param {?} addon * @return {?} */ isBilledProductLoaded(addon) { if (this.noData()) { return false; } if (this.displayContractPricing()) { /** @type {?} */ const value = this.billedProductLoaded.get(addon.addonId); return value ? value : false; } return true; } /** * @return {?} */ ngOnDestroy() { this.subscriptions.forEach(subscription => subscription.unsubscribe()); } } VaAddonListComponent.decorators = [ { type: Component, args: [{ selector: 'va-addon-list', template: "<mat-list *ngIf=\"_addons\" class=\"addon-list\">\n <mat-divider></mat-divider>\n <ng-container *ngFor=\"let addon of _addons\">\n <mat-list-item (click)=\"onClick(addon.addonId)\">\n <div class=\"addon-icon-title\">\n <img *ngIf=\"addon.icon;else noIcon\" class=\"addon-icon\" [src]=\"addon.icon\" mat-list-avatar/>\n <ng-template #noIcon>\n <mat-icon class=\"addon-default-icon\" mat-list-icon>add_circle</mat-icon>\n </ng-template>\n <div class=\"addon-title-tagline\">\n <p class=\"addon-title\" matLine>{{ addon.title }} </p>\n <p class=\"addon-tagline\" matLine>{{ addon.tagline }}</p>\n </div>\n </div>\n <div *ngIf=\"showPricing\" class=\"price-section\">\n <va-pricing\n [pricing]=\"getDisplayPricing(addon)\"\n [highlightPrice]=\"false\"\n [hasVerifiedContract]=\"_hasVerifiedContract\"\n [billedProduct]=\"billedProductsMap.get(addon.addonId)\"\n [loaded]=\"isBilledProductLoaded(addon)\">\n </va-pricing>\n </div>\n </mat-list-item>\n <mat-divider></mat-divider>\n </ng-container>\n</mat-list>\n", styles: [":host{display:block}h2+:host{margin:-8px 0}:host ::ng-deep .mat-list-item.mat-2-line{height:auto!important}:host ::ng-deep .mat-list .mat-list-item .mat-list-item-content{padding:8px;align-items:flex-start;flex-direction:column}@media screen and (min-width:800px){:host ::ng-deep .mat-list .mat-list-item .mat-list-item-content{flex-direction:row}}.addon-list{position:relative}.addon-default-icon{margin:0 5px;color:#4caf50}.addon-icon{width:32px;height:32px}.addon-icon-title{flex-grow:1;display:flex;width:100%}@media screen and (min-width:800px){.addon-icon-title{width:auto}}.addon-title-tagline{padding:0 16px 10px 8px;flex-grow:1}.addon-title-tagline .addon-title{color:#212121;font-size:16px;line-height:1.2;margin:6px 0;white-space:normal}.addon-title-tagline .addon-tagline{color:#616161;font-size:14px;margin:0;white-space:normal}.price-section{min-width:10em;margin-top:6px;flex-shrink:0}mat-list-item:hover{background-color:#fafafa!important;cursor:pointer!important}"] }] } ]; /** @nocollapse */ VaAddonListComponent.ctorParameters = () => [ { type: BillingService }, { type: ChangeDetectorRef } ]; VaAddonListComponent.propDecorators = { addons: [{ type: Input, args: ['addons',] }], showPricing: [{ type: Input }], partnerID: [{ type: Input }], hasVerifiedContract: [{ type: Input, args: ['hasVerifiedContract',] }], canAccessContractPricing: [{ type: Input, args: ['canAccessContractPricing',] }], addonSelected: [{ type: Output }] }; if (false) { /** @type {?} */ VaAddonListComponent.prototype._addons; /** @type {?} */ VaAddonListComponent.prototype.showPricing; /** @type {?} */ VaAddonListComponent.prototype.partnerID; /** @type {?} */ VaAddonListComponent.prototype._hasVerifiedContract; /** @type {?} */ VaAddonListComponent.prototype._canAccessContractPricing; /** @type {?} */ VaAddonListComponent.prototype.addonSelected; /** @type {?} */ VaAddonListComponent.prototype.billedProductsMap; /** * @type {?} * @private */ VaAddonListComponent.prototype.billedProductLoaded; /** * @type {?} * @private */ VaAddonListComponent.prototype.subscriptions; /** * @type {?} * @private */ VaAddonListComponent.prototype.billingService; /** * @type {?} * @private */ VaAddonListComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"addon-list.component.js","sourceRoot":"ng://@vendasta/store/","sources":["lib/addon-list/addon-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ChangeDetectorRef } from '@angular/core';\nimport { Addon } from '@vendasta/core/shared';\nimport { Subscription } from 'rxjs';\nimport { Pricing } from '../pricing/pricing';\nimport { isNullOrUndefined } from 'util';\nimport { BillingService, BilledProduct, buildBilledProductFromProductPricingAndAddon } from '@vendasta/core/billing';\n\n@Component({\n  selector: 'va-addon-list',\n  templateUrl: './addon-list.component.html',\n  styleUrls: ['./addon-list.component.scss']\n})\nexport class VaAddonListComponent implements OnDestroy, OnInit {\n  _addons: Addon[];\n  @Input('addons')\n  set addons(addons: Addon[]) {\n    this._addons = addons;\n    this.populateBilledProduct();\n  }\n  @Input() showPricing = true;\n  @Input() partnerID: string;\n\n  _hasVerifiedContract: boolean = null;\n  @Input('hasVerifiedContract')\n  set hasVerifiedContract(value: boolean) {\n    this._hasVerifiedContract = value;\n    this.populateBilledProduct();\n  }\n  _canAccessContractPricing: boolean = null;\n  @Input('canAccessContractPricing')\n  set canAccessContractPricing(value: boolean) {\n    this._canAccessContractPricing = value;\n    this.populateBilledProduct();\n  }\n\n  @Output() addonSelected = new EventEmitter<String>();\n\n  billedProductsMap: Map<string, BilledProduct> = new Map();\n  private billedProductLoaded: Map<string, boolean> = new Map();\n  private subscriptions: Subscription[] = [];\n\n  constructor(private billingService: BillingService, private cdr: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.populateBilledProduct();\n  }\n\n  populateBilledProduct() {\n    if (this.displayContractPricing()) {\n      const billingIDs = this._addons.map(a => {\n        this.billedProductsMap.set(a.addonId, null);\n        this.billedProductLoaded.set(a.addonId, false);\n        return a.billingId;\n      });\n      this.subscriptions.push(\n        this.billingService.getMultiProductPricing(this.partnerID, billingIDs).subscribe(pricing => {\n          this._addons.forEach(addon => {\n            const addonPricing = pricing[addon.billingId];\n            if (!addonPricing) {\n              return;\n            }\n            const billedProduct = buildBilledProductFromProductPricingAndAddon(addon, addonPricing);\n            this.billedProductsMap.set(addon.addonId, billedProduct);\n            this.billedProductLoaded.set(addon.addonId, true);\n          });\n          this.cdr.detectChanges();\n        })\n      )\n    }\n  }\n\n  onClick(addonId: String): void {\n    this.addonSelected.emit(addonId);\n  }\n\n  public instanceOfPricing(object: any) {\n    if (typeof object === 'number') {\n      return false;\n    }\n    return object.currency !== undefined && object.prices !== undefined;\n  }\n\n  getDisplayPricing(addon: Addon): Pricing {\n    const price: any = addon.price;\n    if (price && this.instanceOfPricing(price)) {\n      return price;\n    }\n    return {\n      currency: addon.currency,\n      prices: [\n        {\n          price: addon.price,\n          frequency: addon.billingFrequency ? addon.billingFrequency : 'Monthly'\n        }\n      ]\n    };\n  }\n\n  noData(): boolean {\n    return isNullOrUndefined(this._hasVerifiedContract) || isNullOrUndefined(this._canAccessContractPricing);\n  }\n\n  displayContractPricing(): boolean {\n    return this._canAccessContractPricing && this._hasVerifiedContract;\n  }\n\n  isBilledProductLoaded(addon: Addon): boolean {\n\n    if (this.noData()) {\n      return false;\n    }\n    if (this.displayContractPricing()) {\n      const value = this.billedProductLoaded.get(addon.addonId);\n      return value ? value : false;\n    }\n    return true;\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(subscription => subscription.unsubscribe());\n  }\n}\n"]}