@vendasta/store
Version:
Components and data for Store
228 lines • 20.1 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';
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"]}