simpo-component-library 3.6.473 → 3.6.475
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.
- package/esm2022/lib/components/hover-elements/hover-elements.component.mjs +1 -4
- package/esm2022/lib/directive/background-directive.mjs +6 -6
- package/esm2022/lib/ecommerce/sections/featured-products/featured-products.component.mjs +34 -3
- package/esm2022/lib/ecommerce/sections/order-details/order-details.component.mjs +7 -4
- package/esm2022/lib/ecommerce/sections/product-desc/product-desc.component.mjs +34 -3
- package/esm2022/lib/ecommerce/sections/product-list/product-list.component.mjs +34 -3
- package/esm2022/lib/ecommerce/sections/small-product-listing/small-product-listing.component.mjs +50 -10
- package/esm2022/lib/ecommerce/sections/store-list/store-list.component.mjs +3 -1
- package/esm2022/lib/ecommerce/sections/verify-payment/verify-payment.component.mjs +4 -2
- package/esm2022/lib/elements/pricing-s1/pricing-s1.component.mjs +4 -7
- package/esm2022/lib/elements/simpo-button/simpo-button.component.mjs +3 -3
- package/esm2022/lib/sections/pricing-section/pricing-section.component.mjs +3 -3
- package/esm2022/lib/sections/process-modern/process-modern.component.mjs +4 -4
- package/esm2022/lib/sections/scheme-detail/scheme-detail.component.mjs +7 -3
- package/esm2022/lib/sections/testimonial-section/testimonial-section.component.mjs +2 -2
- package/esm2022/lib/services/rest.service.mjs +4 -1
- package/fesm2022/simpo-component-library.mjs +188 -54
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/ecommerce/sections/featured-products/featured-products.component.d.ts +2 -0
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +3 -1
- package/lib/ecommerce/sections/product-list/product-list.component.d.ts +2 -0
- package/lib/ecommerce/sections/schemes/schemes.component.d.ts +1 -1
- package/lib/ecommerce/sections/small-product-listing/small-product-listing.component.d.ts +9 -1
- package/lib/elements/pricing-s1/pricing-s1.component.d.ts +1 -1
- package/lib/sections/banner-carousel/banner-carousel.component.d.ts +2 -2
- package/lib/sections/carousel-banner/carousel-banner.component.d.ts +1 -1
- package/lib/sections/contact-us/contact-us.component.d.ts +1 -1
- package/lib/sections/faq-section/faq-section.component.d.ts +1 -1
- package/lib/sections/image-section/image-section.component.d.ts +2 -2
- package/lib/sections/logo-showcase/logo-showcase.component.d.ts +2 -2
- package/lib/sections/new-testimonials/new-testimonials.component.d.ts +1 -1
- package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
- package/lib/services/rest.service.d.ts +1 -0
- package/package.json +1 -1
- package/simpo-component-library-3.6.475.tgz +0 -0
- package/simpo-component-library-3.6.473.tgz +0 -0
package/esm2022/lib/ecommerce/sections/small-product-listing/small-product-listing.component.mjs
CHANGED
@@ -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 "
|
14
|
-
import * as i4 from "
|
15
|
-
import * as i5 from "
|
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
|
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
|
-
|
145
|
-
|
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":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAEzD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAE/D,OAAO,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AAEpE,OAAO,EAAE,qBAAqB,EAAE,MAAM,2DAA2D,CAAC;AAClG,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAI7C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AAiB5C,MAAM,OAAO,4BAA4B;IAEvC,YACmB,WAAwB,EACxB,MAAc,EACd,WAAwB,EACxB,cAAqC,EACrC,cAA8B;QAJ9B,gBAAW,GAAX,WAAW,CAAa;QACxB,WAAM,GAAN,MAAM,CAAQ;QACd,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAuB;QACrC,mBAAc,GAAd,cAAc,CAAgB;QAGzC,cAAS,GAA0B,IAAI,CAAC;QAIvC,0BAAqB,GAAY,KAAK,CAAC;QAGhD,gBAAW,GAAY,KAAK,CAAC;QAsH7B,eAAU,GAAW,CAAC,CAAC,CAAC;IA/HpB,CAAC;IAUL,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IACpF,CAAC;IAED,aAAa,CAAC,KAAgC,EAAE,OAAgB,EAAE,IAAyB;QACzF,wCAAwC;QACxC,kJAAkJ;QAClJ,YAAY;QACZ,IAAI;QAEJ,IAAI,CAAC,OAAO,EAAE,QAAQ;YACpB,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACvB,IAAI,IAAI,IAAI,KAAK,EAAE,CAAC;YAClB,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;QACxB,CAAC;aACI,CAAC;YACJ,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;QACxB,CAAC;QAED,IAAI,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC;YACjC,MAAM,WAAW,GAAuB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;YACxF,IAAI,WAAW,EAAE,CAAC;gBAChB,WAAW,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;gBACxC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC1C,CAAC;QACD,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,SAAS,GAAY,KAAK,CAAC;YAC/B,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,IAAkB,EAAE,EAAE;gBAC7C,IAAI,IAAI,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;oBACxC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;oBACjC,SAAS,GAAG,IAAI,CAAC;gBACnB,CAAC;YACH,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,SAAS;gBACZ,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;QACvE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,IAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QAC7G,CAAC;QACD,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAED,aAAa,CAAC,KAAgC;QAC5C,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IACD,SAAS;QACP,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;QAClD,IAAI,OAAO,GAAG;YACZ,UAAU,EAAE,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC;YAC9C,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK;YAClC,OAAO,EAAE,EAAE;YACX,QAAQ,EAAE,EAAE;YACZ,QAAQ,EAAE;gBACR,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,IAAI;gBAChC,eAAe,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM;gBAC7C,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK;gBAClC,aAAa,EAAE,SAAS;gBACxB,aAAa,EAAE,KAAK;aACrB;YACD,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,IAAI;SACjC,CAAA;QACD,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;YAC7C,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,EAAE,IAAI,EAAE,CAAC;oBACd,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACnH,CAAC;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,IAAI,GAAG,EAAE,CAAC;oBACR,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,sCAAsC,EAAE,CAAC,CAAC;gBACnH,CAAC;YACH,CAAC;SACF,CAAC,CAAA;IACJ,CAAC;IACD,cAAc,CAAC,OAAgB,EAAE,SAAiB;QAChD,IAAI,eAAe,GAAuB,IAAI,CAAC;QAC/C,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC,OAAoB,EAAE,EAAE;YACrD,IAAI,OAAO,CAAC,SAAS,IAAI,SAAS;gBAChC,eAAe,GAAG,OAAO,CAAC;QAC9B,CAAC,CAAC,CAAA;QAEF,OAAO,eAAe,CAAC;IACzB,CAAC;IACD,aAAa,CAAC,OAAgB;QAC5B,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,YAAY,GAAG,OAAO,EAAE,KAAK,EAAE,eAAe,CAAC,GAAG,OAAO,EAAE,KAAK,EAAE,YAAY,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC9H,CAAC;IACD,iBAAiB,CAAC,OAAgB;QAChC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IAC7E,CAAC;IACD,kBAAkB,CAAC,KAAa;QAC9B,IAAI,GAAG,GAAG,KAAK,CAAC;QAChB,IAAI,CAAC,GAAG;YACN,OAAO,KAAK,CAAC;QACf,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAE5B,IAAI,MAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAC/B,IAAI,CAAC,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;QAC5B,IAAI,CAAC,GAAG,MAAM,GAAG,GAAG,CAAC;QAErB,OAAO,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC;IACvC,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,kBAAkB,CAAC,QAAQ,CAAC;IACrC,CAAC;IAED,gBAAgB,CAAC,OAAY;QAC3B,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC;YAC/B,OAAO,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAEnC,IAAI,UAAU,GAAW,OAAO,CAAC,mBAAmB,CAAC,GAAG,OAAO,EAAE,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;QACxF,OAAO,OAAO,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,MAAM,CAAA;IACtD,CAAC;IAGD,KAAK,CAAC,WAAW,CAAC,OAAY,EAAE,MAAuB;QACrD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC;QAC7B,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;QAEvD,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;YACtB,OAAO,CAAC,mBAAmB,CAAC,EAAE,CAAC;QACjC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,mBAAmB,CAAC,EAAE,CAAC;YAE/B,IAAI,OAAO,CAAC,mBAAmB,CAAC,GAAG,CAAC;gBAClC,OAAO,CAAC,mBAAmB,CAAC,GAAG,OAAO,EAAE,CAAC,YAAY,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC;QACvE,CAAC;QACD,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;IACvB,CAAC;IACD,UAAU,CAAC,WAAgB;QACzB,IAAI,WAAW,IAAI,IAAI,IAAI,WAAW,IAAI,KAAK,EAAE,CAAC;YAChD,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QAChD,CAAC;aACI,IAAI,WAAW,GAAG,KAAK,IAAI,WAAW,IAAI,MAAM,EAAE,CAAC;YACtD,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QACjD,CAAC;aACI,IAAI,WAAW,GAAG,MAAM,IAAI,WAAW,IAAI,OAAO,EAAE,CAAC;YACxD,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QAClD,CAAC;aACI,IAAI,WAAW,GAAG,OAAO,EAAE,CAAC;YAC/B,OAAO,CAAC,WAAW,GAAG,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QACnD,CAAC;aACI,CAAC;YACJ,OAAO,WAAW,CAAC;QACrB,CAAC;IACH,CAAC;+GAtKU,4BAA4B;mGAA5B,4BAA4B,+PChCzC,suIAqEkB,y0DDhDd,YAAY,iOACZ,OAAO,2IACP,qBAAqB,qHACrB,cAAc,gFACd,YAAY,wTACZ,WAAW,8VACX,WAAW;;4FAKF,4BAA4B;kBAfxC,SAAS;+BACE,6BAA6B,cAC3B,IAAI,WACP;wBACP,YAAY;wBACZ,OAAO;wBACP,qBAAqB;wBACrB,cAAc;wBACd,YAAY;wBACZ,WAAW;wBACX,WAAW;qBACZ;gMAeQ,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK","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":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAuB,MAAM,eAAe,CAAC;AACtE,OAAO,WAAW,MAAM,+BAA+B,CAAC;AAExD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAC5E,OAAO,EAAE,wBAAwB,EAAE,MAAM,+CAA+C,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0CAA0C,CAAC;AAG/E,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AAEnF,OAAO,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;;;;;;;;;AAwBpE,MAAM,OAAO,kBAAmB,SAAQ,WAAW;IAgBjD,YAAoB,WAAwB,EAClC,MAAc;QAEtB,KAAK,EAAE,CAAC;QAHU,gBAAW,GAAX,WAAW,CAAa;QAClC,WAAM,GAAN,MAAM,CAAQ;QAdf,SAAI,GAAa,IAAI,CAAC;QAI/B,WAAM,GAAW,CAAC,CAAC;QACnB,cAAS,GAAY,KAAK,CAAC;QAC3B,aAAQ,GAAW,EAAE,CAAC;QAsBtB,eAAU,GAAQ,EAAE,CAAC;QAErB,iBAAY,GAAQ;YAClB,UAAU,EAAE,YAAY,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,sCAAsC;YACxF,MAAM,EAAE,CAAC;YACT,QAAQ,EAAE,EAAE;SACb,CAAA;QASD,gBAAW,GAAY,KAAK,CAAC;QAC7B,eAAU,GAAW,CAAC,CAAC;QACvB,WAAM,GAAY,KAAK,CAAC;QACxB,WAAM,GAAY,KAAK,CAAC;QACxB,UAAK,GAAY,KAAK,CAAC;QAuBvB,cAAS,GAAY,IAAI,CAAA;QACzB,kBAAa,GAAW,EAAE,CAAA;IAtD1B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC;QAChC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACrD,IAAI,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAQD,kBAAkB;QAChB,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;YACjB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QACzC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAOD,eAAe;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtE,IAAI,CAAC,UAAU,GAAG,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC;YAClC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,KAAW,EAAC,EAAE;gBACrC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;gBAC/C,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;YACxE,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,UAAU,GAAG,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC;YACnC,IAAI,CAAC,SAAS,GAAG,GAAG,EAAE,IAAI,EAAE,YAAY,CAAC;YACzC,IAAI,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,MAAM,IAAI,CAAC;gBACtC,IAAI,CAAC,WAAW,GAAG,GAAG,EAAE,IAAI,EAAE,YAAY,CAAC;YAC7C,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;YACtB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACtB,CAAC,EACC,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACrB,CAAC,CAAC,CAAA;IACN,CAAC;IAGD,YAAY,CAAC,SAAc;QACzB,IAAI,CAAC,UAAU,GAAG,SAAS,EAAE,SAAS,CAAC;QACvC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,YAAY,CAAC,OAAY;QACvB,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,SAAS,GAAG,GAAG,CAAC,CAAC,kCAAkC;YACzD,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC5C,MAAM,UAAU,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC;YAExD,OAAO,UAAU,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;QACxD,CAAC;QACD,OAAO,UAAU,CAAA;IACnB,CAAC;IACD,YAAY,CAAC,KAAa;QACxB,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,WAAW,GAAG,iBAAiB,KAAK,EAAE,CAAC;YAC7C,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IACD,SAAS,CAAC,OAAe;QACvB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,WAAW,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;IAC1E,CAAC;IACD,OAAO,CAAC,UAAe,EAAE,IAAY;QACnC,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;QACzB,MAAM,OAAO,GAAG,KAAK,CAAC,kBAAkB,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QACrF,KAAK,IAAI,GAAG,IAAI,UAAU,EAAE,CAAC;YAC3B,IAAI,GAAG,CAAC,SAAS,IAAI,OAAO,EAAE,CAAC;gBAC7B,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;oBACnB,OAAO,GAAG,CAAC,WAAW,CAAA;gBACxB,CAAC;qBAAM,CAAC;oBACN,OAAO,GAAG,CAAC,WAAW,CAAA;gBACxB,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,CAAC,OAAY,EAAE,OAAe;QACnC,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAC5C,OAAO,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,OAAO,GAAG,GAAG,GAAG,CAAC;IACpD,CAAC;+GAtHU,kBAAkB;mGAAlB,kBAAkB,yMCzC/B,k5VAgKM,w0DDxIM,YAAY,6VACpB,WAAW,gxBACX,mBAAmB,+BACnB,OAAO,0IACP,oBAAoB,ohBACpB,kBAAkB,yFAClB,mBAAmB,0GACnB,cAAc,gFACd,wBAAwB,sIACxB,mBAAmB,kFACnB,uBAAuB,+BACvB,qBAAqB;;4FAMZ,kBAAkB;kBApB9B,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP,CAAC,YAAY;wBACpB,WAAW;wBACX,mBAAmB;wBACnB,OAAO;wBACP,oBAAoB;wBACpB,kBAAkB;wBAClB,mBAAmB;wBACnB,cAAc;wBACd,wBAAwB;wBACxB,mBAAmB;wBACnB,uBAAuB;wBACvB,qBAAqB;wBACrB,cAAc;qBACf;qGAMQ,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK","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>"]}
|
@@ -52,10 +52,12 @@ export class VerifyComponent extends BaseSection {
|
|
52
52
|
}, 3000);
|
53
53
|
}, 3000);
|
54
54
|
const passBookOrderId = localStorage.getItem("passbookOrderId");
|
55
|
+
const orderId = localStorage.getItem("orderId");
|
56
|
+
console.log('calling verify payment');
|
55
57
|
if (passBookOrderId) {
|
56
58
|
this.checkPassbookPaymentStatus();
|
57
59
|
}
|
58
|
-
else {
|
60
|
+
else if (orderId) {
|
59
61
|
this.checkPaymentStatus();
|
60
62
|
}
|
61
63
|
}
|
@@ -187,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
187
189
|
}], customClass: [{
|
188
190
|
type: Input
|
189
191
|
}] } });
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"verify-payment.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/verify-payment/verify-payment.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/verify-payment/verify-payment.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { RestService } from '../../../services/rest.service';\nimport { Router } from '@angular/router';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport { VerifyPaymentContentModel, VerifyPaymentSectionModal, VerifyPaymentStylesModel } from './verify-payment.model';\nimport Swal from 'sweetalert2';\nimport { User } from '../../styles/user.modal';\nimport { MessageService } from 'primeng/api';\nimport { ToastModule } from 'primeng/toast';\nimport { BackgroundDirective } from '../../../directive/background-directive';\nimport { EventsService } from '../../../services/events.service';\nimport BaseSection from '../../../sections/BaseSection';\nimport { HoverDirective } from '../../../directive/hover-element-directive';\nimport { HoverElementsComponent } from '../../../components/hover-elements/hover-elements.component';\nimport { DeleteHoverElementComponent } from '../../../components/delete-hover-element/delete-hover-element.component';\nimport { CommonModule } from '@angular/common';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\n\n@Component({\n  selector: 'simpo-verify-payment',\n  standalone: true,\n  imports: [\n    BackgroundDirective,\n    HoverDirective,\n    ToastModule,\n    CommonModule,\n    HoverElementsComponent,\n    DeleteHoverElementComponent,\n    MatProgressSpinnerModule\n  ],\n  providers: [MessageService],\n  templateUrl: './verify-payment.component.html',\n  styleUrl: './verify-payment.component.css'\n})\nexport class VerifyComponent extends BaseSection implements OnInit {\n\n  @Input() data?: VerifyPaymentSectionModal;\n  @Input() responseData: any;\n  @Input() edit?: boolean;\n  @Input() index?: number;\n  @Input() delete?: boolean;\n  @Input() customClass?: string;\n  styles?: VerifyPaymentStylesModel;\n  content?: VerifyPaymentContentModel;\n  private userDetails: User | null = null;\n  paymentStatus: 'SUCCESS' | 'FAILED' | 'ONGOING' = 'ONGOING'\n\n  constructor(\n    private readonly restService: RestService,\n    private readonly router: Router,\n    private readonly storageService: StorageServiceService,\n    private readonly messageService: MessageService,\n    private readonly _eventService: EventsService\n  ) {\n    super();\n  }\n\n  public loadingText: string = \"Please wait...\";\n  private API_COUNT: number = 0;\n  private MAX_API_COUNT: number = 20;\n  private PASSBOOK_API_COUNT: number = 0;\n  private MAX_PASSBOOK_API_COUNT = 20;\n\n  ngOnInit(): void {\n    this.content = this.data?.content;\n    this.styles = this.data?.styles;\n\n    this.userDetails = this.storageService.getUser() as User;\n    if (!this.userDetails && (localStorage.getItem(\"REQUEST_FROM\") == \"USER\")) {\n      this.messageService.add({ severity: 'error', summary: 'Error', detail: 'Please login to access profile' });\n      this.router.navigate(['/']);\n    }\n\n    if (localStorage.getItem(\"REQUEST_FROM\") == \"ECOMMERCE\")\n      return;\n\n    setTimeout(() => {\n      this.loadingText = 'Thanks for choosing us';\n      setTimeout(() => {\n        this.loadingText = 'We are processing your payments';\n        setTimeout(() => {\n          this.loadingText = 'Hold On...';\n        }, 3000);\n      }, 3000);\n    }, 3000);\n\n    const passBookOrderId = localStorage.getItem(\"passbookOrderId\");\n      if (passBookOrderId) {\n        this.checkPassbookPaymentStatus();\n      }\n      else {\n        this.checkPaymentStatus();\n    }\n  }\n\n  get getImageUrl() {\n    return this.content?.image?.url;\n  }\n  get isMobile(): boolean {\n    return window.innerWidth < 475;\n  }\n\n  public checkPaymentStatus() {\n    const payload = {\n      \"orderId\": localStorage.getItem(\"orderId\")\n    }\n    this.API_COUNT++;\n    this.restService.checkPaymentStatus(payload).subscribe((response) => {\n      localStorage.removeItem(\"orderId\");\n      localStorage.removeItem(\"cartId\");\n      localStorage.removeItem(\"paymentFor\");\n      this.storageService.clearUserCart();\n      this.paymentStatus = 'SUCCESS'\n\n      setTimeout(() => {\n        this.router.navigate(['/profile']);\n      }, 3000);\n      // Swal.fire({\n      //   icon: \"success\",\n      //   title: \"Hurray\",\n      //   text: \"Order placed successfully\",\n      //   confirmButtonText: \"See Details\"\n      // }).then((response) => {\n      //   if (response.isConfirmed) {\n      //     this.router.navigate(['/profile']);\n      //   }\n      // })\n    }, (error) => {\n      if (this.API_COUNT >= this.MAX_API_COUNT) {\n        this.paymentStatus = 'FAILED'\n        setTimeout(() => {\n          this.router.navigate(['/']);\n        }, 3000);\n        // Swal.fire({\n        //   icon: \"error\",\n        //   title: \"Sorry\",\n        //   text: \"We encountered some issue while placing your order\",\n        //   confirmButtonText: \"Go To Home\"\n        // }).then((response) => {\n        //   if (response.isConfirmed) {\n        //     this.router.navigate(['/']);\n        //   }\n        // })\n      } else {\n        this.checkPaymentStatus();\n      }\n    })\n  }\n  public checkPassbookPaymentStatus() {\n    const orderId = localStorage.getItem(\"passbookOrderId\")\n    this.PASSBOOK_API_COUNT++;\n    this.restService.getPassbookOrderStatus(orderId).subscribe((response) => {\n      localStorage.removeItem(\"passbookOrderId\");\n      this.paymentStatus = 'SUCCESS'\n\n      setTimeout(() => {\n        this.router.navigate(['/profile']);\n      }, 3000);\n      // Swal.fire({\n      //   icon: \"success\",\n      //   title: \"Hurray\",\n      //   text: \"Payment Successful\",\n      //   confirmButtonText: \"See Details\"\n      // }).then((response) => {\n      //   if (response.isConfirmed) {\n      //     this.router.navigate(['/profile'], {queryParams: {tab: 'Scheme Passbook'}});\n      //   }\n      // })\n\n    }, (error) => {\n      if (this.PASSBOOK_API_COUNT >= this.MAX_PASSBOOK_API_COUNT) {\n        // Swal.fire({\n        //   icon: \"error\",\n        //   title: \"Sorry\",\n        //   text: \"We encountered some issue while placing your order\",\n        //   confirmButtonText: \"Go To Home\"\n        // }).then((response) => {\n        //   if (response.isConfirmed) {\n        //     this.router.navigate(['/']);\n        //   }\n        // })\n        this.paymentStatus = 'FAILED'\n        setTimeout(() => {\n          this.router.navigate(['/']);\n        }, 3000);\n      } else {\n        this.checkPassbookPaymentStatus();\n      }\n    })\n  }\n  editSection() {\n\n    if (window.innerWidth <= 475)\n      return;\n\n    this._eventService.toggleEditorEvent.emit(false);\n    setTimeout(() => {\n      this._eventService.editSection.emit({ data: this.data });\n    }, 100);\n  }\n}\n","<!-- <p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\" [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n<section class=\"d-flex flex-column align-items-center justify-content-center total-container\" style=\"height: 100vh;\" [simpoBackground]=\"styles?.background\" simpoHover (hovering)=\"showEditTabs($event)\" [attr.style]=\"customClass\">\n    <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"   [src]=\"getImageUrl\" style=\"height: 200px; width: 200px;\" [alt]=\"content?.image?.altText\">\n    <span class=\"font-bold\">{{loadingText}}</span>\n\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n      <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\" [isEcommerce]=\"true\"></simpo-hover-elements>\n    </div>\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n      <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n  </div>\n</section> -->\n<section *ngIf=\"paymentStatus === 'SUCCESS'\" class=\"main_section\">\n  <div class=\"image_section\">\n    <img alt=\"loader\" src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/688996c175593490852796237-success.gif\">\n  </div>\n  <div class=\"success_heading heading\">\n    Payment Successfull\n  </div>\n  <div class=\"payment_sub_text\">\n    Your payment has been successfully processed.\n  </div>\n  <!-- <div class=\"plan_description\">\n    <div class=\"title_value\">\n      <div class=\"plan_title\">\n        Subscribed Plan\n      </div>\n      <div class=\"plan_value\">\n        {{ planName | titlecase }}\n      </div>\n    </div>\n    <div class=\"title_value\">\n      <div class=\"plan_title\">\n        Amount Paid\n      </div>\n      <div class=\"plan_value\">\n        <span>₹</span><span>{{ planAmount }}</span>\n      </div>\n    </div>\n    <div class=\"title_value\">\n      <div class=\"plan_title\">\n        Valid till\n      </div>\n      <div class=\"plan_value\">\n        {{ validity | date }}\n      </div>\n    </div>\n  </div> -->\n</section>\n<section *ngIf=\"paymentStatus === 'FAILED'\" class=\"main_section\">\n  <div class=\"image_section\">\n    <img alt=\"loader\" src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/663878c1755934932573paymentfailed.gif\">\n  </div>\n  <div class=\"success_heading heading\">\n    Payment Failed\n  </div>\n  <div class=\"payment_sub_text\">\n    Unfortunately Payment was rejected\n  </div>\n  <div class=\"payment_minimal_text\">\n    Page will be automatically redirect to homepage\n  </div>\n  <!-- <div class=\"plan_description\">\n      <button (click)=\"done()\">Done</button>\n  </div> -->\n</section>\n\n<section *ngIf=\"paymentStatus === 'ONGOING'\" class=\"main_section spinner\">\n  <div class=\"payment-ongoing\">\n    <mat-spinner style=\"width: 100%;\"></mat-spinner>\n    <p>{{loadingText}}</p>\n  </div>\n</section>\n"]}
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"verify-payment.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/verify-payment/verify-payment.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/verify-payment/verify-payment.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { RestService } from '../../../services/rest.service';\nimport { Router } from '@angular/router';\nimport { StorageServiceService } from '../../../services/storage.service';\nimport { VerifyPaymentContentModel, VerifyPaymentSectionModal, VerifyPaymentStylesModel } from './verify-payment.model';\nimport Swal from 'sweetalert2';\nimport { User } from '../../styles/user.modal';\nimport { MessageService } from 'primeng/api';\nimport { ToastModule } from 'primeng/toast';\nimport { BackgroundDirective } from '../../../directive/background-directive';\nimport { EventsService } from '../../../services/events.service';\nimport BaseSection from '../../../sections/BaseSection';\nimport { HoverDirective } from '../../../directive/hover-element-directive';\nimport { HoverElementsComponent } from '../../../components/hover-elements/hover-elements.component';\nimport { DeleteHoverElementComponent } from '../../../components/delete-hover-element/delete-hover-element.component';\nimport { CommonModule } from '@angular/common';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\n\n@Component({\n  selector: 'simpo-verify-payment',\n  standalone: true,\n  imports: [\n    BackgroundDirective,\n    HoverDirective,\n    ToastModule,\n    CommonModule,\n    HoverElementsComponent,\n    DeleteHoverElementComponent,\n    MatProgressSpinnerModule\n  ],\n  providers: [MessageService],\n  templateUrl: './verify-payment.component.html',\n  styleUrl: './verify-payment.component.css'\n})\nexport class VerifyComponent extends BaseSection implements OnInit {\n\n  @Input() data?: VerifyPaymentSectionModal;\n  @Input() responseData: any;\n  @Input() edit?: boolean;\n  @Input() index?: number;\n  @Input() delete?: boolean;\n  @Input() customClass?: string;\n  styles?: VerifyPaymentStylesModel;\n  content?: VerifyPaymentContentModel;\n  private userDetails: User | null = null;\n  paymentStatus: 'SUCCESS' | 'FAILED' | 'ONGOING' = 'ONGOING'\n\n  constructor(\n    private readonly restService: RestService,\n    private readonly router: Router,\n    private readonly storageService: StorageServiceService,\n    private readonly messageService: MessageService,\n    private readonly _eventService: EventsService\n  ) {\n    super();\n  }\n\n  public loadingText: string = \"Please wait...\";\n  private API_COUNT: number = 0;\n  private MAX_API_COUNT: number = 20;\n  private PASSBOOK_API_COUNT: number = 0;\n  private MAX_PASSBOOK_API_COUNT = 20;\n\n  ngOnInit(): void {\n    this.content = this.data?.content;\n    this.styles = this.data?.styles;\n\n    this.userDetails = this.storageService.getUser() as User;\n    if (!this.userDetails && (localStorage.getItem(\"REQUEST_FROM\") == \"USER\")) {\n      this.messageService.add({ severity: 'error', summary: 'Error', detail: 'Please login to access profile' });\n      this.router.navigate(['/']);\n    }\n\n    if (localStorage.getItem(\"REQUEST_FROM\") == \"ECOMMERCE\")\n      return;\n\n    setTimeout(() => {\n      this.loadingText = 'Thanks for choosing us';\n      setTimeout(() => {\n        this.loadingText = 'We are processing your payments';\n        setTimeout(() => {\n          this.loadingText = 'Hold On...';\n        }, 3000);\n      }, 3000);\n    }, 3000);\n\n    const passBookOrderId = localStorage.getItem(\"passbookOrderId\");\n    const orderId = localStorage.getItem(\"orderId\")\n    console.log('calling verify payment');\n      if (passBookOrderId) {\n        this.checkPassbookPaymentStatus();\n      }\n      else if(orderId){\n        this.checkPaymentStatus();\n    }\n  }\n\n  get getImageUrl() {\n    return this.content?.image?.url;\n  }\n  get isMobile(): boolean {\n    return window.innerWidth < 475;\n  }\n\n  public checkPaymentStatus() {\n    const payload = {\n      \"orderId\": localStorage.getItem(\"orderId\")\n    }\n    this.API_COUNT++;\n    this.restService.checkPaymentStatus(payload).subscribe((response) => {\n      localStorage.removeItem(\"orderId\");\n      localStorage.removeItem(\"cartId\");\n      localStorage.removeItem(\"paymentFor\");\n      this.storageService.clearUserCart();\n      this.paymentStatus = 'SUCCESS'\n\n      setTimeout(() => {\n        this.router.navigate(['/profile']);\n      }, 3000);\n      // Swal.fire({\n      //   icon: \"success\",\n      //   title: \"Hurray\",\n      //   text: \"Order placed successfully\",\n      //   confirmButtonText: \"See Details\"\n      // }).then((response) => {\n      //   if (response.isConfirmed) {\n      //     this.router.navigate(['/profile']);\n      //   }\n      // })\n    }, (error) => {\n      if (this.API_COUNT >= this.MAX_API_COUNT) {\n        this.paymentStatus = 'FAILED'\n        setTimeout(() => {\n          this.router.navigate(['/']);\n        }, 3000);\n        // Swal.fire({\n        //   icon: \"error\",\n        //   title: \"Sorry\",\n        //   text: \"We encountered some issue while placing your order\",\n        //   confirmButtonText: \"Go To Home\"\n        // }).then((response) => {\n        //   if (response.isConfirmed) {\n        //     this.router.navigate(['/']);\n        //   }\n        // })\n      } else {\n        this.checkPaymentStatus();\n      }\n    })\n  }\n  public checkPassbookPaymentStatus() {\n    const orderId = localStorage.getItem(\"passbookOrderId\")\n    this.PASSBOOK_API_COUNT++;\n    this.restService.getPassbookOrderStatus(orderId).subscribe((response) => {\n      localStorage.removeItem(\"passbookOrderId\");\n      this.paymentStatus = 'SUCCESS'\n\n      setTimeout(() => {\n        this.router.navigate(['/profile']);\n      }, 3000);\n      // Swal.fire({\n      //   icon: \"success\",\n      //   title: \"Hurray\",\n      //   text: \"Payment Successful\",\n      //   confirmButtonText: \"See Details\"\n      // }).then((response) => {\n      //   if (response.isConfirmed) {\n      //     this.router.navigate(['/profile'], {queryParams: {tab: 'Scheme Passbook'}});\n      //   }\n      // })\n\n    }, (error) => {\n      if (this.PASSBOOK_API_COUNT >= this.MAX_PASSBOOK_API_COUNT) {\n        // Swal.fire({\n        //   icon: \"error\",\n        //   title: \"Sorry\",\n        //   text: \"We encountered some issue while placing your order\",\n        //   confirmButtonText: \"Go To Home\"\n        // }).then((response) => {\n        //   if (response.isConfirmed) {\n        //     this.router.navigate(['/']);\n        //   }\n        // })\n        this.paymentStatus = 'FAILED'\n        setTimeout(() => {\n          this.router.navigate(['/']);\n        }, 3000);\n      } else {\n        this.checkPassbookPaymentStatus();\n      }\n    })\n  }\n  editSection() {\n\n    if (window.innerWidth <= 475)\n      return;\n\n    this._eventService.toggleEditorEvent.emit(false);\n    setTimeout(() => {\n      this._eventService.editSection.emit({ data: this.data });\n    }, 100);\n  }\n}\n","<!-- <p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\" [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n<section class=\"d-flex flex-column align-items-center justify-content-center total-container\" style=\"height: 100vh;\" [simpoBackground]=\"styles?.background\" simpoHover (hovering)=\"showEditTabs($event)\" [attr.style]=\"customClass\">\n    <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"   [src]=\"getImageUrl\" style=\"height: 200px; width: 200px;\" [alt]=\"content?.image?.altText\">\n    <span class=\"font-bold\">{{loadingText}}</span>\n\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n      <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\" [isEcommerce]=\"true\"></simpo-hover-elements>\n    </div>\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n      <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n  </div>\n</section> -->\n<section *ngIf=\"paymentStatus === 'SUCCESS'\" class=\"main_section\">\n  <div class=\"image_section\">\n    <img alt=\"loader\" src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/688996c175593490852796237-success.gif\">\n  </div>\n  <div class=\"success_heading heading\">\n    Payment Successfull\n  </div>\n  <div class=\"payment_sub_text\">\n    Your payment has been successfully processed.\n  </div>\n  <!-- <div class=\"plan_description\">\n    <div class=\"title_value\">\n      <div class=\"plan_title\">\n        Subscribed Plan\n      </div>\n      <div class=\"plan_value\">\n        {{ planName | titlecase }}\n      </div>\n    </div>\n    <div class=\"title_value\">\n      <div class=\"plan_title\">\n        Amount Paid\n      </div>\n      <div class=\"plan_value\">\n        <span>₹</span><span>{{ planAmount }}</span>\n      </div>\n    </div>\n    <div class=\"title_value\">\n      <div class=\"plan_title\">\n        Valid till\n      </div>\n      <div class=\"plan_value\">\n        {{ validity | date }}\n      </div>\n    </div>\n  </div> -->\n</section>\n<section *ngIf=\"paymentStatus === 'FAILED'\" class=\"main_section\">\n  <div class=\"image_section\">\n    <img alt=\"loader\" src=\"https://d2z9497xp8xb12.cloudfront.net/prod-images/663878c1755934932573paymentfailed.gif\">\n  </div>\n  <div class=\"success_heading heading\">\n    Payment Failed\n  </div>\n  <div class=\"payment_sub_text\">\n    Unfortunately Payment was rejected\n  </div>\n  <div class=\"payment_minimal_text\">\n    Page will be automatically redirect to homepage\n  </div>\n  <!-- <div class=\"plan_description\">\n      <button (click)=\"done()\">Done</button>\n  </div> -->\n</section>\n\n<section *ngIf=\"paymentStatus === 'ONGOING'\" class=\"main_section spinner\">\n  <div class=\"payment-ongoing\">\n    <mat-spinner style=\"width: 100%;\"></mat-spinner>\n    <p>{{loadingText}}</p>\n  </div>\n</section>\n"]}
|