@vgroup/dialbox 0.0.57 → 0.0.59

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.
@@ -13,6 +13,16 @@ import * as i6 from "@angular/common";
13
13
  import * as i7 from "@angular/forms";
14
14
  import * as i8 from "./components/call-progress/call-progress.component";
15
15
  export class DialboxComponent {
16
+ set isDialpadHidden(value) {
17
+ this._isDialpadHidden = value;
18
+ if (!value) {
19
+ // When dialpad becomes visible, ensure Twilio is initialized
20
+ this.initializeTwilio();
21
+ }
22
+ }
23
+ get isDialpadHidden() {
24
+ return this._isDialpadHidden;
25
+ }
16
26
  constructor(twilioService, extService, dialog, ipService, extensionService, router) {
17
27
  this.twilioService = twilioService;
18
28
  this.extService = extService;
@@ -20,7 +30,7 @@ export class DialboxComponent {
20
30
  this.ipService = ipService;
21
31
  this.extensionService = extensionService;
22
32
  this.router = router;
23
- this.isDialpadHidden = true;
33
+ this._isDialpadHidden = true;
24
34
  this.closeDialpadEvent = new EventEmitter();
25
35
  this.callInitiated = new EventEmitter();
26
36
  this.endCallEvent = new EventEmitter();
@@ -66,70 +76,38 @@ export class DialboxComponent {
66
76
  this.subscriptions = new Subscription();
67
77
  this.shakeDedicatedBtn = false;
68
78
  this.isSmartDialCall = false;
79
+ this.isInitialized = false;
69
80
  this.isMinimised = false;
81
+ // Initialize if dialpad is visible by default
82
+ if (!this.isDialpadHidden) {
83
+ this.initializeTwilio();
84
+ }
70
85
  }
71
86
  initializeTwilio() {
72
- if (!this.twilioService || !this.token) {
87
+ if (this.isInitialized)
88
+ return;
89
+ this.token = localStorage.getItem('ext_token') || '';
90
+ if (!this.token) {
91
+ console.error('No authentication token found');
73
92
  return;
74
93
  }
94
+ this.isInitialized = true;
95
+ // Initialize Twilio service
75
96
  this.twilioService.initializeTwilioDevice();
76
- this.setupIncomingCallSubscription();
77
- }
78
- setupIncomingCallSubscription() {
79
- this.subscriptions.add(this.twilioService.currentCall.subscribe(incomingCallData => {
80
- if (incomingCallData) {
81
- if (this.isCallInProgress) {
82
- this.newIncomingCalls.push(incomingCallData);
83
- this.getUserInformation(incomingCallData);
84
- }
85
- else {
86
- this.handleNewIncomingCall(incomingCallData);
87
- }
97
+ // Subscribe to incoming calls to show dialpad when call comes in
98
+ const callSub = this.twilioService.currentCall.subscribe(call => {
99
+ if (call) {
100
+ this.isCallInProgress = true;
101
+ this._isDialpadHidden = false; // Show dialpad on incoming call
88
102
  }
89
- }));
90
- }
91
- handleNewIncomingCall(call) {
92
- this.isCallInProgress = true;
93
- this.isDialpadHidden = false; // Show the dialpad when there's an incoming call
94
- this.callData = {
95
- phone: call.parameters['From'],
96
- displayNum: call.parameters['From'],
97
- dial: true,
98
- name: call.customParameters?.get('name') || 'Unknown',
99
- img: call.customParameters?.get('image') || 'assets/images/user.jpg',
100
- isIncomingCall: true,
101
- extNum: ''
102
- };
103
- call.on('cancel', () => this.handleCallEnd(call));
104
- call.on('disconnect', () => this.handleCallEnd(call));
105
- this.incomingCallInitiated.emit();
106
- }
107
- handleCallEnd(call) {
108
- this.incomingCallsList = this.incomingCallsList.filter((item) => item.parameters.CallSid !== call.parameters['CallSid']);
109
- if (this.incomingCallsList.length === 0) {
110
- this.isCallInProgress = false;
111
- this.resetCallData();
112
- }
113
- }
114
- resetCallData() {
115
- this.callData = {
116
- phone: '',
117
- displayNum: '',
118
- dial: false,
119
- name: '',
120
- img: 'assets/images/user.jpg',
121
- isIncomingCall: false,
122
- extNum: ''
123
- };
103
+ });
104
+ this.subscriptions.add(callSub);
124
105
  }
125
106
  ngOnInit() {
126
107
  try {
127
- this.token = localStorage.getItem('ext_token') || '';
128
- this.initializeTwilio();
129
- this.getUserCallSetting();
130
- this.getContactList();
131
108
  this.getContactList();
132
109
  this.getUserCallSetting();
110
+ // Subscribe to dial number events
133
111
  const sub1 = this.twilioService.dialNumberFromOtherModule.subscribe((contact) => {
134
112
  if (contact.number) {
135
113
  this.isSmartDialCall = false;
@@ -248,15 +226,12 @@ export class DialboxComponent {
248
226
  this.registerDragElement();
249
227
  }
250
228
  ngOnChanges(changes) {
251
- if (changes['isDialpadHidden']) {
252
- if (!this.isDialpadHidden) {
253
- // Focus the input when dialpad becomes visible
254
- setTimeout(() => {
255
- if (this.dialInputElement?.nativeElement) {
256
- this.dialInputElement.nativeElement.focus();
257
- }
258
- }, 0);
259
- }
229
+ if (changes['isDialpadHidden'] && !this.isDialpadHidden) {
230
+ this.getContactList();
231
+ this.getUserCallSetting();
232
+ setTimeout(() => {
233
+ this.dialInputElement.nativeElement.focus();
234
+ }, 0);
260
235
  }
261
236
  }
262
237
  registerDragElement() {
@@ -989,6 +964,10 @@ export class DialboxComponent {
989
964
  if (this.subscriptions) {
990
965
  this.subscriptions.unsubscribe();
991
966
  }
967
+ // Clean up Twilio device when component is destroyed
968
+ if (this.twilioService['device']) {
969
+ this.twilioService['device'].destroy();
970
+ }
992
971
  // End any active call
993
972
  if (this.isCallInProgress) {
994
973
  this.endCall();
@@ -1029,4 +1008,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
1029
1008
  }], numberDialed: [{
1030
1009
  type: Output
1031
1010
  }] } });
1032
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialbox.component.js","sourceRoot":"","sources":["../../../../projects/dialbox/src/lib/dialbox.component.ts","../../../../projects/dialbox/src/lib/dialbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { TwilioService } from './service/twilio.service';\nimport swal from 'sweetalert2';\nimport { ExtensionService } from './service/extension.service';\nimport { CallerIdDialogComponent } from './components/caller-id-dialog/caller-id-dialog.component';\nimport { MatDialog } from '@angular/material/dialog';\nimport parsePhoneNumberFromString, { AsYouType } from 'libphonenumber-js';\nimport { keypad } from '../keypad';\nimport { Subscription } from 'rxjs'\nimport { IpAddressService } from './service/ip-address.service';\nimport { Router } from '@angular/router';\nimport { Call } from '@twilio/voice-sdk';\n\n\n@Component({\n  selector: 'lib-dialbox',\n  templateUrl: './dialbox.component.html',\n  styleUrls: ['./dialbox.component.css']\n})\nexport class DialboxComponent implements OnInit, AfterViewInit, OnChanges {\n  \n  @Input() isDialpadHidden: boolean = true;\n  @Output() closeDialpadEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() callInitiated: EventEmitter<any> = new EventEmitter<any>();\n  @Output() endCallEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() minimiseEvent: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() incomingCallsNewInfoEvent: EventEmitter<any[]> = new EventEmitter<any[]>();\n  @Output() incomingCallInitiated: EventEmitter<void> = new EventEmitter<void>();\n  @ViewChild('dialInput') dialInputElement!: ElementRef;\n\n  \n  @Output() numberDialed = new EventEmitter<string>();\n\n\n  isCallInProgress: boolean = false;\n  keypadVal = keypad;\n  \n  showInputClearBtn: boolean = false;\n  dialedNumber: string = '';\n  contactList: any[] = [];\n  filteredContactList: any[] = [];\n  callerIdList: any[] = [];\n  selectedCallerId: any;\n  isCallerIdHidden: boolean = true;\n\n  isTrialPeriodOver: boolean = false;\n  isPaymentDue: boolean = false;\n  terminateCall = false;\n  toastTimeout = 7000;\n  callNumberToast = {\n    show: false,\n    type: 'alert-success',\n    number: '',\n    displayNum: ''\n  }\n  callData: any = {\n    phone: '',\n    displayNum: '',\n    dial: false,\n    name: '',\n    img: 'assets/images/user.jpg',\n    isIncomingCall: false,\n    extNum:''\n  };\n  lastDialed: { name?: string; image?: string; number: string } | null = null;\n  sanitizedNum: any;\n  dialAlert = {\n    msg: '',\n    show: false\n  }\n  token?:string;\n \n  showDedicatedPopup:boolean = false;\n  newIncomingCalls: any = [];\n  incomingCallsList: any = [];\n  newIncomingCallData?:Call;\n  private subscriptions: Subscription = new Subscription();\n  callPreference:any;\n  shakeDedicatedBtn: boolean = false;\n  isSmartDialCall:boolean = false;\n  constructor(\n    private twilioService: TwilioService,\n    private extService: ExtensionService,\n    private dialog: MatDialog,\n    private ipService: IpAddressService,\n    private extensionService: ExtensionService,\n    private router: Router,\n  ) { }\n\n  private initializeTwilio() {\n    if (!this.twilioService || !this.token) {\n      return;\n    }\n    this.twilioService.initializeTwilioDevice();\n    this.setupIncomingCallSubscription();\n  }\n\n  private setupIncomingCallSubscription() {\n    this.subscriptions.add(\n      this.twilioService.currentCall.subscribe(incomingCallData => {\n        if (incomingCallData) {\n          if (this.isCallInProgress) {\n            this.newIncomingCalls.push(incomingCallData);\n            this.getUserInformation(incomingCallData);\n          } else {\n            this.handleNewIncomingCall(incomingCallData);\n          }\n        }\n      })\n    );\n  }\n\n  private handleNewIncomingCall(call: any) {\n    this.isCallInProgress = true;\n    this.isDialpadHidden = false; // Show the dialpad when there's an incoming call\n    \n    this.callData = {\n      phone: call.parameters['From'],\n      displayNum: call.parameters['From'],\n      dial: true,\n      name: call.customParameters?.get('name') || 'Unknown',\n      img: call.customParameters?.get('image') || 'assets/images/user.jpg',\n      isIncomingCall: true,\n      extNum: ''\n    };\n\n    call.on('cancel', () => this.handleCallEnd(call));\n    call.on('disconnect', () => this.handleCallEnd(call));\n    this.incomingCallInitiated.emit();\n  }\n\n  private handleCallEnd(call: any) {\n    this.incomingCallsList = this.incomingCallsList.filter(\n      (item: any) => item.parameters.CallSid !== call.parameters['CallSid']\n    );\n    \n    if (this.incomingCallsList.length === 0) {\n      this.isCallInProgress = false;\n      this.resetCallData();\n    }\n  }\n\n  private resetCallData() {\n    this.callData = {\n      phone: '',\n      displayNum: '',\n      dial: false,\n      name: '',\n      img: 'assets/images/user.jpg',\n      isIncomingCall: false,\n      extNum: ''\n    };\n  }\n\n  ngOnInit() {\n    try {\n      this.token = localStorage.getItem('ext_token') || '';\n      this.initializeTwilio();\n      this.getUserCallSetting();\n      this.getContactList();\n      this.getContactList();\n      \n      this.getUserCallSetting();\n      const sub1 = this.twilioService.dialNumberFromOtherModule.subscribe((contact:any) => {\n        if (contact.number) {\n          this.isSmartDialCall = false;\n          if (contact.isDialFromHistory) {\n            //handle dialing from history page\n            if(contact.callerId == 'smartDialing'){\n             \n              this.selectedCallerId = { number: contact.from };\n              this.isSmartDialCall = true;\n              setTimeout(() => {\n                this.isDialpadHidden = false;\n              }, 2000);\n              this.callData.phone = contact.number;\n              this.callData.name = contact.name;\n              this.callData.img = contact.img;\n              this.callData.from = contact.from;\n              this.sanitizedNum = contact.number;\n              this.getUserInformation(contact);\n            // this.incomingCallsList.push(contact)\n            this.initiateCall();\n          }else{\n            this.getUserCallSetting();\n            setTimeout(() => {\n              this.isDialpadHidden = false;\n            }, 1000);\n            this.getUserInformation(contact);\n            // this.incomingCallsList.push(contact)\n              this.dialedNumber = contact.number;\n              this.sanitizedNum = contact.number;\n            }\n          } else {\n            if (contact.callerId == 'alwaysAsk' || contact.callerId == 'smartDialing') {\n              this.getUserCallSetting();\n              setTimeout(() => {\n                this.isDialpadHidden = false;\n              }, 1000);\n              this.dialedNumber = contact.number;\n              this.sanitizedNum = contact.number;\n              \n            } else {\n              setTimeout(() => {\n                this.isDialpadHidden = false;\n              }, 2000);\n              this.callData.phone = contact.number;\n              this.callData.name = contact.name;\n              this.callData.img = contact.img;\n              this.sanitizedNum = contact.number;\n              this.initiateCall();\n            }\n          }\n          \n        }\n      })\n  \n      // handle incoming call\n      const sub2 = this.twilioService.currentCall.subscribe(incomingCallData => {\n        // if (incomingCallData) {\n        //   this.isCallInProgress = true;\n        //   this.isDialpadHidden = false;\n        //   this.callData.phone = incomingCallData.parameters.From;\n        //   this.callData.name = incomingCallData.customParameters.get('name');\n        //   this.callData.img = incomingCallData.customParameters.get('image');\n        //   this.callData.isIncomingCall = true;\n        // }\n        if (incomingCallData) {\n          if (this.isCallInProgress) {\n            this.newIncomingCalls.push(incomingCallData);\n            this.getUserInformation(incomingCallData);\n          } else {\n            this.isCallInProgress = true;\n            this.isDialpadHidden = false;\n            this.callData.phone = incomingCallData.parameters['From'];\n\n            this.getUserInformation(incomingCallData);\n            this.callData.name = incomingCallData.customParameters.get('name');\n            this.callData.img = incomingCallData.customParameters.get('image') || 'assets/images/user.jpg';\n            this.callData.isIncomingCall = true;\n          }\n          incomingCallData.on('cancel', () => {\n            this.incomingCallsList = this.incomingCallsList.filter((item: any) => item.parameters.CallSid !== incomingCallData.parameters['CallSid']);\n            if(this.incomingCallsList.length == 0){\n              this.isCallInProgress = false;\n            }\n          });\n\n          incomingCallData.on('disconnect', () => {\n              this.incomingCallsList = this.incomingCallsList.filter((item: any) => item.parameters.CallSid !== incomingCallData.parameters['CallSid']);\n              if(this.incomingCallsList.length == 0){\n                this.isCallInProgress = false;\n              }\n          });\n        }\n      });\n\n      this.subscriptions.add(sub1);\n      this.subscriptions.add(sub2);\n    }catch(e){\n      console.log(e)\n    }\n    \n  }\n\n  \n  getUserInformation(incomingCallData: any) {\n    // console.log('getUserInformation', incomingCallData);\n    let data = this.fromEntries(Array.from(incomingCallData.customParameters.entries()));\n    this.extensionService.getUserInformation(data['twilioAuthId']).subscribe(\n    response => {\n      incomingCallData['userInfo']=response\n      this.incomingCallsList.push(incomingCallData);\n    }, error => {\n      console.error('Error starting recording', error);\n    });\n  }\n\n  fromEntries(entries: [string, any][]): Record<string, any> {\n    return entries.reduce((acc, [key, value]) => {\n      acc[key] = value;\n      return acc;\n    }, {} as Record<string, any>);\n  }\n\n  ngAfterViewInit() {\n    this.registerDragElement();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['isDialpadHidden']) {\n      if (!this.isDialpadHidden) {\n        // Focus the input when dialpad becomes visible\n        setTimeout(() => {\n          if (this.dialInputElement?.nativeElement) {\n            this.dialInputElement.nativeElement.focus();\n          }\n        }, 0);\n      }\n    }\n  }\n  private registerDragElement() {\n    try {\n      const elmnt = document.getElementById('dragparent1');\n      if (!elmnt) {\n        console.error('Drag element not found');\n        return;\n      }\n\n      let pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;\n\n      const dragMouseDown = (e: MouseEvent) => {\n        const target = e.target as HTMLElement;\n        if (target.tagName.toLowerCase() === 'input') {\n          return;\n        }\n\n        e.preventDefault();\n        pos3 = e.clientX;\n        pos4 = e.clientY;\n        \n        const onMouseMove = (moveEvent: MouseEvent) => elementDrag(moveEvent);\n        const onMouseUp = () => {\n          document.removeEventListener('mouseup', onMouseUp);\n          document.removeEventListener('mousemove', onMouseMove);\n        };\n\n        document.addEventListener('mousemove', onMouseMove);\n        document.addEventListener('mouseup', onMouseUp);\n      };\n\n      const elementDrag = (e: MouseEvent) => {\n        e.preventDefault();\n        pos1 = pos3 - e.clientX;\n        pos2 = pos4 - e.clientY;\n        pos3 = e.clientX;\n        pos4 = e.clientY;\n        \n        elmnt.style.top = (elmnt.offsetTop - pos2) + 'px';\n        elmnt.style.left = (elmnt.offsetLeft - pos1) + 'px';\n      };\n\n      // Check for header element\n      const header = document.getElementById(elmnt.id + 'header');\n      if (header) {\n        header.onmousedown = dragMouseDown;\n      } else {\n        elmnt.onmousedown = dragMouseDown;\n      }\n    } catch (e) {\n      console.log(e)\n    }\n  }\n\n  addNumber(num: any) {\n    if ( num == '#' || num == '*' ||num == '+' || Number.isInteger(num)) {\n      if (num == '#') {\n        new Audio(`/assets/dial-tones/dtmf/dtmf-hash-.mp3`).play();\n      } else if (num == '*') {\n        new Audio(`/assets/dial-tones/dtmf/dtmf-star-.mp3`).play();\n      } else {\n        new Audio(`/assets/dial-tones/dtmf/dtmf-${num}-.mp3`).play();\n      }\n\n      this.dialedNumber += num;\n      this.showInputClearBtn = true;\n\n      this.numberDialed.emit(this.dialedNumber);\n\n      this.onDialInputChange(this.dialedNumber)\n      // this.dialInputRef.nativeElement.focus();\n    }else if(num === 'voicemail'){\n      // this.showDedicatedPopup = true;\n      this.router.navigate(['extension/voicemail/'+this.token]);\n    }\n  }\n  \n  hideDialpad() {\n    this.isDialpadHidden = true;\n    this.closeDialpadEvent.emit();\n    this.clearAllDialed();\n    this.filteredContactList = [];\n  }\n  \n  onDialInputChange(inputVal: any) {\n    try {\n      // Updated regex to include x, X, ext., Ext., and ,\n      const isNumericInput = /^[\\d\\s+\\-]+$/.test(inputVal);\n      let mainNumber = inputVal;\n\n      // Check for extension indicators and split the input\n      const extMatch = inputVal.match(/(x|X|ext\\.|Ext\\.|,)(.*)/);\n      if (extMatch) {\n        mainNumber = inputVal.substring(0, extMatch.index).trim();\n        this.callData.extNum = extMatch[2].trim();\n      }\n      this.sanitizedNum = isNumericInput ? mainNumber.replace(/[\\s\\-]+/g, '') : mainNumber;\n\n      this.callData.phone = isNumericInput ? this.sanitizedNum : '';\n      this.showInputClearBtn = inputVal.length > 0;\n\n      if (isNumericInput) {\n        this.dialedNumber = new AsYouType().input(this.sanitizedNum);\n      }\n\n      // emit current number whenever input changes\n      this.numberDialed.emit(this.dialedNumber);\n\n      if (inputVal.length > 2) {\n        this.filteredContactList = this.contactList.filter(contact => {\n          const fullName = `${contact.firstName} ${contact.middleName} ${contact.lastName}`.toLowerCase();\n          return fullName.includes(this.sanitizedNum.toLowerCase()) || contact.numbersList.some((num: any) => num.number.includes(this.sanitizedNum));\n        }).slice(0, 2);\n      } else {\n        this.filteredContactList = [];\n      }\n\n    } catch (e) {\n      console.log(e);\n    }\n  }\n\n  getFirstLetter(name: string): string {\n    return name ? name.charAt(0).toUpperCase() : '';\n  }\n  clearInput() {\n    if (this.dialedNumber.length > 0) {\n      this.dialedNumber = this.dialedNumber.slice(0, -1);\n      this.showInputClearBtn = this.dialedNumber.length !== 0;\n\n      this.onDialInputChange(this.dialedNumber)\n    }\n  }\n  clearAllDialed() {\n    this.dialedNumber = '';\n    this.sanitizedNum = '';\n    this.showInputClearBtn = false;\n  }\n  getCallerIdList() {\n    this.extService.displayID(this.token || '').subscribe((res: any) => {\n      //this.callerIdList = res.callerIdList.filter(item => item.type === \"C2C Softphone Number\");\n      this.callerIdList = res.callerIdList.filter((item: any) => item.voiceFeature === true);\n      // this.callerIdList = res.callerIdList;\n      if (this.callerIdList.length == 1) {\n        this.selectedCallerId = this.callerIdList[0];\n      } else {\n        if (this.callPreference === 'alwaysAsk' || this.callPreference === 'smartDialing') {\n          this.selectedCallerId = null;\n        } else {\n          this.selectedCallerId = this.callerIdList.find(item => (item.number == this.callPreference));\n        }\n      }\n    });\n  }\n  getContactList() {\n    this.twilioService.getContactList().subscribe((resp: any) => {\n      if (resp.response == 'Success') {\n        this.contactList = resp.phoneBook;\n      }\n    }, err => {\n      console.log(err)\n    })\n  }\n  getFullName(contact: any): string {\n    let fullName = contact.firstName || '';\n    if (contact.middleName) {\n      fullName += ` ${contact.middleName}`;\n    }\n    if (contact.lastName) {\n      fullName += ` ${contact.lastName}`;\n    }\n    return fullName.trim();\n  }\n\n\n  toggleCallerIdDiv() {\n    this.isCallerIdHidden = !this.isCallerIdHidden;\n  }\n\n  onContactSelect(contact: any) {\n    this.dialedNumber = contact.numbersList[0].number;\n    this.callData.name = this.getFullName(contact);\n    this.callData.img = contact.image || 'assets/images/user.jpg';\n    this.onDialInputChange(this.dialedNumber);\n    this.filteredContactList = [];\n  }\n\n  endCall() {\n    try {\n      console.log('Ending call');\n      this.isCallInProgress = false;\n      this.filteredContactList = [];\n      \n      // Reset call data\n      this.callData = {\n        phone: '',\n        name: '',\n        img: 'assets/images/user.jpg',\n        isIncomingCall: false,\n        dial: false,\n        displayNum: '',\n        extNum: ''\n      };\n      \n      // Reset dialed number\n      this.dialedNumber = '';\n      this.sanitizedNum = '';\n      \n      // Emit end call event\n      this.endCallEvent.emit();\n      console.log('Call ended successfully');\n      \n    } catch (error) {\n      console.error('Error in endCall:', error);\n      // Even if there's an error, try to reset the state\n      this.isCallInProgress = false;\n      this.callData = {\n        phone: '',\n        name: '',\n        img: 'assets/images/user.jpg',\n        isIncomingCall: false,\n        dial: false,\n        displayNum: '',\n        extNum: ''\n      };\n      this.endCallEvent.emit();\n    }\n  }\n\n  // async initiateCall() {\n  //   try {\n  //     console.log('Initiating call with number:', this.dialedNumber);\n      \n  //     if (!this.dialedNumber && this.lastDialed) {\n  //       console.log('Using last dialed number:', this.lastDialed.number);\n  //       this.sanitizedNum = this.lastDialed.number;\n  //     }\n\n  //     const isInvalid = await this.isInvalidNumber();\n  //     if (isInvalid) {\n  //       console.error('Invalid number format');\n  //       return false;\n  //     }\n\n  //     this.saveLastDialed();\n  //     this.isSavedContactDialled();\n      \n  //     // Check payment status\n  //     this.isPaymentDue = localStorage.getItem('paymentDue') === 'true';\n  //     if (this.isPaymentDue) {\n  //       console.warn('Payment is due');\n  //       swal('Warning', 'Please note that your payment is due. To continue using our services, kindly subscribe to avoid interruptions.');\n  //       return false;\n  //     }\n\n  //     // Check if dialing own number\n  //     if (this.sanitizedNum === localStorage.getItem('twilioNumber')) {\n  //       console.error('Attempted to dial own number');\n  //       swal('Error', 'You cannot dial your own number');\n  //       return false;\n  //     }\n\n  //     // Check microphone permissions\n  //     const hasPermission = await this.checkMicrophonePermission();\n  //     if (!hasPermission) {\n  //       console.warn('Microphone permission not granted');\n  //       await this.askForMicrophonePermission();\n  //       return false;\n  //     }\n\n  //     if (!this.selectedCallerId) {\n  //       console.error('No caller ID selected');\n  //       this.shakeDedicatedBtn = true;\n  //       this.showDialAlert('Please select a C2C number to call from');\n  //       setTimeout(() => {\n  //         this.shakeDedicatedBtn = false;\n  //       }, 3000);\n  //       return false;\n  //     }\n\n  //     console.log('Getting number with country code...');\n  //     this.callData.displayNum = '';\n      \n  //     try {\n  //       await this.getToNumber(this.sanitizedNum);\n  //     } catch (error) {\n  //       console.error('Error getting number with country code:', error);\n  //       this.showDialAlert('Error processing number. Please try again.');\n  //       return false;\n  //     }\n\n  //     if (this.terminateCall) {\n  //       console.log('Call terminated by user');\n  //       this.terminateCall = false;\n  //       return false;\n  //     }\n\n  //     // Prepare call data\n  //     this.callData = {\n  //       ...this.callData,\n  //       phone: this.sanitizedNum,\n  //       isIncomingCall: false,\n  //       dial: true,\n  //       from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n  //       timestamp: new Date().toISOString()\n  //     };\n\n  //     console.log('Initiating call with data:', this.callData);\n  //     this.isCallInProgress = true;\n  //     this.callInitiated.emit({ ...this.callData });\n      \n  //     return true;\n      \n  //   } catch (error) {\n  //     console.error('Error in initiateCall:', error);\n  //     this.showDialAlert('Failed to initiate call. Please try again.');\n  //     this.isCallInProgress = false;\n  //     return false;\n  //   }\n  //     //this.clearAllDialed();\n  //   // } else {\n  //   //   swal('Error', 'Trial period is over. Please setup payment method to continue services')\n  //   // }\n  // }\n\n\n  //  async initiateCall() {\n  //   if (!this.dialedNumber && this.lastDialed) {\n  //     this.sanitizedNum = this.lastDialed.number;\n  //   }\n  //   const isInvalid = await this.isInvalidNumber();\n  //   if (isInvalid) {\n  //     return false;\n  //   }\n  //   this.saveLastDialed();\n  //   this.isSavedContactDialled();\n  //   //let isCallerIdSet = await this.isCallerIdSet();\n  //   this.isPaymentDue = localStorage.getItem('paymentDue') == 'false' ? false : true;\n  //   if (this.isPaymentDue) {\n  //     swal('Warning', 'Please note that your payment is due, To continue on your services kindly subscribe to use uninterrupted services.');\n  //     return;\n  //   }\n  //   this.isTrialPeriodOver = localStorage.getItem('trialOver') == 'false' ? false : true;\n  //   // if (!this.isTrialPeriodOver) {\n  //     if (this.sanitizedNum == localStorage.getItem('twilioNumber')) {\n  //       swal('Error', 'You can not dial this number');\n  //       return;\n  //     }\n\n  //     const hasPermission = await this.checkMicrophonePermission();\n  //     if (hasPermission) {\n  //       if (this.selectedCallerId) {\n  //         //clear displayNum if value is binded from previous call\n  //         this.callData.displayNum = '';\n  //         // get number to be dialled from backend\n  //         await this.getToNumber(this.sanitizedNum);\n  //         if (this.terminateCall) {\n  //           this.terminateCall = false;\n  //           return;\n  //         }\n  //         this.callData.phone = this.sanitizedNum;\n  //         this.callData.isIncomingCall = false;\n  //         this.callData.dial = true;\n  //         if (!this.isSmartDialCall) {\n  //           this.callData.from = this.selectedCallerId.number;\n  //         }\n          \n  //         this.isCallInProgress = true;\n  //               this.callData = {\n  //               ...this.callData,\n  //               phone: this.sanitizedNum,\n  //               isIncomingCall: false,\n  //               dial: true,\n  //               from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n  //               timestamp: new Date().toISOString()\n  //             };\n\n  //             console.log('Initiating call with data:', this.callData);\n  //             this.isCallInProgress = true;\n  //             this.callInitiated.emit({ ...this.callData });\n  //         return true;\n  //       } else {\n  //         this.shakeDedicatedBtn = true;\n  //         this.showDialAlert('Select a C2C number to call');\n  //         setTimeout(() => {\n  //           this.shakeDedicatedBtn = false;\n  //         }, 3000);\n  //         return false;\n  //       }\n  //       //this.callingOpenEvent.emit({ phone: this.dialedNumber });\n  //     } else {\n  //       await this.askForMicrophonePermission();\n  //     }\n  //     //this.clearAllDialed();\n  //   // } else {\n  //   //   swal('Error', 'Trial period is over. Please setup payment method to continue services')\n  //   // }\n  // }\n\n\n  // async initiateCall() {\n  //   try{\n  //     if (!this.dialedNumber && this.lastDialed) {\n  //       this.sanitizedNum = this.lastDialed.number;\n  //     }\n\n  //     const isInvalid = await this.isInvalidNumber();\n  //     if (isInvalid) {\n  //       return false;\n  //     }\n  //     this.saveLastDialed();\n  //     this.isSavedContactDialled();\n  //     //let isCallerIdSet = await this.isCallerIdSet();\n\n  //     this.isPaymentDue = localStorage.getItem('paymentDue') == 'false' ? false : true;\n  //     if (this.isPaymentDue) {\n  //       swal('Warning', 'Please note that your payment is due, To continue on your services kindly subscribe to use uninterrupted services.');\n  //       return false;\n  //     }\n\n  //     this.isTrialPeriodOver = localStorage.getItem('trialOver') == 'false' ? false : true;\n  //     // if (!this.isTrialPeriodOver) {\n  //       if (this.sanitizedNum == localStorage.getItem('twilioNumber')) {\n  //         swal('Error', 'You can not dial this number');\n  //         return false;\n  //       }\n\n  //       const hasPermission = await this.checkMicrophonePermission();\n  //       if (hasPermission) {\n  //         if (this.selectedCallerId) {\n  //           //clear displayNum if value is binded from previous call\n  //           this.callData.displayNum = '';\n  //           // get number to be dialled from backend\n  //           await this.getToNumber(this.sanitizedNum);\n  //           if (this.terminateCall) {\n  //             this.terminateCall = false;\n  //             return;\n  //           }\n  //           this.callData.phone = this.sanitizedNum;\n  //           this.callData.isIncomingCall = false;\n  //           this.callData.dial = true;\n  //           if (!this.isSmartDialCall) {\n  //             this.callData.from = this.selectedCallerId.number;\n  //           }\n            \n  //           this.isCallInProgress = true;\n  //                 this.callData = {\n  //                 ...this.callData,\n  //                 phone: this.sanitizedNum,\n  //                 isIncomingCall: false,\n  //                 dial: true,\n  //                 from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n  //                 timestamp: new Date().toISOString()\n  //               };\n\n  //               console.log('Initiating call with data:', this.callData);\n  //               this.isCallInProgress = true;\n  //               this.callInitiated.emit({ ...this.callData });\n  //           return true;\n  //         } else {\n  //           this.shakeDedicatedBtn = true;\n  //           this.showDialAlert('Select a C2C number to call');\n  //           setTimeout(() => {\n  //             this.shakeDedicatedBtn = false;\n  //           }, 3000);\n  //           return false;\n  //         }\n  //         //this.callingOpenEvent.emit({ phone: this.dialedNumber });\n  //       } else {\n  //         await this.askForMicrophonePermission();\n  //       }\n  //       //this.clearAllDialed();\n  //     // } else {\n  //     //   swal('Error', 'Trial period is over. Please setup payment method to continue services')\n  //     // }\n  //   }catch(e){\n  //     console.error('Error in initiateCall:', e);\n\n  //     this.showDialAlert('Failed to initiate call. Please try again.');\n\n  //     this.isCallInProgress = false;\n\n  //     return false;\n  //   }\n  // }\n\n\n  async initiateCall() {\n    try {\n      if (!this.dialedNumber && this.lastDialed) {\n        this.sanitizedNum = this.lastDialed.number;\n      }\n  \n      const isInvalid = await this.isInvalidNumber();\n      if (isInvalid) {\n        return false;\n      }\n      this.saveLastDialed();\n      this.isSavedContactDialled();\n  \n      this.isPaymentDue = localStorage.getItem('paymentDue') === 'false' ? false : true;\n      if (this.isPaymentDue) {\n        swal('Warning', 'Please note that your payment is due, To continue on your services kindly subscribe to use uninterrupted services.');\n        return false;\n      }\n  \n      this.isTrialPeriodOver = localStorage.getItem('trialOver') === 'false' ? false : true;\n      \n      if (this.sanitizedNum === localStorage.getItem('twilioNumber')) {\n        swal('Error', 'You can not dial this number');\n        return false;\n      }\n  \n      const hasPermission = await this.checkMicrophonePermission();\n      if (!hasPermission) {\n        await this.askForMicrophonePermission();\n        return false;\n      }\n  \n      if (!this.selectedCallerId) {\n        this.shakeDedicatedBtn = true;\n        this.showDialAlert('Select a C2C number to call');\n        setTimeout(() => {\n          this.shakeDedicatedBtn = false;\n        }, 3000);\n        return false;\n      }\n  \n      // Clear displayNum if value is bound from previous call\n      this.callData.displayNum = '';\n      \n      // Get number to be dialed from backend\n      await this.getToNumber(this.sanitizedNum);\n      if (this.terminateCall) {\n        this.terminateCall = false;\n        return;\n      }\n  \n      // Update call data in a single operation\n      this.callData = {\n        ...this.callData,\n        phone: this.sanitizedNum,\n        isIncomingCall: false,\n        dial: true,\n        from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n        timestamp: new Date().toISOString()\n      };\n  \n      // console.log('Initiating call with data:', this.callData);\n      this.isCallInProgress = true;\n      this.callInitiated.emit({ ...this.callData });\n      return true;\n  \n    } catch (e) {\n      // console.error('Error in initiateCall:', e);\n      this.showDialAlert('Failed to initiate call. Please try again.');\n      this.isCallInProgress = false;\n      return false;\n    }\n  }\n\n  async isInvalidNumber() {\n    try {\n      if(this.sanitizedNum == ''){\n        this.showDialAlert('Invalid Number');\n        return true;\n      }\n      const validNumberPattern = /^[+\\d\\s()-]*$/; // Regular expression to match valid characters\n      const phoneNumber = this.sanitizedNum;\n      if (!validNumberPattern.test(phoneNumber)) {\n        this.showDialAlert('Invalid Number');\n        return true;\n      }\n      return false;\n    } catch (error) {\n      this.showDialAlert('Invalid Number');\n      return true; // Return true if an error occurred, meaning the number is invalid\n    }\n  }\n  \n  saveLastDialed() {\n    const contact = this.filteredContactList.find((c: any) => c.numbersList.some((n: any) => n.number === this.dialedNumber));\n    if (contact) {\n      this.lastDialed = {\n        name: contact.name,\n        image: contact.image,\n        number: this.dialedNumber\n      };\n    } else {\n      if(this.dialedNumber){\n        this.lastDialed = { number: this.dialedNumber };\n      }\n      \n    }\n  }\n  isSavedContactDialled(){\n    let phoneNum = this.sanitizedNum.replace(/\\s+/g, '');\n    let contact =  this.contactList.filter((contact: any) => {\n      return contact.numbersList.some((num: any) => num.number === phoneNum)\n    });\n    if(contact.length){\n      this.callData.name = `${contact[0].firstName} ${contact[0].middleName} ${contact[0].lastName}`.toLowerCase();\n      this.callData.img = contact[0].image || 'assets/images/user.jpg';\n      this.callData.phone = this.sanitizedNum;\n\n      return true;\n    }\n    return false;\n  }\n  showDialAlert(message: string) {\n    this.dialAlert = {\n      msg: message,\n      show: true\n    };\n    setTimeout(() => {\n      this.dialAlert.show = false;\n    }, 3000);\n  }\n  async isCallerIdSet(): Promise<boolean> {\n    try {\n      const tkn = localStorage.getItem('ext_token');\n      const res: any = await this.extService.fetchCallerId(tkn || '').toPromise();\n      if (res.status == 200) {\n        localStorage.setItem('trialOver', res.trialOver);\n        this.twilioService.isTrialOver.next(res.trialOver);\n        localStorage.setItem('paymentDue', res.paymentDue);\n        this.twilioService.isPaymentDue.next(res.paymentDue);\n      }\n      if (res.callerid) {\n        localStorage.setItem('callerID', res.callerid);\n\n        this.extService.changeMessage(res.callerid);\n      } else {\n        localStorage.setItem('callerID', 'Not set');\n        this.extService.changeMessage('Not set');\n      }\n\n      return (localStorage.getItem('callerID') !== 'Not set');\n    } catch (e) {\n      console.log(e);\n      return false;\n    }\n  }\n  async checkMicrophonePermission(): Promise<boolean> {\n    try {\n      const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\n      stream.getTracks().forEach(track => track.stop());\n      return true;\n    } catch (error) {\n      if ((error as any).name === 'NotAllowedError') {\n        return false;\n      } else {\n        return false;\n      }\n    }\n  }\n  async askForMicrophonePermission(): Promise<void> {\n    try {\n      const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\n      stream.getTracks().forEach(track => track.stop());\n    } catch (error) {\n      console.error('User denied microphone permission:', error);\n    }\n  }\n  // below function is to get the country code with number from server \n  async getToNumber(dialedNumber: string) {\n    \n      if (dialedNumber[0] !== '+') {\n        // this is case when user geolocation dial code is on\n        let ipAddress: any = await this.ipService.getIpAddressInfo().toPromise();\n        const res: any = await this.twilioService.getToNumber(dialedNumber,ipAddress.address.countryCode).toPromise();\n        if (res.status == 200) {\n          this.toastTimeout = res.timeInterval * 1000;\n          await this.showNumberToast(res);\n        }\n      }\n  }\n  isAlertEnable() {\n    return localStorage.getItem('isAlertEnable');\n  }\n  async showNumberToast(data: any) {\n    const isAlertOn = (localStorage.getItem('isCountryCodeToastOn'));\n    if (isAlertOn == 'true') {\n      this.callNumberToast.show = true;\n      this.callNumberToast.number = data.toNumber;\n      this.callNumberToast.displayNum = data.displayNumber;\n    }\n    \n    \n    this.callData.displayNum = data.displayNumber;\n    //this.callData.phone = data.toNumber;\n    await this.delay(this.toastTimeout);\n    this.dialedNumber = data.toNumber;\n    this.sanitizedNum = data.toNumber;\n    this.callNumberToast.show = false;\n    this.callNumberToast.number = '';\n    this.callNumberToast.displayNum = '';\n  }\n  delay(ms: number) {\n    return new Promise<void>(resolve => setTimeout(resolve, ms));\n  }\n  isMinimised: boolean = false;\n  onMinimise(isMinimised: boolean) {\n    this.isMinimised = isMinimised;\n    this.minimiseEvent.emit(isMinimised);\n  }\n  handleNumberPaste(event: ClipboardEvent): void {\n    event.preventDefault();\n    const clipboardData = event.clipboardData || (window as any).clipboardData;\n    const pastedData = clipboardData.getData('text');\n\n    // Log the pasted content to the console\n    if(pastedData){\n      this.dialedNumber = pastedData;\n      this.sanitizedNum = pastedData;\n    }\n    \n  }\n  onEnter(num:string) {\n    // console.log(num, 'number fn')\n    this.dialedNumber = this.dialedNumber +num;\n    this.sanitizedNum = this.dialedNumber;\n    this.showInputClearBtn = true;\n    this.numberDialed.emit(this.dialedNumber);\n  }\n  \n  getUserCallSetting() {\n    const tkn = localStorage.getItem('ext_token');\n    this.extService.fetchCallerId(tkn || '').subscribe((resp: any) => {\n      if (resp.status == 200) {\n        //this.callPrefernce = resp.userSetting;\n        this.callPreference = resp.callerid;\n        this.getCallerIdList();\n      }\n    })\n  }\n  onDedicatedNumSelect(id: any) {\n    this.selectedCallerId = id;\n    this.isCallerIdHidden = true;\n    this.extService.setCallerId(id);\n  }\n  cancelDialNumber() {\n    this.terminateCall = true;\n    this.callNumberToast.show = false;\n  }\n\n  handleDivKeydown(ev:any){\n    if(this.dialedNumber.length == 0){\n      this.dialInputElement.nativeElement.focus();\n    }\n    if (ev.key === 'Enter') {\n      // Check if the dialpad is open\n      if (!this.isDialpadHidden) {\n        if(this.dialedNumber.length > 2 && this.selectedCallerId){\n          this.initiateCall();\n        }\n        if(!this.selectedCallerId){\n          this.shakeDedicatedBtn = true;\n          setTimeout(() => {\n            this.shakeDedicatedBtn = false;\n          }, 10000);\n        }\n      }\n    }\n  }\n  onCallBtnMouseEnter(ev: any) {\n    if (!this.selectedCallerId || (this.selectedCallerId == 'alwaysAsk') || (this.selectedCallerId == 'smartDialing')) {\n      this.shakeDedicatedBtn = true;\n    }\n\n  }\n  onCallBtnMouseLeave(ev: any) {\n    if (!this.selectedCallerId || (this.selectedCallerId == 'alwaysAsk') || (this.selectedCallerId == 'smartDialing')) {\n      this.shakeDedicatedBtn = false;\n    }\n  }\n  acceptNewIncomingCall(call: Call) {\n    //first cut the current call\n    //this.callData = call;\n    this.newIncomingCallData = call;\n  }\n  rejectNewIncomingCall(call: Call) {\n    call.reject();\n    this.newIncomingCalls = this.newIncomingCalls.filter((item: any) => item.parameters.CallSid !== call.parameters['CallSid']);\n    this.incomingCallsList = this.incomingCallsList.filter((item: any) => item.parameters.CallSid !== call.parameters['CallSid']);\n  }\n  newIncomingCallInitiated() {\n    this.isCallInProgress = true;\n    this.newIncomingCalls = [];\n    this.incomingCallInitiated.emit();\n  }\n  incomingCallsNewInfo(data:any){\n    this.incomingCallsList = data;\n    this.incomingCallsNewInfoEvent.emit(data);\n  }\n  ngOnDestroy() {\n    try {\n      console.log('Cleaning up C2cDialpadComponent');\n      \n      // Unsubscribe from all subscriptions\n      if (this.subscriptions) {\n        this.subscriptions.unsubscribe();\n      }\n      \n      // End any active call\n      if (this.isCallInProgress) {\n        this.endCall();\n      }\n      \n      // Clear any timeouts or intervals if they exist\n      if (this.toastTimeout) {\n        clearTimeout(this.toastTimeout);\n      }\n      \n      console.log('C2cDialpadComponent cleanup complete');\n      \n    } catch (error) {\n      console.error('Error during component cleanup:', error);\n    }\n  }\n}\n","<div id=\"dragparent1\" [ngStyle]=\"{'display':isDialpadHidden ? 'none': 'block'}\">\r\n  <lib-call-progress *ngIf=\"isCallInProgress\"\r\n   (endCallEvent)=\"endCall()\"\r\n   (minimiseEvent)=\"onMinimise($event)\"\r\n   (incomingCallInitiated)=\"newIncomingCallInitiated()\"\r\n   [newIncomingCallData]=\"newIncomingCallData\"\r\n   [newIncomingCallsList]=\"incomingCallsList\"\r\n   (incomingCallsNewInfo)=\"incomingCallsNewInfo($event)\"\r\n   [callData]=\"callData\">\r\n  </lib-call-progress>\r\n  <div class=\"dialpad-container\" [ngClass]=\"{'mini-dialpad': isMinimised}\" tabindex=\"0\" (keydown)=\"handleDivKeydown($event)\">\r\n    <div id=\"topPanel\" [ngStyle]=\"{'height': callerIdList.length ? '40%' : '39%'}\">\r\n      <div class=\"dialpad-alerts\" *ngIf=\"dialAlert.show\">\r\n        <div class=\"no-selection-alert\">\r\n          <!-- <p class=\"mb-0\">Select C2C number to call</p> -->\r\n          <p class=\"mb-0\">{{dialAlert.msg}}</p>\r\n          <span class=\"fa fa-times\" (click)=\"shakeDedicatedBtn = false\"></span>\r\n        </div>\r\n      </div>\r\n      <div class=\"dialpad-alerts\" *ngIf=\"callNumberToast.show\">\r\n        <div class=\"dialbox-pop1 alert fade show\" [ngClass]=\"callNumberToast.type\" role=\"alert\">\r\n          <div class=\"d-flex justify-content-between\">\r\n            <div class=\"flex-grow-1 my-auto text-left\">\r\n              You'r calling <strong>{{callNumberToast.displayNum}}</strong>\r\n            </div>\r\n            <div class=\"text-right\">\r\n              <button class=\"btn btn-link btn-disc p-0 px-1\" (click)=\"cancelDialNumber()\">Cancel Call</button>\r\n              <!-- <button class=\"btn btn-link btn-success btn-disc p-0 px-2\">Continue</button> -->\r\n            </div>\r\n      \r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div style=\"padding: 0 18px\" (paste)=\"handleNumberPaste($event)\">\r\n        <div class=\"d-flex justify-content-between mt-2\">\r\n          <p></p>\r\n          <span class=\"material-symbols-outlined dial-close-btn\" (click)=\"hideDialpad()\">\r\n            <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#ffffff\"><path d=\"m256-200-56-56 224-224-224-224 56-56 224 224 224-224 56 56-224 224 224 224-56 56-224-224-224 224Z\"/></svg>\r\n          </span>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" #dialInput placeholder=\"Enter a name or number\" tabindex=\"1\" [(ngModel)]=\"dialedNumber\" (ngModelChange)=\"onDialInputChange($event)\"/>\r\n          <span class=\"\" id=\"input-clear-btn\" (click)=\"clearInput()\" *ngIf=\"showInputClearBtn\">\r\n            <svg width=\"50px\" height=\"30px\" viewBox=\"0 10 40 60\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" baseProfile=\"full\" enable-background=\"new 0 0 76.00 76.00\" xml:space=\"preserve\">\r\n              <path fill=\"#5d6061\" fill-opacity=\"1\" stroke-width=\"0.2\" stroke-linejoin=\"round\" d=\"M 47.5282,42.9497L 42.5784,38L 47.5282,33.0502L 44.9497,30.4718L 40,35.4216L 35.0502,30.4718L 32.4718,33.0502L 37.4216,38L 32.4718,42.9497L 35.0502,45.5282L 40,40.5784L 44.9497,45.5282L 47.5282,42.9497 Z M 18.0147,41.5355L 26.9646,50.4854C 28.0683,51.589 29,52 31,52L 52,52C 54.7614,52 57,49.7614 57,47L 57,29C 57,26.2386 54.7614,24 52,24L 31,24C 29,24 28.0683,24.4113 26.9646,25.5149L 18.0147,34.4645C 16.0621,36.4171 16.0621,39.5829 18.0147,41.5355 Z M 31,49C 30,49 29.6048,48.8828 29.086,48.3641L 20.1361,39.4142C 19.355,38.6332 19.355,37.3669 20.1361,36.5858L 29.086,27.6362C 29.6048,27.1175 30,27 31,27.0001L 52,27.0001C 53.1046,27.0001 54,27.8955 54,29.0001L 54,47.0001C 54,48.1046 53.1046,49.0001 52,49.0001L 31,49 Z \"/>\r\n            </svg>        \r\n          </span>\r\n          <span class=\"input-info-icon\" placement=\"bottom-right\" tooltipClass=\"input-tooltip\" ngbTooltip=\"For extension dialing, use formats like +12345678910 x123,+12345678910 ext.123, +12345678910,123\"><i class=\"fa fa-info-circle\"></i></span>\r\n        </div>\r\n        <div class=\"guide\" *ngIf=\"callerIdList.length && !(dialedNumber.length > 2)\">\r\n          <span class=\"guidetext\">Please enter a number or select a saved contact</span>\r\n        </div>\r\n        <!-- <div class=\"input-error\" *ngIf=\"dialAlert.show\">\r\n          <span>{{dialAlert.msg}}</span>\r\n        </div> -->\r\n        <div>\r\n          <div class=\"contact-card\" *ngFor=\"let contact of filteredContactList\" (click)=\"onContactSelect(contact)\">\r\n            <div class=\"contact-img\">\r\n              <img [src]=\"contact.image\" alt=\"user image\" loading=\"lazy\" *ngIf=\"contact.image else alphaName\"/>\r\n              <ng-template #alphaName>\r\n                <span class=\"contact-alpha-img\">{{getFirstLetter(contact.firstName)}}</span>\r\n              </ng-template>\r\n            </div>\r\n            <div class=\"contact-details\">\r\n              <p style=\"margin-bottom: 4px\" class=\"contact-name\">{{getFullName(contact) }}</p>\r\n              <p>{{contact.numbersList[0].number}}</p>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"wave-container\">\r\n        <svg\r\n          class=\"waves\"\r\n          xmlns=\"http://www.w3.org/2000/svg\"\r\n          xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n          viewBox=\"0 24 150 28\"\r\n          preserveAspectRatio=\"none\"\r\n          shape-rendering=\"auto\"\r\n        >\r\n          <defs>\r\n            <path\r\n              id=\"gentle-wave\"\r\n              d=\"M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z\"\r\n            />\r\n          </defs>\r\n          <g class=\"parallax\">\r\n            <use\r\n              xlink:href=\"#gentle-wave\"\r\n              x=\"48\"\r\n              y=\"0\"\r\n              fill=\"rgba(255,255,255,0.7)\"\r\n            />\r\n            <use\r\n              xlink:href=\"#gentle-wave\"\r\n              x=\"48\"\r\n              y=\"3\"\r\n              fill=\"rgba(255,255,255,0.5)\"\r\n            />\r\n            <!-- <use\r\n              xlink:href=\"#gentle-wave\"\r\n              x=\"48\"\r\n              y=\"5\"\r\n              fill=\"rgba(255,255,255,0.3)\"\r\n            /> -->\r\n            <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"7\" fill=\"#fff\" />\r\n          </g>\r\n        </svg>\r\n      </div>\r\n    </div>\r\n    <div class=\"btn-container\" *ngIf=\"!isMinimised\">\r\n      <button class=\"dial-btn\" *ngFor=\"let key of keypadVal;let i = index\"\r\n      (keydown.enter)=\"onEnter(key.num)\" (click)=\"addNumber(key.num)\"\r\n      [ngStyle]=\"{'margin-top': key.text === '+' ? '3px' : '0'}\"\r\n       [tabindex]=\"dialedNumber.length ? '0': i+2\" longPress (longPress)=\"addNumber(key.text)\" shortPress (shortPress)=\"addNumber(key.num)\">\r\n        {{key.num}} \r\n        <span *ngIf=\"key.num == 1;else otherThanOne\" class=\"material-symbols-outlined voicemail\">\r\n          voicemail\r\n        </span>\r\n        <ng-template #otherThanOne>\r\n          <span class=\"btn-albhabets\" [ngClass]=\"{'plusSign': key.text === '+'}\">{{key.text ? key.text : '&nbsp;'}}</span>\r\n        </ng-template>\r\n      </button>\r\n    </div>\r\n    <div class=\"call-btn-container\" *ngIf=\"!isMinimised\" (mouseenter)=\"onCallBtnMouseEnter($event)\" (mouseleave)=\"onCallBtnMouseLeave($event)\">\r\n      <div class=\"call-btn\" (click)=\"initiateCall()\" [tabindex]=\"dialedNumber.length ? '2': '15'\"\r\n        [ngStyle]=\"{'pointer-events': dialedNumber.length && selectedCallerId ? 'auto' : 'none', 'opacity': dialedNumber.length && selectedCallerId ? '1' : '0.5'}\">\r\n        <span class=\"material-symbols-outlined\" style=\"color: white\">\r\n          call\r\n        </span>\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"callerIdList.length && !isMinimised\" class=\"position-relative\">\r\n      <div class=\"shownCallerId\" *ngIf=\"selectedCallerId; else askBlock\" (click)=\"toggleCallerIdDiv()\">\r\n        <div>\r\n          <span [ngClass]=\"'fi fi-' + selectedCallerId?.isoCode?.toLowerCase()\"></span>\r\n          {{selectedCallerId?.number}}\r\n        </div>\r\n      </div>\r\n      <ng-template #askBlock>\r\n        <div class=\"shownCallerId\"  (click)=\"toggleCallerIdDiv()\" [ngClass]=\"{ 'tilt-shaking': shakeDedicatedBtn }\">\r\n          <div class=\"d-flex justify-content-center\">\r\n            <h5 class=\"mb-0\">Select C2C number</h5>\r\n            <!-- <span class=\"ml-2\" style=\"opacity:.8;margin-top:2px\">\r\n              <img src=\"assets/images/icon_down_arrow.svg\" alt=\"down\" width=\"10px\">\r\n            </span> -->\r\n            <span class=\"fa fa-angle-down ml-2 text-blue\" style=\"margin-top:2px\"></span>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <div class=\"guide2\" *ngIf=\"shakeDedicatedBtn\">\r\n        <span class=\"guidetext\">Please select a number from below dropdown</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"callerIdList.length; else noCallerIdMessage\">\r\n    <div class=\"caller-id-list-container\" *ngIf=\"callerIdList.length && !isMinimised\" id=\"callerIdContainer\"  [ngClass]=\"{'visible': !isCallerIdHidden}\" >\r\n      <div style=\"display: flex; justify-content: space-between\">\r\n        <!-- <h4>Select C2C Softphone Number</h4> -->\r\n         <h4>Make outgoing call using</h4>\r\n        <span\r\n          class=\"material-symbols-outlined\"\r\n          style=\"cursor: pointer\"\r\n          (click)=\"isCallerIdHidden = true\"\r\n        >\r\n          close\r\n        </span>\r\n      </div>\r\n      <ul>\r\n        <ng-container *ngFor=\"let callerId of callerIdList\">\r\n          <li [ngClass]=\"{'selectedCallerIdClass': callerId?.number == selectedCallerId?.number}\" (click)=\"onDedicatedNumSelect(callerId)\">\r\n            <div>\r\n              <span [ngClass]=\"'fi fi-' + callerId?.isoCode?.toLowerCase()\"></span>\r\n              {{callerId?.number}}\r\n            </div>\r\n            <span>{{callerId?.countryName}}</span>\r\n          </li>\r\n        </ng-container>\r\n      </ul>\r\n    </div>\r\n    </div>\r\n    <ng-template #noCallerIdMessage>\r\n      <span class=\"no-caller-id-message\">To make any voice calls, please <a routerLink=\"/extension/dedicatednumber/{{token}}\" class=\"click-here-link\" title=\"Settings > C2C Number\">subscribe</a> to a voice capable C2C Number.\r\n      </span>\r\n    </ng-template>\r\n    <div class=\"dedicated-overlay\" *ngIf=\"showDedicatedPopup\">\r\n      <div class=\"card dedicatedNumPopup\">\r\n        <div class=\"card-header chooseDedicatedHeader\">\r\n          <h5>Choose C2C Number</h5>\r\n          <span class=\"material-symbols-outlined dial-close-btn\" (click)=\"showDedicatedPopup = false\">close</span>\r\n        </div>\r\n        <div class=\"card-body dedicatedNumList\">\r\n          <ul>\r\n            <ng-container *ngFor=\"let callerId of callerIdList\">\r\n              <li [ngClass]=\"{'selectedCallerIdClass': callerId?.number == selectedCallerId?.number}\" (click)=\"showDedicatedPopup = false\">\r\n                <div>\r\n                  <span [ngClass]=\"'fi fi-' + callerId?.isoCode?.toLowerCase()\"></span>\r\n                  {{callerId?.number}}\r\n                </div>\r\n                <span>{{callerId?.countryName}}</span>\r\n              </li>\r\n            </ng-container>\r\n          </ul>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"incoming-call-widget\" *ngFor=\"let call of newIncomingCalls;let i = index\" [ngStyle]=\"{'top': (30 + i * 72) + 'px'}\">\r\n      <div>\r\n        <div class=\"inc-user-img\">\r\n          <img src=\"assets/images/user.jpg\" alt=\"user image\">\r\n        </div>\r\n        \r\n      </div>\r\n      <div class=\"flex-grow-1\">\r\n        <!-- <h6 class=\"mb-1 font-weight-bold\">Incoming Call</h6> -->\r\n        <p class=\"inc-user-name\">{{call.customParameters.get('name')}}</p>\r\n        <p>{{call.parameters.From}}</p>\r\n\r\n        <!-- <p class=\"inc-user-name\">John Doe</p> \r\n        <p>+12337472489</p>\r\n        <p style=\"font-size: 12px;color:#d5d5d5 !important;margin-top:2px\">Call on +12264584100</p> -->\r\n\r\n      </div>\r\n      <div class=\"d-flex\">\r\n        <button class=\"inc-call-btn inc-accept-btn mr-2\" (click)=\"acceptNewIncomingCall(call)\">\r\n          <span class=\"material-symbols-outlined\" style=\"color: white\">\r\n            call\r\n          </span>\r\n        </button>\r\n        <button class=\"inc-call-btn inc-reject-btn\" (click)=\"rejectNewIncomingCall(call)\">\r\n          <span class=\"material-symbols-outlined\" style=\"color: white\">\r\n            call_end\r\n          </span>\r\n        </button>\r\n      </div>\r\n     \r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
1011
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialbox.component.js","sourceRoot":"","sources":["../../../../projects/dialbox/src/lib/dialbox.component.ts","../../../../projects/dialbox/src/lib/dialbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { TwilioService } from './service/twilio.service';\nimport swal from 'sweetalert2';\nimport { ExtensionService } from './service/extension.service';\nimport { CallerIdDialogComponent } from './components/caller-id-dialog/caller-id-dialog.component';\nimport { MatDialog } from '@angular/material/dialog';\nimport parsePhoneNumberFromString, { AsYouType } from 'libphonenumber-js';\nimport { keypad } from '../keypad';\nimport { Subscription } from 'rxjs'\nimport { IpAddressService } from './service/ip-address.service';\nimport { Router } from '@angular/router';\nimport { Call } from '@twilio/voice-sdk';\n\n\n@Component({\n  selector: 'lib-dialbox',\n  templateUrl: './dialbox.component.html',\n  styleUrls: ['./dialbox.component.css']\n})\nexport class DialboxComponent implements OnInit, AfterViewInit, OnChanges {\n  \n  private _isDialpadHidden: boolean = true;\n  \n  @Input() set isDialpadHidden(value: boolean) {\n    this._isDialpadHidden = value;\n    if (!value) {\n      // When dialpad becomes visible, ensure Twilio is initialized\n      this.initializeTwilio();\n    }\n  }\n  \n  get isDialpadHidden(): boolean {\n    return this._isDialpadHidden;\n  }\n  @Output() closeDialpadEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() callInitiated: EventEmitter<any> = new EventEmitter<any>();\n  @Output() endCallEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() minimiseEvent: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Output() incomingCallsNewInfoEvent: EventEmitter<any[]> = new EventEmitter<any[]>();\n  @Output() incomingCallInitiated: EventEmitter<void> = new EventEmitter<void>();\n  @ViewChild('dialInput') dialInputElement!: ElementRef;\n\n  \n  @Output() numberDialed = new EventEmitter<string>();\n\n\n  isCallInProgress: boolean = false;\n  keypadVal = keypad;\n  \n  showInputClearBtn: boolean = false;\n  dialedNumber: string = '';\n  contactList: any[] = [];\n  filteredContactList: any[] = [];\n  callerIdList: any[] = [];\n  selectedCallerId: any;\n  isCallerIdHidden: boolean = true;\n\n  isTrialPeriodOver: boolean = false;\n  isPaymentDue: boolean = false;\n  terminateCall = false;\n  toastTimeout = 7000;\n  callNumberToast = {\n    show: false,\n    type: 'alert-success',\n    number: '',\n    displayNum: ''\n  }\n  callData: any = {\n    phone: '',\n    displayNum: '',\n    dial: false,\n    name: '',\n    img: 'assets/images/user.jpg',\n    isIncomingCall: false,\n    extNum:''\n  };\n  lastDialed: { name?: string; image?: string; number: string } | null = null;\n  sanitizedNum: any;\n  dialAlert = {\n    msg: '',\n    show: false\n  }\n  token?:string;\n \n  showDedicatedPopup:boolean = false;\n  newIncomingCalls: any = [];\n  incomingCallsList: any = [];\n  newIncomingCallData?:Call;\n  private subscriptions: Subscription = new Subscription();\n  callPreference: any;\n  shakeDedicatedBtn: boolean = false;\n  isSmartDialCall: boolean = false;\n  private isInitialized = false;\n\n  constructor(\n    private twilioService: TwilioService,\n    private extService: ExtensionService,\n    private dialog: MatDialog,\n    private ipService: IpAddressService,\n    private extensionService: ExtensionService,\n    private router: Router,\n  ) { \n    // Initialize if dialpad is visible by default\n    if (!this.isDialpadHidden) {\n      this.initializeTwilio();\n    }\n  }\n\n  private initializeTwilio() {\n    if (this.isInitialized) return;\n    \n    this.token = localStorage.getItem('ext_token') || '';\n    if (!this.token) {\n      console.error('No authentication token found');\n      return;\n    }\n    \n    this.isInitialized = true;\n    \n    // Initialize Twilio service\n    this.twilioService.initializeTwilioDevice();\n    \n    // Subscribe to incoming calls to show dialpad when call comes in\n    const callSub = this.twilioService.currentCall.subscribe(call => {\n      if (call) {\n        this.isCallInProgress = true;\n        this._isDialpadHidden = false; // Show dialpad on incoming call\n      }\n    });\n    \n    this.subscriptions.add(callSub);\n  }\n\n  ngOnInit() {\n    try {\n      this.getContactList();\n      this.getUserCallSetting();\n      \n      // Subscribe to dial number events\n      const sub1 = this.twilioService.dialNumberFromOtherModule.subscribe((contact: any) => {\n        if (contact.number) {\n          this.isSmartDialCall = false;\n          if (contact.isDialFromHistory) {\n            //handle dialing from history page\n            if(contact.callerId == 'smartDialing'){\n             \n              this.selectedCallerId = { number: contact.from };\n              this.isSmartDialCall = true;\n              setTimeout(() => {\n                this.isDialpadHidden = false;\n              }, 2000);\n              this.callData.phone = contact.number;\n              this.callData.name = contact.name;\n              this.callData.img = contact.img;\n              this.callData.from = contact.from;\n              this.sanitizedNum = contact.number;\n              this.getUserInformation(contact);\n            // this.incomingCallsList.push(contact)\n            this.initiateCall();\n          }else{\n            this.getUserCallSetting();\n            setTimeout(() => {\n              this.isDialpadHidden = false;\n            }, 1000);\n            this.getUserInformation(contact);\n            // this.incomingCallsList.push(contact)\n              this.dialedNumber = contact.number;\n              this.sanitizedNum = contact.number;\n            }\n          } else {\n            if (contact.callerId == 'alwaysAsk' || contact.callerId == 'smartDialing') {\n              this.getUserCallSetting();\n              setTimeout(() => {\n                this.isDialpadHidden = false;\n              }, 1000);\n              this.dialedNumber = contact.number;\n              this.sanitizedNum = contact.number;\n              \n            } else {\n              setTimeout(() => {\n                this.isDialpadHidden = false;\n              }, 2000);\n              this.callData.phone = contact.number;\n              this.callData.name = contact.name;\n              this.callData.img = contact.img;\n              this.sanitizedNum = contact.number;\n              this.initiateCall();\n            }\n          }\n          \n        }\n      })\n  \n      // handle incoming call\n      const sub2 = this.twilioService.currentCall.subscribe(incomingCallData => {\n        // if (incomingCallData) {\n        //   this.isCallInProgress = true;\n        //   this.isDialpadHidden = false;\n        //   this.callData.phone = incomingCallData.parameters.From;\n        //   this.callData.name = incomingCallData.customParameters.get('name');\n        //   this.callData.img = incomingCallData.customParameters.get('image');\n        //   this.callData.isIncomingCall = true;\n        // }\n        if (incomingCallData) {\n          if (this.isCallInProgress) {\n            this.newIncomingCalls.push(incomingCallData);\n            this.getUserInformation(incomingCallData);\n          } else {\n            this.isCallInProgress = true;\n            this.isDialpadHidden = false;\n            this.callData.phone = incomingCallData.parameters['From'];\n\n            this.getUserInformation(incomingCallData);\n            this.callData.name = incomingCallData.customParameters.get('name');\n            this.callData.img = incomingCallData.customParameters.get('image') || 'assets/images/user.jpg';\n            this.callData.isIncomingCall = true;\n          }\n          incomingCallData.on('cancel', () => {\n            this.incomingCallsList = this.incomingCallsList.filter((item: any) => item.parameters.CallSid !== incomingCallData.parameters['CallSid']);\n            if(this.incomingCallsList.length == 0){\n              this.isCallInProgress = false;\n            }\n          });\n\n          incomingCallData.on('disconnect', () => {\n              this.incomingCallsList = this.incomingCallsList.filter((item: any) => item.parameters.CallSid !== incomingCallData.parameters['CallSid']);\n              if(this.incomingCallsList.length == 0){\n                this.isCallInProgress = false;\n              }\n          });\n        }\n      });\n\n      this.subscriptions.add(sub1);\n      this.subscriptions.add(sub2);\n    }catch(e){\n      console.log(e)\n    }\n    \n  }\n\n  \n  getUserInformation(incomingCallData: any) {\n    // console.log('getUserInformation', incomingCallData);\n    let data = this.fromEntries(Array.from(incomingCallData.customParameters.entries()));\n    this.extensionService.getUserInformation(data['twilioAuthId']).subscribe(\n    response => {\n      incomingCallData['userInfo']=response\n      this.incomingCallsList.push(incomingCallData);\n    }, error => {\n      console.error('Error starting recording', error);\n    });\n  }\n\n  fromEntries(entries: [string, any][]): Record<string, any> {\n    return entries.reduce((acc, [key, value]) => {\n      acc[key] = value;\n      return acc;\n    }, {} as Record<string, any>);\n  }\n\n  ngAfterViewInit() {\n    this.registerDragElement();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['isDialpadHidden'] && !this.isDialpadHidden) {\n      this.getContactList();\n      this.getUserCallSetting();\n      setTimeout(() => {\n        this.dialInputElement.nativeElement.focus();\n      }, 0);\n    }\n  }\n  private registerDragElement() {\n    try {\n      const elmnt = document.getElementById('dragparent1');\n      if (!elmnt) {\n        console.error('Drag element not found');\n        return;\n      }\n\n      let pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0;\n\n      const dragMouseDown = (e: MouseEvent) => {\n        const target = e.target as HTMLElement;\n        if (target.tagName.toLowerCase() === 'input') {\n          return;\n        }\n\n        e.preventDefault();\n        pos3 = e.clientX;\n        pos4 = e.clientY;\n        \n        const onMouseMove = (moveEvent: MouseEvent) => elementDrag(moveEvent);\n        const onMouseUp = () => {\n          document.removeEventListener('mouseup', onMouseUp);\n          document.removeEventListener('mousemove', onMouseMove);\n        };\n\n        document.addEventListener('mousemove', onMouseMove);\n        document.addEventListener('mouseup', onMouseUp);\n      };\n\n      const elementDrag = (e: MouseEvent) => {\n        e.preventDefault();\n        pos1 = pos3 - e.clientX;\n        pos2 = pos4 - e.clientY;\n        pos3 = e.clientX;\n        pos4 = e.clientY;\n        \n        elmnt.style.top = (elmnt.offsetTop - pos2) + 'px';\n        elmnt.style.left = (elmnt.offsetLeft - pos1) + 'px';\n      };\n\n      // Check for header element\n      const header = document.getElementById(elmnt.id + 'header');\n      if (header) {\n        header.onmousedown = dragMouseDown;\n      } else {\n        elmnt.onmousedown = dragMouseDown;\n      }\n    } catch (e) {\n      console.log(e)\n    }\n  }\n\n  addNumber(num: any) {\n    if ( num == '#' || num == '*' ||num == '+' || Number.isInteger(num)) {\n      if (num == '#') {\n        new Audio(`/assets/dial-tones/dtmf/dtmf-hash-.mp3`).play();\n      } else if (num == '*') {\n        new Audio(`/assets/dial-tones/dtmf/dtmf-star-.mp3`).play();\n      } else {\n        new Audio(`/assets/dial-tones/dtmf/dtmf-${num}-.mp3`).play();\n      }\n\n      this.dialedNumber += num;\n      this.showInputClearBtn = true;\n\n      this.numberDialed.emit(this.dialedNumber);\n\n      this.onDialInputChange(this.dialedNumber)\n      // this.dialInputRef.nativeElement.focus();\n    }else if(num === 'voicemail'){\n      // this.showDedicatedPopup = true;\n      this.router.navigate(['extension/voicemail/'+this.token]);\n    }\n  }\n  \n  hideDialpad() {\n    this.isDialpadHidden = true;\n    this.closeDialpadEvent.emit();\n    this.clearAllDialed();\n    this.filteredContactList = [];\n  }\n  \n  onDialInputChange(inputVal: any) {\n    try {\n      // Updated regex to include x, X, ext., Ext., and ,\n      const isNumericInput = /^[\\d\\s+\\-]+$/.test(inputVal);\n      let mainNumber = inputVal;\n\n      // Check for extension indicators and split the input\n      const extMatch = inputVal.match(/(x|X|ext\\.|Ext\\.|,)(.*)/);\n      if (extMatch) {\n        mainNumber = inputVal.substring(0, extMatch.index).trim();\n        this.callData.extNum = extMatch[2].trim();\n      }\n      this.sanitizedNum = isNumericInput ? mainNumber.replace(/[\\s\\-]+/g, '') : mainNumber;\n\n      this.callData.phone = isNumericInput ? this.sanitizedNum : '';\n      this.showInputClearBtn = inputVal.length > 0;\n\n      if (isNumericInput) {\n        this.dialedNumber = new AsYouType().input(this.sanitizedNum);\n      }\n\n      // emit current number whenever input changes\n      this.numberDialed.emit(this.dialedNumber);\n\n      if (inputVal.length > 2) {\n        this.filteredContactList = this.contactList.filter(contact => {\n          const fullName = `${contact.firstName} ${contact.middleName} ${contact.lastName}`.toLowerCase();\n          return fullName.includes(this.sanitizedNum.toLowerCase()) || contact.numbersList.some((num: any) => num.number.includes(this.sanitizedNum));\n        }).slice(0, 2);\n      } else {\n        this.filteredContactList = [];\n      }\n\n    } catch (e) {\n      console.log(e);\n    }\n  }\n\n  getFirstLetter(name: string): string {\n    return name ? name.charAt(0).toUpperCase() : '';\n  }\n  clearInput() {\n    if (this.dialedNumber.length > 0) {\n      this.dialedNumber = this.dialedNumber.slice(0, -1);\n      this.showInputClearBtn = this.dialedNumber.length !== 0;\n\n      this.onDialInputChange(this.dialedNumber)\n    }\n  }\n  clearAllDialed() {\n    this.dialedNumber = '';\n    this.sanitizedNum = '';\n    this.showInputClearBtn = false;\n  }\n  getCallerIdList() {\n    this.extService.displayID(this.token || '').subscribe((res: any) => {\n      //this.callerIdList = res.callerIdList.filter(item => item.type === \"C2C Softphone Number\");\n      this.callerIdList = res.callerIdList.filter((item: any) => item.voiceFeature === true);\n      // this.callerIdList = res.callerIdList;\n      if (this.callerIdList.length == 1) {\n        this.selectedCallerId = this.callerIdList[0];\n      } else {\n        if (this.callPreference === 'alwaysAsk' || this.callPreference === 'smartDialing') {\n          this.selectedCallerId = null;\n        } else {\n          this.selectedCallerId = this.callerIdList.find(item => (item.number == this.callPreference));\n        }\n      }\n    });\n  }\n  getContactList() {\n    this.twilioService.getContactList().subscribe((resp: any) => {\n      if (resp.response == 'Success') {\n        this.contactList = resp.phoneBook;\n      }\n    }, err => {\n      console.log(err)\n    })\n  }\n  getFullName(contact: any): string {\n    let fullName = contact.firstName || '';\n    if (contact.middleName) {\n      fullName += ` ${contact.middleName}`;\n    }\n    if (contact.lastName) {\n      fullName += ` ${contact.lastName}`;\n    }\n    return fullName.trim();\n  }\n\n\n  toggleCallerIdDiv() {\n    this.isCallerIdHidden = !this.isCallerIdHidden;\n  }\n\n  onContactSelect(contact: any) {\n    this.dialedNumber = contact.numbersList[0].number;\n    this.callData.name = this.getFullName(contact);\n    this.callData.img = contact.image || 'assets/images/user.jpg';\n    this.onDialInputChange(this.dialedNumber);\n    this.filteredContactList = [];\n  }\n\n  endCall() {\n    try {\n      console.log('Ending call');\n      this.isCallInProgress = false;\n      this.filteredContactList = [];\n      \n      // Reset call data\n      this.callData = {\n        phone: '',\n        name: '',\n        img: 'assets/images/user.jpg',\n        isIncomingCall: false,\n        dial: false,\n        displayNum: '',\n        extNum: ''\n      };\n      \n      // Reset dialed number\n      this.dialedNumber = '';\n      this.sanitizedNum = '';\n      \n      // Emit end call event\n      this.endCallEvent.emit();\n      console.log('Call ended successfully');\n      \n    } catch (error) {\n      console.error('Error in endCall:', error);\n      // Even if there's an error, try to reset the state\n      this.isCallInProgress = false;\n      this.callData = {\n        phone: '',\n        name: '',\n        img: 'assets/images/user.jpg',\n        isIncomingCall: false,\n        dial: false,\n        displayNum: '',\n        extNum: ''\n      };\n      this.endCallEvent.emit();\n    }\n  }\n\n  // async initiateCall() {\n  //   try {\n  //     console.log('Initiating call with number:', this.dialedNumber);\n      \n  //     if (!this.dialedNumber && this.lastDialed) {\n  //       console.log('Using last dialed number:', this.lastDialed.number);\n  //       this.sanitizedNum = this.lastDialed.number;\n  //     }\n\n  //     const isInvalid = await this.isInvalidNumber();\n  //     if (isInvalid) {\n  //       console.error('Invalid number format');\n  //       return false;\n  //     }\n\n  //     this.saveLastDialed();\n  //     this.isSavedContactDialled();\n      \n  //     // Check payment status\n  //     this.isPaymentDue = localStorage.getItem('paymentDue') === 'true';\n  //     if (this.isPaymentDue) {\n  //       console.warn('Payment is due');\n  //       swal('Warning', 'Please note that your payment is due. To continue using our services, kindly subscribe to avoid interruptions.');\n  //       return false;\n  //     }\n\n  //     // Check if dialing own number\n  //     if (this.sanitizedNum === localStorage.getItem('twilioNumber')) {\n  //       console.error('Attempted to dial own number');\n  //       swal('Error', 'You cannot dial your own number');\n  //       return false;\n  //     }\n\n  //     // Check microphone permissions\n  //     const hasPermission = await this.checkMicrophonePermission();\n  //     if (!hasPermission) {\n  //       console.warn('Microphone permission not granted');\n  //       await this.askForMicrophonePermission();\n  //       return false;\n  //     }\n\n  //     if (!this.selectedCallerId) {\n  //       console.error('No caller ID selected');\n  //       this.shakeDedicatedBtn = true;\n  //       this.showDialAlert('Please select a C2C number to call from');\n  //       setTimeout(() => {\n  //         this.shakeDedicatedBtn = false;\n  //       }, 3000);\n  //       return false;\n  //     }\n\n  //     console.log('Getting number with country code...');\n  //     this.callData.displayNum = '';\n      \n  //     try {\n  //       await this.getToNumber(this.sanitizedNum);\n  //     } catch (error) {\n  //       console.error('Error getting number with country code:', error);\n  //       this.showDialAlert('Error processing number. Please try again.');\n  //       return false;\n  //     }\n\n  //     if (this.terminateCall) {\n  //       console.log('Call terminated by user');\n  //       this.terminateCall = false;\n  //       return false;\n  //     }\n\n  //     // Prepare call data\n  //     this.callData = {\n  //       ...this.callData,\n  //       phone: this.sanitizedNum,\n  //       isIncomingCall: false,\n  //       dial: true,\n  //       from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n  //       timestamp: new Date().toISOString()\n  //     };\n\n  //     console.log('Initiating call with data:', this.callData);\n  //     this.isCallInProgress = true;\n  //     this.callInitiated.emit({ ...this.callData });\n      \n  //     return true;\n      \n  //   } catch (error) {\n  //     console.error('Error in initiateCall:', error);\n  //     this.showDialAlert('Failed to initiate call. Please try again.');\n  //     this.isCallInProgress = false;\n  //     return false;\n  //   }\n  //     //this.clearAllDialed();\n  //   // } else {\n  //   //   swal('Error', 'Trial period is over. Please setup payment method to continue services')\n  //   // }\n  // }\n\n\n  //  async initiateCall() {\n  //   if (!this.dialedNumber && this.lastDialed) {\n  //     this.sanitizedNum = this.lastDialed.number;\n  //   }\n  //   const isInvalid = await this.isInvalidNumber();\n  //   if (isInvalid) {\n  //     return false;\n  //   }\n  //   this.saveLastDialed();\n  //   this.isSavedContactDialled();\n  //   //let isCallerIdSet = await this.isCallerIdSet();\n  //   this.isPaymentDue = localStorage.getItem('paymentDue') == 'false' ? false : true;\n  //   if (this.isPaymentDue) {\n  //     swal('Warning', 'Please note that your payment is due, To continue on your services kindly subscribe to use uninterrupted services.');\n  //     return;\n  //   }\n  //   this.isTrialPeriodOver = localStorage.getItem('trialOver') == 'false' ? false : true;\n  //   // if (!this.isTrialPeriodOver) {\n  //     if (this.sanitizedNum == localStorage.getItem('twilioNumber')) {\n  //       swal('Error', 'You can not dial this number');\n  //       return;\n  //     }\n\n  //     const hasPermission = await this.checkMicrophonePermission();\n  //     if (hasPermission) {\n  //       if (this.selectedCallerId) {\n  //         //clear displayNum if value is binded from previous call\n  //         this.callData.displayNum = '';\n  //         // get number to be dialled from backend\n  //         await this.getToNumber(this.sanitizedNum);\n  //         if (this.terminateCall) {\n  //           this.terminateCall = false;\n  //           return;\n  //         }\n  //         this.callData.phone = this.sanitizedNum;\n  //         this.callData.isIncomingCall = false;\n  //         this.callData.dial = true;\n  //         if (!this.isSmartDialCall) {\n  //           this.callData.from = this.selectedCallerId.number;\n  //         }\n          \n  //         this.isCallInProgress = true;\n  //               this.callData = {\n  //               ...this.callData,\n  //               phone: this.sanitizedNum,\n  //               isIncomingCall: false,\n  //               dial: true,\n  //               from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n  //               timestamp: new Date().toISOString()\n  //             };\n\n  //             console.log('Initiating call with data:', this.callData);\n  //             this.isCallInProgress = true;\n  //             this.callInitiated.emit({ ...this.callData });\n  //         return true;\n  //       } else {\n  //         this.shakeDedicatedBtn = true;\n  //         this.showDialAlert('Select a C2C number to call');\n  //         setTimeout(() => {\n  //           this.shakeDedicatedBtn = false;\n  //         }, 3000);\n  //         return false;\n  //       }\n  //       //this.callingOpenEvent.emit({ phone: this.dialedNumber });\n  //     } else {\n  //       await this.askForMicrophonePermission();\n  //     }\n  //     //this.clearAllDialed();\n  //   // } else {\n  //   //   swal('Error', 'Trial period is over. Please setup payment method to continue services')\n  //   // }\n  // }\n\n\n  // async initiateCall() {\n  //   try{\n  //     if (!this.dialedNumber && this.lastDialed) {\n  //       this.sanitizedNum = this.lastDialed.number;\n  //     }\n\n  //     const isInvalid = await this.isInvalidNumber();\n  //     if (isInvalid) {\n  //       return false;\n  //     }\n  //     this.saveLastDialed();\n  //     this.isSavedContactDialled();\n  //     //let isCallerIdSet = await this.isCallerIdSet();\n\n  //     this.isPaymentDue = localStorage.getItem('paymentDue') == 'false' ? false : true;\n  //     if (this.isPaymentDue) {\n  //       swal('Warning', 'Please note that your payment is due, To continue on your services kindly subscribe to use uninterrupted services.');\n  //       return false;\n  //     }\n\n  //     this.isTrialPeriodOver = localStorage.getItem('trialOver') == 'false' ? false : true;\n  //     // if (!this.isTrialPeriodOver) {\n  //       if (this.sanitizedNum == localStorage.getItem('twilioNumber')) {\n  //         swal('Error', 'You can not dial this number');\n  //         return false;\n  //       }\n\n  //       const hasPermission = await this.checkMicrophonePermission();\n  //       if (hasPermission) {\n  //         if (this.selectedCallerId) {\n  //           //clear displayNum if value is binded from previous call\n  //           this.callData.displayNum = '';\n  //           // get number to be dialled from backend\n  //           await this.getToNumber(this.sanitizedNum);\n  //           if (this.terminateCall) {\n  //             this.terminateCall = false;\n  //             return;\n  //           }\n  //           this.callData.phone = this.sanitizedNum;\n  //           this.callData.isIncomingCall = false;\n  //           this.callData.dial = true;\n  //           if (!this.isSmartDialCall) {\n  //             this.callData.from = this.selectedCallerId.number;\n  //           }\n            \n  //           this.isCallInProgress = true;\n  //                 this.callData = {\n  //                 ...this.callData,\n  //                 phone: this.sanitizedNum,\n  //                 isIncomingCall: false,\n  //                 dial: true,\n  //                 from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n  //                 timestamp: new Date().toISOString()\n  //               };\n\n  //               console.log('Initiating call with data:', this.callData);\n  //               this.isCallInProgress = true;\n  //               this.callInitiated.emit({ ...this.callData });\n  //           return true;\n  //         } else {\n  //           this.shakeDedicatedBtn = true;\n  //           this.showDialAlert('Select a C2C number to call');\n  //           setTimeout(() => {\n  //             this.shakeDedicatedBtn = false;\n  //           }, 3000);\n  //           return false;\n  //         }\n  //         //this.callingOpenEvent.emit({ phone: this.dialedNumber });\n  //       } else {\n  //         await this.askForMicrophonePermission();\n  //       }\n  //       //this.clearAllDialed();\n  //     // } else {\n  //     //   swal('Error', 'Trial period is over. Please setup payment method to continue services')\n  //     // }\n  //   }catch(e){\n  //     console.error('Error in initiateCall:', e);\n\n  //     this.showDialAlert('Failed to initiate call. Please try again.');\n\n  //     this.isCallInProgress = false;\n\n  //     return false;\n  //   }\n  // }\n\n\n  async initiateCall() {\n    try {\n      if (!this.dialedNumber && this.lastDialed) {\n        this.sanitizedNum = this.lastDialed.number;\n      }\n  \n      const isInvalid = await this.isInvalidNumber();\n      if (isInvalid) {\n        return false;\n      }\n      this.saveLastDialed();\n      this.isSavedContactDialled();\n  \n      this.isPaymentDue = localStorage.getItem('paymentDue') === 'false' ? false : true;\n      if (this.isPaymentDue) {\n        swal('Warning', 'Please note that your payment is due, To continue on your services kindly subscribe to use uninterrupted services.');\n        return false;\n      }\n  \n      this.isTrialPeriodOver = localStorage.getItem('trialOver') === 'false' ? false : true;\n      \n      if (this.sanitizedNum === localStorage.getItem('twilioNumber')) {\n        swal('Error', 'You can not dial this number');\n        return false;\n      }\n  \n      const hasPermission = await this.checkMicrophonePermission();\n      if (!hasPermission) {\n        await this.askForMicrophonePermission();\n        return false;\n      }\n  \n      if (!this.selectedCallerId) {\n        this.shakeDedicatedBtn = true;\n        this.showDialAlert('Select a C2C number to call');\n        setTimeout(() => {\n          this.shakeDedicatedBtn = false;\n        }, 3000);\n        return false;\n      }\n  \n      // Clear displayNum if value is bound from previous call\n      this.callData.displayNum = '';\n      \n      // Get number to be dialed from backend\n      await this.getToNumber(this.sanitizedNum);\n      if (this.terminateCall) {\n        this.terminateCall = false;\n        return;\n      }\n  \n      // Update call data in a single operation\n      this.callData = {\n        ...this.callData,\n        phone: this.sanitizedNum,\n        isIncomingCall: false,\n        dial: true,\n        from: this.isSmartDialCall ? this.callData.from : this.selectedCallerId.number,\n        timestamp: new Date().toISOString()\n      };\n  \n      // console.log('Initiating call with data:', this.callData);\n      this.isCallInProgress = true;\n      this.callInitiated.emit({ ...this.callData });\n      return true;\n  \n    } catch (e) {\n      // console.error('Error in initiateCall:', e);\n      this.showDialAlert('Failed to initiate call. Please try again.');\n      this.isCallInProgress = false;\n      return false;\n    }\n  }\n\n  async isInvalidNumber() {\n    try {\n      if(this.sanitizedNum == ''){\n        this.showDialAlert('Invalid Number');\n        return true;\n      }\n      const validNumberPattern = /^[+\\d\\s()-]*$/; // Regular expression to match valid characters\n      const phoneNumber = this.sanitizedNum;\n      if (!validNumberPattern.test(phoneNumber)) {\n        this.showDialAlert('Invalid Number');\n        return true;\n      }\n      return false;\n    } catch (error) {\n      this.showDialAlert('Invalid Number');\n      return true; // Return true if an error occurred, meaning the number is invalid\n    }\n  }\n  \n  saveLastDialed() {\n    const contact = this.filteredContactList.find((c: any) => c.numbersList.some((n: any) => n.number === this.dialedNumber));\n    if (contact) {\n      this.lastDialed = {\n        name: contact.name,\n        image: contact.image,\n        number: this.dialedNumber\n      };\n    } else {\n      if(this.dialedNumber){\n        this.lastDialed = { number: this.dialedNumber };\n      }\n      \n    }\n  }\n  isSavedContactDialled(){\n    let phoneNum = this.sanitizedNum.replace(/\\s+/g, '');\n    let contact =  this.contactList.filter((contact: any) => {\n      return contact.numbersList.some((num: any) => num.number === phoneNum)\n    });\n    if(contact.length){\n      this.callData.name = `${contact[0].firstName} ${contact[0].middleName} ${contact[0].lastName}`.toLowerCase();\n      this.callData.img = contact[0].image || 'assets/images/user.jpg';\n      this.callData.phone = this.sanitizedNum;\n\n      return true;\n    }\n    return false;\n  }\n  showDialAlert(message: string) {\n    this.dialAlert = {\n      msg: message,\n      show: true\n    };\n    setTimeout(() => {\n      this.dialAlert.show = false;\n    }, 3000);\n  }\n  async isCallerIdSet(): Promise<boolean> {\n    try {\n      const tkn = localStorage.getItem('ext_token');\n      const res: any = await this.extService.fetchCallerId(tkn || '').toPromise();\n      if (res.status == 200) {\n        localStorage.setItem('trialOver', res.trialOver);\n        this.twilioService.isTrialOver.next(res.trialOver);\n        localStorage.setItem('paymentDue', res.paymentDue);\n        this.twilioService.isPaymentDue.next(res.paymentDue);\n      }\n      if (res.callerid) {\n        localStorage.setItem('callerID', res.callerid);\n\n        this.extService.changeMessage(res.callerid);\n      } else {\n        localStorage.setItem('callerID', 'Not set');\n        this.extService.changeMessage('Not set');\n      }\n\n      return (localStorage.getItem('callerID') !== 'Not set');\n    } catch (e) {\n      console.log(e);\n      return false;\n    }\n  }\n  async checkMicrophonePermission(): Promise<boolean> {\n    try {\n      const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\n      stream.getTracks().forEach(track => track.stop());\n      return true;\n    } catch (error) {\n      if ((error as any).name === 'NotAllowedError') {\n        return false;\n      } else {\n        return false;\n      }\n    }\n  }\n  async askForMicrophonePermission(): Promise<void> {\n    try {\n      const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\n      stream.getTracks().forEach(track => track.stop());\n    } catch (error) {\n      console.error('User denied microphone permission:', error);\n    }\n  }\n  // below function is to get the country code with number from server \n  async getToNumber(dialedNumber: string) {\n    \n      if (dialedNumber[0] !== '+') {\n        // this is case when user geolocation dial code is on\n        let ipAddress: any = await this.ipService.getIpAddressInfo().toPromise();\n        const res: any = await this.twilioService.getToNumber(dialedNumber,ipAddress.address.countryCode).toPromise();\n        if (res.status == 200) {\n          this.toastTimeout = res.timeInterval * 1000;\n          await this.showNumberToast(res);\n        }\n      }\n  }\n  isAlertEnable() {\n    return localStorage.getItem('isAlertEnable');\n  }\n  async showNumberToast(data: any) {\n    const isAlertOn = (localStorage.getItem('isCountryCodeToastOn'));\n    if (isAlertOn == 'true') {\n      this.callNumberToast.show = true;\n      this.callNumberToast.number = data.toNumber;\n      this.callNumberToast.displayNum = data.displayNumber;\n    }\n    \n    \n    this.callData.displayNum = data.displayNumber;\n    //this.callData.phone = data.toNumber;\n    await this.delay(this.toastTimeout);\n    this.dialedNumber = data.toNumber;\n    this.sanitizedNum = data.toNumber;\n    this.callNumberToast.show = false;\n    this.callNumberToast.number = '';\n    this.callNumberToast.displayNum = '';\n  }\n  delay(ms: number) {\n    return new Promise<void>(resolve => setTimeout(resolve, ms));\n  }\n  isMinimised: boolean = false;\n  onMinimise(isMinimised: boolean) {\n    this.isMinimised = isMinimised;\n    this.minimiseEvent.emit(isMinimised);\n  }\n  handleNumberPaste(event: ClipboardEvent): void {\n    event.preventDefault();\n    const clipboardData = event.clipboardData || (window as any).clipboardData;\n    const pastedData = clipboardData.getData('text');\n\n    // Log the pasted content to the console\n    if(pastedData){\n      this.dialedNumber = pastedData;\n      this.sanitizedNum = pastedData;\n    }\n    \n  }\n  onEnter(num:string) {\n    // console.log(num, 'number fn')\n    this.dialedNumber = this.dialedNumber +num;\n    this.sanitizedNum = this.dialedNumber;\n    this.showInputClearBtn = true;\n    this.numberDialed.emit(this.dialedNumber);\n  }\n  \n  getUserCallSetting() {\n    const tkn = localStorage.getItem('ext_token');\n    this.extService.fetchCallerId(tkn || '').subscribe((resp: any) => {\n      if (resp.status == 200) {\n        //this.callPrefernce = resp.userSetting;\n        this.callPreference = resp.callerid;\n        this.getCallerIdList();\n      }\n    })\n  }\n  onDedicatedNumSelect(id: any) {\n    this.selectedCallerId = id;\n    this.isCallerIdHidden = true;\n    this.extService.setCallerId(id);\n  }\n  cancelDialNumber() {\n    this.terminateCall = true;\n    this.callNumberToast.show = false;\n  }\n\n  handleDivKeydown(ev:any){\n    if(this.dialedNumber.length == 0){\n      this.dialInputElement.nativeElement.focus();\n    }\n    if (ev.key === 'Enter') {\n      // Check if the dialpad is open\n      if (!this.isDialpadHidden) {\n        if(this.dialedNumber.length > 2 && this.selectedCallerId){\n          this.initiateCall();\n        }\n        if(!this.selectedCallerId){\n          this.shakeDedicatedBtn = true;\n          setTimeout(() => {\n            this.shakeDedicatedBtn = false;\n          }, 10000);\n        }\n      }\n    }\n  }\n  onCallBtnMouseEnter(ev: any) {\n    if (!this.selectedCallerId || (this.selectedCallerId == 'alwaysAsk') || (this.selectedCallerId == 'smartDialing')) {\n      this.shakeDedicatedBtn = true;\n    }\n\n  }\n  onCallBtnMouseLeave(ev: any) {\n    if (!this.selectedCallerId || (this.selectedCallerId == 'alwaysAsk') || (this.selectedCallerId == 'smartDialing')) {\n      this.shakeDedicatedBtn = false;\n    }\n  }\n  acceptNewIncomingCall(call: Call) {\n    //first cut the current call\n    //this.callData = call;\n    this.newIncomingCallData = call;\n  }\n  rejectNewIncomingCall(call: Call) {\n    call.reject();\n    this.newIncomingCalls = this.newIncomingCalls.filter((item: any) => item.parameters.CallSid !== call.parameters['CallSid']);\n    this.incomingCallsList = this.incomingCallsList.filter((item: any) => item.parameters.CallSid !== call.parameters['CallSid']);\n  }\n  newIncomingCallInitiated() {\n    this.isCallInProgress = true;\n    this.newIncomingCalls = [];\n    this.incomingCallInitiated.emit();\n  }\n  incomingCallsNewInfo(data:any){\n    this.incomingCallsList = data;\n    this.incomingCallsNewInfoEvent.emit(data);\n  }\n  ngOnDestroy() {\n    try {\n      console.log('Cleaning up C2cDialpadComponent');\n      \n      // Unsubscribe from all subscriptions\n      if (this.subscriptions) {\n        this.subscriptions.unsubscribe();\n      }\n      // Clean up Twilio device when component is destroyed\n      if (this.twilioService['device']) {\n        this.twilioService['device'].destroy();\n      }\n      \n      // End any active call\n      if (this.isCallInProgress) {\n        this.endCall();\n      }\n      \n      // Clear any timeouts or intervals if they exist\n      if (this.toastTimeout) {\n        clearTimeout(this.toastTimeout);\n      }\n      \n      console.log('C2cDialpadComponent cleanup complete');\n      \n    } catch (error) {\n      console.error('Error during component cleanup:', error);\n    }\n  }\n}\n","<div id=\"dragparent1\" [ngStyle]=\"{'display':isDialpadHidden ? 'none': 'block'}\">\r\n  <lib-call-progress *ngIf=\"isCallInProgress\"\r\n   (endCallEvent)=\"endCall()\"\r\n   (minimiseEvent)=\"onMinimise($event)\"\r\n   (incomingCallInitiated)=\"newIncomingCallInitiated()\"\r\n   [newIncomingCallData]=\"newIncomingCallData\"\r\n   [newIncomingCallsList]=\"incomingCallsList\"\r\n   (incomingCallsNewInfo)=\"incomingCallsNewInfo($event)\"\r\n   [callData]=\"callData\">\r\n  </lib-call-progress>\r\n  <div class=\"dialpad-container\" [ngClass]=\"{'mini-dialpad': isMinimised}\" tabindex=\"0\" (keydown)=\"handleDivKeydown($event)\">\r\n    <div id=\"topPanel\" [ngStyle]=\"{'height': callerIdList.length ? '40%' : '39%'}\">\r\n      <div class=\"dialpad-alerts\" *ngIf=\"dialAlert.show\">\r\n        <div class=\"no-selection-alert\">\r\n          <!-- <p class=\"mb-0\">Select C2C number to call</p> -->\r\n          <p class=\"mb-0\">{{dialAlert.msg}}</p>\r\n          <span class=\"fa fa-times\" (click)=\"shakeDedicatedBtn = false\"></span>\r\n        </div>\r\n      </div>\r\n      <div class=\"dialpad-alerts\" *ngIf=\"callNumberToast.show\">\r\n        <div class=\"dialbox-pop1 alert fade show\" [ngClass]=\"callNumberToast.type\" role=\"alert\">\r\n          <div class=\"d-flex justify-content-between\">\r\n            <div class=\"flex-grow-1 my-auto text-left\">\r\n              You'r calling <strong>{{callNumberToast.displayNum}}</strong>\r\n            </div>\r\n            <div class=\"text-right\">\r\n              <button class=\"btn btn-link btn-disc p-0 px-1\" (click)=\"cancelDialNumber()\">Cancel Call</button>\r\n              <!-- <button class=\"btn btn-link btn-success btn-disc p-0 px-2\">Continue</button> -->\r\n            </div>\r\n      \r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div style=\"padding: 0 18px\" (paste)=\"handleNumberPaste($event)\">\r\n        <div class=\"d-flex justify-content-between mt-2\">\r\n          <p></p>\r\n          <span class=\"material-symbols-outlined dial-close-btn\" (click)=\"hideDialpad()\">\r\n            <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 -960 960 960\" width=\"24px\" fill=\"#ffffff\"><path d=\"m256-200-56-56 224-224-224-224 56-56 224 224 224-224 56 56-224 224 224 224-56 56-224-224-224 224Z\"/></svg>\r\n          </span>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" #dialInput placeholder=\"Enter a name or number\" tabindex=\"1\" [(ngModel)]=\"dialedNumber\" (ngModelChange)=\"onDialInputChange($event)\"/>\r\n          <span class=\"\" id=\"input-clear-btn\" (click)=\"clearInput()\" *ngIf=\"showInputClearBtn\">\r\n            <svg width=\"50px\" height=\"30px\" viewBox=\"0 10 40 60\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" baseProfile=\"full\" enable-background=\"new 0 0 76.00 76.00\" xml:space=\"preserve\">\r\n              <path fill=\"#5d6061\" fill-opacity=\"1\" stroke-width=\"0.2\" stroke-linejoin=\"round\" d=\"M 47.5282,42.9497L 42.5784,38L 47.5282,33.0502L 44.9497,30.4718L 40,35.4216L 35.0502,30.4718L 32.4718,33.0502L 37.4216,38L 32.4718,42.9497L 35.0502,45.5282L 40,40.5784L 44.9497,45.5282L 47.5282,42.9497 Z M 18.0147,41.5355L 26.9646,50.4854C 28.0683,51.589 29,52 31,52L 52,52C 54.7614,52 57,49.7614 57,47L 57,29C 57,26.2386 54.7614,24 52,24L 31,24C 29,24 28.0683,24.4113 26.9646,25.5149L 18.0147,34.4645C 16.0621,36.4171 16.0621,39.5829 18.0147,41.5355 Z M 31,49C 30,49 29.6048,48.8828 29.086,48.3641L 20.1361,39.4142C 19.355,38.6332 19.355,37.3669 20.1361,36.5858L 29.086,27.6362C 29.6048,27.1175 30,27 31,27.0001L 52,27.0001C 53.1046,27.0001 54,27.8955 54,29.0001L 54,47.0001C 54,48.1046 53.1046,49.0001 52,49.0001L 31,49 Z \"/>\r\n            </svg>        \r\n          </span>\r\n          <span class=\"input-info-icon\" placement=\"bottom-right\" tooltipClass=\"input-tooltip\" ngbTooltip=\"For extension dialing, use formats like +12345678910 x123,+12345678910 ext.123, +12345678910,123\"><i class=\"fa fa-info-circle\"></i></span>\r\n        </div>\r\n        <div class=\"guide\" *ngIf=\"callerIdList.length && !(dialedNumber.length > 2)\">\r\n          <span class=\"guidetext\">Please enter a number or select a saved contact</span>\r\n        </div>\r\n        <!-- <div class=\"input-error\" *ngIf=\"dialAlert.show\">\r\n          <span>{{dialAlert.msg}}</span>\r\n        </div> -->\r\n        <div>\r\n          <div class=\"contact-card\" *ngFor=\"let contact of filteredContactList\" (click)=\"onContactSelect(contact)\">\r\n            <div class=\"contact-img\">\r\n              <img [src]=\"contact.image\" alt=\"user image\" loading=\"lazy\" *ngIf=\"contact.image else alphaName\"/>\r\n              <ng-template #alphaName>\r\n                <span class=\"contact-alpha-img\">{{getFirstLetter(contact.firstName)}}</span>\r\n              </ng-template>\r\n            </div>\r\n            <div class=\"contact-details\">\r\n              <p style=\"margin-bottom: 4px\" class=\"contact-name\">{{getFullName(contact) }}</p>\r\n              <p>{{contact.numbersList[0].number}}</p>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div class=\"wave-container\">\r\n        <svg\r\n          class=\"waves\"\r\n          xmlns=\"http://www.w3.org/2000/svg\"\r\n          xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n          viewBox=\"0 24 150 28\"\r\n          preserveAspectRatio=\"none\"\r\n          shape-rendering=\"auto\"\r\n        >\r\n          <defs>\r\n            <path\r\n              id=\"gentle-wave\"\r\n              d=\"M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z\"\r\n            />\r\n          </defs>\r\n          <g class=\"parallax\">\r\n            <use\r\n              xlink:href=\"#gentle-wave\"\r\n              x=\"48\"\r\n              y=\"0\"\r\n              fill=\"rgba(255,255,255,0.7)\"\r\n            />\r\n            <use\r\n              xlink:href=\"#gentle-wave\"\r\n              x=\"48\"\r\n              y=\"3\"\r\n              fill=\"rgba(255,255,255,0.5)\"\r\n            />\r\n            <!-- <use\r\n              xlink:href=\"#gentle-wave\"\r\n              x=\"48\"\r\n              y=\"5\"\r\n              fill=\"rgba(255,255,255,0.3)\"\r\n            /> -->\r\n            <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"7\" fill=\"#fff\" />\r\n          </g>\r\n        </svg>\r\n      </div>\r\n    </div>\r\n    <div class=\"btn-container\" *ngIf=\"!isMinimised\">\r\n      <button class=\"dial-btn\" *ngFor=\"let key of keypadVal;let i = index\"\r\n      (keydown.enter)=\"onEnter(key.num)\" (click)=\"addNumber(key.num)\"\r\n      [ngStyle]=\"{'margin-top': key.text === '+' ? '3px' : '0'}\"\r\n       [tabindex]=\"dialedNumber.length ? '0': i+2\" longPress (longPress)=\"addNumber(key.text)\" shortPress (shortPress)=\"addNumber(key.num)\">\r\n        {{key.num}} \r\n        <span *ngIf=\"key.num == 1;else otherThanOne\" class=\"material-symbols-outlined voicemail\">\r\n          voicemail\r\n        </span>\r\n        <ng-template #otherThanOne>\r\n          <span class=\"btn-albhabets\" [ngClass]=\"{'plusSign': key.text === '+'}\">{{key.text ? key.text : '&nbsp;'}}</span>\r\n        </ng-template>\r\n      </button>\r\n    </div>\r\n    <div class=\"call-btn-container\" *ngIf=\"!isMinimised\" (mouseenter)=\"onCallBtnMouseEnter($event)\" (mouseleave)=\"onCallBtnMouseLeave($event)\">\r\n      <div class=\"call-btn\" (click)=\"initiateCall()\" [tabindex]=\"dialedNumber.length ? '2': '15'\"\r\n        [ngStyle]=\"{'pointer-events': dialedNumber.length && selectedCallerId ? 'auto' : 'none', 'opacity': dialedNumber.length && selectedCallerId ? '1' : '0.5'}\">\r\n        <span class=\"material-symbols-outlined\" style=\"color: white\">\r\n          call\r\n        </span>\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"callerIdList.length && !isMinimised\" class=\"position-relative\">\r\n      <div class=\"shownCallerId\" *ngIf=\"selectedCallerId; else askBlock\" (click)=\"toggleCallerIdDiv()\">\r\n        <div>\r\n          <span [ngClass]=\"'fi fi-' + selectedCallerId?.isoCode?.toLowerCase()\"></span>\r\n          {{selectedCallerId?.number}}\r\n        </div>\r\n      </div>\r\n      <ng-template #askBlock>\r\n        <div class=\"shownCallerId\"  (click)=\"toggleCallerIdDiv()\" [ngClass]=\"{ 'tilt-shaking': shakeDedicatedBtn }\">\r\n          <div class=\"d-flex justify-content-center\">\r\n            <h5 class=\"mb-0\">Select C2C number</h5>\r\n            <!-- <span class=\"ml-2\" style=\"opacity:.8;margin-top:2px\">\r\n              <img src=\"assets/images/icon_down_arrow.svg\" alt=\"down\" width=\"10px\">\r\n            </span> -->\r\n            <span class=\"fa fa-angle-down ml-2 text-blue\" style=\"margin-top:2px\"></span>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n      <div class=\"guide2\" *ngIf=\"shakeDedicatedBtn\">\r\n        <span class=\"guidetext\">Please select a number from below dropdown</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"callerIdList.length; else noCallerIdMessage\">\r\n    <div class=\"caller-id-list-container\" *ngIf=\"callerIdList.length && !isMinimised\" id=\"callerIdContainer\"  [ngClass]=\"{'visible': !isCallerIdHidden}\" >\r\n      <div style=\"display: flex; justify-content: space-between\">\r\n        <!-- <h4>Select C2C Softphone Number</h4> -->\r\n         <h4>Make outgoing call using</h4>\r\n        <span\r\n          class=\"material-symbols-outlined\"\r\n          style=\"cursor: pointer\"\r\n          (click)=\"isCallerIdHidden = true\"\r\n        >\r\n          close\r\n        </span>\r\n      </div>\r\n      <ul>\r\n        <ng-container *ngFor=\"let callerId of callerIdList\">\r\n          <li [ngClass]=\"{'selectedCallerIdClass': callerId?.number == selectedCallerId?.number}\" (click)=\"onDedicatedNumSelect(callerId)\">\r\n            <div>\r\n              <span [ngClass]=\"'fi fi-' + callerId?.isoCode?.toLowerCase()\"></span>\r\n              {{callerId?.number}}\r\n            </div>\r\n            <span>{{callerId?.countryName}}</span>\r\n          </li>\r\n        </ng-container>\r\n      </ul>\r\n    </div>\r\n    </div>\r\n    <ng-template #noCallerIdMessage>\r\n      <span class=\"no-caller-id-message\">To make any voice calls, please <a routerLink=\"/extension/dedicatednumber/{{token}}\" class=\"click-here-link\" title=\"Settings > C2C Number\">subscribe</a> to a voice capable C2C Number.\r\n      </span>\r\n    </ng-template>\r\n    <div class=\"dedicated-overlay\" *ngIf=\"showDedicatedPopup\">\r\n      <div class=\"card dedicatedNumPopup\">\r\n        <div class=\"card-header chooseDedicatedHeader\">\r\n          <h5>Choose C2C Number</h5>\r\n          <span class=\"material-symbols-outlined dial-close-btn\" (click)=\"showDedicatedPopup = false\">close</span>\r\n        </div>\r\n        <div class=\"card-body dedicatedNumList\">\r\n          <ul>\r\n            <ng-container *ngFor=\"let callerId of callerIdList\">\r\n              <li [ngClass]=\"{'selectedCallerIdClass': callerId?.number == selectedCallerId?.number}\" (click)=\"showDedicatedPopup = false\">\r\n                <div>\r\n                  <span [ngClass]=\"'fi fi-' + callerId?.isoCode?.toLowerCase()\"></span>\r\n                  {{callerId?.number}}\r\n                </div>\r\n                <span>{{callerId?.countryName}}</span>\r\n              </li>\r\n            </ng-container>\r\n          </ul>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"incoming-call-widget\" *ngFor=\"let call of newIncomingCalls;let i = index\" [ngStyle]=\"{'top': (30 + i * 72) + 'px'}\">\r\n      <div>\r\n        <div class=\"inc-user-img\">\r\n          <img src=\"assets/images/user.jpg\" alt=\"user image\">\r\n        </div>\r\n        \r\n      </div>\r\n      <div class=\"flex-grow-1\">\r\n        <!-- <h6 class=\"mb-1 font-weight-bold\">Incoming Call</h6> -->\r\n        <p class=\"inc-user-name\">{{call.customParameters.get('name')}}</p>\r\n        <p>{{call.parameters.From}}</p>\r\n\r\n        <!-- <p class=\"inc-user-name\">John Doe</p> \r\n        <p>+12337472489</p>\r\n        <p style=\"font-size: 12px;color:#d5d5d5 !important;margin-top:2px\">Call on +12264584100</p> -->\r\n\r\n      </div>\r\n      <div class=\"d-flex\">\r\n        <button class=\"inc-call-btn inc-accept-btn mr-2\" (click)=\"acceptNewIncomingCall(call)\">\r\n          <span class=\"material-symbols-outlined\" style=\"color: white\">\r\n            call\r\n          </span>\r\n        </button>\r\n        <button class=\"inc-call-btn inc-reject-btn\" (click)=\"rejectNewIncomingCall(call)\">\r\n          <span class=\"material-symbols-outlined\" style=\"color: white\">\r\n            call_end\r\n          </span>\r\n        </button>\r\n      </div>\r\n     \r\n    </div>\r\n  </div>\r\n</div>\r\n"]}