@vendasta/store
Version:
Components and data for Store
231 lines • 30.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input } from '@angular/core';
import { trigger, transition, animate, style, state } from '@angular/animations';
import { BehaviorSubject, ReplaySubject, combineLatest, zip } from 'rxjs';
import { filter, map, startWith } from 'rxjs/operators';
import { buildSalesPackages, buildSalesProductFromProduct, addStatusesToSalesPackages, addStatusesToSalesProduct, } from './sales-package';
import { ListIndent } from './package-dropdown-item/package-dropdown-item.component';
export class VaPackageDropdownComponent {
constructor() {
this.singularDropdown = false;
this.packageProductIndent = ListIndent.INDENT_ONE;
this.packageAddonWithoutProductIndent = ListIndent.INDENT_ONE;
this.packageAddonWithProductIndent = ListIndent.INDENT_TWO;
this.productAddonIndent = ListIndent.INDENT_ONE;
this.packages$$ = new ReplaySubject(1);
this.products$$ = new ReplaySubject(1);
this.standAloneProducts$$ = new ReplaySubject(1);
this.statuses$$ = new BehaviorSubject([]);
this.addons$$ = new ReplaySubject(1);
this.packageToggles = [];
this.productToggles = [];
}
// packages in dropdown
/**
* @param {?} packages
* @return {?}
*/
set packages(packages) {
this.packages$$.next(packages);
}
// products within given packages
/**
* @param {?} products
* @return {?}
*/
set products(products) {
this.products$$.next(products);
}
// products not associated with a package
/**
* @param {?} standAloneProducts
* @return {?}
*/
set standAloneProducts(standAloneProducts) {
this.standAloneProducts$$.next(standAloneProducts);
}
// statuses for all products and addons
/**
* @param {?} statuses
* @return {?}
*/
set statuses(statuses) {
this.statuses$$.next(statuses);
}
// addons within given packages
/**
* @param {?} addons
* @return {?}
*/
set addons(addons) {
this.addons$$.next(addons);
}
/**
* @return {?}
*/
ngOnInit() {
/** @type {?} */
const packages$ = this.packages$$.pipe(filter(packages => packages !== null));
/** @type {?} */
const products$ = this.products$$.pipe(filter(products => products !== null));
/** @type {?} */
const addons$ = this.addons$$.pipe(filter(addons => addons !== null));
/** @type {?} */
const salesPackage$ = zip(packages$, products$, addons$).pipe(map(([packages, products, addons]) => buildSalesPackages(packages, products, addons)));
this.salesPackages$ = combineLatest(salesPackage$, this.statuses$$).pipe(map(([salesPackages, statuses]) => addStatusesToSalesPackages(salesPackages, statuses)), startWith([]));
this.salesProducts$ = combineLatest(this.standAloneProducts$$, this.statuses$$).pipe(filter(([products, _]) => products !== null), map(([products, statuses]) => {
return products.map(p => {
/** @type {?} */
const addons = p.addons || null;
/** @type {?} */
const salesProducts = buildSalesProductFromProduct(p, addons);
return addStatusesToSalesProduct(salesProducts, statuses);
});
}), startWith([]));
this.templateData$ = combineLatest(this.salesPackages$, this.salesProducts$).pipe(map(([packages, products]) => ({ packages: packages, products: products })));
}
/**
* @param {?} indexToToggle
* @return {?}
*/
togglePackage(indexToToggle) {
if (this.singularDropdown) {
/** @type {?} */
const openedIndex = this.packageToggles.findIndex(value => value === true);
if (openedIndex !== indexToToggle) {
this.packageToggles[openedIndex] = false;
}
/** @type {?} */
const productOpenedIndex = this.productToggles.findIndex(value => value === true);
if (productOpenedIndex > -1) {
this.productToggles[productOpenedIndex] = false;
}
}
this.packageToggles[indexToToggle] = !this.packageToggles[indexToToggle];
}
/**
* @param {?} indexToToggle
* @return {?}
*/
toggleProduct(indexToToggle) {
if (this.singularDropdown) {
/** @type {?} */
const openedIndex = this.productToggles.findIndex(value => value === true);
if (openedIndex !== indexToToggle) {
this.productToggles[openedIndex] = false;
}
/** @type {?} */
const packageOpenedIndex = this.packageToggles.findIndex(value => value === true);
if (packageOpenedIndex > -1) {
this.packageToggles[packageOpenedIndex] = false;
}
}
this.productToggles[indexToToggle] = !this.productToggles[indexToToggle];
}
/**
* @param {?} product
* @return {?}
*/
formatProductEditionName(product) {
return product.editionName ? `${product.name} ${product.editionName}` : product.name;
}
/**
* @param {?} product
* @return {?}
*/
standAloneProductDescription(product) {
if (product.addons && product.addons.length > 0) {
/** @type {?} */
let description = `Contains ${product.addons.length}`;
description = product.addons.length === 1 ? `${description} Addon` : `${description} Addons`;
return description;
}
return '';
}
/**
* @param {?} pkg
* @return {?}
*/
packageDescription(pkg) {
/** @type {?} */
const hasProducts = pkg.products && pkg.products.length > 0;
if (!hasProducts && pkg.totalAddons === 0) {
return 'No Items in Package';
}
/** @type {?} */
let description = '';
/** @type {?} */
const hasOneProduct = pkg.products && pkg.products.length === 1;
if (hasProducts || pkg.totalAddons > 0) {
description = 'Contains ';
}
if (hasProducts) {
description = `${description} ${pkg.products.length}`;
description = hasOneProduct ? `${description} Product` : `${description} Products`;
}
if (hasProducts && pkg.totalAddons > 0) {
description = `${description} & ${pkg.totalAddons}`;
description = pkg.totalAddons === 1 ? `${description} Addon` : `${description} Addons`;
}
return description;
}
}
VaPackageDropdownComponent.decorators = [
{ type: Component, args: [{
selector: 'va-package-dropdown',
animations: [
trigger('listAnimationStart', [
state('void', style({ height: '0px' })),
state('*', style({ height: '*' })),
transition('void => *', [animate('0.25s ease')]),
transition('* => void', [animate('0.25s ease')])
])
],
template: "<ng-container *ngIf=\"templateData$ | async as data\">\n <mat-card class=\"package-list-container\" *ngIf=\"data.products?.length > 0 || data.packages?.length > 0 else loading\">\n <mat-list>\n <div class=\"package-list\" *ngFor=\"let package of data.packages; let packageIndex = index\">\n\n <va-package-dropdown-item\n [title]=\"package.name\"\n [iconUrl]=\"package.icon\"\n [subtitle]=\"package.formattedPrices\"\n [statusItem]=\"package.activationStatus\"\n [description]=\"packageDescription(package)\"\n [enableDropdown]=\"package.products?.length > 0 || package.addonsWithNoParent?.length > 0\"\n [toggleValue]=\"packageToggles[packageIndex]\"\n (itemToggled)=\"togglePackage(packageIndex)\"\n ></va-package-dropdown-item>\n\n <mat-list class=\"product-or-addon-list package-dropdown-font\" *ngIf=\"packageToggles[packageIndex]\"\n [@listAnimationStart]>\n <div *ngFor=\"let product of package.products\">\n <va-package-dropdown-item\n [title]=\"product.name\"\n [subtitle]=\"product.tagline\"\n [iconUrl]=\"product.icon\"\n [statusItem]=\"product.activationStatus\"\n [indent]=\"packageProductIndent\"\n ></va-package-dropdown-item>\n\n <va-package-dropdown-item\n *ngFor=\"let addon of product.addons\"\n [title]=\"addon.name\"\n [subtitle]=\"addon.tagline\"\n [iconUrl]=\"addon.icon\"\n [statusItem]=\"addon.activationStatus\"\n [indent]=\"packageAddonWithProductIndent\"\n ></va-package-dropdown-item>\n </div>\n\n <va-package-dropdown-item\n *ngFor=\"let addon of package.addonsWithNoParent\"\n [title]=\"addon.name\"\n titleDescriptor=\"(Requires {{ addon.parentName || ''}})\"\n [subtitle]=\"addon.tagline\"\n [iconUrl]=\"addon.icon\"\n [secondaryIconUrl]=\"addon.parentIcon\"\n [secondaryIconName]=\"addon.parentName\"\n [statusItem]=\"addon.activationStatus\"\n [indent]=\"packageAddonWithoutProductIndent\"\n ></va-package-dropdown-item>\n </mat-list>\n </div>\n\n <div class=\"product-list\" *ngFor=\"let product of data.products; let productIndex = index\">\n <va-package-dropdown-item\n [title]=\"formatProductEditionName(product)\"\n [iconUrl]=\"product.icon\"\n [subtitle]=\"product.formattedPrices\"\n [statusItem]=\"product.activationStatus\"\n [description]=\"standAloneProductDescription(product)\"\n [enableDropdown]=\"product.addons?.length > 0\"\n [toggleValue]=\"productToggles[productIndex]\"\n (itemToggled)=\"toggleProduct(productIndex)\"\n ></va-package-dropdown-item>\n\n <mat-list class=\"product-or-addon-list product-dropdown-font\" *ngIf=\"productToggles[productIndex]\"\n [@listAnimationStart]>\n <va-package-dropdown-item\n *ngFor=\"let addon of product.addons\"\n [title]=\"addon.name\"\n [subtitle]=\"addon.tagline\"\n [iconUrl]=\"addon.icon\"\n [statusItem]=\"addon.activationStatus\"\n [indent]=\"productAddonIndent\"\n ></va-package-dropdown-item>\n </mat-list>\n </div>\n\n </mat-list>\n </mat-card>\n</ng-container>\n\n<ng-template #loading>\n <mat-card>\n <div class=\"package-dropdown-stencil-display\">\n <va-icon [iconUrl]=\"\"></va-icon>\n <div class=\"stencil-text\">\n <h1 class=\"stencil-title stencil-shimmer\"></h1>\n <span class=\"stencil-tagline stencil-shimmer\"></span>\n </div>\n </div>\n </mat-card>\n</ng-template>\n",
styles: [".package-dropdown-font,.product-dropdown-font{color:rgba(0,0,0,.54);font-size:14px;font-weight:400}.package-list-container{border-top:1px solid rgba(0,0,0,.12);padding:0}.package-list-container mat-list{padding:0}.package-dropdown-stencil-display{display:flex;width:100%;flex-grow:1}.package-dropdown-stencil-display va-icon{margin-right:20px}.package-dropdown-stencil-display .stencil-text{width:inherit;display:flex;flex-direction:column;justify-content:center}.package-dropdown-stencil-display .stencil-text .stencil-title{height:32px;width:40%;margin-bottom:5px!important;margin-top:0!important}.package-dropdown-stencil-display .stencil-text .stencil-tagline{height:32px;width:inherit}.product-or-addon-list{background-color:rgba(0,0,0,.04);overflow:hidden}"]
}] }
];
VaPackageDropdownComponent.propDecorators = {
packages: [{ type: Input }],
products: [{ type: Input }],
standAloneProducts: [{ type: Input }],
statuses: [{ type: Input }],
addons: [{ type: Input }],
singularDropdown: [{ type: Input }]
};
if (false) {
/** @type {?} */
VaPackageDropdownComponent.prototype.singularDropdown;
/** @type {?} */
VaPackageDropdownComponent.prototype.packageProductIndent;
/** @type {?} */
VaPackageDropdownComponent.prototype.packageAddonWithoutProductIndent;
/** @type {?} */
VaPackageDropdownComponent.prototype.packageAddonWithProductIndent;
/** @type {?} */
VaPackageDropdownComponent.prototype.productAddonIndent;
/** @type {?} */
VaPackageDropdownComponent.prototype.packages$$;
/** @type {?} */
VaPackageDropdownComponent.prototype.products$$;
/** @type {?} */
VaPackageDropdownComponent.prototype.standAloneProducts$$;
/** @type {?} */
VaPackageDropdownComponent.prototype.statuses$$;
/** @type {?} */
VaPackageDropdownComponent.prototype.addons$$;
/** @type {?} */
VaPackageDropdownComponent.prototype.templateData$;
/** @type {?} */
VaPackageDropdownComponent.prototype.salesPackages$;
/** @type {?} */
VaPackageDropdownComponent.prototype.salesProducts$;
/** @type {?} */
VaPackageDropdownComponent.prototype.packageToggles;
/** @type {?} */
VaPackageDropdownComponent.prototype.productToggles;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"package-dropdown.component.js","sourceRoot":"ng://@vendasta/store/","sources":["lib/package-dropdown/package-dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { trigger, transition, animate, style, state } from '@angular/animations';\nimport { Observable, BehaviorSubject, ReplaySubject, combineLatest, zip } from 'rxjs';\nimport { filter, map, startWith } from 'rxjs/operators';\n\nimport { Addon } from '@vendasta/core/marketplace-packages';\nimport {\n  SalesPackage,\n  SalesProduct,\n  buildSalesPackages,\n  buildSalesProductFromProduct,\n  addStatusesToSalesPackages,\n  addStatusesToSalesProduct,\n  PackageItemActivationStatus,\n} from './sales-package';\nimport { Product } from '../shared/product';\nimport { Package } from '../package-details/package';\nimport { ListIndent } from './package-dropdown-item/package-dropdown-item.component';\n\n@Component({\n  selector: 'va-package-dropdown',\n  animations: [\n    trigger('listAnimationStart', [\n      state('void', style({ height: '0px' })),\n      state('*', style({ height: '*' })),\n      transition('void => *', [animate('0.25s ease')]),\n      transition('* => void', [animate('0.25s ease')])\n    ])\n  ],\n  templateUrl: 'package-dropdown.component.html',\n  styleUrls: ['./package-dropdown.component.scss']\n})\nexport class VaPackageDropdownComponent implements OnInit {\n  // packages in dropdown\n  @Input()\n  set packages(packages: Package[]) {\n    this.packages$$.next(packages);\n  }\n  // products within given packages\n  @Input()\n  set products(products: Product[]) {\n    this.products$$.next(products);\n  }\n  // products not associated with a package\n  @Input()\n  set standAloneProducts(standAloneProducts: Product[]) {\n    this.standAloneProducts$$.next(standAloneProducts);\n  }\n  // statuses for all products and addons\n  @Input()\n  set statuses(statuses: PackageItemActivationStatus[]) {\n    this.statuses$$.next(statuses);\n  }\n  // addons within given packages\n  @Input()\n  set addons(addons: Addon[]) {\n    this.addons$$.next(addons);\n  }\n  @Input() singularDropdown = false;\n\n  packageProductIndent = ListIndent.INDENT_ONE;\n  packageAddonWithoutProductIndent = ListIndent.INDENT_ONE;\n  packageAddonWithProductIndent = ListIndent.INDENT_TWO;\n  productAddonIndent = ListIndent.INDENT_ONE;\n\n  packages$$: ReplaySubject<Package[]> = new ReplaySubject(1);\n  products$$: ReplaySubject<Product[]> = new ReplaySubject(1);\n  standAloneProducts$$: ReplaySubject<Product[]> = new ReplaySubject(1);\n  statuses$$: BehaviorSubject<PackageItemActivationStatus[]> = new BehaviorSubject([]);\n  addons$$: ReplaySubject<Addon[]> = new ReplaySubject(1);\n\n  templateData$: Observable<{packages: SalesPackage[]; products: SalesProduct[]}>;\n  salesPackages$: Observable<SalesPackage[]>;\n  salesProducts$: Observable<SalesProduct[]>;\n  packageToggles: boolean[] = [];\n  productToggles: boolean[] = [];\n\n  ngOnInit(): void {\n    const packages$: Observable<Package[]> = this.packages$$.pipe(filter(packages => packages !== null));\n    const products$: Observable<Product[]> = this.products$$.pipe(filter(products => products !== null));\n    const addons$: Observable<Addon[]> = this.addons$$.pipe(filter(addons => addons !== null));\n\n    const salesPackage$ = zip(packages$, products$, addons$).pipe(\n      map(([packages, products, addons]) => buildSalesPackages(packages, products, addons)),\n    );\n\n    this.salesPackages$ = combineLatest(salesPackage$, this.statuses$$).pipe(\n      map(([salesPackages, statuses]) => addStatusesToSalesPackages(salesPackages, statuses)),\n      startWith([]),\n    );\n\n    this.salesProducts$ = combineLatest(this.standAloneProducts$$, this.statuses$$).pipe(\n      filter(([products, _]) => products !== null),\n      map(([products, statuses]: [Product[], PackageItemActivationStatus[]]): SalesProduct[] => {\n        return products.map(p => {\n          const addons = p.addons || null;\n          const salesProducts = buildSalesProductFromProduct(p, addons);\n          return addStatusesToSalesProduct(salesProducts, statuses);\n        });\n      }),\n      startWith([]),\n    );\n    this.templateData$ = combineLatest(this.salesPackages$, this.salesProducts$).pipe(\n      map(([packages, products]) => ({packages: packages, products: products}))\n    )\n  }\n\n  public togglePackage(indexToToggle: number): void {\n    if (this.singularDropdown) {\n      const openedIndex = this.packageToggles.findIndex(value => value === true);\n      if (openedIndex !== indexToToggle) {\n        this.packageToggles[openedIndex] = false;\n      }\n      const productOpenedIndex = this.productToggles.findIndex(value => value === true);\n      if (productOpenedIndex > -1) {\n        this.productToggles[productOpenedIndex] = false;\n      }\n    }\n    this.packageToggles[indexToToggle] = !this.packageToggles[indexToToggle];\n  }\n\n  public toggleProduct(indexToToggle: number): void {\n    if (this.singularDropdown) {\n      const openedIndex = this.productToggles.findIndex(value => value === true);\n      if (openedIndex !== indexToToggle) {\n        this.productToggles[openedIndex] = false;\n      }\n      const packageOpenedIndex = this.packageToggles.findIndex(value => value === true);\n      if (packageOpenedIndex > -1) {\n        this.packageToggles[packageOpenedIndex] = false;\n      }\n    }\n    this.productToggles[indexToToggle] = !this.productToggles[indexToToggle];\n  }\n\n  public formatProductEditionName(product: SalesProduct): string {\n    return product.editionName ? `${product.name} ${product.editionName}` : product.name;\n  }\n\n  public standAloneProductDescription(product: SalesProduct): string {\n    if (product.addons && product.addons.length > 0) {\n      let description = `Contains ${product.addons.length}`;\n      description = product.addons.length === 1 ? `${description} Addon` : `${description} Addons`;\n      return description;\n    }\n    return '';\n  }\n\n  public packageDescription(pkg: SalesPackage): string {\n    const hasProducts = pkg.products && pkg.products.length > 0;\n    if (!hasProducts && pkg.totalAddons === 0) {\n      return 'No Items in Package';\n    }\n\n    let description = '';\n    const hasOneProduct = pkg.products && pkg.products.length === 1;\n    if (hasProducts || pkg.totalAddons > 0) {\n      description = 'Contains ';\n    }\n    if (hasProducts) {\n      description = `${description} ${pkg.products.length}`;\n      description = hasOneProduct ? `${description} Product` : `${description} Products`;\n    }\n    if (hasProducts && pkg.totalAddons > 0) {\n      description = `${description} & ${pkg.totalAddons}`;\n      description = pkg.totalAddons === 1 ? `${description} Addon` : `${description} Addons`;\n    }\n    return description;\n  }\n}\n"]}