tango-app-ui-analyse-trax 3.7.13-eyetest-8 → 3.7.13-eyetest-9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -692,12 +692,12 @@ export class SettingsAuditComponent {
692
692
  }
693
693
  /** ---- Apply / Reset ---- */
694
694
  Reset() {
695
- this.RmList.forEach((r) => (r.checked = true));
696
- this.ClusterList.forEach((c) => (c.checked = true));
697
- this.filteredRms = [...this.RmList];
698
- this.filteredClusters = [...this.ClusterList];
695
+ this.rmOpen = false;
696
+ this.clusterOpen = false;
697
+ this.getAllRm();
699
698
  this.Opendropdown = false;
700
- this.getEmail();
699
+ // getAllRm
700
+ // this.getEmail()
701
701
  }
702
702
  selectedRms = [];
703
703
  selectedClusters = [];
@@ -820,4 +820,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
820
820
  type: HostListener,
821
821
  args: ['document:click', ['$event']]
822
822
  }] } });
823
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"settings-audit.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/eye-test-audit/settings-audit/settings-audit.component.ts","../../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/eye-test-audit/settings-audit/settings-audit.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { PageInfoService } from \"tango-app-ui-global\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { EyeTestAuditService } from \"../../services/eye-test-audit.service\";\r\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { any } from \"@amcharts/amcharts5/.internal/core/util/Array\";\r\nimport { FormBuilder, FormGroup } from \"@angular/forms\";\r\n// import * as Plotly from 'plotly.js-dist-min';\r\nimport { DatePipe } from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: \"lib-settings-audit\",\r\n  templateUrl: \"./settings-audit.component.html\",\r\n  styleUrl: \"./settings-audit.component.scss\",\r\n})\r\nexport class SettingsAuditComponent implements OnInit {\r\n  AuditId: any;\r\n  dayjs = dayjs;\r\n  complianceForm: FormGroup;\r\n  constructor(\r\n    private cd: ChangeDetectorRef,\r\n    private zone: NgZone,\r\n    private fb: FormBuilder,\r\n    private pageInfo: PageInfoService,\r\n    private toastService: ToastService,\r\n    private route: ActivatedRoute,\r\n    private $api: EyeTestAuditService,\r\n    private modalService: NgbModal,\r\n    private router: Router,\r\n  ) {}\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if (!target.closest('.dropdown2') && !target.closest('.btn')) {\r\n      this.closeDropdown();\r\n    }\r\n  }\r\n  setPageData() {\r\n    this.pageInfo.setTitle(\"Audit - Eye Test\");\r\n\r\n    this.pageInfo.setBreadcrumbs([\r\n      {\r\n        title: \"Tango Trax\",\r\n        path: \"/manage/trax/dashboard\",\r\n        isActive: false,\r\n        isSeparator: false,\r\n      },\r\n      {\r\n        title: \"Tango Trax\",\r\n        path: \"/manage/trax/dashboard\",\r\n        isActive: false,\r\n        isSeparator: true,\r\n      },\r\n    ]);\r\n  }\r\n  alertUsers: any = [\r\n    {\r\n      id: \"6687d9d1a27ee88f9a4457cb\",\r\n      userName: \"Ajinkya Malshe\",\r\n      email: \"ajinkya.malshe@yopmail.com\",\r\n      role: \"admin\",\r\n    },\r\n    {\r\n      id: \"6687d9d1a27ee88f9a4457cc\",\r\n      userName: \"John Doe\",\r\n      email: \"john.doe@yopmail.com\",\r\n      role: \"manager\",\r\n    },\r\n  ];\r\n  users: any;\r\n  auditData: any;\r\n  currentAuditType: any;\r\n  ngOnInit(): void {\r\n    const userData: any = JSON.parse(localStorage.getItem(\"user-info\") || \"{}\");\r\n    this.users = userData;\r\n    const headers: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    this.auditData = this.$api.getAuditData()\r\n      ? this.$api.getAuditData()\r\n      : headers;\r\n    this.complianceForm = this.fb.group({\r\n      threshold: [{ value: null, disabled: true }],\r\n      percentage: [{ value: null, disabled: true }],\r\n    });\r\n\r\n    this.getUser();\r\n    this.getEmailConfig();\r\n    this.getAllRm();\r\n    // this.buildDataObject();\r\n    this.cd.detectChanges();\r\n    this.setPageData();\r\n    this.tableData = [\r\n      {\r\n        rmName: \"Olivia\",\r\n        clusterName: \"John\",\r\n        optumId: \"OPT001\",\r\n        storeName: \"LKST1001\",\r\n        tangoScore: \"9%\",\r\n        trustScore: \"9%\",\r\n      },\r\n      {\r\n        rmName: \"Emma\",\r\n        clusterName: \"Doe\",\r\n        optumId: \"OPT002\",\r\n        storeName: \"LKST1002\",\r\n        tangoScore: \"8%\",\r\n        trustScore: \"8%\",\r\n      },\r\n      {\r\n        rmName: \"Ava\",\r\n        clusterName: \"Smit\",\r\n        optumId: \"OPT003\",\r\n        storeName: \"LKST1003\",\r\n        tangoScore: \"7%\",\r\n        trustScore: \"7%\",\r\n      },\r\n      {\r\n        rmName: \"Isabella\",\r\n        clusterName: \"Johnson\",\r\n        optumId: \"OPT004\",\r\n        storeName: \"LKST1004\",\r\n        tangoScore: \"6%\",\r\n        trustScore: \"6%\",\r\n      },\r\n    ];\r\n    // this.alertUsers = this.alertUsers.map(\r\n    //   (user: { userName: string; email: string; role: string }) => ({\r\n    //     name: user.userName,\r\n    //     value: user.email,\r\n    //     role: user.role,\r\n    //   })\r\n    // );\r\n    this.route.queryParams.subscribe((params) => {\r\n      // this.storeId = params['storeId'];\r\n      this.currentAuditType = params[\"type\"];\r\n      this.AuditId = params[\"_id\"];\r\n    });\r\n    this.getAuditdetails();\r\n  }\r\n  private readonly destroy$ = new Subject();\r\n  stepWiseProcess: any = [];\r\n  auditDetails: any;\r\n  takeAudit: any;\r\n  getAuditdetails() {\r\n    // this.tableLoading.next('loading');\r\n    let payload = {\r\n      id: this.AuditId,\r\n      type: this.currentAuditType,\r\n    };\r\n    this.$api\r\n      .getAuditdetails(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            // this.disablecancel =  false\r\n            this.auditDetails = res?.data?.result;\r\n            if (this.auditDetails.auditStatus === \"In-Progress\") {\r\n              this.takeAudit = true;\r\n            } else {\r\n              this.takeAudit = false;\r\n            }\r\n            this.stepWiseProcess = this.auditDetails?.steps;\r\n            // setTimeout(()=>{\r\n            //   this.getAuditHistory()\r\n            // },100)\r\n            this.cd.detectChanges();\r\n          }\r\n        },\r\n      });\r\n\r\n    // this.tableLoading.next('loaded')\r\n  }\r\n\r\n  openItem(event: any) {}\r\n\r\n  // component.ts\r\n\r\n  backNavigation() {\r\n    this.$api.auditFilterData = {\r\n      back: \"back\",\r\n      auditDetails: this.auditDetails,\r\n    };\r\n    this.router.navigate([\"/manage/trax/audit\"], {\r\n      queryParams: {\r\n        date: this.dayjs(\r\n          this.auditDetails?.fileDate\r\n            ? this.auditDetails?.fileDate\r\n            : this.filterStartDate\r\n        ).format(\"YYYY-MM-DD\"),\r\n        typeValue: \"physical\",\r\n      },\r\n    });\r\n  }\r\n  selectedComplianceThreshold: any;\r\n  selectedCompliancePercentage: any;\r\n  complianceThresholds = [\r\n    { value: \"<=\", label: \"<=\" },\r\n    { value: \"<\", label: \"<\" },\r\n    { value: \">=\", label: \">=\" },\r\n    { value: \">\", label: \">\" },\r\n    { value: \"=\", label: \"=\" },\r\n  ];\r\n  compliancePercentage = [\r\n    { value: \"10%\", label: \"10%\" },\r\n    { value: \"20%\", label: \"20%\" },\r\n    { value: \"30%\", label: \"30%\" },\r\n    { value: \"40%\", label: \"40%\" },\r\n    { value: \"50%\", label: \"50%\" },\r\n    { value: \"60%\", label: \"60%\" },\r\n    { value: \"70%\", label: \"70%\" },\r\n    { value: \"80%\", label: \"80%\" },\r\n    { value: \"90%\", label: \"90%\" },\r\n    { value: \"100%\", label: \"100%\" },\r\n  ];\r\n\r\n  selectedDateRange: any = {\r\n    startDate: this.dayjs().subtract(30, \"days\"),\r\n    endDate: this.dayjs(),\r\n  };\r\n  filterStartDate: any = this.dayjs().subtract(30, \"days\").format(\"YYYY-MM-DD\");\r\n  filterEndDate: any = this.dayjs().subtract(0, \"days\").format(\"YYYY-MM-DD\");\r\n\r\n  ranges: any = {\r\n    Today: [this.dayjs(), this.dayjs()],\r\n    Yesterday: [\r\n      this.dayjs().subtract(1, \"days\"),\r\n      this.dayjs().subtract(1, \"days\"),\r\n    ],\r\n    \"This Week\": [this.dayjs().subtract(6, \"days\"), this.dayjs()],\r\n    \"Last Week\": [\r\n      this.dayjs().subtract(13, \"days\").startOf(\"days\"),\r\n      this.dayjs().subtract(7, \"days\").endOf(\"days\"),\r\n    ],\r\n    \"This Month\": [\r\n      this.dayjs().subtract(30, \"days\"), // Start date is 30 days before today\r\n      this.dayjs(),\r\n    ],\r\n    \"Last Month\": [\r\n      this.dayjs().subtract(1, \"month\").startOf(\"month\"),\r\n      this.dayjs().subtract(1, \"month\").endOf(\"month\"),\r\n    ],\r\n  };\r\n\r\n  datechange(event: any) {\r\n    if (event.startDate || event.endDate) {\r\n      this.filterStartDate = this.dayjs(event.startDate).format(\"YYYY-MM-DD\");\r\n      this.filterEndDate = this.dayjs(event.endDate).format(\"YYYY-MM-DD\");\r\n      this.Apply();\r\n    }\r\n  }\r\n\r\n  exportXLSX() {\r\n    const requestData = {\r\n       fromDate: this.filterStartDate,\r\n      toDate: this.filterEndDate,\r\n      // type: this.currentAuditType,  it is shows only physical\r\n      RMList: this.selectedRms?.length ? this.selectedRms : [],\r\n      clientId: this.auditData?.client\r\n        ? this.auditData?.client\r\n        : this.users?.clientId,\r\n      cluster: this.selectedClusters?.length\r\n        ? this.selectedClusters\r\n        : [],\r\n      isExport: true,\r\n      searchValue: this.searchValue,\r\n      sortBy: this.sortedColumn ? this.sortedColumn : \"RMEmail\",\r\n      sortOrder: this.sortOrder ? this.sortOrder : 1,\r\n      offset: 1,\r\n      limit: 10000,\r\n    };\r\n\r\n    this.$api\r\n      .getEmailLogExport(requestData)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          this.$api.saveAsExcelFile(\r\n            res,\r\n            `${this.currentAuditType} Eye Test Table `\r\n          );\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err: any) => {\r\n          this.toastService.getErrorToast(\r\n            err?.error?.error ? err?.error?.error : err?.error?.message\r\n          );\r\n        },\r\n      });\r\n  \r\n  }\r\n\r\n  searchValue: any;\r\nsearchData() {\r\n    this.searchValue = this.searchValue;\r\n    this.getEmail();\r\n  }\r\n\r\n  tableData: any = [];\r\n\r\n  sortedColumn: any;\r\n  sortOrder: any;\r\n  onSort(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortOrder = this.sortOrder === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortedColumn = column ? column : \"RMEmail\";\r\n      this.sortOrder = 1;\r\n    }\r\n    this.getEmail();\r\n  }\r\n  allUsers: any;\r\n  getUser() {\r\n    let obj = {\r\n      userType: 'client',\r\n      filterByRole: [\"admin\", \"user\"],\r\n      isActive: this.users?.isActive,\r\n      clientId:this.auditData?.client ? this.auditData?.client : this.users?.clientId\r\n    };\r\n\r\n    this.$api\r\n      .getuserList(obj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res: any) => {\r\n        if (res && res?.code == 200) {\r\n          this.allUsers = res?.data?.result?.map((item: any) => ({\r\n            id: item._id,\r\n            name: item.email,\r\n          }));\r\n\r\n          this.getUserConfig(); // call after allUsers is ready\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  configData: any;\r\n\r\n  updateOwner(selectedEmail: any) {\r\n    this.configData = selectedEmail;\r\n  }\r\n\r\n  toggleEdit() {\r\n    if (!this.editMode) {\r\n      // entering edit mode → make a working copy\r\n      this.configData = [...this.lastSavedConfig];\r\n      this.editMode = true;\r\n    } else {\r\n      // leaving edit without saving → restore baseline\r\n      this.configData = [...this.lastSavedConfig];\r\n      this.editMode = false;\r\n    }\r\n  }\r\n\r\n  cancelEdit() {\r\n    // revert back to last saved state\r\n    this.configData = [...this.lastSavedConfig];\r\n    this.editMode = false;\r\n  }\r\n  editMode = false;\r\n  submitOwners() {\r\n    const payload = {\r\n      clientId: this.auditData?.client, // or this.clientId\r\n      userList: this.configData.map((o: any) => ({\r\n        _id: o.id ?? o.value, // ✅ support both cases\r\n        email: o.name,\r\n      })),\r\n    };\r\n\r\n    this.$api\r\n      .updateUserConfig(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            this.getUserConfig();\r\n            this.toastService.getSuccessToast(res?.message ? res?.message : \"Email configuration updated successfully\");\r\n            this.editMode = false;\r\n          } else {\r\n            this.toastService.getErrorToast(\"Failed to update owners\");\r\n          }\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err) => {\r\n            this.toastService.getSuccessToast(err?.error?.error ? err?.error?.error : err?.error?.message);\r\n        },\r\n      });\r\n  }\r\n\r\n  // this.onSubmit();\r\n  userConfigList: any = [];\r\n  lastSavedConfig: any;\r\n  getUserConfig() {\r\n    this.$api\r\n      .getUserConfigList(this.auditData?.client)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res: any) => {\r\n        if (res && res?.code == 200) {\r\n          // Assigned users\r\n          this.configData =\r\n            res?.data?.result?.userList?.map((item: any) => ({\r\n              id: item._id,\r\n              name: item.email,\r\n            })) ?? [];\r\n          this.lastSavedConfig = [...this.configData];\r\n\r\n          // Build set of assigned ids\r\n          const assignedIds = new Set(this.configData.map((u: any) => u.id));\r\n\r\n          // Filter from allUsers (not from userConfigList!)\r\n          this.userConfigList = this.allUsers.filter(\r\n            (u: any) => !assignedIds.has(u.id)\r\n          );\r\n\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  // email congig method and variables\r\n  emailConfigList: any;\r\n  editMode1 = true;\r\n  toggleEdit1() {\r\n    this.editMode1 = false;\r\n    this.complianceForm.enable();\r\n  }\r\n  getEmailConfig() {\r\n    this.$api\r\n      .getEmailConfigList(\r\n        this.auditData?.client ? this.auditData?.client : this.users?.clientId\r\n      )\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res: any) => {\r\n        if (res && res?.code == 200) {\r\n          this.emailConfigList = res?.data?.result;\r\n\r\n          // Suppose backend returns something like:\r\n          // { threshold: \"10\", percentage: \"80\" }\r\n          const initialData = {\r\n            threshold: this.emailConfigList?.complianceThreshold?.condition,\r\n            percentage: this.emailConfigList?.complianceThreshold?.value,\r\n          };\r\n\r\n          // Fill reactive form with values\r\n          this.complianceForm.patchValue(initialData);\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  lastSavedCompliance: any;\r\n  submitCompliance() {\r\n    if (this.complianceForm.invalid) return;\r\n    const payload = {\r\n      clientId: this.auditData?.client,\r\n      complianceThreshold: {\r\n        condition: this.complianceForm.value.threshold,\r\n        value: this.complianceForm.value.percentage,\r\n      },\r\n    };\r\n\r\n    this.$api\r\n      .updateEmailConfig(this.emailConfigList?._id, payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res) => {\r\n          this.toastService.getSuccessToast(\r\n            res?.message\r\n              ? `Email configuration` + res?.message\r\n              : \"Compliance settings updated successfully\"\r\n          );\r\n          this.getEmailConfig(); // update baseline\r\n          this.complianceForm.disable();\r\n          this.editMode1 = true;\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err) => console.error(\"Update failed:\", err),\r\n      });\r\n  }\r\n\r\n  cancelCompliance() {\r\n    this.complianceForm.disable();\r\n    this.editMode1 = true;\r\n    this.getEmailConfig();\r\n  }\r\n  // RMs\r\n  // RmList: any[] = [];\r\n  filteredRms: any[] = [];\r\n  searchRmText = \"\";\r\n\r\n  // Clusters\r\n  ClusterList: any[] = [];\r\n  filteredClusters: any[] = [];\r\n  searchClusterText = \"\";\r\n\r\n  // Dropdowns\r\n  Opendropdown = false;\r\n  dropdownOpen: string | null = null;\r\n\r\n  // Open/close dropdown\r\n  opendropdown() {\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n  closeDropdown() {\r\n    this.dropdownOpen = null;\r\n  }\r\n  rmOpen = false;\r\n  clusterOpen = false;\r\n\r\n  toggleRmDropdown() {\r\n    this.rmOpen = !this.rmOpen;\r\n    this.clusterOpen = false; // close other\r\n  }\r\n\r\n  toggleClusterDropdown() {\r\n    this.clusterOpen = !this.clusterOpen;\r\n    this.rmOpen = false; // close other\r\n  }\r\n\r\n  closeAllDropdowns() {\r\n    this.rmOpen = false;\r\n    this.clusterOpen = false;\r\n  }\r\nRmList:any[] = [\r\n  {\r\n    _id: \"1\",\r\n    userName: \"Ajay M\",\r\n    email: \"marellapudi.ajay@lenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"2\",\r\n    userName: \"Anirban Ghosh\",\r\n    email: \"anirban.ghosh@lenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"3\",\r\n    userName: \"Avadhesh Sharma\",\r\n    email: \"avadhesh.kumar@lenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"4\",\r\n    userName: \"Ayush Gupta\",\r\n    email: \"ayush.gupta1@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"5\",\r\n    userName: \"Dhiren Bisht\",\r\n    email: \"dhirendra.bisht@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"6\",\r\n    userName: \"Mueen Khan\",\r\n    email: \"mueen.khan@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"7\",\r\n    userName: \"Reshma Shetty\",\r\n    email: \"reshma.shetty@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"8\",\r\n    userName: \"Srinivas Reddy\",\r\n    email: \"srinivas.reddy@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"9\",\r\n    userName: \"Suresh Balaji R\",\r\n    email: \"suresh.r@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"10\",\r\n    userName: \"Thulasi Krishna\",\r\n    email: \"krishna.thulasi@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"11\",\r\n    userName: \"Vijeesh V L\",\r\n    email: \"vijeesh.vl@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"12\",\r\n    userName: \"Kunal Sharma\",\r\n    email: \"kunal.sharma@lenskart.mobi\",\r\n    role: \"admin\",\r\n  },\r\n];\r\n  /** ---- RMs ---- */\r\n  getAllRm() {\r\n    // this.$api.getRmList(this.auditData?.client).subscribe((res: any) => {\r\n    //   if (res?.code === 200) {\r\n    //     const result = Array.isArray(res.data.result)\r\n    //       ? res.data.result\r\n    //       : [res.data.result];\r\n        this.RmList = this.RmList.map((rm: any) => ({ ...rm, checked: true })); // ✅ pre-select all\r\n        this.filteredRms = [...this.RmList];\r\n        //-- Old code --\r\n        // this.getAllGroups(this.RmList);\r\n        // this.Apply();\r\n        this.getAllGroupsPromise(this.RmList).then(() => {\r\n          this.Apply();\r\n        });\r\n    //   }\r\n    // });\r\n  }\r\n\r\n  filterRms() {\r\n    const search = this.searchRmText.toLowerCase();\r\n    this.filteredRms = this.RmList.filter((r) =>\r\n      r.userName.toLowerCase().includes(search)\r\n    );\r\n  }\r\n\r\n  isAllRmsSelected() {\r\n    return (\r\n      this.filteredRms.length > 0 && this.filteredRms.every((r) => r.checked)\r\n    );\r\n  }\r\n\r\n  toggleSelectAllRms(event: any) {\r\n    const checked = event.target.checked;\r\n    this.filteredRms.forEach((r) => (r.checked = checked));\r\nthis.updateSelectedRms();\r\n  }\r\n\r\n  updateSelectedRms() {\r\n    const selected = this.RmList.filter((r) => r.checked);\r\n    // this.getAllGroups(selected); // auto refresh clusters\r\n    this.getAllGroupsPromise(selected).then(() => { \r\n      // auto refresh clusters with promise\r\n    });\r\n  }\r\n\r\nselectedRmsLabel(): string {\r\n  const selected = this.filteredRms.filter(rm => rm.checked);\r\n  if (selected.length === 0) return '';\r\n  return selected[0].userName;\r\n}\r\ngetSelectedRmsCount(): number {\r\n  return this.filteredRms.filter(rm => rm.checked).length;\r\n}\r\n  /** ---- Clusters ---- */\r\n// getAllGroups(event?: any[]) {\r\n//   let rmList: string[] = [];\r\n\r\n//   if (event?.length) {\r\n//     rmList = event.map((o) => o.email);\r\n//   } else if (this.users?.role === \"rm\") {\r\n//     rmList = [this.users?.email];\r\n//   }\r\n\r\n//   const obj = { \r\n//     clientId: this.auditData?.client ? this.auditData?.client : this.users?.clientId,\r\n//     rmList \r\n//   };\r\n\r\n//   this.$api.getClusters(obj).subscribe((res: any) => {\r\n//     if (res?.code === 200) {\r\n//       // Initialize clusters with checked=false\r\n//       this.ClusterList = (res.data.result || []).map((c: any) => ({\r\n//         ...c,\r\n//         checked: true\r\n//       }));\r\n//       this.filteredClusters = [...this.ClusterList];\r\n//     } else {\r\n//       this.ClusterList = [];\r\n//       this.filteredClusters = [];\r\n//     }\r\n//   });\r\n// }\r\n\r\n  getAllGroupsPromise(event?: any[]): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      let rmList: string[] = [];\r\n\r\n      if (event?.length) {\r\n        rmList = event.map((o) => o.email);\r\n      } else if (this.users?.role === \"rm\") {\r\n        rmList = [this.users?.email];\r\n      }\r\n\r\n      const obj = {\r\n        clientId: this.auditData?.client ?? this.users?.clientId,\r\n        rmList\r\n      };\r\n\r\n      this.$api.getClusters(obj).subscribe({\r\n        next: (res: any) => {\r\n          if (res?.code === 200) {\r\n            this.ClusterList = (res.data.result || []).map((c: any) => ({\r\n              ...c,\r\n              checked: true,\r\n            }));\r\n            this.filteredClusters = [...this.ClusterList];\r\n          } else {\r\n            this.ClusterList = [];\r\n            this.filteredClusters = [];\r\n          }\r\n          resolve(); // completion\r\n        },\r\n        error: (err) => reject(err),\r\n      });\r\n    });\r\n  }\r\n\r\nfilterClusters() {\r\n  const search = this.searchClusterText.toLowerCase();\r\n  this.filteredClusters = this.ClusterList.filter((c) =>\r\n    c.clusterName.toLowerCase().includes(search)\r\n  );\r\n}\r\n\r\nisAllClustersSelected() {\r\n  return (\r\n    this.filteredClusters.length > 0 &&\r\n    this.filteredClusters.every((c) => c.checked)\r\n  );\r\n}\r\n\r\ntoggleSelectAllClusters(event: any) {\r\n  const checked = event.target.checked;\r\n  this.filteredClusters.forEach((c) => (c.checked = checked));\r\n  this.updateSelectedClusters();\r\n}\r\n\r\nupdateSelectedClusters() {\r\n  this.selectedClusters = this.ClusterList\r\n    .filter(c => c.checked)\r\n    .map(c => c._id); // or c.clusterName if needed\r\n}\r\n\r\nselectedClustersLabel() {\r\n  const selected = this.ClusterList.filter((c) => c.checked);\r\n  if (selected.length === 0) return '';\r\n  return selected[0].clusterName;\r\n}\r\n\r\ngetSelectedClustersCount() {\r\n  return this.ClusterList.filter(c => c.checked).length;\r\n  // return count > 1 ? count - 1 : 0; // Show \"+N others\"\r\n}\r\n\r\n  /** ---- Apply / Reset ---- */\r\n  Reset() {\r\n    this.RmList.forEach((r) => (r.checked = true));\r\n    this.ClusterList.forEach((c) => (c.checked = true));\r\n    this.filteredRms = [...this.RmList];\r\n    this.filteredClusters = [...this.ClusterList];\r\n       this.Opendropdown = false;\r\n       this.getEmail()\r\n  }\r\n  selectedRms: any = [];\r\n  selectedClusters: any = [];\r\n  Apply() {\r\n    const datePipe = new DatePipe(\"en-US\");\r\n    this.selectedRms = this.RmList.filter((r) => r.checked).map((r) => r.email);\r\n    this.selectedClusters = this.ClusterList.filter((c) => c.checked).map(\r\n      (c) => c.clusterName\r\n    );\r\n    this.getEmail();\r\n    this.rmOpen = false;\r\n    this.clusterOpen = false;\r\n    this.Opendropdown = false;\r\n    if (this.filterStartDate) {\r\n      this.filterStartDate = datePipe.transform(\r\n        this.filterStartDate,\r\n        \"yyyy-MM-dd\"\r\n      );\r\n    }\r\n    if (this.filterEndDate) {\r\n      this.filterEndDate = datePipe.transform(this.filterEndDate, \"yyyy-MM-dd\");\r\n    }\r\n  }\r\n  offset = 1;\r\n  limit = 10;\r\npageSize = 10;            \r\npaginationSizes = [10,20,30]; \r\ntotalItems = 0;\r\n  setPaginationSizes() {\r\n    if (this.totalItems > 10) {\r\n      this.paginationSizes = [10, 20, 30];\r\n    } else {\r\n      this.paginationSizes = [this.totalItems]; // Just one option if less than 10\r\n    }\r\n    this.pageSize = this.paginationSizes[0];\r\n  } \r\n  loading = false;\r\n  noData = false;\r\n  getEmail() {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    let obj = {\r\n      fromDate: this.filterStartDate,\r\n      toDate: this.filterEndDate,\r\n      // type: this.currentAuditType,\r\n      RMList: this.selectedRms?.length ? this.selectedRms : [],\r\n      clientId: this.auditData?.client\r\n        ? this.auditData?.client\r\n        : this.users?.clientId,\r\n      cluster: this.selectedClusters?.length\r\n        ? this.selectedClusters\r\n        : [],\r\n      isExport: false,\r\n      searchValue: this.searchValue,\r\n      sortBy: this.sortedColumn ? this.sortedColumn : \"RMEmail\",\r\n      sortOrder: this.sortOrder ? this.sortOrder : 1,\r\n      offset: this.offset,\r\n      limit: this.limit,\r\n    };\r\n    this.$api\r\n      .getEmailLog(obj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            this.tableData = res.data.result;\r\n            this.totalItems = res?.data?.count || 0;\r\n            this.setPaginationSizes();\r\n            this.loading = false;\r\n            this.noData = false;\r\n          } else {\r\n            this.tableData = [];\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0;\r\n          }\r\n        },\r\n        error: (err) => {\r\n          this.tableData = [];\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.totalItems = 0;\r\n          console.error(\"Update failed:\", err);\r\n        },\r\n      });\r\n  }\r\n\r\nonPageChange(page: number) {\r\n  this.offset = page;\r\n  this.getEmail(); // reload with new page\r\n}\r\n\r\nonPageSizeChange(size: number) {\r\n  this.pageSize = size;\r\n  this.limit = size;\r\n  this.offset = 1;   // reset to first page when page size changes\r\n  this.getEmail();\r\n}\r\n\r\n  eyeTestView(data: any) {\r\n    this.$api.setAuditData(data);\r\n    \r\n    this.router.navigate([\"/manage/trax/audit/start\"], {\r\n      queryParams: {\r\n        type: this.currentAuditType,\r\n        storeId: data?.storeId,\r\n        _id: data.auditedId,\r\n        eyeType :data?.comment ? \"fake\" : \"genuine\",\r\n        RMEmail:data?.RMEmail,\r\n        cluster:data?.cluster,\r\n      },\r\n    });\r\n    let data1: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\n  data1.date = {\r\n  startDate: this.auditDetails?.fileDate,\r\n  endDate: this.auditDetails?.fileDate\r\n};\r\n     localStorage.setItem(\"header-filters\", JSON.stringify(data1));\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  //  @ViewChild('sankeyChart', { static: true }) chartElement!: ElementRef;\r\n\r\n  //   ngAfterViewInit() {\r\n  //     const rawData = [\r\n  //       { from: \"Customization\", to: \"Formal Pants\", value: 3 },\r\n  //       { from: \"Entry\", to: \"Formal Pants\", value: 12 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Joggers\", value: 4 },\r\n  //       { from: \"Joggers\", to: \"Formal Pants\", value: 2 },\r\n  //       { from: \"Power Stretch\", to: \"Customization\", value: 2 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 5 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Power Stretch\", value: 2 },\r\n  //       { from: \"Customization\", to: \"Trial Room\", value: 2 },\r\n  //       { from: \"Joggers\", to: \"Exit\", value: 29 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Power Stretch\", value: 2 },\r\n  //       { from: \"Entry\", to: \"Customization\", value: 64 },\r\n  //       { from: \"Power Stretch\", to: \"Pin Tuck Pants\", value: 3 },\r\n  //       { from: \"Customization\", to: \"Pin Tuck Pants\", value: 10 },\r\n  //       { from: \"Entry\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 49 },\r\n  //       { from: \"Entry\", to: \"Joggers\", value: 29 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Exit\", value: 49 },\r\n  //       { from: \"Joggers\", to: \"Customization\", value: 6 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Joggers\", value: 3 },\r\n  //       { from: \"Power Stretch\", to: \"Joggers\", value: 1 },\r\n  //       { from: \"Customization\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 7 },\r\n  //       { from: \"Formal Pants\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 1 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Exit\", value: 54 },\r\n  //       { from: \"Power Stretch\", to: \"Trial Room\", value: 2 },\r\n  //       { from: \"Formal Pants\", to: \"Customization\", value: 3 },\r\n  //       { from: \"Formal Pants\", to: \"Power Stretch\", value: 1 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Trial Room\", value: 2 },\r\n  //       { from: \"Customization\", to: \"Exit\", value: 64 },\r\n  //       { from: \"Entry\", to: \"Pin Tuck Pants\", value: 54 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Formal Pants\", value: 3 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Pin Tuck Pants\", value: 5 },\r\n  //       { from: \"Joggers\", to: \"Power Stretch\", value: 4 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Formal Pants\", value: 3 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Customization\", value: 11 },\r\n  //       { from: \"Formal Pants\", to: \"Pin Tuck Pants\", value: 3 },\r\n  //       { from: \"Trial Room\", to: \"Pin Tuck Pants\", value: 1 },\r\n  //       { from: \"Customization\", to: \"Power Stretch\", value: 1 },\r\n  //       { from: \"Customization\", to: \"Joggers\", value: 6 },\r\n  //       { from: \"Formal Pants\", to: \"Exit\", value: 12 },\r\n  //       { from: \"Joggers\", to: \"Pin Tuck Pants\", value: 4 },\r\n  //       { from: \"Power Stretch\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 1 },\r\n  //       { from: \"Power Stretch\", to: \"Exit\", value: 18 },\r\n  //       { from: \"Entry\", to: \"Trial Room\", value: 6 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Customization\", value: 5 },\r\n  //       { from: \"Entry\", to: \"Power Stretch\", value: 18 },\r\n  //       { from: \"Power Stretch\", to: \"Formal Pants\", value: 1 },\r\n  //       { from: \"Trial Room\", to: \"Customization\", value: 3 },\r\n  //       { from: \"Trial Room\", to: \"Exit\", value: 6 },\r\n  //       { from: \"Formal Pants\", to: \"Joggers\", value: 4 }\r\n  //     ];\r\n\r\n  //     // Build unique nodes\r\n  //     const labels = [...new Set(rawData.flatMap(d => [d.from, d.to]))];\r\n  //     const labelToIndex: Record<string, number> = {};\r\n  //     labels.forEach((label, i) => (labelToIndex[label] = i));\r\n\r\n  //     // Map data for Sankey\r\n  //     const source = rawData.map(d => labelToIndex[d.from]);\r\n  //     const target = rawData.map(d => labelToIndex[d.to]);\r\n  //     const value = rawData.map(d => d.value);\r\n\r\n  //     // Assign consistent colors (like amCharts distinct palette)\r\n  //     const nodeColors: Record<string, string> = {\r\n  //       \"Customization\": \"#1f77b4\",\r\n  //       \"Formal Pants\": \"#ff7f0e\",\r\n  //       \"Entry\": \"#2ca02c\",\r\n  //       \"Pin Tuck Pants\": \"#d62728\",\r\n  //       \"Joggers\": \"#9467bd\",\r\n  //       \"Power Stretch\": \"#8c564b\",\r\n  //       \"Exit\": \"#e377c2\",\r\n  //       \"Trial Room\": \"#17becf\",\r\n  //       \"Shorts with Lounge wear , Chinos and Pintuck Pants\": \"#bcbd22\"\r\n  //     };\r\n\r\n  //     const nodeColorArray = labels.map(l => nodeColors[l] || \"#999\");\r\n  //     const linkColorArray = rawData.map(d => nodeColors[d.from] || \"#999\");\r\n\r\n  //     const data: any = [{\r\n  //       type: \"sankey\",\r\n  //       orientation: \"h\",\r\n  //       node: {\r\n  //         pad: 15,\r\n  //         thickness: 20,\r\n  //         line: { color: \"black\", width: 0.5 },\r\n  //         label: labels,\r\n  //         color: nodeColorArray\r\n  //       },\r\n  //       link: {\r\n  //         source,\r\n  //         target,\r\n  //         value,\r\n  //         color: linkColorArray\r\n  //       }\r\n  //     }];\r\n\r\n  //     const layout = {\r\n  //       title: { text: \"Sankey Flow (Plotly with AmCharts-like Colors)\" },\r\n  //       font: { size: 12 }\r\n  //     };\r\n\r\n  //     Plotly.newPlot(this.chartElement.nativeElement, data, layout);\r\n  //   }\r\n}\r\n","<div class=\"d-flex align-items-center my-5\">\r\n    <div (click)=\"backNavigation()\" class=\"btn btn-am btn-outline p-3\">\r\n        <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                <path d=\"M15.8332 9.99984H4.1665M4.1665 9.99984L9.99984 15.8332M4.1665 9.99984L9.99984 4.1665\"\r\n                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n            </svg></span>\r\n    </div><span class=\"ms-2 title-head\">Audit Settings</span>\r\n</div>\r\n\r\n\r\n<div class=\"row mt-5\">\r\n    <div class=\"col-12\">\r\n        <div ngbAccordion #accordion=\"ngbAccordion\" [closeOthers]=\"true\" [destroyOnHide]=\"true\"\r\n            (show)=\"openItem($event)\">\r\n            <div class=\"settings-accordian-card \" ngbAccordionItem [collapsed]=\"false\">\r\n                <div class=\"d-flex\" ngbAccordionHeader>\r\n                    <button type=\"button\" class=\"mainheading\" ngbAccordionButton>\r\n                        <div class=\"header-row\">\r\n                            <span>User Configuration</span>\r\n                            <span class=\"divider\"></span>\r\n                        </div>\r\n                    </button>\r\n                </div>\r\n                <div ngbAccordionCollapse>\r\n                    <div ngbAccordionBody>\r\n                        <ng-template>\r\n\r\n                            <div class=\"col-12 mb-5\">\r\n                                <div *ngIf=\"!editMode\" class=\" d-flex justify-content-end\">\r\n                                    <button (click)=\"toggleEdit()\" type=\"button\"\r\n                                        class=\"btn btn-outline align-items-end\"><span class=\"me-2\"><svg\r\n                                                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_2579_25125)\">\r\n                                                    <path\r\n                                                        d=\"M14.167 2.49993C14.3859 2.28106 14.6457 2.10744 14.9317 1.98899C15.2176 1.87054 15.5241 1.80957 15.8337 1.80957C16.1432 1.80957 16.4497 1.87054 16.7357 1.98899C17.0216 2.10744 17.2815 2.28106 17.5003 2.49993C17.7192 2.7188 17.8928 2.97863 18.0113 3.2646C18.1297 3.55057 18.1907 3.85706 18.1907 4.16659C18.1907 4.47612 18.1297 4.78262 18.0113 5.06859C17.8928 5.35455 17.7192 5.61439 17.5003 5.83326L6.25033 17.0833L1.66699 18.3333L2.91699 13.7499L14.167 2.49993Z\"\r\n                                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2579_25125\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg></span>Edit Details</button>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div class=\"w-80\">\r\n                                <label class=\"my-2 form-label fs-4 fw-bold\">Assign Audit Users</label>\r\n                                <div *ngIf=\"editMode; else readonlyView\">\r\n                                    <lib-chip-dropdown [data]=\"userConfigList\" [selectedData]=\"configData\"\r\n                                        (selectedList)=\"updateOwner($event)\">\r\n                                    </lib-chip-dropdown>\r\n                                </div>\r\n\r\n                                <ng-template #readonlyView>\r\n                                    <div class=\"flex flex-wrap gap-2 border-2 border-gray-300 p-3 rounded\">\r\n                                        <ng-container *ngFor=\"let chip of configData\">\r\n                                            <span class=\"p-1 rounded-5 chip px-2 my-3 py-1 bg-gray-200\">\r\n                                                {{ chip?.name || chip }}\r\n                                            </span>\r\n                                        </ng-container>\r\n                                    </div>\r\n\r\n                                </ng-template>\r\n\r\n                            </div>\r\n\r\n                            <div class=\"mt-3 text-end\" *ngIf=\"editMode\">\r\n                                <button class=\"btn btn-outline me-2\" (click)=\"cancelEdit()\">Cancel</button>\r\n                                <button class=\"btn btn-primary\" (click)=\"submitOwners()\">Save</button>\r\n                            </div>\r\n                        </ng-template>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"settings-accordian-card mt-6\" ngbAccordionItem>\r\n                <div class=\"d-flex\" ngbAccordionHeader>\r\n                    <button class=\"mainheading\" ngbAccordionButton>\r\n                        <div class=\"header-row\">\r\n                            <span>Email Configuration</span>\r\n                            <span class=\"divider\"></span>\r\n                        </div>\r\n                    </button>\r\n                </div>\r\n                <div ngbAccordionCollapse>\r\n                    <div ngbAccordionBody>\r\n                        <ng-template>\r\n                            <div class=\"col-12 mb-5\">\r\n                                <div *ngIf=\"editMode1\" class=\" d-flex justify-content-end\">\r\n                                    <button (click)=\"toggleEdit1();\" type=\"button\"\r\n                                        class=\"btn btn-outline align-items-end\"><span class=\"me-2\"><svg\r\n                                                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_2579_25125)\">\r\n                                                    <path\r\n                                                        d=\"M14.167 2.49993C14.3859 2.28106 14.6457 2.10744 14.9317 1.98899C15.2176 1.87054 15.5241 1.80957 15.8337 1.80957C16.1432 1.80957 16.4497 1.87054 16.7357 1.98899C17.0216 2.10744 17.2815 2.28106 17.5003 2.49993C17.7192 2.7188 17.8928 2.97863 18.0113 3.2646C18.1297 3.55057 18.1907 3.85706 18.1907 4.16659C18.1907 4.47612 18.1297 4.78262 18.0113 5.06859C17.8928 5.35455 17.7192 5.61439 17.5003 5.83326L6.25033 17.0833L1.66699 18.3333L2.91699 13.7499L14.167 2.49993Z\"\r\n                                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2579_25125\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg></span>Edit Details</button>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"fw-semibold mb-3\">\r\n                                Compliance Threshold\r\n                            </div>\r\n                            <form [formGroup]=\"complianceForm\">\r\n\r\n                                <div class=\"row\">\r\n                                    <div class=\"col-lg-2\">\r\n                                        <lib-reactive-select formControlName=\"threshold\" [data]=\"complianceThresholds\"\r\n                                            [idField]=\"'value'\" [nameField]=\"'label'\"></lib-reactive-select>\r\n                                    </div>\r\n                                    <div class=\"col-lg-2\">\r\n                                        <lib-reactive-select formControlName=\"percentage\" [data]=\"compliancePercentage\"\r\n                                            [idField]=\"'value'\" [nameField]=\"'label'\"></lib-reactive-select>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"!editMode1\" class=\"mt-3 text-end\">\r\n                                    <button type=\"button\" class=\"btn btn-outline me-2\"\r\n                                        (click)=\"cancelCompliance()\">Cancel</button>\r\n                                    <button type=\"button\" class=\"btn btn-primary \"\r\n                                        (click)=\"submitCompliance()\">Save</button>\r\n                                </div>\r\n                            </form>\r\n                            <div class=\"my-3\">\r\n                                <span class=\"fw-semibold me-3\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                                        height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_762_15430)\">\r\n                                            <path\r\n                                                d=\"M8.00004 10.6663V7.99967M8.00004 5.33301H8.00671M14.6667 7.99967C14.6667 11.6816 11.6819 14.6663 8.00004 14.6663C4.31814 14.6663 1.33337 11.6816 1.33337 7.99967C1.33337 4.31778 4.31814 1.33301 8.00004 1.33301C11.6819 1.33301 14.6667 4.31778 14.6667 7.99967Z\"\r\n                                                stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_762_15430\">\r\n                                                <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg></span>\r\n                                Email will be automatically sent if the compliance doesn’t meet the\r\n                                <span class=\"fw-bold\">{{complianceForm.value?.percentage}}</span> to the respective Optometrist.\r\n                            </div>\r\n                        </ng-template>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"settings-accordian-card mt-6\" ngbAccordionItem>\r\n                <div class=\"d-flex\" ngbAccordionHeader>\r\n                    <button class=\"mainheading\" ngbAccordionButton>\r\n                        <div class=\"header-row\">\r\n                            <span>Email Logs</span>\r\n                            <span class=\"divider\"></span>\r\n                        </div>\r\n                    </button>\r\n                </div>\r\n                <div ngbAccordionCollapse>\r\n                    <div ngbAccordionBody>\r\n                        <ng-template>\r\n                            <div class=\"d-flex justify-content-end align-items-center mb-10\">\r\n                                <div class=\"d-flex align-items-center position-relative my-1\">\r\n                                    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n                                            viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\"\r\n                                                rx=\"1\" transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\">\r\n                                            </rect>\r\n                                            <path\r\n                                                d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n                                                fill=\"currentColor\"></path>\r\n                                        </svg>\r\n                                    </span>\r\n                                    <input (change)=\"searchData()\" [(ngModel)]=\"searchValue\" type=\"text\"\r\n                                        class=\"form-control ps-14 me-2\" autocomplete=\"off\" placeholder=\"Search\" />\r\n                                    <div class=\"d-flex align-items-center\">\r\n                                        <div class=\"d-flex align-items-center position-relative me-2\">\r\n                                            <input class=\"fx-date-range form-control ps-14\"\r\n                                                style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n                                                ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\"\r\n                                                [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\"\r\n                                                [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\"\r\n                                                [showCancel]=\"true\" autocomplete=\"off\" [(ngModel)]=\"selectedDateRange\"\r\n                                                [autoApply]=\"true\"\r\n                                                [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n                                                (datesUpdated)=\"datechange($event)\" name=\"daterange\" />\r\n                                            <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n                                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                                                    viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                    <path\r\n                                                        d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n                                            </span>\r\n                                        </div>\r\n\r\n                                        <div class=\"position-relative\">\r\n\r\n                                            <button type=\"button\" (click)=\"opendropdown()\"\r\n                                                class=\"btn btn-outline mx-2 rounded-3 text-nowrap border-val\">\r\n                                                <span class=\"me-2\">Filter</span> <svg width=\"20\" height=\"20\"\r\n                                                    viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                    <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\"\r\n                                                        stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n                                            </button>\r\n\r\n\r\n                                            <div *ngIf=\"Opendropdown\"\r\n                                                class=\"card p-4 dropdown2 position-absolute z-1 end-0\"\r\n                                                (clickOutside)=\"closeDropdown()\">\r\n                                                <div class=\"dropdown-title d-flex justify-content-between mb-3\">\r\n                                                    <span>Filter Options</span>\r\n\r\n                                                </div>\r\n\r\n\r\n                                                <div class=\"dropdown-container mb-3\">\r\n                                                    <div class=\"position-relative dropdown-header\"\r\n                                                        (click)=\"toggleRmDropdown()\">\r\n                                                        <input type=\"text\"\r\n                                                            class=\"form-control dropdown-input cursor-pointer\"\r\n                                                            value=\"RMs\" readonly placeholder=\"Select RMs\" />\r\n                                                        <span *ngIf=\"getSelectedRmsCount()\"\r\n                                                            class=\"position-absolute top-50 end-0 translate-middle-y me-2 badge badge-light-default text-white text-xs rounded-full px-2 py-0.5\">\r\n                                                            {{ getSelectedRmsCount() }}\r\n                                                        </span>\r\n                                                    </div>\r\n\r\n                                                    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"rmOpen\">\r\n                                                        <input type=\"text\" class=\"form-control mb-2 dropdown-search\"\r\n                                                            placeholder=\"Search RMs\" [(ngModel)]=\"searchRmText\"\r\n                                                            (ngModelChange)=\"filterRms()\" />\r\n\r\n                                                        <div class=\"form-check ps-0 my-5\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                id=\"selectAllRms\" [checked]=\"isAllRmsSelected()\"\r\n                                                                (change)=\"toggleSelectAllRms($event)\" />\r\n                                                            <label class=\"form-check-label\" for=\"selectAllRms\">Select\r\n                                                                All</label>\r\n                                                        </div>\r\n\r\n                                                        <div class=\"form-check mb-5 ps-0\"\r\n                                                            *ngFor=\"let rm of filteredRms\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                [id]=\"rm.email\" [(ngModel)]=\"rm.checked\"\r\n                                                                (change)=\"updateSelectedRms()\" />\r\n                                                            <label class=\"form-check-label\" [for]=\"rm.email\">{{\r\n                                                                rm.userName }}</label>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n\r\n\r\n                                                <div class=\"dropdown-container\">\r\n                                                    <div class=\"dropdown-header position-relative\"\r\n                                                        (click)=\"toggleClusterDropdown()\">\r\n                                                        <input type=\"text\"\r\n                                                            class=\"form-control dropdown-input cursor-pointer pe-5\"\r\n                                                            value=\"Clusters\" readonly placeholder=\"Select Clusters\" />\r\n\r\n\r\n                                                        <span *ngIf=\"getSelectedClustersCount()\"\r\n                                                            class=\"position-absolute top-50 end-0 translate-middle-y me-2 badge badge badge-light-default text-white rounded-pill px-2 py-0\">\r\n                                                            {{ getSelectedClustersCount() }}\r\n                                                        </span>\r\n                                                    </div>\r\n\r\n                                                    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"clusterOpen\">\r\n                                                        <input type=\"text\" class=\"form-control mb-2 dropdown-search\"\r\n                                                            placeholder=\"Search clusters\"\r\n                                                            [(ngModel)]=\"searchClusterText\"\r\n                                                            (ngModelChange)=\"filterClusters()\" />\r\n\r\n                                                        <div class=\"form-check ps-0 my-5\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                id=\"selectAllClusters\"\r\n                                                                [checked]=\"isAllClustersSelected()\"\r\n                                                                (change)=\"toggleSelectAllClusters($event)\" />\r\n                                                            <label class=\"form-check-label\"\r\n                                                                for=\"selectAllClusters\">Select All</label>\r\n                                                        </div>\r\n\r\n                                                        <div class=\"form-check mb-5 ps-0\"\r\n                                                            *ngFor=\"let cluster of filteredClusters\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                [id]=\"cluster._id\" [(ngModel)]=\"cluster.checked\"\r\n                                                                (change)=\"updateSelectedClusters()\" />\r\n                                                            <label class=\"form-check-label\" [for]=\"cluster._id\">{{\r\n                                                                cluster.clusterName }}</label>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n\r\n                                                <div class=\"d-flex gap-2 mt-3\">\r\n                                                    <button class=\"btn btn-outline btn-sm w-50\"\r\n                                                        (click)=\"Reset()\">Reset</button>\r\n                                                    <button class=\"btn btn-primary btn-sm w-50\"\r\n                                                        (click)=\"Apply()\">Apply</button>\r\n                                                </div>\r\n                                            </div>\r\n\r\n                                        </div>\r\n\r\n                                        <button type=\"button\" (click)=\"exportXLSX()\" *ngIf=\"!noData && !loading\"\r\n                                            class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg\r\n                                                xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                                                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.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n                                                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </svg><span class=\"ms-2\">Export</span> </button>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div *ngIf=\"loading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                                <div class=\"shimmer\">\r\n                                    <div class=\"wrapper\">\r\n                                        <div class=\"stroke animate title\"></div>\r\n                                        <div class=\"stroke animate link\"></div>\r\n                                        <div class=\"stroke animate description\"></div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"shimmer\">\r\n                                    <div class=\"wrapper\">\r\n                                        <div class=\"stroke animate title\"></div>\r\n                                        <div class=\"stroke animate link\"></div>\r\n                                        <div class=\"stroke animate description\"></div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <div *ngIf=\"noData\" class=\"row\">\r\n                                <div class=\"col-lg-12 mb-3\">\r\n                                    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                        <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                        <div class=\"nodata-title\">No data found</div>\r\n                                        <div class=\"nodata-sub\">There is no result for this eye test table</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <div *ngIf=\"!noData && !loading\" class=\"table-responsive\">\r\n                                <table class=\"w-100 table bottom-border text-nowrap\">\r\n                                    <thead>\r\n                                        <tr>\r\n                                            <th class=\"text-nowrap text-start\"> <span class=\"cursor-pointer\"\r\n                                                    > RM Name \r\n                                                </span></th>\r\n                                            <th class=\"text-nowrap text-start\"><span class=\"cursor-pointer\"\r\n                                                   > Cluster Name\r\n                                                </span></th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('optumId')\"> Optom ID <svg\r\n                                                        [ngClass]=\"sortedColumn === 'optumId' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'optumId' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('optomEmailId')\"> Optom\r\n                                                    Email <svg\r\n                                                        [ngClass]=\"sortedColumn === 'optomEmailId' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'optomEmailId' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n                                            <th class=\"text-nowrap text-start\"><span class=\"cursor-pointer\"\r\n                                                    (click)=\"onSort('storeName')\"> Store Name <svg\r\n                                                        [ngClass]=\"sortedColumn === 'storeName' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span></th>\r\n\r\n                                            <th class=\"text-nowrap text-start\"><span class=\"cursor-pointer\"\r\n                                                    (click)=\"onSort('auditedBy')\"> Audited By <svg\r\n                                                        [ngClass]=\"sortedColumn === 'auditedBy' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'auditedBy' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span></th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('complianceScore')\"> Tango\r\n                                                    Score <svg\r\n                                                        [ngClass]=\"sortedColumn === 'complianceScore' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'complianceScore' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('trustScore')\"> Trust Score\r\n                                                    <svg [ngClass]=\"sortedColumn === 'trustScore' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'trustScore' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('humanScore')\"> Human\r\n                                                    Audited Score <svg\r\n                                                        [ngClass]=\"sortedColumn === 'humanScore' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'humanScore' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n\r\n                                            <th class=\"text-nowrap text-start\">Action</th>\r\n                                        </tr>\r\n                                    </thead>\r\n                                    <tbody>\r\n                                        <tr *ngFor=\"let item of tableData\">\r\n                                            <td class=\"text-nowrap\">\r\n                                                <span class=\"rm-truncate\" [title]=\"item.RMName\">{{ item.RMName }}</span>\r\n                                            </td>\r\n                                            <td class=\"text-nowrap\">\r\n                                                <span class=\"rm-truncate\" [title]=\"item.cluster\">{{ item.cluster }}</span>\r\n                                            </td>\r\n                                            <td class=\"text-nowrap\">{{item.optumId}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.optomEmailId}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.storeName}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.auditedBy}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.complianceScore ?? \"--\" }}</td>\r\n                                            <td class=\"text-nowrap\">{{item.trustScore}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.humanScore}}</td>\r\n                                            <td class=\"text-nowrap\">\r\n                                                <button type=\"button\" [disabled]=\"!item.auditedId\"\r\n                                                    (click)=\"eyeTestView(item)\"\r\n                                                    class=\"btn btn-link p-0 m-0 border-0 bg-transparent\">\r\n                                                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                                                        viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M0.833252 9.99967C0.833252 9.99967 4.16658 3.33301 9.99992 3.33301C15.8333 3.33301 19.1666 9.99967 19.1666 9.99967C19.1666 9.99967 15.8333 16.6663 9.99992 16.6663C4.16658 16.6663 0.833252 9.99967 0.833252 9.99967Z\"\r\n                                                            stroke=\"#667085\" stroke-width=\"1.66667\"\r\n                                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                        <path\r\n                                                            d=\"M9.99992 12.4997C11.3806 12.4997 12.4999 11.3804 12.4999 9.99967C12.4999 8.61896 11.3806 7.49967 9.99992 7.49967C8.61921 7.49967 7.49992 8.61896 7.49992 9.99967C7.49992 11.3804 8.61921 12.4997 9.99992 12.4997Z\"\r\n                                                            stroke=\"#667085\" stroke-width=\"1.66667\"\r\n                                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                    </svg>\r\n                                                </button>\r\n                                            </td>\r\n                                    </tbody>\r\n                                </table>\r\n                            </div>\r\n                            <div class=\"card-footer\" *ngIf=\"!noData && !loading\">\r\n                                <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"offset\"\r\n                                    [totalItems]=\"totalItems\" [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\"\r\n                                    (pageChange)=\"onPageChange($event)\"\r\n                                    (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n                            </div>\r\n                        </ng-template>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>"]}
823
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"settings-audit.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/eye-test-audit/settings-audit/settings-audit.component.ts","../../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/eye-test-audit/settings-audit/settings-audit.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGL,SAAS,EAET,YAAY,GAKb,MAAM,eAAe,CAAC;AAMvB,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,iBAAiB,CAAC;AAGzB,gDAAgD;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;;;;;;;;;;AAO3C,MAAM,OAAO,sBAAsB;IAKvB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IAZV,OAAO,CAAM;IACb,KAAK,GAAG,KAAK,CAAC;IACd,cAAc,CAAY;IAC1B,YACU,EAAqB,EACrB,IAAY,EACZ,EAAe,EACf,QAAyB,EACzB,YAA0B,EAC1B,KAAqB,EACrB,IAAyB,EACzB,YAAsB,EACtB,MAAc;QARd,OAAE,GAAF,EAAE,CAAmB;QACrB,SAAI,GAAJ,IAAI,CAAQ;QACZ,OAAE,GAAF,EAAE,CAAa;QACf,aAAQ,GAAR,QAAQ,CAAiB;QACzB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,UAAK,GAAL,KAAK,CAAgB;QACrB,SAAI,GAAJ,IAAI,CAAqB;QACzB,iBAAY,GAAZ,YAAY,CAAU;QACtB,WAAM,GAAN,MAAM,CAAQ;IACrB,CAAC;IAEJ,cAAc,CAAC,KAAiB;QAC9B,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAC5D,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QAE3C,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;YAC3B;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,wBAAwB;gBAC9B,QAAQ,EAAE,KAAK;gBACf,WAAW,EAAE,KAAK;aACnB;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,wBAAwB;gBAC9B,QAAQ,EAAE,KAAK;gBACf,WAAW,EAAE,IAAI;aAClB;SACF,CAAC,CAAC;IACL,CAAC;IACD,UAAU,GAAQ;QAChB;YACE,EAAE,EAAE,0BAA0B;YAC9B,QAAQ,EAAE,gBAAgB;YAC1B,KAAK,EAAE,4BAA4B;YACnC,IAAI,EAAE,OAAO;SACd;QACD;YACE,EAAE,EAAE,0BAA0B;YAC9B,QAAQ,EAAE,UAAU;YACpB,KAAK,EAAE,sBAAsB;YAC7B,IAAI,EAAE,SAAS;SAChB;KACF,CAAC;IACF,KAAK,CAAM;IACX,SAAS,CAAM;IACf,gBAAgB,CAAM;IACtB,QAAQ;QACN,MAAM,QAAQ,GAAQ,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,CAAC;QAC5E,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;QACtB,MAAM,OAAO,GAAQ,IAAI,CAAC,KAAK,CAC7B,YAAY,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,IAAI,CAC/C,CAAC;QACF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACvC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YAC1B,CAAC,CAAC,OAAO,CAAC;QACZ,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAClC,SAAS,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAC5C,UAAU,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;SAC9C,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,0BAA0B;QAC1B,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG;YACf;gBACE,MAAM,EAAE,QAAQ;gBAChB,WAAW,EAAE,MAAM;gBACnB,OAAO,EAAE,QAAQ;gBACjB,SAAS,EAAE,UAAU;gBACrB,UAAU,EAAE,IAAI;gBAChB,UAAU,EAAE,IAAI;aACjB;YACD;gBACE,MAAM,EAAE,MAAM;gBACd,WAAW,EAAE,KAAK;gBAClB,OAAO,EAAE,QAAQ;gBACjB,SAAS,EAAE,UAAU;gBACrB,UAAU,EAAE,IAAI;gBAChB,UAAU,EAAE,IAAI;aACjB;YACD;gBACE,MAAM,EAAE,KAAK;gBACb,WAAW,EAAE,MAAM;gBACnB,OAAO,EAAE,QAAQ;gBACjB,SAAS,EAAE,UAAU;gBACrB,UAAU,EAAE,IAAI;gBAChB,UAAU,EAAE,IAAI;aACjB;YACD;gBACE,MAAM,EAAE,UAAU;gBAClB,WAAW,EAAE,SAAS;gBACtB,OAAO,EAAE,QAAQ;gBACjB,SAAS,EAAE,UAAU;gBACrB,UAAU,EAAE,IAAI;gBAChB,UAAU,EAAE,IAAI;aACjB;SACF,CAAC;QACF,yCAAyC;QACzC,oEAAoE;QACpE,2BAA2B;QAC3B,yBAAyB;QACzB,uBAAuB;QACvB,OAAO;QACP,KAAK;QACL,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC1C,oCAAoC;YACpC,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;YACvC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IACgB,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;IAC1C,eAAe,GAAQ,EAAE,CAAC;IAC1B,YAAY,CAAM;IAClB,SAAS,CAAM;IACf,eAAe;QACb,qCAAqC;QACrC,IAAI,OAAO,GAAG;YACZ,EAAE,EAAE,IAAI,CAAC,OAAO;YAChB,IAAI,EAAE,IAAI,CAAC,gBAAgB;SAC5B,CAAC;QACF,IAAI,CAAC,IAAI;aACN,eAAe,CAAC,OAAO,CAAC;aACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE;oBAC3B,8BAA8B;oBAC9B,IAAI,CAAC,YAAY,GAAG,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC;oBACtC,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,KAAK,aAAa,EAAE;wBACnD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;qBACvB;yBAAM;wBACL,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;qBACxB;oBACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC;oBAChD,mBAAmB;oBACnB,2BAA2B;oBAC3B,SAAS;oBACT,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;iBACzB;YACH,CAAC;SACF,CAAC,CAAC;QAEL,mCAAmC;IACrC,CAAC;IAED,QAAQ,CAAC,KAAU,IAAG,CAAC;IAEvB,eAAe;IAEf,cAAc;QACZ,IAAI,CAAC,IAAI,CAAC,eAAe,GAAG;YAC1B,IAAI,EAAE,MAAM;YACZ,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,oBAAoB,CAAC,EAAE;YAC3C,WAAW,EAAE;gBACX,IAAI,EAAE,IAAI,CAAC,KAAK,CACd,IAAI,CAAC,YAAY,EAAE,QAAQ;oBACzB,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ;oBAC7B,CAAC,CAAC,IAAI,CAAC,eAAe,CACzB,CAAC,MAAM,CAAC,YAAY,CAAC;gBACtB,SAAS,EAAE,UAAU;aACtB;SACF,CAAC,CAAC;IACL,CAAC;IACD,2BAA2B,CAAM;IACjC,4BAA4B,CAAM;IAClC,oBAAoB,GAAG;QACrB,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;QAC5B,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE;QAC1B,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;QAC5B,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE;QAC1B,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE;KAC3B,CAAC;IACF,oBAAoB,GAAG;QACrB,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE;QAC9B,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;KACjC,CAAC;IAEF,iBAAiB,GAAQ;QACvB,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;QAC5C,OAAO,EAAE,IAAI,CAAC,KAAK,EAAE;KACtB,CAAC;IACF,eAAe,GAAQ,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IAC9E,aAAa,GAAQ,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IAE3E,MAAM,GAAQ;QACZ,KAAK,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;QACnC,SAAS,EAAE;YACT,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC;YAChC,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC;SACjC;QACD,WAAW,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;QAC7D,WAAW,EAAE;YACX,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;YACjD,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;SAC/C;QACD,YAAY,EAAE;YACZ,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;YACjC,IAAI,CAAC,KAAK,EAAE;SACb;QACD,YAAY,EAAE;YACZ,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;YAClD,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;SACjD;KACF,CAAC;IAEF,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,EAAE;YACpC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YACxE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YACpE,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAED,UAAU;QACR,MAAM,WAAW,GAAG;YACjB,QAAQ,EAAE,IAAI,CAAC,eAAe;YAC/B,MAAM,EAAE,IAAI,CAAC,aAAa;YAC1B,0DAA0D;YAC1D,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;YACxD,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM;gBAC9B,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM;gBACxB,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ;YACxB,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE,MAAM;gBACpC,CAAC,CAAC,IAAI,CAAC,gBAAgB;gBACvB,CAAC,CAAC,EAAE;YACN,QAAQ,EAAE,IAAI;YACd,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;YACzD,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAC9C,MAAM,EAAE,CAAC;YACT,KAAK,EAAE,KAAK;SACb,CAAC;QAEF,IAAI,CAAC,IAAI;aACN,iBAAiB,CAAC,WAAW,CAAC;aAC9B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,IAAI,CAAC,eAAe,CACvB,GAAG,EACH,GAAG,IAAI,CAAC,gBAAgB,kBAAkB,CAC3C,CAAC;gBACF,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,IAAI,CAAC,YAAY,CAAC,aAAa,CAC7B,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAC5D,CAAC;YACJ,CAAC;SACF,CAAC,CAAC;IAEP,CAAC;IAED,WAAW,CAAM;IACnB,UAAU;QACN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,SAAS,GAAQ,EAAE,CAAC;IAEpB,YAAY,CAAM;IAClB,SAAS,CAAM;IACf,MAAM,CAAC,MAAc;QACnB,IAAI,IAAI,CAAC,YAAY,KAAK,MAAM,EAAE;YAChC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SAChD;aAAM;YACL,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;YAChD,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;SACpB;QACD,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IACD,QAAQ,CAAM;IACd,OAAO;QACL,IAAI,GAAG,GAAG;YACR,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC;YAC/B,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ;YAC9B,QAAQ,EAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ;SAChF,CAAC;QAEF,IAAI,CAAC,IAAI;aACN,WAAW,CAAC,GAAG,CAAC;aAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtB,IAAI,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE;gBAC3B,IAAI,CAAC,QAAQ,GAAG,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;oBACrD,EAAE,EAAE,IAAI,CAAC,GAAG;oBACZ,IAAI,EAAE,IAAI,CAAC,KAAK;iBACjB,CAAC,CAAC,CAAC;gBAEJ,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,+BAA+B;gBACrD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,UAAU,CAAM;IAEhB,WAAW,CAAC,aAAkB;QAC5B,IAAI,CAAC,UAAU,GAAG,aAAa,CAAC;IAClC,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,2CAA2C;YAC3C,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC;YAC5C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;aAAM;YACL,iDAAiD;YACjD,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC;YAC5C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACvB;IACH,CAAC;IAED,UAAU;QACR,kCAAkC;QAClC,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACD,QAAQ,GAAG,KAAK,CAAC;IACjB,YAAY;QACV,MAAM,OAAO,GAAG;YACd,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM;YAChC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC;gBACzC,GAAG,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,KAAK;gBACpB,KAAK,EAAE,CAAC,CAAC,IAAI;aACd,CAAC,CAAC;SACJ,CAAC;QAEF,IAAI,CAAC,IAAI;aACN,gBAAgB,CAAC,OAAO,CAAC;aACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE;oBAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;oBACrB,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC,0CAA0C,CAAC,CAAC;oBAC5G,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;iBACvB;qBAAM;oBACL,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,yBAAyB,CAAC,CAAC;iBAC5D;gBACD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACX,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;YACnG,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,mBAAmB;IACnB,cAAc,GAAQ,EAAE,CAAC;IACzB,eAAe,CAAM;IACrB,aAAa;QACX,IAAI,CAAC,IAAI;aACN,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC;aACzC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtB,IAAI,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE;gBAC3B,iBAAiB;gBACjB,IAAI,CAAC,UAAU;oBACb,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;wBAC/C,EAAE,EAAE,IAAI,CAAC,GAAG;wBACZ,IAAI,EAAE,IAAI,CAAC,KAAK;qBACjB,CAAC,CAAC,IAAI,EAAE,CAAC;gBACZ,IAAI,CAAC,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;gBAE5C,4BAA4B;gBAC5B,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;gBAEnE,kDAAkD;gBAClD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CACxC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CACnC,CAAC;gBAEF,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,oCAAoC;IACpC,eAAe,CAAM;IACrB,SAAS,GAAG,IAAI,CAAC;IACjB,WAAW;QACT,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;IAC/B,CAAC;IACD,cAAc;QACZ,IAAI,CAAC,IAAI;aACN,kBAAkB,CACjB,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CACvE;aACA,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtB,IAAI,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE;gBAC3B,IAAI,CAAC,eAAe,GAAG,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC;gBAEzC,0CAA0C;gBAC1C,wCAAwC;gBACxC,MAAM,WAAW,GAAG;oBAClB,SAAS,EAAE,IAAI,CAAC,eAAe,EAAE,mBAAmB,EAAE,SAAS;oBAC/D,UAAU,EAAE,IAAI,CAAC,eAAe,EAAE,mBAAmB,EAAE,KAAK;iBAC7D,CAAC;gBAEF,iCAAiC;gBACjC,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;gBAC5C,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,mBAAmB,CAAM;IACzB,gBAAgB;QACd,IAAI,IAAI,CAAC,cAAc,CAAC,OAAO;YAAE,OAAO;QACxC,MAAM,OAAO,GAAG;YACd,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM;YAChC,mBAAmB,EAAE;gBACnB,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS;gBAC9C,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,UAAU;aAC5C;SACF,CAAC;QAEF,IAAI,CAAC,IAAI;aACN,iBAAiB,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE,OAAO,CAAC;aACrD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAG,EAAE,EAAE;gBACZ,IAAI,CAAC,YAAY,CAAC,eAAe,CAC/B,GAAG,EAAE,OAAO;oBACV,CAAC,CAAC,qBAAqB,GAAG,GAAG,EAAE,OAAO;oBACtC,CAAC,CAAC,0CAA0C,CAC/C,CAAC;gBACF,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,kBAAkB;gBACzC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;gBAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gBACtB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;YAC1B,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,gBAAgB,EAAE,GAAG,CAAC;SACrD,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;QAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IACD,MAAM;IACN,sBAAsB;IACtB,WAAW,GAAU,EAAE,CAAC;IACxB,YAAY,GAAG,EAAE,CAAC;IAElB,WAAW;IACX,WAAW,GAAU,EAAE,CAAC;IACxB,gBAAgB,GAAU,EAAE,CAAC;IAC7B,iBAAiB,GAAG,EAAE,CAAC;IAEvB,YAAY;IACZ,YAAY,GAAG,KAAK,CAAC;IACrB,YAAY,GAAkB,IAAI,CAAC;IAEnC,sBAAsB;IACtB,YAAY;QACV,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;IACzC,CAAC;IACD,aAAa;QACX,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IACD,MAAM,GAAG,KAAK,CAAC;IACf,WAAW,GAAG,KAAK,CAAC;IAEpB,gBAAgB;QACd,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,cAAc;IAC1C,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,cAAc;IACrC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IACH,MAAM,GAAS;QACb;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,QAAQ;YAClB,KAAK,EAAE,+BAA+B;YACtC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,eAAe;YACzB,KAAK,EAAE,4BAA4B;YACnC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,iBAAiB;YAC3B,KAAK,EAAE,6BAA6B;YACpC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,aAAa;YACvB,KAAK,EAAE,0BAA0B;YACjC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,cAAc;YACxB,KAAK,EAAE,iCAAiC;YACxC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,YAAY;YACtB,KAAK,EAAE,4BAA4B;YACnC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,eAAe;YACzB,KAAK,EAAE,2BAA2B;YAClC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,gBAAgB;YAC1B,KAAK,EAAE,gCAAgC;YACvC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,GAAG;YACR,QAAQ,EAAE,iBAAiB;YAC3B,KAAK,EAAE,0BAA0B;YACjC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,IAAI;YACT,QAAQ,EAAE,iBAAiB;YAC3B,KAAK,EAAE,6BAA6B;YACpC,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,IAAI;YACT,QAAQ,EAAE,aAAa;YACvB,KAAK,EAAE,wBAAwB;YAC/B,IAAI,EAAE,OAAO;SACd;QACD;YACE,GAAG,EAAE,IAAI;YACT,QAAQ,EAAE,cAAc;YACxB,KAAK,EAAE,4BAA4B;YACnC,IAAI,EAAE,OAAO;SACd;KACF,CAAC;IACA,oBAAoB;IACpB,QAAQ;QACN,wEAAwE;QACxE,6BAA6B;QAC7B,oDAAoD;QACpD,0BAA0B;QAC1B,6BAA6B;QACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,mBAAmB;QAC3F,IAAI,CAAC,WAAW,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;QACpC,gBAAgB;QAChB,kCAAkC;QAClC,gBAAgB;QAChB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC9C,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QACP,MAAM;QACN,MAAM;IACR,CAAC;IAED,SAAS;QACP,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAC1C,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAC1C,CAAC;IACJ,CAAC;IAED,gBAAgB;QACd,OAAO,CACL,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CACxE,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,KAAU;QAC3B,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;QACrC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;QAC3D,IAAI,CAAC,iBAAiB,EAAE,CAAC;IACvB,CAAC;IAED,iBAAiB;QACf,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QACtD,wDAAwD;QACxD,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;YAC3C,qCAAqC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAEH,gBAAgB;QACd,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;QAC3D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QACrC,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC9B,CAAC;IACD,mBAAmB;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC;IAC1D,CAAC;IACC,yBAAyB;IAC3B,gCAAgC;IAChC,+BAA+B;IAE/B,yBAAyB;IACzB,0CAA0C;IAC1C,4CAA4C;IAC5C,oCAAoC;IACpC,MAAM;IAEN,mBAAmB;IACnB,wFAAwF;IACxF,cAAc;IACd,OAAO;IAEP,yDAAyD;IACzD,+BAA+B;IAC/B,kDAAkD;IAClD,sEAAsE;IACtE,gBAAgB;IAChB,wBAAwB;IACxB,aAAa;IACb,uDAAuD;IACvD,eAAe;IACf,+BAA+B;IAC/B,oCAAoC;IACpC,QAAQ;IACR,QAAQ;IACR,IAAI;IAEF,mBAAmB,CAAC,KAAa;QAC/B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,MAAM,GAAa,EAAE,CAAC;YAE1B,IAAI,KAAK,EAAE,MAAM,EAAE;gBACjB,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;aACpC;iBAAM,IAAI,IAAI,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,EAAE;gBACpC,MAAM,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;aAC9B;YAED,MAAM,GAAG,GAAG;gBACV,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,IAAI,IAAI,CAAC,KAAK,EAAE,QAAQ;gBACxD,MAAM;aACP,CAAC;YAEF,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;gBACnC,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;oBACjB,IAAI,GAAG,EAAE,IAAI,KAAK,GAAG,EAAE;wBACrB,IAAI,CAAC,WAAW,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC;4BAC1D,GAAG,CAAC;4BACJ,OAAO,EAAE,IAAI;yBACd,CAAC,CAAC,CAAC;wBACJ,IAAI,CAAC,gBAAgB,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;qBAC/C;yBAAM;wBACL,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;wBACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;qBAC5B;oBACD,OAAO,EAAE,CAAC,CAAC,aAAa;gBAC1B,CAAC;gBACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC;aAC5B,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEH,cAAc;QACZ,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;QACpD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CACpD,CAAC,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAC7C,CAAC;IACJ,CAAC;IAED,qBAAqB;QACnB,OAAO,CACL,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAC9C,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,KAAU;QAChC,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;QACrC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;QAC5D,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW;aACrC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;aACtB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,6BAA6B;IACnD,CAAC;IAED,qBAAqB;QACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAC3D,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QACrC,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IACjC,CAAC;IAED,wBAAwB;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC;QACtD,wDAAwD;IAC1D,CAAC;IAEC,8BAA8B;IAC9B,KAAK;QACF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,QAAQ,EAAE,CAAC;QACZ,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC3B,YAAY;QACZ,mBAAmB;IACvB,CAAC;IACD,WAAW,GAAQ,EAAE,CAAC;IACtB,gBAAgB,GAAQ,EAAE,CAAC;IAC3B,KAAK;QACH,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC5E,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,CACnE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CACrB,CAAC;QACF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,SAAS,CACvC,IAAI,CAAC,eAAe,EACpB,YAAY,CACb,CAAC;SACH;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;SAC3E;IACH,CAAC;IACD,MAAM,GAAG,CAAC,CAAC;IACX,KAAK,GAAG,EAAE,CAAC;IACb,QAAQ,GAAG,EAAE,CAAC;IACd,eAAe,GAAG,CAAC,EAAE,EAAC,EAAE,EAAC,EAAE,CAAC,CAAC;IAC7B,UAAU,GAAG,CAAC,CAAC;IACb,kBAAkB;QAChB,IAAI,IAAI,CAAC,UAAU,GAAG,EAAE,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;SACrC;aAAM;YACL,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,kCAAkC;SAC7E;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC;IACD,OAAO,GAAG,KAAK,CAAC;IAChB,MAAM,GAAG,KAAK,CAAC;IACf,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,GAAG,GAAG;YACR,QAAQ,EAAE,IAAI,CAAC,eAAe;YAC9B,MAAM,EAAE,IAAI,CAAC,aAAa;YAC1B,+BAA+B;YAC/B,MAAM,EAAE,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;YACxD,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM;gBAC9B,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM;gBACxB,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ;YACxB,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE,MAAM;gBACpC,CAAC,CAAC,IAAI,CAAC,gBAAgB;gBACvB,CAAC,CAAC,EAAE;YACN,QAAQ,EAAE,KAAK;YACf,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;YACzD,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAC9C,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;SAClB,CAAC;QACF,IAAI,CAAC,IAAI;aACN,WAAW,CAAC,GAAG,CAAC;aAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,EAAE,IAAI,IAAI,GAAG,EAAE;oBAC3B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;oBACjC,IAAI,CAAC,UAAU,GAAG,GAAG,EAAE,IAAI,EAAE,KAAK,IAAI,CAAC,CAAC;oBACxC,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC1B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;iBACrB;qBAAM;oBACL,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;oBACpB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;oBACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;iBACrB;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;gBACpB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;gBACpB,OAAO,CAAC,KAAK,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;YACvC,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAEH,YAAY,CAAC,IAAY;QACvB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,uBAAuB;IAC1C,CAAC;IAED,gBAAgB,CAAC,IAAY;QAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAG,6CAA6C;QAChE,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAEC,WAAW,CAAC,IAAS;QACnB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAE7B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,0BAA0B,CAAC,EAAE;YACjD,WAAW,EAAE;gBACX,IAAI,EAAE,IAAI,CAAC,gBAAgB;gBAC3B,OAAO,EAAE,IAAI,EAAE,OAAO;gBACtB,GAAG,EAAE,IAAI,CAAC,SAAS;gBACnB,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;gBAC3C,OAAO,EAAC,IAAI,EAAE,OAAO;gBACrB,OAAO,EAAC,IAAI,EAAE,OAAO;aACtB;SACF,CAAC,CAAC;QACH,IAAI,KAAK,GAAQ,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,CAAC;QAC5E,KAAK,CAAC,IAAI,GAAG;YACb,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE,QAAQ;YACtC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,QAAQ;SACrC,CAAC;QACG,YAAY,CAAC,OAAO,CAAC,gBAAgB,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IACjE,CAAC;wGAh2BU,sBAAsB;4FAAtB,sBAAsB,+HC7BnC,yhwCAyeU;;4FD5cG,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;ySAoB9B,cAAc;sBADb,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { PageInfoService } from \"tango-app-ui-global\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { EyeTestAuditService } from \"../../services/eye-test-audit.service\";\r\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { any } from \"@amcharts/amcharts5/.internal/core/util/Array\";\r\nimport { FormBuilder, FormGroup } from \"@angular/forms\";\r\n// import * as Plotly from 'plotly.js-dist-min';\r\nimport { DatePipe } from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: \"lib-settings-audit\",\r\n  templateUrl: \"./settings-audit.component.html\",\r\n  styleUrl: \"./settings-audit.component.scss\",\r\n})\r\nexport class SettingsAuditComponent implements OnInit {\r\n  AuditId: any;\r\n  dayjs = dayjs;\r\n  complianceForm: FormGroup;\r\n  constructor(\r\n    private cd: ChangeDetectorRef,\r\n    private zone: NgZone,\r\n    private fb: FormBuilder,\r\n    private pageInfo: PageInfoService,\r\n    private toastService: ToastService,\r\n    private route: ActivatedRoute,\r\n    private $api: EyeTestAuditService,\r\n    private modalService: NgbModal,\r\n    private router: Router,\r\n  ) {}\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if (!target.closest('.dropdown2') && !target.closest('.btn')) {\r\n      this.closeDropdown();\r\n    }\r\n  }\r\n  setPageData() {\r\n    this.pageInfo.setTitle(\"Audit - Eye Test\");\r\n\r\n    this.pageInfo.setBreadcrumbs([\r\n      {\r\n        title: \"Tango Trax\",\r\n        path: \"/manage/trax/dashboard\",\r\n        isActive: false,\r\n        isSeparator: false,\r\n      },\r\n      {\r\n        title: \"Tango Trax\",\r\n        path: \"/manage/trax/dashboard\",\r\n        isActive: false,\r\n        isSeparator: true,\r\n      },\r\n    ]);\r\n  }\r\n  alertUsers: any = [\r\n    {\r\n      id: \"6687d9d1a27ee88f9a4457cb\",\r\n      userName: \"Ajinkya Malshe\",\r\n      email: \"ajinkya.malshe@yopmail.com\",\r\n      role: \"admin\",\r\n    },\r\n    {\r\n      id: \"6687d9d1a27ee88f9a4457cc\",\r\n      userName: \"John Doe\",\r\n      email: \"john.doe@yopmail.com\",\r\n      role: \"manager\",\r\n    },\r\n  ];\r\n  users: any;\r\n  auditData: any;\r\n  currentAuditType: any;\r\n  ngOnInit(): void {\r\n    const userData: any = JSON.parse(localStorage.getItem(\"user-info\") || \"{}\");\r\n    this.users = userData;\r\n    const headers: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    this.auditData = this.$api.getAuditData()\r\n      ? this.$api.getAuditData()\r\n      : headers;\r\n    this.complianceForm = this.fb.group({\r\n      threshold: [{ value: null, disabled: true }],\r\n      percentage: [{ value: null, disabled: true }],\r\n    });\r\n\r\n    this.getUser();\r\n    this.getEmailConfig();\r\n    this.getAllRm();\r\n    // this.buildDataObject();\r\n    this.cd.detectChanges();\r\n    this.setPageData();\r\n    this.tableData = [\r\n      {\r\n        rmName: \"Olivia\",\r\n        clusterName: \"John\",\r\n        optumId: \"OPT001\",\r\n        storeName: \"LKST1001\",\r\n        tangoScore: \"9%\",\r\n        trustScore: \"9%\",\r\n      },\r\n      {\r\n        rmName: \"Emma\",\r\n        clusterName: \"Doe\",\r\n        optumId: \"OPT002\",\r\n        storeName: \"LKST1002\",\r\n        tangoScore: \"8%\",\r\n        trustScore: \"8%\",\r\n      },\r\n      {\r\n        rmName: \"Ava\",\r\n        clusterName: \"Smit\",\r\n        optumId: \"OPT003\",\r\n        storeName: \"LKST1003\",\r\n        tangoScore: \"7%\",\r\n        trustScore: \"7%\",\r\n      },\r\n      {\r\n        rmName: \"Isabella\",\r\n        clusterName: \"Johnson\",\r\n        optumId: \"OPT004\",\r\n        storeName: \"LKST1004\",\r\n        tangoScore: \"6%\",\r\n        trustScore: \"6%\",\r\n      },\r\n    ];\r\n    // this.alertUsers = this.alertUsers.map(\r\n    //   (user: { userName: string; email: string; role: string }) => ({\r\n    //     name: user.userName,\r\n    //     value: user.email,\r\n    //     role: user.role,\r\n    //   })\r\n    // );\r\n    this.route.queryParams.subscribe((params) => {\r\n      // this.storeId = params['storeId'];\r\n      this.currentAuditType = params[\"type\"];\r\n      this.AuditId = params[\"_id\"];\r\n    });\r\n    this.getAuditdetails();\r\n  }\r\n  private readonly destroy$ = new Subject();\r\n  stepWiseProcess: any = [];\r\n  auditDetails: any;\r\n  takeAudit: any;\r\n  getAuditdetails() {\r\n    // this.tableLoading.next('loading');\r\n    let payload = {\r\n      id: this.AuditId,\r\n      type: this.currentAuditType,\r\n    };\r\n    this.$api\r\n      .getAuditdetails(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            // this.disablecancel =  false\r\n            this.auditDetails = res?.data?.result;\r\n            if (this.auditDetails.auditStatus === \"In-Progress\") {\r\n              this.takeAudit = true;\r\n            } else {\r\n              this.takeAudit = false;\r\n            }\r\n            this.stepWiseProcess = this.auditDetails?.steps;\r\n            // setTimeout(()=>{\r\n            //   this.getAuditHistory()\r\n            // },100)\r\n            this.cd.detectChanges();\r\n          }\r\n        },\r\n      });\r\n\r\n    // this.tableLoading.next('loaded')\r\n  }\r\n\r\n  openItem(event: any) {}\r\n\r\n  // component.ts\r\n\r\n  backNavigation() {\r\n    this.$api.auditFilterData = {\r\n      back: \"back\",\r\n      auditDetails: this.auditDetails,\r\n    };\r\n    this.router.navigate([\"/manage/trax/audit\"], {\r\n      queryParams: {\r\n        date: this.dayjs(\r\n          this.auditDetails?.fileDate\r\n            ? this.auditDetails?.fileDate\r\n            : this.filterStartDate\r\n        ).format(\"YYYY-MM-DD\"),\r\n        typeValue: \"physical\",\r\n      },\r\n    });\r\n  }\r\n  selectedComplianceThreshold: any;\r\n  selectedCompliancePercentage: any;\r\n  complianceThresholds = [\r\n    { value: \"<=\", label: \"<=\" },\r\n    { value: \"<\", label: \"<\" },\r\n    { value: \">=\", label: \">=\" },\r\n    { value: \">\", label: \">\" },\r\n    { value: \"=\", label: \"=\" },\r\n  ];\r\n  compliancePercentage = [\r\n    { value: \"10%\", label: \"10%\" },\r\n    { value: \"20%\", label: \"20%\" },\r\n    { value: \"30%\", label: \"30%\" },\r\n    { value: \"40%\", label: \"40%\" },\r\n    { value: \"50%\", label: \"50%\" },\r\n    { value: \"60%\", label: \"60%\" },\r\n    { value: \"70%\", label: \"70%\" },\r\n    { value: \"80%\", label: \"80%\" },\r\n    { value: \"90%\", label: \"90%\" },\r\n    { value: \"100%\", label: \"100%\" },\r\n  ];\r\n\r\n  selectedDateRange: any = {\r\n    startDate: this.dayjs().subtract(30, \"days\"),\r\n    endDate: this.dayjs(),\r\n  };\r\n  filterStartDate: any = this.dayjs().subtract(30, \"days\").format(\"YYYY-MM-DD\");\r\n  filterEndDate: any = this.dayjs().subtract(0, \"days\").format(\"YYYY-MM-DD\");\r\n\r\n  ranges: any = {\r\n    Today: [this.dayjs(), this.dayjs()],\r\n    Yesterday: [\r\n      this.dayjs().subtract(1, \"days\"),\r\n      this.dayjs().subtract(1, \"days\"),\r\n    ],\r\n    \"This Week\": [this.dayjs().subtract(6, \"days\"), this.dayjs()],\r\n    \"Last Week\": [\r\n      this.dayjs().subtract(13, \"days\").startOf(\"days\"),\r\n      this.dayjs().subtract(7, \"days\").endOf(\"days\"),\r\n    ],\r\n    \"This Month\": [\r\n      this.dayjs().subtract(30, \"days\"), // Start date is 30 days before today\r\n      this.dayjs(),\r\n    ],\r\n    \"Last Month\": [\r\n      this.dayjs().subtract(1, \"month\").startOf(\"month\"),\r\n      this.dayjs().subtract(1, \"month\").endOf(\"month\"),\r\n    ],\r\n  };\r\n\r\n  datechange(event: any) {\r\n    if (event.startDate || event.endDate) {\r\n      this.filterStartDate = this.dayjs(event.startDate).format(\"YYYY-MM-DD\");\r\n      this.filterEndDate = this.dayjs(event.endDate).format(\"YYYY-MM-DD\");\r\n      this.Apply();\r\n    }\r\n  }\r\n\r\n  exportXLSX() {\r\n    const requestData = {\r\n       fromDate: this.filterStartDate,\r\n      toDate: this.filterEndDate,\r\n      // type: this.currentAuditType,  it is shows only physical\r\n      RMList: this.selectedRms?.length ? this.selectedRms : [],\r\n      clientId: this.auditData?.client\r\n        ? this.auditData?.client\r\n        : this.users?.clientId,\r\n      cluster: this.selectedClusters?.length\r\n        ? this.selectedClusters\r\n        : [],\r\n      isExport: true,\r\n      searchValue: this.searchValue,\r\n      sortBy: this.sortedColumn ? this.sortedColumn : \"RMEmail\",\r\n      sortOrder: this.sortOrder ? this.sortOrder : 1,\r\n      offset: 1,\r\n      limit: 10000,\r\n    };\r\n\r\n    this.$api\r\n      .getEmailLogExport(requestData)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          this.$api.saveAsExcelFile(\r\n            res,\r\n            `${this.currentAuditType} Eye Test Table `\r\n          );\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err: any) => {\r\n          this.toastService.getErrorToast(\r\n            err?.error?.error ? err?.error?.error : err?.error?.message\r\n          );\r\n        },\r\n      });\r\n  \r\n  }\r\n\r\n  searchValue: any;\r\nsearchData() {\r\n    this.searchValue = this.searchValue;\r\n    this.getEmail();\r\n  }\r\n\r\n  tableData: any = [];\r\n\r\n  sortedColumn: any;\r\n  sortOrder: any;\r\n  onSort(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortOrder = this.sortOrder === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortedColumn = column ? column : \"RMEmail\";\r\n      this.sortOrder = 1;\r\n    }\r\n    this.getEmail();\r\n  }\r\n  allUsers: any;\r\n  getUser() {\r\n    let obj = {\r\n      userType: 'client',\r\n      filterByRole: [\"admin\", \"user\"],\r\n      isActive: this.users?.isActive,\r\n      clientId:this.auditData?.client ? this.auditData?.client : this.users?.clientId\r\n    };\r\n\r\n    this.$api\r\n      .getuserList(obj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res: any) => {\r\n        if (res && res?.code == 200) {\r\n          this.allUsers = res?.data?.result?.map((item: any) => ({\r\n            id: item._id,\r\n            name: item.email,\r\n          }));\r\n\r\n          this.getUserConfig(); // call after allUsers is ready\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  configData: any;\r\n\r\n  updateOwner(selectedEmail: any) {\r\n    this.configData = selectedEmail;\r\n  }\r\n\r\n  toggleEdit() {\r\n    if (!this.editMode) {\r\n      // entering edit mode → make a working copy\r\n      this.configData = [...this.lastSavedConfig];\r\n      this.editMode = true;\r\n    } else {\r\n      // leaving edit without saving → restore baseline\r\n      this.configData = [...this.lastSavedConfig];\r\n      this.editMode = false;\r\n    }\r\n  }\r\n\r\n  cancelEdit() {\r\n    // revert back to last saved state\r\n    this.configData = [...this.lastSavedConfig];\r\n    this.editMode = false;\r\n  }\r\n  editMode = false;\r\n  submitOwners() {\r\n    const payload = {\r\n      clientId: this.auditData?.client, // or this.clientId\r\n      userList: this.configData.map((o: any) => ({\r\n        _id: o.id ?? o.value, // ✅ support both cases\r\n        email: o.name,\r\n      })),\r\n    };\r\n\r\n    this.$api\r\n      .updateUserConfig(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            this.getUserConfig();\r\n            this.toastService.getSuccessToast(res?.message ? res?.message : \"Email configuration updated successfully\");\r\n            this.editMode = false;\r\n          } else {\r\n            this.toastService.getErrorToast(\"Failed to update owners\");\r\n          }\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err) => {\r\n            this.toastService.getSuccessToast(err?.error?.error ? err?.error?.error : err?.error?.message);\r\n        },\r\n      });\r\n  }\r\n\r\n  // this.onSubmit();\r\n  userConfigList: any = [];\r\n  lastSavedConfig: any;\r\n  getUserConfig() {\r\n    this.$api\r\n      .getUserConfigList(this.auditData?.client)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res: any) => {\r\n        if (res && res?.code == 200) {\r\n          // Assigned users\r\n          this.configData =\r\n            res?.data?.result?.userList?.map((item: any) => ({\r\n              id: item._id,\r\n              name: item.email,\r\n            })) ?? [];\r\n          this.lastSavedConfig = [...this.configData];\r\n\r\n          // Build set of assigned ids\r\n          const assignedIds = new Set(this.configData.map((u: any) => u.id));\r\n\r\n          // Filter from allUsers (not from userConfigList!)\r\n          this.userConfigList = this.allUsers.filter(\r\n            (u: any) => !assignedIds.has(u.id)\r\n          );\r\n\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  // email congig method and variables\r\n  emailConfigList: any;\r\n  editMode1 = true;\r\n  toggleEdit1() {\r\n    this.editMode1 = false;\r\n    this.complianceForm.enable();\r\n  }\r\n  getEmailConfig() {\r\n    this.$api\r\n      .getEmailConfigList(\r\n        this.auditData?.client ? this.auditData?.client : this.users?.clientId\r\n      )\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res: any) => {\r\n        if (res && res?.code == 200) {\r\n          this.emailConfigList = res?.data?.result;\r\n\r\n          // Suppose backend returns something like:\r\n          // { threshold: \"10\", percentage: \"80\" }\r\n          const initialData = {\r\n            threshold: this.emailConfigList?.complianceThreshold?.condition,\r\n            percentage: this.emailConfigList?.complianceThreshold?.value,\r\n          };\r\n\r\n          // Fill reactive form with values\r\n          this.complianceForm.patchValue(initialData);\r\n          this.cd.detectChanges();\r\n        }\r\n      });\r\n  }\r\n\r\n  lastSavedCompliance: any;\r\n  submitCompliance() {\r\n    if (this.complianceForm.invalid) return;\r\n    const payload = {\r\n      clientId: this.auditData?.client,\r\n      complianceThreshold: {\r\n        condition: this.complianceForm.value.threshold,\r\n        value: this.complianceForm.value.percentage,\r\n      },\r\n    };\r\n\r\n    this.$api\r\n      .updateEmailConfig(this.emailConfigList?._id, payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res) => {\r\n          this.toastService.getSuccessToast(\r\n            res?.message\r\n              ? `Email configuration` + res?.message\r\n              : \"Compliance settings updated successfully\"\r\n          );\r\n          this.getEmailConfig(); // update baseline\r\n          this.complianceForm.disable();\r\n          this.editMode1 = true;\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err) => console.error(\"Update failed:\", err),\r\n      });\r\n  }\r\n\r\n  cancelCompliance() {\r\n    this.complianceForm.disable();\r\n    this.editMode1 = true;\r\n    this.getEmailConfig();\r\n  }\r\n  // RMs\r\n  // RmList: any[] = [];\r\n  filteredRms: any[] = [];\r\n  searchRmText = \"\";\r\n\r\n  // Clusters\r\n  ClusterList: any[] = [];\r\n  filteredClusters: any[] = [];\r\n  searchClusterText = \"\";\r\n\r\n  // Dropdowns\r\n  Opendropdown = false;\r\n  dropdownOpen: string | null = null;\r\n\r\n  // Open/close dropdown\r\n  opendropdown() {\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n  closeDropdown() {\r\n    this.dropdownOpen = null;\r\n  }\r\n  rmOpen = false;\r\n  clusterOpen = false;\r\n\r\n  toggleRmDropdown() {\r\n    this.rmOpen = !this.rmOpen;\r\n    this.clusterOpen = false; // close other\r\n  }\r\n\r\n  toggleClusterDropdown() {\r\n    this.clusterOpen = !this.clusterOpen;\r\n    this.rmOpen = false; // close other\r\n  }\r\n\r\n  closeAllDropdowns() {\r\n    this.rmOpen = false;\r\n    this.clusterOpen = false;\r\n  }\r\nRmList:any[] = [\r\n  {\r\n    _id: \"1\",\r\n    userName: \"Ajay M\",\r\n    email: \"marellapudi.ajay@lenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"2\",\r\n    userName: \"Anirban Ghosh\",\r\n    email: \"anirban.ghosh@lenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"3\",\r\n    userName: \"Avadhesh Sharma\",\r\n    email: \"avadhesh.kumar@lenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"4\",\r\n    userName: \"Ayush Gupta\",\r\n    email: \"ayush.gupta1@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"5\",\r\n    userName: \"Dhiren Bisht\",\r\n    email: \"dhirendra.bisht@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"6\",\r\n    userName: \"Mueen Khan\",\r\n    email: \"mueen.khan@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"7\",\r\n    userName: \"Reshma Shetty\",\r\n    email: \"reshma.shetty@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"8\",\r\n    userName: \"Srinivas Reddy\",\r\n    email: \"srinivas.reddy@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"9\",\r\n    userName: \"Suresh Balaji R\",\r\n    email: \"suresh.r@thelenskart.com\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"10\",\r\n    userName: \"Thulasi Krishna\",\r\n    email: \"krishna.thulasi@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"11\",\r\n    userName: \"Vijeesh V L\",\r\n    email: \"vijeesh.vl@lenskart.in\",\r\n    role: \"admin\",\r\n  },\r\n  {\r\n    _id: \"12\",\r\n    userName: \"Kunal Sharma\",\r\n    email: \"kunal.sharma@lenskart.mobi\",\r\n    role: \"admin\",\r\n  },\r\n];\r\n  /** ---- RMs ---- */\r\n  getAllRm() {\r\n    // this.$api.getRmList(this.auditData?.client).subscribe((res: any) => {\r\n    //   if (res?.code === 200) {\r\n    //     const result = Array.isArray(res.data.result)\r\n    //       ? res.data.result\r\n    //       : [res.data.result];\r\n        this.RmList = this.RmList.map((rm: any) => ({ ...rm, checked: true })); // ✅ pre-select all\r\n        this.filteredRms = [...this.RmList];\r\n        //-- Old code --\r\n        // this.getAllGroups(this.RmList);\r\n        // this.Apply();\r\n        this.getAllGroupsPromise(this.RmList).then(() => {\r\n          this.Apply();\r\n        });\r\n    //   }\r\n    // });\r\n  }\r\n\r\n  filterRms() {\r\n    const search = this.searchRmText.toLowerCase();\r\n    this.filteredRms = this.RmList.filter((r) =>\r\n      r.userName.toLowerCase().includes(search)\r\n    );\r\n  }\r\n\r\n  isAllRmsSelected() {\r\n    return (\r\n      this.filteredRms.length > 0 && this.filteredRms.every((r) => r.checked)\r\n    );\r\n  }\r\n\r\n  toggleSelectAllRms(event: any) {\r\n    const checked = event.target.checked;\r\n    this.filteredRms.forEach((r) => (r.checked = checked));\r\nthis.updateSelectedRms();\r\n  }\r\n\r\n  updateSelectedRms() {\r\n    const selected = this.RmList.filter((r) => r.checked);\r\n    // this.getAllGroups(selected); // auto refresh clusters\r\n    this.getAllGroupsPromise(selected).then(() => { \r\n      // auto refresh clusters with promise\r\n    });\r\n  }\r\n\r\nselectedRmsLabel(): string {\r\n  const selected = this.filteredRms.filter(rm => rm.checked);\r\n  if (selected.length === 0) return '';\r\n  return selected[0].userName;\r\n}\r\ngetSelectedRmsCount(): number {\r\n  return this.filteredRms.filter(rm => rm.checked).length;\r\n}\r\n  /** ---- Clusters ---- */\r\n// getAllGroups(event?: any[]) {\r\n//   let rmList: string[] = [];\r\n\r\n//   if (event?.length) {\r\n//     rmList = event.map((o) => o.email);\r\n//   } else if (this.users?.role === \"rm\") {\r\n//     rmList = [this.users?.email];\r\n//   }\r\n\r\n//   const obj = { \r\n//     clientId: this.auditData?.client ? this.auditData?.client : this.users?.clientId,\r\n//     rmList \r\n//   };\r\n\r\n//   this.$api.getClusters(obj).subscribe((res: any) => {\r\n//     if (res?.code === 200) {\r\n//       // Initialize clusters with checked=false\r\n//       this.ClusterList = (res.data.result || []).map((c: any) => ({\r\n//         ...c,\r\n//         checked: true\r\n//       }));\r\n//       this.filteredClusters = [...this.ClusterList];\r\n//     } else {\r\n//       this.ClusterList = [];\r\n//       this.filteredClusters = [];\r\n//     }\r\n//   });\r\n// }\r\n\r\n  getAllGroupsPromise(event?: any[]): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      let rmList: string[] = [];\r\n\r\n      if (event?.length) {\r\n        rmList = event.map((o) => o.email);\r\n      } else if (this.users?.role === \"rm\") {\r\n        rmList = [this.users?.email];\r\n      }\r\n\r\n      const obj = {\r\n        clientId: this.auditData?.client ?? this.users?.clientId,\r\n        rmList\r\n      };\r\n\r\n      this.$api.getClusters(obj).subscribe({\r\n        next: (res: any) => {\r\n          if (res?.code === 200) {\r\n            this.ClusterList = (res.data.result || []).map((c: any) => ({\r\n              ...c,\r\n              checked: true,\r\n            }));\r\n            this.filteredClusters = [...this.ClusterList];\r\n          } else {\r\n            this.ClusterList = [];\r\n            this.filteredClusters = [];\r\n          }\r\n          resolve(); // completion\r\n        },\r\n        error: (err) => reject(err),\r\n      });\r\n    });\r\n  }\r\n\r\nfilterClusters() {\r\n  const search = this.searchClusterText.toLowerCase();\r\n  this.filteredClusters = this.ClusterList.filter((c) =>\r\n    c.clusterName.toLowerCase().includes(search)\r\n  );\r\n}\r\n\r\nisAllClustersSelected() {\r\n  return (\r\n    this.filteredClusters.length > 0 &&\r\n    this.filteredClusters.every((c) => c.checked)\r\n  );\r\n}\r\n\r\ntoggleSelectAllClusters(event: any) {\r\n  const checked = event.target.checked;\r\n  this.filteredClusters.forEach((c) => (c.checked = checked));\r\n  this.updateSelectedClusters();\r\n}\r\n\r\nupdateSelectedClusters() {\r\n  this.selectedClusters = this.ClusterList\r\n    .filter(c => c.checked)\r\n    .map(c => c._id); // or c.clusterName if needed\r\n}\r\n\r\nselectedClustersLabel() {\r\n  const selected = this.ClusterList.filter((c) => c.checked);\r\n  if (selected.length === 0) return '';\r\n  return selected[0].clusterName;\r\n}\r\n\r\ngetSelectedClustersCount() {\r\n  return this.ClusterList.filter(c => c.checked).length;\r\n  // return count > 1 ? count - 1 : 0; // Show \"+N others\"\r\n}\r\n\r\n  /** ---- Apply / Reset ---- */\r\n  Reset() {\r\n     this.rmOpen = false;\r\n    this.clusterOpen = false;\r\n   this.getAllRm();\r\n       this.Opendropdown = false;\r\n      //  getAllRm\r\n      //  this.getEmail()\r\n  }\r\n  selectedRms: any = [];\r\n  selectedClusters: any = [];\r\n  Apply() {\r\n    const datePipe = new DatePipe(\"en-US\");\r\n    this.selectedRms = this.RmList.filter((r) => r.checked).map((r) => r.email);\r\n    this.selectedClusters = this.ClusterList.filter((c) => c.checked).map(\r\n      (c) => c.clusterName\r\n    );\r\n    this.getEmail();\r\n    this.rmOpen = false;\r\n    this.clusterOpen = false;\r\n    this.Opendropdown = false;\r\n    if (this.filterStartDate) {\r\n      this.filterStartDate = datePipe.transform(\r\n        this.filterStartDate,\r\n        \"yyyy-MM-dd\"\r\n      );\r\n    }\r\n    if (this.filterEndDate) {\r\n      this.filterEndDate = datePipe.transform(this.filterEndDate, \"yyyy-MM-dd\");\r\n    }\r\n  }\r\n  offset = 1;\r\n  limit = 10;\r\npageSize = 10;            \r\npaginationSizes = [10,20,30]; \r\ntotalItems = 0;\r\n  setPaginationSizes() {\r\n    if (this.totalItems > 10) {\r\n      this.paginationSizes = [10, 20, 30];\r\n    } else {\r\n      this.paginationSizes = [this.totalItems]; // Just one option if less than 10\r\n    }\r\n    this.pageSize = this.paginationSizes[0];\r\n  } \r\n  loading = false;\r\n  noData = false;\r\n  getEmail() {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    let obj = {\r\n      fromDate: this.filterStartDate,\r\n      toDate: this.filterEndDate,\r\n      // type: this.currentAuditType,\r\n      RMList: this.selectedRms?.length ? this.selectedRms : [],\r\n      clientId: this.auditData?.client\r\n        ? this.auditData?.client\r\n        : this.users?.clientId,\r\n      cluster: this.selectedClusters?.length\r\n        ? this.selectedClusters\r\n        : [],\r\n      isExport: false,\r\n      searchValue: this.searchValue,\r\n      sortBy: this.sortedColumn ? this.sortedColumn : \"RMEmail\",\r\n      sortOrder: this.sortOrder ? this.sortOrder : 1,\r\n      offset: this.offset,\r\n      limit: this.limit,\r\n    };\r\n    this.$api\r\n      .getEmailLog(obj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            this.tableData = res.data.result;\r\n            this.totalItems = res?.data?.count || 0;\r\n            this.setPaginationSizes();\r\n            this.loading = false;\r\n            this.noData = false;\r\n          } else {\r\n            this.tableData = [];\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0;\r\n          }\r\n        },\r\n        error: (err) => {\r\n          this.tableData = [];\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.totalItems = 0;\r\n          console.error(\"Update failed:\", err);\r\n        },\r\n      });\r\n  }\r\n\r\nonPageChange(page: number) {\r\n  this.offset = page;\r\n  this.getEmail(); // reload with new page\r\n}\r\n\r\nonPageSizeChange(size: number) {\r\n  this.pageSize = size;\r\n  this.limit = size;\r\n  this.offset = 1;   // reset to first page when page size changes\r\n  this.getEmail();\r\n}\r\n\r\n  eyeTestView(data: any) {\r\n    this.$api.setAuditData(data);\r\n    \r\n    this.router.navigate([\"/manage/trax/audit/start\"], {\r\n      queryParams: {\r\n        type: this.currentAuditType,\r\n        storeId: data?.storeId,\r\n        _id: data.auditedId,\r\n        eyeType :data?.comment ? \"fake\" : \"genuine\",\r\n        RMEmail:data?.RMEmail,\r\n        cluster:data?.cluster,\r\n      },\r\n    });\r\n    let data1: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\n  data1.date = {\r\n  startDate: this.auditDetails?.fileDate,\r\n  endDate: this.auditDetails?.fileDate\r\n};\r\n     localStorage.setItem(\"header-filters\", JSON.stringify(data1));\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  //  @ViewChild('sankeyChart', { static: true }) chartElement!: ElementRef;\r\n\r\n  //   ngAfterViewInit() {\r\n  //     const rawData = [\r\n  //       { from: \"Customization\", to: \"Formal Pants\", value: 3 },\r\n  //       { from: \"Entry\", to: \"Formal Pants\", value: 12 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Joggers\", value: 4 },\r\n  //       { from: \"Joggers\", to: \"Formal Pants\", value: 2 },\r\n  //       { from: \"Power Stretch\", to: \"Customization\", value: 2 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 5 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Power Stretch\", value: 2 },\r\n  //       { from: \"Customization\", to: \"Trial Room\", value: 2 },\r\n  //       { from: \"Joggers\", to: \"Exit\", value: 29 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Power Stretch\", value: 2 },\r\n  //       { from: \"Entry\", to: \"Customization\", value: 64 },\r\n  //       { from: \"Power Stretch\", to: \"Pin Tuck Pants\", value: 3 },\r\n  //       { from: \"Customization\", to: \"Pin Tuck Pants\", value: 10 },\r\n  //       { from: \"Entry\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 49 },\r\n  //       { from: \"Entry\", to: \"Joggers\", value: 29 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Exit\", value: 49 },\r\n  //       { from: \"Joggers\", to: \"Customization\", value: 6 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Joggers\", value: 3 },\r\n  //       { from: \"Power Stretch\", to: \"Joggers\", value: 1 },\r\n  //       { from: \"Customization\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 7 },\r\n  //       { from: \"Formal Pants\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 1 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Exit\", value: 54 },\r\n  //       { from: \"Power Stretch\", to: \"Trial Room\", value: 2 },\r\n  //       { from: \"Formal Pants\", to: \"Customization\", value: 3 },\r\n  //       { from: \"Formal Pants\", to: \"Power Stretch\", value: 1 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Trial Room\", value: 2 },\r\n  //       { from: \"Customization\", to: \"Exit\", value: 64 },\r\n  //       { from: \"Entry\", to: \"Pin Tuck Pants\", value: 54 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Formal Pants\", value: 3 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Pin Tuck Pants\", value: 5 },\r\n  //       { from: \"Joggers\", to: \"Power Stretch\", value: 4 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Formal Pants\", value: 3 },\r\n  //       { from: \"Pin Tuck Pants\", to: \"Customization\", value: 11 },\r\n  //       { from: \"Formal Pants\", to: \"Pin Tuck Pants\", value: 3 },\r\n  //       { from: \"Trial Room\", to: \"Pin Tuck Pants\", value: 1 },\r\n  //       { from: \"Customization\", to: \"Power Stretch\", value: 1 },\r\n  //       { from: \"Customization\", to: \"Joggers\", value: 6 },\r\n  //       { from: \"Formal Pants\", to: \"Exit\", value: 12 },\r\n  //       { from: \"Joggers\", to: \"Pin Tuck Pants\", value: 4 },\r\n  //       { from: \"Power Stretch\", to: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", value: 1 },\r\n  //       { from: \"Power Stretch\", to: \"Exit\", value: 18 },\r\n  //       { from: \"Entry\", to: \"Trial Room\", value: 6 },\r\n  //       { from: \"Shorts with Lounge wear , Chinos and Pintuck Pants\", to: \"Customization\", value: 5 },\r\n  //       { from: \"Entry\", to: \"Power Stretch\", value: 18 },\r\n  //       { from: \"Power Stretch\", to: \"Formal Pants\", value: 1 },\r\n  //       { from: \"Trial Room\", to: \"Customization\", value: 3 },\r\n  //       { from: \"Trial Room\", to: \"Exit\", value: 6 },\r\n  //       { from: \"Formal Pants\", to: \"Joggers\", value: 4 }\r\n  //     ];\r\n\r\n  //     // Build unique nodes\r\n  //     const labels = [...new Set(rawData.flatMap(d => [d.from, d.to]))];\r\n  //     const labelToIndex: Record<string, number> = {};\r\n  //     labels.forEach((label, i) => (labelToIndex[label] = i));\r\n\r\n  //     // Map data for Sankey\r\n  //     const source = rawData.map(d => labelToIndex[d.from]);\r\n  //     const target = rawData.map(d => labelToIndex[d.to]);\r\n  //     const value = rawData.map(d => d.value);\r\n\r\n  //     // Assign consistent colors (like amCharts distinct palette)\r\n  //     const nodeColors: Record<string, string> = {\r\n  //       \"Customization\": \"#1f77b4\",\r\n  //       \"Formal Pants\": \"#ff7f0e\",\r\n  //       \"Entry\": \"#2ca02c\",\r\n  //       \"Pin Tuck Pants\": \"#d62728\",\r\n  //       \"Joggers\": \"#9467bd\",\r\n  //       \"Power Stretch\": \"#8c564b\",\r\n  //       \"Exit\": \"#e377c2\",\r\n  //       \"Trial Room\": \"#17becf\",\r\n  //       \"Shorts with Lounge wear , Chinos and Pintuck Pants\": \"#bcbd22\"\r\n  //     };\r\n\r\n  //     const nodeColorArray = labels.map(l => nodeColors[l] || \"#999\");\r\n  //     const linkColorArray = rawData.map(d => nodeColors[d.from] || \"#999\");\r\n\r\n  //     const data: any = [{\r\n  //       type: \"sankey\",\r\n  //       orientation: \"h\",\r\n  //       node: {\r\n  //         pad: 15,\r\n  //         thickness: 20,\r\n  //         line: { color: \"black\", width: 0.5 },\r\n  //         label: labels,\r\n  //         color: nodeColorArray\r\n  //       },\r\n  //       link: {\r\n  //         source,\r\n  //         target,\r\n  //         value,\r\n  //         color: linkColorArray\r\n  //       }\r\n  //     }];\r\n\r\n  //     const layout = {\r\n  //       title: { text: \"Sankey Flow (Plotly with AmCharts-like Colors)\" },\r\n  //       font: { size: 12 }\r\n  //     };\r\n\r\n  //     Plotly.newPlot(this.chartElement.nativeElement, data, layout);\r\n  //   }\r\n}\r\n","<div class=\"d-flex align-items-center my-5\">\r\n    <div (click)=\"backNavigation()\" class=\"btn btn-am btn-outline p-3\">\r\n        <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                <path d=\"M15.8332 9.99984H4.1665M4.1665 9.99984L9.99984 15.8332M4.1665 9.99984L9.99984 4.1665\"\r\n                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n            </svg></span>\r\n    </div><span class=\"ms-2 title-head\">Audit Settings</span>\r\n</div>\r\n\r\n\r\n<div class=\"row mt-5\">\r\n    <div class=\"col-12\">\r\n        <div ngbAccordion #accordion=\"ngbAccordion\" [closeOthers]=\"true\" [destroyOnHide]=\"true\"\r\n            (show)=\"openItem($event)\">\r\n            <div class=\"settings-accordian-card \" ngbAccordionItem [collapsed]=\"false\">\r\n                <div class=\"d-flex\" ngbAccordionHeader>\r\n                    <button type=\"button\" class=\"mainheading\" ngbAccordionButton>\r\n                        <div class=\"header-row\">\r\n                            <span>User Configuration</span>\r\n                            <span class=\"divider\"></span>\r\n                        </div>\r\n                    </button>\r\n                </div>\r\n                <div ngbAccordionCollapse>\r\n                    <div ngbAccordionBody>\r\n                        <ng-template>\r\n\r\n                            <div class=\"col-12 mb-5\">\r\n                                <div *ngIf=\"!editMode\" class=\" d-flex justify-content-end\">\r\n                                    <button (click)=\"toggleEdit()\" type=\"button\"\r\n                                        class=\"btn btn-outline align-items-end\"><span class=\"me-2\"><svg\r\n                                                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_2579_25125)\">\r\n                                                    <path\r\n                                                        d=\"M14.167 2.49993C14.3859 2.28106 14.6457 2.10744 14.9317 1.98899C15.2176 1.87054 15.5241 1.80957 15.8337 1.80957C16.1432 1.80957 16.4497 1.87054 16.7357 1.98899C17.0216 2.10744 17.2815 2.28106 17.5003 2.49993C17.7192 2.7188 17.8928 2.97863 18.0113 3.2646C18.1297 3.55057 18.1907 3.85706 18.1907 4.16659C18.1907 4.47612 18.1297 4.78262 18.0113 5.06859C17.8928 5.35455 17.7192 5.61439 17.5003 5.83326L6.25033 17.0833L1.66699 18.3333L2.91699 13.7499L14.167 2.49993Z\"\r\n                                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2579_25125\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg></span>Edit Details</button>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div class=\"w-80\">\r\n                                <label class=\"my-2 form-label fs-4 fw-bold\">Assign Audit Users</label>\r\n                                <div *ngIf=\"editMode; else readonlyView\">\r\n                                    <lib-chip-dropdown [data]=\"userConfigList\" [selectedData]=\"configData\"\r\n                                        (selectedList)=\"updateOwner($event)\">\r\n                                    </lib-chip-dropdown>\r\n                                </div>\r\n\r\n                                <ng-template #readonlyView>\r\n                                    <div class=\"flex flex-wrap gap-2 border-2 border-gray-300 p-3 rounded\">\r\n                                        <ng-container *ngFor=\"let chip of configData\">\r\n                                            <span class=\"p-1 rounded-5 chip px-2 my-3 py-1 bg-gray-200\">\r\n                                                {{ chip?.name || chip }}\r\n                                            </span>\r\n                                        </ng-container>\r\n                                    </div>\r\n\r\n                                </ng-template>\r\n\r\n                            </div>\r\n\r\n                            <div class=\"mt-3 text-end\" *ngIf=\"editMode\">\r\n                                <button class=\"btn btn-outline me-2\" (click)=\"cancelEdit()\">Cancel</button>\r\n                                <button class=\"btn btn-primary\" (click)=\"submitOwners()\">Save</button>\r\n                            </div>\r\n                        </ng-template>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"settings-accordian-card mt-6\" ngbAccordionItem>\r\n                <div class=\"d-flex\" ngbAccordionHeader>\r\n                    <button class=\"mainheading\" ngbAccordionButton>\r\n                        <div class=\"header-row\">\r\n                            <span>Email Configuration</span>\r\n                            <span class=\"divider\"></span>\r\n                        </div>\r\n                    </button>\r\n                </div>\r\n                <div ngbAccordionCollapse>\r\n                    <div ngbAccordionBody>\r\n                        <ng-template>\r\n                            <div class=\"col-12 mb-5\">\r\n                                <div *ngIf=\"editMode1\" class=\" d-flex justify-content-end\">\r\n                                    <button (click)=\"toggleEdit1();\" type=\"button\"\r\n                                        class=\"btn btn-outline align-items-end\"><span class=\"me-2\"><svg\r\n                                                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_2579_25125)\">\r\n                                                    <path\r\n                                                        d=\"M14.167 2.49993C14.3859 2.28106 14.6457 2.10744 14.9317 1.98899C15.2176 1.87054 15.5241 1.80957 15.8337 1.80957C16.1432 1.80957 16.4497 1.87054 16.7357 1.98899C17.0216 2.10744 17.2815 2.28106 17.5003 2.49993C17.7192 2.7188 17.8928 2.97863 18.0113 3.2646C18.1297 3.55057 18.1907 3.85706 18.1907 4.16659C18.1907 4.47612 18.1297 4.78262 18.0113 5.06859C17.8928 5.35455 17.7192 5.61439 17.5003 5.83326L6.25033 17.0833L1.66699 18.3333L2.91699 13.7499L14.167 2.49993Z\"\r\n                                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2579_25125\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg></span>Edit Details</button>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"fw-semibold mb-3\">\r\n                                Compliance Threshold\r\n                            </div>\r\n                            <form [formGroup]=\"complianceForm\">\r\n\r\n                                <div class=\"row\">\r\n                                    <div class=\"col-lg-2\">\r\n                                        <lib-reactive-select formControlName=\"threshold\" [data]=\"complianceThresholds\"\r\n                                            [idField]=\"'value'\" [nameField]=\"'label'\"></lib-reactive-select>\r\n                                    </div>\r\n                                    <div class=\"col-lg-2\">\r\n                                        <lib-reactive-select formControlName=\"percentage\" [data]=\"compliancePercentage\"\r\n                                            [idField]=\"'value'\" [nameField]=\"'label'\"></lib-reactive-select>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"!editMode1\" class=\"mt-3 text-end\">\r\n                                    <button type=\"button\" class=\"btn btn-outline me-2\"\r\n                                        (click)=\"cancelCompliance()\">Cancel</button>\r\n                                    <button type=\"button\" class=\"btn btn-primary \"\r\n                                        (click)=\"submitCompliance()\">Save</button>\r\n                                </div>\r\n                            </form>\r\n                            <div class=\"my-3\">\r\n                                <span class=\"fw-semibold me-3\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                                        height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_762_15430)\">\r\n                                            <path\r\n                                                d=\"M8.00004 10.6663V7.99967M8.00004 5.33301H8.00671M14.6667 7.99967C14.6667 11.6816 11.6819 14.6663 8.00004 14.6663C4.31814 14.6663 1.33337 11.6816 1.33337 7.99967C1.33337 4.31778 4.31814 1.33301 8.00004 1.33301C11.6819 1.33301 14.6667 4.31778 14.6667 7.99967Z\"\r\n                                                stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_762_15430\">\r\n                                                <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg></span>\r\n                                Email will be automatically sent if the compliance doesn’t meet the\r\n                                <span class=\"fw-bold\">{{complianceForm.value?.percentage}}</span> to the respective Optometrist.\r\n                            </div>\r\n                        </ng-template>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"settings-accordian-card mt-6\" ngbAccordionItem>\r\n                <div class=\"d-flex\" ngbAccordionHeader>\r\n                    <button class=\"mainheading\" ngbAccordionButton>\r\n                        <div class=\"header-row\">\r\n                            <span>Email Logs</span>\r\n                            <span class=\"divider\"></span>\r\n                        </div>\r\n                    </button>\r\n                </div>\r\n                <div ngbAccordionCollapse>\r\n                    <div ngbAccordionBody>\r\n                        <ng-template>\r\n                            <div class=\"d-flex justify-content-end align-items-center mb-10\">\r\n                                <div class=\"d-flex align-items-center position-relative my-1\">\r\n                                    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n                                            viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\"\r\n                                                rx=\"1\" transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\">\r\n                                            </rect>\r\n                                            <path\r\n                                                d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n                                                fill=\"currentColor\"></path>\r\n                                        </svg>\r\n                                    </span>\r\n                                    <input (change)=\"searchData()\" [(ngModel)]=\"searchValue\" type=\"text\"\r\n                                        class=\"form-control ps-14 me-2\" autocomplete=\"off\" placeholder=\"Search\" />\r\n                                    <div class=\"d-flex align-items-center\">\r\n                                        <div class=\"d-flex align-items-center position-relative me-2\">\r\n                                            <input class=\"fx-date-range form-control ps-14\"\r\n                                                style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n                                                ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\"\r\n                                                [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\"\r\n                                                [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\"\r\n                                                [showCancel]=\"true\" autocomplete=\"off\" [(ngModel)]=\"selectedDateRange\"\r\n                                                [autoApply]=\"true\"\r\n                                                [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n                                                (datesUpdated)=\"datechange($event)\" name=\"daterange\" />\r\n                                            <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n                                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                                                    viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                    <path\r\n                                                        d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n                                            </span>\r\n                                        </div>\r\n\r\n                                        <div class=\"position-relative\">\r\n\r\n                                            <button type=\"button\" (click)=\"opendropdown()\"\r\n                                                class=\"btn btn-outline mx-2 rounded-3 text-nowrap border-val\">\r\n                                                <span class=\"me-2\">Filter</span> <svg width=\"20\" height=\"20\"\r\n                                                    viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                    <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\"\r\n                                                        stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </svg>\r\n                                            </button>\r\n\r\n\r\n                                            <div *ngIf=\"Opendropdown\"\r\n                                                class=\"card p-4 dropdown2 position-absolute z-1 end-0\"\r\n                                                (clickOutside)=\"closeDropdown()\">\r\n                                                <div class=\"dropdown-title d-flex justify-content-between mb-3\">\r\n                                                    <span>Filter Options</span>\r\n\r\n                                                </div>\r\n\r\n\r\n                                                <div class=\"dropdown-container mb-3\">\r\n                                                    <div class=\"position-relative dropdown-header\"\r\n                                                        (click)=\"toggleRmDropdown()\">\r\n                                                        <input type=\"text\"\r\n                                                            class=\"form-control dropdown-input cursor-pointer\"\r\n                                                            value=\"RMs\" readonly placeholder=\"Select RMs\" />\r\n                                                        <span *ngIf=\"getSelectedRmsCount()\"\r\n                                                            class=\"position-absolute top-50 end-0 translate-middle-y me-2 badge badge-light-default text-white text-xs rounded-full px-2 py-0.5\">\r\n                                                            {{ getSelectedRmsCount() }}\r\n                                                        </span>\r\n                                                    </div>\r\n\r\n                                                    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"rmOpen\">\r\n                                                        <input type=\"text\" class=\"form-control mb-2 dropdown-search\"\r\n                                                            placeholder=\"Search RMs\" [(ngModel)]=\"searchRmText\"\r\n                                                            (ngModelChange)=\"filterRms()\" />\r\n\r\n                                                        <div class=\"form-check ps-0 my-5\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                id=\"selectAllRms\" [checked]=\"isAllRmsSelected()\"\r\n                                                                (change)=\"toggleSelectAllRms($event)\" />\r\n                                                            <label class=\"form-check-label\" for=\"selectAllRms\">Select\r\n                                                                All</label>\r\n                                                        </div>\r\n\r\n                                                        <div class=\"form-check mb-5 ps-0\"\r\n                                                            *ngFor=\"let rm of filteredRms\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                [id]=\"rm.email\" [(ngModel)]=\"rm.checked\"\r\n                                                                (change)=\"updateSelectedRms()\" />\r\n                                                            <label class=\"form-check-label\" [for]=\"rm.email\">{{\r\n                                                                rm.userName }}</label>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n\r\n\r\n                                                <div class=\"dropdown-container\">\r\n                                                    <div class=\"dropdown-header position-relative\"\r\n                                                        (click)=\"toggleClusterDropdown()\">\r\n                                                        <input type=\"text\"\r\n                                                            class=\"form-control dropdown-input cursor-pointer pe-5\"\r\n                                                            value=\"Clusters\" readonly placeholder=\"Select Clusters\" />\r\n\r\n\r\n                                                        <span *ngIf=\"getSelectedClustersCount()\"\r\n                                                            class=\"position-absolute top-50 end-0 translate-middle-y me-2 badge badge badge-light-default text-white rounded-pill px-2 py-0\">\r\n                                                            {{ getSelectedClustersCount() }}\r\n                                                        </span>\r\n                                                    </div>\r\n\r\n                                                    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"clusterOpen\">\r\n                                                        <input type=\"text\" class=\"form-control mb-2 dropdown-search\"\r\n                                                            placeholder=\"Search clusters\"\r\n                                                            [(ngModel)]=\"searchClusterText\"\r\n                                                            (ngModelChange)=\"filterClusters()\" />\r\n\r\n                                                        <div class=\"form-check ps-0 my-5\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                id=\"selectAllClusters\"\r\n                                                                [checked]=\"isAllClustersSelected()\"\r\n                                                                (change)=\"toggleSelectAllClusters($event)\" />\r\n                                                            <label class=\"form-check-label\"\r\n                                                                for=\"selectAllClusters\">Select All</label>\r\n                                                        </div>\r\n\r\n                                                        <div class=\"form-check mb-5 ps-0\"\r\n                                                            *ngFor=\"let cluster of filteredClusters\">\r\n                                                            <input class=\"form-check-input\" type=\"checkbox\"\r\n                                                                [id]=\"cluster._id\" [(ngModel)]=\"cluster.checked\"\r\n                                                                (change)=\"updateSelectedClusters()\" />\r\n                                                            <label class=\"form-check-label\" [for]=\"cluster._id\">{{\r\n                                                                cluster.clusterName }}</label>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                </div>\r\n\r\n                                                <div class=\"d-flex gap-2 mt-3\">\r\n                                                    <button class=\"btn btn-outline btn-sm w-50\"\r\n                                                        (click)=\"Reset()\">Reset</button>\r\n                                                    <button class=\"btn btn-primary btn-sm w-50\"\r\n                                                        (click)=\"Apply()\">Apply</button>\r\n                                                </div>\r\n                                            </div>\r\n\r\n                                        </div>\r\n\r\n                                        <button type=\"button\" (click)=\"exportXLSX()\" *ngIf=\"!noData && !loading\"\r\n                                            class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg\r\n                                                xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                                                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.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n                                                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </svg><span class=\"ms-2\">Export</span> </button>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div *ngIf=\"loading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                                <div class=\"shimmer\">\r\n                                    <div class=\"wrapper\">\r\n                                        <div class=\"stroke animate title\"></div>\r\n                                        <div class=\"stroke animate link\"></div>\r\n                                        <div class=\"stroke animate description\"></div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"shimmer\">\r\n                                    <div class=\"wrapper\">\r\n                                        <div class=\"stroke animate title\"></div>\r\n                                        <div class=\"stroke animate link\"></div>\r\n                                        <div class=\"stroke animate description\"></div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <div *ngIf=\"noData\" class=\"row\">\r\n                                <div class=\"col-lg-12 mb-3\">\r\n                                    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                        <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                        <div class=\"nodata-title\">No data found</div>\r\n                                        <div class=\"nodata-sub\">There is no result for this eye test table</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <div *ngIf=\"!noData && !loading\" class=\"table-responsive\">\r\n                                <table class=\"w-100 table bottom-border text-nowrap\">\r\n                                    <thead>\r\n                                        <tr>\r\n                                            <th class=\"text-nowrap text-start\"> <span class=\"cursor-pointer\"\r\n                                                    > RM Name \r\n                                                </span></th>\r\n                                            <th class=\"text-nowrap text-start\"><span class=\"cursor-pointer\"\r\n                                                   > Cluster Name\r\n                                                </span></th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('optumId')\"> Optom ID <svg\r\n                                                        [ngClass]=\"sortedColumn === 'optumId' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'optumId' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('optomEmailId')\"> Optom\r\n                                                    Email <svg\r\n                                                        [ngClass]=\"sortedColumn === 'optomEmailId' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'optomEmailId' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n                                            <th class=\"text-nowrap text-start\"><span class=\"cursor-pointer\"\r\n                                                    (click)=\"onSort('storeName')\"> Store Name <svg\r\n                                                        [ngClass]=\"sortedColumn === 'storeName' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span></th>\r\n\r\n                                            <th class=\"text-nowrap text-start\"><span class=\"cursor-pointer\"\r\n                                                    (click)=\"onSort('auditedBy')\"> Audited By <svg\r\n                                                        [ngClass]=\"sortedColumn === 'auditedBy' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'auditedBy' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span></th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('complianceScore')\"> Tango\r\n                                                    Score <svg\r\n                                                        [ngClass]=\"sortedColumn === 'complianceScore' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'complianceScore' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('trustScore')\"> Trust Score\r\n                                                    <svg [ngClass]=\"sortedColumn === 'trustScore' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'trustScore' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n\r\n                                            <th class=\"text-nowrap text-start\">\r\n                                                <span class=\"cursor-pointer\" (click)=\"onSort('humanScore')\"> Human\r\n                                                    Audited Score <svg\r\n                                                        [ngClass]=\"sortedColumn === 'humanScore' && sortOrder === 1 ? 'rotate' : ''\"\r\n                                                        width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                            [attr.stroke]=\"sortedColumn === 'humanScore' ? '#00A3FF' : '#667085'\"\r\n                                                            stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                                            stroke-linejoin=\"round\" />\r\n                                                    </svg></span>\r\n                                            </th>\r\n\r\n                                            <th class=\"text-nowrap text-start\">Action</th>\r\n                                        </tr>\r\n                                    </thead>\r\n                                    <tbody>\r\n                                        <tr *ngFor=\"let item of tableData\">\r\n                                            <td class=\"text-nowrap\">\r\n                                                <span class=\"rm-truncate\" [title]=\"item.RMName\">{{ item.RMName }}</span>\r\n                                            </td>\r\n                                            <td class=\"text-nowrap\">\r\n                                                <span class=\"rm-truncate\" [title]=\"item.cluster\">{{ item.cluster }}</span>\r\n                                            </td>\r\n                                            <td class=\"text-nowrap\">{{item.optumId}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.optomEmailId}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.storeName}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.auditedBy}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.complianceScore ?? \"--\" }}</td>\r\n                                            <td class=\"text-nowrap\">{{item.trustScore}}</td>\r\n                                            <td class=\"text-nowrap\">{{item.humanScore}}</td>\r\n                                            <td class=\"text-nowrap\">\r\n                                                <button type=\"button\" [disabled]=\"!item.auditedId\"\r\n                                                    (click)=\"eyeTestView(item)\"\r\n                                                    class=\"btn btn-link p-0 m-0 border-0 bg-transparent\">\r\n                                                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n                                                        viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                        <path\r\n                                                            d=\"M0.833252 9.99967C0.833252 9.99967 4.16658 3.33301 9.99992 3.33301C15.8333 3.33301 19.1666 9.99967 19.1666 9.99967C19.1666 9.99967 15.8333 16.6663 9.99992 16.6663C4.16658 16.6663 0.833252 9.99967 0.833252 9.99967Z\"\r\n                                                            stroke=\"#667085\" stroke-width=\"1.66667\"\r\n                                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                        <path\r\n                                                            d=\"M9.99992 12.4997C11.3806 12.4997 12.4999 11.3804 12.4999 9.99967C12.4999 8.61896 11.3806 7.49967 9.99992 7.49967C8.61921 7.49967 7.49992 8.61896 7.49992 9.99967C7.49992 11.3804 8.61921 12.4997 9.99992 12.4997Z\"\r\n                                                            stroke=\"#667085\" stroke-width=\"1.66667\"\r\n                                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                    </svg>\r\n                                                </button>\r\n                                            </td>\r\n                                    </tbody>\r\n                                </table>\r\n                            </div>\r\n                            <div class=\"card-footer\" *ngIf=\"!noData && !loading\">\r\n                                <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"offset\"\r\n                                    [totalItems]=\"totalItems\" [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\"\r\n                                    (pageChange)=\"onPageChange($event)\"\r\n                                    (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n                            </div>\r\n                        </ng-template>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>"]}