simpo-component-library 3.0.0 → 3.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/esm2022/lib/elements/index.mjs +6 -7
  2. package/esm2022/lib/elements/my-documents/my-documents.component.mjs +11 -0
  3. package/esm2022/lib/elements/my-orders/my-orders.component.mjs +64 -0
  4. package/esm2022/lib/elements/my-statement/my-statement.component.mjs +26 -0
  5. package/esm2022/lib/elements/need-help/need-help.component.mjs +11 -0
  6. package/esm2022/lib/elements/payment-confirmation/payment-confirmation.component.mjs +90 -0
  7. package/esm2022/lib/elements/portfolio/portfolio.component.mjs +27 -45
  8. package/esm2022/lib/elements/properties/properties.component.mjs +35 -0
  9. package/esm2022/lib/elements/property-view/property-view.component.mjs +79 -0
  10. package/esm2022/lib/sections/kyc-details/kyc-details.component.mjs +163 -0
  11. package/esm2022/lib/sections/navbar-section/navbar-section.component.mjs +41 -12
  12. package/esm2022/lib/sections/profile-section/profile-section.component.mjs +52 -0
  13. package/esm2022/lib/sections/profile-section/profile-section.modal.mjs +2 -0
  14. package/esm2022/lib/sections/property-component/property-component.component.mjs +84 -7
  15. package/esm2022/lib/sections/property-component/property-component.modal.mjs +1 -1
  16. package/esm2022/lib/sections/property-detail/property-detail.component.mjs +149 -0
  17. package/esm2022/lib/sections/property-detail/property-detail.model.mjs +2 -0
  18. package/esm2022/lib/sections/property-list/property-list.component.mjs +29 -57
  19. package/esm2022/lib/sections/signup-signin/signup-signin.component.mjs +278 -0
  20. package/esm2022/lib/sections/signup-signin/signup-signin.model.mjs +2 -0
  21. package/esm2022/lib/sections/verify-property-payment/verify-property-payment.component.mjs +55 -0
  22. package/esm2022/lib/services/events.service.mjs +2 -1
  23. package/esm2022/lib/services/rest.service.mjs +100 -5
  24. package/esm2022/lib/styles/index.mjs +6 -1
  25. package/esm2022/public-api.mjs +5 -1
  26. package/fesm2022/simpo-component-library.mjs +3080 -2096
  27. package/fesm2022/simpo-component-library.mjs.map +1 -1
  28. package/lib/directive/background-directive.d.ts +1 -1
  29. package/lib/directive/button-directive.directive.d.ts +1 -1
  30. package/lib/directive/color.directive.d.ts +1 -1
  31. package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +1 -1
  32. package/lib/elements/index.d.ts +2 -3
  33. package/lib/elements/my-documents/my-documents.component.d.ts +5 -0
  34. package/lib/elements/my-orders/my-orders.component.d.ts +10 -0
  35. package/lib/elements/my-statement/my-statement.component.d.ts +8 -0
  36. package/lib/elements/need-help/need-help.component.d.ts +5 -0
  37. package/lib/elements/payment-confirmation/payment-confirmation.component.d.ts +25 -0
  38. package/lib/elements/portfolio/portfolio.component.d.ts +10 -12
  39. package/lib/elements/properties/properties.component.d.ts +15 -0
  40. package/lib/elements/property-view/property-view.component.d.ts +15 -0
  41. package/lib/sections/banner-carousel/banner-carousel.component.d.ts +2 -2
  42. package/lib/sections/carousel-banner/carousel-banner.component.d.ts +1 -1
  43. package/lib/sections/image-section/image-section.component.d.ts +2 -2
  44. package/lib/sections/kyc-details/kyc-details.component.d.ts +38 -0
  45. package/lib/sections/logo-showcase/logo-showcase.component.d.ts +1 -1
  46. package/lib/sections/navbar-section/navbar-section.component.d.ts +9 -1
  47. package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
  48. package/lib/sections/profile-section/profile-section.component.d.ts +16 -0
  49. package/lib/sections/profile-section/profile-section.modal.d.ts +5 -0
  50. package/lib/sections/property-component/property-component.component.d.ts +25 -4
  51. package/lib/sections/property-component/property-component.modal.d.ts +11 -18
  52. package/lib/sections/property-detail/property-detail.component.d.ts +38 -0
  53. package/lib/sections/property-detail/property-detail.model.d.ts +5 -0
  54. package/lib/sections/property-list/property-list.component.d.ts +9 -2
  55. package/lib/sections/signup-signin/signup-signin.component.d.ts +49 -0
  56. package/lib/sections/signup-signin/signup-signin.model.d.ts +10 -0
  57. package/lib/sections/verify-property-payment/verify-property-payment.component.d.ts +16 -0
  58. package/lib/services/events.service.d.ts +1 -0
  59. package/lib/services/rest.service.d.ts +24 -0
  60. package/lib/styles/index.d.ts +4 -0
  61. package/package.json +1 -1
  62. package/public-api.d.ts +4 -0
  63. package/simpo-component-library-3.0.2.tgz +0 -0
  64. package/esm2022/lib/elements/property/property.component.mjs +0 -41
  65. package/lib/elements/property/property.component.d.ts +0 -8
  66. package/simpo-component-library-3.0.0.tgz +0 -0
@@ -0,0 +1,278 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import BaseSection from '../BaseSection';
3
+ import { CommonModule } from '@angular/common';
4
+ import { SimpoComponentModule } from '../../components/index';
5
+ import { HoverElementsComponent } from "../../components/hover-elements/hover-elements.component";
6
+ import { DeleteHoverElementComponent } from "../../components/delete-hover-element/delete-hover-element.component";
7
+ import { HoverDirective } from '../../directive/hover-element-directive';
8
+ import { BackgroundDirective } from '../../directive/background-directive';
9
+ import { AnimationDirective } from '../../directive/animation-directive';
10
+ import { CornerDirective } from '../../directive/corner-directive';
11
+ import { FormsModule } from '@angular/forms';
12
+ import { MessageService } from 'primeng/api';
13
+ import { KycDetailsComponent } from '../kyc-details/kyc-details.component';
14
+ import { StorageKeys } from '../../styles/index';
15
+ import { ToastModule } from 'primeng/toast';
16
+ import * as i0 from "@angular/core";
17
+ import * as i1 from "./../../services/events.service";
18
+ import * as i2 from "../../services/rest.service";
19
+ import * as i3 from "@angular/router";
20
+ import * as i4 from "primeng/api";
21
+ import * as i5 from "@angular/material/dialog";
22
+ import * as i6 from "@angular/common";
23
+ import * as i7 from "../../components/hover-elements/hover-elements.component";
24
+ import * as i8 from "../../components/delete-hover-element/delete-hover-element.component";
25
+ import * as i9 from "@angular/forms";
26
+ import * as i10 from "primeng/toast";
27
+ export class SignupSigninComponent extends BaseSection {
28
+ constructor(_eventService, restService, router, activatedRoute, messageService, matDialog) {
29
+ super();
30
+ this._eventService = _eventService;
31
+ this.restService = restService;
32
+ this.router = router;
33
+ this.activatedRoute = activatedRoute;
34
+ this.messageService = messageService;
35
+ this.matDialog = matDialog;
36
+ this.buttonLoader = false;
37
+ this.currentPage = 'LOGIN';
38
+ this.backgroundImage = "https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/500415c1739434186310image%2016.png";
39
+ this.otpArray = new Array(4).fill('');
40
+ this.loginOtpArray = new Array(4).fill('');
41
+ this.loginEmail = '';
42
+ this.investor = {
43
+ "fullName": "",
44
+ "emailId": "",
45
+ "phoneNumber": "",
46
+ "password": "",
47
+ "kycVerified": false,
48
+ "active": true,
49
+ "otp": "",
50
+ "deleted": false
51
+ };
52
+ this.otpSent = false;
53
+ }
54
+ ngOnInit() {
55
+ this.activatedRoute.queryParams.subscribe((param) => {
56
+ if (param['type'])
57
+ this.currentPage = param['type'];
58
+ if (param['id'])
59
+ this.propertyId = param['id'];
60
+ });
61
+ }
62
+ ngOnDestroy() {
63
+ this.kycDetailsSubscription?.unsubscribe();
64
+ }
65
+ editSection() {
66
+ this._eventService.toggleEditorEvent.emit(false);
67
+ setTimeout(() => {
68
+ this._eventService.editSection.emit({ data: this.data });
69
+ }, 100);
70
+ }
71
+ move(event, idx) {
72
+ if (isNaN(Number(event.key)) && event.code != "Backspace")
73
+ return;
74
+ if (event.code != "Backspace") {
75
+ this.otpArray[idx] = event.key;
76
+ document.getElementById("otp_" + (idx + 1))?.focus();
77
+ }
78
+ if (event.code == "Backspace" && !this.otpArray[idx]) {
79
+ document.getElementById("otp_" + (idx - 1))?.focus();
80
+ }
81
+ }
82
+ moveLoginOtpCursor(event, idx) {
83
+ if (isNaN(Number(event.key)) && event.code != "Backspace")
84
+ return;
85
+ if (event.code != "Backspace") {
86
+ this.loginOtpArray[idx] = event.key;
87
+ document.getElementById("loginOtp_" + (idx + 1))?.focus();
88
+ }
89
+ if (event.code == "Backspace" && !this.otpArray[idx]) {
90
+ document.getElementById("loginOtp_" + (idx - 1))?.focus();
91
+ }
92
+ }
93
+ buttonClickedEvent() {
94
+ if (this.currentPage === 'SIGN_UP') {
95
+ this.sendOtp();
96
+ }
97
+ if (this.currentPage === 'OTP_VERIFY') {
98
+ this.signUp();
99
+ }
100
+ if (this.currentPage === 'LOGIN') {
101
+ this.loginWithPassword();
102
+ }
103
+ }
104
+ signUp() {
105
+ this.buttonLoader = true;
106
+ this.investor.otp = "";
107
+ this.otpArray.forEach((otp) => {
108
+ this.investor.otp += otp;
109
+ });
110
+ this.restService.signUp(this.investor).subscribe({
111
+ next: (res) => {
112
+ this.messageService.add({
113
+ severity: 'success',
114
+ summary: 'Sign Up',
115
+ detail: 'Sign up Successfully'
116
+ });
117
+ this.currentPage = 'LOGIN';
118
+ this.buttonLoader = false;
119
+ },
120
+ error: (err) => {
121
+ this.messageService.add({
122
+ severity: 'error',
123
+ summary: 'Sign Up Failed',
124
+ detail: 'Something went wrong. Please try again.'
125
+ });
126
+ this.buttonLoader = false;
127
+ }
128
+ });
129
+ }
130
+ sendOtp() {
131
+ this.buttonLoader = true;
132
+ this.restService.sendOtp(this.investor.emailId).subscribe({
133
+ next: (res) => {
134
+ this.messageService.add({
135
+ severity: 'success',
136
+ summary: 'OTP',
137
+ detail: 'OTP Sent Successfully'
138
+ });
139
+ this.currentPage = 'OTP_VERIFY';
140
+ this.buttonLoader = false;
141
+ },
142
+ error: (err) => {
143
+ this.messageService.add({
144
+ severity: 'error',
145
+ summary: 'OTP Failed',
146
+ detail: err.error?.message || 'Failed to send OTP. Please try again.'
147
+ });
148
+ this.buttonLoader = false;
149
+ }
150
+ });
151
+ }
152
+ loginWithPassword() {
153
+ this.buttonLoader = true;
154
+ this.restService.login({ email: this.loginEmail, password: this.investor.password }).subscribe({
155
+ next: (res) => {
156
+ this.messageService.add({
157
+ severity: 'success',
158
+ summary: 'Log In',
159
+ detail: 'Logged in successfully'
160
+ });
161
+ localStorage.setItem(StorageKeys.INVESTOR_ID, res.investorId);
162
+ if (this.propertyId) {
163
+ this.router.navigate(['details'], { queryParams: { id: this.propertyId } });
164
+ return;
165
+ }
166
+ this.getKycDetails();
167
+ this.router.navigate(['property-list']);
168
+ this.buttonLoader = false;
169
+ },
170
+ error: (err) => {
171
+ this.messageService.add({
172
+ severity: 'error',
173
+ summary: 'Login Failed',
174
+ detail: err.error?.message || 'Invalid email or password. Please try again.'
175
+ });
176
+ this.buttonLoader = false;
177
+ }
178
+ });
179
+ }
180
+ sendOtpForLogin() {
181
+ this.buttonLoader = true;
182
+ this.otpSent = false;
183
+ this.restService.sendOtp(this.loginEmail).subscribe({
184
+ next: (res) => {
185
+ this.otpSent = true;
186
+ this.messageService.add({
187
+ severity: 'success',
188
+ summary: 'OTP',
189
+ detail: 'OTP Sent Successfully'
190
+ });
191
+ this.buttonLoader = false;
192
+ },
193
+ error: (err) => {
194
+ this.messageService.add({
195
+ severity: 'error',
196
+ summary: 'Error',
197
+ detail: 'Failed to send OTP. Please try again.'
198
+ });
199
+ this.buttonLoader = false;
200
+ }
201
+ });
202
+ }
203
+ verifyOtp() {
204
+ this.buttonLoader = true;
205
+ let logInOtp = '';
206
+ this.loginOtpArray.forEach((otp) => {
207
+ logInOtp += otp;
208
+ });
209
+ this.restService.verifyOtp(this.loginEmail, logInOtp).subscribe({
210
+ next: (res) => {
211
+ this.messageService.add({
212
+ severity: 'success',
213
+ summary: 'Log In',
214
+ detail: 'Logged in successfully'
215
+ });
216
+ localStorage.setItem(StorageKeys.INVESTOR_ID, res.investorId);
217
+ if (this.propertyId) {
218
+ this.router.navigate(['details'], { queryParams: { id: this.propertyId } });
219
+ return;
220
+ }
221
+ this.getKycDetails();
222
+ this.router.navigate(['property-list']);
223
+ this.buttonLoader = false;
224
+ },
225
+ error: (err) => {
226
+ this.messageService.add({
227
+ severity: 'error',
228
+ summary: 'Error',
229
+ detail: 'Invalid OTP. Please try again.'
230
+ });
231
+ this.buttonLoader = false;
232
+ }
233
+ });
234
+ }
235
+ isValidEmail(email) {
236
+ const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
237
+ return emailRegex.test(email);
238
+ }
239
+ getKycDetails() {
240
+ this.kycDetailsSubscripition = this.restService.getKycDetails().subscribe((res) => {
241
+ if (!(res?.message?.panVerified === 'VALID' && res?.message?.aadhaarVerified === 'VALID')) {
242
+ this.matDialog.open(KycDetailsComponent, { panelClass: "login-signup" });
243
+ }
244
+ });
245
+ }
246
+ get isMobile() {
247
+ return window.innerWidth <= 475;
248
+ }
249
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: SignupSigninComponent, deps: [{ token: i1.EventsService }, { token: i2.RestService }, { token: i3.Router }, { token: i3.ActivatedRoute }, { token: i4.MessageService }, { token: i5.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
250
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: SignupSigninComponent, isStandalone: true, selector: "simpo-signup-signin", inputs: { data: "data", index: "index", edit: "edit", delete: "delete" }, providers: [MessageService], usesInheritance: true, ngImport: i0, template: "<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\n [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n\n<section [id]=\"data?.id\" class=\"main-container h-85 d-flex align-items-center justify-content-center\"\n [ngStyle]=\"{'background-image': 'url(' + backgroundImage + ')'}\" simpoHover (hovering)=\"showEditTabs($event)\">\n <div class=\"middle-container w-40-85\" [id]=\"data?.id\" [simpoBackground]=\"data?.styles?.background\"\n [simpoAnimation]=\"data?.styles?.animation\" [simpoCorner]=\"data?.styles?.corners\">\n <div class=\"head\">{{ currentPage == 'LOGIN' || currentPage == 'OTP' ? \"Sign In\" : currentPage ==\n 'FORGOT_PASSWORD' ? \"Forgot Password\" : currentPage == 'OTP_VERIFY' ? \"OTP Verfication\" : \"Sign Up\"}}</div>\n <div class=\"field-container\">\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'OTP'\">\n <div class=\"field-head\">Email or Phone Number</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Registered Email or Phone number\" [(ngModel)]=\"loginEmail\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'OTP' && otpSent\">\n <div class=\"field-head\">OTP</div>\n <div class=\"field-text-1\">\n <div id=\"otp\" class=\"inputs d-flex flex-row justify-content-center mt-2\">\n <ng-container *ngFor=\"let _ of [].constructor(4); let idx = index\">\n <input class=\"m-2 text-center form-control rounded additional-styles\" type=\"number\" max=\"1\"\n [(ngModel)]=\"loginOtpArray[idx]\" (keyup)=\"moveLoginOtpCursor($event, idx)\" [id]=\"'loginOtp_'+idx\" #otpInput />\n </ng-container>\n </div>\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'OTP_VERIFY'\">\n <!-- <div class=\"field-head\" *ngIf=\"currentPage == 'OTP' \">OTP</div> -->\n <div class=\"field-text-1\">\n <div id=\"otp\" class=\"inputs d-flex flex-row justify-content-center mt-2\">\n <ng-container *ngFor=\"let _ of [].constructor(4); let idx = index\">\n <input class=\"m-2 text-center form-control rounded additional-styles\" type=\"number\" max=\"1\"\n [(ngModel)]=\"otpArray[idx]\" (keyup)=\"move($event, idx)\" [id]=\"'otp_'+idx\" #otpInput />\n </ng-container>\n </div>\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n <div class=\"field-head\">Name</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Name\" [(ngModel)]=\"investor.fullName\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n <div class=\"field-head\">Email</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Email\" [(ngModel)]=\"investor.emailId\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n <div class=\"field-head\">Phone Number</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Phone Number\" [(ngModel)]=\"investor.phoneNumber\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"field-head\">Old Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Enter Your Password\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"field-head\">New Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Enter Your Password\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"field-head\">Re-Enter Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Re-Enter Your Password\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'SIGN_UP' \">\n <div class=\"field-head\">Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Enter Your Password\" [(ngModel)]=\"investor.password\">\n </div>\n </div>\n <div class=\"forgot-password cursor-pointer\" [style.color]=\"data?.styles?.background?.accentColor\"\n *ngIf=\"currentPage == 'LOGIN'\" (click)=\"currentPage = 'FORGOT_PASSWORD'\">Forgot Password?</div>\n <div class=\"forgot-password cursor-pointer\" [style.color]=\"data?.styles?.background?.accentColor\"\n *ngIf=\"currentPage == 'OTP_VERIFY'\">Resend OTP?</div>\n <div class=\"btn-container d-flex align-items-center justify-content-center\">\n <button class=\"login-btn cursor-pointer\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage != 'OTP'\"\n (click)=\"buttonClickedEvent()\" [disabled]=\"buttonLoader\" [class.btn-size]=\"currentPage == 'FORGOT_PASSWORD' || currentPage == 'SIGN_UP' || currentPage == 'OTP_VERIFY'\">\n <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n <span *ngIf=\"!buttonLoader\">{{ currentPage ==\n 'LOGIN' ? \"Login\" : currentPage == 'FORGOT_PASSWORD' ? \"Reset Password\" :\n currentPage == 'OTP_VERIFY' ? 'Verify OTP' : \"Create Account\"}}</span></button>\n\n <button class=\"login-btn cursor-pointer\" (click)=\"sendOtpForLogin()\" [disabled]=\"buttonLoader\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP' && !otpSent\">\n <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n <span *ngIf=\"!buttonLoader\">Send Otp</span>\n </button>\n\n <button class=\"login-btn cursor-pointer\" (click)=\"verifyOtp()\" [disabled]=\"buttonLoader\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP' && otpSent\">\n <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n <span *ngIf=\"!buttonLoader\" >Login</span>\n </button>\n </div>\n <div class=\"another-page\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'OTP'\">\n <div class=\"signup-text\">Don\u2019t have an account? <span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" (click)=\"currentPage = 'SIGN_UP'\">Sign\n Up</span></div>\n <div class=\"signup-text m-5\">or</div>\n <div class=\"signup-text\">Login with <span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'LOGIN' \"\n (click)=\"currentPage = 'OTP'\">OTP</span><span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP'\"\n (click)=\"currentPage = 'LOGIN'\">Password</span></div>\n </div>\n <div class=\"another-page\" *ngIf=\"currentPage == 'SIGN_UP' || currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"signup-text\">Already have an account? <span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" (click)=\"currentPage = 'LOGIN'\">Sign\n In</span></div>\n </div>\n </div>\n </div>\n\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n </div>\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n </div>\n</section>\n", styles: ["*{font-family:DM Sans!important}.h-85{height:85vh;position:relative}.hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.w-40-85{width:40%}.btn-size{width:40%!important}.head{font-size:36px;font-weight:600;line-height:52px;color:#112133;text-align:center;padding:15px;padding-bottom:unset}.field-container{padding:15px}.field-head{margin-bottom:10px;font-size:17px;font-weight:600;line-height:24px;color:#2c2c2c}.field-text{padding:10px;border-radius:20px;font-size:15px;font-weight:400;color:#ababab;background:#fff}.field-text input{width:100%;border:none;appearance:none;outline:unset;background:#fff;color:#000}.forgot-password{text-align:end;font-size:16px;font-weight:600;line-height:24px;margin-bottom:15px}.another-page{margin-top:15px;text-align:center}.signup-text{color:#6b6b6b;font-size:14px;font-weight:400;line-height:24px;margin-bottom:5px}.m-5{margin:5px 0!important}.mb-30{margin-bottom:30px!important}.mb-15{margin-bottom:15px!important}.login-btn{border:unset;padding:12px 18px;border-radius:6px;font-size:18px!important;font-weight:600;line-height:20px}.span-text{font-weight:700!important}.cursor-pointer{cursor:pointer}.additional-styles{padding:15px 5px!important;width:9%!important;border:unset!important;border-radius:20px!important}@media screen and (max-width : 475px){.w-40-85{width:85%}.h-86{height:90vh!important}.btn-size{width:100%!important;white-space:nowrap}.additional-styles{width:15%!important;border-radius:10px!important}}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i7.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged", "isEcommerce"], outputs: ["edit"] }, { kind: "component", type: i8.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "directive", type: HoverDirective, selector: "[simpoHover]", outputs: ["hovering"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i9.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type:
251
+ //Directives
252
+ BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "directive", type: AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "ngmodule", type: ToastModule }, { kind: "component", type: i10.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "life", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }] }); }
253
+ }
254
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: SignupSigninComponent, decorators: [{
255
+ type: Component,
256
+ args: [{ selector: 'simpo-signup-signin', standalone: true, imports: [
257
+ CommonModule,
258
+ SimpoComponentModule,
259
+ HoverElementsComponent,
260
+ DeleteHoverElementComponent,
261
+ HoverDirective,
262
+ FormsModule,
263
+ //Directives
264
+ BackgroundDirective,
265
+ AnimationDirective,
266
+ CornerDirective,
267
+ ToastModule
268
+ ], providers: [MessageService], template: "<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\n [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n\n<section [id]=\"data?.id\" class=\"main-container h-85 d-flex align-items-center justify-content-center\"\n [ngStyle]=\"{'background-image': 'url(' + backgroundImage + ')'}\" simpoHover (hovering)=\"showEditTabs($event)\">\n <div class=\"middle-container w-40-85\" [id]=\"data?.id\" [simpoBackground]=\"data?.styles?.background\"\n [simpoAnimation]=\"data?.styles?.animation\" [simpoCorner]=\"data?.styles?.corners\">\n <div class=\"head\">{{ currentPage == 'LOGIN' || currentPage == 'OTP' ? \"Sign In\" : currentPage ==\n 'FORGOT_PASSWORD' ? \"Forgot Password\" : currentPage == 'OTP_VERIFY' ? \"OTP Verfication\" : \"Sign Up\"}}</div>\n <div class=\"field-container\">\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'OTP'\">\n <div class=\"field-head\">Email or Phone Number</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Registered Email or Phone number\" [(ngModel)]=\"loginEmail\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'OTP' && otpSent\">\n <div class=\"field-head\">OTP</div>\n <div class=\"field-text-1\">\n <div id=\"otp\" class=\"inputs d-flex flex-row justify-content-center mt-2\">\n <ng-container *ngFor=\"let _ of [].constructor(4); let idx = index\">\n <input class=\"m-2 text-center form-control rounded additional-styles\" type=\"number\" max=\"1\"\n [(ngModel)]=\"loginOtpArray[idx]\" (keyup)=\"moveLoginOtpCursor($event, idx)\" [id]=\"'loginOtp_'+idx\" #otpInput />\n </ng-container>\n </div>\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'OTP_VERIFY'\">\n <!-- <div class=\"field-head\" *ngIf=\"currentPage == 'OTP' \">OTP</div> -->\n <div class=\"field-text-1\">\n <div id=\"otp\" class=\"inputs d-flex flex-row justify-content-center mt-2\">\n <ng-container *ngFor=\"let _ of [].constructor(4); let idx = index\">\n <input class=\"m-2 text-center form-control rounded additional-styles\" type=\"number\" max=\"1\"\n [(ngModel)]=\"otpArray[idx]\" (keyup)=\"move($event, idx)\" [id]=\"'otp_'+idx\" #otpInput />\n </ng-container>\n </div>\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n <div class=\"field-head\">Name</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Name\" [(ngModel)]=\"investor.fullName\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n <div class=\"field-head\">Email</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Email\" [(ngModel)]=\"investor.emailId\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n <div class=\"field-head\">Phone Number</div>\n <div class=\"field-text\">\n <input type=\"text\" placeholder=\"Please Enter Your Phone Number\" [(ngModel)]=\"investor.phoneNumber\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"field-head\">Old Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Enter Your Password\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"field-head\">New Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Enter Your Password\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"field-head\">Re-Enter Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Re-Enter Your Password\">\n </div>\n </div>\n <div class=\"field mb-15\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'SIGN_UP' \">\n <div class=\"field-head\">Password</div>\n <div class=\"field-text\">\n <input type=\"password\" placeholder=\"Please Enter Your Password\" [(ngModel)]=\"investor.password\">\n </div>\n </div>\n <div class=\"forgot-password cursor-pointer\" [style.color]=\"data?.styles?.background?.accentColor\"\n *ngIf=\"currentPage == 'LOGIN'\" (click)=\"currentPage = 'FORGOT_PASSWORD'\">Forgot Password?</div>\n <div class=\"forgot-password cursor-pointer\" [style.color]=\"data?.styles?.background?.accentColor\"\n *ngIf=\"currentPage == 'OTP_VERIFY'\">Resend OTP?</div>\n <div class=\"btn-container d-flex align-items-center justify-content-center\">\n <button class=\"login-btn cursor-pointer\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage != 'OTP'\"\n (click)=\"buttonClickedEvent()\" [disabled]=\"buttonLoader\" [class.btn-size]=\"currentPage == 'FORGOT_PASSWORD' || currentPage == 'SIGN_UP' || currentPage == 'OTP_VERIFY'\">\n <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n <span *ngIf=\"!buttonLoader\">{{ currentPage ==\n 'LOGIN' ? \"Login\" : currentPage == 'FORGOT_PASSWORD' ? \"Reset Password\" :\n currentPage == 'OTP_VERIFY' ? 'Verify OTP' : \"Create Account\"}}</span></button>\n\n <button class=\"login-btn cursor-pointer\" (click)=\"sendOtpForLogin()\" [disabled]=\"buttonLoader\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP' && !otpSent\">\n <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n <span *ngIf=\"!buttonLoader\">Send Otp</span>\n </button>\n\n <button class=\"login-btn cursor-pointer\" (click)=\"verifyOtp()\" [disabled]=\"buttonLoader\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP' && otpSent\">\n <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n <span *ngIf=\"!buttonLoader\" >Login</span>\n </button>\n </div>\n <div class=\"another-page\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'OTP'\">\n <div class=\"signup-text\">Don\u2019t have an account? <span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" (click)=\"currentPage = 'SIGN_UP'\">Sign\n Up</span></div>\n <div class=\"signup-text m-5\">or</div>\n <div class=\"signup-text\">Login with <span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'LOGIN' \"\n (click)=\"currentPage = 'OTP'\">OTP</span><span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP'\"\n (click)=\"currentPage = 'LOGIN'\">Password</span></div>\n </div>\n <div class=\"another-page\" *ngIf=\"currentPage == 'SIGN_UP' || currentPage == 'FORGOT_PASSWORD'\">\n <div class=\"signup-text\">Already have an account? <span class=\"span-text cursor-pointer\"\n [style.color]=\"data?.styles?.background?.accentColor\" (click)=\"currentPage = 'LOGIN'\">Sign\n In</span></div>\n </div>\n </div>\n </div>\n\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n </div>\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n </div>\n</section>\n", styles: ["*{font-family:DM Sans!important}.h-85{height:85vh;position:relative}.hover_effect{position:absolute;width:100%;top:0;left:0;height:100%}.w-40-85{width:40%}.btn-size{width:40%!important}.head{font-size:36px;font-weight:600;line-height:52px;color:#112133;text-align:center;padding:15px;padding-bottom:unset}.field-container{padding:15px}.field-head{margin-bottom:10px;font-size:17px;font-weight:600;line-height:24px;color:#2c2c2c}.field-text{padding:10px;border-radius:20px;font-size:15px;font-weight:400;color:#ababab;background:#fff}.field-text input{width:100%;border:none;appearance:none;outline:unset;background:#fff;color:#000}.forgot-password{text-align:end;font-size:16px;font-weight:600;line-height:24px;margin-bottom:15px}.another-page{margin-top:15px;text-align:center}.signup-text{color:#6b6b6b;font-size:14px;font-weight:400;line-height:24px;margin-bottom:5px}.m-5{margin:5px 0!important}.mb-30{margin-bottom:30px!important}.mb-15{margin-bottom:15px!important}.login-btn{border:unset;padding:12px 18px;border-radius:6px;font-size:18px!important;font-weight:600;line-height:20px}.span-text{font-weight:700!important}.cursor-pointer{cursor:pointer}.additional-styles{padding:15px 5px!important;width:9%!important;border:unset!important;border-radius:20px!important}@media screen and (max-width : 475px){.w-40-85{width:85%}.h-86{height:90vh!important}.btn-size{width:100%!important;white-space:nowrap}.additional-styles{width:15%!important;border-radius:10px!important}}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}\n"] }]
269
+ }], ctorParameters: () => [{ type: i1.EventsService }, { type: i2.RestService }, { type: i3.Router }, { type: i3.ActivatedRoute }, { type: i4.MessageService }, { type: i5.MatDialog }], propDecorators: { data: [{
270
+ type: Input
271
+ }], index: [{
272
+ type: Input
273
+ }], edit: [{
274
+ type: Input
275
+ }], delete: [{
276
+ type: Input
277
+ }] } });
278
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signup-signin.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/signup-signin/signup-signin.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/signup-signin/signup-signin.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, QueryList, ViewChildren } from '@angular/core';\nimport { SignInSignUpStylesModel, SignUpSignInModel } from './signup-signin.model';\nimport BaseSection from '../BaseSection';\nimport { CommonModule } from '@angular/common';\nimport { SimpoComponentModule } from '../../components/index';\nimport { EventsService } from './../../services/events.service';\nimport { HoverElementsComponent } from \"../../components/hover-elements/hover-elements.component\";\nimport { DeleteHoverElementComponent } from \"../../components/delete-hover-element/delete-hover-element.component\";\nimport { HoverDirective } from '../../directive/hover-element-directive';\nimport { BackgroundDirective } from '../../directive/background-directive';\nimport { AnimationDirective } from '../../directive/animation-directive';\nimport { CornerDirective } from '../../directive/corner-directive';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { RestService } from '../../services/rest.service';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { MessageService } from 'primeng/api';\nimport { MatDialog } from '@angular/material/dialog';\nimport { KycDetailsComponent } from '../kyc-details/kyc-details.component';\nimport { StorageKeys } from '../../styles/index';\nimport { Subscription } from 'rxjs';\nimport { ToastModule } from 'primeng/toast';\n\n\n@Component({\n  selector: 'simpo-signup-signin',\n  standalone: true,\n  imports: [\n    CommonModule,\n    SimpoComponentModule,\n    HoverElementsComponent,\n    DeleteHoverElementComponent,\n    HoverDirective,\n    FormsModule,\n\n    //Directives\n\n    BackgroundDirective,\n    AnimationDirective,\n    CornerDirective,\n    ToastModule\n\n  ],\n  providers: [MessageService],\n  templateUrl: './signup-signin.component.html',\n  styleUrl: './signup-signin.component.css'\n})\nexport class SignupSigninComponent extends BaseSection {\n  @Input() data?: SignUpSignInModel;\n  @Input() index?: number;\n  @Input() edit?: boolean;\n  @Input() delete?: boolean;\n\n  constructor(private _eventService: EventsService,\n    private restService: RestService,\n    private router: Router,\n    private activatedRoute: ActivatedRoute,\n    private readonly messageService: MessageService,\n    private matDialog: MatDialog\n  ) {\n    super();\n  }\n\n  propertyId?: number;\n  buttonLoader: boolean = false;\n  kycDetailsSubscription?: Subscription;\n  ngOnInit() {\n    this.activatedRoute.queryParams.subscribe((param: any) => {\n      if (param['type'])\n        this.currentPage = param['type'];\n      if (param['id'])\n        this.propertyId = param['id'];\n    })\n  }\n\n  ngOnDestroy() {\n    this.kycDetailsSubscription?.unsubscribe();\n  }\n\n  currentPage: 'LOGIN' | 'SIGN_UP' | 'OTP' | 'FORGOT_PASSWORD' | 'OTP_VERIFY' = 'LOGIN'\n  kycDetailsSubscripition?: Subscription;\n  backgroundImage: any = \"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/500415c1739434186310image%2016.png\"\n\n  editSection() {\n    this._eventService.toggleEditorEvent.emit(false);\n    setTimeout(() => {\n      this._eventService.editSection.emit({ data: this.data });\n    }, 100);\n  }\n\n\n  otpArray = new Array(4).fill('')\n  move(event: any, idx: number) {\n\n    if (isNaN(Number(event.key)) && event.code != \"Backspace\")\n      return;\n\n    if (event.code != \"Backspace\") {\n      this.otpArray[idx] = event.key;\n      document.getElementById(\"otp_\" + (idx + 1))?.focus();\n    }\n    if (event.code == \"Backspace\" && !this.otpArray[idx]) {\n      document.getElementById(\"otp_\" + (idx - 1))?.focus();\n    }\n  }\n\n  loginOtpArray = new Array(4).fill('')\n  moveLoginOtpCursor(event: any, idx: number) {\n\n    if (isNaN(Number(event.key)) && event.code != \"Backspace\")\n      return;\n\n    if (event.code != \"Backspace\") {\n      this.loginOtpArray[idx] = event.key;\n      document.getElementById(\"loginOtp_\" + (idx + 1))?.focus();\n    }\n    if (event.code == \"Backspace\" && !this.otpArray[idx]) {\n      document.getElementById(\"loginOtp_\" + (idx - 1))?.focus();\n    }\n  }\n\n  loginEmail: string = ''\n  investor: any = {\n    \"fullName\": \"\",\n    \"emailId\": \"\",\n    \"phoneNumber\": \"\",\n    \"password\": \"\",\n    \"kycVerified\": false,\n    \"active\": true,\n    \"otp\": \"\",\n    \"deleted\": false\n  }\n  otpSent: boolean = false;\n\n  buttonClickedEvent() {\n    if (this.currentPage === 'SIGN_UP') {\n      this.sendOtp();\n    }\n    if (this.currentPage === 'OTP_VERIFY') {\n      this.signUp();\n    }\n    if (this.currentPage === 'LOGIN') {\n      this.loginWithPassword();\n    }\n  }\n\n  signUp() {\n    this.buttonLoader = true;\n    this.investor.otp = \"\"\n    this.otpArray.forEach((otp) => {\n      this.investor.otp += otp;\n    })\n    this.restService.signUp(this.investor).subscribe({\n      next: (res: any) => {\n        this.messageService.add({\n          severity: 'success',\n          summary: 'Sign Up',\n          detail: 'Sign up Successfully'\n        });\n        this.currentPage = 'LOGIN';\n        this.buttonLoader = false;\n      },\n      error: (err) => {\n        this.messageService.add({\n          severity: 'error',\n          summary: 'Sign Up Failed',\n          detail: 'Something went wrong. Please try again.'\n        });\n        this.buttonLoader = false;\n      }\n    });\n  }\n\n\n\n  sendOtp() {\n    this.buttonLoader = true;\n    this.restService.sendOtp(this.investor.emailId).subscribe({\n      next: (res: any) => {\n        this.messageService.add({\n          severity: 'success',\n          summary: 'OTP',\n          detail: 'OTP Sent Successfully'\n        });\n        this.currentPage = 'OTP_VERIFY';\n        this.buttonLoader = false;\n      },\n      error: (err) => {\n        this.messageService.add({\n          severity: 'error',\n          summary: 'OTP Failed',\n          detail: err.error?.message || 'Failed to send OTP. Please try again.'\n        });\n        this.buttonLoader = false;\n      }\n    })\n  }\n\n  loginWithPassword() {\n    this.buttonLoader = true;\n    this.restService.login({ email: this.loginEmail, password: this.investor.password }).subscribe({\n      next: (res: any) => {\n        this.messageService.add({\n          severity: 'success',\n          summary: 'Log In',\n          detail: 'Logged in successfully'\n        });\n        localStorage.setItem(StorageKeys.INVESTOR_ID, res.investorId);\n        if (this.propertyId) {\n          this.router.navigate(['details'], { queryParams: { id: this.propertyId } });\n          return;\n        }\n        this.getKycDetails();\n        this.router.navigate(['property-list']);\n        this.buttonLoader = false;\n      },\n      error: (err) => {\n        this.messageService.add({\n          severity: 'error',\n          summary: 'Login Failed',\n          detail: err.error?.message || 'Invalid email or password. Please try again.'\n        });\n        this.buttonLoader = false;\n      }\n\n    });\n  }\n\n\n  sendOtpForLogin() {\n    this.buttonLoader = true;\n    this.otpSent = false;\n\n    this.restService.sendOtp(this.loginEmail).subscribe({\n      next: (res: any) => {\n        this.otpSent = true;\n        this.messageService.add({\n          severity: 'success',\n          summary: 'OTP',\n          detail: 'OTP Sent Successfully'\n        });\n        this.buttonLoader = false;\n      },\n      error: (err: any) => {\n        this.messageService.add({\n          severity: 'error',\n          summary: 'Error',\n          detail: 'Failed to send OTP. Please try again.'\n        });\n        this.buttonLoader = false;\n      }\n    });\n  }\n\n  verifyOtp() {\n    this.buttonLoader = true;\n    let logInOtp: string = '';\n    this.loginOtpArray.forEach((otp) => {\n      logInOtp += otp;\n    });\n    this.restService.verifyOtp(this.loginEmail, logInOtp).subscribe({\n      next: (res: any) => {\n        this.messageService.add({\n          severity: 'success',\n          summary: 'Log In',\n          detail: 'Logged in successfully'\n        });\n        localStorage.setItem(StorageKeys.INVESTOR_ID, res.investorId);\n        if (this.propertyId) {\n          this.router.navigate(['details'], { queryParams: { id: this.propertyId } });\n          return;\n        }\n        this.getKycDetails();\n        this.router.navigate(['property-list']);\n        this.buttonLoader = false;\n      },\n      error: (err: any) => {\n        this.messageService.add({\n          severity: 'error',\n          summary: 'Error',\n          detail: 'Invalid OTP. Please try again.'\n        });\n        this.buttonLoader = false;\n      }\n    });\n  }\n\n  isValidEmail(email: string): boolean {\n    const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\n    return emailRegex.test(email);\n  }\n\n  getKycDetails() {\n    this.kycDetailsSubscripition = this.restService.getKycDetails().subscribe((res: any) => {\n      if(!(res?.message?.panVerified === 'VALID' && res?.message?.aadhaarVerified === 'VALID')) {\n        this.matDialog.open(KycDetailsComponent, { panelClass: \"login-signup\" });\n      }\n    })\n  }\n\n  get isMobile() {\n    return window.innerWidth <= 475;\n  }\n\n}\n","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\n    [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\n\n<section [id]=\"data?.id\" class=\"main-container h-85 d-flex align-items-center justify-content-center\"\n  [ngStyle]=\"{'background-image': 'url(' + backgroundImage + ')'}\" simpoHover (hovering)=\"showEditTabs($event)\">\n  <div class=\"middle-container w-40-85\" [id]=\"data?.id\" [simpoBackground]=\"data?.styles?.background\"\n    [simpoAnimation]=\"data?.styles?.animation\" [simpoCorner]=\"data?.styles?.corners\">\n    <div class=\"head\">{{ currentPage == 'LOGIN' || currentPage == 'OTP' ? \"Sign In\" : currentPage ==\n      'FORGOT_PASSWORD' ? \"Forgot Password\" : currentPage == 'OTP_VERIFY' ? \"OTP Verfication\" : \"Sign Up\"}}</div>\n    <div class=\"field-container\">\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'OTP'\">\n        <div class=\"field-head\">Email or Phone Number</div>\n        <div class=\"field-text\">\n          <input type=\"text\" placeholder=\"Please Enter Your Registered Email or Phone number\" [(ngModel)]=\"loginEmail\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'OTP' && otpSent\">\n        <div class=\"field-head\">OTP</div>\n        <div class=\"field-text-1\">\n          <div id=\"otp\" class=\"inputs d-flex flex-row justify-content-center mt-2\">\n            <ng-container *ngFor=\"let _ of [].constructor(4); let idx = index\">\n              <input class=\"m-2 text-center form-control rounded additional-styles\" type=\"number\" max=\"1\"\n                [(ngModel)]=\"loginOtpArray[idx]\" (keyup)=\"moveLoginOtpCursor($event, idx)\" [id]=\"'loginOtp_'+idx\" #otpInput />\n            </ng-container>\n          </div>\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'OTP_VERIFY'\">\n        <!-- <div class=\"field-head\" *ngIf=\"currentPage == 'OTP' \">OTP</div> -->\n        <div class=\"field-text-1\">\n          <div id=\"otp\" class=\"inputs d-flex flex-row justify-content-center mt-2\">\n            <ng-container *ngFor=\"let _ of [].constructor(4); let idx = index\">\n              <input class=\"m-2 text-center form-control rounded additional-styles\" type=\"number\" max=\"1\"\n                [(ngModel)]=\"otpArray[idx]\" (keyup)=\"move($event, idx)\" [id]=\"'otp_'+idx\" #otpInput />\n            </ng-container>\n          </div>\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n        <div class=\"field-head\">Name</div>\n        <div class=\"field-text\">\n          <input type=\"text\" placeholder=\"Please Enter Your Name\" [(ngModel)]=\"investor.fullName\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n        <div class=\"field-head\">Email</div>\n        <div class=\"field-text\">\n          <input type=\"text\" placeholder=\"Please Enter Your Email\" [(ngModel)]=\"investor.emailId\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'SIGN_UP'\">\n        <div class=\"field-head\">Phone Number</div>\n        <div class=\"field-text\">\n          <input type=\"text\" placeholder=\"Please Enter Your Phone Number\" [(ngModel)]=\"investor.phoneNumber\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n        <div class=\"field-head\">Old Password</div>\n        <div class=\"field-text\">\n          <input type=\"password\" placeholder=\"Please Enter Your Password\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n        <div class=\"field-head\">New Password</div>\n        <div class=\"field-text\">\n          <input type=\"password\" placeholder=\"Please Enter Your Password\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'FORGOT_PASSWORD'\">\n        <div class=\"field-head\">Re-Enter Password</div>\n        <div class=\"field-text\">\n          <input type=\"password\" placeholder=\"Please Re-Enter Your Password\">\n        </div>\n      </div>\n      <div class=\"field mb-15\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'SIGN_UP' \">\n        <div class=\"field-head\">Password</div>\n        <div class=\"field-text\">\n          <input type=\"password\" placeholder=\"Please Enter Your Password\" [(ngModel)]=\"investor.password\">\n        </div>\n      </div>\n      <div class=\"forgot-password cursor-pointer\" [style.color]=\"data?.styles?.background?.accentColor\"\n        *ngIf=\"currentPage == 'LOGIN'\" (click)=\"currentPage = 'FORGOT_PASSWORD'\">Forgot Password?</div>\n      <div class=\"forgot-password cursor-pointer\" [style.color]=\"data?.styles?.background?.accentColor\"\n        *ngIf=\"currentPage == 'OTP_VERIFY'\">Resend OTP?</div>\n      <div class=\"btn-container d-flex align-items-center justify-content-center\">\n        <button class=\"login-btn cursor-pointer\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage != 'OTP'\"\n        (click)=\"buttonClickedEvent()\" [disabled]=\"buttonLoader\" [class.btn-size]=\"currentPage == 'FORGOT_PASSWORD' || currentPage == 'SIGN_UP' || currentPage == 'OTP_VERIFY'\">\n          <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n          <span *ngIf=\"!buttonLoader\">{{ currentPage ==\n            'LOGIN' ? \"Login\" : currentPage == 'FORGOT_PASSWORD' ? \"Reset Password\" :\n            currentPage == 'OTP_VERIFY' ? 'Verify OTP' : \"Create Account\"}}</span></button>\n\n        <button class=\"login-btn cursor-pointer\" (click)=\"sendOtpForLogin()\" [disabled]=\"buttonLoader\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP' && !otpSent\">\n          <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n          <span *ngIf=\"!buttonLoader\">Send Otp</span>\n          </button>\n\n        <button class=\"login-btn cursor-pointer\" (click)=\"verifyOtp()\" [disabled]=\"buttonLoader\" [style.background]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP' && otpSent\">\n          <span *ngIf=\"buttonLoader\" ><i class=\"fas fa-circle-notch fa-spin\"></i>&nbsp;Loading</span>\n          <span *ngIf=\"!buttonLoader\" >Login</span>\n         </button>\n      </div>\n      <div class=\"another-page\" *ngIf=\"currentPage == 'LOGIN' || currentPage == 'OTP'\">\n        <div class=\"signup-text\">Don’t have an account? <span class=\"span-text cursor-pointer\"\n            [style.color]=\"data?.styles?.background?.accentColor\" (click)=\"currentPage = 'SIGN_UP'\">Sign\n            Up</span></div>\n        <div class=\"signup-text m-5\">or</div>\n        <div class=\"signup-text\">Login with <span class=\"span-text cursor-pointer\"\n            [style.color]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'LOGIN' \"\n            (click)=\"currentPage = 'OTP'\">OTP</span><span class=\"span-text cursor-pointer\"\n            [style.color]=\"data?.styles?.background?.accentColor\" *ngIf=\"currentPage == 'OTP'\"\n            (click)=\"currentPage = 'LOGIN'\">Password</span></div>\n      </div>\n      <div class=\"another-page\" *ngIf=\"currentPage == 'SIGN_UP' || currentPage == 'FORGOT_PASSWORD'\">\n        <div class=\"signup-text\">Already have an account? <span class=\"span-text cursor-pointer\"\n            [style.color]=\"data?.styles?.background?.accentColor\" (click)=\"currentPage = 'LOGIN'\">Sign\n            In</span></div>\n      </div>\n    </div>\n  </div>\n\n  <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\n    <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\n  </div>\n  <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\n    <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\n  </div>\n</section>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbnVwLXNpZ25pbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvc2VjdGlvbnMvc2lnbnVwLXNpZ25pbi9zaWdudXAtc2lnbmluLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDYXJkU3R5bGVzLCBTdHlsZXNNb2RlbCB9IGZyb20gXCIuLy4uLy4uL3N0eWxlcy9zdHlsZS5tb2RlbFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNpZ25VcFNpZ25Jbk1vZGVse1xuICAgIGlkOiBzdHJpbmcsXG4gICAgc2VjdGlvblR5cGU6IHN0cmluZyxcbiAgICBzZWN0aW9uTmFtZTogc3RyaW5nLFxuICAgIGNvbnRlbnQgOiB7fSxcbiAgICBzdHlsZXM6IFNpZ25JblNpZ25VcFN0eWxlc01vZGVsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNpZ25JblNpZ25VcFN0eWxlc01vZGVsIGV4dGVuZHMgU3R5bGVzTW9kZWwsQ2FyZFN0eWxlc3tcblxufSJdfQ==
@@ -0,0 +1,55 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component } from '@angular/core';
3
+ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services/rest.service";
6
+ import * as i2 from "@angular/router";
7
+ import * as i3 from "@angular/material/progress-spinner";
8
+ import * as i4 from "@angular/common";
9
+ export class VerifyPropertyPaymentComponent {
10
+ constructor(restService, router) {
11
+ this.restService = restService;
12
+ this.router = router;
13
+ this.paymentStatus = 'ONGOING';
14
+ this.API_COUNT = 0;
15
+ this.MAX_API_COUNT = 20;
16
+ }
17
+ ngOnInit() {
18
+ this.checkPaymentStatus();
19
+ }
20
+ checkPaymentStatus() {
21
+ this.API_COUNT++;
22
+ this.restService.verifyPropertyPaymentStatus().subscribe((res) => {
23
+ if (res.status === 'PURCHASED')
24
+ this.paymentStatus = 'SUCCESS';
25
+ else
26
+ this.paymentStatus = 'FAILED';
27
+ this.redirectToPage('profile');
28
+ }, (error) => {
29
+ if (error.message == 'Payment Failed') {
30
+ this.paymentStatus = 'FAILED';
31
+ this.redirectToPage('property-list');
32
+ return;
33
+ }
34
+ if (this.API_COUNT >= this.MAX_API_COUNT) {
35
+ this.paymentStatus = 'FAILED';
36
+ this.redirectToPage('property-list');
37
+ }
38
+ else {
39
+ this.checkPaymentStatus();
40
+ }
41
+ });
42
+ }
43
+ redirectToPage(pageUrl) {
44
+ setTimeout(() => {
45
+ this.router.navigate([`${pageUrl}`]);
46
+ }, 5000);
47
+ }
48
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: VerifyPropertyPaymentComponent, deps: [{ token: i1.RestService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: VerifyPropertyPaymentComponent, isStandalone: true, selector: "simpo-verify-property-payment", ngImport: i0, template: "<section class=\"main-section spinner\" *ngIf=\"paymentStatus === 'ONGOING'\">\n <div>\n <mat-spinner></mat-spinner>\n <p>Please Wait...</p>\n </div>\n</section>\n\n<section class=\"main-section spinner\" *ngIf=\"paymentStatus === 'SUCCESS'\">\n <div>\n <div class=\"image_section\">\n <img src=\"https://dev-beeos.s3.amazonaws.com/product_image/452801c1736315910620sucess.gif\" alt=\"loader\">\n </div>\n <div class=\"success_heading\">\n Payment Successfull\n </div>\n </div>\n\n</section>\n\n<section class=\"main-section spinner\" *ngIf=\"paymentStatus === 'FAILED'\">\n <div>\n <div class=\"image_section\">\n <img src=\"https://dev-beeos.s3.amazonaws.com/product_image/812371c1736315916840fail.jpg\" alt=\"loader\">\n </div>\n <div class=\"success_heading\">\n Payment Failed\n </div>\n </div>\n</section>\n", styles: [".main-section{height:calc(100vh + -0px);z-index:2;position:absolute;top:0;left:0;background:#fff;width:100%;overflow-y:hidden}.spinner{display:flex;align-items:center;justify-content:center}.spinner p{margin-top:22px;font-size:18px;font-weight:500}.success_heading{color:#000;margin-top:10px}.image_section{text-align:center}.image_section img{width:100px}.plan_description{margin-top:10px!important;box-shadow:0 0 1px #28293d14,0 .5px 2px #60617029;border-radius:10px;width:30%;margin:0 auto;padding:40px}.title_value{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px}@media only screen and (max-width:475px){.payment_sub_text{width:80%}.plan_description{width:80%;height:auto}}.main_section{gap:15px;height:100%;width:100%}.success_failed_images{width:12%}.success_failed_images img{width:100%}.title{font-size:18px;font-weight:600;color:#344054;font-family:interMedium}.message{font-size:14px;font-weight:500;color:#00000080;font-family:interMedium}.buttons button{border:none;background-color:#f6c318;padding:2px 8px;color:#000;border-radius:6px;font-size:x-large;font-weight:500;line-height:initial}.create-btn{font-weight:500;color:#000;border:none;padding:10px 16px;border-radius:8px;font-size:15px;line-height:20px;display:flex;align-items:center;gap:5px;background-color:#f6c318}.create-btn .mat-icon{font-size:24px}\n"], dependencies: [{ kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i3.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
50
+ }
51
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: VerifyPropertyPaymentComponent, decorators: [{
52
+ type: Component,
53
+ args: [{ selector: 'simpo-verify-property-payment', standalone: true, imports: [MatProgressSpinnerModule, CommonModule], template: "<section class=\"main-section spinner\" *ngIf=\"paymentStatus === 'ONGOING'\">\n <div>\n <mat-spinner></mat-spinner>\n <p>Please Wait...</p>\n </div>\n</section>\n\n<section class=\"main-section spinner\" *ngIf=\"paymentStatus === 'SUCCESS'\">\n <div>\n <div class=\"image_section\">\n <img src=\"https://dev-beeos.s3.amazonaws.com/product_image/452801c1736315910620sucess.gif\" alt=\"loader\">\n </div>\n <div class=\"success_heading\">\n Payment Successfull\n </div>\n </div>\n\n</section>\n\n<section class=\"main-section spinner\" *ngIf=\"paymentStatus === 'FAILED'\">\n <div>\n <div class=\"image_section\">\n <img src=\"https://dev-beeos.s3.amazonaws.com/product_image/812371c1736315916840fail.jpg\" alt=\"loader\">\n </div>\n <div class=\"success_heading\">\n Payment Failed\n </div>\n </div>\n</section>\n", styles: [".main-section{height:calc(100vh + -0px);z-index:2;position:absolute;top:0;left:0;background:#fff;width:100%;overflow-y:hidden}.spinner{display:flex;align-items:center;justify-content:center}.spinner p{margin-top:22px;font-size:18px;font-weight:500}.success_heading{color:#000;margin-top:10px}.image_section{text-align:center}.image_section img{width:100px}.plan_description{margin-top:10px!important;box-shadow:0 0 1px #28293d14,0 .5px 2px #60617029;border-radius:10px;width:30%;margin:0 auto;padding:40px}.title_value{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px}@media only screen and (max-width:475px){.payment_sub_text{width:80%}.plan_description{width:80%;height:auto}}.main_section{gap:15px;height:100%;width:100%}.success_failed_images{width:12%}.success_failed_images img{width:100%}.title{font-size:18px;font-weight:600;color:#344054;font-family:interMedium}.message{font-size:14px;font-weight:500;color:#00000080;font-family:interMedium}.buttons button{border:none;background-color:#f6c318;padding:2px 8px;color:#000;border-radius:6px;font-size:x-large;font-weight:500;line-height:initial}.create-btn{font-weight:500;color:#000;border:none;padding:10px 16px;border-radius:8px;font-size:15px;line-height:20px;display:flex;align-items:center;gap:5px;background-color:#f6c318}.create-btn .mat-icon{font-size:24px}\n"] }]
54
+ }], ctorParameters: () => [{ type: i1.RestService }, { type: i2.Router }] });
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5LXByb3BlcnR5LXBheW1lbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2ltcG8tdWkvc3JjL2xpYi9zZWN0aW9ucy92ZXJpZnktcHJvcGVydHktcGF5bWVudC92ZXJpZnktcHJvcGVydHktcGF5bWVudC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaW1wby11aS9zcmMvbGliL3NlY3Rpb25zL3ZlcmlmeS1wcm9wZXJ0eS1wYXltZW50L3ZlcmlmeS1wcm9wZXJ0eS1wYXltZW50LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7Ozs7QUFXOUUsTUFBTSxPQUFPLDhCQUE4QjtJQU16QyxZQUFvQixXQUF3QixFQUNsQyxNQUFjO1FBREosZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDbEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQU54QixrQkFBYSxHQUFxQyxTQUFTLENBQUE7UUFFbkQsY0FBUyxHQUFXLENBQUMsQ0FBQztRQUN0QixrQkFBYSxHQUFXLEVBQUUsQ0FBQztJQUkvQixDQUFDO0lBRUwsUUFBUTtRQUNOLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxXQUFXLENBQUMsMkJBQTJCLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFRLEVBQUUsRUFBRTtZQUVwRSxJQUFHLEdBQUcsQ0FBQyxNQUFNLEtBQUssV0FBVztnQkFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxTQUFTLENBQUM7O2dCQUUvQixJQUFJLENBQUMsYUFBYSxHQUFHLFFBQVEsQ0FBQztZQUVoQyxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRWpDLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ1gsSUFBRyxLQUFLLENBQUMsT0FBTyxJQUFJLGdCQUFnQixFQUFDLENBQUM7Z0JBQ3BDLElBQUksQ0FBQyxhQUFhLEdBQUcsUUFBUSxDQUFDO2dCQUM5QixJQUFJLENBQUMsY0FBYyxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUNyQyxPQUFPO1lBQ1QsQ0FBQztZQUVELElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7Z0JBQ3pDLElBQUksQ0FBQyxhQUFhLEdBQUcsUUFBUSxDQUFDO2dCQUM5QixJQUFJLENBQUMsY0FBYyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQ3ZDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztZQUM1QixDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQsY0FBYyxDQUFDLE9BQWU7UUFDNUIsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQUE7UUFDdEMsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFBO0lBQ1YsQ0FBQzs4R0E3Q1UsOEJBQThCO2tHQUE5Qiw4QkFBOEIseUZDYjNDLDIyQkE2QkEsdzRDRHBCWSx3QkFBd0Isa09BQUUsWUFBWTs7MkZBSXJDLDhCQUE4QjtrQkFQMUMsU0FBUzsrQkFDRSwrQkFBK0IsY0FDN0IsSUFBSSxXQUNQLENBQUMsd0JBQXdCLEVBQUUsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XG5pbXBvcnQgeyBSZXN0U2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3Jlc3Quc2VydmljZSc7XG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzaW1wby12ZXJpZnktcHJvcGVydHktcGF5bWVudCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGUsIENvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi92ZXJpZnktcHJvcGVydHktcGF5bWVudC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi92ZXJpZnktcHJvcGVydHktcGF5bWVudC5jb21wb25lbnQuY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBWZXJpZnlQcm9wZXJ0eVBheW1lbnRDb21wb25lbnQge1xuICBwYXltZW50U3RhdHVzOiAnT05HT0lORycgfCAnU1VDQ0VTUycgfCAnRkFJTEVEJyA9ICdPTkdPSU5HJ1xuXG4gIHByaXZhdGUgQVBJX0NPVU5UOiBudW1iZXIgPSAwO1xuICBwcml2YXRlIE1BWF9BUElfQ09VTlQ6IG51bWJlciA9IDIwO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVzdFNlcnZpY2U6IFJlc3RTZXJ2aWNlLFxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXJcbiAgKSB7IH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmNoZWNrUGF5bWVudFN0YXR1cygpO1xuICB9XG5cbiAgY2hlY2tQYXltZW50U3RhdHVzKCkge1xuICAgIHRoaXMuQVBJX0NPVU5UKys7XG4gICAgdGhpcy5yZXN0U2VydmljZS52ZXJpZnlQcm9wZXJ0eVBheW1lbnRTdGF0dXMoKS5zdWJzY3JpYmUoKHJlczogYW55KSA9PiB7XG5cbiAgICAgIGlmKHJlcy5zdGF0dXMgPT09ICdQVVJDSEFTRUQnKVxuICAgICAgICB0aGlzLnBheW1lbnRTdGF0dXMgPSAnU1VDQ0VTUyc7XG4gICAgICBlbHNlXG4gICAgICAgIHRoaXMucGF5bWVudFN0YXR1cyA9ICdGQUlMRUQnO1xuXG4gICAgICB0aGlzLnJlZGlyZWN0VG9QYWdlKCdwcm9maWxlJyk7XG5cbiAgICB9LCAoZXJyb3IpID0+IHtcbiAgICAgIGlmKGVycm9yLm1lc3NhZ2UgPT0gJ1BheW1lbnQgRmFpbGVkJyl7XG4gICAgICAgIHRoaXMucGF5bWVudFN0YXR1cyA9ICdGQUlMRUQnO1xuICAgICAgICB0aGlzLnJlZGlyZWN0VG9QYWdlKCdwcm9wZXJ0eS1saXN0Jyk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgaWYgKHRoaXMuQVBJX0NPVU5UID49IHRoaXMuTUFYX0FQSV9DT1VOVCkge1xuICAgICAgICB0aGlzLnBheW1lbnRTdGF0dXMgPSAnRkFJTEVEJztcbiAgICAgICAgdGhpcy5yZWRpcmVjdFRvUGFnZSgncHJvcGVydHktbGlzdCcpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5jaGVja1BheW1lbnRTdGF0dXMoKTtcbiAgICAgIH1cbiAgICB9KVxuICB9XG5cbiAgcmVkaXJlY3RUb1BhZ2UocGFnZVVybDogc3RyaW5nKSB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbYCR7cGFnZVVybH1gXSlcbiAgICB9LCA1MDAwKVxuICB9XG59XG4iLCI8c2VjdGlvbiBjbGFzcz1cIm1haW4tc2VjdGlvbiBzcGlubmVyXCIgKm5nSWY9XCJwYXltZW50U3RhdHVzID09PSAnT05HT0lORydcIj5cbiAgPGRpdj5cbiAgICA8bWF0LXNwaW5uZXI+PC9tYXQtc3Bpbm5lcj5cbiAgICA8cD5QbGVhc2UgV2FpdC4uLjwvcD5cbiAgPC9kaXY+XG48L3NlY3Rpb24+XG5cbjxzZWN0aW9uIGNsYXNzPVwibWFpbi1zZWN0aW9uIHNwaW5uZXJcIiAqbmdJZj1cInBheW1lbnRTdGF0dXMgPT09ICdTVUNDRVNTJ1wiPlxuICA8ZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJpbWFnZV9zZWN0aW9uXCI+XG4gICAgICA8aW1nIHNyYz1cImh0dHBzOi8vZGV2LWJlZW9zLnMzLmFtYXpvbmF3cy5jb20vcHJvZHVjdF9pbWFnZS80NTI4MDFjMTczNjMxNTkxMDYyMHN1Y2Vzcy5naWZcIiBhbHQ9XCJsb2FkZXJcIj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwic3VjY2Vzc19oZWFkaW5nXCI+XG4gICAgICAgIFBheW1lbnQgU3VjY2Vzc2Z1bGxcbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG5cbjwvc2VjdGlvbj5cblxuPHNlY3Rpb24gY2xhc3M9XCJtYWluLXNlY3Rpb24gc3Bpbm5lclwiICpuZ0lmPVwicGF5bWVudFN0YXR1cyA9PT0gJ0ZBSUxFRCdcIj5cbiAgPGRpdj5cbiAgICA8ZGl2IGNsYXNzPVwiaW1hZ2Vfc2VjdGlvblwiPlxuICAgICAgPGltZyBzcmM9XCJodHRwczovL2Rldi1iZWVvcy5zMy5hbWF6b25hd3MuY29tL3Byb2R1Y3RfaW1hZ2UvODEyMzcxYzE3MzYzMTU5MTY4NDBmYWlsLmpwZ1wiIGFsdD1cImxvYWRlclwiPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJzdWNjZXNzX2hlYWRpbmdcIj5cbiAgICAgICAgUGF5bWVudCBGYWlsZWRcbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L3NlY3Rpb24+XG4iXX0=
@@ -44,6 +44,7 @@ export class EventsService {
44
44
  this.environmentType = new EventEmitter();
45
45
  this.categoryProductList = new EventEmitter();
46
46
  this.collectionsListEvent = new EventEmitter();
47
+ this.propertyListEvent = new EventEmitter();
47
48
  this.categoryListEvent = new EventEmitter();
48
49
  this.showLoadingScreen = new EventEmitter();
49
50
  this.cashFreeEvent = new EventEmitter();
@@ -61,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
61
62
  providedIn: 'root',
62
63
  }]
63
64
  }], ctorParameters: () => [] });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaW1wby11aS9zcmMvbGliL3NlcnZpY2VzL2V2ZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQUtqRSxNQUFNLE9BQU8sYUFBYTtJQUN4QjtRQU1BLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUMxQyxjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN4QyxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNyQyxtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDN0MsdUJBQWtCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNqRCxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDNUMsbUJBQWMsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQzdDLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDcEQsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNoRCxvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDOUMsb0JBQW9CO1FBRXBCLCtCQUEwQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDekQsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN2RCwwQkFBcUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3BELDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDcEQsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNsRCx1QkFBa0IsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2pELHlCQUFvQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDbkQsMkJBQXNCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNyRCx1QkFBa0IsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2pELCtCQUEwQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDekQsNEJBQXVCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN0RCw4QkFBeUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3hELGdDQUEyQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDMUQsOEJBQXlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN4RCx3QkFBbUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2xELHdCQUFtQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDbEQsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNsRCxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDNUMsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNoRCxzQkFBaUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2hELHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFDN0Msa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTNDLHNCQUFpQixHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDNUMsMEJBQTBCO1FBQzFCLG1CQUFjLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUM3QyxjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN4QyxlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN6QywwQkFBcUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3BELG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUM3Qyx3QkFBbUIsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBQ2pELHlCQUFvQixHQUFHLElBQUksWUFBWSxFQUFZLENBQUM7UUFDcEQsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUUvQyxzQkFBaUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBRWhELGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUM1QyxvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFDN0MsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQzFDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7SUF2RDVDLENBQUM7SUFFSixRQUFRLEtBQVUsQ0FBQzs4R0FMUixhQUFhO2tIQUFiLGFBQWEsY0FGWixNQUFNOzsyRkFFUCxhQUFhO2tCQUh6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW1pdHRlciwgSW5qZWN0YWJsZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRXZlbnRzU2VydmljZSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgY29uc3RydWN0b3IoXHJcblxyXG4gICkge31cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7fVxyXG5cclxuICBlZGl0U2VjdGlvbiA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBkdXBsaWNhdGUgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgZGVsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGNoYW5nZVBvc2l0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGFkZE5ld1NlY3Rpb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBjaGFuZ2VDb250ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIHJlc3R5bGVTZWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIHBhZ2VSZWRpcmVjdGlvbkJ1dHRvbiA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBidXR0b25SZWRpcmVjdGlvbiA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBjb250YWN0Rm9ybURhdGEgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgLy9yZWZlcmVuY2Ugc2VydmljZXNcclxuXHJcbiAgYmFja2dyb3VuZEltYWdlQ2hhbmdlQ2hlY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgY29sb3JPdmVybGF5Q2hhbmdlQ2hlY2tzID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGFsaWdubWVudENoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBhbmltYXRpb25DaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgc3BhY2luZ0NoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBib3JkZXJDaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgY2FyZFNpemVDaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgaW1hZ2VTdHlsZUNoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBjb3JuZXJDaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgdGV4dEJhY2tncm91bmRDaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgYnV0dG9uU3R5bGVDaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgcG9zdGlvbkxheW91dENoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBjb250ZW50QWxpZ25tZW50Q2hhbmdlQ2hlY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgb2JqZWN0UG9zaXRpb25DaGFuZ2VDaGVjayA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBsb2NhdGlvbkNoYW5nZUNoZWNrID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIG1hcFN0eWxlQ2hhbmdlQ2hlY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgdGV4dFNpemVDaGFuZ2VDaGVjayA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBibG9nQnlJZEV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIG9wZW5CbG9nTGlzdEV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIHRvZ2dsZUVkaXRvckV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG4gIGNsb3NlRWRpdG9yRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPGZhbHNlPigpO1xyXG4gIHdyYXBEaXJlY3Rpb24gPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcclxuXHJcbiAgc3RvcENhcm91c2VsRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICAvLyBFY29tbWVyY2UgZXZlbnQgZW1pdHRlclxyXG4gIHJlZGlyZWN0VG9QYWdlID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGFkZFRvQ2FydCA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBwbGFjZU9yZGVyID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGZlYXR1cmVDb2xsZWN0aW9uTGlzdCA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBlbnZpcm9ubWVudFR5cGUgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcclxuICBjYXRlZ29yeVByb2R1Y3RMaXN0ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XHJcbiAgY29sbGVjdGlvbnNMaXN0RXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZ1tdPigpO1xyXG4gIGNhdGVnb3J5TGlzdEV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XHJcblxyXG4gIHNob3dMb2FkaW5nU2NyZWVuID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG5cclxuICBjYXNoRnJlZUV2ZW50ID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGFkZHJlc3NBZGRlZElkeCA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xyXG4gIHNob3dCYWdJY29uID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG4gIGZvcm1GaWVsZENoYW5nZWQgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbn1cclxuIl19
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaW1wby11aS9zcmMvbGliL3NlcnZpY2VzL2V2ZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQUtqRSxNQUFNLE9BQU8sYUFBYTtJQUN4QjtRQU1BLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUMxQyxjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN4QyxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNyQyxtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDN0MsdUJBQWtCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNqRCxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDNUMsbUJBQWMsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQzdDLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDcEQsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNoRCxvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDOUMsb0JBQW9CO1FBRXBCLCtCQUEwQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDekQsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN2RCwwQkFBcUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3BELDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDcEQsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNsRCx1QkFBa0IsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2pELHlCQUFvQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDbkQsMkJBQXNCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNyRCx1QkFBa0IsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2pELCtCQUEwQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDekQsNEJBQXVCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN0RCw4QkFBeUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3hELGdDQUEyQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDMUQsOEJBQXlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN4RCx3QkFBbUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2xELHdCQUFtQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDbEQsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNsRCxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDNUMsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNoRCxzQkFBaUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ2hELHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFDN0Msa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTNDLHNCQUFpQixHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDNUMsMEJBQTBCO1FBQzFCLG1CQUFjLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUM3QyxjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN4QyxlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUN6QywwQkFBcUIsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3BELG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUM3Qyx3QkFBbUIsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBQ2pELHlCQUFvQixHQUFHLElBQUksWUFBWSxFQUFZLENBQUM7UUFDcEQsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUMvQyxzQkFBaUIsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRS9DLHNCQUFpQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFFaEQsa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQzVDLG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUM3QyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7UUFDMUMscUJBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztJQXhENUMsQ0FBQztJQUVKLFFBQVEsS0FBVSxDQUFDOzhHQUxSLGFBQWE7a0hBQWIsYUFBYSxjQUZaLE1BQU07OzJGQUVQLGFBQWE7a0JBSHpCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnRFbWl0dGVyLCBJbmplY3RhYmxlLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFdmVudHNTZXJ2aWNlIGltcGxlbWVudHMgT25Jbml0IHtcclxuICBjb25zdHJ1Y3RvcihcclxuXHJcbiAgKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHt9XHJcblxyXG4gIGVkaXRTZWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGR1cGxpY2F0ZSA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBkZWxldGUgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgY2hhbmdlUG9zaXRpb24gPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgYWRkTmV3U2VjdGlvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGNoYW5nZUNvbnRlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgcmVzdHlsZVNlY3Rpb24gPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgcGFnZVJlZGlyZWN0aW9uQnV0dG9uID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGJ1dHRvblJlZGlyZWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGNvbnRhY3RGb3JtRGF0YSA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICAvL3JlZmVyZW5jZSBzZXJ2aWNlc1xyXG5cclxuICBiYWNrZ3JvdW5kSW1hZ2VDaGFuZ2VDaGVjayA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBjb2xvck92ZXJsYXlDaGFuZ2VDaGVja3MgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgYWxpZ25tZW50Q2hhbmdlQ2hlY2tzID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGFuaW1hdGlvbkNoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBzcGFjaW5nQ2hhbmdlQ2hlY2tzID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGJvcmRlckNoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBjYXJkU2l6ZUNoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBpbWFnZVN0eWxlQ2hhbmdlQ2hlY2tzID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGNvcm5lckNoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICB0ZXh0QmFja2dyb3VuZENoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBidXR0b25TdHlsZUNoYW5nZUNoZWNrcyA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBwb3N0aW9uTGF5b3V0Q2hhbmdlQ2hlY2tzID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGNvbnRlbnRBbGlnbm1lbnRDaGFuZ2VDaGVjayA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBvYmplY3RQb3NpdGlvbkNoYW5nZUNoZWNrID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGxvY2F0aW9uQ2hhbmdlQ2hlY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgbWFwU3R5bGVDaGFuZ2VDaGVjayA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICB0ZXh0U2l6ZUNoYW5nZUNoZWNrID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGJsb2dCeUlkRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgb3BlbkJsb2dMaXN0RXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgdG9nZ2xlRWRpdG9yRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XHJcbiAgY2xvc2VFZGl0b3JFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8ZmFsc2U+KCk7XHJcbiAgd3JhcERpcmVjdGlvbiA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG5cclxuICBzdG9wQ2Fyb3VzZWxFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xyXG4gIC8vIEVjb21tZXJjZSBldmVudCBlbWl0dGVyXHJcbiAgcmVkaXJlY3RUb1BhZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgYWRkVG9DYXJ0ID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIHBsYWNlT3JkZXIgPSBuZXcgRXZlbnRFbWl0dGVyPHVua25vd24+KCk7XHJcbiAgZmVhdHVyZUNvbGxlY3Rpb25MaXN0ID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG4gIGVudmlyb25tZW50VHlwZSA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG4gIGNhdGVnb3J5UHJvZHVjdExpc3QgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcclxuICBjb2xsZWN0aW9uc0xpc3RFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nW10+KCk7XHJcbiAgcHJvcGVydHlMaXN0RXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcclxuICBjYXRlZ29yeUxpc3RFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG5cclxuICBzaG93TG9hZGluZ1NjcmVlbiA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuXHJcbiAgY2FzaEZyZWVFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8dW5rbm93bj4oKTtcclxuICBhZGRyZXNzQWRkZWRJZHggPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcclxuICBzaG93QmFnSWNvbiA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuICBmb3JtRmllbGRDaGFuZ2VkID0gbmV3IEV2ZW50RW1pdHRlcjx1bmtub3duPigpO1xyXG59XHJcbiJdfQ==