simpo-component-library 3.6.472 → 3.6.474

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/esm2022/lib/components/hover-elements/hover-elements.component.mjs +1 -4
  2. package/esm2022/lib/directive/background-directive.mjs +6 -6
  3. package/esm2022/lib/ecommerce/sections/featured-products/featured-products.component.mjs +34 -3
  4. package/esm2022/lib/ecommerce/sections/order-details/order-details.component.mjs +7 -4
  5. package/esm2022/lib/ecommerce/sections/product-desc/product-desc.component.mjs +34 -3
  6. package/esm2022/lib/ecommerce/sections/product-list/product-list.component.mjs +34 -3
  7. package/esm2022/lib/ecommerce/sections/small-product-listing/small-product-listing.component.mjs +50 -10
  8. package/esm2022/lib/ecommerce/sections/store-list/store-list.component.mjs +3 -1
  9. package/esm2022/lib/elements/pricing-s1/pricing-s1.component.mjs +4 -7
  10. package/esm2022/lib/elements/simpo-button/simpo-button.component.mjs +3 -3
  11. package/esm2022/lib/elements/text-editor/text-editor.component.mjs +70 -53
  12. package/esm2022/lib/sections/features-section/features-section.component.mjs +3 -3
  13. package/esm2022/lib/sections/image-carousel-section/image-carousel-section.component.mjs +4 -4
  14. package/esm2022/lib/sections/pricing-section/pricing-section.component.mjs +3 -3
  15. package/esm2022/lib/sections/process-modern/process-modern.component.mjs +4 -4
  16. package/esm2022/lib/sections/scheme-detail/scheme-detail.component.mjs +7 -3
  17. package/esm2022/lib/sections/testimonial-section/testimonial-section.component.mjs +2 -2
  18. package/esm2022/lib/services/rest.service.mjs +4 -1
  19. package/fesm2022/simpo-component-library.mjs +259 -110
  20. package/fesm2022/simpo-component-library.mjs.map +1 -1
  21. package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +1 -1
  22. package/lib/ecommerce/sections/featured-products/featured-products.component.d.ts +2 -0
  23. package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +3 -1
  24. package/lib/ecommerce/sections/product-list/product-list.component.d.ts +2 -0
  25. package/lib/ecommerce/sections/schemes/schemes.component.d.ts +1 -1
  26. package/lib/ecommerce/sections/small-product-listing/small-product-listing.component.d.ts +9 -1
  27. package/lib/elements/link-editor/link-editor.component.d.ts +1 -1
  28. package/lib/elements/pricing-s1/pricing-s1.component.d.ts +1 -1
  29. package/lib/elements/text-editor/text-editor.component.d.ts +3 -0
  30. package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
  31. package/lib/services/rest.service.d.ts +1 -0
  32. package/package.json +1 -1
  33. package/simpo-component-library-3.6.474.tgz +0 -0
  34. package/simpo-component-library-3.6.472.tgz +0 -0
@@ -7,21 +7,31 @@ import { ColorDirective } from '../../../directive/color.directive';
7
7
  import { ImageLoadingComponent } from '../../../components/image-loading/image-loading.component';
8
8
  import { RatingModule } from 'primeng/rating';
9
9
  import { FormsModule } from '@angular/forms';
10
+ import { ToastModule } from 'primeng/toast';
10
11
  import * as i0 from "@angular/core";
11
12
  import * as i1 from "../../../services/cart.service";
12
13
  import * as i2 from "@angular/router";
13
- import * as i3 from "@angular/common";
14
- import * as i4 from "primeng/rating";
15
- import * as i5 from "@angular/forms";
14
+ import * as i3 from "../../../services/rest.service";
15
+ import * as i4 from "../../../services/storage.service";
16
+ import * as i5 from "primeng/api";
17
+ import * as i6 from "@angular/common";
18
+ import * as i7 from "primeng/rating";
19
+ import * as i8 from "@angular/forms";
20
+ import * as i9 from "primeng/toast";
16
21
  export class SmallProductListingComponent {
17
- constructor(cartService, router) {
22
+ constructor(cartService, router, restService, storageService, messageService) {
18
23
  this.cartService = cartService;
19
24
  this.router = router;
25
+ this.restService = restService;
26
+ this.storageService = storageService;
27
+ this.messageService = messageService;
20
28
  this.USER_CART = null;
21
29
  this.isCategoryProductList = false;
30
+ this.IsEcommerce = false;
22
31
  this.imageIndex = -1;
23
32
  }
24
33
  ngOnInit() {
34
+ this.IsEcommerce = localStorage.getItem("websiteType") != 'STATIC' ? true : false;
25
35
  }
26
36
  addItemToCart(event, product, type) {
27
37
  // if (this.isItemOutOfStock(product)) {
@@ -65,6 +75,35 @@ export class SmallProductListingComponent {
65
75
  removeDefault(event) {
66
76
  event.stopPropagation();
67
77
  }
78
+ raiseLead() {
79
+ const userDetails = this.storageService.getUser();
80
+ let payload = {
81
+ businessId: localStorage.getItem('businessId'),
82
+ email: userDetails?.contact?.email,
83
+ message: "",
84
+ mobileNo: "",
85
+ moreInfo: {
86
+ Name: userDetails?.contact?.name,
87
+ "Mobile Number": userDetails?.contact?.mobile,
88
+ Email: userDetails?.contact?.email,
89
+ "Lead Source": "Website",
90
+ "Lead Status": "NEW"
91
+ },
92
+ name: userDetails?.contact?.name
93
+ };
94
+ this.restService.createLead(payload).subscribe({
95
+ next: (res) => {
96
+ if (res?.data) {
97
+ this.messageService.add({ severity: 'success', summary: 'Thank you', detail: 'Our team will contact you soon' });
98
+ }
99
+ },
100
+ error: (err) => {
101
+ if (err) {
102
+ this.messageService.add({ severity: 'error', summary: 'Error', detail: 'Error occured please try again later' });
103
+ }
104
+ }
105
+ });
106
+ }
68
107
  getItemVarient(product, varientId) {
69
108
  let selectedVarient = null;
70
109
  product?.itemVariant?.forEach((varient) => {
@@ -129,8 +168,8 @@ export class SmallProductListingComponent {
129
168
  return noofratings;
130
169
  }
131
170
  }
132
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmallProductListingComponent, deps: [{ token: i1.CartService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
133
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SmallProductListingComponent, isStandalone: true, selector: "simpo-small-product-listing", inputs: { product: "product", data: "data", isScrollable: "isScrollable", isCategoryProductList: "isCategoryProductList", customClass: "customClass", index: "index" }, ngImport: i0, template: "<div class=\"product hover-effect\" [ngClass]=\"{'width' : isScrollable, 'adjustHeightWidth': isCategoryProductList}\"\n [style.opacity]=\"product?.itemInventory?.openingStock == 0 ? 0.5 : 1\" [attr.style]=\"customClass\">\n <div class=\"prod-img\" [class.fade-out]=\"imageIndex == index\">\n <image-loading [imageUrl]=\"getProductImages(product)\" [hash]=\"product.itemImages?.[0]?.blurhash\"\n (click)=\"goToProductDetail(product)\" [theme]=\"data?.styles?.theme\"></image-loading>\n <div class=\"discount\" [style.backgroundColor]=\"data?.styles?.background?.color\"\n [simpoColor]=\"data?.styles?.background?.color\" *ngIf=\"getPercentage(product) > '0'\">{{getPercentage(product)}}%\n off</div>\n <div class=\"carousel-buttons\" *ngIf=\"(product?.itemImages?.length || 0) > 1\">\n <div><mat-icon (click)=\"changeImage(product, 'PREV')\">keyboard_arrow_left</mat-icon></div>\n <div><mat-icon (click)=\"changeImage(product, 'NEXT')\">keyboard_arrow_right</mat-icon></div>\n </div>\n </div>\n <div class=\"p-2 h-40\" (click)=\"goToProductDetail(product)\">\n <span class=\"trim-text color\">{{product.name}}</span>\n <div class=\"bottom\">\n <span class=\"m-1\">\n <span class=\"color\"><span\n [innerHTML]=\"currency\"></span> {{product?.price?.sellingPrice ?? 0}}</span>\n <span class=\"color\" *ngIf=\"product.price.value - product.price.discountedPrice > 2\"\n [ngClass]=\"{'strike-through' : product.price.value - product.price.discountedPrice > 2}\"><span\n [innerHTML]=\"currency\"></span> {{product?.price?.value ?? 0}}</span>\n </span>\n <div class=\"review-rating d-flex gap-2 align-items-center justify-content-between\" *ngIf=\"product?.averageRating\">\n <p-rating [(ngModel)]=\"product.averageRating\" [cancel]=\"false\" [readonly]=\"true\" />\n <div class=\"total-ratings\">{{\n getRatings(product?.totalReviewCount)}}</div>\n </div>\n <div class=\"add-to-cart\" [style.borderColor]=\"data.styles?.background?.accentColor\" *ngIf=\"data?.content?.display?.showButton\"\n [ngClass]=\"{'justify-content-between p-0 d-flex': product.quantity, 'justify-content-center': !product.quantity}\"\n (click)=\"removeDefault($event)\">\n <ng-container *ngIf=\"product?.itemInventory?.openingStock\">\n <ng-container *ngIf=\"!product.quantity\">\n <div (click)=\"addItemToCart($event, product, 'ADD')\" [style.color]=\"data.styles?.background?.accentColor\">\n Add to Cart</div>\n </ng-container>\n <ng-container *ngIf=\"product.quantity\">\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'SUBSTRACT')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">-</span>\n <span class=\"quantity\" [style.color]=\"data.styles?.background?.accentColor\">{{product.quantity}}</span>\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'ADD')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">+</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!product?.itemInventory?.openingStock\">\n <span class=\"d-flex align-items-center justify-content-center w-100\">\n <mat-icon>notification_important</mat-icon>\n <span class=\"ml-2\">Notify</span>\n </span>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n\n<!-- <ng-template #loadingScreen>\n <ngx-skeleton-loader *ngIf=\"filterLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n width: '100%',\n height: '100%',\n 'border-radius': '10px',\n 'position': 'relative',\n 'right': '5px'\n }\" />\n</ng-template> -->", styles: [".product{position:relative;display:flex;flex-direction:column;cursor:pointer;margin-bottom:10px;border-radius:10px;overflow:hidden;height:350px;background-color:#fff}.product .prod-img{position:relative;height:55%;width:100%;overflow:hidden;border:1.8px solid;border-radius:10px;border-color:#e5e7eb}.product .prod-img img{height:100%;width:100%;object-fit:cover}*{font-family:var(--website-font-family)}mat-icon{font-family:Material Icons!important}.width{margin-right:10px;min-width:195px;max-width:195px}.styling{height:30px;width:30px;border-radius:50%;background-color:#fff;position:absolute;bottom:0;right:-12px}.strike-through{text-decoration:line-through;color:#d3d3d3;font-size:12px;margin-left:5px;position:relative}.add-to-cart{width:100%;cursor:pointer;background-color:#fff;border:1.5px solid transparent;border-radius:5px;padding:5px;text-align:center;align-items:center}.add-to-cart .quantity-btn{padding:5px 10px;font-weight:700}.discount{position:absolute;top:0;padding:5px;width:60px;text-align:center;font-size:12px;border-bottom-right-radius:3px}@media screen and (max-width: 475px){.width{max-width:160px;min-width:160px;height:300px}.adjustHeightWidth{max-width:100%;min-width:100%}}.h-40{height:45%;position:relative}.bottom{position:absolute;bottom:10px;width:93%;display:flex;flex-direction:column}.discount-price{font-weight:600;font-size:14px}.color{color:#000}.trim-text{text-align:inherit!important}.product-img.fade-out{opacity:0;transform:scale(.95)}.gap-15{gap:15px}.flex-wrap{flex-wrap:wrap}.carousel-buttons{display:flex;gap:10px;position:absolute;bottom:10px;left:10px;transform:translateY(-50%);pointer-events:none}.carousel-buttons div{background:#fff;display:flex;align-items:center;border-radius:100%;height:30px;width:30px;justify-content:center;pointer-events:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ImageLoadingComponent, selector: "image-loading", inputs: ["hash", "imageUrl", "index", "product", "theme"] }, { kind: "directive", type: ColorDirective, selector: "[simpoColor]", inputs: ["simpoColor"] }, { kind: "ngmodule", type: RatingModule }, { kind: "component", type: i4.Rating, selector: "p-rating", inputs: ["disabled", "readonly", "stars", "cancel", "iconOnClass", "iconOnStyle", "iconOffClass", "iconOffStyle", "iconCancelClass", "iconCancelStyle", "autofocus"], outputs: ["onRate", "onCancel", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
171
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmallProductListingComponent, deps: [{ token: i1.CartService }, { token: i2.Router }, { token: i3.RestService }, { token: i4.StorageServiceService }, { token: i5.MessageService }], target: i0.ɵɵFactoryTarget.Component }); }
172
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SmallProductListingComponent, isStandalone: true, selector: "simpo-small-product-listing", inputs: { product: "product", data: "data", isScrollable: "isScrollable", isCategoryProductList: "isCategoryProductList", customClass: "customClass", index: "index" }, ngImport: i0, template: "<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"></p-toast>\n<div class=\"product hover-effect\" [ngClass]=\"{'width' : isScrollable, 'adjustHeightWidth': isCategoryProductList}\"\n [style.opacity]=\"product?.itemInventory?.openingStock == 0 ? 0.5 : 1\" [attr.style]=\"customClass\">\n <div class=\"prod-img\" [class.fade-out]=\"imageIndex == index\">\n <image-loading [imageUrl]=\"getProductImages(product)\" [hash]=\"product.itemImages?.[0]?.blurhash\"\n (click)=\"goToProductDetail(product)\" [theme]=\"data?.styles?.theme\"></image-loading>\n <div class=\"discount\" [style.backgroundColor]=\"data?.styles?.background?.color\"\n [simpoColor]=\"data?.styles?.background?.color\" *ngIf=\"getPercentage(product) > '0'\">{{getPercentage(product)}}%\n off</div>\n <div class=\"carousel-buttons\" *ngIf=\"(product?.itemImages?.length || 0) > 1\">\n <div><mat-icon (click)=\"changeImage(product, 'PREV')\">keyboard_arrow_left</mat-icon></div>\n <div><mat-icon (click)=\"changeImage(product, 'NEXT')\">keyboard_arrow_right</mat-icon></div>\n </div>\n </div>\n <div class=\"p-2 h-40\" (click)=\"goToProductDetail(product)\">\n <span class=\"trim-text color\">{{product.name}}</span>\n <div class=\"bottom\">\n <span class=\"m-1\">\n <span class=\"color\"><span [innerHTML]=\"currency\"></span> {{product?.price?.sellingPrice ?? 0}}</span>\n <span class=\"color\" *ngIf=\"product.price.value - product.price.discountedPrice > 2\"\n [ngClass]=\"{'strike-through' : product.price.value - product.price.discountedPrice > 2}\"><span\n [innerHTML]=\"currency\"></span> {{product?.price?.value ?? 0}}</span>\n </span>\n <div class=\"review-rating d-flex gap-2 align-items-center justify-content-between\" *ngIf=\"product?.averageRating\">\n <p-rating [(ngModel)]=\"product.averageRating\" [cancel]=\"false\" [readonly]=\"true\" />\n <div class=\"total-ratings\">{{\n getRatings(product?.totalReviewCount)}}</div>\n </div>\n <div class=\"add-to-cart\" [style.borderColor]=\"data.styles?.background?.accentColor\"\n *ngIf=\"data?.content?.display?.showButton\"\n [ngClass]=\"{'justify-content-between p-0 d-flex': product.quantity, 'justify-content-center': !product.quantity}\"\n (click)=\"removeDefault($event)\">\n <ng-container *ngIf=\"product?.itemInventory?.openingStock\">\n <ng-container *ngIf=\"!product.quantity\">\n <div (click)=\"addItemToCart($event, product, 'ADD')\" [style.color]=\"data.styles?.background?.accentColor\"\n *ngIf=\"IsEcommerce\">\n Add to Cart</div>\n <div [style.color]=\"data.styles?.background?.accentColor\" *ngIf=\"!IsEcommerce\" (click)=\"raiseLead()\">Notify\n Me</div>\n </ng-container>\n <ng-container *ngIf=\"product.quantity\">\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'SUBSTRACT')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">-</span>\n <span class=\"quantity\" [style.color]=\"data.styles?.background?.accentColor\">{{product.quantity}}</span>\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'ADD')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">+</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!product?.itemInventory?.openingStock\">\n <span class=\"d-flex align-items-center justify-content-center w-100\">\n <mat-icon>notification_important</mat-icon>\n <span class=\"ml-2\">Notify</span>\n </span>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n\n<!-- <ng-template #loadingScreen>\n <ngx-skeleton-loader *ngIf=\"filterLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n width: '100%',\n height: '100%',\n 'border-radius': '10px',\n 'position': 'relative',\n 'right': '5px'\n }\" />\n</ng-template> -->", styles: [".product{position:relative;display:flex;flex-direction:column;cursor:pointer;margin-bottom:10px;border-radius:10px;overflow:hidden;height:350px;background-color:#fff}.product .prod-img{position:relative;height:55%;width:100%;overflow:hidden;border:1.8px solid;border-radius:10px;border-color:#e5e7eb}.product .prod-img img{height:100%;width:100%;object-fit:cover}*{font-family:var(--website-font-family)}mat-icon{font-family:Material Icons!important}.width{margin-right:10px;min-width:195px;max-width:195px}.styling{height:30px;width:30px;border-radius:50%;background-color:#fff;position:absolute;bottom:0;right:-12px}.strike-through{text-decoration:line-through;color:#d3d3d3;font-size:12px;margin-left:5px;position:relative}.add-to-cart{width:100%;cursor:pointer;background-color:#fff;border:1.5px solid transparent;border-radius:5px;padding:5px;text-align:center;align-items:center}.add-to-cart .quantity-btn{padding:5px 10px;font-weight:700}.discount{position:absolute;top:0;padding:5px;width:60px;text-align:center;font-size:12px;border-bottom-right-radius:3px}@media screen and (max-width: 475px){.width{max-width:160px;min-width:160px;height:300px}.adjustHeightWidth{max-width:100%;min-width:100%}}.h-40{height:45%;position:relative}.bottom{position:absolute;bottom:10px;width:93%;display:flex;flex-direction:column}.discount-price{font-weight:600;font-size:14px}.color{color:#000}.trim-text{text-align:inherit!important}.product-img.fade-out{opacity:0;transform:scale(.95)}.gap-15{gap:15px}.flex-wrap{flex-wrap:wrap}.carousel-buttons{display:flex;gap:10px;position:absolute;bottom:10px;left:10px;transform:translateY(-50%);pointer-events:none}.carousel-buttons div{background:#fff;display:flex;align-items:center;border-radius:100%;height:30px;width:30px;justify-content:center;pointer-events:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ImageLoadingComponent, selector: "image-loading", inputs: ["hash", "imageUrl", "index", "product", "theme"] }, { kind: "directive", type: ColorDirective, selector: "[simpoColor]", inputs: ["simpoColor"] }, { kind: "ngmodule", type: RatingModule }, { kind: "component", type: i7.Rating, selector: "p-rating", inputs: ["disabled", "readonly", "stars", "cancel", "iconOnClass", "iconOnStyle", "iconOffClass", "iconOffStyle", "iconCancelClass", "iconCancelStyle", "autofocus"], outputs: ["onRate", "onCancel", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ToastModule }, { kind: "component", type: i9.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "life", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }] }); }
134
173
  }
135
174
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SmallProductListingComponent, decorators: [{
136
175
  type: Component,
@@ -140,9 +179,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
140
179
  ImageLoadingComponent,
141
180
  ColorDirective,
142
181
  RatingModule,
143
- FormsModule
144
- ], template: "<div class=\"product hover-effect\" [ngClass]=\"{'width' : isScrollable, 'adjustHeightWidth': isCategoryProductList}\"\n [style.opacity]=\"product?.itemInventory?.openingStock == 0 ? 0.5 : 1\" [attr.style]=\"customClass\">\n <div class=\"prod-img\" [class.fade-out]=\"imageIndex == index\">\n <image-loading [imageUrl]=\"getProductImages(product)\" [hash]=\"product.itemImages?.[0]?.blurhash\"\n (click)=\"goToProductDetail(product)\" [theme]=\"data?.styles?.theme\"></image-loading>\n <div class=\"discount\" [style.backgroundColor]=\"data?.styles?.background?.color\"\n [simpoColor]=\"data?.styles?.background?.color\" *ngIf=\"getPercentage(product) > '0'\">{{getPercentage(product)}}%\n off</div>\n <div class=\"carousel-buttons\" *ngIf=\"(product?.itemImages?.length || 0) > 1\">\n <div><mat-icon (click)=\"changeImage(product, 'PREV')\">keyboard_arrow_left</mat-icon></div>\n <div><mat-icon (click)=\"changeImage(product, 'NEXT')\">keyboard_arrow_right</mat-icon></div>\n </div>\n </div>\n <div class=\"p-2 h-40\" (click)=\"goToProductDetail(product)\">\n <span class=\"trim-text color\">{{product.name}}</span>\n <div class=\"bottom\">\n <span class=\"m-1\">\n <span class=\"color\"><span\n [innerHTML]=\"currency\"></span> {{product?.price?.sellingPrice ?? 0}}</span>\n <span class=\"color\" *ngIf=\"product.price.value - product.price.discountedPrice > 2\"\n [ngClass]=\"{'strike-through' : product.price.value - product.price.discountedPrice > 2}\"><span\n [innerHTML]=\"currency\"></span> {{product?.price?.value ?? 0}}</span>\n </span>\n <div class=\"review-rating d-flex gap-2 align-items-center justify-content-between\" *ngIf=\"product?.averageRating\">\n <p-rating [(ngModel)]=\"product.averageRating\" [cancel]=\"false\" [readonly]=\"true\" />\n <div class=\"total-ratings\">{{\n getRatings(product?.totalReviewCount)}}</div>\n </div>\n <div class=\"add-to-cart\" [style.borderColor]=\"data.styles?.background?.accentColor\" *ngIf=\"data?.content?.display?.showButton\"\n [ngClass]=\"{'justify-content-between p-0 d-flex': product.quantity, 'justify-content-center': !product.quantity}\"\n (click)=\"removeDefault($event)\">\n <ng-container *ngIf=\"product?.itemInventory?.openingStock\">\n <ng-container *ngIf=\"!product.quantity\">\n <div (click)=\"addItemToCart($event, product, 'ADD')\" [style.color]=\"data.styles?.background?.accentColor\">\n Add to Cart</div>\n </ng-container>\n <ng-container *ngIf=\"product.quantity\">\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'SUBSTRACT')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">-</span>\n <span class=\"quantity\" [style.color]=\"data.styles?.background?.accentColor\">{{product.quantity}}</span>\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'ADD')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">+</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!product?.itemInventory?.openingStock\">\n <span class=\"d-flex align-items-center justify-content-center w-100\">\n <mat-icon>notification_important</mat-icon>\n <span class=\"ml-2\">Notify</span>\n </span>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n\n<!-- <ng-template #loadingScreen>\n <ngx-skeleton-loader *ngIf=\"filterLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n width: '100%',\n height: '100%',\n 'border-radius': '10px',\n 'position': 'relative',\n 'right': '5px'\n }\" />\n</ng-template> -->", styles: [".product{position:relative;display:flex;flex-direction:column;cursor:pointer;margin-bottom:10px;border-radius:10px;overflow:hidden;height:350px;background-color:#fff}.product .prod-img{position:relative;height:55%;width:100%;overflow:hidden;border:1.8px solid;border-radius:10px;border-color:#e5e7eb}.product .prod-img img{height:100%;width:100%;object-fit:cover}*{font-family:var(--website-font-family)}mat-icon{font-family:Material Icons!important}.width{margin-right:10px;min-width:195px;max-width:195px}.styling{height:30px;width:30px;border-radius:50%;background-color:#fff;position:absolute;bottom:0;right:-12px}.strike-through{text-decoration:line-through;color:#d3d3d3;font-size:12px;margin-left:5px;position:relative}.add-to-cart{width:100%;cursor:pointer;background-color:#fff;border:1.5px solid transparent;border-radius:5px;padding:5px;text-align:center;align-items:center}.add-to-cart .quantity-btn{padding:5px 10px;font-weight:700}.discount{position:absolute;top:0;padding:5px;width:60px;text-align:center;font-size:12px;border-bottom-right-radius:3px}@media screen and (max-width: 475px){.width{max-width:160px;min-width:160px;height:300px}.adjustHeightWidth{max-width:100%;min-width:100%}}.h-40{height:45%;position:relative}.bottom{position:absolute;bottom:10px;width:93%;display:flex;flex-direction:column}.discount-price{font-weight:600;font-size:14px}.color{color:#000}.trim-text{text-align:inherit!important}.product-img.fade-out{opacity:0;transform:scale(.95)}.gap-15{gap:15px}.flex-wrap{flex-wrap:wrap}.carousel-buttons{display:flex;gap:10px;position:absolute;bottom:10px;left:10px;transform:translateY(-50%);pointer-events:none}.carousel-buttons div{background:#fff;display:flex;align-items:center;border-radius:100%;height:30px;width:30px;justify-content:center;pointer-events:auto}\n"] }]
145
- }], ctorParameters: () => [{ type: i1.CartService }, { type: i2.Router }], propDecorators: { product: [{
182
+ FormsModule,
183
+ ToastModule
184
+ ], template: "<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"></p-toast>\n<div class=\"product hover-effect\" [ngClass]=\"{'width' : isScrollable, 'adjustHeightWidth': isCategoryProductList}\"\n [style.opacity]=\"product?.itemInventory?.openingStock == 0 ? 0.5 : 1\" [attr.style]=\"customClass\">\n <div class=\"prod-img\" [class.fade-out]=\"imageIndex == index\">\n <image-loading [imageUrl]=\"getProductImages(product)\" [hash]=\"product.itemImages?.[0]?.blurhash\"\n (click)=\"goToProductDetail(product)\" [theme]=\"data?.styles?.theme\"></image-loading>\n <div class=\"discount\" [style.backgroundColor]=\"data?.styles?.background?.color\"\n [simpoColor]=\"data?.styles?.background?.color\" *ngIf=\"getPercentage(product) > '0'\">{{getPercentage(product)}}%\n off</div>\n <div class=\"carousel-buttons\" *ngIf=\"(product?.itemImages?.length || 0) > 1\">\n <div><mat-icon (click)=\"changeImage(product, 'PREV')\">keyboard_arrow_left</mat-icon></div>\n <div><mat-icon (click)=\"changeImage(product, 'NEXT')\">keyboard_arrow_right</mat-icon></div>\n </div>\n </div>\n <div class=\"p-2 h-40\" (click)=\"goToProductDetail(product)\">\n <span class=\"trim-text color\">{{product.name}}</span>\n <div class=\"bottom\">\n <span class=\"m-1\">\n <span class=\"color\"><span [innerHTML]=\"currency\"></span> {{product?.price?.sellingPrice ?? 0}}</span>\n <span class=\"color\" *ngIf=\"product.price.value - product.price.discountedPrice > 2\"\n [ngClass]=\"{'strike-through' : product.price.value - product.price.discountedPrice > 2}\"><span\n [innerHTML]=\"currency\"></span> {{product?.price?.value ?? 0}}</span>\n </span>\n <div class=\"review-rating d-flex gap-2 align-items-center justify-content-between\" *ngIf=\"product?.averageRating\">\n <p-rating [(ngModel)]=\"product.averageRating\" [cancel]=\"false\" [readonly]=\"true\" />\n <div class=\"total-ratings\">{{\n getRatings(product?.totalReviewCount)}}</div>\n </div>\n <div class=\"add-to-cart\" [style.borderColor]=\"data.styles?.background?.accentColor\"\n *ngIf=\"data?.content?.display?.showButton\"\n [ngClass]=\"{'justify-content-between p-0 d-flex': product.quantity, 'justify-content-center': !product.quantity}\"\n (click)=\"removeDefault($event)\">\n <ng-container *ngIf=\"product?.itemInventory?.openingStock\">\n <ng-container *ngIf=\"!product.quantity\">\n <div (click)=\"addItemToCart($event, product, 'ADD')\" [style.color]=\"data.styles?.background?.accentColor\"\n *ngIf=\"IsEcommerce\">\n Add to Cart</div>\n <div [style.color]=\"data.styles?.background?.accentColor\" *ngIf=\"!IsEcommerce\" (click)=\"raiseLead()\">Notify\n Me</div>\n </ng-container>\n <ng-container *ngIf=\"product.quantity\">\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'SUBSTRACT')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">-</span>\n <span class=\"quantity\" [style.color]=\"data.styles?.background?.accentColor\">{{product.quantity}}</span>\n <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'ADD')\"\n [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n [style.color]=\"data.styles?.background?.accentColor\">+</span>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!product?.itemInventory?.openingStock\">\n <span class=\"d-flex align-items-center justify-content-center w-100\">\n <mat-icon>notification_important</mat-icon>\n <span class=\"ml-2\">Notify</span>\n </span>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n\n<!-- <ng-template #loadingScreen>\n <ngx-skeleton-loader *ngIf=\"filterLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n width: '100%',\n height: '100%',\n 'border-radius': '10px',\n 'position': 'relative',\n 'right': '5px'\n }\" />\n</ng-template> -->", styles: [".product{position:relative;display:flex;flex-direction:column;cursor:pointer;margin-bottom:10px;border-radius:10px;overflow:hidden;height:350px;background-color:#fff}.product .prod-img{position:relative;height:55%;width:100%;overflow:hidden;border:1.8px solid;border-radius:10px;border-color:#e5e7eb}.product .prod-img img{height:100%;width:100%;object-fit:cover}*{font-family:var(--website-font-family)}mat-icon{font-family:Material Icons!important}.width{margin-right:10px;min-width:195px;max-width:195px}.styling{height:30px;width:30px;border-radius:50%;background-color:#fff;position:absolute;bottom:0;right:-12px}.strike-through{text-decoration:line-through;color:#d3d3d3;font-size:12px;margin-left:5px;position:relative}.add-to-cart{width:100%;cursor:pointer;background-color:#fff;border:1.5px solid transparent;border-radius:5px;padding:5px;text-align:center;align-items:center}.add-to-cart .quantity-btn{padding:5px 10px;font-weight:700}.discount{position:absolute;top:0;padding:5px;width:60px;text-align:center;font-size:12px;border-bottom-right-radius:3px}@media screen and (max-width: 475px){.width{max-width:160px;min-width:160px;height:300px}.adjustHeightWidth{max-width:100%;min-width:100%}}.h-40{height:45%;position:relative}.bottom{position:absolute;bottom:10px;width:93%;display:flex;flex-direction:column}.discount-price{font-weight:600;font-size:14px}.color{color:#000}.trim-text{text-align:inherit!important}.product-img.fade-out{opacity:0;transform:scale(.95)}.gap-15{gap:15px}.flex-wrap{flex-wrap:wrap}.carousel-buttons{display:flex;gap:10px;position:absolute;bottom:10px;left:10px;transform:translateY(-50%);pointer-events:none}.carousel-buttons div{background:#fff;display:flex;align-items:center;border-radius:100%;height:30px;width:30px;justify-content:center;pointer-events:auto}\n"] }]
185
+ }], ctorParameters: () => [{ type: i1.CartService }, { type: i2.Router }, { type: i3.RestService }, { type: i4.StorageServiceService }, { type: i5.MessageService }], propDecorators: { product: [{
146
186
  type: Input
147
187
  }], data: [{
148
188
  type: Input
@@ -155,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
155
195
  }], index: [{
156
196
  type: Input
157
197
  }] } });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"small-product-listing.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/small-product-listing/small-product-listing.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/small-product-listing/small-product-listing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ItemVariant, Product } from '../../styles/product.modal';\nimport { CommonModule } from '@angular/common';\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\nimport { MatIcon } from '@angular/material/icon';\nimport { OrderedItems } from '../../styles/OrderedItems.modal';\nimport { CartService } from '../../../services/cart.service';\nimport { ColorDirective } from '../../../directive/color.directive';\nimport { Router } from '@angular/router';\nimport { ImageLoadingComponent } from '../../../components/image-loading/image-loading.component';\nimport { RatingModule } from 'primeng/rating';\nimport { FormsModule } from '@angular/forms';\n\n@Component({\n  selector: 'simpo-small-product-listing',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatIcon,\n    ImageLoadingComponent,\n    ColorDirective,\n    RatingModule,\n    FormsModule\n  ],\n  templateUrl: './small-product-listing.component.html',\n  styleUrl: './small-product-listing.component.css'\n})\nexport class SmallProductListingComponent implements OnInit {\n\n  constructor(\n    private readonly cartService: CartService,\n    private readonly router: Router\n  ) {}\n\n  private USER_CART: OrderedItems[] | null = null;\n  @Input() product!: Product;\n  @Input() data?: any;\n  @Input() isScrollable?: boolean;\n  @Input() isCategoryProductList: boolean = false;\n  @Input() customClass?: string;\n  @Input() index!:number\n\n  ngOnInit(): void {\n\n  }\n\n  addItemToCart(event: PointerEvent | MouseEvent, product: Product, type: 'ADD' | 'SUBSTRACT') {\n    // if (this.isItemOutOfStock(product)) {\n    //   this.messageService.add({ severity: 'warn', summary: 'Cart', detail: 'Item is not available as of now. We will notify you once available' });\n    //   return;\n    // }\n\n    if (!product?.quantity)\n      product.quantity = 0;\n    if (type == 'ADD') {\n      product.quantity += 1;\n    }\n    else {\n      product.quantity -= 1;\n    }\n\n    if (product?.itemVariant?.length) {\n      const itemVarient: ItemVariant | null = this.getItemVarient(product, product.varientId);\n      if (itemVarient) {\n        itemVarient.quantity = product.quantity;\n        this.cartService.addItemToCart(product, itemVarient.variantId);\n      }\n    } else {\n      this.cartService.addItemToCart(product);\n    }\n    if (product.quantity) {\n      let isPresent: boolean = false;\n      this.USER_CART?.forEach((item: OrderedItems) => {\n        if (item.varientId == product.varientId) {\n          item.quantity = product.quantity;\n          isPresent = true;\n        }\n      })\n      if (!isPresent)\n        this.USER_CART?.push(new OrderedItems(product, product.varientId));\n    } else {\n      this.USER_CART = this.USER_CART?.filter((item: OrderedItems) => item.varientId != product.varientId) ?? [];\n    }\n    event.stopPropagation();\n  }\n\n  removeDefault(event: PointerEvent | MouseEvent) {\n    event.stopPropagation();\n  }\n\n  getItemVarient(product: Product, varientId: string): ItemVariant | null {\n    let selectedVarient: ItemVariant | null = null;\n    product?.itemVariant?.forEach((varient: ItemVariant) => {\n      if (varient.variantId == varientId)\n        selectedVarient = varient;\n    })\n\n    return selectedVarient;\n  }\n  getPercentage(product: Product) {\n    return (((product?.price?.sellingPrice - product?.price?.discountedPrice) / product?.price?.sellingPrice) * 100).toFixed(0);\n  }\n  goToProductDetail(product: Product) {\n    this.router.navigate([`details`], { queryParams: { id: product.itemId } });\n  }\n  getSupportingColor(color: string): string {\n    let hex = color;\n    if (!hex)\n      return color;\n    hex = hex.replace(/^#/, '');\n\n    let bigint = parseInt(hex, 16);\n    let r = (bigint >> 16) & 255;\n    let g = (bigint >> 8) & 255;\n    let b = bigint & 255;\n\n    return `rgba(${r}, ${g}, ${b}, 0.4)`;\n  }\n\n  get currency(): string {\n    return BUSINESS_CONSTANTS.CURRENCY;\n  }\n\n  getProductImages(product: any) {\n    if(!product['currentImageIndex'])\n      product['currentImageIndex'] = 0;\n\n    let imageIndex:number = product['currentImageIndex'] % product?.['itemImages']?.length;\n    return product?.['itemImages']?.[imageIndex]?.imgUrl\n  }\n\n  imageIndex: number = -1;\n  async changeImage(product: any, action: 'PREV' | 'NEXT') {\n    this.imageIndex = this.index;\n    await new Promise(resolve => setTimeout(resolve, 300));\n\n    if(action === 'NEXT') {\n      product['currentImageIndex']++;\n    } else {\n      product['currentImageIndex']--;\n\n      if(product['currentImageIndex'] < 0)\n        product['currentImageIndex'] = product?.['itemImages']?.length - 1;\n    }\n      this.imageIndex = -1;\n  }\n  getRatings(noofratings : any){\n    if(noofratings >= 1000 && noofratings <= 10000){\n      return (noofratings/1000).toFixed(1) + \"K+\";\n    }\n    else if(noofratings > 10000 && noofratings <= 100000){\n      return (noofratings/10000).toFixed(1) + \"K+\";\n    }\n    else if(noofratings > 100000 && noofratings <= 1000000){\n      return (noofratings/100000).toFixed(1) + \"L+\";\n    }\n    else if(noofratings > 1000000){\n      return (noofratings/1000000).toFixed(1) + \"M+\";\n    }\n    else{\n      return noofratings;\n    }\n  }\n}\n","<div class=\"product hover-effect\" [ngClass]=\"{'width' : isScrollable, 'adjustHeightWidth': isCategoryProductList}\"\n  [style.opacity]=\"product?.itemInventory?.openingStock == 0 ? 0.5 : 1\" [attr.style]=\"customClass\">\n  <div class=\"prod-img\" [class.fade-out]=\"imageIndex == index\">\n    <image-loading [imageUrl]=\"getProductImages(product)\" [hash]=\"product.itemImages?.[0]?.blurhash\"\n      (click)=\"goToProductDetail(product)\" [theme]=\"data?.styles?.theme\"></image-loading>\n    <div class=\"discount\" [style.backgroundColor]=\"data?.styles?.background?.color\"\n      [simpoColor]=\"data?.styles?.background?.color\" *ngIf=\"getPercentage(product) > '0'\">{{getPercentage(product)}}%\n      off</div>\n    <div class=\"carousel-buttons\" *ngIf=\"(product?.itemImages?.length || 0) > 1\">\n      <div><mat-icon (click)=\"changeImage(product, 'PREV')\">keyboard_arrow_left</mat-icon></div>\n      <div><mat-icon (click)=\"changeImage(product, 'NEXT')\">keyboard_arrow_right</mat-icon></div>\n    </div>\n  </div>\n  <div class=\"p-2 h-40\" (click)=\"goToProductDetail(product)\">\n    <span class=\"trim-text color\">{{product.name}}</span>\n    <div class=\"bottom\">\n      <span class=\"m-1\">\n        <span class=\"color\"><span\n            [innerHTML]=\"currency\"></span> {{product?.price?.sellingPrice ?? 0}}</span>\n        <span class=\"color\" *ngIf=\"product.price.value - product.price.discountedPrice > 2\"\n          [ngClass]=\"{'strike-through' : product.price.value - product.price.discountedPrice > 2}\"><span\n            [innerHTML]=\"currency\"></span> {{product?.price?.value ?? 0}}</span>\n      </span>\n      <div class=\"review-rating d-flex gap-2 align-items-center justify-content-between\" *ngIf=\"product?.averageRating\">\n        <p-rating [(ngModel)]=\"product.averageRating\" [cancel]=\"false\" [readonly]=\"true\" />\n        <div class=\"total-ratings\">{{\n          getRatings(product?.totalReviewCount)}}</div>\n      </div>\n      <div class=\"add-to-cart\" [style.borderColor]=\"data.styles?.background?.accentColor\" *ngIf=\"data?.content?.display?.showButton\"\n        [ngClass]=\"{'justify-content-between p-0 d-flex': product.quantity, 'justify-content-center': !product.quantity}\"\n        (click)=\"removeDefault($event)\">\n        <ng-container *ngIf=\"product?.itemInventory?.openingStock\">\n          <ng-container *ngIf=\"!product.quantity\">\n            <div (click)=\"addItemToCart($event, product, 'ADD')\" [style.color]=\"data.styles?.background?.accentColor\">\n              Add to Cart</div>\n          </ng-container>\n          <ng-container *ngIf=\"product.quantity\">\n            <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'SUBSTRACT')\"\n              [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n              [style.color]=\"data.styles?.background?.accentColor\">-</span>\n            <span class=\"quantity\" [style.color]=\"data.styles?.background?.accentColor\">{{product.quantity}}</span>\n            <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'ADD')\"\n              [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n              [style.color]=\"data.styles?.background?.accentColor\">+</span>\n          </ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!product?.itemInventory?.openingStock\">\n          <span class=\"d-flex align-items-center justify-content-center w-100\">\n            <mat-icon>notification_important</mat-icon>\n            <span class=\"ml-2\">Notify</span>\n          </span>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n</div>\n\n<!-- <ng-template #loadingScreen>\n  <ngx-skeleton-loader *ngIf=\"filterLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n          width: '100%',\n          height: '100%',\n          'border-radius': '10px',\n          'position': 'relative',\n          'right': '5px'\n        }\" />\n</ng-template> -->"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"small-product-listing.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/small-product-listing/small-product-listing.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/small-product-listing/small-product-listing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ItemVariant, Product } from '../../styles/product.modal';\nimport { CommonModule } from '@angular/common';\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\nimport { MatIcon } from '@angular/material/icon';\nimport { OrderedItems } from '../../styles/OrderedItems.modal';\nimport { CartService } from '../../../services/cart.service';\nimport { ColorDirective } from '../../../directive/color.directive';\nimport { Router } from '@angular/router';\nimport { ImageLoadingComponent } from '../../../components/image-loading/image-loading.component';\nimport { RatingModule } from 'primeng/rating';\nimport { FormsModule } from '@angular/forms';\nimport { RestService } from '../../../services/rest.service';\nimport { MessageService } from 'primeng/api';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport { ToastModule } from 'primeng/toast';\n\n@Component({\n  selector: 'simpo-small-product-listing',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatIcon,\n    ImageLoadingComponent,\n    ColorDirective,\n    RatingModule,\n    FormsModule,\n    ToastModule\n  ],\n  templateUrl: './small-product-listing.component.html',\n  styleUrl: './small-product-listing.component.css'\n})\nexport class SmallProductListingComponent implements OnInit {\n\n  constructor(\n    private readonly cartService: CartService,\n    private readonly router: Router,\n    private readonly restService: RestService,\n    private readonly storageService: StorageServiceService,\n    private readonly messageService: MessageService\n  ) { }\n\n  private USER_CART: OrderedItems[] | null = null;\n  @Input() product!: Product;\n  @Input() data?: any;\n  @Input() isScrollable?: boolean;\n  @Input() isCategoryProductList: boolean = false;\n  @Input() customClass?: string;\n  @Input() index!: number\n  IsEcommerce: boolean = false;\n  ngOnInit(): void {\n    this.IsEcommerce = localStorage.getItem(\"websiteType\") != 'STATIC' ? true : false;\n  }\n\n  addItemToCart(event: PointerEvent | MouseEvent, product: Product, type: 'ADD' | 'SUBSTRACT') {\n    // if (this.isItemOutOfStock(product)) {\n    //   this.messageService.add({ severity: 'warn', summary: 'Cart', detail: 'Item is not available as of now. We will notify you once available' });\n    //   return;\n    // }\n\n    if (!product?.quantity)\n      product.quantity = 0;\n    if (type == 'ADD') {\n      product.quantity += 1;\n    }\n    else {\n      product.quantity -= 1;\n    }\n\n    if (product?.itemVariant?.length) {\n      const itemVarient: ItemVariant | null = this.getItemVarient(product, product.varientId);\n      if (itemVarient) {\n        itemVarient.quantity = product.quantity;\n        this.cartService.addItemToCart(product, itemVarient.variantId);\n      }\n    } else {\n      this.cartService.addItemToCart(product);\n    }\n    if (product.quantity) {\n      let isPresent: boolean = false;\n      this.USER_CART?.forEach((item: OrderedItems) => {\n        if (item.varientId == product.varientId) {\n          item.quantity = product.quantity;\n          isPresent = true;\n        }\n      })\n      if (!isPresent)\n        this.USER_CART?.push(new OrderedItems(product, product.varientId));\n    } else {\n      this.USER_CART = this.USER_CART?.filter((item: OrderedItems) => item.varientId != product.varientId) ?? [];\n    }\n    event.stopPropagation();\n  }\n\n  removeDefault(event: PointerEvent | MouseEvent) {\n    event.stopPropagation();\n  }\n  raiseLead() {\n    const userDetails = this.storageService.getUser();\n    let payload = {\n      businessId: localStorage.getItem('businessId'),\n      email: userDetails?.contact?.email,\n      message: \"\",\n      mobileNo: \"\",\n      moreInfo: {\n        Name: userDetails?.contact?.name,\n        \"Mobile Number\": userDetails?.contact?.mobile,\n        Email: userDetails?.contact?.email,\n        \"Lead Source\": \"Website\",\n        \"Lead Status\": \"NEW\"\n      },\n      name: userDetails?.contact?.name\n    }\n    this.restService.createLead(payload).subscribe({\n      next: (res: any) => {\n        if (res?.data) {\n          this.messageService.add({ severity: 'success', summary: 'Thank you', detail: 'Our team will contact you soon' });\n        }\n      },\n      error: (err: any) => {\n        if (err) {\n          this.messageService.add({ severity: 'error', summary: 'Error', detail: 'Error occured please try again later' });\n        }\n      }\n    })\n  }\n  getItemVarient(product: Product, varientId: string): ItemVariant | null {\n    let selectedVarient: ItemVariant | null = null;\n    product?.itemVariant?.forEach((varient: ItemVariant) => {\n      if (varient.variantId == varientId)\n        selectedVarient = varient;\n    })\n\n    return selectedVarient;\n  }\n  getPercentage(product: Product) {\n    return (((product?.price?.sellingPrice - product?.price?.discountedPrice) / product?.price?.sellingPrice) * 100).toFixed(0);\n  }\n  goToProductDetail(product: Product) {\n    this.router.navigate([`details`], { queryParams: { id: product.itemId } });\n  }\n  getSupportingColor(color: string): string {\n    let hex = color;\n    if (!hex)\n      return color;\n    hex = hex.replace(/^#/, '');\n\n    let bigint = parseInt(hex, 16);\n    let r = (bigint >> 16) & 255;\n    let g = (bigint >> 8) & 255;\n    let b = bigint & 255;\n\n    return `rgba(${r}, ${g}, ${b}, 0.4)`;\n  }\n\n  get currency(): string {\n    return BUSINESS_CONSTANTS.CURRENCY;\n  }\n\n  getProductImages(product: any) {\n    if (!product['currentImageIndex'])\n      product['currentImageIndex'] = 0;\n\n    let imageIndex: number = product['currentImageIndex'] % product?.['itemImages']?.length;\n    return product?.['itemImages']?.[imageIndex]?.imgUrl\n  }\n\n  imageIndex: number = -1;\n  async changeImage(product: any, action: 'PREV' | 'NEXT') {\n    this.imageIndex = this.index;\n    await new Promise(resolve => setTimeout(resolve, 300));\n\n    if (action === 'NEXT') {\n      product['currentImageIndex']++;\n    } else {\n      product['currentImageIndex']--;\n\n      if (product['currentImageIndex'] < 0)\n        product['currentImageIndex'] = product?.['itemImages']?.length - 1;\n    }\n    this.imageIndex = -1;\n  }\n  getRatings(noofratings: any) {\n    if (noofratings >= 1000 && noofratings <= 10000) {\n      return (noofratings / 1000).toFixed(1) + \"K+\";\n    }\n    else if (noofratings > 10000 && noofratings <= 100000) {\n      return (noofratings / 10000).toFixed(1) + \"K+\";\n    }\n    else if (noofratings > 100000 && noofratings <= 1000000) {\n      return (noofratings / 100000).toFixed(1) + \"L+\";\n    }\n    else if (noofratings > 1000000) {\n      return (noofratings / 1000000).toFixed(1) + \"M+\";\n    }\n    else {\n      return noofratings;\n    }\n  }\n}\n","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"></p-toast>\n<div class=\"product hover-effect\" [ngClass]=\"{'width' : isScrollable, 'adjustHeightWidth': isCategoryProductList}\"\n  [style.opacity]=\"product?.itemInventory?.openingStock == 0 ? 0.5 : 1\" [attr.style]=\"customClass\">\n  <div class=\"prod-img\" [class.fade-out]=\"imageIndex == index\">\n    <image-loading [imageUrl]=\"getProductImages(product)\" [hash]=\"product.itemImages?.[0]?.blurhash\"\n      (click)=\"goToProductDetail(product)\" [theme]=\"data?.styles?.theme\"></image-loading>\n    <div class=\"discount\" [style.backgroundColor]=\"data?.styles?.background?.color\"\n      [simpoColor]=\"data?.styles?.background?.color\" *ngIf=\"getPercentage(product) > '0'\">{{getPercentage(product)}}%\n      off</div>\n    <div class=\"carousel-buttons\" *ngIf=\"(product?.itemImages?.length || 0) > 1\">\n      <div><mat-icon (click)=\"changeImage(product, 'PREV')\">keyboard_arrow_left</mat-icon></div>\n      <div><mat-icon (click)=\"changeImage(product, 'NEXT')\">keyboard_arrow_right</mat-icon></div>\n    </div>\n  </div>\n  <div class=\"p-2 h-40\" (click)=\"goToProductDetail(product)\">\n    <span class=\"trim-text color\">{{product.name}}</span>\n    <div class=\"bottom\">\n      <span class=\"m-1\">\n        <span class=\"color\"><span [innerHTML]=\"currency\"></span> {{product?.price?.sellingPrice ?? 0}}</span>\n        <span class=\"color\" *ngIf=\"product.price.value - product.price.discountedPrice > 2\"\n          [ngClass]=\"{'strike-through' : product.price.value - product.price.discountedPrice > 2}\"><span\n            [innerHTML]=\"currency\"></span> {{product?.price?.value ?? 0}}</span>\n      </span>\n      <div class=\"review-rating d-flex gap-2 align-items-center justify-content-between\" *ngIf=\"product?.averageRating\">\n        <p-rating [(ngModel)]=\"product.averageRating\" [cancel]=\"false\" [readonly]=\"true\" />\n        <div class=\"total-ratings\">{{\n          getRatings(product?.totalReviewCount)}}</div>\n      </div>\n      <div class=\"add-to-cart\" [style.borderColor]=\"data.styles?.background?.accentColor\"\n        *ngIf=\"data?.content?.display?.showButton\"\n        [ngClass]=\"{'justify-content-between p-0 d-flex': product.quantity, 'justify-content-center': !product.quantity}\"\n        (click)=\"removeDefault($event)\">\n        <ng-container *ngIf=\"product?.itemInventory?.openingStock\">\n          <ng-container *ngIf=\"!product.quantity\">\n            <div (click)=\"addItemToCart($event, product, 'ADD')\" [style.color]=\"data.styles?.background?.accentColor\"\n              *ngIf=\"IsEcommerce\">\n              Add to Cart</div>\n            <div [style.color]=\"data.styles?.background?.accentColor\" *ngIf=\"!IsEcommerce\" (click)=\"raiseLead()\">Notify\n              Me</div>\n          </ng-container>\n          <ng-container *ngIf=\"product.quantity\">\n            <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'SUBSTRACT')\"\n              [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n              [style.color]=\"data.styles?.background?.accentColor\">-</span>\n            <span class=\"quantity\" [style.color]=\"data.styles?.background?.accentColor\">{{product.quantity}}</span>\n            <span class=\"quantity-btn\" (click)=\"addItemToCart($event, product, 'ADD')\"\n              [style.backgroundColor]=\"getSupportingColor(data.styles?.background?.accentColor)\"\n              [style.color]=\"data.styles?.background?.accentColor\">+</span>\n          </ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!product?.itemInventory?.openingStock\">\n          <span class=\"d-flex align-items-center justify-content-center w-100\">\n            <mat-icon>notification_important</mat-icon>\n            <span class=\"ml-2\">Notify</span>\n          </span>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n</div>\n\n<!-- <ng-template #loadingScreen>\n  <ngx-skeleton-loader *ngIf=\"filterLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\n          width: '100%',\n          height: '100%',\n          'border-radius': '10px',\n          'position': 'relative',\n          'right': '5px'\n        }\" />\n</ng-template> -->"]}
@@ -105,6 +105,8 @@ export class StoreListComponent extends BaseSection {
105
105
  this.router.navigate(['/store'], { queryParams: { storeId: storeId } });
106
106
  }
107
107
  getTime(storeHours, type) {
108
+ if (!storeHours || storeHours?.length == 0)
109
+ return;
108
110
  const today = new Date();
109
111
  const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();
110
112
  for (let ele of storeHours) {
@@ -154,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
154
156
  }], index: [{
155
157
  type: Input
156
158
  }] } });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-list/store-list.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-list/store-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgModule, ViewChild } from '@angular/core';\nimport BaseSection from '../../../sections/BaseSection';\nimport { StoreListModal, StoreListStyleModel } from './store-list.modal';\nimport { CommonModule } from '@angular/common';\nimport { AnimationDirective } from '../../../directive/animation-directive';\nimport { BackgroundDirective } from '../../../directive/background-directive';\nimport { SimpoComponentModule } from '../../../components/index';\nimport { HoverDirective } from '../../../directive/hover-element-directive';\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatIcon } from '@angular/material/icon';\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\nimport { RestService } from '../../../services/rest.service';\nimport { Router } from '@angular/router';\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\nimport { ButtonEditorDirective } from '../../../directive/button-editor.directive';\nimport { ButtonModel } from '../../../styles/style.model';\nimport { ColorDirective } from '../../../directive/color.directive';\n\n\n\n@Component({\n  selector: 'simpo-store-list',\n  standalone: true,\n  imports: [CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    MatIcon,\n    SimpoComponentModule,\n    AnimationDirective,\n    BackgroundDirective,\n    HoverDirective,\n    ButtonDirectiveDirective,\n    ContentFitDirective,\n    NgxSkeletonLoaderModule,\n    ButtonEditorDirective,\n    ColorDirective,\n  ],\n  templateUrl: './store-list.component.html',\n  styleUrl: './store-list.component.css'\n})\nexport class StoreListComponent extends BaseSection {\n\n  @Input() data?: StoreListModal\n  @Input() edit?: boolean = true;\n  @Input() customClass?: string;\n  @Input() delete?: boolean;\n  @Input() index?: number;\n  pageNo: number = 0;\n  isLoading: boolean = false;\n  cardSize: number = 50;\n\n\n  styles?: StoreListStyleModel;\n  button?: ButtonModel\n\n\n  constructor(private restService: RestService,\n    private router: Router\n  ) {\n    super();\n  }\n\n  ngOnInit() {\n    this.styles = this.data?.styles;\n    this.button = this.data?.action?.buttons[0];\n    this.pincode = localStorage.getItem('pincode') ?? \"\";\n    if (this.pincode?.toString().length == 6) {\n      this.getDataWithPincode();\n    }\n    this.getStoreDetails();\n  }\n  storesList: any = [];\n  pincode: any;\n  storePayload: any = {\n    businessId: localStorage.getItem('businessId') ?? \"1f05f085-d865-6bc5-82b4-0570667d6f5e\",\n    pageNo: 0,\n    pageSize: 15\n  }\n  getDataWithPincode() {\n    if (this.pincode.toString().length != 6) {\n      this.error = true\n      return;\n    }\n    this.storePayload.pincode = this.pincode;\n    this.getStoreDetails();\n  }\n  showMessage: boolean = false;\n  totalCount: number = 0;\n  submit: boolean = false;\n  loader: boolean = false;\n  error: boolean = false;\n  stateList: any\n  getStoreDetails() {\n    this.submit = true;\n    this.loader = true;\n    this.restService.getAllStores(this.storePayload).subscribe((res: any) => {\n      this.storesList = res?.data?.data;\n      this.storesList.forEach((store : any)=> {\n        store.star = Math.floor(Math.random() * 9) + 1;\n        store.reviewCount = Math.floor(Math.random() * (500 - 100 + 1)) + 100;\n      });\n      this.totalCount = res?.data?.count;\n      this.stateList = res?.data?.stateDetails;\n      if (this.pincode?.toString().length == 6)\n        this.showMessage = res?.data?.storePresent;\n      this.storePayload.pageNo++;\n      this.isLoading = false\n      this.loader = false;\n    },\n      (error) => {\n        this.loader = false\n      })\n  }\n  showState: boolean = true\n  selectedState: string = \"\"\n  setStateData(stateData: any) {\n    this.storesList = stateData?.storeList;\n    this.showState = false;\n  }\n  getTextColor(bgColor: any) {\n    if (bgColor) {\n      const threshold = 130; // Adjust this threshold as needed\n      const r = parseInt(bgColor.slice(1, 3), 16);\n      const g = parseInt(bgColor.slice(3, 5), 16);\n      const b = parseInt(bgColor.slice(5, 7), 16);\n      const brightness = (r * 299 + g * 587 + b * 114) / 1000;\n\n      return brightness > threshold ? '#000000' : '#ffffff';\n    }\n    return \"#ffffff;\"\n  }\n  openWhatsapp(phone: string) {\n    if (phone) {\n      const whatsappUrl = `https://wa.me/${phone}`;\n      window.open(whatsappUrl, '_blank');\n    }\n  }\n  viewStore(storeId: string) {\n    this.router.navigate(['/store'], { queryParams: { storeId: storeId } });\n  }\n  getTime(storeHours: any, type: string) {\n    const today = new Date();\n    const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();\n    for (let ele of storeHours) {\n      if (ele.dayOfWeek == dayName) {\n        if (type == 'OPEN') {\n          return ele.openingTime\n        } else {\n          return ele.closingTime\n        }\n      }\n    }\n  }\n  getRGBA(bgColor: any, opacity: number): any {\n    const r = parseInt(bgColor.slice(1, 3), 16);\n    const g = parseInt(bgColor.slice(3, 5), 16);\n    const b = parseInt(bgColor.slice(5, 7), 16);\n    return `rgba(${r}, ${g}, ${b}, ${opacity / 100})`;\n  }\n\n}\n","<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\n    <div class=\"main-container\" [simpoAnimation]=\"styles?.animation\" [id]=\"data?.id\">\n        <div class=\"top-section w-100 d-flex align-items-center justify-content-center text-center flex-column\"\n            [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\n            <ng-container *ngIf=\"!loader\">\n                <div class=\"store-header mb-3\">\n                    {{ submit && showMessage == true && pincode && pincode?.toString()?.length == 6 ? \"Stores in \" +\n                    pincode :\n                    \"Find a Store Near You\"}}\n                </div>\n                <div class=\"sub-text\">\n                    {{ submit && showMessage == true && pincode && pincode?.toString()?.length == 6 ? 'We have ' +\n                    totalCount\n                    + ' stores in this locality, scroll down to view the stores\n                    and browse the designs available.' : 'Locate a store near you — our presence is expanding every day,\n                    and\n                    we look forward to serving you.' }}\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"loader\">\n                <div class=\"sub-text\">\n                    <ngx-skeleton-loader [theme]=\"{\n                width: '35%',\n                height: '3vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                </div>\n                <div class=\"sub-text w-75\">\n                    <ngx-skeleton-loader [theme]=\"{\n                width: '35%',\n                height: '2vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                </div>\n            </ng-container>\n            <div class=\"location-container d-flex align-items-center justify-content-between w-25\"\n                [class.error-border]=\"error\">\n                <div class=\"d-flex align-items-center w-90\">\n                    <div class=\"d-flex mx-1\"><mat-icon class=\"d-flex align-items-center justify-content-center f-20\"\n                            [style.color]=\"data?.styles?.background?.accentColor\">gps_fixed</mat-icon>\n                    </div>\n                    <input type=\"number\" placeholder=\"Pin Code\" [(ngModel)]=\"pincode\" class=\"w-90\"\n                        [style.backgroundColor]=\"data?.styles?.background?.color\"\n                        [style.color]=\"getTextColor(data?.styles?.background?.color)\"\n                        (ngModelChange)=\"pincode.toString().length != 6 ? submit = false : error = false;\" />\n                </div>\n                <div (click)=\"getDataWithPincode()\" class=\"f-13 cursor-pointer\">Submit</div>\n            </div>\n            <span class=\"f-12 w-25 text-start mt-2\" *ngIf=\"error\" [style.color]=\"'#dc3545'\">Invalid Pincode\n                (Ex:500088)</span>\n        </div>\n        <div class=\"bottom-container row mx-auto mt-3\">\n            <div class=\"state-container row gap-3 justify-content-center mb-5\" *ngIf=\"showState && !pincode\">\n                <ng-container *ngFor=\"let state of stateList; let i = index\">\n                    <div class=\"state-card p-2 col-sm-6\" (click)=\"setStateData(state)\">\n                        <ng-container *ngIf=\"state?.stateImage; else noImage\">\n                            <img class=\"w-100 h-75\" [src]=\"state?.stateImage\">\n                        </ng-container>\n                        <ng-template #noImage>\n                            <img class=\"w-100 h-75\"\n                                src=\"https://cdn.caratlane.com/media/static/images/Find_In_Store/city_5.svg\">\n                        </ng-template>\n                        <div class=\"text-center mt-2 state-name\">{{state?.stateName}}</div>\n                        <div class=\"store-count text-center mb-3 mt-1\">{{state?.storeCount + \" stores\"}}</div>\n                    </div>\n                </ng-container>\n            </div>\n            <div class=\"w-100 d-flex align-items-center justify-content-center mb-3\"\n                *ngIf=\"submit && showMessage == false && pincode && pincode.toString().length ==6 && !loader\">\n                <div class=\"text-center not-available-text\">We are not available in this location currently</div>\n            </div>\n            <ng-container *ngIf=\"loader\">\n                <div class=\"sub-text w-100 text-center\">\n                    <ngx-skeleton-loader [theme]=\"{\n                width: '35%',\n                height: '6vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                </div>\n            </ng-container>\n            <div class=\"bottom-sub-text d-flex align-items-center justify-content-center mb-3 w-100 f-20 fw-bold\"> {{\n                submit &&\n                showMessage == true && pincode ? \"Showing \" + totalCount + \" Stores in \" + pincode :\n                \"Showing All Stores\"}}</div>\n            <ng-container *ngIf=\"!loader;else loaderScreen\">\n                <div class=\"row d-flex\">\n                    <div class=\"col-4 p-2 store d-flex flex-column \" style=\"border-radius: 12px; border: none;\"\n                        *ngFor=\"let ele of storesList; let i = index\">\n                        <div class=\"card-body position-relative d-flex flex-column  h-100\">\n                            <!-- Content -->\n                            <div class=\"h-100  p-3 pb-0\">\n                                <div class=\"d-flex justify-content-between align-items-start mb-2\">\n                                    <div class=\"d-flex flex-column mb-2 bb-1 w-100 pb-2\">\n                                        <h6 class=\"card-title fw-bold mb-1 w-100\">{{ele?.storeName}}</h6>\n                                        <div class=\"f-11\">\n                                            ⭐4.{{ele?.star}} &nbsp;&#x2022;&nbsp;{{ele?.reviewCount}}&nbsp;Google Reviews\n                                        </div>\n                                    </div>\n                                </div>\n                                <div class=\"mb-2 f-11\">\n                                    <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.addressLine}},</p>\n                                    <p class=\"mb-1 text-dark fw-medium\">\n                                        {{ele?.addressDetails?.city}},\n                                        {{ele?.addressDetails?.state}},{{ele?.addressDetails?.pincode}},\n                                    </p>\n                                    <p class=\"mb-0 fw-bold\">Phone-\n                                        <span\n                                            [style.color]=\"data?.styles?.background?.accentColor\">{{ele?.storeContactDetails?.mobile}}</span>\n                                    </p>\n                                </div>\n                                <div class=\"mb-2 f-11\">\n                                    <p class=\"mb-0  fw-bold\" [style.color]=\"data?.styles?.background?.accentColor\">\n                                        STORE HOURS -\n                                        {{getTime(ele?.storeHours,'OPEN')}} to {{getTime(ele?.storeHours,'CLOSE')}}\n                                    </p>\n                                </div>\n                            </div>\n                            <!-- Fixed bottom buttons -->\n                            <div class=\"d-flex gap-3 align-items-center justify-content-between  p-3 w-100 br-20\" [style.backgroundColor]=\"getRGBA(styles?.background?.accentColor,10)\">\n                                <div class=\"br-12 d-flex align-items-center justify-content-center\"\n                                    style=\"width: 30px; height: 30px;\" (click)=\"openWhatsapp(ele?.storeContactDetails?.mobile)\"\n                                    [style.backgroundColor]=\"data?.styles?.background?.accentColor\">\n                                    <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 448 512\" style=\"height: 20px;cursor: pointer;\">\n                                        <path [attr.fill]=\"getTextColor(data?.styles?.background?.accentColor)\"\n                                            d=\"M380.9 97.1c-41.9-42-97.7-65.1-157-65.1-122.4 0-222 99.6-222 222 0 39.1 10.2 77.3 29.6 111L0 480 117.7 449.1c32.4 17.7 68.9 27 106.1 27l.1 0c122.3 0 224.1-99.6 224.1-222 0-59.3-25.2-115-67.1-157zm-157 341.6c-33.2 0-65.7-8.9-94-25.7l-6.7-4-69.8 18.3 18.6-68.1-4.4-7c-18.5-29.4-28.2-63.3-28.2-98.2 0-101.7 82.8-184.5 184.6-184.5 49.3 0 95.6 19.2 130.4 54.1s56.2 81.2 56.1 130.5c0 101.8-84.9 184.6-186.6 184.6zM325.1 300.5c-5.5-2.8-32.8-16.2-37.9-18-5.1-1.9-8.8-2.8-12.5 2.8s-14.3 18-17.6 21.8c-3.2 3.7-6.5 4.2-12 1.4-32.6-16.3-54-29.1-75.5-66-5.7-9.8 5.7-9.1 16.3-30.3 1.8-3.7 .9-6.9-.5-9.7s-12.5-30.1-17.1-41.2c-4.5-10.8-9.1-9.3-12.5-9.5-3.2-.2-6.9-.2-10.6-.2s-9.7 1.4-14.8 6.9c-5.1 5.6-19.4 19-19.4 46.3s19.9 53.7 22.6 57.4c2.8 3.7 39.1 59.7 94.8 83.8 35.2 15.2 49 16.5 66.6 13.9 10.7-1.6 32.8-13.4 37.4-26.4s4.6-24.1 3.2-26.4c-1.3-2.5-5-3.9-10.5-6.6z\" />\n                                    </svg>\n                                </div>\n                                <button class=\"btn w-50\" [buttonData]=\"button?.content\" [buttonStyle]=\"button?.styles\"\n                                    simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\"\n                                    [color]=\"data?.styles?.background?.accentColor\"\n                                    [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\"\n                                    [buttonId]=\"button?.id ?? ''\" (click)=\"viewStore(ele.id)\">\n                                    {{button?.content?.label}}\n                                </button>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n\n            </ng-container>\n            <ng-template #loaderScreen>\n                <div class=\"row loader-container\">\n                    <ng-container *ngFor=\"let ele of [1,2,3,4,5,6]\">\n                        <ngx-skeleton-loader class=\"col-4 loader-column\" [theme]=\"{\n                width: '100%',\n                height: '40vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                    </ng-container>\n                </div>\n            </ng-template>\n        </div>\n    </div>\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n        <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n    </div>\n\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n        <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n    </div>\n</div>"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-list/store-list.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/store-list/store-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgModule, ViewChild } from '@angular/core';\nimport BaseSection from '../../../sections/BaseSection';\nimport { StoreListModal, StoreListStyleModel } from './store-list.modal';\nimport { CommonModule } from '@angular/common';\nimport { AnimationDirective } from '../../../directive/animation-directive';\nimport { BackgroundDirective } from '../../../directive/background-directive';\nimport { SimpoComponentModule } from '../../../components/index';\nimport { HoverDirective } from '../../../directive/hover-element-directive';\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatIcon } from '@angular/material/icon';\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\nimport { RestService } from '../../../services/rest.service';\nimport { Router } from '@angular/router';\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\nimport { ButtonEditorDirective } from '../../../directive/button-editor.directive';\nimport { ButtonModel } from '../../../styles/style.model';\nimport { ColorDirective } from '../../../directive/color.directive';\n\n\n\n@Component({\n  selector: 'simpo-store-list',\n  standalone: true,\n  imports: [CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    MatIcon,\n    SimpoComponentModule,\n    AnimationDirective,\n    BackgroundDirective,\n    HoverDirective,\n    ButtonDirectiveDirective,\n    ContentFitDirective,\n    NgxSkeletonLoaderModule,\n    ButtonEditorDirective,\n    ColorDirective,\n  ],\n  templateUrl: './store-list.component.html',\n  styleUrl: './store-list.component.css'\n})\nexport class StoreListComponent extends BaseSection {\n\n  @Input() data?: StoreListModal\n  @Input() edit?: boolean = true;\n  @Input() customClass?: string;\n  @Input() delete?: boolean;\n  @Input() index?: number;\n  pageNo: number = 0;\n  isLoading: boolean = false;\n  cardSize: number = 50;\n\n\n  styles?: StoreListStyleModel;\n  button?: ButtonModel\n\n\n  constructor(private restService: RestService,\n    private router: Router\n  ) {\n    super();\n  }\n\n  ngOnInit() {\n    this.styles = this.data?.styles;\n    this.button = this.data?.action?.buttons[0];\n    this.pincode = localStorage.getItem('pincode') ?? \"\";\n    if (this.pincode?.toString().length == 6) {\n      this.getDataWithPincode();\n    }\n    this.getStoreDetails();\n  }\n  storesList: any = [];\n  pincode: any;\n  storePayload: any = {\n    businessId: localStorage.getItem('businessId') ?? \"1f05f085-d865-6bc5-82b4-0570667d6f5e\",\n    pageNo: 0,\n    pageSize: 15\n  }\n  getDataWithPincode() {\n    if (this.pincode.toString().length != 6) {\n      this.error = true\n      return;\n    }\n    this.storePayload.pincode = this.pincode;\n    this.getStoreDetails();\n  }\n  showMessage: boolean = false;\n  totalCount: number = 0;\n  submit: boolean = false;\n  loader: boolean = false;\n  error: boolean = false;\n  stateList: any\n  getStoreDetails() {\n    this.submit = true;\n    this.loader = true;\n    this.restService.getAllStores(this.storePayload).subscribe((res: any) => {\n      this.storesList = res?.data?.data;\n      this.storesList.forEach((store : any)=> {\n        store.star = Math.floor(Math.random() * 9) + 1;\n        store.reviewCount = Math.floor(Math.random() * (500 - 100 + 1)) + 100;\n      });\n      this.totalCount = res?.data?.count;\n      this.stateList = res?.data?.stateDetails;\n      if (this.pincode?.toString().length == 6)\n        this.showMessage = res?.data?.storePresent;\n      this.storePayload.pageNo++;\n      this.isLoading = false\n      this.loader = false;\n    },\n      (error) => {\n        this.loader = false\n      })\n  }\n  showState: boolean = true\n  selectedState: string = \"\"\n  setStateData(stateData: any) {\n    this.storesList = stateData?.storeList;\n    this.showState = false;\n  }\n  getTextColor(bgColor: any) {\n    if (bgColor) {\n      const threshold = 130; // Adjust this threshold as needed\n      const r = parseInt(bgColor.slice(1, 3), 16);\n      const g = parseInt(bgColor.slice(3, 5), 16);\n      const b = parseInt(bgColor.slice(5, 7), 16);\n      const brightness = (r * 299 + g * 587 + b * 114) / 1000;\n\n      return brightness > threshold ? '#000000' : '#ffffff';\n    }\n    return \"#ffffff;\"\n  }\n  openWhatsapp(phone: string) {\n    if (phone) {\n      const whatsappUrl = `https://wa.me/${phone}`;\n      window.open(whatsappUrl, '_blank');\n    }\n  }\n  viewStore(storeId: string) {\n    this.router.navigate(['/store'], { queryParams: { storeId: storeId } });\n  }\n  getTime(storeHours: any, type: string) {\n    if(!storeHours || storeHours?.length == 0) \n      return;\n    const today = new Date();\n    const dayName = today.toLocaleDateString('en-US', { weekday: 'long' }).toUpperCase();\n    for (let ele of storeHours) {\n      if (ele.dayOfWeek == dayName) {\n        if (type == 'OPEN') {\n          return ele.openingTime\n        } else {\n          return ele.closingTime\n        }\n      }\n    }\n  }\n  getRGBA(bgColor: any, opacity: number): any {\n    const r = parseInt(bgColor.slice(1, 3), 16);\n    const g = parseInt(bgColor.slice(3, 5), 16);\n    const b = parseInt(bgColor.slice(5, 7), 16);\n    return `rgba(${r}, ${g}, ${b}, ${opacity / 100})`;\n  }\n\n}\n","<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\n    <div class=\"main-container\" [simpoAnimation]=\"styles?.animation\" [id]=\"data?.id\">\n        <div class=\"top-section w-100 d-flex align-items-center justify-content-center text-center flex-column\"\n            [simpoBackground]=\"styles?.background\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\">\n            <ng-container *ngIf=\"!loader\">\n                <div class=\"store-header mb-3\">\n                    {{ submit && showMessage == true && pincode && pincode?.toString()?.length == 6 ? \"Stores in \" +\n                    pincode :\n                    \"Find a Store Near You\"}}\n                </div>\n                <div class=\"sub-text\">\n                    {{ submit && showMessage == true && pincode && pincode?.toString()?.length == 6 ? 'We have ' +\n                    totalCount\n                    + ' stores in this locality, scroll down to view the stores\n                    and browse the designs available.' : 'Locate a store near you — our presence is expanding every day,\n                    and\n                    we look forward to serving you.' }}\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"loader\">\n                <div class=\"sub-text\">\n                    <ngx-skeleton-loader [theme]=\"{\n                width: '35%',\n                height: '3vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                </div>\n                <div class=\"sub-text w-75\">\n                    <ngx-skeleton-loader [theme]=\"{\n                width: '35%',\n                height: '2vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                </div>\n            </ng-container>\n            <div class=\"location-container d-flex align-items-center justify-content-between w-25\"\n                [class.error-border]=\"error\">\n                <div class=\"d-flex align-items-center w-90\">\n                    <div class=\"d-flex mx-1\"><mat-icon class=\"d-flex align-items-center justify-content-center f-20\"\n                            [style.color]=\"data?.styles?.background?.accentColor\">gps_fixed</mat-icon>\n                    </div>\n                    <input type=\"number\" placeholder=\"Pin Code\" [(ngModel)]=\"pincode\" class=\"w-90\"\n                        [style.backgroundColor]=\"data?.styles?.background?.color\"\n                        [style.color]=\"getTextColor(data?.styles?.background?.color)\"\n                        (ngModelChange)=\"pincode.toString().length != 6 ? submit = false : error = false;\" />\n                </div>\n                <div (click)=\"getDataWithPincode()\" class=\"f-13 cursor-pointer\">Submit</div>\n            </div>\n            <span class=\"f-12 w-25 text-start mt-2\" *ngIf=\"error\" [style.color]=\"'#dc3545'\">Invalid Pincode\n                (Ex:500088)</span>\n        </div>\n        <div class=\"bottom-container row mx-auto mt-3\">\n            <div class=\"state-container row gap-3 justify-content-center mb-5\" *ngIf=\"showState && !pincode\">\n                <ng-container *ngFor=\"let state of stateList; let i = index\">\n                    <div class=\"state-card p-2 col-sm-6\" (click)=\"setStateData(state)\">\n                        <ng-container *ngIf=\"state?.stateImage; else noImage\">\n                            <img class=\"w-100 h-75\" [src]=\"state?.stateImage\">\n                        </ng-container>\n                        <ng-template #noImage>\n                            <img class=\"w-100 h-75\"\n                                src=\"https://cdn.caratlane.com/media/static/images/Find_In_Store/city_5.svg\">\n                        </ng-template>\n                        <div class=\"text-center mt-2 state-name\">{{state?.stateName}}</div>\n                        <div class=\"store-count text-center mb-3 mt-1\">{{state?.storeCount + \" stores\"}}</div>\n                    </div>\n                </ng-container>\n            </div>\n            <div class=\"w-100 d-flex align-items-center justify-content-center mb-3\"\n                *ngIf=\"submit && showMessage == false && pincode && pincode.toString().length ==6 && !loader\">\n                <div class=\"text-center not-available-text\">We are not available in this location currently</div>\n            </div>\n            <ng-container *ngIf=\"loader\">\n                <div class=\"sub-text w-100 text-center\">\n                    <ngx-skeleton-loader [theme]=\"{\n                width: '35%',\n                height: '6vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                </div>\n            </ng-container>\n            <div class=\"bottom-sub-text d-flex align-items-center justify-content-center mb-3 w-100 f-20 fw-bold\"> {{\n                submit &&\n                showMessage == true && pincode ? \"Showing \" + totalCount + \" Stores in \" + pincode :\n                \"Showing All Stores\"}}</div>\n            <ng-container *ngIf=\"!loader;else loaderScreen\">\n                <div class=\"row d-flex\">\n                    <div class=\"col-4 p-2 store d-flex flex-column \" style=\"border-radius: 12px; border: none;\"\n                        *ngFor=\"let ele of storesList; let i = index\">\n                        <div class=\"card-body position-relative d-flex flex-column  h-100\">\n                            <!-- Content -->\n                            <div class=\"h-100  p-3 pb-0\">\n                                <div class=\"d-flex justify-content-between align-items-start mb-2\">\n                                    <div class=\"d-flex flex-column mb-2 bb-1 w-100 pb-2\">\n                                        <h6 class=\"card-title fw-bold mb-1 w-100\">{{ele?.storeName}}</h6>\n                                        <div class=\"f-11\">\n                                            ⭐4.{{ele?.star}} &nbsp;&#x2022;&nbsp;{{ele?.reviewCount}}&nbsp;Google Reviews\n                                        </div>\n                                    </div>\n                                </div>\n                                <div class=\"mb-2 f-11\">\n                                    <p class=\"mb-1 text-dark fw-medium\">{{ele?.addressDetails?.addressLine}},</p>\n                                    <p class=\"mb-1 text-dark fw-medium\">\n                                        {{ele?.addressDetails?.city}},\n                                        {{ele?.addressDetails?.state}},{{ele?.addressDetails?.pincode}},\n                                    </p>\n                                    <p class=\"mb-0 fw-bold\">Phone-\n                                        <span\n                                            [style.color]=\"data?.styles?.background?.accentColor\">{{ele?.storeContactDetails?.mobile}}</span>\n                                    </p>\n                                </div>\n                                <div class=\"mb-2 f-11\">\n                                    <p class=\"mb-0  fw-bold\" [style.color]=\"data?.styles?.background?.accentColor\">\n                                        STORE HOURS -\n                                        {{getTime(ele?.storeHours,'OPEN')}} to {{getTime(ele?.storeHours,'CLOSE')}}\n                                    </p>\n                                </div>\n                            </div>\n                            <!-- Fixed bottom buttons -->\n                            <div class=\"d-flex gap-3 align-items-center justify-content-between  p-3 w-100 br-20\" [style.backgroundColor]=\"getRGBA(styles?.background?.accentColor,10)\">\n                                <div class=\"br-12 d-flex align-items-center justify-content-center\"\n                                    style=\"width: 30px; height: 30px;\" (click)=\"openWhatsapp(ele?.storeContactDetails?.mobile)\"\n                                    [style.backgroundColor]=\"data?.styles?.background?.accentColor\">\n                                    <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 448 512\" style=\"height: 20px;cursor: pointer;\">\n                                        <path [attr.fill]=\"getTextColor(data?.styles?.background?.accentColor)\"\n                                            d=\"M380.9 97.1c-41.9-42-97.7-65.1-157-65.1-122.4 0-222 99.6-222 222 0 39.1 10.2 77.3 29.6 111L0 480 117.7 449.1c32.4 17.7 68.9 27 106.1 27l.1 0c122.3 0 224.1-99.6 224.1-222 0-59.3-25.2-115-67.1-157zm-157 341.6c-33.2 0-65.7-8.9-94-25.7l-6.7-4-69.8 18.3 18.6-68.1-4.4-7c-18.5-29.4-28.2-63.3-28.2-98.2 0-101.7 82.8-184.5 184.6-184.5 49.3 0 95.6 19.2 130.4 54.1s56.2 81.2 56.1 130.5c0 101.8-84.9 184.6-186.6 184.6zM325.1 300.5c-5.5-2.8-32.8-16.2-37.9-18-5.1-1.9-8.8-2.8-12.5 2.8s-14.3 18-17.6 21.8c-3.2 3.7-6.5 4.2-12 1.4-32.6-16.3-54-29.1-75.5-66-5.7-9.8 5.7-9.1 16.3-30.3 1.8-3.7 .9-6.9-.5-9.7s-12.5-30.1-17.1-41.2c-4.5-10.8-9.1-9.3-12.5-9.5-3.2-.2-6.9-.2-10.6-.2s-9.7 1.4-14.8 6.9c-5.1 5.6-19.4 19-19.4 46.3s19.9 53.7 22.6 57.4c2.8 3.7 39.1 59.7 94.8 83.8 35.2 15.2 49 16.5 66.6 13.9 10.7-1.6 32.8-13.4 37.4-26.4s4.6-24.1 3.2-26.4c-1.3-2.5-5-3.9-10.5-6.6z\" />\n                                    </svg>\n                                </div>\n                                <button class=\"btn w-50\" [buttonData]=\"button?.content\" [buttonStyle]=\"button?.styles\"\n                                    simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\"\n                                    [color]=\"data?.styles?.background?.accentColor\"\n                                    [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\"\n                                    [buttonId]=\"button?.id ?? ''\" (click)=\"viewStore(ele.id)\">\n                                    {{button?.content?.label}}\n                                </button>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n\n            </ng-container>\n            <ng-template #loaderScreen>\n                <div class=\"row loader-container\">\n                    <ng-container *ngFor=\"let ele of [1,2,3,4,5,6]\">\n                        <ngx-skeleton-loader class=\"col-4 loader-column\" [theme]=\"{\n                width: '100%',\n                height: '40vh',\n               'border-radius': '12px',\n                 }\"></ngx-skeleton-loader>\n                    </ng-container>\n                </div>\n            </ng-template>\n        </div>\n    </div>\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n        <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n    </div>\n\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n        <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n    </div>\n</div>"]}
@@ -47,15 +47,12 @@ export class PricingS1Component extends BaseSection {
47
47
  else if (this.content?.listItem?.data?.length === 3) {
48
48
  return 'col-4';
49
49
  }
50
- else if (this.content?.listItem?.data?.length === 4) {
51
- return 'col-3';
52
- }
53
50
  else {
54
- return 'col-3';
51
+ return 'col-4';
55
52
  }
56
53
  }
57
54
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PricingS1Component, deps: [{ token: i1.EventsService }], target: i0.ɵɵFactoryTarget.Component }); }
58
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PricingS1Component, isStandalone: true, selector: "simpo-pricing-s1", inputs: { data: "data", edit: "edit" }, usesInheritance: true, ngImport: i0, template: "<section>\n <div class=\"pricing-options row w-100\">\n <div class=\"individual-options d-flex flex-column justify-content-between mt-4 mb-2 align-items-center\" [attr.class]=\"getClass()\"\n [id]=\"data?.id\" [simpoCorner]=\"style?.corners\" [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\"\n *ngFor=\"let options of content?.listItem?.data\" [ngClass]=\"{'highlighted-option': options?.highlight?.highlighted === true,\n 'individual-options-3': content?.listItem?.data?.length === 3 || content?.listItem?.data?.length === 2}\"\n [ngStyle]=\"{'border': options?.highlight?.highlighted === true ? '3px solid ' + data?.styles?.background?.accentColor : ''}\">\n <div class=\"popular-tag\" [simpoCorner]=\"style?.corners\"\n [ngStyle]=\"{'background-color': data?.styles?.background?.accentColor}\"\n *ngIf=\"options?.highlight?.highlighted === true\">\n <simpo-text-editor [(value)]=\"options.highlight.label\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div>\n <img loading=\"lazy\" class=\"logo-img\" *ngIf=\"content?.display?.showImage === true\"\n [simpoImageDirective]=\"style?.image\" [id]=\"data?.id\" [simpoObjectPosition]=\"options.image.position\"\n [simpoCorner]=\"style?.corners\" [src]=\"options.image.url \" alt=\"\" loading=\"lazy\"\n [appImageEditor]=\"edit || false\" [imageData]=\"options?.image\" [sectionId]=\"data?.id\"\n [class]=\"data?.id+(options?.image?.id || '')\">\n <div class=\"heading-small\">\n <simpo-text-editor [(value)]=\"options.inputText[0].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"heading-large price\">\n <simpo-text-editor [(value)]=\"options.inputText[2].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc mb-3\">\n <simpo-text-editor [(value)]=\"options.inputText[3].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc content-options\" *ngIf=\"content?.display?.showIncludeditems\">\n <div class=\"d-flex gap-15\" *ngFor=\"let content of options.additionalData\">\n <div class=\"d-flex align-items-center\">\n <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#EEF0FC\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M17.0965 7.39004L9.9365 14.3L8.0365 12.27C7.6865 11.94 7.1365 11.92 6.7365 12.2C6.3465 12.49 6.2365 13 6.4765 13.41L8.7265 17.07C8.9465 17.41 9.3265 17.62 9.7565 17.62C10.1665 17.62 10.5565 17.41 10.7765 17.07C11.1365 16.6 18.0065 8.41004 18.0065 8.41004C18.9065 7.49004 17.8165 6.68004 17.0965 7.38004V7.39004Z\"\n fill=\"#4C63D9\" />\n </svg> -->\n </div>\n <simpo-text-editor [(value)]=\"content.content\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n </div>\n </div>\n <div class=\"btn w-75 mt-4 p-0 border-0\" *ngIf=\"content?.display?.showButton === true\">\n <!-- <button class=\"button\" simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [buttonStyle]=\"button?.styles\" [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"style?.background\">{{options?.button?.label}}</button> -->\n <button class=\"custom-btn\" [buttonData]=\"options?.button\" [buttonStyle]=\"button?.styles\" simpoButtonDirective\n [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"getButtonId()\"\n (click)=\"redirectTo()\">{{options?.button?.label}}</button>\n </div>\n </div>\n </div>\n</section>", styles: [".pricing-options{justify-content:center;gap:20px}.individual-options{border:1px solid #80808057;padding:24px 10px}.individual-options-3{width:32%}.highlighted-option{box-shadow:0 0 10px #0000004d}.logo-img{width:85px;height:85px;margin-top:1rem}.img_icon{width:25px;height:25px}.button{font-size:17px!important;padding:.75rem 0}.custom-btn{padding:6px;font-size:16px!important;font-weight:600}.popular-tag{position:absolute;top:-1px;right:-2px;padding:1px 20px 3px;border-top-left-radius:0!important;border-bottom-right-radius:0!important}@media only screen and (max-width: 475px){.pricing-options{flex-direction:column}.individual-options{width:100%;margin-top:1rem;margin-bottom:1rem;padding:2rem}}\n"], dependencies: [{ kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable", "sectionId", "label"], outputs: ["valueChange"] }, { kind: "directive", type: ButtonDirectiveDirective, selector: "[simpoButtonDirective]", inputs: ["buttonStyle", "color", "scrollValue", "backgroundInfo"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: ImageEditorDirective, selector: "[appImageEditor]", inputs: ["appImageEditor", "imageData", "sectionId", "showIcon", "iconData"] }, { kind: "directive", type: ImageDirectiveDirective, selector: "[simpoImageDirective]", inputs: ["simpoImageDirective"] }, { kind: "directive", type: ObjectPositionDirective, selector: "[simpoObjectPosition]", inputs: ["simpoObjectPosition"] }, { kind: "directive", type: ButtonEditorDirective, selector: "button[appButtonEditor]", inputs: ["appButtonEditor", "buttonData", "buttonStyle", "backgroundInfo", "sectionId", "buttonId"] }, { kind: "directive", type: TranslateOnhoverDirective, selector: "[simpoTranslateOnhover]", inputs: ["simpoTranslateOnhover"] }] }); }
55
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PricingS1Component, isStandalone: true, selector: "simpo-pricing-s1", inputs: { data: "data", edit: "edit" }, usesInheritance: true, ngImport: i0, template: "<section>\n <div class=\"pricing-options row w-100\">\n <div\n [id]=\"data?.id\" [simpoCorner]=\"style?.corners\"\n [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" *ngFor=\"let options of content?.listItem?.data\"\n [attr.class]=\"getClass() + ' position-relative individual-options mb-2'\"\n [ngClass]=\"{'highlighted-option': options?.highlight?.highlighted === true}\"\n [ngStyle]=\"{'border': options?.highlight?.highlighted ? '3px solid ' + data?.styles?.background?.accentColor : ''}\">\n <div class=\"popular-tag\" [simpoCorner]=\"style?.corners\"\n [ngStyle]=\"{'background-color': data?.styles?.background?.accentColor}\"\n *ngIf=\"options?.highlight?.highlighted === true\">\n <simpo-text-editor [(value)]=\"options.highlight.label\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div>\n <img loading=\"lazy\" class=\"logo-img\" *ngIf=\"content?.display?.showImage === true\" [id]=\"data?.id\"\n [simpoObjectPosition]=\"options.image.position\" [simpoCorner]=\"style?.corners\" [src]=\"options.image.url \"\n alt=\"\" loading=\"lazy\" [appImageEditor]=\"edit || false\" [imageData]=\"options?.image\" [sectionId]=\"data?.id\"\n [class]=\"data?.id+(options?.image?.id || '')\">\n <div class=\"heading-small\">\n <simpo-text-editor [(value)]=\"options.inputText[0].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"heading-large price\">\n <simpo-text-editor [(value)]=\"options.inputText[2].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc description\" *ngIf=\"content?.display?.showContent === true\">\n <simpo-text-editor [(value)]=\"options.inputText[1].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc mb-3\">\n <simpo-text-editor [(value)]=\"options.inputText[3].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc content-options\" *ngIf=\"content?.display?.showIncludeditems\">\n <div class=\"d-flex gap-15\" *ngFor=\"let content of options.additionalData\">\n <div class=\"d-flex align-items-center\">\n <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#EEF0FC\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M17.0965 7.39004L9.9365 14.3L8.0365 12.27C7.6865 11.94 7.1365 11.92 6.7365 12.2C6.3465 12.49 6.2365 13 6.4765 13.41L8.7265 17.07C8.9465 17.41 9.3265 17.62 9.7565 17.62C10.1665 17.62 10.5565 17.41 10.7765 17.07C11.1365 16.6 18.0065 8.41004 18.0065 8.41004C18.9065 7.49004 17.8165 6.68004 17.0965 7.38004V7.39004Z\"\n fill=\"#4C63D9\" />\n </svg> -->\n </div>\n <simpo-text-editor [(value)]=\"content.content\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n </div>\n </div>\n <div class=\"btn mt-4 p-0 border-0\" *ngIf=\"content?.display?.showButton === true\">\n <!-- <button class=\"button\" simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [buttonStyle]=\"button?.styles\" [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"style?.background\">{{options?.button?.label}}</button> -->\n <button class=\"custom-btn d-flex gap-1\" [buttonData]=\"options?.button\" [buttonStyle]=\"button?.styles\"\n simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\"\n [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"data?.styles?.background\"\n [appButtonEditor]=\"edit ?? false\" [buttonId]=\"getButtonId()\" (click)=\"redirectTo()\"\n [class.flex-row-reverse]=\"options?.button?.icon?.iconPosition === 'left'\">\n <div>{{options?.button?.label}}</div>\n <div class=\"btn-icon\" *ngIf=\"options?.button?.showIcon\" [ngStyle]=\"{\n 'background': button?.styles?.type == 'Text' ? button?.styles?.background : button?.styles?.textColor,\n 'mask-image': 'url(' + options?.button?.icon?.url + ')',\n 'mask-repeat': 'no-repeat',\n 'mask-size': 'cover',\n 'width': '25px',\n 'height': '25px',\n }\"></div>\n </button>\n </div>\n </div>\n </div>\n</section>", styles: [".pricing-options{justify-content:center;gap:15px}.individual-options{border:1px solid #80808057}.highlighted-option{box-shadow:0 0 10px #0000004d}.logo-img{width:85px;height:85px;margin-top:1rem}.img_icon{width:25px;height:25px}.button{font-size:17px!important;padding:.75rem 0}.custom-btn{padding:6px;font-size:16px!important;font-weight:600}.popular-tag{position:absolute;top:0;right:-2px;padding:1px 20px 3px;border-top-left-radius:0!important;border-bottom-right-radius:0!important}@media only screen and (max-width: 475px){.pricing-options{flex-direction:column}.individual-options{width:100%;margin-top:1rem;margin-bottom:1rem;padding:2rem}}.col-4{width:30%!important}\n"], dependencies: [{ kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable", "sectionId", "label"], outputs: ["valueChange"] }, { kind: "directive", type: ButtonDirectiveDirective, selector: "[simpoButtonDirective]", inputs: ["buttonStyle", "color", "scrollValue", "backgroundInfo"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: ImageEditorDirective, selector: "[appImageEditor]", inputs: ["appImageEditor", "imageData", "sectionId", "showIcon", "iconData"] }, { kind: "directive", type: ObjectPositionDirective, selector: "[simpoObjectPosition]", inputs: ["simpoObjectPosition"] }, { kind: "directive", type: ButtonEditorDirective, selector: "button[appButtonEditor]", inputs: ["appButtonEditor", "buttonData", "buttonStyle", "backgroundInfo", "sectionId", "buttonId"] }, { kind: "directive", type: TranslateOnhoverDirective, selector: "[simpoTranslateOnhover]", inputs: ["simpoTranslateOnhover"] }] }); }
59
56
  }
60
57
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PricingS1Component, decorators: [{
61
58
  type: Component,
@@ -71,10 +68,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
71
68
  SimpoButtonComponent,
72
69
  ButtonEditorDirective,
73
70
  TranslateOnhoverDirective
74
- ], template: "<section>\n <div class=\"pricing-options row w-100\">\n <div class=\"individual-options d-flex flex-column justify-content-between mt-4 mb-2 align-items-center\" [attr.class]=\"getClass()\"\n [id]=\"data?.id\" [simpoCorner]=\"style?.corners\" [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\"\n *ngFor=\"let options of content?.listItem?.data\" [ngClass]=\"{'highlighted-option': options?.highlight?.highlighted === true,\n 'individual-options-3': content?.listItem?.data?.length === 3 || content?.listItem?.data?.length === 2}\"\n [ngStyle]=\"{'border': options?.highlight?.highlighted === true ? '3px solid ' + data?.styles?.background?.accentColor : ''}\">\n <div class=\"popular-tag\" [simpoCorner]=\"style?.corners\"\n [ngStyle]=\"{'background-color': data?.styles?.background?.accentColor}\"\n *ngIf=\"options?.highlight?.highlighted === true\">\n <simpo-text-editor [(value)]=\"options.highlight.label\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div>\n <img loading=\"lazy\" class=\"logo-img\" *ngIf=\"content?.display?.showImage === true\"\n [simpoImageDirective]=\"style?.image\" [id]=\"data?.id\" [simpoObjectPosition]=\"options.image.position\"\n [simpoCorner]=\"style?.corners\" [src]=\"options.image.url \" alt=\"\" loading=\"lazy\"\n [appImageEditor]=\"edit || false\" [imageData]=\"options?.image\" [sectionId]=\"data?.id\"\n [class]=\"data?.id+(options?.image?.id || '')\">\n <div class=\"heading-small\">\n <simpo-text-editor [(value)]=\"options.inputText[0].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"heading-large price\">\n <simpo-text-editor [(value)]=\"options.inputText[2].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc mb-3\">\n <simpo-text-editor [(value)]=\"options.inputText[3].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc content-options\" *ngIf=\"content?.display?.showIncludeditems\">\n <div class=\"d-flex gap-15\" *ngFor=\"let content of options.additionalData\">\n <div class=\"d-flex align-items-center\">\n <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#EEF0FC\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M17.0965 7.39004L9.9365 14.3L8.0365 12.27C7.6865 11.94 7.1365 11.92 6.7365 12.2C6.3465 12.49 6.2365 13 6.4765 13.41L8.7265 17.07C8.9465 17.41 9.3265 17.62 9.7565 17.62C10.1665 17.62 10.5565 17.41 10.7765 17.07C11.1365 16.6 18.0065 8.41004 18.0065 8.41004C18.9065 7.49004 17.8165 6.68004 17.0965 7.38004V7.39004Z\"\n fill=\"#4C63D9\" />\n </svg> -->\n </div>\n <simpo-text-editor [(value)]=\"content.content\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n </div>\n </div>\n <div class=\"btn w-75 mt-4 p-0 border-0\" *ngIf=\"content?.display?.showButton === true\">\n <!-- <button class=\"button\" simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [buttonStyle]=\"button?.styles\" [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"style?.background\">{{options?.button?.label}}</button> -->\n <button class=\"custom-btn\" [buttonData]=\"options?.button\" [buttonStyle]=\"button?.styles\" simpoButtonDirective\n [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"getButtonId()\"\n (click)=\"redirectTo()\">{{options?.button?.label}}</button>\n </div>\n </div>\n </div>\n</section>", styles: [".pricing-options{justify-content:center;gap:20px}.individual-options{border:1px solid #80808057;padding:24px 10px}.individual-options-3{width:32%}.highlighted-option{box-shadow:0 0 10px #0000004d}.logo-img{width:85px;height:85px;margin-top:1rem}.img_icon{width:25px;height:25px}.button{font-size:17px!important;padding:.75rem 0}.custom-btn{padding:6px;font-size:16px!important;font-weight:600}.popular-tag{position:absolute;top:-1px;right:-2px;padding:1px 20px 3px;border-top-left-radius:0!important;border-bottom-right-radius:0!important}@media only screen and (max-width: 475px){.pricing-options{flex-direction:column}.individual-options{width:100%;margin-top:1rem;margin-bottom:1rem;padding:2rem}}\n"] }]
71
+ ], template: "<section>\n <div class=\"pricing-options row w-100\">\n <div\n [id]=\"data?.id\" [simpoCorner]=\"style?.corners\"\n [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" *ngFor=\"let options of content?.listItem?.data\"\n [attr.class]=\"getClass() + ' position-relative individual-options mb-2'\"\n [ngClass]=\"{'highlighted-option': options?.highlight?.highlighted === true}\"\n [ngStyle]=\"{'border': options?.highlight?.highlighted ? '3px solid ' + data?.styles?.background?.accentColor : ''}\">\n <div class=\"popular-tag\" [simpoCorner]=\"style?.corners\"\n [ngStyle]=\"{'background-color': data?.styles?.background?.accentColor}\"\n *ngIf=\"options?.highlight?.highlighted === true\">\n <simpo-text-editor [(value)]=\"options.highlight.label\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div>\n <img loading=\"lazy\" class=\"logo-img\" *ngIf=\"content?.display?.showImage === true\" [id]=\"data?.id\"\n [simpoObjectPosition]=\"options.image.position\" [simpoCorner]=\"style?.corners\" [src]=\"options.image.url \"\n alt=\"\" loading=\"lazy\" [appImageEditor]=\"edit || false\" [imageData]=\"options?.image\" [sectionId]=\"data?.id\"\n [class]=\"data?.id+(options?.image?.id || '')\">\n <div class=\"heading-small\">\n <simpo-text-editor [(value)]=\"options.inputText[0].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"heading-large price\">\n <simpo-text-editor [(value)]=\"options.inputText[2].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc description\" *ngIf=\"content?.display?.showContent === true\">\n <simpo-text-editor [(value)]=\"options.inputText[1].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc mb-3\">\n <simpo-text-editor [(value)]=\"options.inputText[3].value\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n <div class=\"body-desc content-options\" *ngIf=\"content?.display?.showIncludeditems\">\n <div class=\"d-flex gap-15\" *ngFor=\"let content of options.additionalData\">\n <div class=\"d-flex align-items-center\">\n <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#EEF0FC\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M17.0965 7.39004L9.9365 14.3L8.0365 12.27C7.6865 11.94 7.1365 11.92 6.7365 12.2C6.3465 12.49 6.2365 13 6.4765 13.41L8.7265 17.07C8.9465 17.41 9.3265 17.62 9.7565 17.62C10.1665 17.62 10.5565 17.41 10.7765 17.07C11.1365 16.6 18.0065 8.41004 18.0065 8.41004C18.9065 7.49004 17.8165 6.68004 17.0965 7.38004V7.39004Z\"\n fill=\"#4C63D9\" />\n </svg> -->\n </div>\n <simpo-text-editor [(value)]=\"content.content\" [editable]=\"edit || false\"></simpo-text-editor>\n </div>\n </div>\n </div>\n <div class=\"btn mt-4 p-0 border-0\" *ngIf=\"content?.display?.showButton === true\">\n <!-- <button class=\"button\" simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [buttonStyle]=\"button?.styles\" [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"style?.background\">{{options?.button?.label}}</button> -->\n <button class=\"custom-btn d-flex gap-1\" [buttonData]=\"options?.button\" [buttonStyle]=\"button?.styles\"\n simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\"\n [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"data?.styles?.background\"\n [appButtonEditor]=\"edit ?? false\" [buttonId]=\"getButtonId()\" (click)=\"redirectTo()\"\n [class.flex-row-reverse]=\"options?.button?.icon?.iconPosition === 'left'\">\n <div>{{options?.button?.label}}</div>\n <div class=\"btn-icon\" *ngIf=\"options?.button?.showIcon\" [ngStyle]=\"{\n 'background': button?.styles?.type == 'Text' ? button?.styles?.background : button?.styles?.textColor,\n 'mask-image': 'url(' + options?.button?.icon?.url + ')',\n 'mask-repeat': 'no-repeat',\n 'mask-size': 'cover',\n 'width': '25px',\n 'height': '25px',\n }\"></div>\n </button>\n </div>\n </div>\n </div>\n</section>", styles: [".pricing-options{justify-content:center;gap:15px}.individual-options{border:1px solid #80808057}.highlighted-option{box-shadow:0 0 10px #0000004d}.logo-img{width:85px;height:85px;margin-top:1rem}.img_icon{width:25px;height:25px}.button{font-size:17px!important;padding:.75rem 0}.custom-btn{padding:6px;font-size:16px!important;font-weight:600}.popular-tag{position:absolute;top:0;right:-2px;padding:1px 20px 3px;border-top-left-radius:0!important;border-bottom-right-radius:0!important}@media only screen and (max-width: 475px){.pricing-options{flex-direction:column}.individual-options{width:100%;margin-top:1rem;margin-bottom:1rem;padding:2rem}}.col-4{width:30%!important}\n"] }]
75
72
  }], ctorParameters: () => [{ type: i1.EventsService }], propDecorators: { data: [{
76
73
  type: Input
77
74
  }], edit: [{
78
75
  type: Input
79
76
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pricing-s1.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/pricing-s1/pricing-s1.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/pricing-s1/pricing-s1.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport BaseSection from '../../sections/BaseSection';\nimport { PricingSectionContentModal, PricingSectionModal, PricingSectionStylesModel } from '../../sections/pricing-section/pricing-section.modal';\nimport { ButtonModel } from '../../styles/style.model';\nimport { TextEditorComponent } from '../text-editor/text-editor.component';\nimport { ButtonDirectiveDirective } from '../../directive/button-directive.directive';\nimport { ColorDirective } from '../../directive/color.directive';\nimport { CornerDirective } from '../../directive/corner-directive';\nimport { CommonModule } from '@angular/common';\nimport { EventsService } from '../../services/events.service';\nimport { ImageDirectiveDirective } from '../../directive/image-directive.directive';\nimport { ObjectPositionDirective } from '../../directive/image-position.directive';\nimport { ImageEditorDirective } from '../../directive/image-editor.directive';\nimport { SimpoButtonComponent } from '../simpo-button/simpo-button.component';\nimport { ButtonEditorDirective } from '../../directive/button-editor.directive';\nimport { TranslateOnhoverDirective } from '../../directive/translate-onhover.directive';\n\n@Component({\n  selector: 'simpo-pricing-s1',\n  standalone: true,\n  imports: [\n    TextEditorComponent,\n    ButtonDirectiveDirective,\n    ColorDirective,\n    CornerDirective,\n    CommonModule,\n    ImageEditorDirective,\n    ImageDirectiveDirective,\n    ObjectPositionDirective,\n    SimpoButtonComponent,\n    ButtonEditorDirective,\n    TranslateOnhoverDirective\n\n  ],\n  templateUrl: './pricing-s1.component.html',\n  styleUrl: './pricing-s1.component.css'\n})\nexport class PricingS1Component extends BaseSection {\n  @Input() data?: PricingSectionModal;\n  @Input() edit?: boolean;\n  content?: PricingSectionContentModal;\n  style?: PricingSectionStylesModel;\n  button?: ButtonModel;\n\n  constructor(private _eventService: EventsService) {\n    super();\n  }\n\n  ngOnInit() {\n    this.content = this.data?.content;\n    this.style = this.data?.styles;\n    this.button = this.data?.action.buttons[0];\n  }\n\n  editSection() {\n\n    if (window.innerWidth <= 475)\n      return\n    this._eventService.toggleEditorEvent.emit(false);\n    setTimeout(() => {\n      this._eventService.editSection.emit({ data: this.data });\n    }, 100);\n  }\n  getButtonId() {\n    return this.button?.id ?? \"\"\n  }\n  redirectTo() {\n  }\n  getClass() {\n    if (this.content?.listItem?.data?.length === 1) {\n      return 'col-12';\n    } else if (this.content?.listItem?.data?.length === 2) {\n      return 'col-5';\n    } else if (this.content?.listItem?.data?.length === 3) {\n      return 'col-4';\n    } else if (this.content?.listItem?.data?.length === 4) {\n      return 'col-3';\n    } else {\n      return 'col-3';\n    }\n\n  }\n}\n","<section>\n  <div class=\"pricing-options row w-100\">\n    <div class=\"individual-options d-flex flex-column justify-content-between mt-4 mb-2 align-items-center\" [attr.class]=\"getClass()\"\n      [id]=\"data?.id\" [simpoCorner]=\"style?.corners\" [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\"\n      *ngFor=\"let options of content?.listItem?.data\" [ngClass]=\"{'highlighted-option': options?.highlight?.highlighted === true,\n          'individual-options-3': content?.listItem?.data?.length === 3 || content?.listItem?.data?.length === 2}\"\n      [ngStyle]=\"{'border': options?.highlight?.highlighted === true ? '3px solid ' + data?.styles?.background?.accentColor : ''}\">\n      <div class=\"popular-tag\" [simpoCorner]=\"style?.corners\"\n        [ngStyle]=\"{'background-color': data?.styles?.background?.accentColor}\"\n        *ngIf=\"options?.highlight?.highlighted === true\">\n        <simpo-text-editor [(value)]=\"options.highlight.label\" [editable]=\"edit || false\"></simpo-text-editor>\n      </div>\n      <div>\n        <img loading=\"lazy\" class=\"logo-img\" *ngIf=\"content?.display?.showImage === true\"\n          [simpoImageDirective]=\"style?.image\" [id]=\"data?.id\" [simpoObjectPosition]=\"options.image.position\"\n          [simpoCorner]=\"style?.corners\" [src]=\"options.image.url \" alt=\"\" loading=\"lazy\"\n          [appImageEditor]=\"edit || false\" [imageData]=\"options?.image\" [sectionId]=\"data?.id\"\n          [class]=\"data?.id+(options?.image?.id || '')\">\n        <div class=\"heading-small\">\n          <simpo-text-editor [(value)]=\"options.inputText[0].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"heading-large price\">\n          <simpo-text-editor [(value)]=\"options.inputText[2].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"body-desc mb-3\">\n          <simpo-text-editor [(value)]=\"options.inputText[3].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"body-desc content-options\" *ngIf=\"content?.display?.showIncludeditems\">\n          <div class=\"d-flex gap-15\" *ngFor=\"let content of options.additionalData\">\n            <div class=\"d-flex align-items-center\">\n              <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#EEF0FC\" />\n                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                  d=\"M17.0965 7.39004L9.9365 14.3L8.0365 12.27C7.6865 11.94 7.1365 11.92 6.7365 12.2C6.3465 12.49 6.2365 13 6.4765 13.41L8.7265 17.07C8.9465 17.41 9.3265 17.62 9.7565 17.62C10.1665 17.62 10.5565 17.41 10.7765 17.07C11.1365 16.6 18.0065 8.41004 18.0065 8.41004C18.9065 7.49004 17.8165 6.68004 17.0965 7.38004V7.39004Z\"\n                  fill=\"#4C63D9\" />\n              </svg> -->\n            </div>\n            <simpo-text-editor [(value)]=\"content.content\" [editable]=\"edit || false\"></simpo-text-editor>\n          </div>\n        </div>\n      </div>\n      <div class=\"btn w-75 mt-4 p-0 border-0\" *ngIf=\"content?.display?.showButton === true\">\n        <!-- <button class=\"button\" simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [buttonStyle]=\"button?.styles\" [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"style?.background\">{{options?.button?.label}}</button> -->\n        <button class=\"custom-btn\" [buttonData]=\"options?.button\" [buttonStyle]=\"button?.styles\" simpoButtonDirective\n          [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\" [color]=\"data?.styles?.background?.accentColor\"\n          [backgroundInfo]=\"data?.styles?.background\" [appButtonEditor]=\"edit ?? false\" [buttonId]=\"getButtonId()\"\n          (click)=\"redirectTo()\">{{options?.button?.label}}</button>\n      </div>\n    </div>\n  </div>\n</section>"]}
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pricing-s1.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/pricing-s1/pricing-s1.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/pricing-s1/pricing-s1.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport BaseSection from '../../sections/BaseSection';\nimport { PricingSectionContentModal, PricingSectionModal, PricingSectionStylesModel } from '../../sections/pricing-section/pricing-section.modal';\nimport { ButtonModel } from '../../styles/style.model';\nimport { TextEditorComponent } from '../text-editor/text-editor.component';\nimport { ButtonDirectiveDirective } from '../../directive/button-directive.directive';\nimport { ColorDirective } from '../../directive/color.directive';\nimport { CornerDirective } from '../../directive/corner-directive';\nimport { CommonModule } from '@angular/common';\nimport { EventsService } from '../../services/events.service';\nimport { ImageDirectiveDirective } from '../../directive/image-directive.directive';\nimport { ObjectPositionDirective } from '../../directive/image-position.directive';\nimport { ImageEditorDirective } from '../../directive/image-editor.directive';\nimport { SimpoButtonComponent } from '../simpo-button/simpo-button.component';\nimport { ButtonEditorDirective } from '../../directive/button-editor.directive';\nimport { TranslateOnhoverDirective } from '../../directive/translate-onhover.directive';\n\n@Component({\n  selector: 'simpo-pricing-s1',\n  standalone: true,\n  imports: [\n    TextEditorComponent,\n    ButtonDirectiveDirective,\n    ColorDirective,\n    CornerDirective,\n    CommonModule,\n    ImageEditorDirective,\n    ImageDirectiveDirective,\n    ObjectPositionDirective,\n    SimpoButtonComponent,\n    ButtonEditorDirective,\n    TranslateOnhoverDirective\n\n  ],\n  templateUrl: './pricing-s1.component.html',\n  styleUrl: './pricing-s1.component.css'\n})\nexport class PricingS1Component extends BaseSection {\n  @Input() data?: PricingSectionModal;\n  @Input() edit?: boolean;\n  content?: PricingSectionContentModal;\n  style?: PricingSectionStylesModel;\n  button?: ButtonModel;\n\n  constructor(private _eventService: EventsService) {\n    super();\n  }\n\n  ngOnInit() {\n    this.content = this.data?.content;\n    this.style = this.data?.styles;\n    this.button = this.data?.action.buttons[0];\n  }\n\n  editSection() {\n\n    if (window.innerWidth <= 475)\n      return\n    this._eventService.toggleEditorEvent.emit(false);\n    setTimeout(() => {\n      this._eventService.editSection.emit({ data: this.data });\n    }, 100);\n  }\n  getButtonId() {\n    return this.button?.id ?? \"\"\n  }\n  redirectTo() {\n  }\n  getClass() {\n    if (this.content?.listItem?.data?.length === 1) {\n      return 'col-12';\n    } else if (this.content?.listItem?.data?.length === 2) {\n      return 'col-5';\n    } else if (this.content?.listItem?.data?.length === 3) {\n      return 'col-4';\n    } else {\n      return 'col-4';\n    }\n  }\n}\n","<section>\n  <div class=\"pricing-options row w-100\">\n    <div\n       [id]=\"data?.id\" [simpoCorner]=\"style?.corners\"\n      [simpoTranslateOnhover]=\"content?.display?.showHoverEffect\" *ngFor=\"let options of content?.listItem?.data\"\n      [attr.class]=\"getClass() + ' position-relative individual-options mb-2'\"\n      [ngClass]=\"{'highlighted-option': options?.highlight?.highlighted === true}\"\n      [ngStyle]=\"{'border': options?.highlight?.highlighted  ? '3px solid ' + data?.styles?.background?.accentColor : ''}\">\n      <div class=\"popular-tag\" [simpoCorner]=\"style?.corners\"\n        [ngStyle]=\"{'background-color': data?.styles?.background?.accentColor}\"\n        *ngIf=\"options?.highlight?.highlighted === true\">\n        <simpo-text-editor [(value)]=\"options.highlight.label\" [editable]=\"edit || false\"></simpo-text-editor>\n      </div>\n      <div>\n        <img loading=\"lazy\" class=\"logo-img\" *ngIf=\"content?.display?.showImage === true\" [id]=\"data?.id\"\n          [simpoObjectPosition]=\"options.image.position\" [simpoCorner]=\"style?.corners\" [src]=\"options.image.url \"\n          alt=\"\" loading=\"lazy\" [appImageEditor]=\"edit || false\" [imageData]=\"options?.image\" [sectionId]=\"data?.id\"\n          [class]=\"data?.id+(options?.image?.id || '')\">\n        <div class=\"heading-small\">\n          <simpo-text-editor [(value)]=\"options.inputText[0].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"heading-large price\">\n          <simpo-text-editor [(value)]=\"options.inputText[2].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"body-desc description\" *ngIf=\"content?.display?.showContent === true\">\n          <simpo-text-editor [(value)]=\"options.inputText[1].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"body-desc mb-3\">\n          <simpo-text-editor [(value)]=\"options.inputText[3].value\" [editable]=\"edit || false\"></simpo-text-editor>\n        </div>\n        <div class=\"body-desc content-options\" *ngIf=\"content?.display?.showIncludeditems\">\n          <div class=\"d-flex gap-15\" *ngFor=\"let content of options.additionalData\">\n            <div class=\"d-flex align-items-center\">\n              <!-- <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <rect width=\"24\" height=\"24\" rx=\"12\" fill=\"#EEF0FC\" />\n                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                  d=\"M17.0965 7.39004L9.9365 14.3L8.0365 12.27C7.6865 11.94 7.1365 11.92 6.7365 12.2C6.3465 12.49 6.2365 13 6.4765 13.41L8.7265 17.07C8.9465 17.41 9.3265 17.62 9.7565 17.62C10.1665 17.62 10.5565 17.41 10.7765 17.07C11.1365 16.6 18.0065 8.41004 18.0065 8.41004C18.9065 7.49004 17.8165 6.68004 17.0965 7.38004V7.39004Z\"\n                  fill=\"#4C63D9\" />\n              </svg> -->\n            </div>\n            <simpo-text-editor [(value)]=\"content.content\" [editable]=\"edit || false\"></simpo-text-editor>\n          </div>\n        </div>\n      </div>\n      <div class=\"btn mt-4 p-0 border-0\" *ngIf=\"content?.display?.showButton === true\">\n        <!-- <button class=\"button\" simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [buttonStyle]=\"button?.styles\" [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"style?.background\">{{options?.button?.label}}</button> -->\n        <button class=\"custom-btn d-flex gap-1\" [buttonData]=\"options?.button\" [buttonStyle]=\"button?.styles\"\n          simpoButtonDirective [id]=\"data?.id+(button?.id || '')\" [sectionId]=\"data?.id\"\n          [color]=\"data?.styles?.background?.accentColor\" [backgroundInfo]=\"data?.styles?.background\"\n          [appButtonEditor]=\"edit ?? false\" [buttonId]=\"getButtonId()\" (click)=\"redirectTo()\"\n          [class.flex-row-reverse]=\"options?.button?.icon?.iconPosition === 'left'\">\n          <div>{{options?.button?.label}}</div>\n          <div class=\"btn-icon\" *ngIf=\"options?.button?.showIcon\" [ngStyle]=\"{\n            'background':  button?.styles?.type == 'Text' ? button?.styles?.background : button?.styles?.textColor,\n            'mask-image': 'url(' + options?.button?.icon?.url + ')',\n            'mask-repeat': 'no-repeat',\n            'mask-size': 'cover',\n            'width': '25px',\n            'height': '25px',\n          }\"></div>\n        </button>\n      </div>\n    </div>\n  </div>\n</section>"]}