verben-authentication-ui 0.3.6 → 0.3.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/auth-callback/auth-callback.component.mjs +48 -0
- package/esm2022/lib/components/auth-callback/auth-callback.module.mjs +18 -0
- package/esm2022/lib/components/button/button.component.mjs +6 -3
- package/esm2022/lib/components/forgot-password/forgot-password.component.mjs +1 -1
- package/esm2022/lib/components/mail/mail.component.mjs +1 -1
- package/esm2022/lib/components/o-auth/o-auth.component.mjs +65 -79
- package/esm2022/lib/components/reset-password/reset-password.component.mjs +1 -1
- package/esm2022/lib/components/sign-in/sign-in.component.mjs +108 -30
- package/esm2022/lib/components/sign-up/sign-up.component.mjs +1 -1
- package/esm2022/lib/components/sso/sso-form/sso-form.component.mjs +1 -1
- package/esm2022/lib/components/two-factor-auth-otp/two-factor-auth-otp.component.mjs +1 -1
- package/esm2022/lib/components/user-management/user-management-form/use-management-form.component.mjs +1 -1
- package/esm2022/lib/components/user-management/user-management.component.mjs +2 -2
- package/esm2022/lib/components/user-request/user-request.component.mjs +125 -49
- package/esm2022/lib/components/user-request/user-request.module.mjs +7 -3
- package/esm2022/lib/components/user-request-approval/user-request-approval.component.mjs +2 -2
- package/esm2022/lib/components/user-request-approval/user-request-form/use-request-form.component.mjs +1 -1
- package/esm2022/lib/models/UserRequest.mjs +1 -1
- package/esm2022/lib/models/log-in.mjs +1 -1
- package/esm2022/lib/models/oauth-response.mjs +2 -0
- package/esm2022/lib/services/http-web-request.service.mjs +5 -6
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/verben-authentication-ui.mjs +432 -234
- package/fesm2022/verben-authentication-ui.mjs.map +1 -1
- package/lib/components/auth-callback/auth-callback.component.d.ts +17 -0
- package/lib/components/auth-callback/auth-callback.module.d.ts +8 -0
- package/lib/components/button/button.component.d.ts +2 -1
- package/lib/components/o-auth/o-auth.component.d.ts +14 -5
- package/lib/components/sign-in/sign-in.component.d.ts +19 -4
- package/lib/components/user-request/user-request.component.d.ts +19 -2
- package/lib/components/user-request/user-request.module.d.ts +2 -1
- package/lib/models/UserRequest.d.ts +2 -0
- package/lib/models/log-in.d.ts +1 -0
- package/lib/models/oauth-response.d.ts +6 -0
- package/package.json +2 -2
- package/public-api.d.ts +2 -0
|
@@ -1,21 +1,25 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { Validators, } from '@angular/forms';
|
|
2
|
+
import { FormControl, Validators, } from '@angular/forms';
|
|
3
3
|
import { ObjectState } from '../../models/object-state';
|
|
4
4
|
import { ErrorResponse } from '../../models/ErrorResponse';
|
|
5
5
|
import { Status } from '../../models/status';
|
|
6
6
|
import { RequestStatus } from '../../models/request-status';
|
|
7
|
+
import { MechanismType } from '../../models/auth-mechanism';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@angular/forms";
|
|
9
10
|
import * as i2 from "../../services/http-web-request.service";
|
|
10
11
|
import * as i3 from "../../services/util.service";
|
|
11
12
|
import * as i4 from "../../services/environment.service";
|
|
12
|
-
import * as i5 from "
|
|
13
|
-
import * as i6 from "
|
|
13
|
+
import * as i5 from "@angular/router";
|
|
14
|
+
import * as i6 from "verben-ng-ui";
|
|
15
|
+
import * as i7 from "@angular/common";
|
|
16
|
+
import * as i8 from "../o-auth/o-auth.component";
|
|
14
17
|
export class UserRequestComponent {
|
|
15
18
|
fb;
|
|
16
19
|
server;
|
|
17
20
|
utilService;
|
|
18
21
|
envSvc;
|
|
22
|
+
route;
|
|
19
23
|
width = '500px';
|
|
20
24
|
headingTitle = 'Request an account';
|
|
21
25
|
headingClass = 'font-medium text-[2rem] leading-[48px] text-[#333]';
|
|
@@ -27,8 +31,9 @@ export class UserRequestComponent {
|
|
|
27
31
|
textColor = '#333';
|
|
28
32
|
height = 'auto';
|
|
29
33
|
pd = '32px 48px';
|
|
34
|
+
isFormEditable = true;
|
|
30
35
|
apiKey = '';
|
|
31
|
-
|
|
36
|
+
isCode = false;
|
|
32
37
|
text = 'Send Request';
|
|
33
38
|
color = 'black';
|
|
34
39
|
btnBorder = '1px solid #FFE681';
|
|
@@ -43,20 +48,58 @@ export class UserRequestComponent {
|
|
|
43
48
|
googleClick = new EventEmitter();
|
|
44
49
|
onSubmitSuccess = new EventEmitter();
|
|
45
50
|
appleClick = new EventEmitter();
|
|
51
|
+
microsoftClick = new EventEmitter();
|
|
52
|
+
onSubmitGoogleAuth = new EventEmitter();
|
|
46
53
|
onSubmitResponseEnd = new EventEmitter();
|
|
47
54
|
userRequestForm;
|
|
48
|
-
|
|
55
|
+
tenantDetails = null;
|
|
56
|
+
AuthMechanisms = null;
|
|
57
|
+
showform = false;
|
|
58
|
+
code = '';
|
|
59
|
+
constructor(fb, server, utilService, envSvc, route) {
|
|
49
60
|
this.fb = fb;
|
|
50
61
|
this.server = server;
|
|
51
62
|
this.utilService = utilService;
|
|
52
63
|
this.envSvc = envSvc;
|
|
64
|
+
this.route = route;
|
|
53
65
|
this.apiKey = this.envSvc.environment.APIKey;
|
|
54
66
|
this.userRequestForm = this.fb.group({
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
67
|
+
Code: new FormControl('', { nonNullable: true }),
|
|
68
|
+
FirstName: new FormControl('', {
|
|
69
|
+
nonNullable: true,
|
|
70
|
+
validators: [Validators.required],
|
|
71
|
+
}),
|
|
72
|
+
LastName: new FormControl('', {
|
|
73
|
+
nonNullable: true,
|
|
74
|
+
validators: [Validators.required],
|
|
75
|
+
}),
|
|
76
|
+
MailAddress: new FormControl('', {
|
|
77
|
+
nonNullable: true,
|
|
78
|
+
validators: [Validators.required, Validators.email],
|
|
79
|
+
}),
|
|
80
|
+
Password: new FormControl('', {
|
|
81
|
+
nonNullable: true,
|
|
82
|
+
validators: [Validators.required, Validators.minLength(8)],
|
|
83
|
+
}),
|
|
84
|
+
PhoneNumber: new FormControl('', { nonNullable: true }),
|
|
85
|
+
OtherName: new FormControl('', { nonNullable: true }),
|
|
86
|
+
Role: new FormControl([], { nonNullable: true }),
|
|
87
|
+
Tags: new FormControl([], { nonNullable: true }),
|
|
88
|
+
Status: new FormControl(Status.Active, { nonNullable: true }),
|
|
89
|
+
RequestStatus: new FormControl(RequestStatus.Pending, {
|
|
90
|
+
nonNullable: true,
|
|
91
|
+
}),
|
|
92
|
+
UpdatedAt: new FormControl(new Date(), { nonNullable: true }),
|
|
93
|
+
CreatedAt: new FormControl(new Date(), { nonNullable: true }),
|
|
94
|
+
Id: new FormControl('', { nonNullable: true }),
|
|
95
|
+
DataState: new FormControl(ObjectState.New, {
|
|
96
|
+
nonNullable: true,
|
|
97
|
+
}),
|
|
98
|
+
TenantId: new FormControl('', { nonNullable: true }),
|
|
99
|
+
SignUpType: new FormControl(MechanismType.InApp, { nonNullable: true }),
|
|
100
|
+
ServiceName: new FormControl('', { nonNullable: true }),
|
|
101
|
+
ActionBy: new FormControl('', { nonNullable: true }),
|
|
102
|
+
Comment: new FormControl('', { nonNullable: true }),
|
|
60
103
|
}, { validators: this.passwordMatchValidator });
|
|
61
104
|
}
|
|
62
105
|
passwordMatchValidator(control) {
|
|
@@ -79,78 +122,107 @@ export class UserRequestComponent {
|
|
|
79
122
|
padding: this.pd,
|
|
80
123
|
};
|
|
81
124
|
}
|
|
125
|
+
async ngOnInit() {
|
|
126
|
+
await this.getTenantConfig();
|
|
127
|
+
this.route.queryParams.subscribe(params => {
|
|
128
|
+
this.code = params['code'];
|
|
129
|
+
console.log(this.code, 'code');
|
|
130
|
+
if (this.code) {
|
|
131
|
+
this.verifyUserDetails();
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
async getTenantConfig() {
|
|
136
|
+
this.userRequestForm.addControl('ConfirmPassword', new FormControl('', Validators.required));
|
|
137
|
+
const res = await this.server.get(`Tenant/GetTenantConfigByKey/${this.apiKey}`);
|
|
138
|
+
this.tenantDetails = res;
|
|
139
|
+
this.AuthMechanisms = this.tenantDetails?.AuthMechanisms;
|
|
140
|
+
if (!this.tenantDetails?.AuthMechanism &&
|
|
141
|
+
this.tenantDetails?.AuthMechanism !== MechanismType.InApp) {
|
|
142
|
+
this.showform = false;
|
|
143
|
+
}
|
|
144
|
+
else if (this.tenantDetails?.AuthMechanism === MechanismType.InApp) {
|
|
145
|
+
this.showform = true;
|
|
146
|
+
}
|
|
147
|
+
else if (this.AuthMechanisms !== null) {
|
|
148
|
+
this.showform = this.AuthMechanisms.some((item) => item.AuthMechanism.includes(MechanismType.InApp));
|
|
149
|
+
}
|
|
150
|
+
}
|
|
82
151
|
checkForm() {
|
|
83
152
|
return this.userRequestForm.valid;
|
|
84
153
|
}
|
|
85
154
|
handleGoogleAuth() {
|
|
86
|
-
this.
|
|
155
|
+
if (this.AuthMechanisms !== null) {
|
|
156
|
+
const data = this.AuthMechanisms.filter((item) => item.AuthMechanism === MechanismType.Google);
|
|
157
|
+
this.googleClick.emit();
|
|
158
|
+
}
|
|
87
159
|
}
|
|
88
160
|
handleAppleAuth() {
|
|
89
161
|
this.appleClick.emit();
|
|
90
162
|
}
|
|
163
|
+
handleMicrosoft() {
|
|
164
|
+
if (this.AuthMechanisms !== null) {
|
|
165
|
+
const data = this.AuthMechanisms.filter((item) => item.AuthMechanism === MechanismType.MicrosoftAD);
|
|
166
|
+
this.microsoftClick.emit();
|
|
167
|
+
}
|
|
168
|
+
}
|
|
91
169
|
async submitForm() {
|
|
92
170
|
if (!this.checkForm()) {
|
|
93
171
|
return;
|
|
94
172
|
}
|
|
95
|
-
const
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
LastName: this.userRequestForm.controls['LastName'].value,
|
|
100
|
-
MailAddress: this.userRequestForm.controls['Email'].value,
|
|
101
|
-
Password: this.userRequestForm.controls['Password'].value,
|
|
102
|
-
PhoneNumber: '',
|
|
103
|
-
OtherName: '',
|
|
104
|
-
Role: [],
|
|
105
|
-
Tags: [],
|
|
106
|
-
Status: Status.Active,
|
|
107
|
-
RequestStatus: RequestStatus.Pending,
|
|
108
|
-
UpdatedAt: new Date(),
|
|
109
|
-
CreatedAt: new Date(),
|
|
110
|
-
Id: '',
|
|
111
|
-
DataState: ObjectState.New,
|
|
112
|
-
TenantId: '',
|
|
113
|
-
ServiceName: '',
|
|
114
|
-
ActionBy: '',
|
|
115
|
-
Comment: '',
|
|
116
|
-
},
|
|
117
|
-
];
|
|
118
|
-
// Emit payload if needed
|
|
119
|
-
this.formSubmit.emit(payload);
|
|
120
|
-
// Show loading indicator
|
|
173
|
+
const formValue = this.userRequestForm.getRawValue();
|
|
174
|
+
const { ConfirmPassword, ...payload } = formValue;
|
|
175
|
+
const payloadToSubmit = [payload];
|
|
176
|
+
this.formSubmit.emit(payloadToSubmit);
|
|
121
177
|
this.utilService.sendBI(true);
|
|
122
178
|
try {
|
|
123
|
-
|
|
124
|
-
const res = await this.server.post(`User/SaveUserAccessRequests`, payload);
|
|
125
|
-
// Hide loading indicator
|
|
179
|
+
const res = await this.server.post(`User/SaveUserAccessRequests`, payloadToSubmit);
|
|
126
180
|
this.utilService.sendBI(false);
|
|
127
181
|
if (res instanceof ErrorResponse) {
|
|
128
|
-
// Emit error response
|
|
129
182
|
this.onSubmitResponseEnd.emit(res);
|
|
130
183
|
console.log(res);
|
|
131
184
|
}
|
|
132
185
|
else {
|
|
133
|
-
// Emit success response
|
|
134
186
|
const result = res;
|
|
135
187
|
this.onSubmitResponseEnd.emit(result);
|
|
136
|
-
// Emit success event
|
|
137
188
|
this.onSubmitSuccess.emit(result);
|
|
138
189
|
}
|
|
139
190
|
}
|
|
140
191
|
catch (error) {
|
|
141
|
-
// Handle unexpected errors
|
|
142
192
|
this.utilService.sendBI(false);
|
|
143
193
|
console.error('Unexpected error:', error);
|
|
144
194
|
this.onSubmitResponseEnd.emit(error);
|
|
145
195
|
}
|
|
146
196
|
}
|
|
147
|
-
|
|
148
|
-
|
|
197
|
+
async verifyUserDetails() {
|
|
198
|
+
if (this.AuthMechanisms !== null && this.apiKey) {
|
|
199
|
+
const data = this.AuthMechanisms.find((item) => item.AuthMechanism.includes(MechanismType.Google));
|
|
200
|
+
const payload = {
|
|
201
|
+
AuthCode: this.code,
|
|
202
|
+
APIKey: this.apiKey,
|
|
203
|
+
AuthMechanism: data.AuthMechanism,
|
|
204
|
+
};
|
|
205
|
+
this.utilService.sendBI(true);
|
|
206
|
+
const res = await this.server.post(`Authentication/GetUserDetails`, payload);
|
|
207
|
+
this.utilService.sendBI(false);
|
|
208
|
+
if (res instanceof ErrorResponse) {
|
|
209
|
+
this.onSubmitGoogleAuth.emit(res);
|
|
210
|
+
}
|
|
211
|
+
else {
|
|
212
|
+
this.userRequestForm.controls['FirstName'].setValue(res.FirstName);
|
|
213
|
+
this.userRequestForm.controls['LastName'].setValue(res.LastName);
|
|
214
|
+
this.userRequestForm.controls['MailAddress'].setValue(res.Email);
|
|
215
|
+
this.userRequestForm.controls['SignUpType'].setValue(MechanismType.Google);
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestComponent, deps: [{ token: i1.FormBuilder }, { token: i2.HttpWebRequestService }, { token: i3.UtilService }, { token: i4.EnvironmentService }, { token: i5.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
|
|
220
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: UserRequestComponent, selector: "lib-user-request", inputs: { width: "width", headingTitle: "headingTitle", headingClass: "headingClass", customClass: "customClass", bgColor: "bgColor", boxShadow: "boxShadow", border: "border", borderRadius: "borderRadius", textColor: "textColor", height: "height", pd: "pd", text: "text", color: "color", btnBorder: "btnBorder", btnBorderRadius: "btnBorderRadius", btnBgColor: "btnBgColor", btnWidth: "btnWidth", btnPd: "btnPd", termsLink: "termsLink", privacyLink: "privacyLink", routerLink: "routerLink" }, outputs: { formSubmit: "formSubmit", googleClick: "googleClick", onSubmitSuccess: "onSubmitSuccess", appleClick: "appleClick", microsoftClick: "microsoftClick", onSubmitGoogleAuth: "onSubmitGoogleAuth", onSubmitResponseEnd: "onSubmitResponseEnd" }, ngImport: i0, template: "<section [ngStyle]=\"styles\" class=\"{{ customClass }}\">\n <h2 class=\"{{ headingClass }}\">\n {{ headingTitle }}\n </h2>\n\n <form\n [formGroup]=\"userRequestForm\"\n (ngSubmit)=\"submitForm()\"\n class=\"flex flex-col gap-5 mt-3\"\n >\n <verbena-input\n [label]=\"'First Name'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'text'\"\n formControlName=\"FirstName\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n <verbena-input\n [label]=\"'Last Name'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'text'\"\n formControlName=\"LastName\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n <verbena-input\n [label]=\"'E-mail Address'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'email'\"\n formControlName=\"MailAddress\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [customErrorMessages]=\"{\n required: 'Email address is required',\n email: 'Email address must be valid'\n }\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n\n <verbena-input\n [label]=\"'Password'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [passwordToggle]=\"true\"\n formControlName=\"Password\"\n [required]=\"true\"\n [type]=\"'password'\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n\n <verbena-input\n [label]=\"'Confirm Password'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'password'\"\n formControlName=\"ConfirmPassword\"\n [showBorder]=\"true\"\n [passwordToggle]=\"true\"\n [bgColor]=\"'white'\"\n [minLength]=\"userRequestForm.controls['Password'].value?.length\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [customErrorMessages]=\"{\n minLength:'Confirm Password must match password',\n required: 'Confirm Password is required and must match password',\n password: 'Password does not match',\n }\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n\n <verbena-button\n [class]=\"'mt-6'\"\n [disable]=\"!this.checkForm()\"\n [text]=\"text\"\n [bgColor]=\"btnBgColor\"\n [textColor]=\"color\"\n [buttonClass]=\"'cursor-not-allowed'\"\n [border]=\"btnBorder\"\n [borderRadius]=\"btnBorderRadius\"\n [pd]=\"btnPd\"\n [ngClass]=\"{\n 'cursor-not-allowed':!checkForm()\n }\"\n [width]=\"btnWidth\"\n buttonClass=\"font-medium text-[22px] leading-[33px]\"\n ></verbena-button>\n\n <div *ngIf=\"AuthMechanisms !== null\"> \n <verben-o-auth \n [authMechanisms]=\"AuthMechanisms\"\n (googleClick)=\"handleGoogleAuth()\"\n (appleClick)=\"handleAppleAuth()\"\n (microsoftClick)=\"handleMicrosoft()\"\n ></verben-o-auth>\n </div>\n <!-- <verbena-button\n svg=\"apple-logo\"\n (click)=\"handleAppleAuth()\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Apple\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n ></verbena-button> -->\n </form>\n\n \n</section>\n\n", styles: [".flex{display:flex}.items-center{align-items:center}.overflow-hidden{overflow:hidden}.justify-center{justify-content:center}.h-full{height:100%}.text-center{text-align:center}.underline{text-decoration:underline}.gap-5{gap:20px}.mt-4{margin-top:1rem}.space-y-4>:not([hidden])~:not([hidden]){margin-top:1rem}.gap-1>:not([hidden])~:not([hidden]){gap:.25rem}.pt-3{padding-top:.75rem}.mt-5{margin-top:1.25rem}.border{border-width:1px}.rounded-xl{border-radius:.75rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.flex-col{flex-direction:column}.object-cover{object-fit:cover}.w-full{width:100%}.cursor-not-allowed{cursor:not-allowed!important}.accent{accent-color:#000}.OR{color:#666;gap:6px}.OR span{width:150px;border-top:2px solid #6666663d;display:block}\n"], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i6.VerbenaInputComponent, selector: "verbena-input", inputs: ["label", "placeHolder", "required", "svgPosition", "minLength", "maxLength", "type", "bgColor", "border", "borderRadius", "textColor", "value", "labelPosition", "labelColor", "disable", "readOnly", "min", "max", "showBorder", "showErrorMessage", "errorMessageColor", "errorBorderColor", "errorPosition", "svg", "svgWidth", "svgHeight", "svgColor", "capitalization", "inputContainerClass", "inputFieldClass", "passLength", "inputWrapperClass", "passwordToggle", "customErrorMessages", "icon", "textPass"], outputs: ["valueChange"] }, { kind: "component", type: i6.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i8.OAuthComponent, selector: "verben-o-auth", inputs: ["authMechanisms"], outputs: ["microsoftClick", "googleClick", "appleClick"] }] });
|
|
149
221
|
}
|
|
150
222
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestComponent, decorators: [{
|
|
151
223
|
type: Component,
|
|
152
|
-
args: [{ selector: 'lib-user-request', template: "<section [ngStyle]=\"styles\" class=\"{{ customClass }}\">\n <h2 class=\"{{ headingClass }}\">\n {{ headingTitle }}\n </h2>\n\n <form\n [formGroup]=\"userRequestForm\"\n (ngSubmit)=\"submitForm()\"\n class=\"flex flex-col gap-5 mt-3\"\n >\n <verbena-input\n [label]=\"'First Name'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'text'\"\n formControlName=\"FirstName\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n <verbena-input\n [label]=\"'Last Name'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'text'\"\n formControlName=\"LastName\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n <verbena-input\n [label]=\"'E-mail Address'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'email'\"\n formControlName=\"
|
|
153
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.HttpWebRequestService }, { type: i3.UtilService }, { type: i4.EnvironmentService }], propDecorators: { width: [{
|
|
224
|
+
args: [{ selector: 'lib-user-request', template: "<section [ngStyle]=\"styles\" class=\"{{ customClass }}\">\n <h2 class=\"{{ headingClass }}\">\n {{ headingTitle }}\n </h2>\n\n <form\n [formGroup]=\"userRequestForm\"\n (ngSubmit)=\"submitForm()\"\n class=\"flex flex-col gap-5 mt-3\"\n >\n <verbena-input\n [label]=\"'First Name'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'text'\"\n formControlName=\"FirstName\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n <verbena-input\n [label]=\"'Last Name'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'text'\"\n formControlName=\"LastName\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n <verbena-input\n [label]=\"'E-mail Address'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'email'\"\n formControlName=\"MailAddress\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [customErrorMessages]=\"{\n required: 'Email address is required',\n email: 'Email address must be valid'\n }\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n\n <verbena-input\n [label]=\"'Password'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [passwordToggle]=\"true\"\n formControlName=\"Password\"\n [required]=\"true\"\n [type]=\"'password'\"\n [showBorder]=\"true\"\n [bgColor]=\"'white'\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n\n <verbena-input\n [label]=\"'Confirm Password'\"\n [labelColor]=\"'#666'\"\n [placeHolder]=\"''\"\n [required]=\"true\"\n [type]=\"'password'\"\n formControlName=\"ConfirmPassword\"\n [showBorder]=\"true\"\n [passwordToggle]=\"true\"\n [bgColor]=\"'white'\"\n [minLength]=\"userRequestForm.controls['Password'].value?.length\"\n [border]=\"'1px solid #66666659'\"\n [borderRadius]=\"'12px'\"\n [showErrorMessage]=\"true\"\n [errorMessageColor]=\"'red'\"\n [customErrorMessages]=\"{\n minLength:'Confirm Password must match password',\n required: 'Confirm Password is required and must match password',\n password: 'Password does not match',\n }\"\n [errorBorderColor]=\"'red'\"\n [errorPosition]=\"'bottom'\"\n class=\"outline-none focus-none\"\n ></verbena-input>\n\n <verbena-button\n [class]=\"'mt-6'\"\n [disable]=\"!this.checkForm()\"\n [text]=\"text\"\n [bgColor]=\"btnBgColor\"\n [textColor]=\"color\"\n [buttonClass]=\"'cursor-not-allowed'\"\n [border]=\"btnBorder\"\n [borderRadius]=\"btnBorderRadius\"\n [pd]=\"btnPd\"\n [ngClass]=\"{\n 'cursor-not-allowed':!checkForm()\n }\"\n [width]=\"btnWidth\"\n buttonClass=\"font-medium text-[22px] leading-[33px]\"\n ></verbena-button>\n\n <div *ngIf=\"AuthMechanisms !== null\"> \n <verben-o-auth \n [authMechanisms]=\"AuthMechanisms\"\n (googleClick)=\"handleGoogleAuth()\"\n (appleClick)=\"handleAppleAuth()\"\n (microsoftClick)=\"handleMicrosoft()\"\n ></verben-o-auth>\n </div>\n <!-- <verbena-button\n svg=\"apple-logo\"\n (click)=\"handleAppleAuth()\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n text=\"Continue with Apple\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n ></verbena-button> -->\n </form>\n\n \n</section>\n\n", styles: [".flex{display:flex}.items-center{align-items:center}.overflow-hidden{overflow:hidden}.justify-center{justify-content:center}.h-full{height:100%}.text-center{text-align:center}.underline{text-decoration:underline}.gap-5{gap:20px}.mt-4{margin-top:1rem}.space-y-4>:not([hidden])~:not([hidden]){margin-top:1rem}.gap-1>:not([hidden])~:not([hidden]){gap:.25rem}.pt-3{padding-top:.75rem}.mt-5{margin-top:1.25rem}.border{border-width:1px}.rounded-xl{border-radius:.75rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.flex-col{flex-direction:column}.object-cover{object-fit:cover}.w-full{width:100%}.cursor-not-allowed{cursor:not-allowed!important}.accent{accent-color:#000}.OR{color:#666;gap:6px}.OR span{width:150px;border-top:2px solid #6666663d;display:block}\n"] }]
|
|
225
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.HttpWebRequestService }, { type: i3.UtilService }, { type: i4.EnvironmentService }, { type: i5.ActivatedRoute }], propDecorators: { width: [{
|
|
154
226
|
type: Input
|
|
155
227
|
}], headingTitle: [{
|
|
156
228
|
type: Input
|
|
@@ -200,7 +272,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
200
272
|
type: Output
|
|
201
273
|
}], appleClick: [{
|
|
202
274
|
type: Output
|
|
275
|
+
}], microsoftClick: [{
|
|
276
|
+
type: Output
|
|
277
|
+
}], onSubmitGoogleAuth: [{
|
|
278
|
+
type: Output
|
|
203
279
|
}], onSubmitResponseEnd: [{
|
|
204
280
|
type: Output
|
|
205
281
|
}] } });
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-request.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/user-request/user-request.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/user-request/user-request.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormGroup,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\nimport {UserRequestPayload } from '../../models/UserRequest';\nimport { ObjectState } from '../../models/object-state';\nimport { UtilService } from '../../services/util.service';\nimport { ResponseKeyValue } from '../../models/ResponseKeyValue';\nimport { ErrorResponse } from '../../models/ErrorResponse';\nimport { Status } from '../../models/status';\nimport { RequestStatus } from '../../models/request-status';\nimport { EnvironmentService } from '../../services/environment.service';\n@Component({\n  selector: 'lib-user-request',\n  templateUrl: './user-request.component.html',\n  styleUrls: ['./user-request.component.css'],\n})\nexport class UserRequestComponent {\n  @Input() width: string = '500px';\n  @Input() headingTitle: string = 'Request an account';\n  @Input() headingClass: string =\n    'font-medium text-[2rem] leading-[48px] text-[#333]';\n  @Input() customClass: string = '';\n  @Input() bgColor: string = '#fff';\n  @Input() boxShadow: string = '4px 4px 4px rgba(0, 0, 0, 0.25)';\n  @Input() border: string = '1px solid #66666680';\n  @Input() borderRadius: string = '24px';\n  @Input() textColor: string = '#333';\n  @Input() height: string = 'auto';\n  @Input() pd: string = '32px 48px';\napiKey:string=''\n  // Button Inputs\n  @Input() text: string = 'Send Request';\n  @Input() color: string = 'black';\n  @Input() btnBorder: string = '1px solid #FFE681';\n  @Input() btnBorderRadius: string = '40px';\n  @Input() btnBgColor: string = '#FFE681';\n  @Input() btnWidth: string = '100%';\n  @Input() btnPd: string = '10px 20px';\n  @Input() termsLink: string = '';\n  @Input() privacyLink: string = '';\n  @Input() routerLink: string = '';\n  @Output() formSubmit = new EventEmitter<UserRequestPayload[]>();\n  @Output() googleClick = new EventEmitter();\n  @Output() onSubmitSuccess = new EventEmitter<any>();\n  @Output() appleClick = new EventEmitter();\n  @Output() onSubmitResponseEnd: EventEmitter<any> = new EventEmitter();\n  userRequestForm: FormGroup;\n\n  constructor(\n    private fb: FormBuilder,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService,\n  ) {\n    this.apiKey =  this.envSvc.environment.APIKey\n    this.userRequestForm = this.fb.group(\n      {\n        FirstName: [null, [Validators.required]],\n        LastName: [null, [Validators.required]],\n        Email: [null, [Validators.required, Validators.email]],\n        Password: [null, [Validators.required, Validators.minLength(8)]],\n        ConfirmPassword: [null, [Validators.required]],\n      },\n      { validators: this.passwordMatchValidator }\n    );\n  }\n  passwordMatchValidator(control: AbstractControl): ValidationErrors | null {\n    const password = control.get('Password')?.value;\n    const confirmPassword = control.get('ConfirmPassword')?.value;\n\n    return password === confirmPassword ? null : { passwordMismatch: true };\n  }\n\n  get passwordMismatchError(): boolean {\n    return this.userRequestForm.hasError('passwordMismatch');\n  }\n  get styles() {\n    return {\n      'background-color': this.bgColor,\n      'box-shadow': this.boxShadow,\n      border: this.border,\n      'border-radius': this.borderRadius,\n      color: this.textColor,\n      'max-width': this.width,\n      height: this.height,\n      padding: this.pd,\n    };\n  }\n  checkForm(): boolean {\n    return this.userRequestForm.valid;\n  }\n  handleGoogleAuth() {\n    this.googleClick.emit();\n  }\n  handleAppleAuth() {\n    this.appleClick.emit();\n  }\n  async submitForm() {\n    if (!this.checkForm()) {\n      return;\n    }\n  \n    const payload: UserRequestPayload[] = [\n      {\n        Code: '',\n        FirstName: this.userRequestForm.controls['FirstName'].value,\n        LastName: this.userRequestForm.controls['LastName'].value,\n        MailAddress: this.userRequestForm.controls['Email'].value,\n        Password: this.userRequestForm.controls['Password'].value,\n        PhoneNumber: '',\n        OtherName: '',\n        Role: [],\n        Tags: [],\n        Status: Status.Active,\n        RequestStatus: RequestStatus.Pending,\n        UpdatedAt: new Date(),\n        CreatedAt: new Date(),\n        Id: '',\n        DataState: ObjectState.New,\n        TenantId: '',\n        ServiceName: '',\n        ActionBy: '',\n        Comment: '',\n      },\n    ];\n  \n    // Emit payload if needed\n    this.formSubmit.emit(payload);\n  \n    // Show loading indicator\n    this.utilService.sendBI(true);\n  \n    try {\n      // Make the API call\n      const res = await this.server.post(`User/SaveUserAccessRequests`, payload);\n  \n      // Hide loading indicator\n      this.utilService.sendBI(false);\n  \n      if (res instanceof ErrorResponse) {\n        // Emit error response\n        this.onSubmitResponseEnd.emit(res);\n        console.log(res);\n      } else {\n        // Emit success response\n        const result = res as ResponseKeyValue;\n        this.onSubmitResponseEnd.emit(result);\n  \n        // Emit success event\n        this.onSubmitSuccess.emit(result);\n\n      }\n    } catch (error) {\n      // Handle unexpected errors\n      this.utilService.sendBI(false);\n      console.error('Unexpected error:', error);\n      this.onSubmitResponseEnd.emit(error);\n    }\n  }\n  \n}\n","<section [ngStyle]=\"styles\" class=\"{{ customClass }}\">\n  <h2 class=\"{{ headingClass }}\">\n    {{ headingTitle }}\n  </h2>\n\n  <form\n    [formGroup]=\"userRequestForm\"\n    (ngSubmit)=\"submitForm()\"\n    class=\"flex flex-col gap-5 mt-3\"\n  >\n    <verbena-input\n      [label]=\"'First Name'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'text'\"\n      formControlName=\"FirstName\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n    <verbena-input\n      [label]=\"'Last Name'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'text'\"\n      formControlName=\"LastName\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n    <verbena-input\n      [label]=\"'E-mail Address'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'email'\"\n      formControlName=\"Email\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [customErrorMessages]=\"{\n        required: 'Email address is required',\n        email: 'Email address must be valid'\n      }\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n\n    <verbena-input\n      [label]=\"'Password'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [passwordToggle]=\"true\"\n      formControlName=\"Password\"\n      [required]=\"true\"\n      [type]=\"'password'\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n\n    <verbena-input\n      [label]=\"'Confirm Password'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'password'\"\n      formControlName=\"ConfirmPassword\"\n      [showBorder]=\"true\"\n      [passwordToggle]=\"true\"\n      [bgColor]=\"'white'\"\n      [minLength]=\"userRequestForm.controls['Password'].value?.length\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [customErrorMessages]=\"{\n        minLength:'Confirm Password must match password',\n        required: 'Confirm Password is required and must match password',\n        password: 'Password does not match',\n      }\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n\n    <verbena-button\n    [class]=\"'mt-6'\"\n      [disable]=\"!this.checkForm()\"\n      [text]=\"text\"\n      [bgColor]=\"btnBgColor\"\n      [textColor]=\"color\"\n      [buttonClass]=\"'cursor-not-allowed'\"\n      [border]=\"btnBorder\"\n      [borderRadius]=\"btnBorderRadius\"\n      [pd]=\"btnPd\"\n      [ngClass]=\"{\n       'cursor-not-allowed':!checkForm()\n      }\"\n      [width]=\"btnWidth\"\n      buttonClass=\"font-medium text-[22px] leading-[33px]\"\n    ></verbena-button>\n    <div class=\"flex justify-center items-center OR\">\n      <span></span>\n      OR\n      <span></span>\n  </div>\n\n    <verbena-button\n      svg=\"google-logo\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      (click)=\"handleGoogleAuth()\"\n      text=\"Continue with Google\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333]\"\n    ></verbena-button>\n\n    <verbena-button\n      svg=\"apple-logo\"\n      (click)=\"handleAppleAuth()\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      text=\"Continue with Apple\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n    ></verbena-button>\n  </form>\n</section>\n"]}
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-request.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/user-request/user-request.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/user-request/user-request.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  ValidationErrors,\n  Validators,\n} from '@angular/forms';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\nimport { UserRequestPayload } from '../../models/UserRequest';\nimport { ObjectState } from '../../models/object-state';\nimport { UtilService } from '../../services/util.service';\nimport { ResponseKeyValue } from '../../models/ResponseKeyValue';\nimport { ErrorResponse } from '../../models/ErrorResponse';\nimport { Status } from '../../models/status';\nimport { RequestStatus } from '../../models/request-status';\nimport { EnvironmentService } from '../../services/environment.service';\nimport { AuthMechanism, MechanismType } from '../../models/auth-mechanism';\nimport { ActivatedRoute } from '@angular/router';\nimport { OAuthResponse } from '../../models/oauth-response';\n\n@Component({\n  selector: 'lib-user-request',\n  templateUrl: './user-request.component.html',\n  styleUrls: ['./user-request.component.css'],\n})\nexport class UserRequestComponent {\n  @Input() width: string = '500px';\n  @Input() headingTitle: string = 'Request an account';\n  @Input() headingClass: string =\n    'font-medium text-[2rem] leading-[48px] text-[#333]';\n  @Input() customClass: string = '';\n  @Input() bgColor: string = '#fff';\n  @Input() boxShadow: string = '4px 4px 4px rgba(0, 0, 0, 0.25)';\n  @Input() border: string = '1px solid #66666680';\n  @Input() borderRadius: string = '24px';\n  @Input() textColor: string = '#333';\n  @Input() height: string = 'auto';\n  @Input() pd: string = '32px 48px';\n  isFormEditable: boolean = true;\n  apiKey: string = '';\n  isCode: boolean = false;\n  @Input() text: string = 'Send Request';\n  @Input() color: string = 'black';\n  @Input() btnBorder: string = '1px solid #FFE681';\n  @Input() btnBorderRadius: string = '40px';\n  @Input() btnBgColor: string = '#FFE681';\n  @Input() btnWidth: string = '100%';\n  @Input() btnPd: string = '10px 20px';\n  @Input() termsLink: string = '';\n  @Input() privacyLink: string = '';\n  @Input() routerLink: string = '';\n  @Output() formSubmit = new EventEmitter<UserRequestPayload[]>();\n  @Output() googleClick = new EventEmitter();\n  @Output() onSubmitSuccess = new EventEmitter<any>();\n  @Output() appleClick = new EventEmitter();\n  @Output() microsoftClick = new EventEmitter();\n  @Output() onSubmitGoogleAuth: EventEmitter<ResponseKeyValue | ErrorResponse> =\n    new EventEmitter();\n  @Output() onSubmitResponseEnd: EventEmitter<any> = new EventEmitter();\n  userRequestForm: FormGroup;\n  tenantDetails: any | null = null;\n  AuthMechanisms: AuthMechanism[] | null = null;\n  showform: boolean = false;\n  code: string = '';\n  constructor(\n    private fb: FormBuilder,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService,\n    private route: ActivatedRoute\n  ) {\n    this.apiKey = this.envSvc.environment.APIKey;\n    \n    this.userRequestForm = this.fb.group<{\n      [K in keyof UserRequestPayload]: FormControl<UserRequestPayload[K]>;\n    }>(\n      {\n        Code: new FormControl('', { nonNullable: true }),\n        FirstName: new FormControl('', {\n          nonNullable: true,\n          validators: [Validators.required],\n        }),\n        LastName: new FormControl('', {\n          nonNullable: true,\n          validators: [Validators.required],\n        }),\n        MailAddress: new FormControl('', {\n          nonNullable: true,\n          validators: [Validators.required, Validators.email],\n        }),\n        Password: new FormControl('', {\n          nonNullable: true,\n          validators: [Validators.required, Validators.minLength(8)],\n        }),\n        PhoneNumber: new FormControl('', { nonNullable: true }),\n        OtherName: new FormControl('', { nonNullable: true }),\n        Role: new FormControl<string[]>([], { nonNullable: true }),\n        Tags: new FormControl<[]>([], { nonNullable: true }),\n        Status: new FormControl<Status>(Status.Active, { nonNullable: true }),\n        RequestStatus: new FormControl<RequestStatus>(RequestStatus.Pending, {\n          nonNullable: true,\n        }),\n        UpdatedAt: new FormControl(new Date(), { nonNullable: true }),\n        CreatedAt: new FormControl(new Date(), { nonNullable: true }),\n        Id: new FormControl('', { nonNullable: true }),\n        DataState: new FormControl<ObjectState>(ObjectState.New, {\n          nonNullable: true,\n        }),\n        TenantId: new FormControl('', { nonNullable: true }),\n        SignUpType: new FormControl(MechanismType.InApp, { nonNullable: true }),\n        ServiceName: new FormControl('', { nonNullable: true }),\n        ActionBy: new FormControl('', { nonNullable: true }),\n        Comment: new FormControl('', { nonNullable: true }),\n      },\n      { validators: this.passwordMatchValidator }\n    );\n  }\n  passwordMatchValidator(control: AbstractControl): ValidationErrors | null {\n\n    const password = control.get('Password')?.value;\n    const confirmPassword = control.get('ConfirmPassword')?.value;\n\n    return password === confirmPassword ? null : { passwordMismatch: true };\n  }\n\n  get passwordMismatchError(): boolean {\n    return this.userRequestForm.hasError('passwordMismatch');\n  }\n\n  get styles() {\n    return {\n      'background-color': this.bgColor,\n      'box-shadow': this.boxShadow,\n      border: this.border,\n      'border-radius': this.borderRadius,\n      color: this.textColor,\n      'max-width': this.width,\n      height: this.height,\n      padding: this.pd,\n    };\n  }\n  async  ngOnInit() {\n    await this.getTenantConfig(); \n   \n    this.route.queryParams.subscribe(params => {\n      this.code = params['code'];\n      console.log(this.code,'code');\n      \n      if (this.code) {\n        this.verifyUserDetails();\n      }\n    });\n   \n  }\n\n  async getTenantConfig() {\n    this.userRequestForm.addControl(\n      'ConfirmPassword',\n      new FormControl('', Validators.required)\n    );\n    const res = await this.server.get(\n      `Tenant/GetTenantConfigByKey/${this.apiKey}`\n    );\n    this.tenantDetails = res;\n    this.AuthMechanisms = this.tenantDetails?.AuthMechanisms;\n    if (\n      !this.tenantDetails?.AuthMechanism &&\n      this.tenantDetails?.AuthMechanism !== MechanismType.InApp\n    ) {\n      this.showform = false;\n    } else if (this.tenantDetails?.AuthMechanism === MechanismType.InApp) {\n      this.showform = true;\n    } else if (this.AuthMechanisms !== null) {\n      this.showform = this.AuthMechanisms.some((item) =>\n        item.AuthMechanism.includes(MechanismType.InApp)\n      );\n    }\n  }\n  checkForm(): boolean {\n    return this.userRequestForm.valid;\n  }\n  handleGoogleAuth() {\n    if (this.AuthMechanisms !== null) {\n      const data = this.AuthMechanisms.filter(\n        (item) => item.AuthMechanism === MechanismType.Google\n      );\n      this.googleClick.emit();\n    }\n  }\n  handleAppleAuth() {\n    this.appleClick.emit();\n  }\n  handleMicrosoft() {\n    if (this.AuthMechanisms !== null) {\n      const data = this.AuthMechanisms.filter(\n        (item) => item.AuthMechanism === MechanismType.MicrosoftAD\n      );\n      this.microsoftClick.emit();\n    }\n  }\n\n  async submitForm() {\n    if (!this.checkForm()) {\n      return;\n    }\n\n    const formValue = this.userRequestForm.getRawValue();\n    const { ConfirmPassword, ...payload } = formValue;\n\n    const payloadToSubmit: UserRequestPayload[] = [payload];\n\n    this.formSubmit.emit(payloadToSubmit);\n    this.utilService.sendBI(true);\n\n    try {\n      const res = await this.server.post(\n        `User/SaveUserAccessRequests`,\n        payloadToSubmit\n      );\n\n      this.utilService.sendBI(false);\n\n      if (res instanceof ErrorResponse) {\n        this.onSubmitResponseEnd.emit(res);\n        console.log(res);\n      } else {\n        const result = res as ResponseKeyValue;\n        this.onSubmitResponseEnd.emit(result);\n        this.onSubmitSuccess.emit(result);\n      }\n    } catch (error) {\n      this.utilService.sendBI(false);\n      console.error('Unexpected error:', error);\n      this.onSubmitResponseEnd.emit(error);\n    }\n  }\n  async verifyUserDetails() {\n    if (this.AuthMechanisms !== null && this.apiKey) {\n      const data: any = this.AuthMechanisms.find((item) =>\n        item.AuthMechanism.includes(MechanismType.Google)\n      );\n      const payload = {\n        AuthCode: this.code,\n        APIKey: this.apiKey,\n        AuthMechanism: data.AuthMechanism,\n      };\n\n      this.utilService.sendBI(true);\n      const res: OAuthResponse = await this.server.post(\n        `Authentication/GetUserDetails`,\n        payload\n      );\n      this.utilService.sendBI(false);\n      if (res instanceof ErrorResponse) {\n        this.onSubmitGoogleAuth.emit(res);\n      } else {\n        this.userRequestForm.controls['FirstName'].setValue(res.FirstName);\n        this.userRequestForm.controls['LastName'].setValue(res.LastName);\n        this.userRequestForm.controls['MailAddress'].setValue(res.Email);\n        this.userRequestForm.controls['SignUpType'].setValue(\n          MechanismType.Google\n        );\n      }\n    }\n  }\n}\n","<section [ngStyle]=\"styles\" class=\"{{ customClass }}\">\n  <h2 class=\"{{ headingClass }}\">\n    {{ headingTitle }}\n  </h2>\n\n  <form\n    [formGroup]=\"userRequestForm\"\n    (ngSubmit)=\"submitForm()\"\n    class=\"flex flex-col gap-5 mt-3\"\n  >\n    <verbena-input\n      [label]=\"'First Name'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'text'\"\n      formControlName=\"FirstName\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n    <verbena-input\n      [label]=\"'Last Name'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'text'\"\n      formControlName=\"LastName\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n    <verbena-input\n      [label]=\"'E-mail Address'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'email'\"\n      formControlName=\"MailAddress\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [customErrorMessages]=\"{\n        required: 'Email address is required',\n        email: 'Email address must be valid'\n      }\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n\n    <verbena-input\n      [label]=\"'Password'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [passwordToggle]=\"true\"\n      formControlName=\"Password\"\n      [required]=\"true\"\n      [type]=\"'password'\"\n      [showBorder]=\"true\"\n      [bgColor]=\"'white'\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n\n    <verbena-input\n      [label]=\"'Confirm Password'\"\n      [labelColor]=\"'#666'\"\n      [placeHolder]=\"''\"\n      [required]=\"true\"\n      [type]=\"'password'\"\n      formControlName=\"ConfirmPassword\"\n      [showBorder]=\"true\"\n      [passwordToggle]=\"true\"\n      [bgColor]=\"'white'\"\n      [minLength]=\"userRequestForm.controls['Password'].value?.length\"\n      [border]=\"'1px solid #66666659'\"\n      [borderRadius]=\"'12px'\"\n      [showErrorMessage]=\"true\"\n      [errorMessageColor]=\"'red'\"\n      [customErrorMessages]=\"{\n        minLength:'Confirm Password must match password',\n        required: 'Confirm Password is required and must match password',\n        password: 'Password does not match',\n      }\"\n      [errorBorderColor]=\"'red'\"\n      [errorPosition]=\"'bottom'\"\n      class=\"outline-none focus-none\"\n    ></verbena-input>\n\n    <verbena-button\n      [class]=\"'mt-6'\"\n      [disable]=\"!this.checkForm()\"\n      [text]=\"text\"\n      [bgColor]=\"btnBgColor\"\n      [textColor]=\"color\"\n      [buttonClass]=\"'cursor-not-allowed'\"\n      [border]=\"btnBorder\"\n      [borderRadius]=\"btnBorderRadius\"\n      [pd]=\"btnPd\"\n      [ngClass]=\"{\n       'cursor-not-allowed':!checkForm()\n      }\"\n      [width]=\"btnWidth\"\n      buttonClass=\"font-medium text-[22px] leading-[33px]\"\n    ></verbena-button>\n\n  <div *ngIf=\"AuthMechanisms !== null\"> \n    <verben-o-auth \n      [authMechanisms]=\"AuthMechanisms\"\n      (googleClick)=\"handleGoogleAuth()\"\n      (appleClick)=\"handleAppleAuth()\"\n      (microsoftClick)=\"handleMicrosoft()\"\n    ></verben-o-auth>\n  </div>\n    <!-- <verbena-button\n      svg=\"apple-logo\"\n      (click)=\"handleAppleAuth()\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      text=\"Continue with Apple\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n    ></verbena-button> -->\n  </form>\n\n  \n</section>\n\n"]}
|
|
@@ -3,6 +3,7 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
|
3
3
|
import { VerbenaButtonModule, VerbenaInputModule } from 'verben-ng-ui';
|
|
4
4
|
import { CommonModule } from '@angular/common';
|
|
5
5
|
import { UserRequestComponent } from './user-request.component';
|
|
6
|
+
import { OAuthModule } from '../o-auth/o-auth.module';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export class UserRequestModule {
|
|
8
9
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -10,12 +11,14 @@ export class UserRequestModule {
|
|
|
10
11
|
ReactiveFormsModule,
|
|
11
12
|
VerbenaInputModule,
|
|
12
13
|
VerbenaButtonModule,
|
|
13
|
-
CommonModule
|
|
14
|
+
CommonModule,
|
|
15
|
+
OAuthModule], exports: [UserRequestComponent] });
|
|
14
16
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestModule, imports: [FormsModule,
|
|
15
17
|
ReactiveFormsModule,
|
|
16
18
|
VerbenaInputModule,
|
|
17
19
|
VerbenaButtonModule,
|
|
18
|
-
CommonModule
|
|
20
|
+
CommonModule,
|
|
21
|
+
OAuthModule] });
|
|
19
22
|
}
|
|
20
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UserRequestModule, decorators: [{
|
|
21
24
|
type: NgModule,
|
|
@@ -27,8 +30,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
27
30
|
VerbenaInputModule,
|
|
28
31
|
VerbenaButtonModule,
|
|
29
32
|
CommonModule,
|
|
33
|
+
OAuthModule
|
|
30
34
|
],
|
|
31
35
|
exports: [UserRequestComponent],
|
|
32
36
|
}]
|
|
33
37
|
}] });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1yZXF1ZXN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZlcmJlbi1hdXRoZW50aWNhdGlvbi11aS9zcmMvbGliL2NvbXBvbmVudHMvdXNlci1yZXF1ZXN0L3VzZXItcmVxdWVzdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBY3RELE1BQU0sT0FBTyxpQkFBaUI7d0dBQWpCLGlCQUFpQjt5R0FBakIsaUJBQWlCLGlCQVhiLG9CQUFvQixhQUVqQyxXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsWUFBWTtZQUNaLFdBQVcsYUFFSCxvQkFBb0I7eUdBRW5CLGlCQUFpQixZQVQxQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsWUFBWTtZQUNaLFdBQVc7OzRGQUlGLGlCQUFpQjtrQkFaN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDcEMsT0FBTyxFQUFFO3dCQUNQLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixrQkFBa0I7d0JBQ2xCLG1CQUFtQjt3QkFDbkIsWUFBWTt3QkFDWixXQUFXO3FCQUNaO29CQUNELE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDO2lCQUNoQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFZlcmJlbmFCdXR0b25Nb2R1bGUsIFZlcmJlbmFJbnB1dE1vZHVsZSB9IGZyb20gJ3ZlcmJlbi1uZy11aSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgVXNlclJlcXVlc3RDb21wb25lbnQgfSBmcm9tICcuL3VzZXItcmVxdWVzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgT0F1dGhNb2R1bGUgfSBmcm9tICcuLi9vLWF1dGgvby1hdXRoLm1vZHVsZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1VzZXJSZXF1ZXN0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgVmVyYmVuYUlucHV0TW9kdWxlLFxuICAgIFZlcmJlbmFCdXR0b25Nb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE9BdXRoTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtVc2VyUmVxdWVzdENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJSZXF1ZXN0TW9kdWxlIHt9XG4iXX0=
|