tango-app-ui-manage-users 3.4.0-alpha.20 → 3.4.0-alpha.22

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.
@@ -348,7 +348,7 @@ export class AddUserPopupComponent {
348
348
  "application/csv",
349
349
  ];
350
350
  if (!allowedExtensions.test(file.name) || !allowedTypes.includes(file.type)) {
351
- this.ts.getErrorToast("Only .xls, .xlsx, or .csv files are allowed.");
351
+ this.ts.getErrorToast("Only .xlsx, or .csv files are allowed.");
352
352
  this.inputFile.nativeElement.value = "";
353
353
  return;
354
354
  }
@@ -361,6 +361,7 @@ export class AddUserPopupComponent {
361
361
  const ws = wb.Sheets[wsname];
362
362
  if (wb.SheetNames[0] != "Users") {
363
363
  this.ts.getErrorToast('Please Upload the Valid File');
364
+ this.inputFile.nativeElement.value = "";
364
365
  return;
365
366
  }
366
367
  data = utils.sheet_to_json(ws);
@@ -370,6 +371,7 @@ export class AddUserPopupComponent {
370
371
  let processedArray = [];
371
372
  let errMsgs = [];
372
373
  for (let i = 0; i < data.length; i++) {
374
+ this.inputFile.nativeElement.value = "";
373
375
  errMsgs.push(this.validateField(data[i].UserName, "User name", i));
374
376
  errMsgs.push(this.validateField(data[i].Email, "Email", i, this.emailRegex));
375
377
  if (this.hasInvalidChars(data[i].UserName)) {
@@ -423,8 +425,8 @@ export class AddUserPopupComponent {
423
425
  }
424
426
  },
425
427
  error: (error) => {
426
- console.log(error);
427
428
  if (error) {
429
+ this.inputFile.nativeElement.value = "";
428
430
  this.ts.getErrorToast(error.error.error ? error.error.error : 'Unable to create multiple Users!');
429
431
  // } else {
430
432
  // this.ts.getErrorToast('Unable to create multiple Users!');
@@ -434,6 +436,10 @@ export class AddUserPopupComponent {
434
436
  };
435
437
  $("#kt_create_account_form_account_type_personal").val("");
436
438
  }
439
+ else {
440
+ this.ts.getErrorToast("Please Upload a Valid File");
441
+ this.inputFile.nativeElement.value = "";
442
+ }
437
443
  }
438
444
  validateField(value, fieldName, row, regex) {
439
445
  if (typeof value !== "string" && typeof value !== "number") {
@@ -515,4 +521,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
515
521
  type: ViewChild,
516
522
  args: ["inputFile"]
517
523
  }] } });
518
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-user-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-manage-users/src/lib/components/tango-manage-users/add-user-popup/add-user-popup.component.ts","../../../../../../../projects/tango-manage-users/src/lib/components/tango-manage-users/add-user-popup/add-user-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport { FormArray, FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { NgbActiveModal, NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport Swal from \"sweetalert2\";\r\nimport { UserService } from \"../../../services/user.service\";\r\nimport { WorkBook, read, utils, WorkSheet } from \"xlsx\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\"\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { AddUsersComponent } from \"../../../components-v2/add-users/add-users.component\";\r\n\r\ndeclare var $: any;\r\n\r\n@Component({\r\n  selector: \"lib-add-user-popup\",\r\n  templateUrl: \"./add-user-popup.component.html\",\r\n  styleUrl: \"./add-user-popup.component.scss\",\r\n})\r\nexport class AddUserPopupComponent implements OnInit, OnDestroy {\r\n  @Input() type: string;\r\n  @Input() user: any;\r\n  @Input() userType: any;\r\n  @Output() dataTosingleuser: EventEmitter<string> = new EventEmitter<string>();\r\n  @ViewChild(\"inputFile\") inputFile: ElementRef;\r\n  permissionArray = [\r\n    {\r\n      featureName: \"Global\",\r\n      modules: [\r\n        { name: \"Store\", isAdd: false, isEdit: false },\r\n        { name: \"User\", isAdd: false, isEdit: false },\r\n        { name: \"Camera\", isAdd: false, isEdit: false },\r\n        { name: \"Configuration\", isAdd: false, isEdit: false },\r\n        { name: \"Subscription\", isAdd: false, isEdit: false },\r\n        { name: \"Billing\", isAdd: false, isEdit: false },\r\n      ]\r\n    },\r\n    {\r\n      featureName: \"TangoEye\",\r\n      modules: [\r\n\r\n        { name: \"ZoneTag\", isAdd: false, isEdit: false },\r\n      ]\r\n    },\r\n    {\r\n      featureName: \"TangoTrax\",\r\n      modules: [\r\n        { name: \"checklist\", isAdd: false, isEdit: false },\r\n        { name: \"Task\", isAdd: false, isEdit: false },\r\n      ]\r\n    },\r\n\r\n  ];\r\n  userForm: FormGroup;\r\n  operationType: string;\r\n  expandedItems: string[] = [];\r\n  showsingleuser: boolean = false;\r\n  phoneRegex: RegExp = /^(\\d{3})?\\d{15}$/;\r\n  emailRegex: RegExp = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/;\r\n  userData: string;\r\n  isExpanded: boolean[] = [];\r\n  $headerFilters: any;\r\n  private readonly destroy$ = new Subject();\r\n  user_data: any;\r\n  handleAddChange(product: FormGroup | any): void {\r\n    if (!product.get(\"isAdd\")?.value) {\r\n      product.get(\"isDelete\")?.setValue(false);\r\n      product.get(\"isEdit\")?.setValue(false);\r\n    }\r\n  }\r\n  handleEditChange(product: FormGroup | any): void {\r\n    if (!product.get(\"isEdit\")?.value) {\r\n      // product.get('isDownload')?.setValue(false);\r\n      product.get(\"isDelete\")?.setValue(false);\r\n    }\r\n  }\r\n  constructor(\r\n    public activeModal: NgbActiveModal,\r\n    private cd: ChangeDetectorRef, public modalService: NgbModal,\r\n    private fb: FormBuilder,\r\n    private userService: UserService,\r\n    private ts: ToastService,\r\n    public gs: GlobalStateService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    let data: any = JSON.parse(localStorage.getItem('header-filters') || '');\r\n    this.user_data = JSON.parse(localStorage.getItem('user-info') || '');\r\n    this.$headerFilters = data ? data : this.user_data;\r\n    this.operationType = this.type;\r\n    this.userService.dataSubject.subscribe({\r\n      next: (data: any) => {\r\n        if (data) {\r\n          this.userData = data;\r\n          // this.userType = data == \"Tango User\" ? \"tango\" : \"client\";\r\n        }\r\n      },\r\n    });\r\n    if (this.type === \"view\" || (this.type === \"edit\" && this.user.email)) {\r\n      this.addSingleUser();\r\n      this.loadUserForm();\r\n    } else {\r\n      this.initUserForm();\r\n      this.showsingleuser = false;\r\n    }\r\n    if (this.userType === 'tango') {\r\n      this.permissionArray.push({\r\n        featureName: \"TangoAdmin\",\r\n        modules: [\r\n          {\r\n            name: \"invoiceApproval\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n          {\r\n            name: \"EditBilling\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n          {\r\n            name: \"TicketConfiguration\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n          {\r\n            name: \"Reports\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n        ]\r\n      },)\r\n    }\r\n  }\r\n\r\n  initUserForm() {\r\n    this.userForm = this.fb.group({\r\n      userName: [\"\", Validators.required],\r\n      email: [\"\", Validators.compose([Validators.required,\r\n      Validators.pattern(\"^[a-zA-Z0-9]+([.-_]?[a-zA-Z0-9]+)*@[a-zA-Z0-9]+([.-_]?[a-zA-Z]+)*[.]{1}[a-zA-Z]{2,}$\"),\r\n      ])],\r\n      mobileNumber: [\"\", [Validators.required, Validators.minLength(7), Validators.maxLength(13)]],\r\n      role: [\"user\", Validators.required],\r\n      userType: [this.userType],\r\n      tangoUserType: [\"dashboard\", Validators.required],\r\n      permission: this.fb.array([], Validators.required),\r\n    });\r\n    this.getUserPermissionData(\"user\", this.userType);\r\n  }\r\n  maskEmail(value: string): string {\r\n    if (!value || !value.includes('@')) return '';\r\n    const [local, domain] = value.split('@');\r\n    const visibleLength = Math.min(5, local.length);\r\n    const visiblePart = local.slice(0, visibleLength);\r\n    const maskedPart = '*'.repeat(local.length - visibleLength);\r\n    return `${visiblePart}${maskedPart}@${domain}`;\r\n  }\r\n  \r\n  maskMobile(value: string): string {\r\n    if (!value || value.length <= 4) return '*'.repeat(value.length);\r\n    const first2 = value.slice(0, 2);\r\n    const last2 = value.slice(-2);\r\n    const maskedMiddle = '*'.repeat(value.length - 4);\r\n    return `${first2}${maskedMiddle}${last2}`;\r\n  }\r\n  \r\n  loadUserForm() {\r\n    this.userService.getUser(this.user.email).pipe(takeUntil(this.destroy$)).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200 && res.data.result) {\r\n          const userData = res.data.result;\r\n          const isViewMode = this.operationType === 'view';\r\n          const isSuperadmin = userData.role === 'superadmin';\r\n  \r\n          const email = (isViewMode && !isSuperadmin) ? this.maskEmail(userData.email) : userData.email;\r\n          const mobile = (isViewMode && !isSuperadmin) ? this.maskMobile(userData.mobileNumber) : userData.mobileNumber;\r\n  \r\n          this.userForm = this.fb.group({\r\n            userName: [userData.userName, Validators.required],\r\n            email: [email, Validators.compose([\r\n              Validators.required,\r\n              Validators.pattern(\"^[a-zA-Z0-9]+([.-_]?[a-zA-Z0-9]+)*@[a-zA-Z0-9]+([.-_]?[a-zA-Z]+)*[.]{1}[a-zA-Z]{2,}$\"),\r\n            ])],\r\n            mobileNumber: [mobile, [Validators.required, Validators.minLength(7), Validators.maxLength(13)]],\r\n            role: [userData.role, Validators.required],\r\n            userType: [userData.userType, Validators.required],\r\n            tangoUserType: [userData.tangoUserType, Validators.required],\r\n            permission: this.fb.array([], Validators.required),\r\n          });\r\n  \r\n          this.populatePermission(userData.permission);\r\n  \r\n          if (isViewMode) {\r\n            this.userForm.disable(); // disable entire form\r\n          }\r\n  \r\n          this.userForm.get(\"email\")?.disable(); // email is always disabled\r\n  \r\n          this.cd.detectChanges();\r\n        } else {\r\n          this.initUserForm();\r\n        }\r\n      },\r\n      error: () => {\r\n        this.initUserForm();\r\n      },\r\n      complete: () => {},\r\n    });\r\n  }\r\n  \r\n\r\n  // toggleCollapse(id: string): void {\r\n  //   if (this.isExpanded(id)) {\r\n  //     this.expandedItems = this.expandedItems.filter((item) => item !== id);\r\n  //   } else {\r\n  //     this.expandedItems.push(id);\r\n  //   }\r\n  // }\r\n\r\n  toggleCollapse(index: number): void {\r\n    this.isExpanded[index] = !this.isExpanded[index];\r\n  }\r\n\r\n  // isExpanded(id: string): boolean {\r\n  //   return this.expandedItems.includes(id);\r\n  // }\r\n\r\n  // getArrowIcon(id: string): string {\r\n  //   return this.isExpanded(id) ? \"fa-chevron-up\" : \"fa-chevron-down\";\r\n  // }\r\n\r\n  addSingleUser() {\r\n    // this.activeModal.close(\"\");\r\n    let obj = {\r\n      type: 'add'\r\n    }\r\n\r\n    const modalRef = this.modalService.open(AddUsersComponent, { centered: true, size: 'lg', backdrop: 'static' });\r\n    modalRef.componentInstance.data = obj;\r\n    modalRef.componentInstance.userType = this.userType\r\n    modalRef.result.then((result) => {\r\n      this.activeModal.close('submit');\r\n    })\r\n    const data = \"single user\";\r\n    this.dataTosingleuser.emit(data);\r\n    // this.showsingleuser = true;\r\n  }\r\n\r\n  addUserSubmit() {\r\n    this.userService.createUser({ ...this.userForm.value, ...{ clientId: this.$headerFilters.client ? this.$headerFilters.client : this.user_data.clientId } }).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code == 200) {\r\n          this.ts.getSuccessToast(\"User created successfully.\");\r\n          this.activeModal.close('submit');\r\n          this.gs.manageRefreshTrigger.next(true)\r\n        } else {\r\n          this.ts.getErrorToast(\"Unable to create User!\");\r\n          this.activeModal.close();\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        console.log(err)\r\n        this.ts.getErrorToast(err?.error?.error ? err?.error?.error : \"Unable to create User!\");\r\n        this.activeModal.close();\r\n      },\r\n      complete: () => { },\r\n    });\r\n  }\r\n\r\n  cancel() {\r\n    this.activeModal.close('submit');\r\n  }\r\n\r\n  editUser() {\r\n    if (this.user.isActive) {\r\n      this.operationType = \"edit\";\r\n      this.userForm.enable();\r\n      this.userForm.get(\"email\")?.disable();\r\n    }\r\n  }\r\n\r\n  populatePermission(permissionsData: any[]) {\r\n    const permissions = this.userForm.get(\"permission\") as FormArray;\r\n    permissions.clear();\r\n    permissionsData.forEach((permission: any) => {\r\n      const featureGroup = this.fb.group({\r\n        featureName: [permission?.featureName],\r\n        product: this.fb.array([]),\r\n      });\r\n\r\n      const products = featureGroup.get(\"product\") as FormArray;\r\n      permission.product.forEach((product: any) => {\r\n        const productGroup = this.fb.group({\r\n          name: [product.name],\r\n          isView: [product.isView],\r\n          isEdit: [product.isEdit],\r\n          // isDownload: [product.isDownload],\r\n          // isDelete: [product.isDelete],\r\n        });\r\n        products.push(productGroup);\r\n      });\r\n\r\n      permissions.push(featureGroup);\r\n    });\r\n    for (let i = 0; i < this.getPermissions().length; i++) {\r\n      this.isExpanded.push(true);\r\n    }\r\n  }\r\n\r\n  getProducts(featureName: string): FormArray {\r\n    return this.userForm\r\n      .get(\"permission\")\r\n      ?.value.find((permission: any) => permission.featureName === featureName)\r\n      .product;\r\n  }\r\n\r\n  getUserPermissionData(roleName: string, userType: string) {\r\n    (this.userForm.get(\"permission\") as FormArray).clear();\r\n    this.cd.detectChanges();\r\n    this.userService\r\n      .getPersmissions({\r\n        roleName: roleName,\r\n        userType: userType,\r\n      })\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res) {\r\n            if (res.code == 200) {\r\n              this.populatePermission(res.data.result[0]?.permission);\r\n            } else {\r\n              (this.userForm.get(\"permission\") as FormArray).clear();\r\n            }\r\n          } else {\r\n            (this.userForm.get(\"permission\") as FormArray).clear();\r\n          }\r\n        },\r\n        error: (error: any) => {\r\n          (this.userForm.get(\"permission\") as FormArray).clear();\r\n        },\r\n        complete: () => { },\r\n      });\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  omit_special_char(event: any) {\r\n    var k;\r\n    k = event.charCode; //         k = event.keyCode;  (Both can be used)\r\n    return k == 8 || k == 32 || (k >= 48 && k <= 57);\r\n  }\r\n\r\n  getPermissions(): FormArray {\r\n    return this.userForm.get(\"permission\") as FormArray;\r\n  }\r\n\r\n  getFeaturePermissions(permission: FormGroup | any): FormArray {\r\n    return permission.get(\"product\") as FormArray;\r\n  }\r\nhasInvalidChars(value: string): boolean {\r\n  const regex = /^[a-zA-Z0-9 _-]*$/;\r\n  return !regex.test(value);\r\n}\r\n  onUpload(e: any) {\r\n    let data: any[];\r\n    const target: DataTransfer = <DataTransfer>e.target;\r\n    if (target.files.length > 1) {\r\n      this.inputFile.nativeElement.value = \"\";\r\n    }\r\n      const file: File = e.target.files[0];\r\n  const allowedExtensions = /\\.(xls|xlsx|csv)$/i;\r\n  const allowedTypes = [\r\n    \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\", \r\n    \"application/vnd.ms-excel\",                                          \r\n    \"text/csv\",                                                         \r\n    \"application/csv\",                                                   \r\n  ];\r\n\r\n  if (!allowedExtensions.test(file.name) || !allowedTypes.includes(file.type)) {\r\n    this.ts.getErrorToast(\"Only .xls, .xlsx, or .csv files are allowed.\");\r\n    this.inputFile.nativeElement.value = \"\";\r\n    return;\r\n  }\r\n    if (!!target.files[0].name.match(/(.xls|.xlsx)/)) {\r\n      const reader: FileReader = new FileReader();\r\n      reader.onload = (e: any) => {\r\n        const bstr: string = e.target.result;\r\n        const wb: WorkBook = read(bstr, { type: \"binary\" });\r\n        const wsname: string = wb.SheetNames[0];\r\n        const ws: WorkSheet = wb.Sheets[wsname];\r\n        if (wb.SheetNames[0] != \"Users\") {\r\n          this.ts.getErrorToast('Please Upload the Valid File');\r\n          return;\r\n        }\r\n        data = utils.sheet_to_json(ws);\r\n      };\r\n\r\n      reader.readAsBinaryString(target.files[0]);\r\n\r\n      reader.onloadend = async (e) => {\r\n        let processedArray: any[] = [];\r\n        let errMsgs: any[] = [];\r\n        for (let i = 0; i < data.length; i++) {\r\n          errMsgs.push(this.validateField(data[i].UserName, \"User name\", i));\r\n          errMsgs.push(\r\n            this.validateField(data[i].Email, \"Email\", i, this.emailRegex)\r\n          );\r\n                       if (this.hasInvalidChars(data[i].UserName)) {\r\n      errMsgs.push(`Row ${i + 1}: UserName : ${data[i].UserName} has invalid characters.`);\r\n    }\r\n          errMsgs.push(\r\n            this.validateField(\r\n              data[i].Contact,\r\n              \"Contact\",\r\n              i,\r\n              this.phoneRegex\r\n            )\r\n          );\r\n          // errMsgs.push(this.validateField(data[i].Role, \"Role\", i));\r\n        }\r\n\r\n        errMsgs = errMsgs.filter((x) => x != null);\r\n        if (errMsgs.length > 0) {\r\n          let errors = errMsgs.join(\"<br>\");\r\n          Swal.fire({\r\n            icon: \"error\",\r\n            html: errors,\r\n            customClass: {\r\n              htmlContainer: \"error-htmlcontainer-class\",\r\n            },\r\n            heightAuto: false,\r\n            showCancelButton: false,\r\n            showConfirmButton: true,\r\n            confirmButtonColor: \"#009EF7\",\r\n            confirmButtonText: \"OK\",\r\n          }).then((result) => { });\r\n          return;\r\n        }\r\n\r\n        console.log('data', data)\r\n\r\n        for (let i = 0; i < data.length; i++) {\r\n          processedArray.push({\r\n            userName: data[i].UserName,\r\n            email: data[i].Email,\r\n            mobileNumber: data[i].Contact.toString(),\r\n            tangoUserType: data[i].UserType,\r\n            role: 'user',\r\n            rolespermission: this.permissionArray\r\n          });\r\n        }\r\n\r\n        if (processedArray.length == 0) {\r\n          return this.ts.getErrorToast(\"No user entered in CSV\")\r\n        }\r\n\r\n\r\n        this.userService\r\n          .createBulkUpload(\r\n            {\r\n              users: processedArray,\r\n              userType: this.userType,\r\n              ...(this.userType == 'client') ? { clientId: this.$headerFilters.client } : {}\r\n            }\r\n          )\r\n          .subscribe({\r\n            next: (res: any) => {\r\n              if (res.code == 200) {\r\n                this.activeModal.close('submit');\r\n                this.ts.getSuccessToast('Users have been uploaded Successfully!');\r\n              }\r\n            },\r\n            error: (error: any) => {\r\n              console.log(error)\r\n              if (error) {\r\n                this.ts.getErrorToast(error.error.error ? error.error.error : 'Unable to create multiple Users!');\r\n                // } else {\r\n                //   this.ts.getErrorToast('Unable to create multiple Users!');\r\n              }\r\n            },\r\n          });\r\n      };\r\n      $(\"#kt_create_account_form_account_type_personal\").val(\"\");\r\n    }\r\n  }\r\n\r\n  validateField(\r\n    value: string | undefined | null | number,\r\n    fieldName: string,\r\n    row: number,\r\n    regex?: RegExp\r\n  ): string | null {\r\n    if (typeof value !== \"string\" && typeof value !== \"number\") {\r\n      return `Invalid value for ${fieldName.toLowerCase()} in row ${row + 1}`;\r\n    }\r\n    const defaultValue = `please enter the ${fieldName\r\n      .toLowerCase()\r\n      .replace(/\\b\\w/g, (l) => l.toUpperCase())}`;\r\n    if (!value) {\r\n      return `Please enter ${fieldName.toLowerCase()} in row ${row + 1}`;\r\n    }\r\n    if (typeof value == \"string\") {\r\n      if (value.trim() === defaultValue.trim()) {\r\n        return `Invalid value for ${fieldName.toLowerCase()} in row ${row + 1}`;\r\n      }\r\n      if (regex && !regex.test(value.trim())) {\r\n        return `Please enter valid ${fieldName.toLowerCase()} in row ${row + 1\r\n          }`;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  onRoleChange(role: string) {\r\n    this.getUserPermissionData(role, this.userType);\r\n  }\r\n\r\n  userUpdate() {\r\n    this.userForm.get(\"email\")?.enable();\r\n    let user: any = this.userForm.value;\r\n    this.userForm.get(\"email\")?.disable();\r\n    this.userService.updateUser(user).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code == 200) {\r\n          this.ts.getSuccessToast(\r\n            \"User details updated successfully.\"\r\n          );\r\n          this.activeModal.close('submit');\r\n        } else {\r\n          this.ts.getErrorToast(\"Unable to update User!\");\r\n          this.activeModal.close();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        this.ts.getErrorToast(err?.error?.error ? err?.error?.error : \"Unable to update User!\");\r\n        this.activeModal.close();\r\n      },\r\n      complete: () => { },\r\n    });\r\n  }\r\n\r\n  onSubmit() {\r\n    if (this.operationType == \"edit\") {\r\n      this.userUpdate();\r\n    } else {\r\n      this.addUserSubmit();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  camelCaseToText(input: string): string {\r\n    return input.replace(/([A-Z])/g, ' $1')\r\n      .replace(/^./, (str) => str.toUpperCase())\r\n      .trim();\r\n  }\r\n}\r\n","<div class=\"card py-0 scroll\">\r\n    <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n        <div class=\"my-5\">\r\n            <!-- <div class=\"symbol symbol-75px symbol-circle\">\r\n                <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n            </div> -->\r\n        </div>\r\n        <div class=\"row w-100\">\r\n            <div *ngIf=\"operationType==='add'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add\r\n                    User</a>\r\n                <div class=\"sub-title\">Please add your user details</div>\r\n            </div>\r\n            <!-- <div *ngIf=\"operationType==='edit'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Edit User Details</a>\r\n                <div class=\"sub-title\">Please Edit your user details</div>\r\n            </div> -->\r\n            <div *ngIf=\"operationType==='view'\" class=\"col-md-9\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">User Details</a>\r\n                <div class=\"sub-title\">View your user details</div>\r\n            </div>\r\n            <!-- @if ((gs.userAccess | async)?.Global_User_isEdit) { -->\r\n            <div *ngIf=\"operationType==='view' && (gs.userAccess | async)?.Global_User_isEdit\"\r\n                class=\"col-md-3 text-end px-0\" (click)=\"editUser()\">\r\n                <button class=\"btn btn-outline\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                        viewBox=\"0 0 20 20\" fill=\"none\">\r\n                        <g clip-path=\"url(#clip0_3833_85908)\">\r\n                            <path\r\n                                d=\"M9.16602 3.3332H3.33268C2.89065 3.3332 2.46673 3.50879 2.15417 3.82135C1.84161 4.13391 1.66602 4.55784 1.66602 4.99986V16.6665C1.66602 17.1086 1.84161 17.5325 2.15417 17.845C2.46673 18.1576 2.89065 18.3332 3.33268 18.3332H14.9993C15.4414 18.3332 15.8653 18.1576 16.1779 17.845C16.4904 17.5325 16.666 17.1086 16.666 16.6665V10.8332M15.416 2.0832C15.7475 1.75168 16.1972 1.56543 16.666 1.56543C17.1349 1.56543 17.5845 1.75168 17.916 2.0832C18.2475 2.41472 18.4338 2.86436 18.4338 3.3332C18.4338 3.80204 18.2475 4.25168 17.916 4.5832L9.99935 12.4999L6.66602 13.3332L7.49935 9.99986L15.416 2.0832Z\"\r\n                                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                        </g>\r\n                        <defs>\r\n                            <clipPath id=\"clip0_3833_85908\">\r\n                                <rect width=\"20\" height=\"20\" fill=\"white\" />\r\n                            </clipPath>\r\n                        </defs>\r\n                    </svg></button>\r\n            </div>\r\n            <!-- } -->\r\n        </div>\r\n        <div class=\"fw-bold text-gray-500 my-6\" *ngIf=\"!showsingleuser && this.operationType ==='add'\">\r\n            <ul class=\"text-gray-400 fw-bold fs-6\">\r\n                <li>Use the template to upload multiple users at once.</li>\r\n                <li>Download the template here -\r\n                    <a [attr.href]=\"userType ==='tango' ? '../../../assets/files/TangoUsersTemplate.xlsx' : '../../../assets/files/UsersTemplate.xlsx'\"\r\n                        download>\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                            <path\r\n                                d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M5.83333 8.33333L10 12.5M10 12.5L14.1667 8.33333M10 12.5V2.5\"\r\n                                stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        <span class=\"template ms-2\">Download Template</span>\r\n                    </a>\r\n                </li>\r\n                <li>Add your data to the Template File</li>\r\n                <li>Upload it below for processing</li>\r\n\r\n            </ul>\r\n        </div>\r\n        <div class=\"d-flex flex-center flex-wrap mb-5 w-100\" *ngIf=\"!showsingleuser && this.operationType ==='add'\">\r\n            <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\" accept = \".csv, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel\"\r\n                (change)=\"onUpload($event)\" value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n                ng-reflect-form-control-name=\"accountType\" ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n            <label for=\"kt_create_account_form_account_type_personal\"\r\n                class=\"btn btn-outline  bg-primary btn-outline-default rounded-3 w-100 p-4 mt-5\"><span\r\n                    class=\"fw-bold fs-4\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\"\r\n                        viewBox=\"0 0 21 20\" fill=\"none\">\r\n                        <path\r\n                            d=\"M18 12.5V15.8333C18 16.2754 17.8244 16.6993 17.5118 17.0118C17.1993 17.3244 16.7754 17.5 16.3333 17.5H4.66667C4.22464 17.5 3.80072 17.3244 3.48816 17.0118C3.17559 16.6993 3 16.2754 3 15.8333V12.5M14.6667 6.66667L10.5 2.5M10.5 2.5L6.33333 6.66667M10.5 2.5V12.5\"\r\n                            stroke=\"white\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </svg> <span class=\"text-white mx-2 single-user\">Add Multiple Users</span></span>\r\n            </label>\r\n            <p class=\"text-gray-400 fw-bold my-3\">\r\n                <span class=\"mx-2 orval\">Or </span>\r\n            </p>\r\n            <input type=\"radio\" id=\"kt_account_team_size_select_1\" value=\"1-1\" (click)=\"addSingleUser()\"\r\n                class=\"btn-check ng-untouched ng-pristine ng-valid\" />\r\n            <label for=\"kt_account_team_size_select_1\"\r\n                class=\"btn btn-outline btn-outline-default rounded-3 w-100 p-4 mt-3\"><span class=\"fw-bold fs-4\"><svg\r\n                        xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n                        <path\r\n                            d=\"M17.1663 17.5V15.8333C17.1663 14.9493 16.8152 14.1014 16.19 13.4763C15.5649 12.8512 14.7171 12.5 13.833 12.5H7.16634C6.28229 12.5 5.43444 12.8512 4.80932 13.4763C4.1842 14.1014 3.83301 14.9493 3.83301 15.8333V17.5M13.833 5.83333C13.833 7.67428 12.3406 9.16667 10.4997 9.16667C8.65873 9.16667 7.16634 7.67428 7.16634 5.83333C7.16634 3.99238 8.65873 2.5 10.4997 2.5C12.3406 2.5 13.833 3.99238 13.833 5.83333Z\"\r\n                            stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </svg><span id=\"triggerButtonId\" class=\"mx-2 single-user fw-bold\">Add Single\r\n                        User</span></span></label>\r\n        </div>\r\n\r\n        <div class=\"w-100 h-500px scroll\" *ngIf=\"showsingleuser\">\r\n            <div class=\"mt-5\" *ngIf=\"userForm\">\r\n                <form [formGroup]=\"userForm\" novalidate=\"novalidate\" class=\"\">\r\n                    <div class=\"row px-0 me-3\">\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"username\" class=\"form-label\">User Name</label>\r\n                            <input type=\"text\" class=\"form-control\" id=\"username\" formControlName=\"userName\"\r\n                                autocomplete=\"off\">\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"email\" class=\"form-label\">Email</label>\r\n                            <input type=\"email\" class=\"form-control\" id=\"email\" formControlName=\"email\"\r\n                                autocomplete=\"off\" required>\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"contact\" class=\"form-label\">Contact Number</label>\r\n                            <input type=\"text\" class=\"form-control\" id=\"contact\" formControlName=\"mobileNumber\"\r\n                                autocomplete=\"off\" required minlength=\"10\" maxlength=\"13\"\r\n                                (keypress)=\"omit_special_char($event)\">\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"role\" class=\"form-label\">Role</label>\r\n                            <select class=\"form-select\" formControlName=\"role\"\r\n                                (change)=\"onRoleChange(userForm.get('role')?.value)\">\r\n                                <option value=\"superadmin\">Super Admin</option>\r\n                                <option value=\"admin\">Admin</option>\r\n                                <option value=\"user\">User</option>\r\n                            </select>\r\n                        </div>\r\n                        <div *ngIf=\"userType === 'tango'\" class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"tangoUserType\" class=\"form-label\">User Type</label>\r\n                            <select class=\"form-select\" formControlName=\"tangoUserType\"\r\n                                (change)=\"onRoleChange(userForm.get('tangoUserType')?.value)\">\r\n                                <option value=\"dashboard\">Dashboard</option>\r\n                                <option value=\"audit\">Audit</option>\r\n                            </select>\r\n                        </div>\r\n                    </div>\r\n                    <a class=\"fs-4 text-gray-800 text-hover-primary fw-bolder mb-0 title cursor-pointer\">Access for\r\n                        {{userForm.get('role')?.value | titlecase}}</a>\r\n                    <div class=\"sub-title font-sub\">{{userForm.get('role')?.value | titlecase}} can access respective\r\n                        enabled features and products</div>\r\n                    <ng-container *ngIf=\"getPermissions().length\">\r\n                        <ng-container formArrayName=\"permission\">\r\n                            <ng-container *ngFor=\"let permission of getPermissions().controls; let i = index\"\r\n                                [formGroupName]=\"i\">\r\n                                <div class=\"my-6\">\r\n                                    <div class=\"row me-3\">\r\n                                        <div class=\"col-6\">\r\n                                            <div class=\"title fw-semibold\">\r\n                                                {{ permission.get('featureName')?.value | titlecase }}\r\n\r\n                                            </div>\r\n                                        </div>\r\n                                        <div class=\"col-6 d-flex justify-content-end\" (click)=\"toggleCollapse(i)\">\r\n                                            <div class=\"text-end\">\r\n                                                @if (!isExpanded[i]) {\r\n                                                <svg width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" fill=\"none\"\r\n                                                    xmlns=\"http://www.w3.org/2000/svg\">\r\n                                                    <path d=\"M1.5 1.5L6.5 6.5L11.5 1.5\" stroke=\"#667085\"\r\n                                                        stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n                                                } @else {\r\n                                                <svg width=\"12\" height=\"8\" viewBox=\"0 0 12 8\" fill=\"none\"\r\n                                                    xmlns=\"http://www.w3.org/2000/svg\">\r\n                                                    <path d=\"M11 6.5L6 1.5L1 6.5\" stroke=\"#667085\" stroke-width=\"1.67\"\r\n                                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n\r\n                                                }\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div [ngClass]=\"{ 'collapsed': !isExpanded[i] }\">\r\n                                        <div class=\"table-responsive my-2 me-3\">\r\n                                            <table class=\"w-100\">\r\n                                                <thead>\r\n                                                    <tr>\r\n                                                        <th>Modules</th>\r\n                                                        <th>View</th>\r\n                                                        <th>Edit</th>\r\n                                                        <th>Download</th>\r\n                                                        <th>Delete</th>\r\n                                                    </tr>\r\n                                                </thead>\r\n                                                <tbody>\r\n                                                    <ng-container *ngIf=\"permission.get('product')\"\r\n                                                        formArrayName=\"product\">\r\n                                                        <ng-container\r\n                                                            *ngFor=\"let product of getFeaturePermissions(permission)?.controls;let j=index;\"\r\n                                                            [formGroupName]=\"j\">\r\n                                                            <tr>\r\n                                                                <td>{{ camelCaseToText(product.get('name')?.value) }}\r\n                                                                </td>\r\n                                                                <td><input formControlName=\"isView\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        (change)=\"handleAddChange(product)\"></td>\r\n                                                                <td><input formControlName=\"isEdit\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        (change)=\"handleEditChange(product)\"></td>\r\n                                                                <td><input formControlName=\"isDownload\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        [disabled]=\"!product.get('isEdit')?.value || !product.get('isView')?.value\">\r\n                                                                </td>\r\n                                                                <td><input formControlName=\"isDelete\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        [disabled]=\"!product.get('isEdit')?.value || !product.get('isView')?.value\">\r\n                                                                </td>\r\n                                                            </tr>\r\n                                                        </ng-container>\r\n                                                    </ng-container>\r\n                                                </tbody>\r\n                                            </table>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </ng-container>\r\n\r\n                    <div *ngIf=\"operationType!=='view'\" class=\"d-flex my-14\" role=\"group\">\r\n                        <button class=\"btn btn-outline w-100 mx-3\" (click)=\"cancel()\">Cancel</button>\r\n                        <button class=\"btn btn-primary w-100 mx-3\" [disabled]=\"userForm.invalid\" id=\"alert-toast\"\r\n                            (click)=\"onSubmit()\">Submit</button>\r\n                    </div>\r\n                </form>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>"]}
524
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-user-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-manage-users/src/lib/components/tango-manage-users/add-user-popup/add-user-popup.component.ts","../../../../../../../projects/tango-manage-users/src/lib/components/tango-manage-users/add-user-popup/add-user-popup.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAqC,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE/E,OAAO,IAAI,MAAM,aAAa,CAAC;AAE/B,OAAO,EAAY,IAAI,EAAE,KAAK,EAAa,MAAM,MAAM,CAAC;AAGxD,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sDAAsD,CAAC;;;;;;;;AASzF,MAAM,OAAO,qBAAqB;IA0DvB;IACC;IAA8B;IAC9B;IACA;IACA;IACD;IA9DA,IAAI,CAAS;IACb,IAAI,CAAM;IACV,QAAQ,CAAM;IACb,gBAAgB,GAAyB,IAAI,YAAY,EAAU,CAAC;IACtD,SAAS,CAAa;IAC9C,eAAe,GAAG;QAChB;YACE,WAAW,EAAE,QAAQ;YACrB,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;gBAC9C,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;gBAC7C,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;gBAC/C,EAAE,IAAI,EAAE,eAAe,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;gBACtD,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;gBACrD,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;aACjD;SACF;QACD;YACE,WAAW,EAAE,UAAU;YACvB,OAAO,EAAE;gBAEP,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;aACjD;SACF;QACD;YACE,WAAW,EAAE,WAAW;YACxB,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;gBAClD,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;aAC9C;SACF;KAEF,CAAC;IACF,QAAQ,CAAY;IACpB,aAAa,CAAS;IACtB,aAAa,GAAa,EAAE,CAAC;IAC7B,cAAc,GAAY,KAAK,CAAC;IAChC,UAAU,GAAW,kBAAkB,CAAC;IACxC,UAAU,GAAW,4BAA4B,CAAC;IAClD,QAAQ,CAAS;IACjB,UAAU,GAAc,EAAE,CAAC;IAC3B,cAAc,CAAM;IACH,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;IAC1C,SAAS,CAAM;IACf,eAAe,CAAC,OAAwB;QACtC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE;YAChC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;YACzC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxC;IACH,CAAC;IACD,gBAAgB,CAAC,OAAwB;QACvC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE;YACjC,8CAA8C;YAC9C,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;SAC1C;IACH,CAAC;IACD,YACS,WAA2B,EAC1B,EAAqB,EAAS,YAAsB,EACpD,EAAe,EACf,WAAwB,EACxB,EAAgB,EACjB,EAAsB;QALtB,gBAAW,GAAX,WAAW,CAAgB;QAC1B,OAAE,GAAF,EAAE,CAAmB;QAAS,iBAAY,GAAZ,YAAY,CAAU;QACpD,OAAE,GAAF,EAAE,CAAa;QACf,gBAAW,GAAX,WAAW,CAAa;QACxB,OAAE,GAAF,EAAE,CAAc;QACjB,OAAE,GAAF,EAAE,CAAoB;IAC3B,CAAC;IAEL,QAAQ;QACN,IAAI,IAAI,GAAQ,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;QACrE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;QACnD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,SAAS,CAAC;YACrC,IAAI,EAAE,CAAC,IAAS,EAAE,EAAE;gBAClB,IAAI,IAAI,EAAE;oBACR,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;oBACrB,6DAA6D;iBAC9D;YACH,CAAC;SACF,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACrE,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;SAC7B;QACD,IAAI,IAAI,CAAC,QAAQ,KAAK,OAAO,EAAE;YAC7B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBACxB,WAAW,EAAE,YAAY;gBACzB,OAAO,EAAE;oBACP;wBACE,IAAI,EAAE,iBAAiB,EAAE,KAAK,EAAE,KAAK;wBACrC,MAAM,EAAE,KAAK;qBACd;oBACD;wBACE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,KAAK;wBACjC,MAAM,EAAE,KAAK;qBACd;oBACD;wBACE,IAAI,EAAE,qBAAqB,EAAE,KAAK,EAAE,KAAK;wBACzC,MAAM,EAAE,KAAK;qBACd;oBACD;wBACE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK;wBAC7B,MAAM,EAAE,KAAK;qBACd;iBACF;aACF,CAAE,CAAA;SACJ;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC5B,QAAQ,EAAE,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;YACnC,KAAK,EAAE,CAAC,EAAE,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,QAAQ;oBACnD,UAAU,CAAC,OAAO,CAAC,sFAAsF,CAAC;iBACzG,CAAC,CAAC;YACH,YAAY,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5F,IAAI,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,QAAQ,CAAC;YACnC,QAAQ,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;YACzB,aAAa,EAAE,CAAC,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC;YACjD,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;SACnD,CAAC,CAAC;QACH,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;IACD,SAAS,CAAC,KAAa;QACrB,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC;YAAE,OAAO,EAAE,CAAC;QAC9C,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACzC,MAAM,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QAChD,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC;QAClD,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,aAAa,CAAC,CAAC;QAC5D,OAAO,GAAG,WAAW,GAAG,UAAU,IAAI,MAAM,EAAE,CAAC;IACjD,CAAC;IAED,UAAU,CAAC,KAAa;QACtB,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACjE,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACjC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAClD,OAAO,GAAG,MAAM,GAAG,YAAY,GAAG,KAAK,EAAE,CAAC;IAC5C,CAAC;IAED,YAAY;QACV,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;YACjF,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE;oBAC9C,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;oBACjC,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,KAAK,MAAM,CAAC;oBACjD,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,KAAK,YAAY,CAAC;oBAEpD,MAAM,KAAK,GAAG,CAAC,UAAU,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAC9F,MAAM,MAAM,GAAG,CAAC,UAAU,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC;oBAE9G,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;wBAC5B,QAAQ,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC;wBAClD,KAAK,EAAE,CAAC,KAAK,EAAE,UAAU,CAAC,OAAO,CAAC;gCAChC,UAAU,CAAC,QAAQ;gCACnB,UAAU,CAAC,OAAO,CAAC,sFAAsF,CAAC;6BAC3G,CAAC,CAAC;wBACH,YAAY,EAAE,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;wBAChG,IAAI,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;wBAC1C,QAAQ,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC;wBAClD,aAAa,EAAE,CAAC,QAAQ,CAAC,aAAa,EAAE,UAAU,CAAC,QAAQ,CAAC;wBAC5D,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;qBACnD,CAAC,CAAC;oBAEH,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;oBAE7C,IAAI,UAAU,EAAE;wBACd,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,sBAAsB;qBAChD;oBAED,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,2BAA2B;oBAElE,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;iBACzB;qBAAM;oBACL,IAAI,CAAC,YAAY,EAAE,CAAC;iBACrB;YACH,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;SACnB,CAAC,CAAC;IACL,CAAC;IAGD,qCAAqC;IACrC,+BAA+B;IAC/B,6EAA6E;IAC7E,aAAa;IACb,mCAAmC;IACnC,MAAM;IACN,IAAI;IAEJ,cAAc,CAAC,KAAa;QAC1B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAED,oCAAoC;IACpC,4CAA4C;IAC5C,IAAI;IAEJ,qCAAqC;IACrC,sEAAsE;IACtE,IAAI;IAEJ,aAAa;QACX,8BAA8B;QAC9B,IAAI,GAAG,GAAG;YACR,IAAI,EAAE,KAAK;SACZ,CAAA;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC/G,QAAQ,CAAC,iBAAiB,CAAC,IAAI,GAAG,GAAG,CAAC;QACtC,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;QACnD,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YAC9B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACnC,CAAC,CAAC,CAAA;QACF,MAAM,IAAI,GAAG,aAAa,CAAC;QAC3B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,8BAA8B;IAChC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC;YACpK,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,EAAE;oBAC1B,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,4BAA4B,CAAC,CAAC;oBACtD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;oBACjC,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;iBACxC;qBAAM;oBACL,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,wBAAwB,CAAC,CAAC;oBAChD,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;iBAC1B;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;gBAChB,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC;gBACxF,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YAC3B,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE,GAAG,CAAC;SACpB,CAAC,CAAC;IACL,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;YAC5B,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;SACvC;IACH,CAAC;IAED,kBAAkB,CAAC,eAAsB;QACvC,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAc,CAAC;QACjE,WAAW,CAAC,KAAK,EAAE,CAAC;QACpB,eAAe,CAAC,OAAO,CAAC,CAAC,UAAe,EAAE,EAAE;YAC1C,MAAM,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;gBACjC,WAAW,EAAE,CAAC,UAAU,EAAE,WAAW,CAAC;gBACtC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;aAC3B,CAAC,CAAC;YAEH,MAAM,QAAQ,GAAG,YAAY,CAAC,GAAG,CAAC,SAAS,CAAc,CAAC;YAC1D,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAY,EAAE,EAAE;gBAC1C,MAAM,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;oBACjC,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;oBACpB,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;oBACxB,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;oBACxB,oCAAoC;oBACpC,gCAAgC;iBACjC,CAAC,CAAC;gBACH,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC9B,CAAC,CAAC,CAAC;YAEH,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACrD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC5B;IACH,CAAC;IAED,WAAW,CAAC,WAAmB;QAC7B,OAAO,IAAI,CAAC,QAAQ;aACjB,GAAG,CAAC,YAAY,CAAC;YAClB,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,UAAe,EAAE,EAAE,CAAC,UAAU,CAAC,WAAW,KAAK,WAAW,CAAC;aACxE,OAAO,CAAC;IACb,CAAC;IAED,qBAAqB,CAAC,QAAgB,EAAE,QAAgB;QACrD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAe,CAAC,KAAK,EAAE,CAAC;QACvD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW;aACb,eAAe,CAAC;YACf,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,QAAQ;SACnB,CAAC;aACD,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,EAAE;oBACP,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,EAAE;wBACnB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;qBACzD;yBAAM;wBACJ,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAe,CAAC,KAAK,EAAE,CAAC;qBACxD;iBACF;qBAAM;oBACJ,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAe,CAAC,KAAK,EAAE,CAAC;iBACxD;YACH,CAAC;YACD,KAAK,EAAE,CAAC,KAAU,EAAE,EAAE;gBACnB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAe,CAAC,KAAK,EAAE,CAAC;YACzD,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE,GAAG,CAAC;SACpB,CAAC,CAAC;QACL,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IAED,iBAAiB,CAAC,KAAU;QAC1B,IAAI,CAAC,CAAC;QACN,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,iDAAiD;QACrE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAc,CAAC;IACtD,CAAC;IAED,qBAAqB,CAAC,UAA2B;QAC/C,OAAO,UAAU,CAAC,GAAG,CAAC,SAAS,CAAc,CAAC;IAChD,CAAC;IACH,eAAe,CAAC,KAAa;QAC3B,MAAM,KAAK,GAAG,mBAAmB,CAAC;QAClC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IACC,QAAQ,CAAC,CAAM;QACb,IAAI,IAAW,CAAC;QAChB,MAAM,MAAM,GAA+B,CAAC,CAAC,MAAM,CAAC;QACpD,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3B,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;SACzC;QACC,MAAM,IAAI,GAAS,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,iBAAiB,GAAG,oBAAoB,CAAC;QAC/C,MAAM,YAAY,GAAG;YACnB,mEAAmE;YACnE,0BAA0B;YAC1B,UAAU;YACV,iBAAiB;SAClB,CAAC;QAEF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YAC3E,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,wCAAwC,CAAC,CAAC;YAChE,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;YACxC,OAAO;SACR;QACC,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE;YAChD,MAAM,MAAM,GAAe,IAAI,UAAU,EAAE,CAAC;YAC5C,MAAM,CAAC,MAAM,GAAG,CAAC,CAAM,EAAE,EAAE;gBACzB,MAAM,IAAI,GAAW,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;gBACrC,MAAM,EAAE,GAAa,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;gBACpD,MAAM,MAAM,GAAW,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBACxC,MAAM,EAAE,GAAc,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACxC,IAAI,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,OAAO,EAAE;oBAC/B,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,8BAA8B,CAAC,CAAC;oBACnD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;oBAC3C,OAAO;iBACR;gBACD,IAAI,GAAG,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;YACjC,CAAC,CAAC;YAEF,MAAM,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAE3C,MAAM,CAAC,SAAS,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;gBAC7B,IAAI,cAAc,GAAU,EAAE,CAAC;gBAC/B,IAAI,OAAO,GAAU,EAAE,CAAC;gBACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACjC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;oBAC3C,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;oBACnE,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAC/D,CAAC;oBACW,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE;wBAC7D,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,0BAA0B,CAAC,CAAC;qBACtF;oBACK,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,aAAa,CAChB,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,EACf,SAAS,EACT,CAAC,EACD,IAAI,CAAC,UAAU,CAChB,CACF,CAAC;oBACF,6DAA6D;iBAC9D;gBAED,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC;gBAC3C,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;oBACtB,IAAI,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAClC,IAAI,CAAC,IAAI,CAAC;wBACR,IAAI,EAAE,OAAO;wBACb,IAAI,EAAE,MAAM;wBACZ,WAAW,EAAE;4BACX,aAAa,EAAE,2BAA2B;yBAC3C;wBACD,UAAU,EAAE,KAAK;wBACjB,gBAAgB,EAAE,KAAK;wBACvB,iBAAiB,EAAE,IAAI;wBACvB,kBAAkB,EAAE,SAAS;wBAC7B,iBAAiB,EAAE,IAAI;qBACxB,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC;oBACzB,OAAO;iBACR;gBAED,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;gBAEzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACpC,cAAc,CAAC,IAAI,CAAC;wBAClB,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ;wBAC1B,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK;wBACpB,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE;wBACxC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ;wBAC/B,IAAI,EAAE,MAAM;wBACZ,eAAe,EAAE,IAAI,CAAC,eAAe;qBACtC,CAAC,CAAC;iBACJ;gBAED,IAAI,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE;oBAC9B,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,wBAAwB,CAAC,CAAA;iBACvD;gBAGD,IAAI,CAAC,WAAW;qBACb,gBAAgB,CACf;oBACE,KAAK,EAAE,cAAc;oBACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE;iBAC/E,CACF;qBACA,SAAS,CAAC;oBACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;wBACjB,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,EAAE;4BACnB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;4BACjC,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,wCAAwC,CAAC,CAAC;yBACnE;oBACH,CAAC;oBACD,KAAK,EAAE,CAAC,KAAU,EAAE,EAAE;wBACpB,IAAI,KAAK,EAAE;4BACN,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;4BAC3C,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,kCAAkC,CAAC,CAAC;4BAClG,WAAW;4BACX,+DAA+D;yBAChE;oBACH,CAAC;iBACF,CAAC,CAAC;YACP,CAAC,CAAC;YACF,CAAC,CAAC,+CAA+C,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;SAC5D;aAAK;YACJ,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,4BAA4B,CAAC,CAAC;YACpD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;SACzC;IACH,CAAC;IAED,aAAa,CACX,KAAyC,EACzC,SAAiB,EACjB,GAAW,EACX,KAAc;QAEd,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC1D,OAAO,qBAAqB,SAAS,CAAC,WAAW,EAAE,WAAW,GAAG,GAAG,CAAC,EAAE,CAAC;SACzE;QACD,MAAM,YAAY,GAAG,oBAAoB,SAAS;aAC/C,WAAW,EAAE;aACb,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;QAC9C,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,gBAAgB,SAAS,CAAC,WAAW,EAAE,WAAW,GAAG,GAAG,CAAC,EAAE,CAAC;SACpE;QACD,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE;YAC5B,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,YAAY,CAAC,IAAI,EAAE,EAAE;gBACxC,OAAO,qBAAqB,SAAS,CAAC,WAAW,EAAE,WAAW,GAAG,GAAG,CAAC,EAAE,CAAC;aACzE;YACD,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,EAAE;gBACtC,OAAO,sBAAsB,SAAS,CAAC,WAAW,EAAE,WAAW,GAAG,GAAG,CACnE,EAAE,CAAC;aACN;SACF;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAClD,CAAC;IAED,UAAU;QACR,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;QACrC,IAAI,IAAI,GAAQ,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;QACtC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;YAC1C,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,IAAI,GAAG,EAAE;oBAC1B,IAAI,CAAC,EAAE,CAAC,eAAe,CACrB,oCAAoC,CACrC,CAAC;oBACF,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;iBAClC;qBAAM;oBACL,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,wBAAwB,CAAC,CAAC;oBAChD,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;iBAC1B;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC;gBACxF,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YAC3B,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE,GAAG,CAAC;SACpB,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,aAAa,IAAI,MAAM,EAAE;YAChC,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;aAAM;YACL,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,KAAa;QAC3B,OAAO,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC;aACpC,OAAO,CAAC,IAAI,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;aACzC,IAAI,EAAE,CAAC;IACZ,CAAC;wGAxhBU,qBAAqB;4FAArB,qBAAqB,mRC5BlC,2jiBA0NM;;4FD9LO,qBAAqB;kBALjC,SAAS;+BACE,oBAAoB;0PAKrB,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,gBAAgB;sBAAzB,MAAM;gBACiB,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport { FormArray, FormBuilder, FormGroup, Validators } from \"@angular/forms\";\r\nimport { NgbActiveModal, NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport Swal from \"sweetalert2\";\r\nimport { UserService } from \"../../../services/user.service\";\r\nimport { WorkBook, read, utils, WorkSheet } from \"xlsx\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\"\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { AddUsersComponent } from \"../../../components-v2/add-users/add-users.component\";\r\n\r\ndeclare var $: any;\r\n\r\n@Component({\r\n  selector: \"lib-add-user-popup\",\r\n  templateUrl: \"./add-user-popup.component.html\",\r\n  styleUrl: \"./add-user-popup.component.scss\",\r\n})\r\nexport class AddUserPopupComponent implements OnInit, OnDestroy {\r\n  @Input() type: string;\r\n  @Input() user: any;\r\n  @Input() userType: any;\r\n  @Output() dataTosingleuser: EventEmitter<string> = new EventEmitter<string>();\r\n  @ViewChild(\"inputFile\") inputFile: ElementRef;\r\n  permissionArray = [\r\n    {\r\n      featureName: \"Global\",\r\n      modules: [\r\n        { name: \"Store\", isAdd: false, isEdit: false },\r\n        { name: \"User\", isAdd: false, isEdit: false },\r\n        { name: \"Camera\", isAdd: false, isEdit: false },\r\n        { name: \"Configuration\", isAdd: false, isEdit: false },\r\n        { name: \"Subscription\", isAdd: false, isEdit: false },\r\n        { name: \"Billing\", isAdd: false, isEdit: false },\r\n      ]\r\n    },\r\n    {\r\n      featureName: \"TangoEye\",\r\n      modules: [\r\n\r\n        { name: \"ZoneTag\", isAdd: false, isEdit: false },\r\n      ]\r\n    },\r\n    {\r\n      featureName: \"TangoTrax\",\r\n      modules: [\r\n        { name: \"checklist\", isAdd: false, isEdit: false },\r\n        { name: \"Task\", isAdd: false, isEdit: false },\r\n      ]\r\n    },\r\n\r\n  ];\r\n  userForm: FormGroup;\r\n  operationType: string;\r\n  expandedItems: string[] = [];\r\n  showsingleuser: boolean = false;\r\n  phoneRegex: RegExp = /^(\\d{3})?\\d{15}$/;\r\n  emailRegex: RegExp = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/;\r\n  userData: string;\r\n  isExpanded: boolean[] = [];\r\n  $headerFilters: any;\r\n  private readonly destroy$ = new Subject();\r\n  user_data: any;\r\n  handleAddChange(product: FormGroup | any): void {\r\n    if (!product.get(\"isAdd\")?.value) {\r\n      product.get(\"isDelete\")?.setValue(false);\r\n      product.get(\"isEdit\")?.setValue(false);\r\n    }\r\n  }\r\n  handleEditChange(product: FormGroup | any): void {\r\n    if (!product.get(\"isEdit\")?.value) {\r\n      // product.get('isDownload')?.setValue(false);\r\n      product.get(\"isDelete\")?.setValue(false);\r\n    }\r\n  }\r\n  constructor(\r\n    public activeModal: NgbActiveModal,\r\n    private cd: ChangeDetectorRef, public modalService: NgbModal,\r\n    private fb: FormBuilder,\r\n    private userService: UserService,\r\n    private ts: ToastService,\r\n    public gs: GlobalStateService\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    let data: any = JSON.parse(localStorage.getItem('header-filters') || '');\r\n    this.user_data = JSON.parse(localStorage.getItem('user-info') || '');\r\n    this.$headerFilters = data ? data : this.user_data;\r\n    this.operationType = this.type;\r\n    this.userService.dataSubject.subscribe({\r\n      next: (data: any) => {\r\n        if (data) {\r\n          this.userData = data;\r\n          // this.userType = data == \"Tango User\" ? \"tango\" : \"client\";\r\n        }\r\n      },\r\n    });\r\n    if (this.type === \"view\" || (this.type === \"edit\" && this.user.email)) {\r\n      this.addSingleUser();\r\n      this.loadUserForm();\r\n    } else {\r\n      this.initUserForm();\r\n      this.showsingleuser = false;\r\n    }\r\n    if (this.userType === 'tango') {\r\n      this.permissionArray.push({\r\n        featureName: \"TangoAdmin\",\r\n        modules: [\r\n          {\r\n            name: \"invoiceApproval\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n          {\r\n            name: \"EditBilling\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n          {\r\n            name: \"TicketConfiguration\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n          {\r\n            name: \"Reports\", isAdd: false,\r\n            isEdit: false\r\n          },\r\n        ]\r\n      },)\r\n    }\r\n  }\r\n\r\n  initUserForm() {\r\n    this.userForm = this.fb.group({\r\n      userName: [\"\", Validators.required],\r\n      email: [\"\", Validators.compose([Validators.required,\r\n      Validators.pattern(\"^[a-zA-Z0-9]+([.-_]?[a-zA-Z0-9]+)*@[a-zA-Z0-9]+([.-_]?[a-zA-Z]+)*[.]{1}[a-zA-Z]{2,}$\"),\r\n      ])],\r\n      mobileNumber: [\"\", [Validators.required, Validators.minLength(7), Validators.maxLength(13)]],\r\n      role: [\"user\", Validators.required],\r\n      userType: [this.userType],\r\n      tangoUserType: [\"dashboard\", Validators.required],\r\n      permission: this.fb.array([], Validators.required),\r\n    });\r\n    this.getUserPermissionData(\"user\", this.userType);\r\n  }\r\n  maskEmail(value: string): string {\r\n    if (!value || !value.includes('@')) return '';\r\n    const [local, domain] = value.split('@');\r\n    const visibleLength = Math.min(5, local.length);\r\n    const visiblePart = local.slice(0, visibleLength);\r\n    const maskedPart = '*'.repeat(local.length - visibleLength);\r\n    return `${visiblePart}${maskedPart}@${domain}`;\r\n  }\r\n  \r\n  maskMobile(value: string): string {\r\n    if (!value || value.length <= 4) return '*'.repeat(value.length);\r\n    const first2 = value.slice(0, 2);\r\n    const last2 = value.slice(-2);\r\n    const maskedMiddle = '*'.repeat(value.length - 4);\r\n    return `${first2}${maskedMiddle}${last2}`;\r\n  }\r\n  \r\n  loadUserForm() {\r\n    this.userService.getUser(this.user.email).pipe(takeUntil(this.destroy$)).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200 && res.data.result) {\r\n          const userData = res.data.result;\r\n          const isViewMode = this.operationType === 'view';\r\n          const isSuperadmin = userData.role === 'superadmin';\r\n  \r\n          const email = (isViewMode && !isSuperadmin) ? this.maskEmail(userData.email) : userData.email;\r\n          const mobile = (isViewMode && !isSuperadmin) ? this.maskMobile(userData.mobileNumber) : userData.mobileNumber;\r\n  \r\n          this.userForm = this.fb.group({\r\n            userName: [userData.userName, Validators.required],\r\n            email: [email, Validators.compose([\r\n              Validators.required,\r\n              Validators.pattern(\"^[a-zA-Z0-9]+([.-_]?[a-zA-Z0-9]+)*@[a-zA-Z0-9]+([.-_]?[a-zA-Z]+)*[.]{1}[a-zA-Z]{2,}$\"),\r\n            ])],\r\n            mobileNumber: [mobile, [Validators.required, Validators.minLength(7), Validators.maxLength(13)]],\r\n            role: [userData.role, Validators.required],\r\n            userType: [userData.userType, Validators.required],\r\n            tangoUserType: [userData.tangoUserType, Validators.required],\r\n            permission: this.fb.array([], Validators.required),\r\n          });\r\n  \r\n          this.populatePermission(userData.permission);\r\n  \r\n          if (isViewMode) {\r\n            this.userForm.disable(); // disable entire form\r\n          }\r\n  \r\n          this.userForm.get(\"email\")?.disable(); // email is always disabled\r\n  \r\n          this.cd.detectChanges();\r\n        } else {\r\n          this.initUserForm();\r\n        }\r\n      },\r\n      error: () => {\r\n        this.initUserForm();\r\n      },\r\n      complete: () => {},\r\n    });\r\n  }\r\n  \r\n\r\n  // toggleCollapse(id: string): void {\r\n  //   if (this.isExpanded(id)) {\r\n  //     this.expandedItems = this.expandedItems.filter((item) => item !== id);\r\n  //   } else {\r\n  //     this.expandedItems.push(id);\r\n  //   }\r\n  // }\r\n\r\n  toggleCollapse(index: number): void {\r\n    this.isExpanded[index] = !this.isExpanded[index];\r\n  }\r\n\r\n  // isExpanded(id: string): boolean {\r\n  //   return this.expandedItems.includes(id);\r\n  // }\r\n\r\n  // getArrowIcon(id: string): string {\r\n  //   return this.isExpanded(id) ? \"fa-chevron-up\" : \"fa-chevron-down\";\r\n  // }\r\n\r\n  addSingleUser() {\r\n    // this.activeModal.close(\"\");\r\n    let obj = {\r\n      type: 'add'\r\n    }\r\n\r\n    const modalRef = this.modalService.open(AddUsersComponent, { centered: true, size: 'lg', backdrop: 'static' });\r\n    modalRef.componentInstance.data = obj;\r\n    modalRef.componentInstance.userType = this.userType\r\n    modalRef.result.then((result) => {\r\n      this.activeModal.close('submit');\r\n    })\r\n    const data = \"single user\";\r\n    this.dataTosingleuser.emit(data);\r\n    // this.showsingleuser = true;\r\n  }\r\n\r\n  addUserSubmit() {\r\n    this.userService.createUser({ ...this.userForm.value, ...{ clientId: this.$headerFilters.client ? this.$headerFilters.client : this.user_data.clientId } }).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code == 200) {\r\n          this.ts.getSuccessToast(\"User created successfully.\");\r\n          this.activeModal.close('submit');\r\n          this.gs.manageRefreshTrigger.next(true)\r\n        } else {\r\n          this.ts.getErrorToast(\"Unable to create User!\");\r\n          this.activeModal.close();\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        console.log(err)\r\n        this.ts.getErrorToast(err?.error?.error ? err?.error?.error : \"Unable to create User!\");\r\n        this.activeModal.close();\r\n      },\r\n      complete: () => { },\r\n    });\r\n  }\r\n\r\n  cancel() {\r\n    this.activeModal.close('submit');\r\n  }\r\n\r\n  editUser() {\r\n    if (this.user.isActive) {\r\n      this.operationType = \"edit\";\r\n      this.userForm.enable();\r\n      this.userForm.get(\"email\")?.disable();\r\n    }\r\n  }\r\n\r\n  populatePermission(permissionsData: any[]) {\r\n    const permissions = this.userForm.get(\"permission\") as FormArray;\r\n    permissions.clear();\r\n    permissionsData.forEach((permission: any) => {\r\n      const featureGroup = this.fb.group({\r\n        featureName: [permission?.featureName],\r\n        product: this.fb.array([]),\r\n      });\r\n\r\n      const products = featureGroup.get(\"product\") as FormArray;\r\n      permission.product.forEach((product: any) => {\r\n        const productGroup = this.fb.group({\r\n          name: [product.name],\r\n          isView: [product.isView],\r\n          isEdit: [product.isEdit],\r\n          // isDownload: [product.isDownload],\r\n          // isDelete: [product.isDelete],\r\n        });\r\n        products.push(productGroup);\r\n      });\r\n\r\n      permissions.push(featureGroup);\r\n    });\r\n    for (let i = 0; i < this.getPermissions().length; i++) {\r\n      this.isExpanded.push(true);\r\n    }\r\n  }\r\n\r\n  getProducts(featureName: string): FormArray {\r\n    return this.userForm\r\n      .get(\"permission\")\r\n      ?.value.find((permission: any) => permission.featureName === featureName)\r\n      .product;\r\n  }\r\n\r\n  getUserPermissionData(roleName: string, userType: string) {\r\n    (this.userForm.get(\"permission\") as FormArray).clear();\r\n    this.cd.detectChanges();\r\n    this.userService\r\n      .getPersmissions({\r\n        roleName: roleName,\r\n        userType: userType,\r\n      })\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res) {\r\n            if (res.code == 200) {\r\n              this.populatePermission(res.data.result[0]?.permission);\r\n            } else {\r\n              (this.userForm.get(\"permission\") as FormArray).clear();\r\n            }\r\n          } else {\r\n            (this.userForm.get(\"permission\") as FormArray).clear();\r\n          }\r\n        },\r\n        error: (error: any) => {\r\n          (this.userForm.get(\"permission\") as FormArray).clear();\r\n        },\r\n        complete: () => { },\r\n      });\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  omit_special_char(event: any) {\r\n    var k;\r\n    k = event.charCode; //         k = event.keyCode;  (Both can be used)\r\n    return k == 8 || k == 32 || (k >= 48 && k <= 57);\r\n  }\r\n\r\n  getPermissions(): FormArray {\r\n    return this.userForm.get(\"permission\") as FormArray;\r\n  }\r\n\r\n  getFeaturePermissions(permission: FormGroup | any): FormArray {\r\n    return permission.get(\"product\") as FormArray;\r\n  }\r\nhasInvalidChars(value: string): boolean {\r\n  const regex = /^[a-zA-Z0-9 _-]*$/;\r\n  return !regex.test(value);\r\n}\r\n  onUpload(e: any) {\r\n    let data: any[];\r\n    const target: DataTransfer = <DataTransfer>e.target;\r\n    if (target.files.length > 1) {\r\n      this.inputFile.nativeElement.value = \"\";\r\n    }\r\n      const file: File = e.target.files[0];\r\n  const allowedExtensions = /\\.(xls|xlsx|csv)$/i;\r\n  const allowedTypes = [\r\n    \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\", \r\n    \"application/vnd.ms-excel\",                                          \r\n    \"text/csv\",                                                         \r\n    \"application/csv\",                                                   \r\n  ];\r\n\r\n  if (!allowedExtensions.test(file.name) || !allowedTypes.includes(file.type)) {\r\n    this.ts.getErrorToast(\"Only .xlsx, or .csv files are allowed.\");\r\n    this.inputFile.nativeElement.value = \"\";\r\n    return;\r\n  }\r\n    if (!!target.files[0].name.match(/(.xls|.xlsx)/)) {\r\n      const reader: FileReader = new FileReader();\r\n      reader.onload = (e: any) => {\r\n        const bstr: string = e.target.result;\r\n        const wb: WorkBook = read(bstr, { type: \"binary\" });\r\n        const wsname: string = wb.SheetNames[0];\r\n        const ws: WorkSheet = wb.Sheets[wsname];\r\n        if (wb.SheetNames[0] != \"Users\") {\r\n          this.ts.getErrorToast('Please Upload the Valid File');\r\n             this.inputFile.nativeElement.value = \"\";\r\n          return;\r\n        }\r\n        data = utils.sheet_to_json(ws);\r\n      };\r\n\r\n      reader.readAsBinaryString(target.files[0]);\r\n\r\n      reader.onloadend = async (e) => {\r\n        let processedArray: any[] = [];\r\n        let errMsgs: any[] = [];\r\n        for (let i = 0; i < data.length; i++) {\r\n             this.inputFile.nativeElement.value = \"\";\r\n          errMsgs.push(this.validateField(data[i].UserName, \"User name\", i));\r\n          errMsgs.push(\r\n            this.validateField(data[i].Email, \"Email\", i, this.emailRegex)\r\n          );\r\n                       if (this.hasInvalidChars(data[i].UserName)) {\r\n      errMsgs.push(`Row ${i + 1}: UserName : ${data[i].UserName} has invalid characters.`);\r\n    }\r\n          errMsgs.push(\r\n            this.validateField(\r\n              data[i].Contact,\r\n              \"Contact\",\r\n              i,\r\n              this.phoneRegex\r\n            )\r\n          );\r\n          // errMsgs.push(this.validateField(data[i].Role, \"Role\", i));\r\n        }\r\n\r\n        errMsgs = errMsgs.filter((x) => x != null);\r\n        if (errMsgs.length > 0) {\r\n          let errors = errMsgs.join(\"<br>\");\r\n          Swal.fire({\r\n            icon: \"error\",\r\n            html: errors,\r\n            customClass: {\r\n              htmlContainer: \"error-htmlcontainer-class\",\r\n            },\r\n            heightAuto: false,\r\n            showCancelButton: false,\r\n            showConfirmButton: true,\r\n            confirmButtonColor: \"#009EF7\",\r\n            confirmButtonText: \"OK\",\r\n          }).then((result) => { });\r\n          return;\r\n        }\r\n\r\n        console.log('data', data)\r\n\r\n        for (let i = 0; i < data.length; i++) {\r\n          processedArray.push({\r\n            userName: data[i].UserName,\r\n            email: data[i].Email,\r\n            mobileNumber: data[i].Contact.toString(),\r\n            tangoUserType: data[i].UserType,\r\n            role: 'user',\r\n            rolespermission: this.permissionArray\r\n          });\r\n        }\r\n\r\n        if (processedArray.length == 0) {\r\n          return this.ts.getErrorToast(\"No user entered in CSV\")\r\n        }\r\n\r\n\r\n        this.userService\r\n          .createBulkUpload(\r\n            {\r\n              users: processedArray,\r\n              userType: this.userType,\r\n              ...(this.userType == 'client') ? { clientId: this.$headerFilters.client } : {}\r\n            }\r\n          )\r\n          .subscribe({\r\n            next: (res: any) => {\r\n              if (res.code == 200) {\r\n                this.activeModal.close('submit');\r\n                this.ts.getSuccessToast('Users have been uploaded Successfully!');\r\n              }\r\n            },\r\n            error: (error: any) => {\r\n              if (error) {\r\n                   this.inputFile.nativeElement.value = \"\";\r\n                this.ts.getErrorToast(error.error.error ? error.error.error : 'Unable to create multiple Users!');\r\n                // } else {\r\n                //   this.ts.getErrorToast('Unable to create multiple Users!');\r\n              }\r\n            },\r\n          });\r\n      };\r\n      $(\"#kt_create_account_form_account_type_personal\").val(\"\");\r\n    }else {\r\n      this.ts.getErrorToast(\"Please Upload a Valid File\");\r\n      this.inputFile.nativeElement.value = \"\";\r\n    }\r\n  }\r\n\r\n  validateField(\r\n    value: string | undefined | null | number,\r\n    fieldName: string,\r\n    row: number,\r\n    regex?: RegExp\r\n  ): string | null {\r\n    if (typeof value !== \"string\" && typeof value !== \"number\") {\r\n      return `Invalid value for ${fieldName.toLowerCase()} in row ${row + 1}`;\r\n    }\r\n    const defaultValue = `please enter the ${fieldName\r\n      .toLowerCase()\r\n      .replace(/\\b\\w/g, (l) => l.toUpperCase())}`;\r\n    if (!value) {\r\n      return `Please enter ${fieldName.toLowerCase()} in row ${row + 1}`;\r\n    }\r\n    if (typeof value == \"string\") {\r\n      if (value.trim() === defaultValue.trim()) {\r\n        return `Invalid value for ${fieldName.toLowerCase()} in row ${row + 1}`;\r\n      }\r\n      if (regex && !regex.test(value.trim())) {\r\n        return `Please enter valid ${fieldName.toLowerCase()} in row ${row + 1\r\n          }`;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  onRoleChange(role: string) {\r\n    this.getUserPermissionData(role, this.userType);\r\n  }\r\n\r\n  userUpdate() {\r\n    this.userForm.get(\"email\")?.enable();\r\n    let user: any = this.userForm.value;\r\n    this.userForm.get(\"email\")?.disable();\r\n    this.userService.updateUser(user).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code == 200) {\r\n          this.ts.getSuccessToast(\r\n            \"User details updated successfully.\"\r\n          );\r\n          this.activeModal.close('submit');\r\n        } else {\r\n          this.ts.getErrorToast(\"Unable to update User!\");\r\n          this.activeModal.close();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        this.ts.getErrorToast(err?.error?.error ? err?.error?.error : \"Unable to update User!\");\r\n        this.activeModal.close();\r\n      },\r\n      complete: () => { },\r\n    });\r\n  }\r\n\r\n  onSubmit() {\r\n    if (this.operationType == \"edit\") {\r\n      this.userUpdate();\r\n    } else {\r\n      this.addUserSubmit();\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  camelCaseToText(input: string): string {\r\n    return input.replace(/([A-Z])/g, ' $1')\r\n      .replace(/^./, (str) => str.toUpperCase())\r\n      .trim();\r\n  }\r\n}\r\n","<div class=\"card py-0 scroll\">\r\n    <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n        <div class=\"my-5\">\r\n            <!-- <div class=\"symbol symbol-75px symbol-circle\">\r\n                <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n            </div> -->\r\n        </div>\r\n        <div class=\"row w-100\">\r\n            <div *ngIf=\"operationType==='add'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add\r\n                    User</a>\r\n                <div class=\"sub-title\">Please add your user details</div>\r\n            </div>\r\n            <!-- <div *ngIf=\"operationType==='edit'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Edit User Details</a>\r\n                <div class=\"sub-title\">Please Edit your user details</div>\r\n            </div> -->\r\n            <div *ngIf=\"operationType==='view'\" class=\"col-md-9\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">User Details</a>\r\n                <div class=\"sub-title\">View your user details</div>\r\n            </div>\r\n            <!-- @if ((gs.userAccess | async)?.Global_User_isEdit) { -->\r\n            <div *ngIf=\"operationType==='view' && (gs.userAccess | async)?.Global_User_isEdit\"\r\n                class=\"col-md-3 text-end px-0\" (click)=\"editUser()\">\r\n                <button class=\"btn btn-outline\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                        viewBox=\"0 0 20 20\" fill=\"none\">\r\n                        <g clip-path=\"url(#clip0_3833_85908)\">\r\n                            <path\r\n                                d=\"M9.16602 3.3332H3.33268C2.89065 3.3332 2.46673 3.50879 2.15417 3.82135C1.84161 4.13391 1.66602 4.55784 1.66602 4.99986V16.6665C1.66602 17.1086 1.84161 17.5325 2.15417 17.845C2.46673 18.1576 2.89065 18.3332 3.33268 18.3332H14.9993C15.4414 18.3332 15.8653 18.1576 16.1779 17.845C16.4904 17.5325 16.666 17.1086 16.666 16.6665V10.8332M15.416 2.0832C15.7475 1.75168 16.1972 1.56543 16.666 1.56543C17.1349 1.56543 17.5845 1.75168 17.916 2.0832C18.2475 2.41472 18.4338 2.86436 18.4338 3.3332C18.4338 3.80204 18.2475 4.25168 17.916 4.5832L9.99935 12.4999L6.66602 13.3332L7.49935 9.99986L15.416 2.0832Z\"\r\n                                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                        </g>\r\n                        <defs>\r\n                            <clipPath id=\"clip0_3833_85908\">\r\n                                <rect width=\"20\" height=\"20\" fill=\"white\" />\r\n                            </clipPath>\r\n                        </defs>\r\n                    </svg></button>\r\n            </div>\r\n            <!-- } -->\r\n        </div>\r\n        <div class=\"fw-bold text-gray-500 my-6\" *ngIf=\"!showsingleuser && this.operationType ==='add'\">\r\n            <ul class=\"text-gray-400 fw-bold fs-6\">\r\n                <li>Use the template to upload multiple users at once.</li>\r\n                <li>Download the template here -\r\n                    <a [attr.href]=\"userType ==='tango' ? '../../../assets/files/TangoUsersTemplate.xlsx' : '../../../assets/files/UsersTemplate.xlsx'\"\r\n                        download>\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                            <path\r\n                                d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M5.83333 8.33333L10 12.5M10 12.5L14.1667 8.33333M10 12.5V2.5\"\r\n                                stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        <span class=\"template ms-2\">Download Template</span>\r\n                    </a>\r\n                </li>\r\n                <li>Add your data to the Template File</li>\r\n                <li>Upload it below for processing</li>\r\n\r\n            </ul>\r\n        </div>\r\n        <div class=\"d-flex flex-center flex-wrap mb-5 w-100\" *ngIf=\"!showsingleuser && this.operationType ==='add'\">\r\n            <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\" accept = \".csv, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel\"\r\n                (change)=\"onUpload($event)\" value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n                ng-reflect-form-control-name=\"accountType\" ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n            <label for=\"kt_create_account_form_account_type_personal\"\r\n                class=\"btn btn-outline  bg-primary btn-outline-default rounded-3 w-100 p-4 mt-5\"><span\r\n                    class=\"fw-bold fs-4\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\"\r\n                        viewBox=\"0 0 21 20\" fill=\"none\">\r\n                        <path\r\n                            d=\"M18 12.5V15.8333C18 16.2754 17.8244 16.6993 17.5118 17.0118C17.1993 17.3244 16.7754 17.5 16.3333 17.5H4.66667C4.22464 17.5 3.80072 17.3244 3.48816 17.0118C3.17559 16.6993 3 16.2754 3 15.8333V12.5M14.6667 6.66667L10.5 2.5M10.5 2.5L6.33333 6.66667M10.5 2.5V12.5\"\r\n                            stroke=\"white\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </svg> <span class=\"text-white mx-2 single-user\">Add Multiple Users</span></span>\r\n            </label>\r\n            <p class=\"text-gray-400 fw-bold my-3\">\r\n                <span class=\"mx-2 orval\">Or </span>\r\n            </p>\r\n            <input type=\"radio\" id=\"kt_account_team_size_select_1\" value=\"1-1\" (click)=\"addSingleUser()\"\r\n                class=\"btn-check ng-untouched ng-pristine ng-valid\" />\r\n            <label for=\"kt_account_team_size_select_1\"\r\n                class=\"btn btn-outline btn-outline-default rounded-3 w-100 p-4 mt-3\"><span class=\"fw-bold fs-4\"><svg\r\n                        xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n                        <path\r\n                            d=\"M17.1663 17.5V15.8333C17.1663 14.9493 16.8152 14.1014 16.19 13.4763C15.5649 12.8512 14.7171 12.5 13.833 12.5H7.16634C6.28229 12.5 5.43444 12.8512 4.80932 13.4763C4.1842 14.1014 3.83301 14.9493 3.83301 15.8333V17.5M13.833 5.83333C13.833 7.67428 12.3406 9.16667 10.4997 9.16667C8.65873 9.16667 7.16634 7.67428 7.16634 5.83333C7.16634 3.99238 8.65873 2.5 10.4997 2.5C12.3406 2.5 13.833 3.99238 13.833 5.83333Z\"\r\n                            stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </svg><span id=\"triggerButtonId\" class=\"mx-2 single-user fw-bold\">Add Single\r\n                        User</span></span></label>\r\n        </div>\r\n\r\n        <div class=\"w-100 h-500px scroll\" *ngIf=\"showsingleuser\">\r\n            <div class=\"mt-5\" *ngIf=\"userForm\">\r\n                <form [formGroup]=\"userForm\" novalidate=\"novalidate\" class=\"\">\r\n                    <div class=\"row px-0 me-3\">\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"username\" class=\"form-label\">User Name</label>\r\n                            <input type=\"text\" class=\"form-control\" id=\"username\" formControlName=\"userName\"\r\n                                autocomplete=\"off\">\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"email\" class=\"form-label\">Email</label>\r\n                            <input type=\"email\" class=\"form-control\" id=\"email\" formControlName=\"email\"\r\n                                autocomplete=\"off\" required>\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"contact\" class=\"form-label\">Contact Number</label>\r\n                            <input type=\"text\" class=\"form-control\" id=\"contact\" formControlName=\"mobileNumber\"\r\n                                autocomplete=\"off\" required minlength=\"10\" maxlength=\"13\"\r\n                                (keypress)=\"omit_special_char($event)\">\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"role\" class=\"form-label\">Role</label>\r\n                            <select class=\"form-select\" formControlName=\"role\"\r\n                                (change)=\"onRoleChange(userForm.get('role')?.value)\">\r\n                                <option value=\"superadmin\">Super Admin</option>\r\n                                <option value=\"admin\">Admin</option>\r\n                                <option value=\"user\">User</option>\r\n                            </select>\r\n                        </div>\r\n                        <div *ngIf=\"userType === 'tango'\" class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"tangoUserType\" class=\"form-label\">User Type</label>\r\n                            <select class=\"form-select\" formControlName=\"tangoUserType\"\r\n                                (change)=\"onRoleChange(userForm.get('tangoUserType')?.value)\">\r\n                                <option value=\"dashboard\">Dashboard</option>\r\n                                <option value=\"audit\">Audit</option>\r\n                            </select>\r\n                        </div>\r\n                    </div>\r\n                    <a class=\"fs-4 text-gray-800 text-hover-primary fw-bolder mb-0 title cursor-pointer\">Access for\r\n                        {{userForm.get('role')?.value | titlecase}}</a>\r\n                    <div class=\"sub-title font-sub\">{{userForm.get('role')?.value | titlecase}} can access respective\r\n                        enabled features and products</div>\r\n                    <ng-container *ngIf=\"getPermissions().length\">\r\n                        <ng-container formArrayName=\"permission\">\r\n                            <ng-container *ngFor=\"let permission of getPermissions().controls; let i = index\"\r\n                                [formGroupName]=\"i\">\r\n                                <div class=\"my-6\">\r\n                                    <div class=\"row me-3\">\r\n                                        <div class=\"col-6\">\r\n                                            <div class=\"title fw-semibold\">\r\n                                                {{ permission.get('featureName')?.value | titlecase }}\r\n\r\n                                            </div>\r\n                                        </div>\r\n                                        <div class=\"col-6 d-flex justify-content-end\" (click)=\"toggleCollapse(i)\">\r\n                                            <div class=\"text-end\">\r\n                                                @if (!isExpanded[i]) {\r\n                                                <svg width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" fill=\"none\"\r\n                                                    xmlns=\"http://www.w3.org/2000/svg\">\r\n                                                    <path d=\"M1.5 1.5L6.5 6.5L11.5 1.5\" stroke=\"#667085\"\r\n                                                        stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n                                                } @else {\r\n                                                <svg width=\"12\" height=\"8\" viewBox=\"0 0 12 8\" fill=\"none\"\r\n                                                    xmlns=\"http://www.w3.org/2000/svg\">\r\n                                                    <path d=\"M11 6.5L6 1.5L1 6.5\" stroke=\"#667085\" stroke-width=\"1.67\"\r\n                                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n\r\n                                                }\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div [ngClass]=\"{ 'collapsed': !isExpanded[i] }\">\r\n                                        <div class=\"table-responsive my-2 me-3\">\r\n                                            <table class=\"w-100\">\r\n                                                <thead>\r\n                                                    <tr>\r\n                                                        <th>Modules</th>\r\n                                                        <th>View</th>\r\n                                                        <th>Edit</th>\r\n                                                        <th>Download</th>\r\n                                                        <th>Delete</th>\r\n                                                    </tr>\r\n                                                </thead>\r\n                                                <tbody>\r\n                                                    <ng-container *ngIf=\"permission.get('product')\"\r\n                                                        formArrayName=\"product\">\r\n                                                        <ng-container\r\n                                                            *ngFor=\"let product of getFeaturePermissions(permission)?.controls;let j=index;\"\r\n                                                            [formGroupName]=\"j\">\r\n                                                            <tr>\r\n                                                                <td>{{ camelCaseToText(product.get('name')?.value) }}\r\n                                                                </td>\r\n                                                                <td><input formControlName=\"isView\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        (change)=\"handleAddChange(product)\"></td>\r\n                                                                <td><input formControlName=\"isEdit\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        (change)=\"handleEditChange(product)\"></td>\r\n                                                                <td><input formControlName=\"isDownload\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        [disabled]=\"!product.get('isEdit')?.value || !product.get('isView')?.value\">\r\n                                                                </td>\r\n                                                                <td><input formControlName=\"isDelete\" type=\"checkbox\"\r\n                                                                        class=\"cursor-pointer\"\r\n                                                                        [disabled]=\"!product.get('isEdit')?.value || !product.get('isView')?.value\">\r\n                                                                </td>\r\n                                                            </tr>\r\n                                                        </ng-container>\r\n                                                    </ng-container>\r\n                                                </tbody>\r\n                                            </table>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </ng-container>\r\n\r\n                    <div *ngIf=\"operationType!=='view'\" class=\"d-flex my-14\" role=\"group\">\r\n                        <button class=\"btn btn-outline w-100 mx-3\" (click)=\"cancel()\">Cancel</button>\r\n                        <button class=\"btn btn-primary w-100 mx-3\" [disabled]=\"userForm.invalid\" id=\"alert-toast\"\r\n                            (click)=\"onSubmit()\">Submit</button>\r\n                    </div>\r\n                </form>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>"]}
@@ -1235,7 +1235,7 @@ class AddUserPopupComponent {
1235
1235
  "application/csv",
1236
1236
  ];
1237
1237
  if (!allowedExtensions.test(file.name) || !allowedTypes.includes(file.type)) {
1238
- this.ts.getErrorToast("Only .xls, .xlsx, or .csv files are allowed.");
1238
+ this.ts.getErrorToast("Only .xlsx, or .csv files are allowed.");
1239
1239
  this.inputFile.nativeElement.value = "";
1240
1240
  return;
1241
1241
  }
@@ -1248,6 +1248,7 @@ class AddUserPopupComponent {
1248
1248
  const ws = wb.Sheets[wsname];
1249
1249
  if (wb.SheetNames[0] != "Users") {
1250
1250
  this.ts.getErrorToast('Please Upload the Valid File');
1251
+ this.inputFile.nativeElement.value = "";
1251
1252
  return;
1252
1253
  }
1253
1254
  data = utils.sheet_to_json(ws);
@@ -1257,6 +1258,7 @@ class AddUserPopupComponent {
1257
1258
  let processedArray = [];
1258
1259
  let errMsgs = [];
1259
1260
  for (let i = 0; i < data.length; i++) {
1261
+ this.inputFile.nativeElement.value = "";
1260
1262
  errMsgs.push(this.validateField(data[i].UserName, "User name", i));
1261
1263
  errMsgs.push(this.validateField(data[i].Email, "Email", i, this.emailRegex));
1262
1264
  if (this.hasInvalidChars(data[i].UserName)) {
@@ -1310,8 +1312,8 @@ class AddUserPopupComponent {
1310
1312
  }
1311
1313
  },
1312
1314
  error: (error) => {
1313
- console.log(error);
1314
1315
  if (error) {
1316
+ this.inputFile.nativeElement.value = "";
1315
1317
  this.ts.getErrorToast(error.error.error ? error.error.error : 'Unable to create multiple Users!');
1316
1318
  // } else {
1317
1319
  // this.ts.getErrorToast('Unable to create multiple Users!');
@@ -1321,6 +1323,10 @@ class AddUserPopupComponent {
1321
1323
  };
1322
1324
  $("#kt_create_account_form_account_type_personal").val("");
1323
1325
  }
1326
+ else {
1327
+ this.ts.getErrorToast("Please Upload a Valid File");
1328
+ this.inputFile.nativeElement.value = "";
1329
+ }
1324
1330
  }
1325
1331
  validateField(value, fieldName, row, regex) {
1326
1332
  if (typeof value !== "string" && typeof value !== "number") {