|
@@ -1,9 +1,11 @@
|
|
|
import { Component, OnInit } from '@angular/core';
|
|
|
import { ActivatedRoute, Params } from '@angular/router';
|
|
|
import { ComponentBase } from '@core/base/common-base';
|
|
|
-import { take, takeUntil } from 'rxjs';
|
|
|
+import { from, take, takeUntil } from 'rxjs';
|
|
|
import { BaseForm } from '@core/base/base-form';
|
|
|
import { AuthService } from '@core/services/authentication/auth.service';
|
|
|
+import { ToastrService } from 'ngx-toastr';
|
|
|
+import { SharedService } from '../../../core/services/shared.service';
|
|
|
|
|
|
import {
|
|
|
FormGroup,
|
|
@@ -17,6 +19,7 @@ import {
|
|
|
UNIVERISTY,
|
|
|
COUNTRY,
|
|
|
INDUSTRY,
|
|
|
+ CITY,
|
|
|
} from '@core/models/authenticcation.model';
|
|
|
|
|
|
@Component({
|
|
@@ -34,11 +37,14 @@ export class SignupEmployeeComponent
|
|
|
qualificationList: QUALIFICATION[] = [];
|
|
|
univerisites: UNIVERISTY[] = [];
|
|
|
countries: COUNTRY[] = [];
|
|
|
+ cities: CITY[] = [];
|
|
|
industriesList: INDUSTRY[] = [];
|
|
|
|
|
|
constructor(
|
|
|
private readonly route: ActivatedRoute,
|
|
|
- private readonly authService: AuthService
|
|
|
+ private readonly authService: AuthService,
|
|
|
+ private readonly toastr: ToastrService,
|
|
|
+ private readonly sharedService: SharedService
|
|
|
) {
|
|
|
super();
|
|
|
}
|
|
@@ -72,8 +78,15 @@ export class SignupEmployeeComponent
|
|
|
phoneNumber: new UntypedFormControl(null, [Validators.required]),
|
|
|
userType: new UntypedFormControl(null, [Validators.required]),
|
|
|
linkedInLink: new UntypedFormControl(null, [Validators.required]),
|
|
|
- userName: new UntypedFormControl(null, [Validators.required]),
|
|
|
- password: new UntypedFormControl(null, [Validators.required]),
|
|
|
+ userName: new UntypedFormControl(null, [
|
|
|
+ Validators.required,
|
|
|
+ Validators.minLength(6),
|
|
|
+ ]),
|
|
|
+ password: new UntypedFormControl(null, [
|
|
|
+ Validators.required,
|
|
|
+ Validators.pattern(this.sharedService.StrongPasswordRegx),
|
|
|
+ Validators.minLength(8),
|
|
|
+ ]),
|
|
|
favoriteName: new UntypedFormControl(null, [Validators.required]),
|
|
|
passportNumber: new UntypedFormControl(null, [Validators.required]),
|
|
|
qualificationId: new UntypedFormControl(null, [Validators.required]),
|
|
@@ -82,6 +95,11 @@ export class SignupEmployeeComponent
|
|
|
industryId: new UntypedFormControl(null, [Validators.required]),
|
|
|
taxNumber: new UntypedFormControl(null, [Validators.required]),
|
|
|
incomeTaxValue: new UntypedFormControl(null, Validators.required),
|
|
|
+ cvAttach: new UntypedFormControl(null),
|
|
|
+ passportAttach: new UntypedFormControl(null),
|
|
|
+ eduCertificateAttach: new UntypedFormControl(null),
|
|
|
+ experienceCertificateAttach: new UntypedFormControl(null),
|
|
|
+ profCertificateAttach: new UntypedFormControl(null),
|
|
|
userAddress: new UntypedFormGroup({
|
|
|
countryId: new UntypedFormControl(null, [Validators.required]),
|
|
|
cityId: new UntypedFormControl(null, [Validators.required]),
|
|
@@ -136,42 +154,39 @@ export class SignupEmployeeComponent
|
|
|
});
|
|
|
}
|
|
|
|
|
|
+ onChangeCountry(event: any): void {
|
|
|
+ this.authService
|
|
|
+ .getCities({ CountryId: event.target.value })
|
|
|
+ .subscribe((res) => {
|
|
|
+ this.cities = res;
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
onUploadFile(event: any): void {
|
|
|
if (event.file) {
|
|
|
- this.multiPartForm.append(event.type, event.file);
|
|
|
+ this.form.patchValue({ [event.type]: event.file });
|
|
|
} else {
|
|
|
- this.multiPartForm.delete(event.type);
|
|
|
+ this.form.patchValue({ [event.type]: null });
|
|
|
}
|
|
|
}
|
|
|
|
|
|
onSubmit(): void {
|
|
|
- console.log(this.form.get('userName')?.value);
|
|
|
- for (const key in this.form.value) {
|
|
|
- if (this.form.value.hasOwnProperty(key)) {
|
|
|
- this.multiPartForm.append(key, this.form.value[key]);
|
|
|
+ const multiPartForm = new FormData();
|
|
|
+ if (this.submitValidity(this.form)) {
|
|
|
+ for (const key in { ...this.form.value }) {
|
|
|
+ if (this.form.value.hasOwnProperty(key)) {
|
|
|
+ if (this.form.get(key)?.value) {
|
|
|
+ multiPartForm.append(key, this.form.get(key)?.value);
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
- }
|
|
|
|
|
|
- // this.multiPartForm.append(
|
|
|
- // 'userAddress',
|
|
|
- // JSON.stringify({
|
|
|
- // countryId: this.form.get('countryId')?.value,
|
|
|
- // cityId: 1,
|
|
|
- // postalCode: this.form.get('postalCode')?.value,
|
|
|
- // addressDesc: this.form.get('addressDesc')?.value,
|
|
|
- // })
|
|
|
- // );
|
|
|
-
|
|
|
- this.authService
|
|
|
- .addEmployee(this.multiPartForm)
|
|
|
- .pipe(takeUntil(this.destroy$))
|
|
|
- .subscribe(
|
|
|
- (res) => {
|
|
|
- console.log(res);
|
|
|
- },
|
|
|
- (err) => {
|
|
|
- console.log(err);
|
|
|
- }
|
|
|
- );
|
|
|
+ this.authService
|
|
|
+ .addEmployee(multiPartForm)
|
|
|
+ .pipe(takeUntil(this.destroy$))
|
|
|
+ .subscribe((res) => {
|
|
|
+ this.toastr.success('Registeration Successfully !');
|
|
|
+ });
|
|
|
+ }
|
|
|
}
|
|
|
}
|