UNPKG

@vendasta/store

Version:

Components and data for Store

228 lines 20.1 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'; var VaPricingComponent = /** @class */ (function () { function VaPricingComponent() { this.pricing = null; this.wrapFrequency = false; this.isAddon = false; this.hasVerifiedContract = false; this.highlightPrice = true; this.loaded = true; } Object.defineProperty(VaPricingComponent.prototype, "isFree", { get: /** * @return {?} */ function () { /** @type {?} */ var isFreeHelper = function (prices) { return prices ? prices.some(function (p) { return 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; }, enumerable: true, configurable: true }); Object.defineProperty(VaPricingComponent.prototype, "shouldContactSales", { get: /** * @return {?} */ function () { /** @type {?} */ var nestedPricesIsContactSales = function (prices) { return prices && prices.length > 0 ? prices.some(function (p) { return 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); }, enumerable: true, configurable: true }); /** * @param {?} billedProduct * @return {?} */ VaPricingComponent.prototype.isFlatPrice = /** * @param {?} billedProduct * @return {?} */ function (billedProduct) { return billedProduct.pricingTiers.length === 1; }; /** * @param {?} tier * @return {?} */ VaPricingComponent.prototype.buildPricingTierString = /** * @param {?} tier * @return {?} */ function (tier) { /** @type {?} */ var 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 {?} */ VaPricingComponent.prototype.buildPricingTierForProduct = /** * @param {?} tier * @param {?=} frequency * @return {?} */ function (tier, frequency) { /** @type {?} */ var pricingTier = this.buildPricingTierString(tier); /** @type {?} */ var formattedFrequency = formatBillingFrequency(frequency); return pricingTier ? pricingTier + ' accounts ' + formattedFrequency : formattedFrequency; }; /** * @param {?} tier * @return {?} */ VaPricingComponent.prototype.buildPricingTierForAddon = /** * @param {?} tier * @return {?} */ function (tier) { /** @type {?} */ var pricingRange = this.buildPricingTierString(tier); return pricingRange ? pricingRange : ''; }; /** * @param {?} price * @param {?} currency * @param {?=} excludeFrequency * @return {?} */ VaPricingComponent.prototype.buildPriceStringForPricing = /** * @param {?} price * @param {?} currency * @param {?=} excludeFrequency * @return {?} */ function (price, currency, excludeFrequency) { return formatDisplayPrice(price.price, currency, (/** @type {?} */ ((excludeFrequency ? '' : price.frequency))), true, true, true, price.isStartingPrice); }; /** * @param {?} tier * @param {?=} frequency * @param {?=} isStartingPrice * @return {?} */ VaPricingComponent.prototype.buildPriceStringForTier = /** * @param {?} tier * @param {?=} frequency * @param {?=} isStartingPrice * @return {?} */ function (tier, frequency, isStartingPrice) { return formatDisplayPrice(tier.price, this.billedProduct.currency, (/** @type {?} */ (frequency)), undefined, undefined, undefined, isStartingPrice); }; /** * @param {?=} frequency * @return {?} */ VaPricingComponent.prototype.buildFrequencyString = /** * @param {?=} frequency * @return {?} */ function (frequency) { return formatBillingFrequency(frequency); }; /** * @return {?} */ VaPricingComponent.prototype.buildCommitmentMessage = /** * @return {?} */ function () { /** @type {?} */ var frequency = this.billedProduct ? this.billedProduct.billingFrequency.toString().toLowerCase() : this.pricing && this.pricing.prices.length > 0 ? this.pricing.prices[0].frequency.toLowerCase() : ''; /** @type {?} */ var 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 {?} */ var initial = this.billedProduct.commitment.initial; /** @type {?} */ var 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 }] }; return VaPricingComponent; }()); export { VaPricingComponent }; 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"]}