UNPKG

@vendasta/store

Version:

Components and data for Store

231 lines 30.5 kB
/** * @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"]}