UNPKG

@vendasta/store

Version:

Components and data for Store

250 lines 20 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'; var VaAddonListComponent = /** @class */ (function () { function VaAddonListComponent(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 = []; } Object.defineProperty(VaAddonListComponent.prototype, "addons", { set: /** * @param {?} addons * @return {?} */ function (addons) { this._addons = addons; this.populateBilledProduct(); }, enumerable: true, configurable: true }); Object.defineProperty(VaAddonListComponent.prototype, "hasVerifiedContract", { set: /** * @param {?} value * @return {?} */ function (value) { this._hasVerifiedContract = value; this.populateBilledProduct(); }, enumerable: true, configurable: true }); Object.defineProperty(VaAddonListComponent.prototype, "canAccessContractPricing", { set: /** * @param {?} value * @return {?} */ function (value) { this._canAccessContractPricing = value; this.populateBilledProduct(); }, enumerable: true, configurable: true }); /** * @return {?} */ VaAddonListComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.populateBilledProduct(); }; /** * @return {?} */ VaAddonListComponent.prototype.populateBilledProduct = /** * @return {?} */ function () { var _this = this; if (this.displayContractPricing()) { /** @type {?} */ var billingIDs = this._addons.map(function (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(function (pricing) { _this._addons.forEach(function (addon) { /** @type {?} */ var addonPricing = pricing[addon.billingId]; if (!addonPricing) { return; } /** @type {?} */ var billedProduct = buildBilledProductFromProductPricingAndAddon(addon, addonPricing); _this.billedProductsMap.set(addon.addonId, billedProduct); _this.billedProductLoaded.set(addon.addonId, true); }); _this.cdr.detectChanges(); })); } }; /** * @param {?} addonId * @return {?} */ VaAddonListComponent.prototype.onClick = /** * @param {?} addonId * @return {?} */ function (addonId) { this.addonSelected.emit(addonId); }; /** * @param {?} object * @return {?} */ VaAddonListComponent.prototype.instanceOfPricing = /** * @param {?} object * @return {?} */ function (object) { if (typeof object === 'number') { return false; } return object.currency !== undefined && object.prices !== undefined; }; /** * @param {?} addon * @return {?} */ VaAddonListComponent.prototype.getDisplayPricing = /** * @param {?} addon * @return {?} */ function (addon) { /** @type {?} */ var 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 {?} */ VaAddonListComponent.prototype.noData = /** * @return {?} */ function () { return isNullOrUndefined(this._hasVerifiedContract) || isNullOrUndefined(this._canAccessContractPricing); }; /** * @return {?} */ VaAddonListComponent.prototype.displayContractPricing = /** * @return {?} */ function () { return this._canAccessContractPricing && this._hasVerifiedContract; }; /** * @param {?} addon * @return {?} */ VaAddonListComponent.prototype.isBilledProductLoaded = /** * @param {?} addon * @return {?} */ function (addon) { if (this.noData()) { return false; } if (this.displayContractPricing()) { /** @type {?} */ var value = this.billedProductLoaded.get(addon.addonId); return value ? value : false; } return true; }; /** * @return {?} */ VaAddonListComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.subscriptions.forEach(function (subscription) { return 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 = function () { return [ { 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 }] }; return VaAddonListComponent; }()); export { VaAddonListComponent }; 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"]}