UNPKG

@vendasta/store

Version:

Components and data for Store

182 lines 18.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input } from '@angular/core'; import { formatDisplayPrice, formatBillingFrequency } from '@vendasta/core/shared'; export class VaPricingComponent { constructor() { this.pricing = null; this.wrapFrequency = false; this.isAddon = false; this.hasVerifiedContract = false; this.highlightPrice = true; this.loaded = true; } /** * @return {?} */ get isFree() { /** @type {?} */ const isFreeHelper = (prices) => { return prices ? prices.some(p => p.price === 0 || p.price === undefined) : false; }; if (this.hasVerifiedContract && this.billedProduct) { return this.billedProduct.pricingTiers.length === 1 ? isFreeHelper(this.billedProduct.pricingTiers) : false; } return this.pricing && isFreeHelper(this.pricing.prices) ? true : false; } /** * @return {?} */ get shouldContactSales() { /** @type {?} */ const nestedPricesIsContactSales = (prices) => { return prices && prices.length > 0 ? prices.some(p => p.price === null || p.price < 0) : true; }; if (this.hasVerifiedContract && this.billedProduct) { return nestedPricesIsContactSales(this.billedProduct.pricingTiers) ? true : false; } if (!this.pricing) { return true; } return nestedPricesIsContactSales(this.pricing.prices); } /** * @param {?} billedProduct * @return {?} */ isFlatPrice(billedProduct) { return billedProduct.pricingTiers.length === 1; } /** * @param {?} tier * @return {?} */ buildPricingTierString(tier) { /** @type {?} */ let max = String(tier.rangeMax); if (tier.rangeMax === -1) { max = '∞'; if (tier.rangeMin === 0 || tier.rangeMin === 1) { return ''; } } return String(tier.rangeMin) + ' to ' + max; } /** * @param {?} tier * @param {?=} frequency * @return {?} */ buildPricingTierForProduct(tier, frequency) { /** @type {?} */ const pricingTier = this.buildPricingTierString(tier); /** @type {?} */ const formattedFrequency = formatBillingFrequency(frequency); return pricingTier ? pricingTier + ' accounts ' + formattedFrequency : formattedFrequency; } /** * @param {?} tier * @return {?} */ buildPricingTierForAddon(tier) { /** @type {?} */ const pricingRange = this.buildPricingTierString(tier); return pricingRange ? pricingRange : ''; } /** * @param {?} price * @param {?} currency * @param {?=} excludeFrequency * @return {?} */ buildPriceStringForPricing(price, currency, excludeFrequency) { return formatDisplayPrice(price.price, currency, (/** @type {?} */ ((excludeFrequency ? '' : price.frequency))), true, true, true, price.isStartingPrice); } /** * @param {?} tier * @param {?=} frequency * @param {?=} isStartingPrice * @return {?} */ buildPriceStringForTier(tier, frequency, isStartingPrice) { return formatDisplayPrice(tier.price, this.billedProduct.currency, (/** @type {?} */ (frequency)), undefined, undefined, undefined, isStartingPrice); } /** * @param {?=} frequency * @return {?} */ buildFrequencyString(frequency) { return formatBillingFrequency(frequency); } /** * @return {?} */ buildCommitmentMessage() { /** @type {?} */ const frequency = this.billedProduct ? this.billedProduct.billingFrequency.toString().toLowerCase() : this.pricing && this.pricing.prices.length > 0 ? this.pricing.prices[0].frequency.toLowerCase() : ''; /** @type {?} */ let frequencyString = ''; if (frequency === 'yearly') { frequencyString = 'year'; } else if (frequency === 'monthly') { frequencyString = 'month'; } if (!frequencyString || this.isFree || this.shouldContactSales) { return ''; } if (this.billedProduct && this.billedProduct.commitment) { /** @type {?} */ const initial = this.billedProduct.commitment.initial; /** @type {?} */ const recurring = this.billedProduct.commitment.recurring; if (this.highlightPrice) { return `*${initial} ${frequencyString} minimum, renews for ${recurring} ${frequencyString} periods`; } else { return `${initial} ${frequencyString} commitment`; } } return ''; } } VaPricingComponent.decorators = [ { type: Component, args: [{ selector: 'va-pricing', template: "<ng-container *ngIf=\"highlightPrice\">\n <highlight-pricing [pricing]=\"pricing\"\n [billedProduct]=\"billedProduct\"\n [highlightPrice]=\"highlightPrice\"\n [isAddon]=\"isAddon\"\n [hasVerifiedContract]=\"hasVerifiedContract\"\n [wrapFrequency]=\"wrapFrequency\"\n [loaded]=\"loaded\">\n </highlight-pricing>\n</ng-container>\n<ng-container *ngIf=\"!highlightPrice\">\n <table-pricing [pricing]=\"pricing\"\n [highlightPrice]=\"highlightPrice\"\n [billedProduct]=\"billedProduct\"\n [hasVerifiedContract]=\"hasVerifiedContract\"\n [loaded]=\"loaded\">\n </table-pricing>\n</ng-container>\n", styles: [""] }] } ]; VaPricingComponent.propDecorators = { pricing: [{ type: Input }], billedProduct: [{ type: Input }], wrapFrequency: [{ type: Input }], isAddon: [{ type: Input }], hasVerifiedContract: [{ type: Input }], highlightPrice: [{ type: Input }], loaded: [{ type: Input }] }; if (false) { /** @type {?} */ VaPricingComponent.prototype.pricing; /** @type {?} */ VaPricingComponent.prototype.billedProduct; /** @type {?} */ VaPricingComponent.prototype.wrapFrequency; /** @type {?} */ VaPricingComponent.prototype.isAddon; /** @type {?} */ VaPricingComponent.prototype.hasVerifiedContract; /** @type {?} */ VaPricingComponent.prototype.highlightPrice; /** @type {?} */ VaPricingComponent.prototype.loaded; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pricing.component.js","sourceRoot":"ng://@vendasta/store/","sources":["lib/pricing/pricing.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { BilledProduct, PricingTier } from '@vendasta/core/billing';\nimport { MarketplaceBillingFrequency, formatDisplayPrice, formatBillingFrequency } from '@vendasta/core/shared';\nimport { Pricing, Price } from './pricing';\n\n@Component({\n    selector: 'va-pricing',\n    templateUrl: './pricing.component.html',\n    styleUrls: ['./pricing.component.scss']\n})\nexport class VaPricingComponent {\n    @Input() pricing: Pricing = null;\n    @Input() billedProduct: BilledProduct;\n    @Input() wrapFrequency = false;\n    @Input() isAddon = false;\n    @Input() hasVerifiedContract = false;\n    @Input() highlightPrice = true;\n    @Input() loaded = true;\n\n    get isFree(): boolean {\n        const isFreeHelper = (prices: { price: number }[]): boolean => {\n            return prices\n                ? prices.some(p => p.price === 0 || p.price === undefined)\n                : false;\n        };\n\n        if (this.hasVerifiedContract && this.billedProduct) {\n            return this.billedProduct.pricingTiers.length === 1 ? isFreeHelper(this.billedProduct.pricingTiers) : false;\n        }\n        return this.pricing && isFreeHelper(this.pricing.prices) ? true : false;\n    }\n\n    get shouldContactSales(): boolean {\n        const nestedPricesIsContactSales = (prices: { price: number }[]) => {\n            return prices && prices.length > 0\n                ? prices.some(p => p.price === null || p.price < 0)\n                : true;\n        };\n\n        if (this.hasVerifiedContract && this.billedProduct) {\n            return nestedPricesIsContactSales(this.billedProduct.pricingTiers) ? true : false;\n        }\n        if (!this.pricing) {\n            return true;\n        }\n        return nestedPricesIsContactSales(this.pricing.prices);\n    }\n\n    isFlatPrice(billedProduct: BilledProduct): boolean {\n        return billedProduct.pricingTiers.length === 1;\n    }\n\n    buildPricingTierString(tier: PricingTier): string {\n        let max = String(tier.rangeMax);\n        if (tier.rangeMax === -1) {\n            max = '∞';\n            if (tier.rangeMin === 0 || tier.rangeMin === 1) {\n                return '';\n            }\n        }\n        return String(tier.rangeMin) + ' to ' + max;\n    }\n\n    buildPricingTierForProduct(tier: PricingTier, frequency?: string) {\n        const pricingTier = this.buildPricingTierString(tier);\n        const formattedFrequency = formatBillingFrequency(frequency);\n        return pricingTier ? pricingTier + ' accounts ' + formattedFrequency : formattedFrequency;\n    }\n\n    buildPricingTierForAddon(tier: PricingTier): string {\n        const pricingRange = this.buildPricingTierString(tier);\n        return pricingRange ? pricingRange : '';\n    }\n\n    buildPriceStringForPricing(price: Price, currency: string, excludeFrequency?: boolean): string {\n        return formatDisplayPrice(\n          price.price,\n          currency,\n          (excludeFrequency ? '' : price.frequency) as any,\n          true,\n          true,\n          true,\n          price.isStartingPrice,\n        )\n    }\n\n    buildPriceStringForTier(tier: PricingTier, frequency?: MarketplaceBillingFrequency, isStartingPrice?: boolean) {\n        return formatDisplayPrice(\n          tier.price,\n          this.billedProduct.currency,\n          frequency as any,\n          undefined,\n          undefined,\n          undefined,\n          isStartingPrice);\n    }\n\n    buildFrequencyString(frequency?: string): string {\n        return formatBillingFrequency(frequency);\n    }\n\n    buildCommitmentMessage(): string {\n      const frequency = this.billedProduct ? this.billedProduct.billingFrequency.toString().toLowerCase() :\n        this.pricing && this.pricing.prices.length > 0 ? this.pricing.prices[0].frequency.toLowerCase() : '';\n      let frequencyString = '';\n      if (frequency === 'yearly') {\n        frequencyString = 'year';\n      } else if (frequency === 'monthly') {\n        frequencyString = 'month';\n      }\n      if (!frequencyString || this.isFree || this.shouldContactSales) {\n        return '';\n      }\n      if (this.billedProduct && this.billedProduct.commitment) {\n        const initial = this.billedProduct.commitment.initial;\n        const recurring = this.billedProduct.commitment.recurring;\n        if (this.highlightPrice) {\n          return `*${initial} ${frequencyString} minimum, renews for ${recurring} ${frequencyString} periods`\n        } else {\n          return `${initial} ${frequencyString} commitment`;\n        }\n      }\n      return '';\n    }\n}\n"]}