simpo-component-library 1.6.145 → 1.6.146
Sign up to get free protection for your applications and to get access to all the features.
- package/esm2022/lib/ecommerce/sections/authenticate-user/authenticate-user.component.mjs +3 -3
- package/esm2022/lib/ecommerce/sections/authentication-required/authentication-required.component.mjs +111 -11
- package/esm2022/lib/ecommerce/sections/cart/cart.component.mjs +5 -3
- package/fesm2022/simpo-component-library.mjs +107 -10
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/directive/background-directive.d.ts +1 -1
- package/lib/directive/button-directive.directive.d.ts +1 -1
- package/lib/directive/color.directive.d.ts +1 -1
- package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +13 -2
- package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
- package/package.json +1 -1
- package/simpo-component-library-1.6.146.tgz +0 -0
package/esm2022/lib/ecommerce/sections/authentication-required/authentication-required.component.mjs
CHANGED
@@ -1,23 +1,31 @@
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
2
|
-
import { Component } from '@angular/core';
|
2
|
+
import { Component, Optional } from '@angular/core';
|
3
3
|
import { FormsModule } from '@angular/forms';
|
4
4
|
import { MessageService } from 'primeng/api';
|
5
5
|
import { ToastModule } from 'primeng/toast';
|
6
6
|
import Swal from 'sweetalert2';
|
7
|
+
import { MatIconModule } from '@angular/material/icon';
|
8
|
+
import { UserBasicInfoComponent } from '../user-basic-info/user-basic-info.component';
|
7
9
|
import * as i0 from "@angular/core";
|
8
10
|
import * as i1 from "../../../services/rest.service";
|
9
11
|
import * as i2 from "@angular/router";
|
10
12
|
import * as i3 from "primeng/api";
|
11
13
|
import * as i4 from "../../../services/storage.service";
|
12
|
-
import * as i5 from "@angular/
|
13
|
-
import * as i6 from "@angular/
|
14
|
-
import * as i7 from "
|
14
|
+
import * as i5 from "@angular/material/dialog";
|
15
|
+
import * as i6 from "@angular/material/bottom-sheet";
|
16
|
+
import * as i7 from "@angular/common";
|
17
|
+
import * as i8 from "@angular/forms";
|
18
|
+
import * as i9 from "primeng/toast";
|
19
|
+
import * as i10 from "@angular/material/icon";
|
15
20
|
export class AuthenticationRequiredComponent {
|
16
|
-
constructor(restService, router, messageService, storageService) {
|
21
|
+
constructor(restService, router, messageService, storageService, matDialog, dialogRef, bottomsheetRef) {
|
17
22
|
this.restService = restService;
|
18
23
|
this.router = router;
|
19
24
|
this.messageService = messageService;
|
20
25
|
this.storageService = storageService;
|
26
|
+
this.matDialog = matDialog;
|
27
|
+
this.dialogRef = dialogRef;
|
28
|
+
this.bottomsheetRef = bottomsheetRef;
|
21
29
|
this.email = "";
|
22
30
|
this.mobile = "";
|
23
31
|
this.otp = "";
|
@@ -26,8 +34,17 @@ export class AuthenticationRequiredComponent {
|
|
26
34
|
this.userName = "";
|
27
35
|
this.buttonLoading = false;
|
28
36
|
this.businessId = localStorage.getItem("bId");
|
37
|
+
this.loginType = "OTP";
|
29
38
|
}
|
30
39
|
login() {
|
40
|
+
if (this.loginType == "OTP") {
|
41
|
+
this.verifyOTP();
|
42
|
+
}
|
43
|
+
else {
|
44
|
+
this.verifyPassword();
|
45
|
+
}
|
46
|
+
}
|
47
|
+
verifyPassword() {
|
31
48
|
const payload = {
|
32
49
|
businessId: this.businessId,
|
33
50
|
email: this.email,
|
@@ -42,6 +59,52 @@ export class AuthenticationRequiredComponent {
|
|
42
59
|
this.messageService.add({ severity: 'error', summary: 'Invalid credentials', detail: 'Please enter valid credentials' });
|
43
60
|
});
|
44
61
|
}
|
62
|
+
verifyOTP() {
|
63
|
+
const deviceInfo = {
|
64
|
+
firebaseToken: localStorage.getItem("fbToken") ?? ""
|
65
|
+
};
|
66
|
+
this.buttonLoading = true;
|
67
|
+
this.restService.verifyOTP(this.mobile ?? "", this.otp, deviceInfo).subscribe((response) => {
|
68
|
+
const userDetails = this.storageService.setUser(response.data);
|
69
|
+
this.storageService.updateAllData();
|
70
|
+
if (this.dialogRef)
|
71
|
+
this.dialogRef.close("SUCCESS");
|
72
|
+
if (this.bottomsheetRef)
|
73
|
+
this.bottomsheetRef.dismiss("SUCCESS");
|
74
|
+
this.buttonLoading = false;
|
75
|
+
Swal.fire({
|
76
|
+
icon: "success",
|
77
|
+
title: "Hurray",
|
78
|
+
text: "Your account successfully created",
|
79
|
+
showCancelButton: !(userDetails.contact?.name?.length > 0),
|
80
|
+
confirmButtonText: "I loved it",
|
81
|
+
cancelButtonText: "Fill other basic details",
|
82
|
+
cancelButtonColor: "#928c8c",
|
83
|
+
}).then((result) => {
|
84
|
+
if (result.isConfirmed) {
|
85
|
+
if (this.dialogRef)
|
86
|
+
this.dialogRef.close("SUCCESS");
|
87
|
+
if (this.bottomsheetRef)
|
88
|
+
this.bottomsheetRef.dismiss("SUCCESS");
|
89
|
+
}
|
90
|
+
else if (result.isDismissed) {
|
91
|
+
if (this.dialogRef)
|
92
|
+
this.dialogRef.close("SUCCESS");
|
93
|
+
if (this.bottomsheetRef)
|
94
|
+
this.bottomsheetRef.dismiss("SUCCESS");
|
95
|
+
this.matDialog.open(UserBasicInfoComponent, {
|
96
|
+
height: '50vh',
|
97
|
+
width: window.innerWidth > 475 ? '40vw' : '95vw',
|
98
|
+
maxWidth: window.innerWidth > 475 ? '100vw' : '80vw',
|
99
|
+
data: {}
|
100
|
+
});
|
101
|
+
}
|
102
|
+
});
|
103
|
+
}, (error) => {
|
104
|
+
this.buttonLoading = false;
|
105
|
+
this.messageService.add({ severity: 'error', summary: 'Invalid OTP', detail: 'Please enter valid otp' });
|
106
|
+
});
|
107
|
+
}
|
45
108
|
createAccount() {
|
46
109
|
const deviceInfo = {
|
47
110
|
firebaseToken: localStorage.getItem("fbToken") ?? ""
|
@@ -79,18 +142,55 @@ export class AuthenticationRequiredComponent {
|
|
79
142
|
}
|
80
143
|
});
|
81
144
|
}
|
145
|
+
enterMobile() {
|
146
|
+
if (this.mobile.length == 10) {
|
147
|
+
this.generateOTP();
|
148
|
+
}
|
149
|
+
}
|
150
|
+
generateOTP() {
|
151
|
+
this.buttonLoading = true;
|
152
|
+
this.restService.generateOTP(this.mobile ?? "", "91").subscribe((response) => {
|
153
|
+
this.buttonLoading = false;
|
154
|
+
this.messageService.add({
|
155
|
+
severity: 'success',
|
156
|
+
summary: 'OTP Sent',
|
157
|
+
detail: 'OTP sent to mobile. Valid for 3 mins',
|
158
|
+
life: 10000
|
159
|
+
});
|
160
|
+
}, (error) => {
|
161
|
+
this.buttonLoading = false;
|
162
|
+
const errorMessage = error?.error?.message;
|
163
|
+
this.messageService.add({
|
164
|
+
severity: 'error',
|
165
|
+
summary: 'OTP Request',
|
166
|
+
detail: errorMessage,
|
167
|
+
life: 10000
|
168
|
+
});
|
169
|
+
});
|
170
|
+
}
|
171
|
+
validateNumber(event) {
|
172
|
+
const charCode = event.charCode;
|
173
|
+
if (charCode < 48 || charCode > 57) {
|
174
|
+
event.preventDefault();
|
175
|
+
}
|
176
|
+
}
|
82
177
|
get isMobile() {
|
83
178
|
return window.innerWidth <= 475;
|
84
179
|
}
|
85
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: AuthenticationRequiredComponent, deps: [{ token: i1.RestService }, { token: i2.Router }, { token: i3.MessageService }, { token: i4.StorageServiceService }], target: i0.ɵɵFactoryTarget.Component }); }
|
86
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: AuthenticationRequiredComponent, isStandalone: true, selector: "simpo-authentication-required", providers: [MessageService], ngImport: i0, template: "\r\n<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n<section>\r\n <div class=\"main\"> \t\r\n <input type=\"checkbox\" id=\"chk\" aria-hidden=\"true\">\r\n\r\n <div class=\"signup\">\r\n <form>\r\n <label for=\"chk\" aria-hidden=\"true\">Sign up</label>\r\n <input type=\"
|
180
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: AuthenticationRequiredComponent, deps: [{ token: i1.RestService }, { token: i2.Router }, { token: i3.MessageService }, { token: i4.StorageServiceService }, { token: i5.MatDialog }, { token: i5.MatDialogRef, optional: true }, { token: i6.MatBottomSheetRef, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
181
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: AuthenticationRequiredComponent, isStandalone: true, selector: "simpo-authentication-required", providers: [MessageService], ngImport: i0, template: "\r\n<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n<div class=\"close-icon\">\r\n <mat-icon>close</mat-icon>\r\n</div>\r\n<section>\r\n <div class=\"main\"> \t\r\n <input type=\"checkbox\" id=\"chk\" aria-hidden=\"true\">\r\n\r\n <div class=\"signup\">\r\n <form>\r\n <label for=\"chk\" aria-hidden=\"true\">Sign up</label>\r\n <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n <input type=\"mobile\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" (keypress)=\"validateNumber($event)\" [(ngModel)]=\"mobile\">\r\n <input type=\"otp\" name=\"otp\" placeholder=\"OTP\" required=\"\" [(ngModel)]=\"otp\">\r\n <input type=\"password\" name=\"password\" placeholder=\"Create Password\" required=\"\" [(ngModel)]=\"password\">\r\n <button (click)=\"createAccount()\">Sign up</button>\r\n </form>\r\n </div>\r\n\r\n <div class=\"login\">\r\n <form>\r\n <label for=\"chk\" aria-hidden=\"true\">Login</label>\r\n <div class=\"d-flex justify-content-center\" style=\"gap: 5px;\">\r\n <div class=\"login-type\" [ngClass]=\"{'login-type__active': loginType == 'OTP'}\" (click)=\"loginType = 'OTP'\">OTP Login</div>\r\n <div class=\"login-type\" [ngClass]=\"{'login-type__active': loginType == 'PASSWORD'}\" (click)=\"loginType = 'PASSWORD'\">Password Login</div>\r\n </div>\r\n <ng-container *ngIf=\"loginType == 'PASSWORD'\">\r\n <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n <input type=\"password\" name=\"pswd\" placeholder=\"Password\" required=\"\" [(ngModel)]=\"password\">\r\n </ng-container>\r\n <ng-container *ngIf=\"loginType == 'OTP'\">\r\n <input type=\"mobile\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" (keypress)=\"validateNumber($event)\" [(ngModel)]=\"mobile\" (ngModelChange)=\"enterMobile()\">\r\n <input type=\"otp\" name=\"otp\" [placeholder]=\"mobile.length == 10 ? 'Enter received otp' : 'Enter mobile to receive otp'\" required=\"\" [(ngModel)]=\"otp\" [disabled]=\"mobile.length != 10\">\r\n </ng-container>\r\n <button (click)=\"login()\" *ngIf=\"!buttonLoading\">Login</button>\r\n <button *ngIf=\"buttonLoading\">Loading...</button>\r\n </form>\r\n </div>\r\n </div>\r\n</section>", styles: ["section{margin:0;padding:0;display:flex;justify-content:center;align-items:center;height:100%;font-family:Jost,sans-serif;background:linear-gradient(to bottom,#0f0c29,#302b63,#24243e)}.close-icon{position:absolute;top:10px;right:10px;background-color:#fff;border-radius:50%;padding:5px;height:30px;width:30px;display:flex;align-items:center;justify-content:center;cursor:pointer}.close-icon .mat-icon{position:relative;right:2px}.login-type{background-color:#fff;border:#573b8a;color:#573b8a;width:130px!important;font-size:14px!important;padding:5px;border-radius:5px;display:flex;justify-content:center;cursor:pointer}.login-type__active{width:130px!important;font-size:14px!important;font-weight:500!important;padding:5px;border-radius:5px;display:flex;justify-content:center;cursor:pointer;font-weight:800!important;border:1px solid #573b8a}.main{width:350px;height:500px;background:red;overflow:hidden;background:url(https://doc-08-2c-docs.googleusercontent.com/docs/securesc/68c90smiglihng9534mvqmq1946dmis5/fo0picsp1nhiucmc0l25s29respgpr4j/1631524275000/03522360960922298374/03522360960922298374/1Sx0jhdpEpnNIydS4rnN4kHSJtU1EyWka?e=view&authuser=0&nonce=gcrocepgbb17m&user=03522360960922298374&hash=tfhgbs86ka6divo3llbvp93mg4csvb38) no-repeat center/ cover;border-radius:10px;box-shadow:5px 20px 50px #000}#chk{display:none}.signup{position:relative;width:100%;height:100%}label{color:#fff;font-size:2.3em;justify-content:center;display:flex;margin:50px 50px 20px;font-weight:700;cursor:pointer;transition:.5s ease-in-out}input{width:80%;height:10px;background:#e0dede;justify-content:center;display:flex;margin:20px auto;padding:18px;border:none;outline:none;border-radius:5px}button{width:80%!important;height:40px;margin:10px auto;justify-content:center;display:block;color:#fff;background:#573b8a;font-size:1em;font-weight:700;outline:none;border:none;border-radius:5px;transition:.2s ease-in;cursor:pointer}button:hover{background:#6d44b8}.login{height:460px;background:#eee;border-radius:60%/10%;transform:translateY(-180px);transition:.8s ease-in-out}.login label{color:#573b8a;transform:scale(.6)}#chk:checked~.login{transform:translateY(-500px)}#chk:checked~.login label{transform:scale(1)}#chk:checked~.signup label{transform:scale(.6)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i8.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: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i8.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: ToastModule }, { kind: "component", type: i9.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "life", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
|
87
182
|
}
|
88
183
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: AuthenticationRequiredComponent, decorators: [{
|
89
184
|
type: Component,
|
90
185
|
args: [{ selector: 'simpo-authentication-required', standalone: true, imports: [
|
91
186
|
CommonModule,
|
92
187
|
FormsModule,
|
93
|
-
ToastModule
|
94
|
-
|
95
|
-
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication-required.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { Router } from '@angular/router';\r\nimport { MessageService } from 'primeng/api';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { DeviceInfo } from '../../styles/user.modal';\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\nimport Swal from 'sweetalert2';\r\n\r\n@Component({\r\n  selector: 'simpo-authentication-required',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ToastModule\r\n  ],\r\n  providers: [MessageService],\r\n  templateUrl: './authentication-required.component.html',\r\n  styleUrl: './authentication-required.component.css'\r\n})\r\nexport class AuthenticationRequiredComponent {\r\n  public email: string = \"\";\r\n  public mobile: string = \"\";\r\n  public otp: string = \"\";\r\n  public password: string = \"\";\r\n  public confPassword: string = \"\";\r\n  public userName: string = \"\";\r\n  public buttonLoading: boolean = false;\r\n  public businessId: string | null = localStorage.getItem(\"bId\");\r\n\r\n  constructor(\r\n    private readonly restService: RestService,\r\n    private readonly router: Router,\r\n    private readonly messageService: MessageService,\r\n    private readonly storageService: StorageServiceService\r\n  ) {}\r\n\r\n  login(){\r\n    \r\n    const payload = {\r\n      businessId: this.businessId,\r\n      email: this.email,\r\n      password: this.password\r\n    }\r\n\r\n    this.buttonLoading = true;\r\n    this.restService.signinPassword(payload).subscribe((res:any)=>{\r\n      this.router.navigate(['/']);\r\n      this.buttonLoading = false;\r\n    },\r\n      (error) => {\r\n        this.buttonLoading = false;\r\n        this.messageService.add({ severity: 'error', summary: 'Invalid credentials', detail: 'Please enter valid credentials' });\r\n      })\r\n  }\r\n  createAccount() {\r\n\r\n    const deviceInfo: DeviceInfo | null = {\r\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\r\n    };\r\n\r\n    this.buttonLoading = true;\r\n    // this.otpData.forEach((value: string | undefined, idx: number) => this.SignupOtpString += (value ?? \"\"));\r\n    let verifySignData = {\r\n      businessId: this.businessId,\r\n      mobile: this.mobile,\r\n      email: this.email,\r\n      password: this.password,\r\n      countryCode: \"+91\"\r\n    }\r\n    this.restService.verifySignupOTP(verifySignData).subscribe((response: any) => {\r\n      const userDetails = this.storageService.setUser(response.data);\r\n      this.storageService.updateAllData();\r\n      this.router.navigate(['/']);\r\n      this.buttonLoading = false;\r\n      Swal.fire({\r\n        icon: \"success\",\r\n        title: \"Hurray\",\r\n        text: \"Your account successfully created\",\r\n        showCancelButton: !(userDetails.contact?.name?.length > 0),\r\n        confirmButtonText: \"I loved it\",\r\n        cancelButtonText: \"Fill other basic details\",\r\n        cancelButtonColor: \"#928c8c\",\r\n      })\r\n    }, (error) => {\r\n      this.buttonLoading = false;\r\n      if (error.status === 500) {\r\n        this.messageService.add({ severity: 'error', summary: 'User already exists' })\r\n      }\r\n      else {\r\n        this.messageService.add({ severity: 'error', summary: 'Invalid OTP', detail: 'Please enter valid otp' });\r\n      }\r\n    })\r\n  }\r\n\r\n  get isMobile(): boolean {\r\n    return window.innerWidth <= 475;\r\n  }\r\n}\r\n","\r\n<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n    [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n<section>\r\n    <div class=\"main\">  \t\r\n        <input type=\"checkbox\" id=\"chk\" aria-hidden=\"true\">\r\n\r\n            <div class=\"signup\">\r\n                <form>\r\n                    <label for=\"chk\" aria-hidden=\"true\">Sign up</label>\r\n                    <input type=\"text\" name=\"txt\" placeholder=\"User name\" required=\"\" [(ngModel)]=\"userName\">\r\n                    <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n                    <input type=\"email\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" [(ngModel)]=\"mobile\">\r\n                    <input type=\"email\" name=\"otp\" placeholder=\"OTP\" required=\"\" [(ngModel)]=\"otp\">\r\n                    <input type=\"password\" name=\"password\" placeholder=\"Password\" required=\"\" [(ngModel)]=\"password\">\r\n                    <!-- <input type=\"password\" name=\"confPassword\" placeholder=\"Confirm Password\" required=\"\" [(ngModel)]=\"confPassword\"> -->\r\n                    <button (click)=\"createAccount()\">Sign up</button>\r\n                </form>\r\n            </div>\r\n\r\n            <div class=\"login\">\r\n                <form>\r\n                    <label for=\"chk\" aria-hidden=\"true\">Login</label>\r\n                    <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n                    <input type=\"password\" name=\"pswd\" placeholder=\"Password\" required=\"\" [(ngModel)]=\"password\">\r\n                    <button (click)=\"login()\" *ngIf=\"!buttonLoading\">Login</button>\r\n                    <button *ngIf=\"buttonLoading\">Loading...</button>\r\n                </form>\r\n            </div>\r\n    </div>\r\n</section>"]}
|
188
|
+
ToastModule,
|
189
|
+
MatIconModule
|
190
|
+
], providers: [MessageService], template: "\r\n<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n<div class=\"close-icon\">\r\n <mat-icon>close</mat-icon>\r\n</div>\r\n<section>\r\n <div class=\"main\"> \t\r\n <input type=\"checkbox\" id=\"chk\" aria-hidden=\"true\">\r\n\r\n <div class=\"signup\">\r\n <form>\r\n <label for=\"chk\" aria-hidden=\"true\">Sign up</label>\r\n <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n <input type=\"mobile\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" (keypress)=\"validateNumber($event)\" [(ngModel)]=\"mobile\">\r\n <input type=\"otp\" name=\"otp\" placeholder=\"OTP\" required=\"\" [(ngModel)]=\"otp\">\r\n <input type=\"password\" name=\"password\" placeholder=\"Create Password\" required=\"\" [(ngModel)]=\"password\">\r\n <button (click)=\"createAccount()\">Sign up</button>\r\n </form>\r\n </div>\r\n\r\n <div class=\"login\">\r\n <form>\r\n <label for=\"chk\" aria-hidden=\"true\">Login</label>\r\n <div class=\"d-flex justify-content-center\" style=\"gap: 5px;\">\r\n <div class=\"login-type\" [ngClass]=\"{'login-type__active': loginType == 'OTP'}\" (click)=\"loginType = 'OTP'\">OTP Login</div>\r\n <div class=\"login-type\" [ngClass]=\"{'login-type__active': loginType == 'PASSWORD'}\" (click)=\"loginType = 'PASSWORD'\">Password Login</div>\r\n </div>\r\n <ng-container *ngIf=\"loginType == 'PASSWORD'\">\r\n <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n <input type=\"password\" name=\"pswd\" placeholder=\"Password\" required=\"\" [(ngModel)]=\"password\">\r\n </ng-container>\r\n <ng-container *ngIf=\"loginType == 'OTP'\">\r\n <input type=\"mobile\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" (keypress)=\"validateNumber($event)\" [(ngModel)]=\"mobile\" (ngModelChange)=\"enterMobile()\">\r\n <input type=\"otp\" name=\"otp\" [placeholder]=\"mobile.length == 10 ? 'Enter received otp' : 'Enter mobile to receive otp'\" required=\"\" [(ngModel)]=\"otp\" [disabled]=\"mobile.length != 10\">\r\n </ng-container>\r\n <button (click)=\"login()\" *ngIf=\"!buttonLoading\">Login</button>\r\n <button *ngIf=\"buttonLoading\">Loading...</button>\r\n </form>\r\n </div>\r\n </div>\r\n</section>", styles: ["section{margin:0;padding:0;display:flex;justify-content:center;align-items:center;height:100%;font-family:Jost,sans-serif;background:linear-gradient(to bottom,#0f0c29,#302b63,#24243e)}.close-icon{position:absolute;top:10px;right:10px;background-color:#fff;border-radius:50%;padding:5px;height:30px;width:30px;display:flex;align-items:center;justify-content:center;cursor:pointer}.close-icon .mat-icon{position:relative;right:2px}.login-type{background-color:#fff;border:#573b8a;color:#573b8a;width:130px!important;font-size:14px!important;padding:5px;border-radius:5px;display:flex;justify-content:center;cursor:pointer}.login-type__active{width:130px!important;font-size:14px!important;font-weight:500!important;padding:5px;border-radius:5px;display:flex;justify-content:center;cursor:pointer;font-weight:800!important;border:1px solid #573b8a}.main{width:350px;height:500px;background:red;overflow:hidden;background:url(https://doc-08-2c-docs.googleusercontent.com/docs/securesc/68c90smiglihng9534mvqmq1946dmis5/fo0picsp1nhiucmc0l25s29respgpr4j/1631524275000/03522360960922298374/03522360960922298374/1Sx0jhdpEpnNIydS4rnN4kHSJtU1EyWka?e=view&authuser=0&nonce=gcrocepgbb17m&user=03522360960922298374&hash=tfhgbs86ka6divo3llbvp93mg4csvb38) no-repeat center/ cover;border-radius:10px;box-shadow:5px 20px 50px #000}#chk{display:none}.signup{position:relative;width:100%;height:100%}label{color:#fff;font-size:2.3em;justify-content:center;display:flex;margin:50px 50px 20px;font-weight:700;cursor:pointer;transition:.5s ease-in-out}input{width:80%;height:10px;background:#e0dede;justify-content:center;display:flex;margin:20px auto;padding:18px;border:none;outline:none;border-radius:5px}button{width:80%!important;height:40px;margin:10px auto;justify-content:center;display:block;color:#fff;background:#573b8a;font-size:1em;font-weight:700;outline:none;border:none;border-radius:5px;transition:.2s ease-in;cursor:pointer}button:hover{background:#6d44b8}.login{height:460px;background:#eee;border-radius:60%/10%;transform:translateY(-180px);transition:.8s ease-in-out}.login label{color:#573b8a;transform:scale(.6)}#chk:checked~.login{transform:translateY(-500px)}#chk:checked~.login label{transform:scale(1)}#chk:checked~.signup label{transform:scale(.6)}\n"] }]
|
191
|
+
}], ctorParameters: () => [{ type: i1.RestService }, { type: i2.Router }, { type: i3.MessageService }, { type: i4.StorageServiceService }, { type: i5.MatDialog }, { type: i5.MatDialogRef, decorators: [{
|
192
|
+
type: Optional
|
193
|
+
}] }, { type: i6.MatBottomSheetRef, decorators: [{
|
194
|
+
type: Optional
|
195
|
+
}] }] });
|
196
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication-required.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/authentication-required/authentication-required.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Optional } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { Router } from '@angular/router';\r\nimport { MessageService } from 'primeng/api';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { DeviceInfo } from '../../styles/user.modal';\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\nimport Swal from 'sweetalert2';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatBottomSheetRef } from '@angular/material/bottom-sheet';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { UserBasicInfoComponent } from '../user-basic-info/user-basic-info.component';\r\n\r\n@Component({\r\n  selector: 'simpo-authentication-required',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ToastModule,\r\n    MatIconModule\r\n  ],\r\n  providers: [MessageService],\r\n  templateUrl: './authentication-required.component.html',\r\n  styleUrl: './authentication-required.component.css'\r\n})\r\nexport class AuthenticationRequiredComponent {\r\n  public email: string = \"\";\r\n  public mobile: string = \"\";\r\n  public otp: string = \"\";\r\n  public password: string = \"\";\r\n  public confPassword: string = \"\";\r\n  public userName: string = \"\";\r\n  public buttonLoading: boolean = false;\r\n  public businessId: string | null = localStorage.getItem(\"bId\");\r\n\r\n  constructor(\r\n    private readonly restService: RestService,\r\n    private readonly router: Router,\r\n    private readonly messageService: MessageService,\r\n    private readonly storageService: StorageServiceService,\r\n    private readonly matDialog: MatDialog,\r\n    @Optional() private readonly dialogRef: MatDialogRef<AuthenticationRequiredComponent>,\r\n    @Optional() private readonly bottomsheetRef: MatBottomSheetRef<AuthenticationRequiredComponent>,\r\n  ) {}\r\n\r\n  loginType: \"PASSWORD\" | \"OTP\" = \"OTP\";\r\n\r\n  login(){\r\n    if (this.loginType == \"OTP\") {\r\n      this.verifyOTP();\r\n    } else {\r\n      this.verifyPassword();\r\n    }\r\n  }\r\n  verifyPassword() {\r\n    const payload = {\r\n      businessId: this.businessId,\r\n      email: this.email,\r\n      password: this.password\r\n    }\r\n\r\n    this.buttonLoading = true;\r\n    this.restService.signinPassword(payload).subscribe((res:any)=>{\r\n      this.router.navigate(['/']);\r\n      this.buttonLoading = false;\r\n    },\r\n    (error) => {\r\n      this.buttonLoading = false;\r\n      this.messageService.add({ severity: 'error', summary: 'Invalid credentials', detail: 'Please enter valid credentials' });\r\n    })\r\n  }\r\n  verifyOTP() {\r\n\r\n    const deviceInfo: DeviceInfo | null = {\r\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\r\n    };\r\n\r\n    this.buttonLoading = true;\r\n    this.restService.verifyOTP(this.mobile ?? \"\", this.otp, deviceInfo).subscribe((response: any) => {\r\n      const userDetails = this.storageService.setUser(response.data);\r\n      this.storageService.updateAllData();\r\n      if (this.dialogRef)\r\n        this.dialogRef.close(\"SUCCESS\");\r\n      if (this.bottomsheetRef)\r\n        this.bottomsheetRef.dismiss(\"SUCCESS\");\r\n\r\n      this.buttonLoading = false;\r\n      Swal.fire({\r\n        icon: \"success\",\r\n        title: \"Hurray\",\r\n        text: \"Your account successfully created\",\r\n        showCancelButton: !(userDetails.contact?.name?.length > 0),\r\n        confirmButtonText: \"I loved it\",\r\n        cancelButtonText: \"Fill other basic details\",\r\n        cancelButtonColor: \"#928c8c\",\r\n      }).then((result) => {\r\n\r\n        if (result.isConfirmed) {\r\n          if (this.dialogRef)\r\n            this.dialogRef.close(\"SUCCESS\");\r\n          if (this.bottomsheetRef)\r\n            this.bottomsheetRef.dismiss(\"SUCCESS\");\r\n\r\n        } else if (result.isDismissed) {\r\n          if (this.dialogRef)\r\n            this.dialogRef.close(\"SUCCESS\");\r\n          if (this.bottomsheetRef)\r\n            this.bottomsheetRef.dismiss(\"SUCCESS\");\r\n          this.matDialog.open(UserBasicInfoComponent, {\r\n            height: '50vh',\r\n            width: window.innerWidth > 475 ? '40vw' : '95vw',\r\n            maxWidth: window.innerWidth > 475 ? '100vw' : '80vw',\r\n            data: {}\r\n          });\r\n        }\r\n      })\r\n    }, (error) => {\r\n      this.buttonLoading = false;\r\n      this.messageService.add({ severity: 'error', summary: 'Invalid OTP', detail: 'Please enter valid otp' });\r\n    })\r\n  }\r\n  createAccount() {\r\n\r\n    const deviceInfo: DeviceInfo | null = {\r\n      firebaseToken: localStorage.getItem(\"fbToken\") ?? \"\"\r\n    };\r\n\r\n    this.buttonLoading = true;\r\n    // this.otpData.forEach((value: string | undefined, idx: number) => this.SignupOtpString += (value ?? \"\"));\r\n    let verifySignData = {\r\n      businessId: this.businessId,\r\n      mobile: this.mobile,\r\n      email: this.email,\r\n      password: this.password,\r\n      countryCode: \"+91\"\r\n    }\r\n    this.restService.verifySignupOTP(verifySignData).subscribe((response: any) => {\r\n      const userDetails = this.storageService.setUser(response.data);\r\n      this.storageService.updateAllData();\r\n      this.router.navigate(['/']);\r\n      this.buttonLoading = false;\r\n      Swal.fire({\r\n        icon: \"success\",\r\n        title: \"Hurray\",\r\n        text: \"Your account successfully created\",\r\n        showCancelButton: !(userDetails.contact?.name?.length > 0),\r\n        confirmButtonText: \"I loved it\",\r\n        cancelButtonText: \"Fill other basic details\",\r\n        cancelButtonColor: \"#928c8c\",\r\n      })\r\n    }, (error) => {\r\n      this.buttonLoading = false;\r\n      if (error.status === 500) {\r\n        this.messageService.add({ severity: 'error', summary: 'User already exists' })\r\n      }\r\n      else {\r\n        this.messageService.add({ severity: 'error', summary: 'Invalid OTP', detail: 'Please enter valid otp' });\r\n      }\r\n    })\r\n  }\r\n  enterMobile() {\r\n    if (this.mobile.length == 10) {\r\n      this.generateOTP();\r\n    }\r\n  }\r\n\r\n  generateOTP() {\r\n    this.buttonLoading = true;\r\n    this.restService.generateOTP(this.mobile ?? \"\", \"91\").subscribe(\r\n      (response) => {\r\n        this.buttonLoading = false;\r\n        this.messageService.add({\r\n          severity: 'success',\r\n          summary: 'OTP Sent',\r\n          detail: 'OTP sent to mobile. Valid for 3 mins',\r\n          life: 10000\r\n        });\r\n      },\r\n      (error) => {\r\n        this.buttonLoading = false;\r\n        const errorMessage = error?.error?.message;\r\n  \r\n        this.messageService.add({\r\n          severity: 'error',\r\n          summary: 'OTP Request',\r\n          detail: errorMessage,\r\n          life: 10000\r\n        });\r\n      }\r\n    );\r\n  }\r\n\r\n  validateNumber(event: KeyboardEvent): void {\r\n    const charCode = event.charCode; \r\n    if (charCode < 48 || charCode > 57) {\r\n      event.preventDefault();  \r\n    }\r\n  }\r\n\r\n  get isMobile(): boolean {\r\n    return window.innerWidth <= 475;\r\n  }\r\n}\r\n","\r\n<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n    [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n<div class=\"close-icon\">\r\n    <mat-icon>close</mat-icon>\r\n</div>\r\n<section>\r\n    <div class=\"main\">  \t\r\n        <input type=\"checkbox\" id=\"chk\" aria-hidden=\"true\">\r\n\r\n            <div class=\"signup\">\r\n                <form>\r\n                    <label for=\"chk\" aria-hidden=\"true\">Sign up</label>\r\n                    <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n                    <input type=\"mobile\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" (keypress)=\"validateNumber($event)\" [(ngModel)]=\"mobile\">\r\n                    <input type=\"otp\" name=\"otp\" placeholder=\"OTP\" required=\"\" [(ngModel)]=\"otp\">\r\n                    <input type=\"password\" name=\"password\" placeholder=\"Create Password\" required=\"\" [(ngModel)]=\"password\">\r\n                    <button (click)=\"createAccount()\">Sign up</button>\r\n                </form>\r\n            </div>\r\n\r\n            <div class=\"login\">\r\n                <form>\r\n                    <label for=\"chk\" aria-hidden=\"true\">Login</label>\r\n                    <div class=\"d-flex justify-content-center\" style=\"gap: 5px;\">\r\n                        <div class=\"login-type\" [ngClass]=\"{'login-type__active': loginType == 'OTP'}\" (click)=\"loginType = 'OTP'\">OTP Login</div>\r\n                        <div class=\"login-type\" [ngClass]=\"{'login-type__active': loginType == 'PASSWORD'}\" (click)=\"loginType = 'PASSWORD'\">Password Login</div>\r\n                    </div>\r\n                    <ng-container *ngIf=\"loginType == 'PASSWORD'\">\r\n                        <input type=\"email\" name=\"email\" placeholder=\"Email\" required=\"\" [(ngModel)]=\"email\">\r\n                        <input type=\"password\" name=\"pswd\" placeholder=\"Password\" required=\"\" [(ngModel)]=\"password\">\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"loginType == 'OTP'\">\r\n                        <input type=\"mobile\" name=\"mobile\" placeholder=\"Mobile\" required=\"\" (keypress)=\"validateNumber($event)\" [(ngModel)]=\"mobile\" (ngModelChange)=\"enterMobile()\">\r\n                        <input type=\"otp\" name=\"otp\" [placeholder]=\"mobile.length == 10 ? 'Enter received otp' : 'Enter mobile to receive otp'\" required=\"\" [(ngModel)]=\"otp\" [disabled]=\"mobile.length != 10\">\r\n                    </ng-container>\r\n                    <button (click)=\"login()\" *ngIf=\"!buttonLoading\">Login</button>\r\n                    <button *ngIf=\"buttonLoading\">Loading...</button>\r\n                </form>\r\n            </div>\r\n    </div>\r\n</section>"]}
|