simpo-component-library 1.5.0 → 1.5.2
Sign up to get free protection for your applications and to get access to all the features.
- package/esm2022/lib/components/hover-elements/hover-elements.component.mjs +7 -5
- package/esm2022/lib/constants/business.constant.mjs +14 -0
- package/esm2022/lib/directive/background-directive.mjs +1 -1
- package/esm2022/lib/directive/border-directive.mjs +23 -11
- package/esm2022/lib/directive/spacing-horizontal.directive.mjs +48 -0
- package/esm2022/lib/directive/wrap-containers.directive.mjs +31 -0
- package/esm2022/lib/ecommerce/sections/address/address.component.mjs +134 -28
- package/esm2022/lib/ecommerce/sections/authenticate-user/authenticate-user.component.mjs +104 -39
- package/esm2022/lib/ecommerce/sections/cart/cart.component.mjs +296 -61
- package/esm2022/lib/ecommerce/sections/cart/cart.modal.mjs +1 -1
- package/esm2022/lib/ecommerce/sections/checkout/checkout.component.mjs +13 -3
- package/esm2022/lib/ecommerce/sections/featured-category/featured-category.component.mjs +13 -4
- package/esm2022/lib/ecommerce/sections/featured-products/featured-products.component.mjs +212 -42
- package/esm2022/lib/ecommerce/sections/featured-products/featured-products.modal.mjs +11 -2
- package/esm2022/lib/ecommerce/sections/item-varient/item-varient.component.mjs +11 -0
- package/esm2022/lib/ecommerce/sections/order-details/order-details.component.mjs +77 -10
- package/esm2022/lib/ecommerce/sections/pagnination/pagnination.component.mjs +13 -7
- package/esm2022/lib/ecommerce/sections/product-desc/product-desc.component.mjs +272 -39
- package/esm2022/lib/ecommerce/sections/product-desc/product-desc.modal.mjs +1 -1
- package/esm2022/lib/ecommerce/sections/product-list/product-list.component.mjs +252 -33
- package/esm2022/lib/ecommerce/sections/product-list/product-list.modal.mjs +1 -1
- package/esm2022/lib/ecommerce/sections/user-basic-info/user-basic-info.component.mjs +44 -17
- package/esm2022/lib/ecommerce/sections/user-profile/user-profile.component.mjs +300 -28
- package/esm2022/lib/ecommerce/sections/user-profile/user-profile.modal.mjs +1 -1
- package/esm2022/lib/ecommerce/sections/verify-payment/verify-payment.component.mjs +124 -0
- package/esm2022/lib/ecommerce/sections/verify-payment/verify-payment.model.mjs +2 -0
- package/esm2022/lib/ecommerce/sections/whislist/whislist.component.mjs +183 -17
- package/esm2022/lib/ecommerce/styles/OrderedItems.modal.mjs +11 -3
- package/esm2022/lib/ecommerce/styles/cart.modal.mjs +2 -1
- package/esm2022/lib/ecommerce/styles/product.modal.mjs +10 -1
- package/esm2022/lib/ecommerce/styles/user.modal.mjs +1 -1
- package/esm2022/lib/elements/below-image-card/below-image-card.component.mjs +3 -3
- package/esm2022/lib/elements/covering-image-card/covering-image-card.component.mjs +3 -3
- package/esm2022/lib/elements/top-of-image-card/top-of-image-card.component.mjs +3 -3
- package/esm2022/lib/pipes/amount.pipe.mjs +35 -0
- package/esm2022/lib/pipes/gender.pipe.mjs +36 -0
- package/esm2022/lib/sections/BaseSection.mjs +1 -1
- package/esm2022/lib/sections/banner-carousel/banner-carousel.component.mjs +3 -3
- package/esm2022/lib/sections/banner-grid-section/banner-grid-section.component.mjs +9 -4
- package/esm2022/lib/sections/banner-grid-section/banner-grid-section.model.mjs +1 -1
- package/esm2022/lib/sections/banner-section/banner-section.component.mjs +3 -3
- package/esm2022/lib/sections/blog-list/blog-list.component.mjs +3 -3
- package/esm2022/lib/sections/carousel-banner/carousel-banner.component.mjs +12 -12
- package/esm2022/lib/sections/carousel-banner/carousel-banner.model.mjs +1 -1
- package/esm2022/lib/sections/choose-us-section/choose-us-section.component.mjs +2 -2
- package/esm2022/lib/sections/contact-us/contact-us.component.mjs +7 -5
- package/esm2022/lib/sections/faq-section/faq-section.component.mjs +3 -3
- package/esm2022/lib/sections/features-section/features-section.component.mjs +3 -3
- package/esm2022/lib/sections/footer-section/footer-section.component.mjs +3 -3
- package/esm2022/lib/sections/header-text/header-text.component.mjs +3 -3
- package/esm2022/lib/sections/image-carousel-section/image-carousel-section.component.mjs +3 -3
- package/esm2022/lib/sections/image-grid-section/image-grid-section.component.mjs +3 -3
- package/esm2022/lib/sections/image-section/image-section.component.mjs +3 -3
- package/esm2022/lib/sections/location-section/location-section.component.mjs +2 -2
- package/esm2022/lib/sections/logo-showcase/logo-showcase.component.mjs +3 -3
- package/esm2022/lib/sections/navbar-section/navbar-section.component.mjs +42 -18
- package/esm2022/lib/sections/navbar-section/navbar-section.model.mjs +1 -1
- package/esm2022/lib/sections/pricing-section/pricing-section.component.mjs +3 -3
- package/esm2022/lib/sections/process-modern/process-modern.component.mjs +3 -3
- package/esm2022/lib/sections/process-section/process-section.component.mjs +3 -3
- package/esm2022/lib/sections/recent-blog-post-section/recent-blog-post-section.component.mjs +3 -3
- package/esm2022/lib/sections/service-section/service-section.component.mjs +1 -1
- package/esm2022/lib/sections/team-member-section/team-member-section.component.mjs +1 -1
- package/esm2022/lib/sections/testimonial-fullwidth/testimonial-fullwidth.component.mjs +3 -3
- package/esm2022/lib/sections/testimonial-section/testimonial-section.component.mjs +3 -3
- package/esm2022/lib/sections/text-image-section/text-image-section.component.mjs +3 -3
- package/esm2022/lib/sections/text-section/text-section.component.mjs +2 -2
- package/esm2022/lib/sections/video-section/video-section.component.mjs +11 -3
- package/esm2022/lib/sections/view-blog/view-blog.component.mjs +3 -3
- package/esm2022/lib/services/cart.service.mjs +54 -120
- package/esm2022/lib/services/endUser.service.mjs +28 -0
- package/esm2022/lib/services/events.service.mjs +4 -1
- package/esm2022/lib/services/rest.service.mjs +58 -16
- package/esm2022/lib/services/storage.service.mjs +103 -35
- package/esm2022/lib/styles/index.mjs +8 -1
- package/esm2022/lib/styles/style.model.mjs +1 -1
- package/esm2022/lib/styles/types.mjs +1 -1
- package/esm2022/public-api.mjs +4 -1
- package/fesm2022/simpo-component-library.mjs +2518 -712
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/components/hover-elements/hover-elements.component.d.ts +2 -1
- package/lib/constants/business.constant.d.ts +11 -0
- package/lib/directive/spacing-horizontal.directive.d.ts +18 -0
- package/lib/directive/wrap-containers.directive.d.ts +14 -0
- package/lib/ecommerce/sections/address/address.component.d.ts +30 -9
- package/lib/ecommerce/sections/authenticate-user/authenticate-user.component.d.ts +31 -6
- package/lib/ecommerce/sections/cart/cart.component.d.ts +26 -11
- package/lib/ecommerce/sections/cart/cart.modal.d.ts +10 -1
- package/lib/ecommerce/sections/checkout/checkout.component.d.ts +2 -0
- package/lib/ecommerce/sections/featured-category/featured-category.component.d.ts +2 -0
- package/lib/ecommerce/sections/featured-products/featured-products.component.d.ts +27 -9
- package/lib/ecommerce/sections/featured-products/featured-products.modal.d.ts +5 -1
- package/lib/ecommerce/sections/item-varient/item-varient.component.d.ts +5 -0
- package/lib/ecommerce/sections/order-details/order-details.component.d.ts +16 -2
- package/lib/ecommerce/sections/pagnination/pagnination.component.d.ts +3 -2
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +33 -4
- package/lib/ecommerce/sections/product-desc/product-desc.modal.d.ts +4 -1
- package/lib/ecommerce/sections/product-list/product-list.component.d.ts +39 -3
- package/lib/ecommerce/sections/product-list/product-list.modal.d.ts +2 -0
- package/lib/ecommerce/sections/user-basic-info/user-basic-info.component.d.ts +11 -1
- package/lib/ecommerce/sections/user-profile/user-profile.component.d.ts +52 -13
- package/lib/ecommerce/sections/user-profile/user-profile.modal.d.ts +6 -8
- package/lib/ecommerce/sections/verify-payment/verify-payment.component.d.ts +34 -0
- package/lib/ecommerce/sections/verify-payment/verify-payment.model.d.ts +23 -0
- package/lib/ecommerce/sections/whislist/whislist.component.d.ts +22 -6
- package/lib/ecommerce/styles/OrderedItems.modal.d.ts +6 -2
- package/lib/ecommerce/styles/cart.modal.d.ts +1 -0
- package/lib/ecommerce/styles/product.modal.d.ts +4 -0
- package/lib/ecommerce/styles/user.modal.d.ts +3 -3
- package/lib/pipes/amount.pipe.d.ts +7 -0
- package/lib/pipes/gender.pipe.d.ts +8 -0
- package/lib/sections/banner-grid-section/banner-grid-section.component.d.ts +1 -0
- package/lib/sections/banner-grid-section/banner-grid-section.model.d.ts +1 -0
- package/lib/sections/carousel-banner/carousel-banner.component.d.ts +7 -5
- package/lib/sections/carousel-banner/carousel-banner.model.d.ts +41 -26
- package/lib/sections/navbar-section/navbar-section.component.d.ts +6 -1
- package/lib/sections/navbar-section/navbar-section.model.d.ts +1 -1
- package/lib/sections/video-section/video-section.component.d.ts +4 -2
- package/lib/services/cart.service.d.ts +13 -8
- package/lib/services/endUser.service.d.ts +13 -0
- package/lib/services/events.service.d.ts +5 -2
- package/lib/services/rest.service.d.ts +16 -2
- package/lib/services/storage.service.d.ts +11 -44
- package/lib/styles/index.d.ts +6 -0
- package/lib/styles/style.model.d.ts +4 -1
- package/lib/styles/types.d.ts +2 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
- package/simpo-component-library-1.5.2.tgz +0 -0
- package/esm2022/lib/ecommerce/json/user-cart.json +0 -40
- package/esm2022/lib/ecommerce/json/user-details.json +0 -15
- package/esm2022/lib/ecommerce/json/user-favourite.json +0 -32
- package/simpo-component-library-1.5.0.tgz +0 -0
@@ -1,4 +1,5 @@
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
2
|
+
import { ToastModule } from 'primeng/toast';
|
2
3
|
import { FormsModule } from '@angular/forms';
|
3
4
|
import { CommonModule } from '@angular/common';
|
4
5
|
import { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';
|
@@ -8,11 +9,14 @@ import { HoverDirective } from '../../../directive/hover-element-directive';
|
|
8
9
|
import { ContentFitDirective } from '../../../directive/content-fit-directive';
|
9
10
|
import { SimpoComponentModule } from '../../../components/index';
|
10
11
|
import BaseSection from '../../../sections/BaseSection';
|
11
|
-
import UserCart from './../../json/user-cart.json';
|
12
|
-
import UserInfo from './../../json/user-details.json';
|
13
12
|
import { AddressComponent } from "../address/address.component";
|
14
13
|
import { AuthenticateUserComponent } from '../authenticate-user/authenticate-user.component';
|
15
14
|
import { MatDialogModule } from '@angular/material/dialog';
|
15
|
+
import { BUSINESS_CONSTANTS } from '../../../constants/business.constant';
|
16
|
+
import { MessageService } from 'primeng/api';
|
17
|
+
import Swal from 'sweetalert2';
|
18
|
+
import { BackgroundDirective } from '../../../directive/background-directive';
|
19
|
+
import { MatBottomSheetModule } from '@angular/material/bottom-sheet';
|
16
20
|
import * as i0 from "@angular/core";
|
17
21
|
import * as i1 from ".././../../services/events.service";
|
18
22
|
import * as i2 from "../../../services/cart.service";
|
@@ -20,13 +24,15 @@ import * as i3 from "@angular/router";
|
|
20
24
|
import * as i4 from "../../../services/rest.service";
|
21
25
|
import * as i5 from "@angular/material/dialog";
|
22
26
|
import * as i6 from "../../../services/storage.service";
|
23
|
-
import * as i7 from "
|
24
|
-
import * as i8 from "@angular/
|
25
|
-
import * as i9 from "
|
26
|
-
import * as i10 from "../../../components/
|
27
|
-
import * as i11 from "
|
27
|
+
import * as i7 from "primeng/api";
|
28
|
+
import * as i8 from "@angular/material/bottom-sheet";
|
29
|
+
import * as i9 from "@angular/common";
|
30
|
+
import * as i10 from "../../../components/hover-elements/hover-elements.component";
|
31
|
+
import * as i11 from "../../../components/delete-hover-element/delete-hover-element.component";
|
32
|
+
import * as i12 from "ngx-skeleton-loader";
|
33
|
+
import * as i13 from "primeng/toast";
|
28
34
|
export class CartComponent extends BaseSection {
|
29
|
-
constructor(_eventService, cartService, router, restService, matDialog, storageService,
|
35
|
+
constructor(_eventService, cartService, router, restService, matDialog, storageService, messageService, bottomSheet) {
|
30
36
|
super();
|
31
37
|
this._eventService = _eventService;
|
32
38
|
this.cartService = cartService;
|
@@ -34,74 +40,215 @@ export class CartComponent extends BaseSection {
|
|
34
40
|
this.restService = restService;
|
35
41
|
this.matDialog = matDialog;
|
36
42
|
this.storageService = storageService;
|
37
|
-
this.
|
43
|
+
this.messageService = messageService;
|
44
|
+
this.bottomSheet = bottomSheet;
|
45
|
+
this.edit = false;
|
38
46
|
this.isLoading = false;
|
39
|
-
this.selectedAddressIdx = -1;
|
40
47
|
this.currentTab = "BAG";
|
41
|
-
this.
|
48
|
+
this.userDetails = null;
|
49
|
+
this.USER_CART_ITEMS = null;
|
50
|
+
this.selectedAddressIdx = 0;
|
51
|
+
this.cartInfo = {
|
52
|
+
orderedItems: null,
|
53
|
+
businessId: localStorage.getItem("bId") ?? localStorage.getItem("businessId"),
|
54
|
+
billdetails: {
|
55
|
+
"totalNetValue": 0,
|
56
|
+
"totalGrossValue": 0,
|
57
|
+
"totalTax": 0,
|
58
|
+
"totalOfferedValue": 0,
|
59
|
+
"deliveryCharges": 0
|
60
|
+
},
|
61
|
+
platform: "WEB",
|
62
|
+
cartType: "CART",
|
63
|
+
addressDetails: null,
|
64
|
+
userDetails: {
|
65
|
+
"userId": "",
|
66
|
+
"userName": "",
|
67
|
+
"mobile": "",
|
68
|
+
"email": ""
|
69
|
+
},
|
70
|
+
totalAmount: 0
|
71
|
+
};
|
42
72
|
}
|
43
73
|
ngOnInit() {
|
44
74
|
this._eventService.showLoadingScreen.subscribe((response) => {
|
45
75
|
this.isLoading = response;
|
76
|
+
if (!this.isLoading) {
|
77
|
+
this.getIndexDBData();
|
78
|
+
}
|
46
79
|
});
|
47
80
|
if (this.storageService.getUser()) {
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
81
|
+
this.userDetails = this.storageService.getUser();
|
82
|
+
this.cartInfo.userDetails = {
|
83
|
+
"userId": this.userDetails?.userId,
|
84
|
+
"userName": this.userDetails?.contact.name,
|
85
|
+
"mobile": this.userDetails?.contact.mobile,
|
86
|
+
"email": this.userDetails?.contact.email,
|
87
|
+
};
|
88
|
+
this.restService.getUserItems(this.userDetails.userId, "CART").subscribe((response) => {
|
89
|
+
const tempUserCart = response?.data?.[0]?.orderedItems ?? [];
|
90
|
+
localStorage.setItem('cartId', response.data?.[0]?.cartId);
|
91
|
+
this.cartInfo["cartId"] = response.data?.[0]?.cartId;
|
92
|
+
if (response.data?.[0]?.orderedItems?.length > 0) {
|
93
|
+
this.storageService.addAllProductsToCart(tempUserCart).oncomplete = () => {
|
94
|
+
this.storageService.getUserCart().then((cartResponse) => {
|
95
|
+
cartResponse.onsuccess = (cartData) => {
|
96
|
+
// this.cartInfo["orderedItems"]?.forEach((item: OrderedItems)=> item.itemVariant = null);
|
97
|
+
const restResponse = this.restService.addItemToDB(this.cartInfo).toPromise();
|
98
|
+
restResponse.finally(() => {
|
99
|
+
this.cartInfo.billdetails.totalGrossValue = 0;
|
100
|
+
this.cartInfo.billdetails.totalTax = 0;
|
101
|
+
this.cartInfo.billdetails.totalNetValue = 0;
|
102
|
+
this.cartInfo.totalAmount = 0;
|
103
|
+
this.USER_CART_ITEMS = cartData.target.result;
|
104
|
+
this.USER_CART_ITEMS.forEach((item) => {
|
105
|
+
this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));
|
106
|
+
this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));
|
107
|
+
});
|
108
|
+
this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;
|
109
|
+
this.cartInfo.orderedItems = this.USER_CART_ITEMS;
|
110
|
+
this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;
|
111
|
+
this.responseData = this.cartInfo;
|
112
|
+
console.log(this.responseData);
|
113
|
+
});
|
114
|
+
};
|
115
|
+
cartResponse.onerror = (cartData) => {
|
116
|
+
this.messageService.add({ severity: 'error', summary: 'Error', detail: 'Failed to update cart details' });
|
117
|
+
};
|
118
|
+
});
|
119
|
+
};
|
120
|
+
}
|
121
|
+
else {
|
122
|
+
this.storageService.getUserCart().then((cartResponse) => {
|
123
|
+
cartResponse.onsuccess = (cartData) => {
|
124
|
+
console.log("cart Data", cartData);
|
125
|
+
this.USER_CART_ITEMS = cartData.target.result;
|
126
|
+
this.cartInfo.billdetails.totalGrossValue = 0;
|
127
|
+
this.cartInfo.billdetails.totalTax = 0;
|
128
|
+
this.cartInfo.billdetails.totalNetValue = 0;
|
129
|
+
this.cartInfo.totalAmount = 0;
|
130
|
+
this.USER_CART_ITEMS.forEach((item) => {
|
131
|
+
this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));
|
132
|
+
this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));
|
133
|
+
});
|
134
|
+
this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;
|
135
|
+
this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;
|
136
|
+
this.cartInfo.orderedItems = this.USER_CART_ITEMS;
|
137
|
+
console.log(this.responseData);
|
138
|
+
// this.cartInfo["orderedItems"]?.forEach((item: OrderedItems)=> item.itemVariant = null);
|
139
|
+
this.responseData = this.cartInfo;
|
140
|
+
this.restService.addItemToDB(this.responseData).subscribe((response) => {
|
141
|
+
localStorage.setItem('cartId', response.data?.cartId);
|
142
|
+
this.cartInfo["cartId"] = response.data?.cartId;
|
143
|
+
this.responseData["cartId"] = this.cartInfo["cartId"];
|
144
|
+
});
|
145
|
+
};
|
146
|
+
});
|
58
147
|
}
|
59
|
-
console.log("a: ", UserCart, this.responseData, response);
|
60
|
-
this.responseData = this.storageService.calculateBillingDetails();
|
61
148
|
});
|
62
149
|
}
|
63
150
|
else {
|
64
|
-
|
65
|
-
this.responseData = this.storageService.calculateBillingDetails();
|
151
|
+
this.getIndexDBData();
|
152
|
+
// this.responseData = this.storageService.calculateBillingDetails();
|
66
153
|
console.log(this.responseData);
|
67
154
|
}
|
155
|
+
console.log(this.responseData);
|
68
156
|
this.styles = this.data?.styles;
|
69
157
|
}
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
158
|
+
getIndexDBData() {
|
159
|
+
this.storageService.getUserCart().then((cartResponse) => {
|
160
|
+
console.log(cartResponse);
|
161
|
+
this.cartInfo.billdetails.totalGrossValue = 0;
|
162
|
+
this.cartInfo.billdetails.totalTax = 0;
|
163
|
+
this.cartInfo.billdetails.totalNetValue = 0;
|
164
|
+
this.cartInfo.totalAmount = 0;
|
165
|
+
cartResponse.onsuccess = (cartData) => {
|
166
|
+
this.USER_CART_ITEMS = cartData.target.result;
|
167
|
+
this.USER_CART_ITEMS.forEach((item) => {
|
168
|
+
this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));
|
169
|
+
this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));
|
170
|
+
});
|
171
|
+
this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;
|
172
|
+
this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;
|
173
|
+
this.cartInfo.orderedItems = this.USER_CART_ITEMS;
|
174
|
+
this.responseData = this.cartInfo;
|
175
|
+
};
|
176
|
+
});
|
177
|
+
}
|
79
178
|
proceedToCheckout() {
|
80
179
|
if (this.storageService.getUser()) {
|
81
180
|
this.currentTab = "ADDRESS";
|
181
|
+
if (this.isMobile) {
|
182
|
+
document.body.scrollTop = 0;
|
183
|
+
document.documentElement.scrollTop = 0;
|
184
|
+
}
|
82
185
|
}
|
83
186
|
else {
|
187
|
+
this.messageService.add({ severity: 'info', summary: 'Login', detail: 'Please login with mobile number to order' });
|
84
188
|
if (window.innerWidth <= 475)
|
85
|
-
this.
|
189
|
+
this.bottomSheet.open(AuthenticateUserComponent, { data: this.data });
|
86
190
|
else {
|
87
191
|
this.matDialog.open(AuthenticateUserComponent, {
|
88
192
|
height: '50vh',
|
89
193
|
width: '35vw',
|
90
194
|
data: this.data
|
195
|
+
}).afterClosed().subscribe((response) => {
|
196
|
+
this.userDetails = this.storageService.getUser();
|
197
|
+
this.cartInfo.userDetails = {
|
198
|
+
"userId": this.userDetails?.userId,
|
199
|
+
"userName": this.userDetails?.contact.name,
|
200
|
+
"mobile": this.userDetails?.contact.mobile,
|
201
|
+
"email": this.userDetails?.contact.email,
|
202
|
+
};
|
91
203
|
});
|
92
204
|
}
|
93
205
|
}
|
94
206
|
}
|
207
|
+
goToProductDetails(product) {
|
208
|
+
this.router.navigate(['/details'], { queryParams: { id: product.itemId, varientId: product.varientId } });
|
209
|
+
}
|
95
210
|
proceedToListPage() {
|
96
|
-
// this._eventService.redirectToPage.emit({ redirectTo: '/list'});
|
97
211
|
this.router.navigate(['/']);
|
98
212
|
}
|
99
213
|
removeItem(item) {
|
214
|
+
Swal.fire({
|
215
|
+
icon: "warning",
|
216
|
+
html: "<span>You can move </span> <b>" + item.itemName + "</b> <span>to wishlist so you can buy later.</span>",
|
217
|
+
showCancelButton: true,
|
218
|
+
confirmButtonText: "Move to wishlist",
|
219
|
+
cancelButtonText: "Delete item",
|
220
|
+
cancelButtonColor: "#928c8c",
|
221
|
+
}).then((response) => {
|
222
|
+
if (response.isConfirmed) {
|
223
|
+
this.removeItemFromCart(item);
|
224
|
+
this.moveItemToWishlist(item);
|
225
|
+
}
|
226
|
+
else if (response.isDismissed) {
|
227
|
+
this.removeItemFromCart(item);
|
228
|
+
}
|
229
|
+
});
|
230
|
+
}
|
231
|
+
moveItemToWishlist(item) {
|
232
|
+
this.cartService.addItemToFavFromCart(item);
|
233
|
+
}
|
234
|
+
removeItemFromCart(item) {
|
100
235
|
item.quantity = 0;
|
101
|
-
this.
|
102
|
-
|
103
|
-
|
104
|
-
|
236
|
+
if (this.USER_CART_ITEMS)
|
237
|
+
this.USER_CART_ITEMS = this.USER_CART_ITEMS.filter((product) => product.varientId != item.varientId);
|
238
|
+
this.cartInfo.orderedItems = this.USER_CART_ITEMS;
|
239
|
+
this.responseData = this.cartInfo;
|
240
|
+
this.cartService.addItemFromCartPage(item, this.responseData).subscribe((response) => {
|
241
|
+
this.cartInfo.billdetails.totalGrossValue = 0;
|
242
|
+
this.cartInfo.billdetails.totalTax = 0;
|
243
|
+
this.cartInfo.billdetails.totalNetValue = 0;
|
244
|
+
this.cartInfo.totalAmount = 0;
|
245
|
+
response?.data?.orderedItems.forEach((item) => {
|
246
|
+
this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));
|
247
|
+
this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));
|
248
|
+
});
|
249
|
+
this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;
|
250
|
+
this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;
|
251
|
+
this.cartInfo.orderedItems = this.USER_CART_ITEMS;
|
105
252
|
});
|
106
253
|
}
|
107
254
|
addToCart(item, type) {
|
@@ -111,25 +258,52 @@ export class CartComponent extends BaseSection {
|
|
111
258
|
else {
|
112
259
|
item.quantity -= 1;
|
113
260
|
}
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
261
|
+
if (item.quantity) {
|
262
|
+
this.cartService.addItemFromCartPage(item, this.responseData).subscribe((response) => {
|
263
|
+
this.cartInfo.billdetails.totalGrossValue = 0;
|
264
|
+
this.cartInfo.billdetails.totalTax = 0;
|
265
|
+
this.cartInfo.billdetails.totalNetValue = 0;
|
266
|
+
this.cartInfo.totalAmount = 0;
|
267
|
+
response?.data?.orderedItems.forEach((item) => {
|
268
|
+
this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));
|
269
|
+
this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));
|
270
|
+
});
|
271
|
+
this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;
|
272
|
+
this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;
|
273
|
+
this.cartInfo.orderedItems = this.USER_CART_ITEMS;
|
274
|
+
});
|
275
|
+
}
|
276
|
+
else {
|
277
|
+
this.removeItem(item);
|
278
|
+
}
|
119
279
|
}
|
120
|
-
proceedToPayment() {
|
280
|
+
async proceedToPayment() {
|
121
281
|
if (!this.storageService.getUser()) {
|
122
|
-
|
282
|
+
this.messageService.add({ severity: 'info', summary: 'Login', detail: 'Please login with mobile number to order' });
|
123
283
|
return;
|
124
284
|
}
|
125
285
|
const userDetail = this.storageService.getUser();
|
126
|
-
|
127
|
-
|
128
|
-
|
286
|
+
const address = userDetail?.addressDetailsList[this.selectedAddressIdx];
|
287
|
+
if (address?.receiverName?.length == 0) {
|
288
|
+
this.messageService.add({ severity: 'error', summary: 'Payment Failure', detail: 'Please provide address details' });
|
289
|
+
return;
|
290
|
+
}
|
291
|
+
if (localStorage.getItem("cartId"))
|
292
|
+
this.cartInfo["cartId"] = localStorage.getItem("cartId");
|
293
|
+
else {
|
294
|
+
this.messageService.add({ severity: 'info', summary: 'Please wait', detail: 'We are processing your payment', life: 2000 });
|
295
|
+
await this.restService.addItemToDB(this.cartInfo).toPromise().then((response) => {
|
296
|
+
localStorage.setItem("cartId", response.data?.cartId);
|
297
|
+
this.cartInfo["cartId"] = response.data?.cartId;
|
298
|
+
});
|
299
|
+
}
|
300
|
+
this.cartInfo["addressDetails"] = address;
|
301
|
+
const updateAddress = await this.restService.addItemToDB(this.cartInfo).toPromise();
|
129
302
|
const payload = {
|
130
|
-
"userId": userDetail.userId
|
131
|
-
"cartId":
|
132
|
-
"orderAmount": this.responseData.
|
303
|
+
"userId": userDetail.userId,
|
304
|
+
"cartId": localStorage.getItem('cartId'),
|
305
|
+
"orderAmount": Number(Number(this.responseData.totalAmount).toFixed(2)),
|
306
|
+
"isPaymentGatewayEnabled": true,
|
133
307
|
"contactDetails": {
|
134
308
|
"name": address.receiverName,
|
135
309
|
"mobile": address.receiverPhone,
|
@@ -139,16 +313,74 @@ export class CartComponent extends BaseSection {
|
|
139
313
|
};
|
140
314
|
this.restService.createPaymentToken(payload).subscribe((paymentDetails) => {
|
141
315
|
this._eventService.cashFreeEvent.emit(paymentDetails);
|
316
|
+
}, (error) => {
|
317
|
+
if (error.errorCode == 1001 || error.errorCode == 1002) {
|
318
|
+
Swal.fire({
|
319
|
+
icon: "info",
|
320
|
+
html: "<p>" + error.message.replace(/ *\([^)]*\) */g, "") + "</p>",
|
321
|
+
showCancelButton: error.errorCode == 1002,
|
322
|
+
confirmButtonText: "Remove item & Place Order",
|
323
|
+
cancelButtonText: "Reduce quantity",
|
324
|
+
cancelButtonColor: "#928c8c",
|
325
|
+
}).then(async (response) => {
|
326
|
+
this.messageService.add({ severity: 'info', summary: 'Processing', detail: 'Please wait, updaing your cart', life: 2000 });
|
327
|
+
const regExp = /{([^}]+)}/g;
|
328
|
+
const id = regExp.exec(error.message)?.[1];
|
329
|
+
let itemDetail = null;
|
330
|
+
const productDetailsAsync = await this.restService.getProductDetails(id).toPromise().then((response) => {
|
331
|
+
itemDetail = response[0];
|
332
|
+
});
|
333
|
+
if (response.isDismissed) {
|
334
|
+
this.cartInfo.orderedItems.forEach((item) => {
|
335
|
+
if (item.itemId == itemDetail?.itemId)
|
336
|
+
item.quantity = itemDetail?.itemInventory.openingStock;
|
337
|
+
});
|
338
|
+
const addItemDBAsync = await this.restService.addItemToDB(this.cartInfo).toPromise();
|
339
|
+
const addItemIndexDBAsync = await this.storageService.addAllProductsToCart(this.cartInfo.orderedItems);
|
340
|
+
}
|
341
|
+
else if (response.isConfirmed) {
|
342
|
+
this.cartInfo.orderedItems = this.cartInfo.orderedItems.filter((item) => item.itemId != itemDetail?.itemId);
|
343
|
+
const addItemDBAsync = await this.restService.addItemToDB(this.cartInfo).toPromise();
|
344
|
+
const addItemIndexDBAsync = await this.storageService.addAllProductsToCart(this.cartInfo.orderedItems);
|
345
|
+
this.proceedToPayment();
|
346
|
+
}
|
347
|
+
});
|
348
|
+
}
|
349
|
+
else {
|
350
|
+
this.messageService.add({ severity: 'error', summary: 'Payment Failure', detail: 'Please try again' });
|
351
|
+
}
|
142
352
|
});
|
143
353
|
}
|
144
|
-
|
145
|
-
|
354
|
+
addressSelected(index) {
|
355
|
+
this.selectedAddressIdx = index;
|
356
|
+
}
|
357
|
+
isItemOutOfStock(product) {
|
358
|
+
return false; // need condition
|
359
|
+
}
|
360
|
+
getKeys(object) {
|
361
|
+
if (object)
|
362
|
+
return Object.keys(object);
|
363
|
+
return [];
|
364
|
+
}
|
365
|
+
editSection() {
|
366
|
+
this._eventService.toggleEditorEvent.emit(false);
|
367
|
+
setTimeout(() => {
|
368
|
+
this._eventService.editSection.emit({ data: this.data });
|
369
|
+
}, 100);
|
146
370
|
}
|
147
371
|
get getAddressList() {
|
148
|
-
return
|
372
|
+
return this.userDetails ? [...this.userDetails?.addressDetailsList] : [];
|
373
|
+
}
|
374
|
+
get isMobile() {
|
375
|
+
return window.innerWidth <= 475;
|
376
|
+
}
|
377
|
+
get currency() {
|
378
|
+
return BUSINESS_CONSTANTS.CURRENCY;
|
149
379
|
}
|
150
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: CartComponent, deps: [{ token: i1.EventsService }, { token: i2.CartService }, { token: i3.Router }, { token: i4.RestService }, { token: i5.MatDialog }, { token: i6.StorageServiceService }, { token: i7.
|
151
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: CartComponent, isStandalone: true, selector: "simpo-cart", inputs: { data: "data", responseData: "responseData", index: "index", edit: "edit", delete: "delete" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"!isLoading\">\r\n <section class=\"total-container\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\" >\r\n <div class=\"d-flex align-items-center justify-content-center mb-4\" style=\"margin-top: 50px;\" *ngIf=\"responseData?.orderedItems?.length\">\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'BAG'}\" (click)=\"currentTab = 'BAG'\">Bag</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'ADDRESS'}\" (click)=\"currentTab = 'ADDRESS'\">Address</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'PAYMENT'}\" (click)=\"currentTab = 'PAYMENT'\">Payment</span>\r\n </div>\r\n <div class=\"cart-parent container\" *ngIf=\"(responseData?.orderedItems?.length || 0) > 0\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\r\n <ng-container [ngSwitch]=\"currentTab\">\r\n <div class=\"left-panel\" *ngSwitchCase=\"'BAG'\">\r\n <div class=\"my-bag\">\r\n My Bag <span>({{responseData?.orderedItems?.length}} Items)</span>\r\n </div>\r\n <div class=\"cart-items\">\r\n <ng-container *ngFor=\"let item of responseData?.orderedItems; let idx = index\">\r\n <div class=\"row item-parent\">\r\n <div class=\"h-100\" style=\"padding: 0px; width: fit-content;\">\r\n <img class=\"product-img\" [src]=\"item.imgUrl\" alt=\"\">\r\n </div>\r\n <div class=\"col-md-6 h-100\">\r\n <div class=\"lh-23\">\r\n <div class=\"item-name heading-large\">{{item.itemName}}</div>\r\n <div class=\"price-with-tax\">\r\n ₹ {{item.price + (item.itemTax ?? 0)}}\r\n </div>\r\n <div class=\"item-quantity\">\r\n <ng-container *ngIf=\"!isItemLoading(item.itemId)\">\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'SUBSTRACT')\">-</span>\r\n <span>{{item.quantity}}</span>\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'ADD')\">+</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"isItemLoading(item.itemId)\">\r\n <div class=\"d-flex\"> <i class=\"fa fa-spinner fa-spin\" style=\"font-size:24px; margin-right: 10px;\"></i> <span>Loading...</span></div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4 position-relative\" style=\"margin-left: auto;\">\r\n <div class=\"item-price\">₹ {{(item.price + (item.itemTax ?? 0)) * item.quantity}}</div>\r\n <div>\r\n <mat-icon class=\"delete-item\" (click)=\"removeItem(item)\">delete</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"responseData?.orderedItems?.length != (idx +1)\">\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'ADDRESS'\">\r\n <simpo-address [isCart]=\"true\" [responseData]=\"getAddressList\" [selectedAddressIdx]=\"selectedAddressIdx\"></simpo-address>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'PAYMENT'\"></div>\r\n </ng-container>\r\n <div class=\"right-panel\">\r\n <div class=\"my-bag\">\r\n Price Details\r\n </div>\r\n <div class=\"price-details\">\r\n <div class=\"price-parent-block\" *ngIf=\"responseData?.billdetails?.totalNetValue\">\r\n <div class=\"price-type\">Total Price</div>\r\n <div class=\"price-value\">₹ {{responseData.billdetails.totalNetValue}}</div>\r\n </div>\r\n <div class=\"price-parent-block\" *ngIf=\"responseData?.billdetails?.totalTax\">\r\n <div class=\"price-type\">Total Tax</div>\r\n <div class=\"price-value\">₹ {{responseData?.billdetails?.totalTax}}</div>\r\n </div>\r\n <div class=\"price-parent-block\"\r\n *ngIf=\"responseData?.billdetails?.deliveryCharges && responseData.billdetails.deliveryCharges > 0\">\r\n <div class=\"price-type\">Delivery Charge</div>\r\n <div class=\"price-value\">₹ {{responseData.billdetails.deliveryCharges}}</div>\r\n </div>\r\n <hr>\r\n <div class=\"price-parent-block\" *ngIf=\"responseData?.totalAmount\">\r\n <div class=\"price-type\" style=\"color: black;font-weight: 600;\">Total Amount</div>\r\n <div class=\"price-value\" style=\"font-weight: 600;\">₹ {{responseData.totalAmount}}</div>\r\n </div>\r\n\r\n <div class=\"button-parent\">\r\n <ng-container *ngIf=\"currentTab == 'BAG'\">\r\n <div class=\"btn\" (click)=\"proceedToCheckout()\">Checkout Cart</div>\r\n <div class=\"btn\" (click)=\"proceedToListPage()\">Continue Shopping</div>\r\n </ng-container>\r\n \r\n <ng-container *ngIf=\"currentTab == 'ADDRESS'\">\r\n <div class=\"btn\" (click)=\"proceedToPayment()\">Place Order</div>\r\n </ng-container>\r\n <!-- <div *ngFor=\"let button of data?.action?.buttons;let i = index\">\r\n <button class=\"btn\" (click)=\"i == 0 ? proceedToCheckout() : proceedToListPage()\" simpoButtonDirective [id]=\"data?.id+button.id\" [buttonStyle]=\"button?.styles\"\r\n [color]=\"styles?.background?.accentColor\">{{button?.content?.label}}</button>\r\n </div> -->\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <section class=\"empty-cart\" *ngIf=\"(responseData?.orderedItems?.length || 0) == 0\">\r\n <div>\r\n <div class=\"cart-image\">\r\n <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/107213c1716543334040empty-cart.png\" alt=\"\">\r\n </div>\r\n <div class=\"cart-text\">\r\n <div class=\"heading-medium d-flex justify-content-center\">\r\n Your cart is empty\r\n </div>\r\n <div class=\"description d-flex mt-4\">\r\n Looks like you have not added anything to your cart. Go ahead & explore top categories.\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n\r\n </section>\r\n</ng-container>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n width: '100%',\r\n height: '40vh',\r\n 'border-radius': '10px',\r\n 'position': 'relative',\r\n 'right': '5px'\r\n}\">\r\n</ngx-skeleton-loader>\r\n", styles: [".cart-parent{display:flex;margin-top:15px;gap:20px}.left-panel{width:65%}.timeline{cursor:pointer}.cart-items{padding:10px;margin-top:10px;margin-bottom:15px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029}.isActive{color:#0267c1;font-weight:600}.bar{width:150px;border-top:2px solid lightgray;margin:0 5px}.right-panel{width:35%}.my-bag{font-size:16px;font-weight:600;color:#000}.my-bag span{color:#939393}.item-parent{margin:10px 0}.lh-23{line-height:23px}.item-name{color:#141514;font-size:16px;line-height:30px;font-weight:600}.price-with-tax{font-weight:400;font-size:16px;color:#626262}.item-sku{font-weight:400;font-size:14px;color:#626262}.item-price{display:flex;justify-content:flex-end;font-weight:600;font-size:16px;color:#141514}.product-img{border-radius:5px;height:95px;width:100px;padding:0}.quantity-box{display:flex;gap:5px;align-items:center;border:1px solid #E8E8E8;width:45px;height:22px}.quantity-box input{outline:none;text-align:center;border:none;width:30px;height:100%}.quantity-box .plus{font-size:20px;position:relative;top:-3px;font-weight:500}.quantity-box .minus{font-size:30px;position:relative;top:-3px;font-weight:500}.delete-item{color:#626262;cursor:pointer}.item-quantity{margin-top:5px;display:flex;min-width:90px;max-width:fit-content;border:1px solid lightgray;justify-content:space-between;align-items:center;padding:5px 10px;border-radius:3px}.coupon{display:flex;justify-content:space-between;border:1px solid #E8E8E8;border-radius:5px;padding:10px;margin-top:10px}.apply-coupon{font-weight:500;color:#626262;font-size:15px}.coupon-desc{color:#939393;font-size:12px;font-weight:500}.apply-coupon-btn{color:#0267c1;font-size:16px;font-weight:600}.price-details{padding:10px;margin-top:10px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029;margin-bottom:15px}.price-parent-block{display:flex;justify-content:space-between;margin-top:5px}.price-type{font-weight:400;font-size:16px;color:#434443}.price-value{font-weight:500;font-size:18px;color:#141514}.button-parent{margin-top:20px;display:flex;flex-direction:column;gap:10px}hr{border:1px solid #E8E8E8}.btn{height:40px;font-size:16px!important;border:1px solid lightgray}.cursor{cursor:pointer}.delete-item{text-align:right;position:absolute;right:16px;bottom:10px}.quantity{display:flex;border:2px solid #E6E6E6;align-items:center;gap:15px;height:47px;margin-top:1rem;border-radius:5px}.quantity .plus{position:relative;left:10px;font-size:18px;font-weight:600;cursor:pointer;color:#848484}.quantity .minus{position:relative;right:15px;font-size:18px;font-weight:600;color:#848484;cursor:pointer}.quantity input{width:60px;border:none;outline:none;text-align:center}.label{color:#000}.total-container{min-height:80vh;position:relative;display:block!important}.hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.cart-image{width:13%;display:flex;margin-right:auto;margin-left:auto}.cart-image img{width:100%}.heading-medium{font-weight:600;color:#000}.description{font-size:18px;color:#7f7676;margin-left:auto;margin-right:auto;width:30%;text-align:center}@media screen and (max-width: 475px){.cart-parent{flex-direction:column}.left-panel,.right-panel{width:100%}.cart-image{width:42%}.description{width:84%}.heading-medium{font-size:28px}}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i8.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i9.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged"], outputs: ["edit"] }, { kind: "component", type: i10.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "component", type: i11.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["count", "loadingText", "appearance", "animation", "ariaLabel", "theme"] }, { kind: "directive", type: AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: ContentFitDirective, selector: "[simpoLayout]", inputs: ["simpoLayout"] }, { kind: "component", type: AddressComponent, selector: "simpo-address", inputs: ["responseData", "data", "isCart", "selectedAddressIdx"] }] }); }
|
380
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: CartComponent, deps: [{ token: i1.EventsService }, { token: i2.CartService }, { token: i3.Router }, { token: i4.RestService }, { token: i5.MatDialog }, { token: i6.StorageServiceService }, { token: i7.MessageService }, { token: i8.MatBottomSheet }], target: i0.ɵɵFactoryTarget.Component }); }
|
381
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: CartComponent, isStandalone: true, selector: "simpo-cart", inputs: { data: "data", responseData: "responseData", index: "index", edit: "edit", delete: "delete" }, providers: [MessageService], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"!isLoading\">\r\n <p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"></p-toast>\r\n\r\n <section class=\"total-container\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\" [id]=\"data?.id\" [simpoBackground]=\"styles?.background\" [attr.class]=\"isMobile ? 'py-5' : ''\" simpoHover (hovering)=\"showEditTabs($event)\" (click)=\"editSection()\" >\r\n <div class=\"d-flex align-items-center justify-content-center m-auto mb-4\" [style.marginTop.px]=\"isMobile ? '': '50'\" [style.width.%]=\"isMobile ? '90' : ''\" *ngIf=\"responseData?.orderedItems?.length\">\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'BAG'}\" (click)=\"currentTab = 'BAG'\">Bag</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'ADDRESS'}\" (click)=\"currentTab = 'ADDRESS'\">Address</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'PAYMENT'}\" style=\"cursor: auto;\">Payment</span>\r\n </div>\r\n <div class=\"cart-parent container\" *ngIf=\"(responseData?.orderedItems?.length || 0) > 0\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\r\n <ng-container [ngSwitch]=\"currentTab\">\r\n <div class=\"left-panel\" *ngSwitchCase=\"'BAG'\">\r\n <div class=\"my-bag\">\r\n My Bag <span>({{responseData?.orderedItems?.length}} Items)</span>\r\n </div>\r\n <div class=\"cart-items\">\r\n <ng-container *ngFor=\"let item of responseData?.orderedItems; let idx = index\">\r\n <div class=\"item-parent d-flex\">\r\n <div class=\"h-100\" style=\"padding: 0px; width: fit-content;\">\r\n <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" class=\"product-img\" [src]=\"item.imgUrl ?? 'https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" alt=\"\" (click)=\"goToProductDetails(item)\">\r\n </div>\r\n <div class=\"col-md-6 h-100\" [style.width.px]=\"isMobile ? '200' : ''\" style=\"margin-left: px;\">\r\n <div class=\"lh-23\">\r\n <div class=\"item-name trim-text heading-large\">{{item.itemName}}</div>\r\n <div class=\"price-with-tax\">\r\n <span [innerHTML]='currency'></span> {{(item.discountedPrice) | number: '1.0-2'}}\r\n </div>\r\n <ng-container *ngIf=\"item.itemVariant\"> \r\n <div class=\"d-flex align-items-center\" *ngFor=\"let varient of getKeys(item.itemVariant.properties)\">\r\n <div class=\"fw-bold\">{{ varient }} : </div>\r\n <!-- <div class=\"fw-normal\" style=\"margin-left: 5px; height: 13px; width: 13px; border-radius: 50%;\" *ngIf=\"varient.toLowerCase() == 'color'\" [style.backgroundColor]=\"item.itemVariant.properties[varient]\"></div> -->\r\n <div class=\"fw-normal\" style=\"margin-left: 5px;\"> {{ item.itemVariant.properties[varient] | uppercase }}</div>\r\n </div>\r\n </ng-container>\r\n <div class=\"item-quantity\">\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'SUBSTRACT')\">-</span>\r\n <span>{{item.quantity}}</span>\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'ADD')\">+</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4 position-relative\" style=\"margin-left: auto;\">\r\n <div class=\"item-price\"><span [innerHTML]='currency'></span> {{((item.discountedPrice) * item.quantity) | number: '1.0-2'}}</div>\r\n <div>\r\n <mat-icon class=\"delete-item\" (click)=\"removeItem(item)\" [style.right.px]=\"isMobile ? '5' : '0'\">delete</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"responseData?.orderedItems?.length != (idx +1)\">\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'ADDRESS'\">\r\n <simpo-address [isCart]=\"true\" [responseData]=\"getAddressList\" [data]=\"data\" (selectedAddress)=\"addressSelected($event)\"></simpo-address>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'PAYMENT'\"></div>\r\n </ng-container>\r\n <div class=\"right-panel\">\r\n <div class=\"my-bag\">\r\n Price Details\r\n </div>\r\n <div class=\"price-details\">\r\n <div class=\"price-parent-block\">\r\n <div class=\"price-type\">Total Price</div>\r\n <div class=\"price-value\"><span [innerHTML]='currency'></span> {{(responseData?.billdetails?.totalNetValue ?? 0) | number: '1.0-2'}}</div>\r\n </div>\r\n <div class=\"price-parent-block\">\r\n <div class=\"price-type\">Total Tax</div>\r\n <div class=\"price-value\"><span [innerHTML]='currency'></span> {{(responseData?.billdetails?.totalTax ?? 0) | number: '1.0-2'}}</div>\r\n </div>\r\n <div class=\"price-parent-block\"\r\n *ngIf=\"responseData?.billdetails?.deliveryCharges && responseData.billdetails.deliveryCharges > 0\">\r\n <div class=\"price-type\">Delivery Charge</div>\r\n <div class=\"price-value\"><span [innerHtml]='currency'></span> {{responseData.billdetails.deliveryCharges | number: '1.0-2'}}</div>\r\n </div>\r\n <hr>\r\n <div class=\"price-parent-block\">\r\n <div class=\"price-type\" style=\"color: black;font-weight: 600;\">Total Amount</div>\r\n <div class=\"price-value\" style=\"font-weight: 600;\"><span [innerHtml]='currency'></span> {{(responseData?.totalAmount ?? 0) | number: '1.0-2'}}</div>\r\n </div>\r\n\r\n <div class=\"button-parent\">\r\n <ng-container *ngIf=\"currentTab == 'BAG'\">\r\n <div class=\"btn mobile-fixed\" (click)=\"proceedToCheckout()\" [style.backgroundColor]=\"data?.styles?.background?.accentColor\" [style.color]=\"data?.styles?.background?.color\">{{data?.action?.buttons?.[0]?.content?.label ?? 'Checkout Cart'}}</div>\r\n <div class=\"btn\" (click)=\"proceedToListPage()\" simpoButtonDirective [buttonStyle]=\"data?.action?.buttons?.[1]?.styles\" [color]=\"data?.styles?.background?.accentColor\">{{data?.action?.buttons?.[1]?.content?.label ?? 'Continue Shopping'}}</div>\r\n </ng-container>\r\n \r\n <ng-container *ngIf=\"currentTab == 'ADDRESS'\">\r\n <div class=\"btn mobile-fixed\" (click)=\"proceedToPayment()\" [style.backgroundColor]=\"data?.styles?.background?.accentColor\" [style.color]=\"data?.styles?.background?.color\">{{data?.action?.buttons?.[2]?.content?.label ?? 'Place Order'}}</div>\r\n </ng-container>\r\n <!-- <div *ngFor=\"let button of data?.action?.buttons;let i = index\">\r\n <button class=\"btn\" (click)=\"i == 0 ? proceedToCheckout() : proceedToListPage()\" simpoButtonDirective [id]=\"data?.id+button.id\" [buttonStyle]=\"button?.styles\"\r\n [color]=\"styles?.background?.accentColor\">{{button?.content?.label}}</button>\r\n </div> -->\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <section class=\"empty-cart\" *ngIf=\"(responseData?.orderedItems?.length || 0) == 0\">\r\n <div>\r\n <div class=\"cart-image\">\r\n <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" [src]=\"data?.content?.image?.url\" [alt]=\"data?.content?.image?.altText\">\r\n </div>\r\n <div class=\"cart-text\">\r\n <ng-container *ngFor=\"let text of data?.content?.inputText\">\r\n <div class=\"d-flex justify-content-center\" [ngClass]=\"{'heading-medium': text.label == 'Heading', 'description': text.label == 'Text'}\">{{text.value}}</div>\r\n </ng-container>\r\n <!-- <div class=\"description d-flex mt-4\">\r\n Looks like you have not added anything to your cart. Go ahead & explore top categories.\r\n </div> -->\r\n </div>\r\n </div>\r\n </section>\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\" [isEcommerce]=\"true\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n\r\n </section>\r\n</ng-container>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n width: '100%',\r\n height: '40vh',\r\n 'border-radius': '10px',\r\n 'position': 'relative',\r\n 'right': '5px'\r\n}\">\r\n</ngx-skeleton-loader>\r\n", styles: [".cart-parent{display:flex;margin-top:15px;gap:20px}.left-panel{width:65%}.timeline{cursor:pointer}.cart-items{padding:10px;margin-top:10px;margin-bottom:15px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029}.isActive{color:#0267c1;font-weight:600}.bar{width:150px;border-top:2px solid lightgray;margin:0 5px}.right-panel{width:35%}.my-bag{font-size:16px;font-weight:600;color:#000;margin-left:8px}.my-bag span{color:#939393}.item-parent{margin:10px 0}.lh-23{line-height:23px}.item-name{color:#141514;font-size:16px;line-height:30px;font-weight:600}.price-with-tax{font-weight:400;font-size:16px;color:#626262}.item-sku{font-weight:400;font-size:14px;color:#626262}.item-price{display:flex;justify-content:flex-end;font-weight:600;font-size:16px;color:#141514}.product-img{border-radius:5px;height:100%;width:110px;padding:0;cursor:pointer}.quantity-box{display:flex;gap:5px;align-items:center;border:1px solid #E8E8E8;width:45px;height:22px}.quantity-box input{outline:none;text-align:center;border:none;width:30px;height:100%}.quantity-box .plus{font-size:20px;position:relative;top:-3px;font-weight:500}.quantity-box .minus{font-size:30px;position:relative;top:-3px;font-weight:500}.delete-item{color:#df2e2e;cursor:pointer}.item-quantity{margin-top:5px;display:flex;min-width:90px;max-width:fit-content;border:1px solid lightgray;justify-content:space-between;align-items:center;padding:5px 10px;border-radius:3px}.coupon{display:flex;justify-content:space-between;border:1px solid #E8E8E8;border-radius:5px;padding:10px;margin-top:10px}.apply-coupon{font-weight:500;color:#626262;font-size:15px}.coupon-desc{color:#939393;font-size:12px;font-weight:500}.apply-coupon-btn{color:#0267c1;font-size:16px;font-weight:600}.price-details{padding:10px;margin-top:10px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029;margin-bottom:15px}.price-parent-block{display:flex;justify-content:space-between;margin-top:5px}.price-type{font-weight:400;font-size:16px;color:#434443}.price-value{font-weight:500;font-size:18px;color:#141514}.button-parent{margin-top:20px;display:flex;flex-direction:column;gap:10px}hr{border:1px solid #E8E8E8}.btn{height:40px;font-size:16px!important;border:1px solid lightgray}.cursor{cursor:pointer}.delete-item{text-align:right;position:absolute;right:16px;bottom:10px}.quantity{display:flex;border:2px solid #E6E6E6;align-items:center;gap:15px;height:47px;margin-top:1rem;border-radius:5px}.quantity .plus{position:relative;left:10px;font-size:18px;font-weight:600;cursor:pointer;color:#848484}.quantity .minus{position:relative;right:15px;font-size:18px;font-weight:600;color:#848484;cursor:pointer}.quantity input{width:60px;border:none;outline:none;text-align:center}.label{color:#000}.total-container{min-height:80vh;position:relative;display:block!important}.hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.cart-image{width:13%;display:flex;margin-right:auto;margin-left:auto}.cart-image img{width:100%}.heading-medium{font-weight:600;color:#000}.description{font-size:18px;color:#7f7676;margin-left:auto;margin-right:auto;width:30%;text-align:center}@media screen and (max-width: 475px){.cart-parent{flex-direction:column}.left-panel{width:100%}.right-panel{width:100%;background:#fff;z-index:1000}.cart-image{width:42%}.description{width:84%}.heading-medium{font-size:28px}.item-price{white-space:nowrap;display:unset}.product-img{width:82px}[class*=col-md]{padding-left:5px!important;padding-right:5px!important}.mobile-fixed{height:40px;font-size:16px!important;border:1px solid lightgray;width:100%;position:relative;bottom:10px}}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: i9.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i9.DecimalPipe, name: "number" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatDialogModule }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i10.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged", "isEcommerce"], outputs: ["edit"] }, { kind: "component", type: i11.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "component", type: i12.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["count", "loadingText", "appearance", "animation", "ariaLabel", "theme"] }, { kind: "directive", type: BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "ngmodule", type: MatBottomSheetModule }, { kind: "directive", type:
|
382
|
+
//DIRECTIVE
|
383
|
+
ButtonDirectiveDirective, selector: "[simpoButtonDirective]", inputs: ["buttonStyle", "color", "scrollValue"] }, { kind: "directive", type: AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: ContentFitDirective, selector: "[simpoLayout]", inputs: ["simpoLayout"] }, { kind: "directive", type: HoverDirective, selector: "[simpoHover]", outputs: ["hovering"] }, { kind: "component", type: AddressComponent, selector: "simpo-address", inputs: ["responseData", "data", "index", "edit", "delete", "isCart"], outputs: ["selectedAddress"] }, { kind: "ngmodule", type: ToastModule }, { kind: "component", type: i13.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "life", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }] }); }
|
152
384
|
}
|
153
385
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: CartComponent, decorators: [{
|
154
386
|
type: Component,
|
@@ -158,14 +390,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
158
390
|
MatIcon,
|
159
391
|
MatDialogModule,
|
160
392
|
SimpoComponentModule,
|
393
|
+
BackgroundDirective,
|
394
|
+
MatBottomSheetModule,
|
161
395
|
//DIRECTIVE
|
162
396
|
ButtonDirectiveDirective,
|
163
397
|
AnimationDirective,
|
164
398
|
ContentFitDirective,
|
165
399
|
HoverDirective,
|
166
400
|
AddressComponent,
|
167
|
-
], template: "<ng-container *ngIf=\"!isLoading\">\r\n <section class=\"total-container\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\" >\r\n <div class=\"d-flex align-items-center justify-content-center mb-4\" style=\"margin-top: 50px;\" *ngIf=\"responseData?.orderedItems?.length\">\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'BAG'}\" (click)=\"currentTab = 'BAG'\">Bag</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'ADDRESS'}\" (click)=\"currentTab = 'ADDRESS'\">Address</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'PAYMENT'}\" (click)=\"currentTab = 'PAYMENT'\">Payment</span>\r\n </div>\r\n <div class=\"cart-parent container\" *ngIf=\"(responseData?.orderedItems?.length || 0) > 0\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\r\n <ng-container [ngSwitch]=\"currentTab\">\r\n <div class=\"left-panel\" *ngSwitchCase=\"'BAG'\">\r\n <div class=\"my-bag\">\r\n My Bag <span>({{responseData?.orderedItems?.length}} Items)</span>\r\n </div>\r\n <div class=\"cart-items\">\r\n <ng-container *ngFor=\"let item of responseData?.orderedItems; let idx = index\">\r\n <div class=\"row item-parent\">\r\n <div class=\"h-100\" style=\"padding: 0px; width: fit-content;\">\r\n <img class=\"product-img\" [src]=\"item.imgUrl\" alt=\"\">\r\n </div>\r\n <div class=\"col-md-6 h-100\">\r\n <div class=\"lh-23\">\r\n <div class=\"item-name heading-large\">{{item.itemName}}</div>\r\n <div class=\"price-with-tax\">\r\n ₹ {{item.price + (item.itemTax ?? 0)}}\r\n </div>\r\n <div class=\"item-quantity\">\r\n <ng-container *ngIf=\"!isItemLoading(item.itemId)\">\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'SUBSTRACT')\">-</span>\r\n <span>{{item.quantity}}</span>\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'ADD')\">+</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"isItemLoading(item.itemId)\">\r\n <div class=\"d-flex\"> <i class=\"fa fa-spinner fa-spin\" style=\"font-size:24px; margin-right: 10px;\"></i> <span>Loading...</span></div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4 position-relative\" style=\"margin-left: auto;\">\r\n <div class=\"item-price\">₹ {{(item.price + (item.itemTax ?? 0)) * item.quantity}}</div>\r\n <div>\r\n <mat-icon class=\"delete-item\" (click)=\"removeItem(item)\">delete</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"responseData?.orderedItems?.length != (idx +1)\">\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'ADDRESS'\">\r\n <simpo-address [isCart]=\"true\" [responseData]=\"getAddressList\" [selectedAddressIdx]=\"selectedAddressIdx\"></simpo-address>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'PAYMENT'\"></div>\r\n </ng-container>\r\n <div class=\"right-panel\">\r\n <div class=\"my-bag\">\r\n Price Details\r\n </div>\r\n <div class=\"price-details\">\r\n <div class=\"price-parent-block\" *ngIf=\"responseData?.billdetails?.totalNetValue\">\r\n <div class=\"price-type\">Total Price</div>\r\n <div class=\"price-value\">₹ {{responseData.billdetails.totalNetValue}}</div>\r\n </div>\r\n <div class=\"price-parent-block\" *ngIf=\"responseData?.billdetails?.totalTax\">\r\n <div class=\"price-type\">Total Tax</div>\r\n <div class=\"price-value\">₹ {{responseData?.billdetails?.totalTax}}</div>\r\n </div>\r\n <div class=\"price-parent-block\"\r\n *ngIf=\"responseData?.billdetails?.deliveryCharges && responseData.billdetails.deliveryCharges > 0\">\r\n <div class=\"price-type\">Delivery Charge</div>\r\n <div class=\"price-value\">₹ {{responseData.billdetails.deliveryCharges}}</div>\r\n </div>\r\n <hr>\r\n <div class=\"price-parent-block\" *ngIf=\"responseData?.totalAmount\">\r\n <div class=\"price-type\" style=\"color: black;font-weight: 600;\">Total Amount</div>\r\n <div class=\"price-value\" style=\"font-weight: 600;\">₹ {{responseData.totalAmount}}</div>\r\n </div>\r\n\r\n <div class=\"button-parent\">\r\n <ng-container *ngIf=\"currentTab == 'BAG'\">\r\n <div class=\"btn\" (click)=\"proceedToCheckout()\">Checkout Cart</div>\r\n <div class=\"btn\" (click)=\"proceedToListPage()\">Continue Shopping</div>\r\n </ng-container>\r\n \r\n <ng-container *ngIf=\"currentTab == 'ADDRESS'\">\r\n <div class=\"btn\" (click)=\"proceedToPayment()\">Place Order</div>\r\n </ng-container>\r\n <!-- <div *ngFor=\"let button of data?.action?.buttons;let i = index\">\r\n <button class=\"btn\" (click)=\"i == 0 ? proceedToCheckout() : proceedToListPage()\" simpoButtonDirective [id]=\"data?.id+button.id\" [buttonStyle]=\"button?.styles\"\r\n [color]=\"styles?.background?.accentColor\">{{button?.content?.label}}</button>\r\n </div> -->\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <section class=\"empty-cart\" *ngIf=\"(responseData?.orderedItems?.length || 0) == 0\">\r\n <div>\r\n <div class=\"cart-image\">\r\n <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/107213c1716543334040empty-cart.png\" alt=\"\">\r\n </div>\r\n <div class=\"cart-text\">\r\n <div class=\"heading-medium d-flex justify-content-center\">\r\n Your cart is empty\r\n </div>\r\n <div class=\"description d-flex mt-4\">\r\n Looks like you have not added anything to your cart. Go ahead & explore top categories.\r\n </div>\r\n </div>\r\n </div>\r\n </section>\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n\r\n </section>\r\n</ng-container>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n width: '100%',\r\n height: '40vh',\r\n 'border-radius': '10px',\r\n 'position': 'relative',\r\n 'right': '5px'\r\n}\">\r\n</ngx-skeleton-loader>\r\n", styles: [".cart-parent{display:flex;margin-top:15px;gap:20px}.left-panel{width:65%}.timeline{cursor:pointer}.cart-items{padding:10px;margin-top:10px;margin-bottom:15px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029}.isActive{color:#0267c1;font-weight:600}.bar{width:150px;border-top:2px solid lightgray;margin:0 5px}.right-panel{width:35%}.my-bag{font-size:16px;font-weight:600;color:#000}.my-bag span{color:#939393}.item-parent{margin:10px 0}.lh-23{line-height:23px}.item-name{color:#141514;font-size:16px;line-height:30px;font-weight:600}.price-with-tax{font-weight:400;font-size:16px;color:#626262}.item-sku{font-weight:400;font-size:14px;color:#626262}.item-price{display:flex;justify-content:flex-end;font-weight:600;font-size:16px;color:#141514}.product-img{border-radius:5px;height:95px;width:100px;padding:0}.quantity-box{display:flex;gap:5px;align-items:center;border:1px solid #E8E8E8;width:45px;height:22px}.quantity-box input{outline:none;text-align:center;border:none;width:30px;height:100%}.quantity-box .plus{font-size:20px;position:relative;top:-3px;font-weight:500}.quantity-box .minus{font-size:30px;position:relative;top:-3px;font-weight:500}.delete-item{color:#626262;cursor:pointer}.item-quantity{margin-top:5px;display:flex;min-width:90px;max-width:fit-content;border:1px solid lightgray;justify-content:space-between;align-items:center;padding:5px 10px;border-radius:3px}.coupon{display:flex;justify-content:space-between;border:1px solid #E8E8E8;border-radius:5px;padding:10px;margin-top:10px}.apply-coupon{font-weight:500;color:#626262;font-size:15px}.coupon-desc{color:#939393;font-size:12px;font-weight:500}.apply-coupon-btn{color:#0267c1;font-size:16px;font-weight:600}.price-details{padding:10px;margin-top:10px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029;margin-bottom:15px}.price-parent-block{display:flex;justify-content:space-between;margin-top:5px}.price-type{font-weight:400;font-size:16px;color:#434443}.price-value{font-weight:500;font-size:18px;color:#141514}.button-parent{margin-top:20px;display:flex;flex-direction:column;gap:10px}hr{border:1px solid #E8E8E8}.btn{height:40px;font-size:16px!important;border:1px solid lightgray}.cursor{cursor:pointer}.delete-item{text-align:right;position:absolute;right:16px;bottom:10px}.quantity{display:flex;border:2px solid #E6E6E6;align-items:center;gap:15px;height:47px;margin-top:1rem;border-radius:5px}.quantity .plus{position:relative;left:10px;font-size:18px;font-weight:600;cursor:pointer;color:#848484}.quantity .minus{position:relative;right:15px;font-size:18px;font-weight:600;color:#848484;cursor:pointer}.quantity input{width:60px;border:none;outline:none;text-align:center}.label{color:#000}.total-container{min-height:80vh;position:relative;display:block!important}.hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.cart-image{width:13%;display:flex;margin-right:auto;margin-left:auto}.cart-image img{width:100%}.heading-medium{font-weight:600;color:#000}.description{font-size:18px;color:#7f7676;margin-left:auto;margin-right:auto;width:30%;text-align:center}@media screen and (max-width: 475px){.cart-parent{flex-direction:column}.left-panel,.right-panel{width:100%}.cart-image{width:42%}.description{width:84%}.heading-medium{font-size:28px}}\n"] }]
|
168
|
-
}], ctorParameters: () => [{ type: i1.EventsService }, { type: i2.CartService }, { type: i3.Router }, { type: i4.RestService }, { type: i5.MatDialog }, { type: i6.StorageServiceService }, { type: i7.CookieService }], propDecorators: { data: [{
|
401
|
+
ToastModule
|
402
|
+
], providers: [MessageService], template: "<ng-container *ngIf=\"!isLoading\">\r\n <p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"></p-toast>\r\n\r\n <section class=\"total-container\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\" [id]=\"data?.id\" [simpoBackground]=\"styles?.background\" [attr.class]=\"isMobile ? 'py-5' : ''\" simpoHover (hovering)=\"showEditTabs($event)\" (click)=\"editSection()\" >\r\n <div class=\"d-flex align-items-center justify-content-center m-auto mb-4\" [style.marginTop.px]=\"isMobile ? '': '50'\" [style.width.%]=\"isMobile ? '90' : ''\" *ngIf=\"responseData?.orderedItems?.length\">\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'BAG'}\" (click)=\"currentTab = 'BAG'\">Bag</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'ADDRESS'}\" (click)=\"currentTab = 'ADDRESS'\">Address</span>\r\n <div class=\"bar\"></div>\r\n <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'PAYMENT'}\" style=\"cursor: auto;\">Payment</span>\r\n </div>\r\n <div class=\"cart-parent container\" *ngIf=\"(responseData?.orderedItems?.length || 0) > 0\" [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\r\n <ng-container [ngSwitch]=\"currentTab\">\r\n <div class=\"left-panel\" *ngSwitchCase=\"'BAG'\">\r\n <div class=\"my-bag\">\r\n My Bag <span>({{responseData?.orderedItems?.length}} Items)</span>\r\n </div>\r\n <div class=\"cart-items\">\r\n <ng-container *ngFor=\"let item of responseData?.orderedItems; let idx = index\">\r\n <div class=\"item-parent d-flex\">\r\n <div class=\"h-100\" style=\"padding: 0px; width: fit-content;\">\r\n <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" class=\"product-img\" [src]=\"item.imgUrl ?? 'https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" alt=\"\" (click)=\"goToProductDetails(item)\">\r\n </div>\r\n <div class=\"col-md-6 h-100\" [style.width.px]=\"isMobile ? '200' : ''\" style=\"margin-left: px;\">\r\n <div class=\"lh-23\">\r\n <div class=\"item-name trim-text heading-large\">{{item.itemName}}</div>\r\n <div class=\"price-with-tax\">\r\n <span [innerHTML]='currency'></span> {{(item.discountedPrice) | number: '1.0-2'}}\r\n </div>\r\n <ng-container *ngIf=\"item.itemVariant\"> \r\n <div class=\"d-flex align-items-center\" *ngFor=\"let varient of getKeys(item.itemVariant.properties)\">\r\n <div class=\"fw-bold\">{{ varient }} : </div>\r\n <!-- <div class=\"fw-normal\" style=\"margin-left: 5px; height: 13px; width: 13px; border-radius: 50%;\" *ngIf=\"varient.toLowerCase() == 'color'\" [style.backgroundColor]=\"item.itemVariant.properties[varient]\"></div> -->\r\n <div class=\"fw-normal\" style=\"margin-left: 5px;\"> {{ item.itemVariant.properties[varient] | uppercase }}</div>\r\n </div>\r\n </ng-container>\r\n <div class=\"item-quantity\">\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'SUBSTRACT')\">-</span>\r\n <span>{{item.quantity}}</span>\r\n <span class=\"cursor\" (click)=\"addToCart(item, 'ADD')\">+</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4 position-relative\" style=\"margin-left: auto;\">\r\n <div class=\"item-price\"><span [innerHTML]='currency'></span> {{((item.discountedPrice) * item.quantity) | number: '1.0-2'}}</div>\r\n <div>\r\n <mat-icon class=\"delete-item\" (click)=\"removeItem(item)\" [style.right.px]=\"isMobile ? '5' : '0'\">delete</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"responseData?.orderedItems?.length != (idx +1)\">\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'ADDRESS'\">\r\n <simpo-address [isCart]=\"true\" [responseData]=\"getAddressList\" [data]=\"data\" (selectedAddress)=\"addressSelected($event)\"></simpo-address>\r\n </div>\r\n <div class=\"left-panel\" *ngSwitchCase=\"'PAYMENT'\"></div>\r\n </ng-container>\r\n <div class=\"right-panel\">\r\n <div class=\"my-bag\">\r\n Price Details\r\n </div>\r\n <div class=\"price-details\">\r\n <div class=\"price-parent-block\">\r\n <div class=\"price-type\">Total Price</div>\r\n <div class=\"price-value\"><span [innerHTML]='currency'></span> {{(responseData?.billdetails?.totalNetValue ?? 0) | number: '1.0-2'}}</div>\r\n </div>\r\n <div class=\"price-parent-block\">\r\n <div class=\"price-type\">Total Tax</div>\r\n <div class=\"price-value\"><span [innerHTML]='currency'></span> {{(responseData?.billdetails?.totalTax ?? 0) | number: '1.0-2'}}</div>\r\n </div>\r\n <div class=\"price-parent-block\"\r\n *ngIf=\"responseData?.billdetails?.deliveryCharges && responseData.billdetails.deliveryCharges > 0\">\r\n <div class=\"price-type\">Delivery Charge</div>\r\n <div class=\"price-value\"><span [innerHtml]='currency'></span> {{responseData.billdetails.deliveryCharges | number: '1.0-2'}}</div>\r\n </div>\r\n <hr>\r\n <div class=\"price-parent-block\">\r\n <div class=\"price-type\" style=\"color: black;font-weight: 600;\">Total Amount</div>\r\n <div class=\"price-value\" style=\"font-weight: 600;\"><span [innerHtml]='currency'></span> {{(responseData?.totalAmount ?? 0) | number: '1.0-2'}}</div>\r\n </div>\r\n\r\n <div class=\"button-parent\">\r\n <ng-container *ngIf=\"currentTab == 'BAG'\">\r\n <div class=\"btn mobile-fixed\" (click)=\"proceedToCheckout()\" [style.backgroundColor]=\"data?.styles?.background?.accentColor\" [style.color]=\"data?.styles?.background?.color\">{{data?.action?.buttons?.[0]?.content?.label ?? 'Checkout Cart'}}</div>\r\n <div class=\"btn\" (click)=\"proceedToListPage()\" simpoButtonDirective [buttonStyle]=\"data?.action?.buttons?.[1]?.styles\" [color]=\"data?.styles?.background?.accentColor\">{{data?.action?.buttons?.[1]?.content?.label ?? 'Continue Shopping'}}</div>\r\n </ng-container>\r\n \r\n <ng-container *ngIf=\"currentTab == 'ADDRESS'\">\r\n <div class=\"btn mobile-fixed\" (click)=\"proceedToPayment()\" [style.backgroundColor]=\"data?.styles?.background?.accentColor\" [style.color]=\"data?.styles?.background?.color\">{{data?.action?.buttons?.[2]?.content?.label ?? 'Place Order'}}</div>\r\n </ng-container>\r\n <!-- <div *ngFor=\"let button of data?.action?.buttons;let i = index\">\r\n <button class=\"btn\" (click)=\"i == 0 ? proceedToCheckout() : proceedToListPage()\" simpoButtonDirective [id]=\"data?.id+button.id\" [buttonStyle]=\"button?.styles\"\r\n [color]=\"styles?.background?.accentColor\">{{button?.content?.label}}</button>\r\n </div> -->\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <section class=\"empty-cart\" *ngIf=\"(responseData?.orderedItems?.length || 0) == 0\">\r\n <div>\r\n <div class=\"cart-image\">\r\n <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" [src]=\"data?.content?.image?.url\" [alt]=\"data?.content?.image?.altText\">\r\n </div>\r\n <div class=\"cart-text\">\r\n <ng-container *ngFor=\"let text of data?.content?.inputText\">\r\n <div class=\"d-flex justify-content-center\" [ngClass]=\"{'heading-medium': text.label == 'Heading', 'description': text.label == 'Text'}\">{{text.value}}</div>\r\n </ng-container>\r\n <!-- <div class=\"description d-flex mt-4\">\r\n Looks like you have not added anything to your cart. Go ahead & explore top categories.\r\n </div> -->\r\n </div>\r\n </div>\r\n </section>\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\" [isEcommerce]=\"true\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n\r\n </section>\r\n</ng-container>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n width: '100%',\r\n height: '40vh',\r\n 'border-radius': '10px',\r\n 'position': 'relative',\r\n 'right': '5px'\r\n}\">\r\n</ngx-skeleton-loader>\r\n", styles: [".cart-parent{display:flex;margin-top:15px;gap:20px}.left-panel{width:65%}.timeline{cursor:pointer}.cart-items{padding:10px;margin-top:10px;margin-bottom:15px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029}.isActive{color:#0267c1;font-weight:600}.bar{width:150px;border-top:2px solid lightgray;margin:0 5px}.right-panel{width:35%}.my-bag{font-size:16px;font-weight:600;color:#000;margin-left:8px}.my-bag span{color:#939393}.item-parent{margin:10px 0}.lh-23{line-height:23px}.item-name{color:#141514;font-size:16px;line-height:30px;font-weight:600}.price-with-tax{font-weight:400;font-size:16px;color:#626262}.item-sku{font-weight:400;font-size:14px;color:#626262}.item-price{display:flex;justify-content:flex-end;font-weight:600;font-size:16px;color:#141514}.product-img{border-radius:5px;height:100%;width:110px;padding:0;cursor:pointer}.quantity-box{display:flex;gap:5px;align-items:center;border:1px solid #E8E8E8;width:45px;height:22px}.quantity-box input{outline:none;text-align:center;border:none;width:30px;height:100%}.quantity-box .plus{font-size:20px;position:relative;top:-3px;font-weight:500}.quantity-box .minus{font-size:30px;position:relative;top:-3px;font-weight:500}.delete-item{color:#df2e2e;cursor:pointer}.item-quantity{margin-top:5px;display:flex;min-width:90px;max-width:fit-content;border:1px solid lightgray;justify-content:space-between;align-items:center;padding:5px 10px;border-radius:3px}.coupon{display:flex;justify-content:space-between;border:1px solid #E8E8E8;border-radius:5px;padding:10px;margin-top:10px}.apply-coupon{font-weight:500;color:#626262;font-size:15px}.coupon-desc{color:#939393;font-size:12px;font-weight:500}.apply-coupon-btn{color:#0267c1;font-size:16px;font-weight:600}.price-details{padding:10px;margin-top:10px;border-radius:5px;box-shadow:0 0 1px #28293d14,0 0 2px #60617029;margin-bottom:15px}.price-parent-block{display:flex;justify-content:space-between;margin-top:5px}.price-type{font-weight:400;font-size:16px;color:#434443}.price-value{font-weight:500;font-size:18px;color:#141514}.button-parent{margin-top:20px;display:flex;flex-direction:column;gap:10px}hr{border:1px solid #E8E8E8}.btn{height:40px;font-size:16px!important;border:1px solid lightgray}.cursor{cursor:pointer}.delete-item{text-align:right;position:absolute;right:16px;bottom:10px}.quantity{display:flex;border:2px solid #E6E6E6;align-items:center;gap:15px;height:47px;margin-top:1rem;border-radius:5px}.quantity .plus{position:relative;left:10px;font-size:18px;font-weight:600;cursor:pointer;color:#848484}.quantity .minus{position:relative;right:15px;font-size:18px;font-weight:600;color:#848484;cursor:pointer}.quantity input{width:60px;border:none;outline:none;text-align:center}.label{color:#000}.total-container{min-height:80vh;position:relative;display:block!important}.hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.cart-image{width:13%;display:flex;margin-right:auto;margin-left:auto}.cart-image img{width:100%}.heading-medium{font-weight:600;color:#000}.description{font-size:18px;color:#7f7676;margin-left:auto;margin-right:auto;width:30%;text-align:center}@media screen and (max-width: 475px){.cart-parent{flex-direction:column}.left-panel{width:100%}.right-panel{width:100%;background:#fff;z-index:1000}.cart-image{width:42%}.description{width:84%}.heading-medium{font-size:28px}.item-price{white-space:nowrap;display:unset}.product-img{width:82px}[class*=col-md]{padding-left:5px!important;padding-right:5px!important}.mobile-fixed{height:40px;font-size:16px!important;border:1px solid lightgray;width:100%;position:relative;bottom:10px}}\n"] }]
|
403
|
+
}], ctorParameters: () => [{ type: i1.EventsService }, { type: i2.CartService }, { type: i3.Router }, { type: i4.RestService }, { type: i5.MatDialog }, { type: i6.StorageServiceService }, { type: i7.MessageService }, { type: i8.MatBottomSheet }], propDecorators: { data: [{
|
169
404
|
type: Input
|
170
405
|
}], responseData: [{
|
171
406
|
type: Input
|
@@ -176,4 +411,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
176
411
|
}], delete: [{
|
177
412
|
type: Input
|
178
413
|
}] } });
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cart.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/cart/cart.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/cart/cart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { Address, CartSectionModal, CartSectionStylesModel } from './cart.modal';\r\nimport { Cart } from '../../styles/cart.modal';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { AnimationDirective } from '../../../directive/animation-directive';\r\nimport { HoverDirective } from '../../../directive/hover-element-directive';\r\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport BaseSection from '../../../sections/BaseSection';\r\nimport { EventsService } from '.././../../services/events.service';\r\nimport UserCart from './../../json/user-cart.json';\r\nimport UserInfo from './../../json/user-details.json';\r\nimport { CartService } from '../../../services/cart.service';\r\nimport { AddressComponent } from \"../address/address.component\";\r\nimport { Router } from '@angular/router';\r\nimport { AuthenticateUserComponent } from '../authenticate-user/authenticate-user.component';\r\nimport { MatDialog, MatDialogModule } from '@angular/material/dialog';\r\nimport { RestService } from \"../../../services/rest.service\";\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\nimport { CookieService } from 'ngx-cookie-service';\r\nimport { User } from '../../styles/user.modal';\r\n@Component({\r\n  selector: 'simpo-cart',\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule, \r\n    CommonModule,\r\n    MatIcon,\r\n    MatDialogModule,\r\n    SimpoComponentModule,\r\n    //DIRECTIVE\r\n    ButtonDirectiveDirective,\r\n    AnimationDirective,\r\n    ContentFitDirective,\r\n    HoverDirective, \r\n    AddressComponent,\r\n\r\n  ],\r\n  templateUrl: './cart.component.html',\r\n  styleUrl: './cart.component.css'\r\n})\r\nexport class CartComponent extends BaseSection{\r\n  @Input() data?: CartSectionModal;\r\n  @Input() responseData?: any;\r\n  @Input() index? : number;\r\n  @Input() edit? : boolean;\r\n  @Input() delete? : boolean;\r\n  isLoading: boolean = false;\r\n\r\n  selectedAddressIdx: number = -1;\r\n  styles?: CartSectionStylesModel;\r\n  public currentTab: 'BAG' | 'ADDRESS' | 'PAYMENT' = \"BAG\";\r\n\r\n  constructor(\r\n    private readonly _eventService : EventsService,\r\n    private readonly cartService: CartService,\r\n    private readonly router: Router,\r\n    private readonly restService: RestService,\r\n    private readonly matDialog: MatDialog,\r\n    private readonly storageService: StorageServiceService,\r\n    private readonly cookieService: CookieService\r\n  ){\r\n    super()\r\n  }\r\n\r\n  private loadingItems: string[] = [];\r\n\r\n  ngOnInit(){\r\n    this._eventService.showLoadingScreen.subscribe((response)=> {\r\n      this.isLoading = response;\r\n    })\r\n      if (this.storageService.getUser()) {\r\n        const userDetails = this.storageService.getUser() as User;\r\n        console.log(\"user deatils\", userDetails);\r\n          UserInfo.user.addressDetailsList = userDetails.addressDetailsList as never;\r\n          UserCart.userDetails = {...UserCart.userDetails, ...UserInfo.user.contact, userId: userDetails.userId};\r\n          this.cartService.storeDataToServer().subscribe((response: any)=> {\r\n            console.log(\"a: \", UserCart, this.responseData, response);\r\n            if (response[0].data) {\r\n              UserCart.billdetails = response[0].data.billdetails;\r\n              UserCart.cartId = response[0].data.cartId;\r\n              UserCart.orderedItems = response[0].data.orderedItems;\r\n            }\r\n            console.log(\"a: \", UserCart, this.responseData, response);\r\n            this.responseData = this.storageService.calculateBillingDetails();\r\n          })\r\n        } else {\r\n          console.log(\"B\");\r\n          this.responseData = this.storageService.calculateBillingDetails();\r\n          console.log(this.responseData);\r\n        }\r\n        this.styles = this.data?.styles;\r\n    }\r\n  // userDetails: any;\r\n  // getUserInfo() {\r\n  //   const userId = \"dc915bd4-fa6f-446e-bce2-440b6804af22\";\r\n  //   \r\n  //   return this.restService.getUserInfo(userId).subscribe((response: any)=> {\r\n  //     this.userDetails = response.data;\r\n  //     \r\n  //   })\r\n  // }\r\n\r\n  proceedToCheckout(){\r\n    if(this.storageService.getUser()){\r\n      this.currentTab = \"ADDRESS\";  \r\n    } else {\r\n        if (window.innerWidth <= 475)\r\n          this.router.navigate(['/auth']);\r\n        else {\r\n          this.matDialog.open(AuthenticateUserComponent, {\r\n            height: '50vh',\r\n            width: '35vw',\r\n            data: this.data \r\n          });\r\n        }\r\n    }\r\n  }\r\n\r\n  proceedToListPage(){\r\n    // this._eventService.redirectToPage.emit({ redirectTo: '/list'});\r\n    this.router.navigate(['/']);\r\n  }\r\n  removeItem(item: any) {\r\n    item.quantity = 0;\r\n    this.loadingItems.push(item.itemId);\r\n    this.cartService.addItemFromCartPage(item).subscribe((response)=> {\r\n      this.loadingItems = this.loadingItems.filter((idx: string)=> idx != item.itemId);\r\n      this.responseData = this.storageService.calculateBillingDetails();\r\n    })\r\n  }\r\n  addToCart(item: any, type: 'ADD' | 'SUBSTRACT') {\r\n    if (type == 'ADD') {\r\n      item.quantity += 1;\r\n    }\r\n    else {\r\n      item.quantity -= 1;\r\n    }\r\n    this.loadingItems.push(item.itemId);\r\n    this.cartService.addItemFromCartPage(item).subscribe((response)=> {\r\n      this.loadingItems = this.loadingItems.filter((idx: string)=> idx != item.itemId);\r\n      this.responseData = this.storageService.calculateBillingDetails();\r\n    })\r\n  }\r\n  proceedToPayment() {\r\n    if (!this.storageService.getUser()) {\r\n      console.log(\"User not logged In\");\r\n      return;\r\n    }\r\n    const userDetail = this.storageService.getUser() as User;\r\n    console.log(\"User Details\", userDetail);\r\n    const address = UserInfo.user.addressDetailsList[0] as Address;\r\n    console.log(\"a: \", UserCart, this.responseData);\r\n    const payload = {\r\n      \"userId\": userDetail.userId ?? UserInfo.user.userId,\r\n      \"cartId\": UserCart.cartId,\r\n      \"orderAmount\": this.responseData.billdetails.totalNetValue,\r\n      \"contactDetails\": {\r\n        \"name\": address.receiverName,\r\n        \"mobile\": address.receiverPhone,\r\n        \"countryCode\": \"91\",\r\n        \"email\": address.receiverEmail\r\n      }\r\n    }\r\n    this.restService.createPaymentToken(payload).subscribe((paymentDetails: any)=> {\r\n      this._eventService.cashFreeEvent.emit(paymentDetails);\r\n    })\r\n  }\r\n\r\n  isItemLoading(itemId: string): boolean {\r\n    return this.loadingItems.includes(itemId);\r\n  }\r\n\r\n  get getAddressList() {\r\n    return UserInfo.user ? [...UserInfo.user?.addressDetailsList] : [];\r\n  }\r\n}\r\n","<ng-container *ngIf=\"!isLoading\">\r\n  <section class=\"total-container\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\" >\r\n    <div class=\"d-flex align-items-center justify-content-center mb-4\" style=\"margin-top: 50px;\" *ngIf=\"responseData?.orderedItems?.length\">\r\n      <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'BAG'}\" (click)=\"currentTab = 'BAG'\">Bag</span>\r\n      <div class=\"bar\"></div>\r\n      <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'ADDRESS'}\" (click)=\"currentTab = 'ADDRESS'\">Address</span>\r\n      <div class=\"bar\"></div>\r\n      <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'PAYMENT'}\" (click)=\"currentTab = 'PAYMENT'\">Payment</span>\r\n    </div>\r\n    <div class=\"cart-parent container\" *ngIf=\"(responseData?.orderedItems?.length || 0) > 0\"  [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\r\n      <ng-container [ngSwitch]=\"currentTab\">\r\n        <div class=\"left-panel\" *ngSwitchCase=\"'BAG'\">\r\n          <div class=\"my-bag\">\r\n            My Bag&nbsp; <span>({{responseData?.orderedItems?.length}} Items)</span>\r\n          </div>\r\n          <div class=\"cart-items\">\r\n            <ng-container *ngFor=\"let item of responseData?.orderedItems; let idx = index\">\r\n              <div class=\"row item-parent\">\r\n                <div class=\"h-100\" style=\"padding: 0px; width: fit-content;\">\r\n                  <img class=\"product-img\" [src]=\"item.imgUrl\" alt=\"\">\r\n                </div>\r\n                <div class=\"col-md-6 h-100\">\r\n                  <div class=\"lh-23\">\r\n                    <div class=\"item-name heading-large\">{{item.itemName}}</div>\r\n                    <div class=\"price-with-tax\">\r\n                      &#8377; {{item.price + (item.itemTax ?? 0)}}\r\n                    </div>\r\n                    <div class=\"item-quantity\">\r\n                      <ng-container *ngIf=\"!isItemLoading(item.itemId)\">\r\n                        <span class=\"cursor\" (click)=\"addToCart(item, 'SUBSTRACT')\">-</span>\r\n                        <span>{{item.quantity}}</span>\r\n                        <span class=\"cursor\" (click)=\"addToCart(item, 'ADD')\">+</span>\r\n                      </ng-container>\r\n                      <ng-container *ngIf=\"isItemLoading(item.itemId)\">\r\n                        <div class=\"d-flex\"> <i  class=\"fa fa-spinner fa-spin\" style=\"font-size:24px; margin-right: 10px;\"></i> <span>Loading...</span></div>\r\n                      </ng-container>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n                <div class=\"col-md-4 position-relative\" style=\"margin-left: auto;\">\r\n                  <div class=\"item-price\">&#8377; {{(item.price + (item.itemTax ?? 0)) * item.quantity}}</div>\r\n                  <div>\r\n                    <mat-icon class=\"delete-item\" (click)=\"removeItem(item)\">delete</mat-icon>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n              <hr *ngIf=\"responseData?.orderedItems?.length != (idx +1)\">\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n        <div class=\"left-panel\" *ngSwitchCase=\"'ADDRESS'\">\r\n          <simpo-address [isCart]=\"true\" [responseData]=\"getAddressList\" [selectedAddressIdx]=\"selectedAddressIdx\"></simpo-address>\r\n        </div>\r\n        <div class=\"left-panel\" *ngSwitchCase=\"'PAYMENT'\"></div>\r\n      </ng-container>\r\n      <div class=\"right-panel\">\r\n        <div class=\"my-bag\">\r\n          Price Details\r\n        </div>\r\n        <div class=\"price-details\">\r\n          <div class=\"price-parent-block\" *ngIf=\"responseData?.billdetails?.totalNetValue\">\r\n            <div class=\"price-type\">Total Price</div>\r\n            <div class=\"price-value\">&#8377; {{responseData.billdetails.totalNetValue}}</div>\r\n          </div>\r\n          <div class=\"price-parent-block\" *ngIf=\"responseData?.billdetails?.totalTax\">\r\n            <div class=\"price-type\">Total Tax</div>\r\n            <div class=\"price-value\">&#8377; {{responseData?.billdetails?.totalTax}}</div>\r\n          </div>\r\n          <div class=\"price-parent-block\"\r\n            *ngIf=\"responseData?.billdetails?.deliveryCharges && responseData.billdetails.deliveryCharges > 0\">\r\n            <div class=\"price-type\">Delivery Charge</div>\r\n            <div class=\"price-value\">&#8377; {{responseData.billdetails.deliveryCharges}}</div>\r\n          </div>\r\n          <hr>\r\n          <div class=\"price-parent-block\" *ngIf=\"responseData?.totalAmount\">\r\n            <div class=\"price-type\" style=\"color: black;font-weight: 600;\">Total Amount</div>\r\n            <div class=\"price-value\" style=\"font-weight: 600;\">&#8377; {{responseData.totalAmount}}</div>\r\n          </div>\r\n\r\n          <div class=\"button-parent\">\r\n            <ng-container *ngIf=\"currentTab == 'BAG'\">\r\n              <div class=\"btn\" (click)=\"proceedToCheckout()\">Checkout Cart</div>\r\n              <div class=\"btn\" (click)=\"proceedToListPage()\">Continue Shopping</div>\r\n            </ng-container>\r\n            \r\n            <ng-container *ngIf=\"currentTab == 'ADDRESS'\">\r\n              <div class=\"btn\" (click)=\"proceedToPayment()\">Place Order</div>\r\n            </ng-container>\r\n            <!-- <div *ngFor=\"let button of data?.action?.buttons;let i = index\">\r\n              <button class=\"btn\" (click)=\"i == 0 ? proceedToCheckout() : proceedToListPage()\" simpoButtonDirective [id]=\"data?.id+button.id\" [buttonStyle]=\"button?.styles\"\r\n                [color]=\"styles?.background?.accentColor\">{{button?.content?.label}}</button>\r\n            </div> -->\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <section class=\"empty-cart\" *ngIf=\"(responseData?.orderedItems?.length || 0) == 0\">\r\n      <div>\r\n        <div class=\"cart-image\">\r\n          <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/107213c1716543334040empty-cart.png\" alt=\"\">\r\n        </div>\r\n        <div class=\"cart-text\">\r\n          <div class=\"heading-medium d-flex justify-content-center\">\r\n            Your cart is empty\r\n          </div>\r\n          <div class=\"description d-flex mt-4\">\r\n            Looks like you have not added anything to your cart. Go ahead & explore top categories.\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </section>\r\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n      <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n    </div>\r\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n      <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n    </div>\r\n\r\n  </section>\r\n</ng-container>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n  width: '100%',\r\n  height: '40vh',\r\n  'border-radius': '10px',\r\n  'position': 'relative',\r\n  'right': '5px'\r\n}\">\r\n</ngx-skeleton-loader>\r\n"]}
|
414
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cart.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/cart/cart.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/cart/cart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { Address, CartSectionModal, CartSectionStylesModel } from './cart.modal';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { AnimationDirective } from '../../../directive/animation-directive';\r\nimport { HoverDirective } from '../../../directive/hover-element-directive';\r\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport BaseSection from '../../../sections/BaseSection';\r\nimport { EventsService } from '.././../../services/events.service';\r\nimport { CartService } from '../../../services/cart.service';\r\nimport { AddressComponent } from \"../address/address.component\";\r\nimport { Router } from '@angular/router';\r\nimport { AuthenticateUserComponent } from '../authenticate-user/authenticate-user.component';\r\nimport { MatDialog, MatDialogModule } from '@angular/material/dialog';\r\nimport { RestService } from \"../../../services/rest.service\";\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\nimport { User } from '../../styles/user.modal';\r\nimport { OrderedItems } from '../../styles/OrderedItems.modal';\r\nimport { BUSINESS_CONSTANTS } from '../../../constants/business.constant';\r\nimport { MessageService } from 'primeng/api';\r\nimport Swal from 'sweetalert2';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { MatBottomSheet, MatBottomSheetModule } from '@angular/material/bottom-sheet';\r\nimport { Product } from '../../styles/product.modal';\r\n\r\n@Component({\r\n  selector: 'simpo-cart',\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule, \r\n    CommonModule,\r\n    MatIcon,\r\n    MatDialogModule,\r\n    SimpoComponentModule,\r\n    BackgroundDirective,\r\n    MatBottomSheetModule,\r\n    //DIRECTIVE\r\n    ButtonDirectiveDirective,\r\n    AnimationDirective,\r\n    ContentFitDirective,\r\n    HoverDirective, \r\n    AddressComponent,\r\n    ToastModule\r\n  ],\r\n  providers: [MessageService],\r\n  templateUrl: './cart.component.html',\r\n  styleUrl: './cart.component.css'\r\n})\r\nexport class CartComponent extends BaseSection implements OnInit {\r\n  @Input() data?: CartSectionModal;\r\n  @Input() responseData?: any;\r\n  @Input() index? : number;\r\n  @Input() edit? : boolean = false;\r\n  @Input() delete? : boolean;\r\n  isLoading: boolean = false;\r\n\r\n  styles?: CartSectionStylesModel;\r\n  public currentTab: 'BAG' | 'ADDRESS' | 'PAYMENT' = \"BAG\";\r\n\r\n  constructor(\r\n    private readonly _eventService : EventsService,\r\n    private readonly cartService: CartService,\r\n    private readonly router: Router,\r\n    private readonly restService: RestService,\r\n    private readonly matDialog: MatDialog,\r\n    private readonly storageService: StorageServiceService,\r\n    private readonly messageService: MessageService,\r\n    private readonly bottomSheet: MatBottomSheet\r\n  ){\r\n    super()\r\n  }\r\n\r\n  private userDetails: User | null = null;\r\n  private USER_CART_ITEMS: OrderedItems[] | null = null;\r\n  public selectedAddressIdx: number = 0;\r\n\r\n  cartInfo: any = {\r\n    orderedItems: null,\r\n    businessId: localStorage.getItem(\"bId\") ?? localStorage.getItem(\"businessId\"),\r\n    billdetails: {\r\n      \"totalNetValue\": 0,\r\n      \"totalGrossValue\": 0,\r\n      \"totalTax\": 0,\r\n      \"totalOfferedValue\": 0,\r\n      \"deliveryCharges\": 0\r\n    },\r\n    platform: \"WEB\",\r\n    cartType: \"CART\",\r\n    addressDetails: null,\r\n    userDetails: {\r\n      \"userId\": \"\",\r\n      \"userName\": \"\",\r\n      \"mobile\": \"\",\r\n      \"email\": \"\"\r\n    },\r\n    totalAmount: 0\r\n  }\r\n\r\n  ngOnInit(){\r\n    this._eventService.showLoadingScreen.subscribe((response)=> {\r\n      this.isLoading = response;\r\n      if (!this.isLoading) {\r\n        this.getIndexDBData();\r\n      }\r\n    })\r\n    if (this.storageService.getUser()) {\r\n      this.userDetails = this.storageService.getUser() as User;\r\n      this.cartInfo.userDetails = {\r\n        \"userId\": this.userDetails?.userId,\r\n        \"userName\": this.userDetails?.contact.name,\r\n        \"mobile\": this.userDetails?.contact.mobile,\r\n        \"email\": this.userDetails?.contact.email,\r\n      }\r\n      this.restService.getUserItems(this.userDetails.userId, \"CART\").subscribe((response: any)=> {\r\n        const tempUserCart = response?.data?.[0]?.orderedItems ?? [];\r\n        localStorage.setItem('cartId', response.data?.[0]?.cartId);\r\n        this.cartInfo[\"cartId\"] = response.data?.[0]?.cartId; \r\n        if (response.data?.[0]?.orderedItems?.length > 0) {\r\n          \r\n          this.storageService.addAllProductsToCart(tempUserCart).oncomplete = ()=> {\r\n            \r\n            this.storageService.getUserCart().then((cartResponse)=> {\r\n              cartResponse.onsuccess = (cartData: any) => {\r\n                // this.cartInfo[\"orderedItems\"]?.forEach((item: OrderedItems)=> item.itemVariant = null);\r\n                const restResponse = this.restService.addItemToDB(this.cartInfo).toPromise();\r\n                restResponse.finally(()=> {\r\n                  this.cartInfo.billdetails.totalGrossValue = 0;\r\n                  this.cartInfo.billdetails.totalTax = 0;\r\n                  this.cartInfo.billdetails.totalNetValue = 0;\r\n                  this.cartInfo.totalAmount = 0;\r\n                  \r\n                  this.USER_CART_ITEMS = cartData.target.result as unknown as OrderedItems[];\r\n                  this.USER_CART_ITEMS.forEach((item)=> {\r\n                    this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));\r\n                    this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));\r\n                  })\r\n                  this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;\r\n                  this.cartInfo.orderedItems = this.USER_CART_ITEMS;\r\n                  this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;\r\n                  this.responseData = this.cartInfo;\r\n                  console.log(this.responseData);\r\n                })\r\n              }\r\n              cartResponse.onerror = (cartData: any) => {\r\n                this.messageService.add({ severity: 'error', summary: 'Error', detail: 'Failed to update cart details' });\r\n              }\r\n            })\r\n          }\r\n        } else {\r\n          this.storageService.getUserCart().then((cartResponse)=> {\r\n            cartResponse.onsuccess = (cartData: any) => {\r\n              console.log(\"cart Data\", cartData);\r\n              this.USER_CART_ITEMS = cartData.target.result as unknown as OrderedItems[];\r\n              this.cartInfo.billdetails.totalGrossValue = 0;\r\n              this.cartInfo.billdetails.totalTax = 0;\r\n              this.cartInfo.billdetails.totalNetValue = 0;\r\n              this.cartInfo.totalAmount = 0;\r\n              \r\n              this.USER_CART_ITEMS.forEach((item)=> {\r\n                this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));\r\n                this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));\r\n              })\r\n              this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;\r\n              this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;\r\n              this.cartInfo.orderedItems = this.USER_CART_ITEMS;\r\n              console.log(this.responseData);\r\n              // this.cartInfo[\"orderedItems\"]?.forEach((item: OrderedItems)=> item.itemVariant = null);\r\n              this.responseData = this.cartInfo;\r\n              this.restService.addItemToDB(this.responseData).subscribe((response: any)=> {\r\n                localStorage.setItem('cartId', response.data?.cartId);\r\n                this.cartInfo[\"cartId\"] = response.data?.cartId;\r\n                this.responseData[\"cartId\"] = this.cartInfo[\"cartId\"];\r\n              })\r\n            }\r\n          })\r\n        }\r\n      })\r\n    } else {\r\n      this.getIndexDBData();\r\n      // this.responseData = this.storageService.calculateBillingDetails();\r\n      console.log(this.responseData);\r\n    }\r\n    console.log(this.responseData);\r\n    this.styles = this.data?.styles;\r\n  }\r\n\r\n  getIndexDBData() {\r\n    this.storageService.getUserCart().then((cartResponse)=> {\r\n      console.log(cartResponse);\r\n      \r\n      this.cartInfo.billdetails.totalGrossValue = 0;\r\n      this.cartInfo.billdetails.totalTax = 0;\r\n      this.cartInfo.billdetails.totalNetValue = 0;\r\n      this.cartInfo.totalAmount = 0;\r\n      \r\n\r\n      cartResponse.onsuccess = (cartData: any) => {\r\n        this.USER_CART_ITEMS = cartData.target.result as unknown as OrderedItems[];\r\n        this.USER_CART_ITEMS.forEach((item)=> {\r\n          this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));\r\n          this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));\r\n        })\r\n        this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;\r\n        this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;\r\n        this.cartInfo.orderedItems = this.USER_CART_ITEMS;\r\n        this.responseData = this.cartInfo;\r\n      }\r\n    })\r\n  }\r\n  proceedToCheckout(){\r\n    if(this.storageService.getUser()){\r\n      this.currentTab = \"ADDRESS\"; \r\n      if (this.isMobile) {\r\n        document.body.scrollTop = 0;\r\n        document.documentElement.scrollTop = 0;\r\n      }\r\n         \r\n    } else {\r\n        this.messageService.add({ severity: 'info', summary: 'Login', detail: 'Please login with mobile number to order' });\r\n        if (window.innerWidth <= 475)\r\n          this.bottomSheet.open(AuthenticateUserComponent, {data: this.data});\r\n        else {\r\n          this.matDialog.open(AuthenticateUserComponent, {\r\n            height: '50vh',\r\n            width: '35vw',\r\n            data: this.data \r\n          }).afterClosed().subscribe((response)=> {\r\n            this.userDetails = this.storageService.getUser();\r\n            this.cartInfo.userDetails = {\r\n              \"userId\": this.userDetails?.userId,\r\n              \"userName\": this.userDetails?.contact.name,\r\n              \"mobile\": this.userDetails?.contact.mobile,\r\n              \"email\": this.userDetails?.contact.email,\r\n            }\r\n          })\r\n        }\r\n    }\r\n  }\r\n  goToProductDetails(product: OrderedItems) {\r\n    this.router.navigate(['/details'], {queryParams: {id: product.itemId, varientId: product.varientId}});\r\n  }\r\n  proceedToListPage(){\r\n    this.router.navigate(['/']);\r\n  }\r\n  removeItem(item: OrderedItems) {\r\n\r\n    Swal.fire({\r\n      icon: \"warning\",\r\n      html: \"<span>You can move </span> <b>\" + item.itemName + \"</b> <span>to wishlist so you can buy later.</span>\",\r\n      showCancelButton: true,\r\n      confirmButtonText: \"Move to wishlist\",\r\n      cancelButtonText: \"Delete item\",\r\n      cancelButtonColor: \"#928c8c\",\r\n    }).then((response)=> {\r\n      if (response.isConfirmed) {\r\n        this.removeItemFromCart(item);\r\n        this.moveItemToWishlist(item);\r\n      } else if (response.isDismissed) {\r\n        this.removeItemFromCart(item);\r\n      }\r\n    })\r\n  }\r\n  private moveItemToWishlist(item: OrderedItems) {\r\n    this.cartService.addItemToFavFromCart(item);\r\n  }\r\n  private removeItemFromCart(item: OrderedItems) {\r\n    item.quantity = 0;\r\n    if (this.USER_CART_ITEMS)\r\n      this.USER_CART_ITEMS = this.USER_CART_ITEMS.filter((product: any)=> product.varientId != item.varientId);\r\n    this.cartInfo.orderedItems = this.USER_CART_ITEMS;\r\n    this.responseData = this.cartInfo;\r\n    this.cartService.addItemFromCartPage(item, this.responseData).subscribe((response: any)=> {\r\n\r\n      this.cartInfo.billdetails.totalGrossValue = 0;\r\n      this.cartInfo.billdetails.totalTax = 0;\r\n      this.cartInfo.billdetails.totalNetValue = 0;\r\n      this.cartInfo.totalAmount = 0;\r\n      \r\n      response?.data?.orderedItems.forEach((item: any)=> {\r\n        this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));\r\n        this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));\r\n      })\r\n      this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;\r\n      this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;\r\n      this.cartInfo.orderedItems = this.USER_CART_ITEMS;\r\n    })\r\n  }\r\n  addToCart(item: OrderedItems, type: 'ADD' | 'SUBSTRACT') {\r\n    if (type == 'ADD') {\r\n      item.quantity += 1;\r\n    }\r\n    else {\r\n      item.quantity -= 1;\r\n    }\r\n  \r\n    if (item.quantity) {\r\n      this.cartService.addItemFromCartPage(item, this.responseData).subscribe((response: any)=> {\r\n        \r\n        this.cartInfo.billdetails.totalGrossValue = 0;\r\n        this.cartInfo.billdetails.totalTax = 0;\r\n        this.cartInfo.billdetails.totalNetValue = 0;\r\n        this.cartInfo.totalAmount = 0;\r\n        \r\n        response?.data?.orderedItems.forEach((item: any)=> {\r\n          this.cartInfo.billdetails.totalGrossValue += (item.discountedPrice * (item.quantity ?? 1));\r\n          this.cartInfo.billdetails.totalTax += (item.quantity * (item.itemTax ?? 0));\r\n        })\r\n        this.cartInfo.billdetails.totalNetValue = this.cartInfo.billdetails.totalGrossValue - this.cartInfo.billdetails.deliveryCharges;\r\n        this.cartInfo.totalAmount = this.cartInfo.billdetails.totalNetValue + this.cartInfo.billdetails.totalTax;\r\n        this.cartInfo.orderedItems = this.USER_CART_ITEMS;\r\n      })\r\n    } else {\r\n      this.removeItem(item);\r\n    }\r\n  }\r\n  async proceedToPayment() {\r\n\r\n    if (!this.storageService.getUser()) {\r\n      this.messageService.add({ severity: 'info', summary: 'Login', detail: 'Please login with mobile number to order' });\r\n      return;\r\n    }\r\n    const userDetail = this.storageService.getUser() as User;\r\n    const address = userDetail?.addressDetailsList[this.selectedAddressIdx] as Address;\r\n    if (address?.receiverName?.length == 0) {\r\n      this.messageService.add({ severity: 'error', summary: 'Payment Failure', detail: 'Please provide address details' });\r\n      return;\r\n    }\r\n    if (localStorage.getItem(\"cartId\"))\r\n      this.cartInfo[\"cartId\"] = localStorage.getItem(\"cartId\");\r\n    else {\r\n      this.messageService.add({ severity: 'info', summary: 'Please wait', detail: 'We are processing your payment', life: 2000 });\r\n      await this.restService.addItemToDB(this.cartInfo).toPromise().then((response: any)=> {\r\n        localStorage.setItem(\"cartId\", response.data?.cartId);\r\n        this.cartInfo[\"cartId\"] = response.data?.cartId;\r\n      })\r\n    }\r\n    this.cartInfo[\"addressDetails\"] = address;\r\n    const updateAddress = await this.restService.addItemToDB(this.cartInfo).toPromise();\r\n    const payload = {\r\n      \"userId\": userDetail.userId,\r\n      \"cartId\": localStorage.getItem('cartId'),\r\n      \"orderAmount\": Number(Number(this.responseData.totalAmount).toFixed(2)),\r\n      \"isPaymentGatewayEnabled\": true,\r\n      \"contactDetails\": {\r\n        \"name\": address.receiverName,\r\n        \"mobile\": address.receiverPhone,\r\n        \"countryCode\": \"91\",\r\n        \"email\": address.receiverEmail\r\n      }\r\n    }\r\n    this.restService.createPaymentToken(payload).subscribe((paymentDetails: any)=> {\r\n      this._eventService.cashFreeEvent.emit(paymentDetails);\r\n    }, (error)=> {\r\n      if (error.errorCode == 1001 || error.errorCode == 1002) {\r\n        Swal.fire({\r\n          icon: \"info\",\r\n          html: \"<p>\" + error.message.replace(/ *\\([^)]*\\) */g, \"\") + \"</p>\",\r\n          showCancelButton: error.errorCode == 1002,\r\n          confirmButtonText: \"Remove item & Place Order\",\r\n          cancelButtonText: \"Reduce quantity\",\r\n          cancelButtonColor: \"#928c8c\",\r\n        }).then(async (response)=> {\r\n          this.messageService.add({ severity: 'info', summary: 'Processing', detail: 'Please wait, updaing your cart', life: 2000});\r\n          const regExp = /{([^}]+)}/g;\r\n          const id = regExp.exec(error.message)?.[1];\r\n          let itemDetail: Product | null = null;\r\n          const productDetailsAsync = await this.restService.getProductDetails(id).toPromise().then((response) => {\r\n            itemDetail = response[0] as Product;\r\n          })\r\n          if (response.isDismissed) {\r\n            this.cartInfo.orderedItems.forEach((item: OrderedItems)=> {\r\n              if (item.itemId == itemDetail?.itemId)\r\n                item.quantity = itemDetail?.itemInventory.openingStock;\r\n            })\r\n            const addItemDBAsync = await this.restService.addItemToDB(this.cartInfo).toPromise();\r\n            const addItemIndexDBAsync = await this.storageService.addAllProductsToCart(this.cartInfo.orderedItems);\r\n          } else if (response.isConfirmed) {\r\n            this.cartInfo.orderedItems = this.cartInfo.orderedItems.filter((item: OrderedItems)=> item.itemId != itemDetail?.itemId);\r\n            const addItemDBAsync = await this.restService.addItemToDB(this.cartInfo).toPromise();\r\n            const addItemIndexDBAsync = await this.storageService.addAllProductsToCart(this.cartInfo.orderedItems);\r\n            this.proceedToPayment();\r\n          }\r\n        })\r\n      } else {\r\n        this.messageService.add({ severity: 'error', summary: 'Payment Failure', detail: 'Please try again' });\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n  addressSelected(index: number) {\r\n    this.selectedAddressIdx = index;\r\n  }\r\n\r\n  isItemOutOfStock(product: OrderedItems) {\r\n    return false; // need condition\r\n  }\r\n  getKeys(object: Object): string[] {\r\n    if (object)\r\n      return Object.keys(object);\r\n    return [];\r\n  }\r\n\r\n  editSection(){\r\n    \r\n    this._eventService.toggleEditorEvent.emit(false);\r\n    setTimeout(()=> {\r\n      this._eventService.editSection.emit({data:this.data});\r\n    }, 100);\r\n  }\r\n\r\n  get getAddressList() {\r\n    return this.userDetails ? [...this.userDetails?.addressDetailsList] : [];\r\n  }\r\n  get isMobile() {\r\n    return window.innerWidth <= 475;\r\n  }\r\n  get currency(): string {\r\n    return BUSINESS_CONSTANTS.CURRENCY;\r\n  }\r\n}\r\n","<ng-container *ngIf=\"!isLoading\">\r\n  <p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"></p-toast>\r\n\r\n  <section class=\"total-container\" [id]=\"data?.id\" [simpoLayout]=\"styles?.layout\" [id]=\"data?.id\" [simpoBackground]=\"styles?.background\" [attr.class]=\"isMobile ? 'py-5' : ''\" simpoHover (hovering)=\"showEditTabs($event)\" (click)=\"editSection()\" >\r\n    <div class=\"d-flex align-items-center justify-content-center m-auto mb-4\" [style.marginTop.px]=\"isMobile ? '': '50'\" [style.width.%]=\"isMobile ? '90' : ''\" *ngIf=\"responseData?.orderedItems?.length\">\r\n      <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'BAG'}\" (click)=\"currentTab = 'BAG'\">Bag</span>\r\n      <div class=\"bar\"></div>\r\n      <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'ADDRESS'}\" (click)=\"currentTab = 'ADDRESS'\">Address</span>\r\n      <div class=\"bar\"></div>\r\n      <span class=\"timeline\" [ngClass]=\"{'isActive': currentTab == 'PAYMENT'}\" style=\"cursor: auto;\">Payment</span>\r\n    </div>\r\n    <div class=\"cart-parent container\" *ngIf=\"(responseData?.orderedItems?.length || 0) > 0\"  [id]=\"data?.id\" [simpoAnimation]=\"styles?.animation\">\r\n      <ng-container [ngSwitch]=\"currentTab\">\r\n        <div class=\"left-panel\" *ngSwitchCase=\"'BAG'\">\r\n          <div class=\"my-bag\">\r\n            My Bag&nbsp; <span>({{responseData?.orderedItems?.length}} Items)</span>\r\n          </div>\r\n          <div class=\"cart-items\">\r\n            <ng-container *ngFor=\"let item of responseData?.orderedItems; let idx = index\">\r\n              <div class=\"item-parent d-flex\">\r\n                <div class=\"h-100\" style=\"padding: 0px; width: fit-content;\">\r\n                  <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" class=\"product-img\" [src]=\"item.imgUrl ?? 'https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\" alt=\"\" (click)=\"goToProductDetails(item)\">\r\n                </div>\r\n                <div class=\"col-md-6 h-100\" [style.width.px]=\"isMobile ? '200' : ''\" style=\"margin-left: px;\">\r\n                  <div class=\"lh-23\">\r\n                    <div class=\"item-name trim-text heading-large\">{{item.itemName}}</div>\r\n                    <div class=\"price-with-tax\">\r\n                      <span [innerHTML]='currency'></span> {{(item.discountedPrice) | number: '1.0-2'}}\r\n                    </div>\r\n                    <ng-container *ngIf=\"item.itemVariant\"> \r\n                      <div class=\"d-flex align-items-center\" *ngFor=\"let varient of getKeys(item.itemVariant.properties)\">\r\n                        <div class=\"fw-bold\">{{ varient }} : </div>\r\n                        <!-- <div class=\"fw-normal\" style=\"margin-left: 5px; height: 13px; width: 13px; border-radius: 50%;\" *ngIf=\"varient.toLowerCase() == 'color'\" [style.backgroundColor]=\"item.itemVariant.properties[varient]\"></div> -->\r\n                        <div class=\"fw-normal\" style=\"margin-left: 5px;\"> {{ item.itemVariant.properties[varient] | uppercase }}</div>\r\n                      </div>\r\n                    </ng-container>\r\n                    <div class=\"item-quantity\">\r\n                        <span class=\"cursor\" (click)=\"addToCart(item, 'SUBSTRACT')\">-</span>\r\n                        <span>{{item.quantity}}</span>\r\n                        <span class=\"cursor\" (click)=\"addToCart(item, 'ADD')\">+</span>\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n                <div class=\"col-md-4 position-relative\" style=\"margin-left: auto;\">\r\n                  <div class=\"item-price\"><span [innerHTML]='currency'></span> {{((item.discountedPrice) * item.quantity)  | number: '1.0-2'}}</div>\r\n                  <div>\r\n                    <mat-icon class=\"delete-item\" (click)=\"removeItem(item)\" [style.right.px]=\"isMobile ? '5' : '0'\">delete</mat-icon>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n              <hr *ngIf=\"responseData?.orderedItems?.length != (idx +1)\">\r\n            </ng-container>\r\n          </div>\r\n        </div>\r\n        <div class=\"left-panel\" *ngSwitchCase=\"'ADDRESS'\">\r\n          <simpo-address [isCart]=\"true\" [responseData]=\"getAddressList\" [data]=\"data\" (selectedAddress)=\"addressSelected($event)\"></simpo-address>\r\n        </div>\r\n        <div class=\"left-panel\" *ngSwitchCase=\"'PAYMENT'\"></div>\r\n      </ng-container>\r\n      <div class=\"right-panel\">\r\n        <div class=\"my-bag\">\r\n          Price Details\r\n        </div>\r\n        <div class=\"price-details\">\r\n          <div class=\"price-parent-block\">\r\n            <div class=\"price-type\">Total Price</div>\r\n            <div class=\"price-value\"><span [innerHTML]='currency'></span> {{(responseData?.billdetails?.totalNetValue ?? 0) | number: '1.0-2'}}</div>\r\n          </div>\r\n          <div class=\"price-parent-block\">\r\n            <div class=\"price-type\">Total Tax</div>\r\n            <div class=\"price-value\"><span [innerHTML]='currency'></span> {{(responseData?.billdetails?.totalTax ?? 0) | number: '1.0-2'}}</div>\r\n          </div>\r\n          <div class=\"price-parent-block\"\r\n            *ngIf=\"responseData?.billdetails?.deliveryCharges && responseData.billdetails.deliveryCharges > 0\">\r\n            <div class=\"price-type\">Delivery Charge</div>\r\n            <div class=\"price-value\"><span [innerHtml]='currency'></span> {{responseData.billdetails.deliveryCharges | number: '1.0-2'}}</div>\r\n          </div>\r\n          <hr>\r\n          <div class=\"price-parent-block\">\r\n            <div class=\"price-type\" style=\"color: black;font-weight: 600;\">Total Amount</div>\r\n            <div class=\"price-value\" style=\"font-weight: 600;\"><span [innerHtml]='currency'></span> {{(responseData?.totalAmount ?? 0) | number: '1.0-2'}}</div>\r\n          </div>\r\n\r\n          <div class=\"button-parent\">\r\n            <ng-container *ngIf=\"currentTab == 'BAG'\">\r\n              <div class=\"btn mobile-fixed\" (click)=\"proceedToCheckout()\"  [style.backgroundColor]=\"data?.styles?.background?.accentColor\" [style.color]=\"data?.styles?.background?.color\">{{data?.action?.buttons?.[0]?.content?.label ?? 'Checkout Cart'}}</div>\r\n              <div class=\"btn\" (click)=\"proceedToListPage()\" simpoButtonDirective [buttonStyle]=\"data?.action?.buttons?.[1]?.styles\" [color]=\"data?.styles?.background?.accentColor\">{{data?.action?.buttons?.[1]?.content?.label ?? 'Continue Shopping'}}</div>\r\n            </ng-container>\r\n            \r\n            <ng-container *ngIf=\"currentTab == 'ADDRESS'\">\r\n              <div class=\"btn mobile-fixed\" (click)=\"proceedToPayment()\" [style.backgroundColor]=\"data?.styles?.background?.accentColor\" [style.color]=\"data?.styles?.background?.color\">{{data?.action?.buttons?.[2]?.content?.label ?? 'Place Order'}}</div>\r\n            </ng-container>\r\n            <!-- <div *ngFor=\"let button of data?.action?.buttons;let i = index\">\r\n              <button class=\"btn\" (click)=\"i == 0 ? proceedToCheckout() : proceedToListPage()\" simpoButtonDirective [id]=\"data?.id+button.id\" [buttonStyle]=\"button?.styles\"\r\n                [color]=\"styles?.background?.accentColor\">{{button?.content?.label}}</button>\r\n            </div> -->\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <section class=\"empty-cart\" *ngIf=\"(responseData?.orderedItems?.length || 0) == 0\">\r\n      <div>\r\n        <div class=\"cart-image\">\r\n          <img loading=\"lazy\" onerror=\"this.src='https://i.postimg.cc/hPS2JpV0/no-image-available.jpg'\"   [src]=\"data?.content?.image?.url\" [alt]=\"data?.content?.image?.altText\">\r\n        </div>\r\n        <div class=\"cart-text\">\r\n          <ng-container *ngFor=\"let text of data?.content?.inputText\">\r\n            <div class=\"d-flex justify-content-center\" [ngClass]=\"{'heading-medium': text.label == 'Heading', 'description': text.label == 'Text'}\">{{text.value}}</div>\r\n          </ng-container>\r\n          <!-- <div class=\"description d-flex mt-4\">\r\n            Looks like you have not added anything to your cart. Go ahead & explore top categories.\r\n          </div> -->\r\n        </div>\r\n      </div>\r\n    </section>\r\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n      <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\" [isEcommerce]=\"true\"></simpo-hover-elements>\r\n    </div>\r\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n      <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n    </div>\r\n\r\n  </section>\r\n</ng-container>\r\n\r\n<ngx-skeleton-loader *ngIf=\"isLoading\" count=\"1\" appearance=\"circle\" [theme]=\"{\r\n  width: '100%',\r\n  height: '40vh',\r\n  'border-radius': '10px',\r\n  'position': 'relative',\r\n  'right': '5px'\r\n}\">\r\n</ngx-skeleton-loader>\r\n"]}
|