UNPKG

@vendasta/store

Version:

Components and data for Store

300 lines 33.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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'; var VaPackageDropdownComponent = /** @class */ (function () { function VaPackageDropdownComponent() { 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 = []; } Object.defineProperty(VaPackageDropdownComponent.prototype, "packages", { // packages in dropdown set: // packages in dropdown /** * @param {?} packages * @return {?} */ function (packages) { this.packages$$.next(packages); }, enumerable: true, configurable: true }); Object.defineProperty(VaPackageDropdownComponent.prototype, "products", { // products within given packages set: // products within given packages /** * @param {?} products * @return {?} */ function (products) { this.products$$.next(products); }, enumerable: true, configurable: true }); Object.defineProperty(VaPackageDropdownComponent.prototype, "standAloneProducts", { // products not associated with a package set: // products not associated with a package /** * @param {?} standAloneProducts * @return {?} */ function (standAloneProducts) { this.standAloneProducts$$.next(standAloneProducts); }, enumerable: true, configurable: true }); Object.defineProperty(VaPackageDropdownComponent.prototype, "statuses", { // statuses for all products and addons set: // statuses for all products and addons /** * @param {?} statuses * @return {?} */ function (statuses) { this.statuses$$.next(statuses); }, enumerable: true, configurable: true }); Object.defineProperty(VaPackageDropdownComponent.prototype, "addons", { // addons within given packages set: // addons within given packages /** * @param {?} addons * @return {?} */ function (addons) { this.addons$$.next(addons); }, enumerable: true, configurable: true }); /** * @return {?} */ VaPackageDropdownComponent.prototype.ngOnInit = /** * @return {?} */ function () { /** @type {?} */ var packages$ = this.packages$$.pipe(filter(function (packages) { return packages !== null; })); /** @type {?} */ var products$ = this.products$$.pipe(filter(function (products) { return products !== null; })); /** @type {?} */ var addons$ = this.addons$$.pipe(filter(function (addons) { return addons !== null; })); /** @type {?} */ var salesPackage$ = zip(packages$, products$, addons$).pipe(map(function (_a) { var _b = tslib_1.__read(_a, 3), packages = _b[0], products = _b[1], addons = _b[2]; return buildSalesPackages(packages, products, addons); })); this.salesPackages$ = combineLatest(salesPackage$, this.statuses$$).pipe(map(function (_a) { var _b = tslib_1.__read(_a, 2), salesPackages = _b[0], statuses = _b[1]; return addStatusesToSalesPackages(salesPackages, statuses); }), startWith([])); this.salesProducts$ = combineLatest(this.standAloneProducts$$, this.statuses$$).pipe(filter(function (_a) { var _b = tslib_1.__read(_a, 2), products = _b[0], _ = _b[1]; return products !== null; }), map(function (_a) { var _b = tslib_1.__read(_a, 2), products = _b[0], statuses = _b[1]; return products.map(function (p) { /** @type {?} */ var addons = p.addons || null; /** @type {?} */ var salesProducts = buildSalesProductFromProduct(p, addons); return addStatusesToSalesProduct(salesProducts, statuses); }); }), startWith([])); this.templateData$ = combineLatest(this.salesPackages$, this.salesProducts$).pipe(map(function (_a) { var _b = tslib_1.__read(_a, 2), packages = _b[0], products = _b[1]; return ({ packages: packages, products: products }); })); }; /** * @param {?} indexToToggle * @return {?} */ VaPackageDropdownComponent.prototype.togglePackage = /** * @param {?} indexToToggle * @return {?} */ function (indexToToggle) { if (this.singularDropdown) { /** @type {?} */ var openedIndex = this.packageToggles.findIndex(function (value) { return value === true; }); if (openedIndex !== indexToToggle) { this.packageToggles[openedIndex] = false; } /** @type {?} */ var productOpenedIndex = this.productToggles.findIndex(function (value) { return value === true; }); if (productOpenedIndex > -1) { this.productToggles[productOpenedIndex] = false; } } this.packageToggles[indexToToggle] = !this.packageToggles[indexToToggle]; }; /** * @param {?} indexToToggle * @return {?} */ VaPackageDropdownComponent.prototype.toggleProduct = /** * @param {?} indexToToggle * @return {?} */ function (indexToToggle) { if (this.singularDropdown) { /** @type {?} */ var openedIndex = this.productToggles.findIndex(function (value) { return value === true; }); if (openedIndex !== indexToToggle) { this.productToggles[openedIndex] = false; } /** @type {?} */ var packageOpenedIndex = this.packageToggles.findIndex(function (value) { return value === true; }); if (packageOpenedIndex > -1) { this.packageToggles[packageOpenedIndex] = false; } } this.productToggles[indexToToggle] = !this.productToggles[indexToToggle]; }; /** * @param {?} product * @return {?} */ VaPackageDropdownComponent.prototype.formatProductEditionName = /** * @param {?} product * @return {?} */ function (product) { return product.editionName ? product.name + " " + product.editionName : product.name; }; /** * @param {?} product * @return {?} */ VaPackageDropdownComponent.prototype.standAloneProductDescription = /** * @param {?} product * @return {?} */ function (product) { if (product.addons && product.addons.length > 0) { /** @type {?} */ var description = "Contains " + product.addons.length; description = product.addons.length === 1 ? description + " Addon" : description + " Addons"; return description; } return ''; }; /** * @param {?} pkg * @return {?} */ VaPackageDropdownComponent.prototype.packageDescription = /** * @param {?} pkg * @return {?} */ function (pkg) { /** @type {?} */ var hasProducts = pkg.products && pkg.products.length > 0; if (!hasProducts && pkg.totalAddons === 0) { return 'No Items in Package'; } /** @type {?} */ var description = ''; /** @type {?} */ var 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 }] }; return VaPackageDropdownComponent; }()); export { VaPackageDropdownComponent }; 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":";;;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAAc,eAAe,EAAE,aAAa,EAAE,aAAa,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtF,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAGxD,OAAO,EAGL,kBAAkB,EAClB,4BAA4B,EAC5B,0BAA0B,EAC1B,yBAAyB,GAE1B,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EAAE,UAAU,EAAE,MAAM,yDAAyD,CAAC;AAErF;IAAA;QAuCW,qBAAgB,GAAG,KAAK,CAAC;QAElC,yBAAoB,GAAG,UAAU,CAAC,UAAU,CAAC;QAC7C,qCAAgC,GAAG,UAAU,CAAC,UAAU,CAAC;QACzD,kCAA6B,GAAG,UAAU,CAAC,UAAU,CAAC;QACtD,uBAAkB,GAAG,UAAU,CAAC,UAAU,CAAC;QAE3C,eAAU,GAA6B,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC;QAC5D,eAAU,GAA6B,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC;QAC5D,yBAAoB,GAA6B,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC;QACtE,eAAU,GAAmD,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;QACrF,aAAQ,GAA2B,IAAI,aAAa,CAAC,CAAC,CAAC,CAAC;QAKxD,mBAAc,GAAc,EAAE,CAAC;QAC/B,mBAAc,GAAc,EAAE,CAAC;IA8FjC,CAAC;IAvIC,sBACI,gDAAQ;QAFZ,uBAAuB;;;;;;;QACvB,UACa,QAAmB;YAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;;;OAAA;IAED,sBACI,gDAAQ;QAFZ,iCAAiC;;;;;;;QACjC,UACa,QAAmB;YAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;;;OAAA;IAED,sBACI,0DAAkB;QAFtB,yCAAyC;;;;;;;QACzC,UACuB,kBAA6B;YAClD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACrD,CAAC;;;OAAA;IAED,sBACI,gDAAQ;QAFZ,uCAAuC;;;;;;;QACvC,UACa,QAAuC;YAClD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;;;OAAA;IAED,sBACI,8CAAM;QAFV,+BAA+B;;;;;;;QAC/B,UACW,MAAe;YACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7B,CAAC;;;OAAA;;;;IAoBD,6CAAQ;;;IAAR;;YACQ,SAAS,GAA0B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,UAAA,QAAQ,IAAI,OAAA,QAAQ,KAAK,IAAI,EAAjB,CAAiB,CAAC,CAAC;;YAC9F,SAAS,GAA0B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,UAAA,QAAQ,IAAI,OAAA,QAAQ,KAAK,IAAI,EAAjB,CAAiB,CAAC,CAAC;;YAC9F,OAAO,GAAwB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAA,MAAM,IAAI,OAAA,MAAM,KAAK,IAAI,EAAf,CAAe,CAAC,CAAC;;YAEpF,aAAa,GAAG,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC,IAAI,CAC3D,GAAG,CAAC,UAAC,EAA4B;gBAA5B,0BAA4B,EAA3B,gBAAQ,EAAE,gBAAQ,EAAE,cAAM;YAAM,OAAA,kBAAkB,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,CAAC;QAA9C,CAA8C,CAAC,CACtF;QAED,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CACtE,GAAG,CAAC,UAAC,EAAyB;gBAAzB,0BAAyB,EAAxB,qBAAa,EAAE,gBAAQ;YAAM,OAAA,0BAA0B,CAAC,aAAa,EAAE,QAAQ,CAAC;QAAnD,CAAmD,CAAC,EACvF,SAAS,CAAC,EAAE,CAAC,CACd,CAAC;QAEF,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAClF,MAAM,CAAC,UAAC,EAAa;gBAAb,0BAAa,EAAZ,gBAAQ,EAAE,SAAC;YAAM,OAAA,QAAQ,KAAK,IAAI;QAAjB,CAAiB,CAAC,EAC5C,GAAG,CAAC,UAAC,EAAgE;gBAAhE,0BAAgE,EAA/D,gBAAQ,EAAE,gBAAQ;YACtB,OAAO,QAAQ,CAAC,GAAG,CAAC,UAAA,CAAC;;oBACb,MAAM,GAAG,CAAC,CAAC,MAAM,IAAI,IAAI;;oBACzB,aAAa,GAAG,4BAA4B,CAAC,CAAC,EAAE,MAAM,CAAC;gBAC7D,OAAO,yBAAyB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YAC5D,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,EAAE,CAAC,CACd,CAAC;QACF,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,IAAI,CAC/E,GAAG,CAAC,UAAC,EAAoB;gBAApB,0BAAoB,EAAnB,gBAAQ,EAAE,gBAAQ;YAAM,OAAA,CAAC,EAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAC,CAAC;QAA1C,CAA0C,CAAC,CAC1E,CAAA;IACH,CAAC;;;;;IAEM,kDAAa;;;;IAApB,UAAqB,aAAqB;QACxC,IAAI,IAAI,CAAC,gBAAgB,EAAE;;gBACnB,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,KAAK,IAAI,EAAd,CAAc,CAAC;YAC1E,IAAI,WAAW,KAAK,aAAa,EAAE;gBACjC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC;aAC1C;;gBACK,kBAAkB,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,KAAK,IAAI,EAAd,CAAc,CAAC;YACjF,IAAI,kBAAkB,GAAG,CAAC,CAAC,EAAE;gBAC3B,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,GAAG,KAAK,CAAC;aACjD;SACF;QACD,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;IAC3E,CAAC;;;;;IAEM,kDAAa;;;;IAApB,UAAqB,aAAqB;QACxC,IAAI,IAAI,CAAC,gBAAgB,EAAE;;gBACnB,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,KAAK,IAAI,EAAd,CAAc,CAAC;YAC1E,IAAI,WAAW,KAAK,aAAa,EAAE;gBACjC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC;aAC1C;;gBACK,kBAAkB,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,KAAK,IAAI,EAAd,CAAc,CAAC;YACjF,IAAI,kBAAkB,GAAG,CAAC,CAAC,EAAE;gBAC3B,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,GAAG,KAAK,CAAC;aACjD;SACF;QACD,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;IAC3E,CAAC;;;;;IAEM,6DAAwB;;;;IAA/B,UAAgC,OAAqB;QACnD,OAAO,OAAO,CAAC,WAAW,CAAC,CAAC,CAAI,OAAO,CAAC,IAAI,SAAI,OAAO,CAAC,WAAa,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;IACvF,CAAC;;;;;IAEM,iEAA4B;;;;IAAnC,UAAoC,OAAqB;QACvD,IAAI,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;;gBAC3C,WAAW,GAAG,cAAY,OAAO,CAAC,MAAM,CAAC,MAAQ;YACrD,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAI,WAAW,WAAQ,CAAC,CAAC,CAAI,WAAW,YAAS,CAAC;YAC7F,OAAO,WAAW,CAAC;SACpB;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;;;;;IAEM,uDAAkB;;;;IAAzB,UAA0B,GAAiB;;YACnC,WAAW,GAAG,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;QAC3D,IAAI,CAAC,WAAW,IAAI,GAAG,CAAC,WAAW,KAAK,CAAC,EAAE;YACzC,OAAO,qBAAqB,CAAC;SAC9B;;YAEG,WAAW,GAAG,EAAE;;YACd,aAAa,GAAG,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC;QAC/D,IAAI,WAAW,IAAI,GAAG,CAAC,WAAW,GAAG,CAAC,EAAE;YACtC,WAAW,GAAG,WAAW,CAAC;SAC3B;QACD,IAAI,WAAW,EAAE;YACf,WAAW,GAAM,WAAW,SAAI,GAAG,CAAC,QAAQ,CAAC,MAAQ,CAAC;YACtD,WAAW,GAAG,aAAa,CAAC,CAAC,CAAI,WAAW,aAAU,CAAC,CAAC,CAAI,WAAW,cAAW,CAAC;SACpF;QACD,IAAI,WAAW,IAAI,GAAG,CAAC,WAAW,GAAG,CAAC,EAAE;YACtC,WAAW,GAAM,WAAW,WAAM,GAAG,CAAC,WAAa,CAAC;YACpD,WAAW,GAAG,GAAG,CAAC,WAAW,KAAK,CAAC,CAAC,CAAC,CAAI,WAAW,WAAQ,CAAC,CAAC,CAAI,WAAW,YAAS,CAAC;SACxF;QACD,OAAO,WAAW,CAAC;IACrB,CAAC;;gBArJF,SAAS,SAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,UAAU,EAAE;wBACV,OAAO,CAAC,oBAAoB,EAAE;4BAC5B,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;4BACvC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;4BAClC,UAAU,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;4BAChD,UAAU,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;yBACjD,CAAC;qBACH;oBACD,0zHAA8C;;iBAE/C;;;2BAGE,KAAK;2BAKL,KAAK;qCAKL,KAAK;2BAKL,KAAK;yBAKL,KAAK;mCAIL,KAAK;;IA+GR,iCAAC;CAAA,AAtJD,IAsJC;SAzIY,0BAA0B;;;IA0BrC,sDAAkC;;IAElC,0DAA6C;;IAC7C,sEAAyD;;IACzD,mEAAsD;;IACtD,wDAA2C;;IAE3C,gDAA4D;;IAC5D,gDAA4D;;IAC5D,0DAAsE;;IACtE,gDAAqF;;IACrF,8CAAwD;;IAExD,mDAAgF;;IAChF,oDAA2C;;IAC3C,oDAA2C;;IAC3C,oDAA+B;;IAC/B,oDAA+B","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"]}