@vendasta/store
Version:
Components and data for Store
182 lines • 18.4 kB
JavaScript
/**
* @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"]}