@snugdesk/avaya-ipo-widget 0.0.9 → 0.1.0
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.
Potentially problematic release.
This version of @snugdesk/avaya-ipo-widget might be problematic. Click here for more details.
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, EventEmitter, Output, Component, ViewChild,
|
|
2
|
+
import { Injectable, EventEmitter, Output, Input, Component, ViewChild, NgModule } from '@angular/core';
|
|
3
3
|
import { trigger, transition, style, animate } from '@angular/animations';
|
|
4
|
-
import * as
|
|
4
|
+
import * as i1$1 from '@angular/forms';
|
|
5
5
|
import { Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
6
6
|
import { BehaviorSubject, Subject, lastValueFrom, filter } from 'rxjs';
|
|
7
7
|
import * as i1 from '@angular/common/http';
|
|
@@ -16,6 +16,7 @@ import { MatInputModule } from '@angular/material/input';
|
|
|
16
16
|
import * as i5 from 'ngx-intl-tel-input';
|
|
17
17
|
import { CountryISO, SearchCountryField, NgxIntlTelInputModule } from 'ngx-intl-tel-input';
|
|
18
18
|
import { PhoneNumberUtil, PhoneNumberFormat } from 'google-libphonenumber';
|
|
19
|
+
import { JwtHelperService } from '@auth0/angular-jwt';
|
|
19
20
|
|
|
20
21
|
var LoginState;
|
|
21
22
|
(function (LoginState) {
|
|
@@ -134,6 +135,10 @@ class AvayaIPOService {
|
|
|
134
135
|
};
|
|
135
136
|
agentStatusApiUrl = 'https://v2xla9n0t6.execute-api.us-west-2.amazonaws.com/dev';
|
|
136
137
|
CALL_HISTORY_API_URL = 'https://ktgxyy2x2h.execute-api.us-west-2.amazonaws.com/avayaCallHistory';
|
|
138
|
+
prewarmedStream;
|
|
139
|
+
isSafari() {
|
|
140
|
+
return /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
|
|
141
|
+
}
|
|
137
142
|
_rpcPatched = false;
|
|
138
143
|
constructor(zone, http) {
|
|
139
144
|
this.zone = zone;
|
|
@@ -203,7 +208,8 @@ class AvayaIPOService {
|
|
|
203
208
|
console.debug('setDeviceIds: ', deviceIds);
|
|
204
209
|
this.cli.setDeviceIds(deviceIds);
|
|
205
210
|
}
|
|
206
|
-
makeCall(destination) {
|
|
211
|
+
async makeCall(destination) {
|
|
212
|
+
await this.prewarmMic();
|
|
207
213
|
console.debug('makeCall devicelist: ', this.getDeviceList());
|
|
208
214
|
const freeSlot = ['1', '2', '3'].find((s) => this.callSlots[s] === null);
|
|
209
215
|
if (!freeSlot) {
|
|
@@ -566,8 +572,9 @@ class AvayaIPOService {
|
|
|
566
572
|
return origSend(raw);
|
|
567
573
|
};
|
|
568
574
|
}
|
|
569
|
-
makeCallWithCustomData(destination, dataToSend) {
|
|
570
|
-
//
|
|
575
|
+
async makeCallWithCustomData(destination, dataToSend) {
|
|
576
|
+
// 0) Safari race fix
|
|
577
|
+
await this.prewarmMic();
|
|
571
578
|
this.patchRpcForTransfers(dataToSend);
|
|
572
579
|
// 2) find a free slot
|
|
573
580
|
const freeSlot = ['1', '2', '3'].find((s) => this.callSlots[s] === null);
|
|
@@ -621,10 +628,37 @@ class AvayaIPOService {
|
|
|
621
628
|
return origSend(data);
|
|
622
629
|
};
|
|
623
630
|
}
|
|
624
|
-
|
|
625
|
-
|
|
631
|
+
/** Pre-warm microphone so AWL always has a local stream when it tries addStream() */
|
|
632
|
+
async prewarmMic() {
|
|
633
|
+
// Reuse if we already have a healthy stream
|
|
634
|
+
if (this.prewarmedStream && this.prewarmedStream.getTracks().length) {
|
|
635
|
+
return this.prewarmedStream;
|
|
636
|
+
}
|
|
637
|
+
// On Safari, first call should be simple (no exact device constraints)
|
|
638
|
+
const audio = this.isSafari() ? true : { echoCancellation: false, noiseSuppression: false, autoGainControl: false };
|
|
639
|
+
const stream = await navigator.mediaDevices.getUserMedia({ audio });
|
|
640
|
+
this.prewarmedStream = stream;
|
|
641
|
+
this.localStream = stream;
|
|
642
|
+
// Hand it to the polyfill fallback so addStream(undefined) still works
|
|
643
|
+
window.__LAST_LOCAL_STREAM = stream;
|
|
644
|
+
// (Optional) Nudge autoplay policy: attach to a muted hidden <audio> once
|
|
645
|
+
try {
|
|
646
|
+
const a = document.createElement('audio');
|
|
647
|
+
a.muted = true;
|
|
648
|
+
a.autoplay = true;
|
|
649
|
+
a.style.display = 'none';
|
|
650
|
+
a.srcObject = stream;
|
|
651
|
+
document.body.appendChild(a);
|
|
652
|
+
await a.play().catch(() => { });
|
|
653
|
+
// keep element for lifetime of the page to avoid GC issues
|
|
654
|
+
}
|
|
655
|
+
catch { }
|
|
656
|
+
return stream;
|
|
657
|
+
}
|
|
658
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOService, deps: [{ token: i0.NgZone }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
659
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOService, providedIn: 'root' });
|
|
626
660
|
}
|
|
627
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
661
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOService, decorators: [{
|
|
628
662
|
type: Injectable,
|
|
629
663
|
args: [{ providedIn: 'root' }]
|
|
630
664
|
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i1.HttpClient }] });
|
|
@@ -651,10 +685,10 @@ class CountryService {
|
|
|
651
685
|
await this.getAllCountries();
|
|
652
686
|
return this.countriesData?.find((c) => c.code === countryCode);
|
|
653
687
|
}
|
|
654
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
655
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.
|
|
688
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CountryService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
689
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CountryService, providedIn: 'root' });
|
|
656
690
|
}
|
|
657
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
691
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CountryService, decorators: [{
|
|
658
692
|
type: Injectable,
|
|
659
693
|
args: [{
|
|
660
694
|
providedIn: 'root',
|
|
@@ -674,16 +708,159 @@ class PhoneNumberLookupService {
|
|
|
674
708
|
// console.debug('res_lookupPhoneNumber: ', res_lookupPhoneNumber);
|
|
675
709
|
return res_lookupPhoneNumber;
|
|
676
710
|
}
|
|
677
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
678
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.
|
|
711
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: PhoneNumberLookupService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
712
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: PhoneNumberLookupService, providedIn: 'root' });
|
|
679
713
|
}
|
|
680
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
714
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: PhoneNumberLookupService, decorators: [{
|
|
681
715
|
type: Injectable,
|
|
682
716
|
args: [{
|
|
683
717
|
providedIn: 'root',
|
|
684
718
|
}]
|
|
685
719
|
}], ctorParameters: () => [{ type: i1.HttpClient }] });
|
|
686
720
|
|
|
721
|
+
// import { Injectable } from '@angular/core';
|
|
722
|
+
// import { HttpClient } from '@angular/common/http';
|
|
723
|
+
// import { lastValueFrom } from 'rxjs';
|
|
724
|
+
// import { CallMetadata } from '../models/active-call.model';
|
|
725
|
+
// export interface RecordingSession {
|
|
726
|
+
// audioContext: AudioContext;
|
|
727
|
+
// recordingStream: MediaStreamAudioDestinationNode;
|
|
728
|
+
// recorder: MediaRecorder;
|
|
729
|
+
// metadata: CallMetadata;
|
|
730
|
+
// }
|
|
731
|
+
// @Injectable({ providedIn: 'root' })
|
|
732
|
+
// export class RecordingManagerService {
|
|
733
|
+
// private sessions = new Map<string, RecordingSession>();
|
|
734
|
+
// private readonly MIME_TYPE_PREFERRED = 'audio/webm;codecs=opus';
|
|
735
|
+
// private readonly MIME_TYPE_FALLBACK = 'audio/webm';
|
|
736
|
+
// private readonly CHUNK_DURATION_MS = 5000;
|
|
737
|
+
// private readonly AUDIO_CONTEXT_CLOSE_DELAY_MS = 200;
|
|
738
|
+
// private readonly CALL_HISTORY_API_URL =
|
|
739
|
+
// 'https://ktgxyy2x2h.execute-api.us-west-2.amazonaws.com/avayaCallHistory';
|
|
740
|
+
// constructor(private http: HttpClient) {}
|
|
741
|
+
// // prettier-ignore
|
|
742
|
+
// startRecording(localMediaStream: MediaStream, remoteMediaStream: MediaStream, metadata: RecordingSession['metadata']): RecordingSession | undefined {
|
|
743
|
+
// // Stop any existing recording session for this callId
|
|
744
|
+
// this.stopRecording(metadata.callId);
|
|
745
|
+
// if (!localMediaStream || !remoteMediaStream) {
|
|
746
|
+
// console.warn(`[${metadata.callId}] Skipped start recording: missing remote or local stream`);
|
|
747
|
+
// return undefined;
|
|
748
|
+
// }
|
|
749
|
+
// const audioContext = new AudioContext();
|
|
750
|
+
// const recordingStream = audioContext.createMediaStreamDestination();
|
|
751
|
+
// // console.debug(`[${metadata.callId}] Connecting local and remote audio streams to recording context`);
|
|
752
|
+
// audioContext.createMediaStreamSource(localMediaStream).connect(recordingStream);
|
|
753
|
+
// audioContext.createMediaStreamSource(remoteMediaStream).connect(recordingStream);
|
|
754
|
+
// const mimeType = MediaRecorder.isTypeSupported(this.MIME_TYPE_PREFERRED)
|
|
755
|
+
// ? this.MIME_TYPE_PREFERRED
|
|
756
|
+
// : this.MIME_TYPE_FALLBACK;
|
|
757
|
+
// const recorder = new MediaRecorder(recordingStream.stream, { mimeType });
|
|
758
|
+
// recorder.ondataavailable = (evt: BlobEvent) => this.handleDataAvailable(evt, metadata);
|
|
759
|
+
// recorder.onerror = (err) => console.error(`[${metadata.callId}] MediaRecorder error:`, err);
|
|
760
|
+
// recorder.start(this.CHUNK_DURATION_MS);
|
|
761
|
+
// console.debug(`[${metadata.callId}] MediaRecorder started (chunk size: ${this.CHUNK_DURATION_MS / 1000}s)`);
|
|
762
|
+
// const session: RecordingSession = {
|
|
763
|
+
// audioContext,
|
|
764
|
+
// recordingStream,
|
|
765
|
+
// recorder,
|
|
766
|
+
// metadata,
|
|
767
|
+
// };
|
|
768
|
+
// this.sessions.set(metadata.callId, session);
|
|
769
|
+
// return session;
|
|
770
|
+
// }
|
|
771
|
+
// getSession(callId: string): RecordingSession | undefined {
|
|
772
|
+
// return this.sessions.get(callId);
|
|
773
|
+
// }
|
|
774
|
+
// stopRecording(callId: string): void {
|
|
775
|
+
// const session = this.sessions.get(callId);
|
|
776
|
+
// if (!session) return;
|
|
777
|
+
// const { recorder, audioContext } = session;
|
|
778
|
+
// if (recorder?.state === 'recording') {
|
|
779
|
+
// recorder.stop();
|
|
780
|
+
// console.debug(`[${callId}] MediaRecorder stopped`);
|
|
781
|
+
// }
|
|
782
|
+
// setTimeout(() => {
|
|
783
|
+
// if (audioContext.state !== 'closed') {
|
|
784
|
+
// audioContext.close();
|
|
785
|
+
// console.debug(`[${callId}] AudioContext closed`);
|
|
786
|
+
// }
|
|
787
|
+
// }, this.AUDIO_CONTEXT_CLOSE_DELAY_MS);
|
|
788
|
+
// this.sessions.delete(callId);
|
|
789
|
+
// }
|
|
790
|
+
// // prettier-ignore
|
|
791
|
+
// private async handleDataAvailable(evt: BlobEvent, metadata: RecordingSession['metadata']): Promise<void> {
|
|
792
|
+
// if (!evt.data || evt.data.size === 0) return;
|
|
793
|
+
// const filename = this.generateFilename(metadata.callId);
|
|
794
|
+
// // console.debug(`[${metadata.callId}] Recording chunk ready → preparing to upload as "${filename}"`);
|
|
795
|
+
// try {
|
|
796
|
+
// await this.uploadCallRecording(metadata, evt.data, filename);
|
|
797
|
+
// console.debug(`[${metadata.callId}] Upload successful → "${filename}"`);
|
|
798
|
+
// } catch (err) {
|
|
799
|
+
// console.error(`[${metadata.callId}] Upload failed → "${filename}"`, err);
|
|
800
|
+
// }
|
|
801
|
+
// }
|
|
802
|
+
// // prettier-ignore
|
|
803
|
+
// private async uploadCallRecording(metadata: RecordingSession['metadata'], file: Blob, filename?: string): Promise<{ success: boolean; message: string; s3Key?: string }> {
|
|
804
|
+
// try {
|
|
805
|
+
// if (!filename) {
|
|
806
|
+
// const timestamp = new Date()
|
|
807
|
+
// .toISOString()
|
|
808
|
+
// .replace(/[:.]/g, '')
|
|
809
|
+
// .replace('T', '-')
|
|
810
|
+
// .slice(0, 15);
|
|
811
|
+
// filename = `${timestamp}-${metadata.agentId}.webm`;
|
|
812
|
+
// console.debug(`[${metadata.callId}] filename generated: "${filename}"`);
|
|
813
|
+
// }
|
|
814
|
+
// // console.debug(`[${metadata.callId}] Converting Blob to Base64 for upload`);
|
|
815
|
+
// const base64 = await this.convertBlobToBase64(file);
|
|
816
|
+
// const body = base64.split(',')[1];
|
|
817
|
+
// const payload = {
|
|
818
|
+
// ...metadata,
|
|
819
|
+
// filename,
|
|
820
|
+
// isBase64: true,
|
|
821
|
+
// body,
|
|
822
|
+
// };
|
|
823
|
+
// const url = `${this.CALL_HISTORY_API_URL}?action=uploadRecording`;
|
|
824
|
+
// console.debug(`[${metadata.callId}] Sending recording chunk to ${url}`);
|
|
825
|
+
// console.debug(`[${metadata.callId}] Payload: `, payload);
|
|
826
|
+
// const res: any = await lastValueFrom(
|
|
827
|
+
// this.http.post(url, payload, {
|
|
828
|
+
// headers: { 'Content-Type': 'application/json' },
|
|
829
|
+
// responseType: 'json',
|
|
830
|
+
// })
|
|
831
|
+
// );
|
|
832
|
+
// console.debug(`[${metadata.callId}] Upload response: `, res);
|
|
833
|
+
// return {
|
|
834
|
+
// success: true,
|
|
835
|
+
// message: res?.message || 'Upload successful',
|
|
836
|
+
// s3Key: res?.s3Key,
|
|
837
|
+
// };
|
|
838
|
+
// } catch (err: any) {
|
|
839
|
+
// console.error(`[${metadata.callId}] Upload failed: `, err);
|
|
840
|
+
// return {
|
|
841
|
+
// success: false,
|
|
842
|
+
// message: err?.message || 'Upload failed',
|
|
843
|
+
// };
|
|
844
|
+
// }
|
|
845
|
+
// }
|
|
846
|
+
// private convertBlobToBase64(blob: Blob): Promise<string> {
|
|
847
|
+
// return new Promise((resolve, reject) => {
|
|
848
|
+
// const reader = new FileReader();
|
|
849
|
+
// reader.onerror = reject;
|
|
850
|
+
// reader.onload = () => resolve(reader.result as string);
|
|
851
|
+
// reader.readAsDataURL(blob);
|
|
852
|
+
// });
|
|
853
|
+
// }
|
|
854
|
+
// private generateFilename(callId: string): string {
|
|
855
|
+
// const now = new Date();
|
|
856
|
+
// const dateStr = now.toISOString().slice(0, 10).replace(/-/g, '');
|
|
857
|
+
// const timeStr = now.toTimeString().slice(0, 8).replace(/:/g, '');
|
|
858
|
+
// const msStr = now.getMilliseconds().toString().padStart(3, '0');
|
|
859
|
+
// const filename = `${callId}-${dateStr}-${timeStr}${msStr}.webm`;
|
|
860
|
+
// console.debug(`[${callId}] Generated filename: "${filename}"`);
|
|
861
|
+
// return filename;
|
|
862
|
+
// }
|
|
863
|
+
// }
|
|
687
864
|
class RecordingManagerService {
|
|
688
865
|
http;
|
|
689
866
|
sessions = new Map();
|
|
@@ -695,9 +872,9 @@ class RecordingManagerService {
|
|
|
695
872
|
constructor(http) {
|
|
696
873
|
this.http = http;
|
|
697
874
|
}
|
|
698
|
-
//
|
|
875
|
+
// ---- Public API ----------------------------------------------------------
|
|
699
876
|
startRecording(localMediaStream, remoteMediaStream, metadata) {
|
|
700
|
-
//
|
|
877
|
+
// stop any previous session for this call
|
|
701
878
|
this.stopRecording(metadata.callId);
|
|
702
879
|
if (!localMediaStream || !remoteMediaStream) {
|
|
703
880
|
console.warn(`[${metadata.callId}] Skipped start recording: missing remote or local stream`);
|
|
@@ -705,24 +882,20 @@ class RecordingManagerService {
|
|
|
705
882
|
}
|
|
706
883
|
const audioContext = new AudioContext();
|
|
707
884
|
const recordingStream = audioContext.createMediaStreamDestination();
|
|
708
|
-
// console.debug(`[${metadata.callId}] Connecting local and remote audio streams to recording context`);
|
|
709
885
|
audioContext.createMediaStreamSource(localMediaStream).connect(recordingStream);
|
|
710
886
|
audioContext.createMediaStreamSource(remoteMediaStream).connect(recordingStream);
|
|
711
|
-
const mimeType = MediaRecorder.isTypeSupported(this.MIME_TYPE_PREFERRED)
|
|
712
|
-
? this.MIME_TYPE_PREFERRED
|
|
713
|
-
: this.MIME_TYPE_FALLBACK;
|
|
714
|
-
const recorder = new MediaRecorder(recordingStream.stream, { mimeType });
|
|
715
|
-
recorder.ondataavailable = (evt) => this.handleDataAvailable(evt, metadata);
|
|
716
|
-
recorder.onerror = (err) => console.error(`[${metadata.callId}] MediaRecorder error:`, err);
|
|
717
|
-
recorder.start(this.CHUNK_DURATION_MS);
|
|
718
|
-
console.debug(`[${metadata.callId}] MediaRecorder started (chunk size: ${this.CHUNK_DURATION_MS / 1000}s)`);
|
|
719
887
|
const session = {
|
|
720
888
|
audioContext,
|
|
721
889
|
recordingStream,
|
|
722
|
-
recorder,
|
|
723
890
|
metadata,
|
|
891
|
+
stopping: false,
|
|
892
|
+
chunkIndex: 0,
|
|
893
|
+
recorder: null,
|
|
894
|
+
chunkTimer: undefined
|
|
724
895
|
};
|
|
725
896
|
this.sessions.set(metadata.callId, session);
|
|
897
|
+
// kick off the chunk loop
|
|
898
|
+
this.startNextChunk(session);
|
|
726
899
|
return session;
|
|
727
900
|
}
|
|
728
901
|
getSession(callId) {
|
|
@@ -732,46 +905,78 @@ class RecordingManagerService {
|
|
|
732
905
|
const session = this.sessions.get(callId);
|
|
733
906
|
if (!session)
|
|
734
907
|
return;
|
|
735
|
-
|
|
736
|
-
if (
|
|
737
|
-
|
|
738
|
-
|
|
908
|
+
session.stopping = true;
|
|
909
|
+
if (session.chunkTimer) {
|
|
910
|
+
clearTimeout(session.chunkTimer);
|
|
911
|
+
session.chunkTimer = undefined;
|
|
912
|
+
}
|
|
913
|
+
const rec = session.recorder;
|
|
914
|
+
if (rec && rec.state === 'recording') {
|
|
915
|
+
try {
|
|
916
|
+
rec.stop(); // this will still produce the final (playable) chunk
|
|
917
|
+
}
|
|
918
|
+
catch { }
|
|
739
919
|
}
|
|
920
|
+
// close audio context a bit later
|
|
740
921
|
setTimeout(() => {
|
|
741
|
-
if (audioContext.state !== 'closed') {
|
|
742
|
-
audioContext.close();
|
|
743
|
-
console.debug(`[${callId}] AudioContext closed`);
|
|
922
|
+
if (session.audioContext.state !== 'closed') {
|
|
923
|
+
session.audioContext.close();
|
|
924
|
+
console.debug(`[${session.metadata.callId}] AudioContext closed`);
|
|
744
925
|
}
|
|
745
926
|
}, this.AUDIO_CONTEXT_CLOSE_DELAY_MS);
|
|
746
927
|
this.sessions.delete(callId);
|
|
747
928
|
}
|
|
748
|
-
//
|
|
749
|
-
|
|
750
|
-
|
|
929
|
+
// ---- Internals -----------------------------------------------------------
|
|
930
|
+
/** Start a new MediaRecorder for the next chunk so the blob has its own headers */
|
|
931
|
+
startNextChunk(session) {
|
|
932
|
+
if (session.stopping)
|
|
751
933
|
return;
|
|
752
|
-
const
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
934
|
+
const mimeType = MediaRecorder.isTypeSupported(this.MIME_TYPE_PREFERRED)
|
|
935
|
+
? this.MIME_TYPE_PREFERRED
|
|
936
|
+
: this.MIME_TYPE_FALLBACK;
|
|
937
|
+
const recorder = new MediaRecorder(session.recordingStream.stream, { mimeType });
|
|
938
|
+
session.recorder = recorder;
|
|
939
|
+
const myChunkIdx = session.chunkIndex++;
|
|
940
|
+
recorder.ondataavailable = async (evt) => {
|
|
941
|
+
if (!evt.data || evt.data.size === 0)
|
|
942
|
+
return;
|
|
943
|
+
// give each chunk its own unique filename (includes index)
|
|
944
|
+
const filename = this.generateChunkFilename(session.metadata.callId, myChunkIdx);
|
|
945
|
+
try {
|
|
946
|
+
await this.uploadCallRecording(session.metadata, evt.data, filename);
|
|
947
|
+
console.debug(`[${session.metadata.callId}] ✅ uploaded chunk → ${filename}`);
|
|
948
|
+
}
|
|
949
|
+
catch (err) {
|
|
950
|
+
console.error(`[${session.metadata.callId}] ❌ upload failed → ${filename}`, err);
|
|
951
|
+
}
|
|
952
|
+
};
|
|
953
|
+
recorder.onerror = (err) => {
|
|
954
|
+
console.error(`[${session.metadata.callId}] MediaRecorder error:`, err);
|
|
955
|
+
};
|
|
956
|
+
// when this recorder is stopped, immediately start the next one (unless stopping)
|
|
957
|
+
recorder.onstop = () => {
|
|
958
|
+
if (session.stopping)
|
|
959
|
+
return;
|
|
960
|
+
// start the next chunk on the next tick to avoid overlap
|
|
961
|
+
setTimeout(() => this.startNextChunk(session), 0);
|
|
962
|
+
};
|
|
963
|
+
// Start recording this chunk (no timeslice!) and schedule a stop after N ms.
|
|
964
|
+
recorder.start();
|
|
965
|
+
console.debug(`[${session.metadata.callId}] MediaRecorder started for chunk #${myChunkIdx}`);
|
|
966
|
+
session.chunkTimer = window.setTimeout(() => {
|
|
967
|
+
if (!session.stopping && recorder.state === 'recording') {
|
|
968
|
+
// ensure we flush a complete, headered WebM
|
|
969
|
+
recorder.stop();
|
|
970
|
+
console.debug(`[${session.metadata.callId}] MediaRecorder stopped for chunk #${myChunkIdx}`);
|
|
971
|
+
}
|
|
972
|
+
}, this.CHUNK_DURATION_MS);
|
|
761
973
|
}
|
|
762
|
-
//
|
|
974
|
+
// Upload a single chunk (Blob) as base64 payload
|
|
763
975
|
async uploadCallRecording(metadata, file, filename) {
|
|
764
976
|
try {
|
|
765
977
|
if (!filename) {
|
|
766
|
-
|
|
767
|
-
.toISOString()
|
|
768
|
-
.replace(/[:.]/g, '')
|
|
769
|
-
.replace('T', '-')
|
|
770
|
-
.slice(0, 15);
|
|
771
|
-
filename = `${timestamp}-${metadata.agentId}.webm`;
|
|
772
|
-
console.debug(`[${metadata.callId}] filename generated: "${filename}"`);
|
|
978
|
+
filename = this.generateFilename(metadata.callId, metadata.agentId);
|
|
773
979
|
}
|
|
774
|
-
// console.debug(`[${metadata.callId}] Converting Blob to Base64 for upload`);
|
|
775
980
|
const base64 = await this.convertBlobToBase64(file);
|
|
776
981
|
const body = base64.split(',')[1];
|
|
777
982
|
const payload = {
|
|
@@ -781,13 +986,10 @@ class RecordingManagerService {
|
|
|
781
986
|
body,
|
|
782
987
|
};
|
|
783
988
|
const url = `${this.CALL_HISTORY_API_URL}?action=uploadRecording`;
|
|
784
|
-
console.debug(`[${metadata.callId}] Sending recording chunk to ${url}`);
|
|
785
|
-
console.debug(`[${metadata.callId}] Payload: `, payload);
|
|
786
989
|
const res = await lastValueFrom(this.http.post(url, payload, {
|
|
787
990
|
headers: { 'Content-Type': 'application/json' },
|
|
788
991
|
responseType: 'json',
|
|
789
992
|
}));
|
|
790
|
-
console.debug(`[${metadata.callId}] Upload response: `, res);
|
|
791
993
|
return {
|
|
792
994
|
success: true,
|
|
793
995
|
message: res?.message || 'Upload successful',
|
|
@@ -795,7 +997,6 @@ class RecordingManagerService {
|
|
|
795
997
|
};
|
|
796
998
|
}
|
|
797
999
|
catch (err) {
|
|
798
|
-
console.error(`[${metadata.callId}] Upload failed: `, err);
|
|
799
1000
|
return {
|
|
800
1001
|
success: false,
|
|
801
1002
|
message: err?.message || 'Upload failed',
|
|
@@ -810,68 +1011,146 @@ class RecordingManagerService {
|
|
|
810
1011
|
reader.readAsDataURL(blob);
|
|
811
1012
|
});
|
|
812
1013
|
}
|
|
813
|
-
generateFilename(callId) {
|
|
1014
|
+
generateFilename(callId, agentId) {
|
|
1015
|
+
const timestamp = new Date().toISOString().replace(/[:.]/g, '').replace('T', '-').slice(0, 15);
|
|
1016
|
+
return `${timestamp}-${agentId}-${callId}.webm`;
|
|
1017
|
+
}
|
|
1018
|
+
generateChunkFilename(callId, chunkIndex) {
|
|
814
1019
|
const now = new Date();
|
|
815
1020
|
const dateStr = now.toISOString().slice(0, 10).replace(/-/g, '');
|
|
816
1021
|
const timeStr = now.toTimeString().slice(0, 8).replace(/:/g, '');
|
|
817
1022
|
const msStr = now.getMilliseconds().toString().padStart(3, '0');
|
|
818
|
-
const
|
|
819
|
-
|
|
820
|
-
return filename;
|
|
1023
|
+
const part = String(chunkIndex).padStart(4, '0');
|
|
1024
|
+
return `${callId}-${dateStr}-${timeStr}${msStr}-part${part}.webm`;
|
|
821
1025
|
}
|
|
822
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
823
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.
|
|
1026
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: RecordingManagerService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1027
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: RecordingManagerService, providedIn: 'root' });
|
|
824
1028
|
}
|
|
825
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
1029
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: RecordingManagerService, decorators: [{
|
|
826
1030
|
type: Injectable,
|
|
827
1031
|
args: [{ providedIn: 'root' }]
|
|
828
1032
|
}], ctorParameters: () => [{ type: i1.HttpClient }] });
|
|
829
1033
|
|
|
1034
|
+
// import { Injectable } from '@angular/core';
|
|
1035
|
+
// import { BehaviorSubject } from 'rxjs';
|
|
1036
|
+
// import { CallMetadata } from '../models/active-call.model';
|
|
1037
|
+
// @Injectable({ providedIn: 'root' })
|
|
1038
|
+
// export class CallSocketService {
|
|
1039
|
+
// private socket: WebSocket | null = null;
|
|
1040
|
+
// readonly message$ = new BehaviorSubject<any>(null);
|
|
1041
|
+
// open(metadata: CallMetadata): void {
|
|
1042
|
+
// if (this.socket?.readyState === WebSocket.OPEN) return;
|
|
1043
|
+
// if (this.socket?.readyState === WebSocket.CONNECTING) return;
|
|
1044
|
+
// this.socket = new WebSocket(
|
|
1045
|
+
// 'wss://hymtqh7k82.execute-api.us-west-2.amazonaws.com/callSession'
|
|
1046
|
+
// );
|
|
1047
|
+
// this.socket.onopen = () => {
|
|
1048
|
+
// console.warn('[WS] open----------------------------------------------');
|
|
1049
|
+
// this.socket!.send(JSON.stringify(metadata));
|
|
1050
|
+
// };
|
|
1051
|
+
// this.socket.onmessage = (ev) => {
|
|
1052
|
+
// try {
|
|
1053
|
+
// this.message$.next(JSON.parse(ev.data));
|
|
1054
|
+
// } catch {
|
|
1055
|
+
// this.message$.next(ev.data);
|
|
1056
|
+
// }
|
|
1057
|
+
// };
|
|
1058
|
+
// this.socket.onerror = (ev) => {
|
|
1059
|
+
// console.error('[WS] error', ev);
|
|
1060
|
+
// };
|
|
1061
|
+
// this.socket.onclose = () => {
|
|
1062
|
+
// console.warn('[WS] closed');
|
|
1063
|
+
// this.socket = null;
|
|
1064
|
+
// };
|
|
1065
|
+
// }
|
|
1066
|
+
// send(payload: object): void {
|
|
1067
|
+
// if (this.socket?.readyState === WebSocket.OPEN) {
|
|
1068
|
+
// this.socket.send(JSON.stringify(payload));
|
|
1069
|
+
// } else {
|
|
1070
|
+
// console.warn('[WS] not open; dropping', payload);
|
|
1071
|
+
// }
|
|
1072
|
+
// }
|
|
1073
|
+
// close(): void {
|
|
1074
|
+
// this.socket?.close();
|
|
1075
|
+
// this.socket = null;
|
|
1076
|
+
// }
|
|
1077
|
+
// }
|
|
830
1078
|
class CallSocketService {
|
|
831
|
-
|
|
832
|
-
|
|
1079
|
+
sockets = new Map();
|
|
1080
|
+
subjects = new Map();
|
|
833
1081
|
open(metadata) {
|
|
834
|
-
|
|
1082
|
+
const { callId } = metadata;
|
|
1083
|
+
const existing = this.sockets.get(callId);
|
|
1084
|
+
if (existing && (existing.readyState === WebSocket.OPEN || existing.readyState === WebSocket.CONNECTING)) {
|
|
835
1085
|
return;
|
|
836
|
-
|
|
837
|
-
|
|
838
|
-
this.
|
|
839
|
-
this.
|
|
840
|
-
|
|
841
|
-
|
|
1086
|
+
}
|
|
1087
|
+
const ws = new WebSocket('wss://hymtqh7k82.execute-api.us-west-2.amazonaws.com/callSession');
|
|
1088
|
+
this.sockets.set(callId, ws);
|
|
1089
|
+
if (!this.subjects.has(callId))
|
|
1090
|
+
this.subjects.set(callId, new BehaviorSubject(null));
|
|
1091
|
+
ws.onopen = () => {
|
|
1092
|
+
console.warn('[WS Open ]', { callId });
|
|
1093
|
+
ws.send(JSON.stringify(metadata));
|
|
842
1094
|
};
|
|
843
|
-
|
|
1095
|
+
ws.onmessage = (ev) => {
|
|
1096
|
+
const subj = this.subjects.get(callId);
|
|
1097
|
+
if (!subj)
|
|
1098
|
+
return;
|
|
844
1099
|
try {
|
|
845
|
-
|
|
1100
|
+
subj.next(JSON.parse(ev.data));
|
|
846
1101
|
}
|
|
847
1102
|
catch {
|
|
848
|
-
|
|
1103
|
+
subj.next(ev.data);
|
|
849
1104
|
}
|
|
850
1105
|
};
|
|
851
|
-
|
|
852
|
-
console.
|
|
1106
|
+
ws.onerror = (ev) => {
|
|
1107
|
+
console.warn('[WS Error]', { callId, ev });
|
|
853
1108
|
};
|
|
854
|
-
|
|
855
|
-
console.warn('[WS]
|
|
856
|
-
this.
|
|
1109
|
+
ws.onclose = () => {
|
|
1110
|
+
console.warn('[WS Closed]', { callId });
|
|
1111
|
+
this.sockets.delete(callId);
|
|
1112
|
+
// keep subject around if you want late subscribers to see last value.
|
|
1113
|
+
// If you want to free it too, uncomment the next line:
|
|
1114
|
+
// this.subjects.delete(callId);
|
|
857
1115
|
};
|
|
858
1116
|
}
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
1117
|
+
messages$(callId) {
|
|
1118
|
+
return this.subjects.get(callId);
|
|
1119
|
+
}
|
|
1120
|
+
send(callId, payload) {
|
|
1121
|
+
const ws = this.sockets.get(callId);
|
|
1122
|
+
if (ws?.readyState === WebSocket.OPEN) {
|
|
1123
|
+
ws.send(JSON.stringify(payload));
|
|
862
1124
|
}
|
|
863
1125
|
else {
|
|
864
|
-
console.warn('[WS]
|
|
1126
|
+
console.warn('[WS NotOpen ]', { callId, dropping: payload });
|
|
865
1127
|
}
|
|
866
1128
|
}
|
|
867
|
-
close() {
|
|
868
|
-
this.
|
|
869
|
-
|
|
1129
|
+
close(callId) {
|
|
1130
|
+
const ws = this.sockets.get(callId);
|
|
1131
|
+
if (ws) {
|
|
1132
|
+
ws.close();
|
|
1133
|
+
this.sockets.delete(callId);
|
|
1134
|
+
// optional: also remove the subject
|
|
1135
|
+
// this.subjects.delete(callId);
|
|
1136
|
+
}
|
|
1137
|
+
}
|
|
1138
|
+
closeAll() {
|
|
1139
|
+
for (const [callId, ws] of this.sockets.entries()) {
|
|
1140
|
+
try {
|
|
1141
|
+
ws.close();
|
|
1142
|
+
}
|
|
1143
|
+
catch { }
|
|
1144
|
+
console.warn('[WS Closed]', { callId });
|
|
1145
|
+
}
|
|
1146
|
+
this.sockets.clear();
|
|
1147
|
+
// optional: also clear subjects
|
|
1148
|
+
// this.subjects.clear();
|
|
870
1149
|
}
|
|
871
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
872
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.
|
|
1150
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CallSocketService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1151
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CallSocketService, providedIn: 'root' });
|
|
873
1152
|
}
|
|
874
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
1153
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CallSocketService, decorators: [{
|
|
875
1154
|
type: Injectable,
|
|
876
1155
|
args: [{ providedIn: 'root' }]
|
|
877
1156
|
}] });
|
|
@@ -880,7 +1159,9 @@ class CallHistoryComponent {
|
|
|
880
1159
|
http;
|
|
881
1160
|
authenticationService;
|
|
882
1161
|
cdr;
|
|
1162
|
+
mode = 'dial';
|
|
883
1163
|
makeCallEv = new EventEmitter();
|
|
1164
|
+
transferEv = new EventEmitter();
|
|
884
1165
|
CALL_HISTORY_API_URL = 'https://ktgxyy2x2h.execute-api.us-west-2.amazonaws.com/avayaCallHistory';
|
|
885
1166
|
showHistoryLoader = false;
|
|
886
1167
|
callHistory = [];
|
|
@@ -925,23 +1206,99 @@ class CallHistoryComponent {
|
|
|
925
1206
|
makeCall(phoneNumber) {
|
|
926
1207
|
this.makeCallEv.emit(phoneNumber);
|
|
927
1208
|
}
|
|
928
|
-
|
|
929
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.4", type: CallHistoryComponent, isStandalone: false, selector: "app-call-history", outputs: { makeCallEv: "makeCallEv" }, ngImport: i0, template: "<div *ngIf=\"showHistoryLoader\">Loading...</div>\n<div class=\"recent_container_outer\">\n <div class=\"recent_options_header\">\n <div class=\"recent_inner\">\n <button class=\"recent_btn\" (click)=\"recentSelectTab('recentCall')\"\n [class.active]=\"recentCallactiveTab === 'recentCall'\">\n Recent\n </button>\n <button class=\"recent_btn\" (click)=\"recentSelectTab('missedCall')\"\n [class.active]=\"recentCallactiveTab === 'missedCall'\">\n Missed Call\n </button>\n </div>\n </div>\n <h2 class=\"recent_heading\">Recent</h2>\n <div class=\"container_recent_search\">\n <input type=\"search\" placeholder=\"Type to search\">\n </div>\n\n <div class=\"recent_tab_container\" *ngIf=\"recentCallactiveTab === 'recentCall' \">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n\n <div class=\"outer_container_recent\" *ngFor=\"let call of callHistory\">\n <div class=\"container_recent_item\">\n <!-- avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner grd1\">\n {{ (call.phoneNumber?.country?.code) | uppercase }}\n </div>\n </div>\n\n <!-- middle -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">{{call.phoneNumber?.normalizedPhoneNumber}}</div>\n\n <div class=\"recent_time_back\" [ngClass]=\"{ missed_call_color: call.status === 'MISSED' }\">\n <!-- use your existing SVGs -->\n {{ call.direction}}\n </div>\n </div>\n\n <!-- right time -->\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">\n {{ call.timestamp | date: 'dd/MM/yyyy' }}\n </span>\n </div>\n </div>\n\n <!-- call button -->\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\" (click)=\"makeCall(call.phoneNumber?.normalizedPhoneNumber)\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- no results -->\n <div *ngIf=\"callHistory.length === 0\" class=\"container_call_history_not_found\">\n <div class=\"icon_round_area_call_history\"></div>\n <h2>No Call History</h2>\n <p>Your call history is empty</p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"recent_tab_container\" *ngIf=\"recentCallactiveTab === 'missedCall'\">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_recent\">\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".recent_container_outer{margin:0;padding:0;width:100%;position:relative}.recent_options_header{margin:0;padding:15px 15px 10px;width:100%;text-align:center}.recent_inner{margin:0;padding:0 2px;width:100%;height:32px;background:#f0f0f4;border-radius:8px;display:flex;align-items:center;justify-content:center}.recent_btn{margin:0 1px;padding:0;width:50%;display:flex;align-items:center;justify-content:center;border:none;outline:none;background:#f0f0f4;height:26px;border-radius:8px;color:var(--sd-text-color);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn:hover{background:#e6e6eb;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn.active{color:var(--sd-text-color-dark);background:var(--sd-background-color);font-weight:700}.recent_heading{font-family:var(--sd-text-font-family);font-size:20px;color:var(--sd-text-color-dark);font-weight:700;letter-spacing:-.65px;padding:0 0 15px 15px;line-height:normal;margin:0}.container_recent_search{margin:0 0 15px;padding:0 15px;width:100%}.container_recent_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:39px}.recent_tab_container{margin:0;padding:0;width:100%;height:100%;position:relative}.container_recent_list{width:100%;margin:0;padding:0;position:relative}.container_recent_list_inner{width:100%;position:relative;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:calc(100vh - 204px)}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.outer_container_recent{width:100%;margin:0;padding:0 15px}.container_recent_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;pointer-events:all;border-radius:8px;overflow:hidden;cursor:pointer}.calling_btn{display:none}.container_recent_item:hover .calling_btn{display:block;position:absolute;text-align:right;right:0;width:78px;height:38px;background:var(--sd-background-color)}.container_recent_item_image{display:flex;align-items:center}.container_recent_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400;background:#2a7b9b}.grd1{background:#718ede}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.container_recent_item_left .missed_call_color{color:#e0261f}.container_recent_item_left .recent_time_back{font-size:12px;color:var(--sd-text-color-medium)}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_recent_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.calling_btn_inner{position:relative;width:100%;margin:0;padding:0;display:flex;justify-content:right}.button_recent_call{width:38px;height:38px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center;line-height:normal;border-radius:26px;outline:none;border:none;font-size:22px;font-weight:700;color:#6c0;background:#f1f1f1;border:1px solid #f1f1f1}.container_call_history_not_found{position:absolute;width:100%;height:100%;display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;background:#f8f8f8}.container_call_history_not_found h2{font-size:18px;font-weight:700;letter-spacing:-.65px;color:var(--sd-text-color-dark);text-align:center;padding-top:26px}.container_call_history_not_found p{font-size:12px;line-height:normal;color:var(--sd-text-color);font-weight:600;white-space:normal;text-align:center;padding-top:10px}.icon_round_area_call_history{width:165px;height:75px;background:var(--sd-background-color) url() center no-repeat;border-radius:38px;display:flex;grid-row:1}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i3.DatePipe, name: "date" }] });
|
|
1209
|
+
selectFromHistory(item) {
|
|
1210
|
+
if (this.mode === 'transfer') {
|
|
1211
|
+
this.transferEv.emit(item);
|
|
1212
|
+
return;
|
|
1213
|
+
}
|
|
1214
|
+
const dialable = this.resolveDialable(item) || (item?.phoneNumber ?? '').toString().replace(/\s+/g, '');
|
|
1215
|
+
if (!dialable) {
|
|
1216
|
+
console.warn('No dialable number found in history item:', item);
|
|
1217
|
+
return;
|
|
1218
|
+
}
|
|
1219
|
+
this.makeCallEv.emit(dialable);
|
|
1220
|
+
}
|
|
1221
|
+
resolveDialable(item) {
|
|
1222
|
+
const clean = (v) => (v ?? '').toString().replace(/\s+/g, '');
|
|
1223
|
+
return (clean(item?.resolvedDialable) ||
|
|
1224
|
+
clean(item?.lookupPhoneNumber?.['local-number']) ||
|
|
1225
|
+
clean(item?.lookupPhoneNumber?.lookupPhoneNumber?.['local-number']) ||
|
|
1226
|
+
clean(item?.lookupPhoneNumber?.normalizedPhoneNumber) ||
|
|
1227
|
+
null);
|
|
1228
|
+
}
|
|
1229
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CallHistoryComponent, deps: [{ token: i1.HttpClient }, { token: i8.SnugdeskAuthenticationService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
1230
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.9", type: CallHistoryComponent, isStandalone: false, selector: "app-call-history", inputs: { mode: "mode" }, outputs: { makeCallEv: "makeCallEv", transferEv: "transferEv" }, ngImport: i0, template: "@if (showHistoryLoader) {\n<div>Loading...</div>\n}\n\n<div class=\"recent_container_outer\">\n <div class=\"recent_options_header\">\n <div class=\"recent_inner\">\n <button\n class=\"recent_btn\"\n (click)=\"recentSelectTab('recentCall')\"\n [class.active]=\"recentCallactiveTab === 'recentCall'\"\n >\n Recent\n </button>\n <button\n class=\"recent_btn\"\n (click)=\"recentSelectTab('missedCall')\"\n [class.active]=\"recentCallactiveTab === 'missedCall'\"\n >\n Missed Call\n </button>\n </div>\n </div>\n\n <h2 class=\"recent_heading\">Recent</h2>\n\n <div class=\"container_recent_search\">\n <input type=\"search\" placeholder=\"Type to search\" />\n </div>\n\n @if (recentCallactiveTab === 'recentCall') {\n <div class=\"recent_tab_container\">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n @for (call of callHistory; track $index) {\n <div class=\"outer_container_recent\">\n <div class=\"container_recent_item\">\n <!-- avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner grd1\">\n {{ call.phoneNumber?.country?.code | uppercase }}\n </div>\n </div>\n\n <!-- middle -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">\n {{ call.phoneNumber?.normalizedPhoneNumber }}\n </div>\n\n <div\n class=\"recent_time_back\"\n [ngClass]=\"{\n missed_call_color: call.status === 'MISSED'\n }\"\n >\n <!-- Direction icon (generic handset) -->\n <svg\n viewBox=\"0 0 512 512\"\n width=\"12px\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n {{ call.direction }}\n </div>\n </div>\n\n <!-- right time -->\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">\n {{ call.timestamp | date : \"dd/MM/yyyy\" }}\n </span>\n </div>\n </div>\n\n <!-- call button -->\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <!-- <button\n class=\"button_recent_call\"\n (click)=\"makeCall(call.phoneNumber?.normalizedPhoneNumber)\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button> -->\n\n @if (mode === 'transfer') {\n <button\n class=\"button_recent_call\"\n (click)=\"transferEv.emit(call)\"\n >\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n } @else {\n <button\n class=\"button_recent_call\"\n (click)=\"\n makeCall(call.phoneNumber?.normalizedPhoneNumber)\n \"\n >\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n }\n </div>\n </div>\n </div>\n <!-- /middle -->\n </div>\n </div>\n } @if (callHistory.length === 0) {\n <div class=\"container_call_history_not_found\">\n <div class=\"icon_round_area_call_history\"></div>\n <h2>No Call History</h2>\n <p>Your call history is empty</p>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n </div>\n } @if (recentCallactiveTab === 'missedCall') {\n <div class=\"recent_tab_container\">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_recent\">\n <!-- Missed call item 1 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 2 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 3 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 4 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 5 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 6 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 7 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 8 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 9 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 10 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- /.outer_container_recent -->\n </div>\n <!-- /.scrollbox-content -->\n </div>\n <!-- /.scrollbox -->\n </div>\n <!-- /.container_recent_list_inner -->\n </div>\n <!-- /.container_recent_list -->\n </div>\n <!-- /.recent_tab_container -->\n }\n</div>\n", styles: [".recent_container_outer{margin:0;padding:0;width:100%;position:relative}.recent_options_header{margin:0;padding:15px 15px 10px;width:100%;text-align:center}.recent_inner{margin:0;padding:0 2px;width:100%;height:32px;background:#f0f0f4;border-radius:8px;display:flex;align-items:center;justify-content:center}.recent_btn{margin:0 1px;padding:0;width:50%;display:flex;align-items:center;justify-content:center;border:none;outline:none;background:#f0f0f4;height:26px;border-radius:8px;color:var(--sd-text-color);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn:hover{background:#e6e6eb;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn.active{color:var(--sd-text-color-dark);background:var(--sd-background-color);font-weight:700}.recent_heading{font-family:var(--sd-text-font-family);font-size:20px;color:var(--sd-text-color-dark);font-weight:700;letter-spacing:-.65px;padding:0 0 15px 15px;line-height:normal;margin:0}.container_recent_search{margin:0 0 15px;padding:0 15px;width:100%}.container_recent_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:39px}.recent_tab_container{margin:0;padding:0;width:100%;height:100%;position:relative}.container_recent_list{width:100%;margin:0;padding:0;position:relative}.container_recent_list_inner{width:100%;position:relative;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:calc(100vh - 204px)}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.outer_container_recent{width:100%;margin:0;padding:0 15px}.container_recent_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;pointer-events:all;border-radius:8px;overflow:hidden;cursor:pointer}.calling_btn{display:none}.container_recent_item:hover .calling_btn{display:block;position:absolute;text-align:right;right:0;width:78px;height:38px;background:var(--sd-background-color)}.container_recent_item_image{display:flex;align-items:center}.container_recent_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400;background:#2a7b9b}.grd1{background:#718ede}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.container_recent_item_left .missed_call_color{color:#e0261f}.container_recent_item_left .recent_time_back{font-size:12px;color:var(--sd-text-color-medium)}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_recent_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.calling_btn_inner{position:relative;width:100%;margin:0;padding:0;display:flex;justify-content:right}.button_recent_call{width:38px;height:38px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center;line-height:normal;border-radius:26px;outline:none;border:none;font-size:22px;font-weight:700;color:#6c0;background:#f1f1f1;border:1px solid #f1f1f1}.container_call_history_not_found{position:absolute;width:100%;height:100%;display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;background:#f8f8f8}.container_call_history_not_found h2{font-size:18px;font-weight:700;letter-spacing:-.65px;color:var(--sd-text-color-dark);text-align:center;padding-top:26px}.container_call_history_not_found p{font-size:12px;line-height:normal;color:var(--sd-text-color);font-weight:600;white-space:normal;text-align:center;padding-top:10px}.icon_round_area_call_history{width:165px;height:75px;background:var(--sd-background-color) url() center no-repeat;border-radius:38px;display:flex;grid-row:1}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i3.DatePipe, name: "date" }] });
|
|
930
1231
|
}
|
|
931
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
1232
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: CallHistoryComponent, decorators: [{
|
|
932
1233
|
type: Component,
|
|
933
|
-
args: [{ selector: 'app-call-history', standalone: false, template: "<div *ngIf=\"showHistoryLoader\">Loading...</div>\n<div class=\"recent_container_outer\">\n <div class=\"recent_options_header\">\n <div class=\"recent_inner\">\n <button class=\"recent_btn\" (click)=\"recentSelectTab('recentCall')\"\n [class.active]=\"recentCallactiveTab === 'recentCall'\">\n Recent\n </button>\n <button class=\"recent_btn\" (click)=\"recentSelectTab('missedCall')\"\n [class.active]=\"recentCallactiveTab === 'missedCall'\">\n Missed Call\n </button>\n </div>\n </div>\n <h2 class=\"recent_heading\">Recent</h2>\n <div class=\"container_recent_search\">\n <input type=\"search\" placeholder=\"Type to search\">\n </div>\n\n <div class=\"recent_tab_container\" *ngIf=\"recentCallactiveTab === 'recentCall' \">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n\n <div class=\"outer_container_recent\" *ngFor=\"let call of callHistory\">\n <div class=\"container_recent_item\">\n <!-- avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner grd1\">\n {{ (call.phoneNumber?.country?.code) | uppercase }}\n </div>\n </div>\n\n <!-- middle -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">{{call.phoneNumber?.normalizedPhoneNumber}}</div>\n\n <div class=\"recent_time_back\" [ngClass]=\"{ missed_call_color: call.status === 'MISSED' }\">\n <!-- use your existing SVGs -->\n {{ call.direction}}\n </div>\n </div>\n\n <!-- right time -->\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">\n {{ call.timestamp | date: 'dd/MM/yyyy' }}\n </span>\n </div>\n </div>\n\n <!-- call button -->\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\" (click)=\"makeCall(call.phoneNumber?.normalizedPhoneNumber)\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- no results -->\n <div *ngIf=\"callHistory.length === 0\" class=\"container_call_history_not_found\">\n <div class=\"icon_round_area_call_history\"></div>\n <h2>No Call History</h2>\n <p>Your call history is empty</p>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"recent_tab_container\" *ngIf=\"recentCallactiveTab === 'missedCall'\">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_recent\">\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">\n R\n </div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\"><svg fill=\"currentColor\" viewBox=\"0 0 640 512\"\n width=\"12px\">\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\" />\n </svg> 9560981960</div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".recent_container_outer{margin:0;padding:0;width:100%;position:relative}.recent_options_header{margin:0;padding:15px 15px 10px;width:100%;text-align:center}.recent_inner{margin:0;padding:0 2px;width:100%;height:32px;background:#f0f0f4;border-radius:8px;display:flex;align-items:center;justify-content:center}.recent_btn{margin:0 1px;padding:0;width:50%;display:flex;align-items:center;justify-content:center;border:none;outline:none;background:#f0f0f4;height:26px;border-radius:8px;color:var(--sd-text-color);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn:hover{background:#e6e6eb;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn.active{color:var(--sd-text-color-dark);background:var(--sd-background-color);font-weight:700}.recent_heading{font-family:var(--sd-text-font-family);font-size:20px;color:var(--sd-text-color-dark);font-weight:700;letter-spacing:-.65px;padding:0 0 15px 15px;line-height:normal;margin:0}.container_recent_search{margin:0 0 15px;padding:0 15px;width:100%}.container_recent_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:39px}.recent_tab_container{margin:0;padding:0;width:100%;height:100%;position:relative}.container_recent_list{width:100%;margin:0;padding:0;position:relative}.container_recent_list_inner{width:100%;position:relative;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:calc(100vh - 204px)}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.outer_container_recent{width:100%;margin:0;padding:0 15px}.container_recent_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;pointer-events:all;border-radius:8px;overflow:hidden;cursor:pointer}.calling_btn{display:none}.container_recent_item:hover .calling_btn{display:block;position:absolute;text-align:right;right:0;width:78px;height:38px;background:var(--sd-background-color)}.container_recent_item_image{display:flex;align-items:center}.container_recent_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400;background:#2a7b9b}.grd1{background:#718ede}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.container_recent_item_left .missed_call_color{color:#e0261f}.container_recent_item_left .recent_time_back{font-size:12px;color:var(--sd-text-color-medium)}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_recent_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.calling_btn_inner{position:relative;width:100%;margin:0;padding:0;display:flex;justify-content:right}.button_recent_call{width:38px;height:38px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center;line-height:normal;border-radius:26px;outline:none;border:none;font-size:22px;font-weight:700;color:#6c0;background:#f1f1f1;border:1px solid #f1f1f1}.container_call_history_not_found{position:absolute;width:100%;height:100%;display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;background:#f8f8f8}.container_call_history_not_found h2{font-size:18px;font-weight:700;letter-spacing:-.65px;color:var(--sd-text-color-dark);text-align:center;padding-top:26px}.container_call_history_not_found p{font-size:12px;line-height:normal;color:var(--sd-text-color);font-weight:600;white-space:normal;text-align:center;padding-top:10px}.icon_round_area_call_history{width:165px;height:75px;background:var(--sd-background-color) url() center no-repeat;border-radius:38px;display:flex;grid-row:1}\n"] }]
|
|
934
|
-
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i8.SnugdeskAuthenticationService }, { type: i0.ChangeDetectorRef }], propDecorators: {
|
|
1234
|
+
args: [{ selector: 'app-call-history', standalone: false, template: "@if (showHistoryLoader) {\n<div>Loading...</div>\n}\n\n<div class=\"recent_container_outer\">\n <div class=\"recent_options_header\">\n <div class=\"recent_inner\">\n <button\n class=\"recent_btn\"\n (click)=\"recentSelectTab('recentCall')\"\n [class.active]=\"recentCallactiveTab === 'recentCall'\"\n >\n Recent\n </button>\n <button\n class=\"recent_btn\"\n (click)=\"recentSelectTab('missedCall')\"\n [class.active]=\"recentCallactiveTab === 'missedCall'\"\n >\n Missed Call\n </button>\n </div>\n </div>\n\n <h2 class=\"recent_heading\">Recent</h2>\n\n <div class=\"container_recent_search\">\n <input type=\"search\" placeholder=\"Type to search\" />\n </div>\n\n @if (recentCallactiveTab === 'recentCall') {\n <div class=\"recent_tab_container\">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n @for (call of callHistory; track $index) {\n <div class=\"outer_container_recent\">\n <div class=\"container_recent_item\">\n <!-- avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner grd1\">\n {{ call.phoneNumber?.country?.code | uppercase }}\n </div>\n </div>\n\n <!-- middle -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">\n {{ call.phoneNumber?.normalizedPhoneNumber }}\n </div>\n\n <div\n class=\"recent_time_back\"\n [ngClass]=\"{\n missed_call_color: call.status === 'MISSED'\n }\"\n >\n <!-- Direction icon (generic handset) -->\n <svg\n viewBox=\"0 0 512 512\"\n width=\"12px\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n {{ call.direction }}\n </div>\n </div>\n\n <!-- right time -->\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">\n {{ call.timestamp | date : \"dd/MM/yyyy\" }}\n </span>\n </div>\n </div>\n\n <!-- call button -->\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <!-- <button\n class=\"button_recent_call\"\n (click)=\"makeCall(call.phoneNumber?.normalizedPhoneNumber)\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button> -->\n\n @if (mode === 'transfer') {\n <button\n class=\"button_recent_call\"\n (click)=\"transferEv.emit(call)\"\n >\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n } @else {\n <button\n class=\"button_recent_call\"\n (click)=\"\n makeCall(call.phoneNumber?.normalizedPhoneNumber)\n \"\n >\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n }\n </div>\n </div>\n </div>\n <!-- /middle -->\n </div>\n </div>\n } @if (callHistory.length === 0) {\n <div class=\"container_call_history_not_found\">\n <div class=\"icon_round_area_call_history\"></div>\n <h2>No Call History</h2>\n <p>Your call history is empty</p>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n </div>\n } @if (recentCallactiveTab === 'missedCall') {\n <div class=\"recent_tab_container\">\n <div class=\"container_recent_list\">\n <div class=\"container_recent_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_recent\">\n <!-- Missed call item 1 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 2 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 3 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 4 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 5 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 6 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 7 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 8 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 9 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Missed call item 10 -->\n <div class=\"container_recent_item\">\n <div class=\"container_recent_item_image\">\n <div class=\"container_recent_item_image_inner\">R</div>\n </div>\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar singh</div>\n <div class=\"recent_time_back missed_call_color\">\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 640 512\"\n width=\"12px\"\n >\n <path\n d=\"M232 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-39 39 58.7 58.7C282.3 152.4 300.8 160 320 160s37.7-7.6 51.3-21.3L503 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L405.3 172.7C382.6 195.3 352 208 320 208s-62.6-12.7-85.3-35.3L176 113.9l-39 39c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2L96 24c0-13.3 10.7-24 24-24L232 0zM51.4 489.9l-35.4-62c-9.7-16.9-8.3-38.1 5.5-51.7C72.6 325.9 178.1 256 320 256s247.4 69.9 298.5 120.2c13.9 13.6 15.2 34.8 5.5 51.7l-35.4 62c-7.4 12.9-22.7 19.1-37 14.8L438.8 470.8c-13.5-4.1-22.8-16.5-22.8-30.6l0-56.2c-62.3-20.8-129.7-20.8-192 0l0 56.2c0 14.1-9.3 26.6-22.8 30.6L88.4 504.7c-14.3 4.3-29.6-1.8-37-14.8z\"\n /></svg\n > 9560981960\n </div>\n </div>\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">13/04/2025</span>\n </div>\n </div>\n <div class=\"calling_btn\">\n <div class=\"calling_btn_inner\">\n <button class=\"button_recent_call\">\n <svg viewBox=\"0 0 512 512\" height=\"15px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- /.outer_container_recent -->\n </div>\n <!-- /.scrollbox-content -->\n </div>\n <!-- /.scrollbox -->\n </div>\n <!-- /.container_recent_list_inner -->\n </div>\n <!-- /.container_recent_list -->\n </div>\n <!-- /.recent_tab_container -->\n }\n</div>\n", styles: [".recent_container_outer{margin:0;padding:0;width:100%;position:relative}.recent_options_header{margin:0;padding:15px 15px 10px;width:100%;text-align:center}.recent_inner{margin:0;padding:0 2px;width:100%;height:32px;background:#f0f0f4;border-radius:8px;display:flex;align-items:center;justify-content:center}.recent_btn{margin:0 1px;padding:0;width:50%;display:flex;align-items:center;justify-content:center;border:none;outline:none;background:#f0f0f4;height:26px;border-radius:8px;color:var(--sd-text-color);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn:hover{background:#e6e6eb;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.recent_btn.active{color:var(--sd-text-color-dark);background:var(--sd-background-color);font-weight:700}.recent_heading{font-family:var(--sd-text-font-family);font-size:20px;color:var(--sd-text-color-dark);font-weight:700;letter-spacing:-.65px;padding:0 0 15px 15px;line-height:normal;margin:0}.container_recent_search{margin:0 0 15px;padding:0 15px;width:100%}.container_recent_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:39px}.recent_tab_container{margin:0;padding:0;width:100%;height:100%;position:relative}.container_recent_list{width:100%;margin:0;padding:0;position:relative}.container_recent_list_inner{width:100%;position:relative;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:calc(100vh - 204px)}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.outer_container_recent{width:100%;margin:0;padding:0 15px}.container_recent_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;pointer-events:all;border-radius:8px;overflow:hidden;cursor:pointer}.calling_btn{display:none}.container_recent_item:hover .calling_btn{display:block;position:absolute;text-align:right;right:0;width:78px;height:38px;background:var(--sd-background-color)}.container_recent_item_image{display:flex;align-items:center}.container_recent_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400;background:#2a7b9b}.grd1{background:#718ede}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.container_recent_item_left .missed_call_color{color:#e0261f}.container_recent_item_left .recent_time_back{font-size:12px;color:var(--sd-text-color-medium)}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_recent_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.calling_btn_inner{position:relative;width:100%;margin:0;padding:0;display:flex;justify-content:right}.button_recent_call{width:38px;height:38px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center;line-height:normal;border-radius:26px;outline:none;border:none;font-size:22px;font-weight:700;color:#6c0;background:#f1f1f1;border:1px solid #f1f1f1}.container_call_history_not_found{position:absolute;width:100%;height:100%;display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;background:#f8f8f8}.container_call_history_not_found h2{font-size:18px;font-weight:700;letter-spacing:-.65px;color:var(--sd-text-color-dark);text-align:center;padding-top:26px}.container_call_history_not_found p{font-size:12px;line-height:normal;color:var(--sd-text-color);font-weight:600;white-space:normal;text-align:center;padding-top:10px}.icon_round_area_call_history{width:165px;height:75px;background:var(--sd-background-color) url() center no-repeat;border-radius:38px;display:flex;grid-row:1}\n"] }]
|
|
1235
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i8.SnugdeskAuthenticationService }, { type: i0.ChangeDetectorRef }], propDecorators: { mode: [{
|
|
1236
|
+
type: Input
|
|
1237
|
+
}], makeCallEv: [{
|
|
1238
|
+
type: Output
|
|
1239
|
+
}], transferEv: [{
|
|
935
1240
|
type: Output
|
|
936
1241
|
}] } });
|
|
937
1242
|
|
|
938
1243
|
class AuthenticationService {
|
|
1244
|
+
jwtHelper = new JwtHelperService();
|
|
939
1245
|
tenant$ = new BehaviorSubject(null);
|
|
940
1246
|
user$ = new BehaviorSubject(null);
|
|
941
|
-
|
|
942
|
-
|
|
1247
|
+
isAuthenticated$ = new BehaviorSubject(false);
|
|
1248
|
+
isAuthenticated() {
|
|
1249
|
+
try {
|
|
1250
|
+
const mySessionToken = this.getAuthSessionToken();
|
|
1251
|
+
// console.log(`Got sessionToken: ${sessionToken}`);
|
|
1252
|
+
if (!mySessionToken) {
|
|
1253
|
+
throw new Error('Session token not found');
|
|
1254
|
+
}
|
|
1255
|
+
else if (this.jwtHelper.isTokenExpired(mySessionToken)) {
|
|
1256
|
+
throw new Error('Session token expired');
|
|
1257
|
+
}
|
|
1258
|
+
this.isAuthenticated$.next(true);
|
|
1259
|
+
return true;
|
|
1260
|
+
}
|
|
1261
|
+
catch (err) {
|
|
1262
|
+
console.warn(err);
|
|
1263
|
+
this.isAuthenticated$.next(false);
|
|
1264
|
+
return false;
|
|
1265
|
+
}
|
|
1266
|
+
}
|
|
1267
|
+
getAuthSessionToken() {
|
|
1268
|
+
return sessionStorage.getItem('auth_sessionToken');
|
|
1269
|
+
}
|
|
1270
|
+
getAuthDomainToken() {
|
|
1271
|
+
return sessionStorage.getItem('auth_domainToken');
|
|
1272
|
+
}
|
|
1273
|
+
getDecodedAuthDomainToken() {
|
|
1274
|
+
const token = this.getAuthDomainToken();
|
|
1275
|
+
return token ? this.jwtHelper.decodeToken(token) : null;
|
|
1276
|
+
}
|
|
1277
|
+
getTenantId() {
|
|
1278
|
+
// return this.getDecodedAuthSessionToken().tenantId;
|
|
1279
|
+
return this.getDecodedAuthDomainToken()?.tenantId;
|
|
1280
|
+
}
|
|
1281
|
+
getDecodedAuthSessionToken() {
|
|
1282
|
+
if (!this.isAuthenticated()) {
|
|
1283
|
+
const err = new Error(`User not authenticated`);
|
|
1284
|
+
err.status = 403;
|
|
1285
|
+
throw err;
|
|
1286
|
+
}
|
|
1287
|
+
const token = this.getAuthSessionToken();
|
|
1288
|
+
if (!token) {
|
|
1289
|
+
const err = new Error(`Token missing`);
|
|
1290
|
+
err.status = 401;
|
|
1291
|
+
throw err;
|
|
1292
|
+
}
|
|
1293
|
+
return this.jwtHelper.decodeToken(token);
|
|
1294
|
+
}
|
|
1295
|
+
getUserId() {
|
|
1296
|
+
return this.getDecodedAuthSessionToken()?.userId;
|
|
1297
|
+
}
|
|
1298
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AuthenticationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1299
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AuthenticationService, providedIn: 'root' });
|
|
943
1300
|
}
|
|
944
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
1301
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AuthenticationService, decorators: [{
|
|
945
1302
|
type: Injectable,
|
|
946
1303
|
args: [{
|
|
947
1304
|
providedIn: 'root',
|
|
@@ -1076,13 +1433,13 @@ class DialpadComponent {
|
|
|
1076
1433
|
this.isRinging = false;
|
|
1077
1434
|
this.audio.pause();
|
|
1078
1435
|
}
|
|
1079
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
1080
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.4", type: DialpadComponent, isStandalone: false, selector: "app-dialpad", inputs: { contacts: "contacts" }, outputs: { makeCallEv: "makeCallEv" }, viewQueries: [{ propertyName: "audioElement", first: true, predicate: ["audioElement"], descendants: true }], ngImport: i0, template: "<div class=\"container_pd_sd\">\n <div class=\"container_phone_number_input\" [formGroup]=\"dialForm\" (ngSubmit)=\"makeCall()\">\n <button class=\"button_phonebook\" *ngIf=\"contacts.length > 0\"\n (click)=\"this.showDirectoryPhonebook = !this.showDirectoryPhonebook\">\n <svg fill=\"currentColor\" height=\"22px\" style=\"enable-background:new 0 0 611.985 611.986;\" version=\"1.1\"\n viewBox=\"0 0 611.985 611.986\" width=\"40.985px\" routerLinkActive=\"active\" xml:space=\"preserve\">\n <g>\n <path d=\"M143.021,158.99c42.525,0,79.456-36.931,79.456-79.456S185.546,0.078,143.021,0.078\n S63.565,37.009,63.565,79.534S100.496,158.99,143.021,158.99z\" fill=\"currentColor\" />\n <path d=\"M278.097,381.467c0-127.13-65.98-190.695-139.048-190.695S0,254.338,0,381.467\n C0,468.583,278.097,468.583,278.097,381.467z\" fill=\"currentColor\" />\n <path d=\"M373.444,220.807c42.525,0,79.456-36.931,79.456-79.456s-36.931-79.456-79.456-79.456\n s-79.456,36.931-79.456,79.456S330.919,220.807,373.444,220.807z\" fill=\"currentColor\" />\n <path d=\"M369.471,252.59c-21.962,0-43.033,6.452-62.071,17.957c11.537,31.051,18.37,67.792,18.37,110.921\n c0,42.843-28.541,76.151-77.517,95.22c60.768,51.424,260.267,40.459,260.267-33.403\n C508.52,316.155,442.539,252.59,369.471,252.59z\" fill=\"currentColor\" />\n </g>\n </svg>\n </button>\n\n <audio id=\"sd_call_ring\" #audioElement></audio>\n<div *ngIf=\"isRinging\" class=\"call_continer\">\n <div class=\"continer_dark_gray slide-right \">\n <div class=\"call_inner\">\n <div class=\"customer_images call_active_animation\">\n <img src=\"../../../assets/images/incomingCall_avatar.gif\" class=\"images_cover\">\n </div>\n <div class=\"customer_name_area\">\n <!-- <span class=\"name_st\">{{this.interaction?.host?.name}}</span> -->\n <span class=\"name_st\">{{incomingCallNumber}}</span>\n <span class=\"short_name_st\">Incoming web call</span>\n </div>\n <div class=\"customer_connect_area_right\">\n <ul>\n <li title=\"Video Call\">\n <button type=\"button\" class=\"decline_icon\" (click)=\"declineAvayaCall()\">\n <svg height=\"17px\" viewBox=\"0 0 640 512\">\n <path class=\"icon_color\" d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg>\n </button>\n </li>\n <li title=\"Hang Up\">\n <button type=\"button\" class=\"answer_call_icon\" (click)=\"acceptAvayaCAll()\">\n <svg height=\"16\" viewBox=\"0 0 512 512\">\n <path class=\"icon_color\" d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </li>\n </ul>\n </div>\n <div class=\"clear\"></div>\n </div>\n </div>\n</div>\n\n <ngx-intl-tel-input formControlName=\"phoneNumber\" name=\"phoneNumber\" [cssClass]=\"'phone_number_sd'\"\n [preferredCountries]=\"['in']\" [customPlaceholder]=\"'Phone Number'\" [enableAutoCountrySelect]=\"false\"\n [enablePlaceholder]=\"false\" [searchCountryFlag]=\"true\"\n [searchCountryField]=\"[SearchCountryField.Iso2, SearchCountryField.Name]\" [selectFirstCountry]=\"false\"\n [selectedCountryISO]=\"CountryISO.India\" [maxLength]=\"15\" [phoneValidation]=\"true\" [separateDialCode]=\"true\"\n (keydown)=\"handleKeyboardInput($event)\">\n </ngx-intl-tel-input>\n <!-- <input type=\"text\" class=\"phone_number_sd\"> -->\n <button class=\"button_backspace\" (click)=\"onClear()\"></button>\n </div>\n</div>\n\n\n <div class=\"container_phonebook\" *ngIf=\"showDirectoryPhonebook\">\n <div class=\"container_phonebook_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <ng-container *ngFor=\"let contact of contacts\">\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ contact.name }}</div>\n <div class=\"contact_field\">{{ contact.phone }}</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1,2,3,4,5]\" [class.filled]=\"star <= (contact.rating || 0)\">\u2605</span>\n </div>\n </span>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n<div class=\"container_dialpad\">\n\n\n <div class=\"container_dialpad_content\">\n <div class=\"container_dialpad_digits\">\n <!-- <div class=\"active-calls-container\"></div> -->\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('6')\"> 6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\" />\n </svg></button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('#')\"><svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg></button>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit button_call_green\" (click)=\"makeCall()\" [disabled]=\"!this.dialForm.valid \"\n [ngClass]=\"{ 'button_call_disabled': !this.dialForm.valid }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".container_pd_sd{width:100%;padding:0 30px;margin:0}.container_dialpad{width:100%;margin:0 auto;padding:32px 0;position:relative;background:var(--sd-background-color);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.container_dialpad_header{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_dialpad_header_inner1{margin:0;width:100%;padding:0 15px;position:relative}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_phone_number_input{width:100%;margin:0;padding:0;position:relative}.container_phone_number_input .phone_number_sd{width:100%;display:flex;height:48px;outline:none;text-align:center;align-items:center;border:1px solid var(--sd-border-color-light);border-radius:27px;font-size:20px;font-weight:400;color:#000;padding:0 50px}.container_phone_number_input .button_phonebook{position:absolute;width:38px;height:38px;background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;border-radius:50%;border:none;outline:none;display:flex;align-items:center;justify-content:center;top:5px;left:8px;color:#a6a6a6}.container_phone_number_input .button_phonebook:hover,.container_phone_number_input .button_phonebook .sec_button{background:#f0f0f0;color:#29abe0}.container_phone_number_input .button_backspace{width:48px;height:48px;display:block;background:url() center no-repeat;position:absolute;right:0;top:0;outline:none;border:none}.container_phonebook{position:absolute;width:100%;left:0;right:0;top:149px;background:var(--sd-background-color);height:386px;overflow:hidden}.container_phonebook_inner{width:100%;position:relative;height:100%;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_content{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding:21px 0 15px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.NgxIntlTelInputComponent, selector: "ngx-intl-tel-input", inputs: ["value", "preferredCountries", "enablePlaceholder", "customPlaceholder", "numberFormat", "cssClass", "onlyCountries", "enableAutoCountrySelect", "searchCountryFlag", "searchCountryField", "searchCountryPlaceholder", "maxLength", "selectFirstCountry", "selectedCountryISO", "phoneValidation", "inputId", "separateDialCode"], outputs: ["countryChange"] }, { kind: "directive", type: i5.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }] });
|
|
1436
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: DialpadComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1$1.FormBuilder }, { token: AvayaIPOService }, { token: AuthenticationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1437
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.9", type: DialpadComponent, isStandalone: false, selector: "app-dialpad", inputs: { contacts: "contacts" }, outputs: { makeCallEv: "makeCallEv" }, viewQueries: [{ propertyName: "audioElement", first: true, predicate: ["audioElement"], descendants: true }], ngImport: i0, template: "<div class=\"container_pd_sd\">\n <div\n class=\"container_phone_number_input\"\n [formGroup]=\"dialForm\"\n (ngSubmit)=\"makeCall()\"\n >\n @if (contacts?.length > 0) {\n <button\n class=\"button_phonebook\"\n (click)=\"showDirectoryPhonebook = !showDirectoryPhonebook\"\n >\n <svg\n fill=\"currentColor\"\n height=\"22px\"\n style=\"enable-background: new 0 0 611.985 611.986\"\n version=\"1.1\"\n viewBox=\"0 0 611.985 611.986\"\n width=\"40.985px\"\n routerLinkActive=\"active\"\n xml:space=\"preserve\"\n >\n <g>\n <path\n d=\"M143.021,158.99c42.525,0,79.456-36.931,79.456-79.456S185.546,0.078,143.021,0.078\n S63.565,37.009,63.565,79.534S100.496,158.99,143.021,158.99z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M278.097,381.467c0-127.13-65.98-190.695-139.048-190.695S0,254.338,0,381.467\n C0,468.583,278.097,468.583,278.097,381.467z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M373.444,220.807c42.525,0,79.456-36.931,79.456-79.456s-36.931-79.456-79.456-79.456\n s-79.456,36.931-79.456,79.456S330.919,220.807,373.444,220.807z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M369.471,252.59c-21.962,0-43.033,6.452-62.071,17.957c11.537,31.051,18.37,67.792,18.37,110.921\n c0,42.843-28.541,76.151-77.517,95.22c60.768,51.424,260.267,40.459,260.267-33.403\n C508.52,316.155,442.539,252.59,369.471,252.59z\"\n fill=\"currentColor\"\n />\n </g>\n </svg>\n </button>\n}\n\n\n <audio id=\"sd_call_ring\" #audioElement></audio>\n @if (isRinging) {\n <div class=\"call_continer\">\n <div class=\"continer_dark_gray slide-right\">\n <div class=\"call_inner\">\n <div class=\"customer_images call_active_animation\">\n <img\n src=\"../../../assets/images/incomingCall_avatar.gif\"\n class=\"images_cover\"\n />\n </div>\n\n <div class=\"customer_name_area\">\n <span class=\"name_st\">{{ incomingCallNumber }}</span>\n <span class=\"short_name_st\">Incoming web call</span>\n </div>\n\n <div class=\"customer_connect_area_right\">\n <ul>\n <li title=\"Video Call\">\n <button\n type=\"button\"\n class=\"decline_icon\"\n (click)=\"declineAvayaCall()\"\n >\n <svg height=\"17px\" viewBox=\"0 0 640 512\">\n <path\n class=\"icon_color\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\"\n />\n </svg>\n </button>\n </li>\n <li title=\"Hang Up\">\n <button\n type=\"button\"\n class=\"answer_call_icon\"\n (click)=\"acceptAvayaCAll()\"\n >\n <svg height=\"16\" viewBox=\"0 0 512 512\">\n <path\n class=\"icon_color\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </li>\n </ul>\n </div>\n\n <div class=\"clear\"></div>\n </div>\n </div>\n </div>\n}\n\n\n <ngx-intl-tel-input\n formControlName=\"phoneNumber\"\n name=\"phoneNumber\"\n [cssClass]=\"'phone_number_sd'\"\n [preferredCountries]=\"['in']\"\n [customPlaceholder]=\"'Phone Number'\"\n [enableAutoCountrySelect]=\"false\"\n [enablePlaceholder]=\"false\"\n [searchCountryFlag]=\"true\"\n [searchCountryField]=\"[SearchCountryField.Iso2, SearchCountryField.Name]\"\n [selectFirstCountry]=\"false\"\n [selectedCountryISO]=\"CountryISO.India\"\n [maxLength]=\"15\"\n [phoneValidation]=\"true\"\n [separateDialCode]=\"true\"\n (keydown)=\"handleKeyboardInput($event)\"\n >\n </ngx-intl-tel-input>\n <!-- <input type=\"text\" class=\"phone_number_sd\"> -->\n <button class=\"button_backspace\" (click)=\"onClear()\"></button>\n </div>\n</div>\n\n@if (showDirectoryPhonebook) {\n <div class=\"container_phonebook\">\n <div class=\"container_phonebook_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n @for (contact of contacts; track contact.id ?? contact.phone ?? $index) {\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg\n viewBox=\"0 0 212 212\"\n height=\"49px\"\n width=\"49px\"\n version=\"1.1\"\n x=\"0px\"\n y=\"0px\"\n enable-background=\"new 0 0 212 212\"\n >\n <path\n fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\"\n ></path>\n <g>\n <path\n fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\"\n ></path>\n <path\n fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\"\n ></path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ contact.name }}</div>\n <div class=\"contact_field\">{{ contact.phone }}</div>\n </div>\n </div>\n\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n @for (star of [1,2,3,4,5]; track star) {\n <span [class.filled]=\"star <= (contact.rating || 0)\">\u2605</span>\n }\n </div>\n </span>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n}\n\n<div class=\"container_dialpad\">\n <div class=\"container_dialpad_content\">\n <div class=\"container_dialpad_digits\">\n <!-- <div class=\"active-calls-container\"></div> -->\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('1')\">\n 1\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('2')\">\n 2\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('3')\">\n 3\n </button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('4')\">\n 4\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('5')\">\n 5\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('6')\">\n 6\n </button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('7')\">\n 7\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('8')\">\n 8\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('9')\">\n 9\n </button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path\n fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\"\n />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('0')\">\n 0\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path\n fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\"\n />\n </svg>\n </button>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <button\n class=\"button_dialpad_digit button_call_green\"\n (click)=\"makeCall()\"\n [disabled]=\"!this.dialForm.valid\"\n [ngClass]=\"{ button_call_disabled: !this.dialForm.valid }\"\n >\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".container_pd_sd{width:100%;padding:0 30px;margin:0}.container_dialpad{width:100%;margin:0 auto;padding:32px 0;position:relative;background:var(--sd-background-color);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.container_dialpad_header{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_dialpad_header_inner1{margin:0;width:100%;padding:0 15px;position:relative}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_phone_number_input{width:100%;margin:0;padding:0;position:relative}.container_phone_number_input .phone_number_sd{width:100%;display:flex;height:48px;outline:none;text-align:center;align-items:center;border:1px solid var(--sd-border-color-light);border-radius:27px;font-size:20px;font-weight:400;color:#000;padding:0 50px}.container_phone_number_input .button_phonebook{position:absolute;width:38px;height:38px;background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;border-radius:50%;border:none;outline:none;display:flex;align-items:center;justify-content:center;top:5px;left:8px;color:#a6a6a6}.container_phone_number_input .button_phonebook:hover,.container_phone_number_input .button_phonebook .sec_button{background:#f0f0f0;color:#29abe0}.container_phone_number_input .button_backspace{width:48px;height:48px;display:block;background:url() center no-repeat;position:absolute;right:0;top:0;outline:none;border:none}.container_phonebook{position:absolute;width:100%;left:0;right:0;top:149px;background:var(--sd-background-color);height:386px;overflow:hidden}.container_phonebook_inner{width:100%;position:relative;height:100%;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_content{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding:21px 0 15px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.NgxIntlTelInputComponent, selector: "ngx-intl-tel-input", inputs: ["value", "preferredCountries", "enablePlaceholder", "customPlaceholder", "numberFormat", "cssClass", "onlyCountries", "enableAutoCountrySelect", "searchCountryFlag", "searchCountryField", "searchCountryPlaceholder", "maxLength", "selectFirstCountry", "selectedCountryISO", "phoneValidation", "inputId", "separateDialCode"], outputs: ["countryChange"] }, { kind: "directive", type: i5.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }] });
|
|
1081
1438
|
}
|
|
1082
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
1439
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: DialpadComponent, decorators: [{
|
|
1083
1440
|
type: Component,
|
|
1084
|
-
args: [{ selector: 'app-dialpad', standalone: false, template: "<div class=\"container_pd_sd\">\n <div class=\"container_phone_number_input\" [formGroup]=\"dialForm\" (ngSubmit)=\"makeCall()\">\n <button class=\"button_phonebook\" *ngIf=\"contacts.length > 0\"\n (click)=\"this.showDirectoryPhonebook = !this.showDirectoryPhonebook\">\n <svg fill=\"currentColor\" height=\"22px\" style=\"enable-background:new 0 0 611.985 611.986;\" version=\"1.1\"\n viewBox=\"0 0 611.985 611.986\" width=\"40.985px\" routerLinkActive=\"active\" xml:space=\"preserve\">\n <g>\n <path d=\"M143.021,158.99c42.525,0,79.456-36.931,79.456-79.456S185.546,0.078,143.021,0.078\n S63.565,37.009,63.565,79.534S100.496,158.99,143.021,158.99z\" fill=\"currentColor\" />\n <path d=\"M278.097,381.467c0-127.13-65.98-190.695-139.048-190.695S0,254.338,0,381.467\n C0,468.583,278.097,468.583,278.097,381.467z\" fill=\"currentColor\" />\n <path d=\"M373.444,220.807c42.525,0,79.456-36.931,79.456-79.456s-36.931-79.456-79.456-79.456\n s-79.456,36.931-79.456,79.456S330.919,220.807,373.444,220.807z\" fill=\"currentColor\" />\n <path d=\"M369.471,252.59c-21.962,0-43.033,6.452-62.071,17.957c11.537,31.051,18.37,67.792,18.37,110.921\n c0,42.843-28.541,76.151-77.517,95.22c60.768,51.424,260.267,40.459,260.267-33.403\n C508.52,316.155,442.539,252.59,369.471,252.59z\" fill=\"currentColor\" />\n </g>\n </svg>\n </button>\n\n <audio id=\"sd_call_ring\" #audioElement></audio>\n<div *ngIf=\"isRinging\" class=\"call_continer\">\n <div class=\"continer_dark_gray slide-right \">\n <div class=\"call_inner\">\n <div class=\"customer_images call_active_animation\">\n <img src=\"../../../assets/images/incomingCall_avatar.gif\" class=\"images_cover\">\n </div>\n <div class=\"customer_name_area\">\n <!-- <span class=\"name_st\">{{this.interaction?.host?.name}}</span> -->\n <span class=\"name_st\">{{incomingCallNumber}}</span>\n <span class=\"short_name_st\">Incoming web call</span>\n </div>\n <div class=\"customer_connect_area_right\">\n <ul>\n <li title=\"Video Call\">\n <button type=\"button\" class=\"decline_icon\" (click)=\"declineAvayaCall()\">\n <svg height=\"17px\" viewBox=\"0 0 640 512\">\n <path class=\"icon_color\" d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg>\n </button>\n </li>\n <li title=\"Hang Up\">\n <button type=\"button\" class=\"answer_call_icon\" (click)=\"acceptAvayaCAll()\">\n <svg height=\"16\" viewBox=\"0 0 512 512\">\n <path class=\"icon_color\" d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </li>\n </ul>\n </div>\n <div class=\"clear\"></div>\n </div>\n </div>\n</div>\n\n <ngx-intl-tel-input formControlName=\"phoneNumber\" name=\"phoneNumber\" [cssClass]=\"'phone_number_sd'\"\n [preferredCountries]=\"['in']\" [customPlaceholder]=\"'Phone Number'\" [enableAutoCountrySelect]=\"false\"\n [enablePlaceholder]=\"false\" [searchCountryFlag]=\"true\"\n [searchCountryField]=\"[SearchCountryField.Iso2, SearchCountryField.Name]\" [selectFirstCountry]=\"false\"\n [selectedCountryISO]=\"CountryISO.India\" [maxLength]=\"15\" [phoneValidation]=\"true\" [separateDialCode]=\"true\"\n (keydown)=\"handleKeyboardInput($event)\">\n </ngx-intl-tel-input>\n <!-- <input type=\"text\" class=\"phone_number_sd\"> -->\n <button class=\"button_backspace\" (click)=\"onClear()\"></button>\n </div>\n</div>\n\n\n <div class=\"container_phonebook\" *ngIf=\"showDirectoryPhonebook\">\n <div class=\"container_phonebook_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <ng-container *ngFor=\"let contact of contacts\">\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ contact.name }}</div>\n <div class=\"contact_field\">{{ contact.phone }}</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1,2,3,4,5]\" [class.filled]=\"star <= (contact.rating || 0)\">\u2605</span>\n </div>\n </span>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n<div class=\"container_dialpad\">\n\n\n <div class=\"container_dialpad_content\">\n <div class=\"container_dialpad_digits\">\n <!-- <div class=\"active-calls-container\"></div> -->\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('6')\"> 6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\" />\n </svg></button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('#')\"><svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg></button>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit button_call_green\" (click)=\"makeCall()\" [disabled]=\"!this.dialForm.valid \"\n [ngClass]=\"{ 'button_call_disabled': !this.dialForm.valid }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".container_pd_sd{width:100%;padding:0 30px;margin:0}.container_dialpad{width:100%;margin:0 auto;padding:32px 0;position:relative;background:var(--sd-background-color);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.container_dialpad_header{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_dialpad_header_inner1{margin:0;width:100%;padding:0 15px;position:relative}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_phone_number_input{width:100%;margin:0;padding:0;position:relative}.container_phone_number_input .phone_number_sd{width:100%;display:flex;height:48px;outline:none;text-align:center;align-items:center;border:1px solid var(--sd-border-color-light);border-radius:27px;font-size:20px;font-weight:400;color:#000;padding:0 50px}.container_phone_number_input .button_phonebook{position:absolute;width:38px;height:38px;background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;border-radius:50%;border:none;outline:none;display:flex;align-items:center;justify-content:center;top:5px;left:8px;color:#a6a6a6}.container_phone_number_input .button_phonebook:hover,.container_phone_number_input .button_phonebook .sec_button{background:#f0f0f0;color:#29abe0}.container_phone_number_input .button_backspace{width:48px;height:48px;display:block;background:url() center no-repeat;position:absolute;right:0;top:0;outline:none;border:none}.container_phonebook{position:absolute;width:100%;left:0;right:0;top:149px;background:var(--sd-background-color);height:386px;overflow:hidden}.container_phonebook_inner{width:100%;position:relative;height:100%;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_content{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding:21px 0 15px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}\n"] }]
|
|
1085
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type:
|
|
1441
|
+
args: [{ selector: 'app-dialpad', standalone: false, template: "<div class=\"container_pd_sd\">\n <div\n class=\"container_phone_number_input\"\n [formGroup]=\"dialForm\"\n (ngSubmit)=\"makeCall()\"\n >\n @if (contacts?.length > 0) {\n <button\n class=\"button_phonebook\"\n (click)=\"showDirectoryPhonebook = !showDirectoryPhonebook\"\n >\n <svg\n fill=\"currentColor\"\n height=\"22px\"\n style=\"enable-background: new 0 0 611.985 611.986\"\n version=\"1.1\"\n viewBox=\"0 0 611.985 611.986\"\n width=\"40.985px\"\n routerLinkActive=\"active\"\n xml:space=\"preserve\"\n >\n <g>\n <path\n d=\"M143.021,158.99c42.525,0,79.456-36.931,79.456-79.456S185.546,0.078,143.021,0.078\n S63.565,37.009,63.565,79.534S100.496,158.99,143.021,158.99z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M278.097,381.467c0-127.13-65.98-190.695-139.048-190.695S0,254.338,0,381.467\n C0,468.583,278.097,468.583,278.097,381.467z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M373.444,220.807c42.525,0,79.456-36.931,79.456-79.456s-36.931-79.456-79.456-79.456\n s-79.456,36.931-79.456,79.456S330.919,220.807,373.444,220.807z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M369.471,252.59c-21.962,0-43.033,6.452-62.071,17.957c11.537,31.051,18.37,67.792,18.37,110.921\n c0,42.843-28.541,76.151-77.517,95.22c60.768,51.424,260.267,40.459,260.267-33.403\n C508.52,316.155,442.539,252.59,369.471,252.59z\"\n fill=\"currentColor\"\n />\n </g>\n </svg>\n </button>\n}\n\n\n <audio id=\"sd_call_ring\" #audioElement></audio>\n @if (isRinging) {\n <div class=\"call_continer\">\n <div class=\"continer_dark_gray slide-right\">\n <div class=\"call_inner\">\n <div class=\"customer_images call_active_animation\">\n <img\n src=\"../../../assets/images/incomingCall_avatar.gif\"\n class=\"images_cover\"\n />\n </div>\n\n <div class=\"customer_name_area\">\n <span class=\"name_st\">{{ incomingCallNumber }}</span>\n <span class=\"short_name_st\">Incoming web call</span>\n </div>\n\n <div class=\"customer_connect_area_right\">\n <ul>\n <li title=\"Video Call\">\n <button\n type=\"button\"\n class=\"decline_icon\"\n (click)=\"declineAvayaCall()\"\n >\n <svg height=\"17px\" viewBox=\"0 0 640 512\">\n <path\n class=\"icon_color\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\"\n />\n </svg>\n </button>\n </li>\n <li title=\"Hang Up\">\n <button\n type=\"button\"\n class=\"answer_call_icon\"\n (click)=\"acceptAvayaCAll()\"\n >\n <svg height=\"16\" viewBox=\"0 0 512 512\">\n <path\n class=\"icon_color\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </li>\n </ul>\n </div>\n\n <div class=\"clear\"></div>\n </div>\n </div>\n </div>\n}\n\n\n <ngx-intl-tel-input\n formControlName=\"phoneNumber\"\n name=\"phoneNumber\"\n [cssClass]=\"'phone_number_sd'\"\n [preferredCountries]=\"['in']\"\n [customPlaceholder]=\"'Phone Number'\"\n [enableAutoCountrySelect]=\"false\"\n [enablePlaceholder]=\"false\"\n [searchCountryFlag]=\"true\"\n [searchCountryField]=\"[SearchCountryField.Iso2, SearchCountryField.Name]\"\n [selectFirstCountry]=\"false\"\n [selectedCountryISO]=\"CountryISO.India\"\n [maxLength]=\"15\"\n [phoneValidation]=\"true\"\n [separateDialCode]=\"true\"\n (keydown)=\"handleKeyboardInput($event)\"\n >\n </ngx-intl-tel-input>\n <!-- <input type=\"text\" class=\"phone_number_sd\"> -->\n <button class=\"button_backspace\" (click)=\"onClear()\"></button>\n </div>\n</div>\n\n@if (showDirectoryPhonebook) {\n <div class=\"container_phonebook\">\n <div class=\"container_phonebook_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n @for (contact of contacts; track contact.id ?? contact.phone ?? $index) {\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg\n viewBox=\"0 0 212 212\"\n height=\"49px\"\n width=\"49px\"\n version=\"1.1\"\n x=\"0px\"\n y=\"0px\"\n enable-background=\"new 0 0 212 212\"\n >\n <path\n fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\"\n ></path>\n <g>\n <path\n fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\"\n ></path>\n <path\n fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\"\n ></path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ contact.name }}</div>\n <div class=\"contact_field\">{{ contact.phone }}</div>\n </div>\n </div>\n\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n @for (star of [1,2,3,4,5]; track star) {\n <span [class.filled]=\"star <= (contact.rating || 0)\">\u2605</span>\n }\n </div>\n </span>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n}\n\n<div class=\"container_dialpad\">\n <div class=\"container_dialpad_content\">\n <div class=\"container_dialpad_digits\">\n <!-- <div class=\"active-calls-container\"></div> -->\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('1')\">\n 1\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('2')\">\n 2\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('3')\">\n 3\n </button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('4')\">\n 4\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('5')\">\n 5\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('6')\">\n 6\n </button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('7')\">\n 7\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('8')\">\n 8\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('9')\">\n 9\n </button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path\n fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\"\n />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('0')\">\n 0\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"handleKeypadInput('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path\n fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\"\n />\n </svg>\n </button>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <button\n class=\"button_dialpad_digit button_call_green\"\n (click)=\"makeCall()\"\n [disabled]=\"!this.dialForm.valid\"\n [ngClass]=\"{ button_call_disabled: !this.dialForm.valid }\"\n >\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path\n fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"\n />\n </svg>\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: [".container_pd_sd{width:100%;padding:0 30px;margin:0}.container_dialpad{width:100%;margin:0 auto;padding:32px 0;position:relative;background:var(--sd-background-color);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center}.container_dialpad_header{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_dialpad_header_inner1{margin:0;width:100%;padding:0 15px;position:relative}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_phone_number_input{width:100%;margin:0;padding:0;position:relative}.container_phone_number_input .phone_number_sd{width:100%;display:flex;height:48px;outline:none;text-align:center;align-items:center;border:1px solid var(--sd-border-color-light);border-radius:27px;font-size:20px;font-weight:400;color:#000;padding:0 50px}.container_phone_number_input .button_phonebook{position:absolute;width:38px;height:38px;background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;border-radius:50%;border:none;outline:none;display:flex;align-items:center;justify-content:center;top:5px;left:8px;color:#a6a6a6}.container_phone_number_input .button_phonebook:hover,.container_phone_number_input .button_phonebook .sec_button{background:#f0f0f0;color:#29abe0}.container_phone_number_input .button_backspace{width:48px;height:48px;display:block;background:url() center no-repeat;position:absolute;right:0;top:0;outline:none;border:none}.container_phonebook{position:absolute;width:100%;left:0;right:0;top:149px;background:var(--sd-background-color);height:386px;overflow:hidden}.container_phonebook_inner{width:100%;position:relative;height:100%;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_content{width:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding:21px 0 15px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}\n"] }]
|
|
1442
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1$1.FormBuilder }, { type: AvayaIPOService }, { type: AuthenticationService }], propDecorators: { contacts: [{
|
|
1086
1443
|
type: Input
|
|
1087
1444
|
}], makeCallEv: [{
|
|
1088
1445
|
type: Output
|
|
@@ -1143,12 +1500,12 @@ class DeviceSelectorComponent {
|
|
|
1143
1500
|
trackByDeviceId(index, device) {
|
|
1144
1501
|
return device.deviceId;
|
|
1145
1502
|
}
|
|
1146
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
1147
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
1503
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: DeviceSelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
1504
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.9", type: DeviceSelectorComponent, isStandalone: false, selector: "app-device-selector", inputs: { selectedAudioInputId: "selectedAudioInputId", selectedAudioOutputId: "selectedAudioOutputId" }, outputs: { change: "change" }, ngImport: i0, template: "<div class=\"sd_container_device_selector\">\n <h2 class=\"sd_tab_heading\">Preferences</h2>\n\n <div class=\"sd_tab_content\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"sd_tab_pd_sd\">\n <h3>Audio settings</h3>\n\n <div class=\"sd_container_selector_item\">\n <label for=\"audioInputSelect\">\n Microphone<br />\n <p>The device used to capture your voice</p>\n </label>\n\n <div class=\"sd_container_item_input\">\n <div class=\"sd_container_item_icon\">\n <svg width=\"14px\" viewBox=\"0 0 384 512\">\n <path\n d=\"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l144 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128S64 326.7 64 256l0-40z\"\n />\n </svg>\n </div>\n\n <select\n id=\"audioInputSelect\"\n [(ngModel)]=\"selectedAudioInputId\"\n (change)=\"onMicChange(selectedAudioInputId)\"\n >\n @for (mic of audioInputs; track mic.deviceId; let i = $index) {\n <option [value]=\"mic.deviceId\">\n {{ mic.label || \"Microphone \" + (i + 1) }}\n </option>\n } @empty {\n <option disabled>No microphones found</option>\n }\n </select>\n </div>\n </div>\n\n <div class=\"sd_container_selector_item\">\n <label for=\"audioOutputSelect\">\n Speakers<br />\n <p>The device that rings when you get a call.</p>\n </label>\n\n <div class=\"sd_container_item_input\">\n <div class=\"sd_container_item_icon\">\n <svg width=\"21px\" viewBox=\"0 0 576 512\">\n <path\n d=\"M333.1 34.8C344.6 40 352 51.4 352 64l0 384c0 12.6-7.4 24-18.9 29.2s-25 3.1-34.4-5.3L163.8 352 96 352c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l67.8 0L298.7 40.1c9.4-8.4 22.9-10.4 34.4-5.3zm172 72.2c43.2 35.2 70.9 88.9 70.9 149s-27.7 113.8-70.9 149c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C507.3 341.3 528 301.1 528 256s-20.7-85.3-53.2-111.8c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zm-60.5 74.5C466.1 199.1 480 225.9 480 256s-13.9 56.9-35.4 74.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C425.1 284.4 432 271 432 256s-6.9-28.4-17.7-37.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5z\"\n />\n </svg>\n </div>\n\n <select\n id=\"audioOutputSelect\"\n [(ngModel)]=\"selectedAudioOutputId\"\n (change)=\"onSpeakerChange(selectedAudioOutputId)\"\n >\n @for (spk of audioOutputs; track spk.deviceId; let i = $index) {\n <option [value]=\"spk.deviceId\">\n {{ spk.label || \"Speaker \" + (i + 1) }}\n </option>\n } @empty {\n <option disabled>No speakers found</option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".sd_container_device_selector{margin:0;padding:15px 0 0;width:100%;position:relative}.sd_tab_heading{font-family:var(--sd-text-font-family);font-size:20px;color:var(--sd-text-color-dark);font-weight:700;letter-spacing:-.65px;padding:0 0 15px 15px;line-height:normal;margin:0}.sd_tab_content{margin:0;padding:0 0 15px;width:100%;position:relative;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:calc(100vh - 108px)}.sd_tab_pd_sd{margin:0;padding:0 15px;width:100%}.sd_tab_content h3{font-family:var(--sd-text-font-family);font-size:16px;color:var(--sd-text-color-dark);letter-spacing:-.26px;font-weight:700;padding-bottom:10px}.sd_container_selector_item{width:100%;background:var(--sd-background-color);border-radius:8px;padding:15px;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;margin-bottom:15px;position:relative}.sd_container_selector_item label{font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;display:block;color:var(--sd-text-color-dark);margin-bottom:8px}.sd_container_selector_item label p{font-size:12px;color:var(--sd-text-color-medium);margin:4px 0 0;line-height:1.4}.sd_container_selector_item select{font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;display:block;color:var(--sd-text-color);width:100%;border:1px solid var(--sd-border-color-dark);padding:12px 8px 12px 63px;border-radius:4px;outline:none;position:relative;box-sizing:border-box}.sd_container_item_input{margin:0;padding:0;width:100%;position:relative}.sd_container_item_icon{position:absolute;width:54px;height:44px;display:flex;align-items:center;justify-content:center;background:#f1f1f1;top:1px;left:1px;border-bottom-left-radius:3px;border-top-left-radius:3px;z-index:9}\n"], dependencies: [{ kind: "directive", type: i1$1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1$1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }] });
|
|
1148
1505
|
}
|
|
1149
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
1506
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: DeviceSelectorComponent, decorators: [{
|
|
1150
1507
|
type: Component,
|
|
1151
|
-
args: [{ selector: 'app-device-selector', standalone: false, template: "<div class=\"sd_container_device_selector\">\n <h2 class=\"sd_tab_heading\">Preferences</h2>\n\n <div class=\"sd_tab_content\">\n
|
|
1508
|
+
args: [{ selector: 'app-device-selector', standalone: false, template: "<div class=\"sd_container_device_selector\">\n <h2 class=\"sd_tab_heading\">Preferences</h2>\n\n <div class=\"sd_tab_content\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"sd_tab_pd_sd\">\n <h3>Audio settings</h3>\n\n <div class=\"sd_container_selector_item\">\n <label for=\"audioInputSelect\">\n Microphone<br />\n <p>The device used to capture your voice</p>\n </label>\n\n <div class=\"sd_container_item_input\">\n <div class=\"sd_container_item_icon\">\n <svg width=\"14px\" viewBox=\"0 0 384 512\">\n <path\n d=\"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l144 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128S64 326.7 64 256l0-40z\"\n />\n </svg>\n </div>\n\n <select\n id=\"audioInputSelect\"\n [(ngModel)]=\"selectedAudioInputId\"\n (change)=\"onMicChange(selectedAudioInputId)\"\n >\n @for (mic of audioInputs; track mic.deviceId; let i = $index) {\n <option [value]=\"mic.deviceId\">\n {{ mic.label || \"Microphone \" + (i + 1) }}\n </option>\n } @empty {\n <option disabled>No microphones found</option>\n }\n </select>\n </div>\n </div>\n\n <div class=\"sd_container_selector_item\">\n <label for=\"audioOutputSelect\">\n Speakers<br />\n <p>The device that rings when you get a call.</p>\n </label>\n\n <div class=\"sd_container_item_input\">\n <div class=\"sd_container_item_icon\">\n <svg width=\"21px\" viewBox=\"0 0 576 512\">\n <path\n d=\"M333.1 34.8C344.6 40 352 51.4 352 64l0 384c0 12.6-7.4 24-18.9 29.2s-25 3.1-34.4-5.3L163.8 352 96 352c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l67.8 0L298.7 40.1c9.4-8.4 22.9-10.4 34.4-5.3zm172 72.2c43.2 35.2 70.9 88.9 70.9 149s-27.7 113.8-70.9 149c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C507.3 341.3 528 301.1 528 256s-20.7-85.3-53.2-111.8c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zm-60.5 74.5C466.1 199.1 480 225.9 480 256s-13.9 56.9-35.4 74.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C425.1 284.4 432 271 432 256s-6.9-28.4-17.7-37.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5z\"\n />\n </svg>\n </div>\n\n <select\n id=\"audioOutputSelect\"\n [(ngModel)]=\"selectedAudioOutputId\"\n (change)=\"onSpeakerChange(selectedAudioOutputId)\"\n >\n @for (spk of audioOutputs; track spk.deviceId; let i = $index) {\n <option [value]=\"spk.deviceId\">\n {{ spk.label || \"Speaker \" + (i + 1) }}\n </option>\n } @empty {\n <option disabled>No speakers found</option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".sd_container_device_selector{margin:0;padding:15px 0 0;width:100%;position:relative}.sd_tab_heading{font-family:var(--sd-text-font-family);font-size:20px;color:var(--sd-text-color-dark);font-weight:700;letter-spacing:-.65px;padding:0 0 15px 15px;line-height:normal;margin:0}.sd_tab_content{margin:0;padding:0 0 15px;width:100%;position:relative;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:calc(100vh - 108px)}.sd_tab_pd_sd{margin:0;padding:0 15px;width:100%}.sd_tab_content h3{font-family:var(--sd-text-font-family);font-size:16px;color:var(--sd-text-color-dark);letter-spacing:-.26px;font-weight:700;padding-bottom:10px}.sd_container_selector_item{width:100%;background:var(--sd-background-color);border-radius:8px;padding:15px;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;margin-bottom:15px;position:relative}.sd_container_selector_item label{font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;display:block;color:var(--sd-text-color-dark);margin-bottom:8px}.sd_container_selector_item label p{font-size:12px;color:var(--sd-text-color-medium);margin:4px 0 0;line-height:1.4}.sd_container_selector_item select{font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;display:block;color:var(--sd-text-color);width:100%;border:1px solid var(--sd-border-color-dark);padding:12px 8px 12px 63px;border-radius:4px;outline:none;position:relative;box-sizing:border-box}.sd_container_item_input{margin:0;padding:0;width:100%;position:relative}.sd_container_item_icon{position:absolute;width:54px;height:44px;display:flex;align-items:center;justify-content:center;background:#f1f1f1;top:1px;left:1px;border-bottom-left-radius:3px;border-top-left-radius:3px;z-index:9}\n"] }]
|
|
1152
1509
|
}], propDecorators: { selectedAudioInputId: [{
|
|
1153
1510
|
type: Input
|
|
1154
1511
|
}], selectedAudioOutputId: [{
|
|
@@ -1239,6 +1596,32 @@ class AvayaIPOWidgetComponent {
|
|
|
1239
1596
|
showInitLoader = false;
|
|
1240
1597
|
tenant;
|
|
1241
1598
|
user;
|
|
1599
|
+
internalContacts = [
|
|
1600
|
+
{ id: 1, name: 'Lovish Snug', phone: '6283675354', role: 'Agent', ext: '8002' },
|
|
1601
|
+
{ id: 2, name: 'Rakesh Kumar', phone: '(888) 9876549', role: 'Administrator', ext: '3005' },
|
|
1602
|
+
{ id: 3, name: 'Sohan Singh', phone: '(876) 8800965', role: 'Manager', ext: '3005' },
|
|
1603
|
+
{ id: 4, name: 'Pardeep Mishra', phone: '(876) 8800965', role: 'Agent', ext: '3005' },
|
|
1604
|
+
{ id: 5, name: 'Varun Ji', phone: '(876) 8800965', role: 'Manager', ext: '3005' }
|
|
1605
|
+
];
|
|
1606
|
+
directoryContacts = [
|
|
1607
|
+
{ id: 101, name: 'Rajeev Kumar Singh', phone: '(654) 9876549', rating: 4 },
|
|
1608
|
+
{ id: 102, name: 'Amit Sharma', phone: '(987) 6543210', rating: 5 },
|
|
1609
|
+
{ id: 103, name: 'Sunita Verma', phone: '(765) 4321987', rating: 3 }
|
|
1610
|
+
];
|
|
1611
|
+
recognition;
|
|
1612
|
+
transcriptText = '';
|
|
1613
|
+
showTranscriptionPopup = false;
|
|
1614
|
+
recognitionKeepAlive;
|
|
1615
|
+
transcriptHistory = [];
|
|
1616
|
+
recognitionActive = false;
|
|
1617
|
+
transcriptSegments = []; // final lines w/ timestamps
|
|
1618
|
+
transcriptStartedAt = 0;
|
|
1619
|
+
transcriptEndedAt = 0;
|
|
1620
|
+
autoDownloadSummaryOnEnd = true; // toggle if you want auto-download
|
|
1621
|
+
summaryText = '';
|
|
1622
|
+
displayCallingNumber;
|
|
1623
|
+
redialnumber;
|
|
1624
|
+
isTransferring = false;
|
|
1242
1625
|
constructor(http, cdr, zone, formBuilder, countryService, phoneNumberLookupService, avayaIPOService, recordingManagerService, callSocket, authenticationService, tenantService, userService) {
|
|
1243
1626
|
this.http = http;
|
|
1244
1627
|
this.cdr = cdr;
|
|
@@ -1264,6 +1647,14 @@ class AvayaIPOWidgetComponent {
|
|
|
1264
1647
|
});
|
|
1265
1648
|
}
|
|
1266
1649
|
async ngOnInit() {
|
|
1650
|
+
if (!('serviceWorker' in navigator)) {
|
|
1651
|
+
// Service Worker isn't supported on this browser, disable or hide UI.
|
|
1652
|
+
return;
|
|
1653
|
+
}
|
|
1654
|
+
if (!('PushManager' in window)) {
|
|
1655
|
+
// Push isn't supported on this browser, disable or hide UI.
|
|
1656
|
+
return;
|
|
1657
|
+
}
|
|
1267
1658
|
this.loadScript('https://snugdesk-assets.s3.us-east-1.amazonaws.com/js/awl.min.js').then(() => {
|
|
1268
1659
|
this.avayaIPOService.init();
|
|
1269
1660
|
});
|
|
@@ -1323,6 +1714,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1323
1714
|
console.debug('Got Avaya IPO Login response: ', response);
|
|
1324
1715
|
if (!response) {
|
|
1325
1716
|
this.showLoginForm = true;
|
|
1717
|
+
this.cdr.detectChanges();
|
|
1326
1718
|
// this.hasAvayaDeviceError = true;
|
|
1327
1719
|
return;
|
|
1328
1720
|
}
|
|
@@ -1443,6 +1835,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1443
1835
|
this.currentActiveCallIndex = idx;
|
|
1444
1836
|
this.avayaIPOService.agentBusy();
|
|
1445
1837
|
this.handleCallConnect();
|
|
1838
|
+
this.cdr.detectChanges();
|
|
1446
1839
|
break;
|
|
1447
1840
|
case CallState.DISCONNECTED:
|
|
1448
1841
|
console.log(this.disconnecttriggered);
|
|
@@ -1568,15 +1961,18 @@ class AvayaIPOWidgetComponent {
|
|
|
1568
1961
|
this.avayaIPOService.logOut();
|
|
1569
1962
|
}
|
|
1570
1963
|
async makeCall(phoneNumber) {
|
|
1964
|
+
this.redialnumber = phoneNumber;
|
|
1571
1965
|
console.log('phone number passed', phoneNumber);
|
|
1572
1966
|
this.isCalling = true;
|
|
1967
|
+
this.displayCallingNumber = phoneNumber;
|
|
1573
1968
|
this.showActiveCall = true;
|
|
1574
1969
|
this.cdr.detectChanges();
|
|
1575
|
-
const initPhoneNumber = phoneNumber.replace(/\s+/g, '');
|
|
1576
1970
|
if (!phoneNumber) {
|
|
1577
1971
|
alert('Please enter a number to call.');
|
|
1972
|
+
this.isCalling = false;
|
|
1578
1973
|
return;
|
|
1579
1974
|
}
|
|
1975
|
+
const initPhoneNumber = phoneNumber.replace(/\s+/g, '');
|
|
1580
1976
|
this.lookupPhoneNumber = await this.getLookupPhoneNumber(phoneNumber);
|
|
1581
1977
|
console.log('lookupPhoneNumber: ', this.lookupPhoneNumber);
|
|
1582
1978
|
this.phoneNumber = this.lookupPhoneNumber?.lookupPhoneNumber?.['local-number']?.replace(/\s+/g, '');
|
|
@@ -1591,30 +1987,38 @@ class AvayaIPOWidgetComponent {
|
|
|
1591
1987
|
const alreadyExists = this.activeCalls.some((c) => c.phoneNumber === phoneNumber);
|
|
1592
1988
|
if (alreadyExists) {
|
|
1593
1989
|
console.warn('Call already in progress for this number.');
|
|
1990
|
+
this.isCalling = false;
|
|
1594
1991
|
return;
|
|
1595
1992
|
}
|
|
1596
1993
|
const dataToSend = '*************custom data in sdp*************';
|
|
1597
|
-
|
|
1598
|
-
|
|
1599
|
-
|
|
1994
|
+
try {
|
|
1995
|
+
// 🔴 FIX: await the Promise returned by the service
|
|
1996
|
+
const slot = await this.avayaIPOService.makeCallWithCustomData(this.phoneNumber, dataToSend);
|
|
1997
|
+
if (!slot) {
|
|
1998
|
+
console.warn('Could not place call: no free slot or call failed to start.');
|
|
1999
|
+
this.isCalling = false;
|
|
2000
|
+
return;
|
|
2001
|
+
}
|
|
2002
|
+
this.activeCalls.push({
|
|
2003
|
+
callId: this.avayaIPOService.activeCallId,
|
|
2004
|
+
phoneNumber,
|
|
2005
|
+
lookupPhoneNumber: this.lookupPhoneNumber,
|
|
2006
|
+
duration: 0,
|
|
2007
|
+
isMuted: false,
|
|
2008
|
+
isOnHold: false,
|
|
2009
|
+
startTime: Date.now(),
|
|
2010
|
+
slot, // ✅ now a "1" | "2" | "3" value, not a Promise
|
|
2011
|
+
});
|
|
2012
|
+
this.currentActiveCallIndex = this.activeCalls.length - 1;
|
|
2013
|
+
this.noOfCalls = this.activeCalls.length;
|
|
2014
|
+
this.avayaIPOService.agentBusy();
|
|
2015
|
+
this.isCallingFromContact = false;
|
|
2016
|
+
this.isAddingNewCall = false;
|
|
2017
|
+
}
|
|
2018
|
+
catch (err) {
|
|
2019
|
+
console.error('Failed to start call:', err);
|
|
1600
2020
|
this.isCalling = false;
|
|
1601
|
-
return;
|
|
1602
2021
|
}
|
|
1603
|
-
this.activeCalls.push({
|
|
1604
|
-
callId: this.avayaIPOService.activeCallId,
|
|
1605
|
-
phoneNumber,
|
|
1606
|
-
lookupPhoneNumber: this.lookupPhoneNumber,
|
|
1607
|
-
duration: 0,
|
|
1608
|
-
isMuted: false,
|
|
1609
|
-
isOnHold: false,
|
|
1610
|
-
startTime: Date.now(),
|
|
1611
|
-
slot, // store the slot returned
|
|
1612
|
-
});
|
|
1613
|
-
this.currentActiveCallIndex = this.activeCalls.length - 1;
|
|
1614
|
-
this.noOfCalls = this.activeCalls.length;
|
|
1615
|
-
this.avayaIPOService.agentBusy();
|
|
1616
|
-
this.isCallingFromContact = false;
|
|
1617
|
-
this.isAddingNewCall = false;
|
|
1618
2022
|
}
|
|
1619
2023
|
async makeCallFromContact(phoneNumber) {
|
|
1620
2024
|
this.isCallingFromContact = true;
|
|
@@ -1794,6 +2198,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1794
2198
|
return lastValueFrom(this.http.get('https://search.snugdesk.com/entities?' + queryString));
|
|
1795
2199
|
}
|
|
1796
2200
|
handleCallConnect() {
|
|
2201
|
+
console.log("handle call connect ----------------------------");
|
|
1797
2202
|
const active = this.activeCalls[this.currentActiveCallIndex];
|
|
1798
2203
|
if (!active)
|
|
1799
2204
|
return;
|
|
@@ -1804,18 +2209,28 @@ class AvayaIPOWidgetComponent {
|
|
|
1804
2209
|
callId,
|
|
1805
2210
|
phoneNumber,
|
|
1806
2211
|
};
|
|
2212
|
+
this.callSocket.open(callMetadata);
|
|
1807
2213
|
// Update UI and call state
|
|
1808
2214
|
this.startTimer(this.currentActiveCallIndex);
|
|
1809
2215
|
this.isRinging = false;
|
|
1810
2216
|
this.isactiveCall = true;
|
|
2217
|
+
console.log("this.isactiveCall = ", this.isactiveCall);
|
|
1811
2218
|
this.isCalling = false;
|
|
1812
2219
|
this.showActiveCall = true;
|
|
2220
|
+
this.cdr.detectChanges();
|
|
1813
2221
|
const local = this.lastLocalStream || undefined;
|
|
1814
2222
|
const remote = this.lastRemoteStream || undefined;
|
|
1815
2223
|
const hasAudio = (stream) => stream instanceof MediaStream && stream.getAudioTracks().length > 0;
|
|
1816
2224
|
if (hasAudio(remote) && hasAudio(local)) {
|
|
1817
2225
|
console.debug(`[${callId}] Starting recording with available local & remote streams`);
|
|
1818
2226
|
this.recordingManagerService.startRecording(local, remote, callMetadata);
|
|
2227
|
+
this.initTranscription();
|
|
2228
|
+
this.recognition.start();
|
|
2229
|
+
this.showTranscriptionPopup = true;
|
|
2230
|
+
this.transcriptSegments = [];
|
|
2231
|
+
this.transcriptHistory = [];
|
|
2232
|
+
this.transcriptText = '';
|
|
2233
|
+
this.transcriptStartedAt = Date.now();
|
|
1819
2234
|
return;
|
|
1820
2235
|
}
|
|
1821
2236
|
console.debug(`[${callId}] Waiting for remote stream...`);
|
|
@@ -1826,6 +2241,13 @@ class AvayaIPOWidgetComponent {
|
|
|
1826
2241
|
const freshLocal = this.avayaIPOService.localStream;
|
|
1827
2242
|
console.debug(`[${callId}] Remote stream received! Starting recording.`);
|
|
1828
2243
|
this.recordingManagerService.startRecording(freshLocal, freshRemote, callMetadata);
|
|
2244
|
+
this.initTranscription();
|
|
2245
|
+
this.recognition.start();
|
|
2246
|
+
this.showTranscriptionPopup = true;
|
|
2247
|
+
this.transcriptSegments = [];
|
|
2248
|
+
this.transcriptHistory = [];
|
|
2249
|
+
this.transcriptText = '';
|
|
2250
|
+
this.transcriptStartedAt = Date.now();
|
|
1829
2251
|
remoteStreamSubscription.unsubscribe(); // stop listening after the first hit
|
|
1830
2252
|
},
|
|
1831
2253
|
error: (err) => {
|
|
@@ -1850,7 +2272,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1850
2272
|
const callId = this.activeCalls[this.currentActiveCallIndex].callId;
|
|
1851
2273
|
this.recordingManagerService.stopRecording(disconnectingCall.callId);
|
|
1852
2274
|
console.log('***********stopping recording in disconnect***********');
|
|
1853
|
-
this.callSocket.close();
|
|
2275
|
+
this.callSocket.close(callId);
|
|
1854
2276
|
// const callData = {
|
|
1855
2277
|
// tenantId: this.tenantId,
|
|
1856
2278
|
// agentId: this.extensionNumber,
|
|
@@ -1934,6 +2356,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1934
2356
|
this.isRinging = false;
|
|
1935
2357
|
console.log('handleCallDisconnect() done. new active index =', this.currentActiveCallIndex);
|
|
1936
2358
|
console.log('active call div decider ', this.showActiveCall);
|
|
2359
|
+
this.stopTranscription(disconnectingCall.callId);
|
|
1937
2360
|
}
|
|
1938
2361
|
goToDiv(div) {
|
|
1939
2362
|
this.currentView = div;
|
|
@@ -1963,7 +2386,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1963
2386
|
this.redialTimeout = null;
|
|
1964
2387
|
}
|
|
1965
2388
|
this.isCalling = true;
|
|
1966
|
-
this.makeCall(this.
|
|
2389
|
+
this.makeCall(this.redialnumber);
|
|
1967
2390
|
}
|
|
1968
2391
|
swapLinesToIndex(index) {
|
|
1969
2392
|
const slotMap = ['1', '2', '3'];
|
|
@@ -1989,7 +2412,7 @@ class AvayaIPOWidgetComponent {
|
|
|
1989
2412
|
this.avayaIPOService.mergeCall();
|
|
1990
2413
|
}
|
|
1991
2414
|
onAddCall() {
|
|
1992
|
-
this.isCallTransferOpen =
|
|
2415
|
+
this.isCallTransferOpen = false;
|
|
1993
2416
|
this.isAddingNewCall = true;
|
|
1994
2417
|
// this.dialForm.reset();
|
|
1995
2418
|
}
|
|
@@ -2022,8 +2445,244 @@ class AvayaIPOWidgetComponent {
|
|
|
2022
2445
|
videoInputID: event.videoInputId || undefined,
|
|
2023
2446
|
});
|
|
2024
2447
|
}
|
|
2025
|
-
|
|
2026
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.4", type: AvayaIPOWidgetComponent, isStandalone: false, selector: "snugdesk-avaya-ipo-widget", inputs: { tenantId: "tenantId", userId: "userId", isVisible: "isVisible", containerHeightObservable: "containerHeightObservable", containerWidthObservable: "containerWidthObservable" }, outputs: { notificationEvent: "notificationEvent" }, ngImport: i0, template: "<div class=\"container_connection_status_overlay\"\n *ngIf=\"isReconnectingInProgress || isFailoverInProgress || isFailbackInProgress\">\n <div class=\"container_connection_status\">\n <i class=\"fa-solid fa-circle-dot\"></i>\n <ng-container *ngIf=\"isReconnectingInProgress\">\n <span>Reconnecting to the server...</span>\n </ng-container>\n\n <ng-container *ngIf=\"isFailoverInProgress\">\n <span>Failover in progress...</span>\n </ng-container>\n\n <ng-container *ngIf=\"isFailbackInProgress\">\n <span>Failback in progress...</span>\n </ng-container>\n <div class=\"container_connection_status_loader\">\n <div class=\"container_three_dot_loader\">\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n </div>\n </div>\n </div>\n</div>\n\n<ng-container *ngIf=\"showLoginForm else showSoftphoneDiv\">\n <div class=\"container_avaya_login\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_avaya_login_inner\">\n <div class=\"container_avaya_login_content\">\n\n <div class=\"container_avaya_logo\">\n <div class=\"container_avaya_logo_image\"></div>\n <h3>IP Office<span>TM</span></h3>\n </div>\n\n <div class=\"container_avaya_login_error\"\n *ngIf=\"hasAvayaSocketError || hasAvayaLoginError || hasAvayaLoginConflictError || hasAvayaDeviceError\">\n <p class=\"message_label error_message\">\n <ng-container *ngIf=\"hasAvayaSocketError\">\n We're having trouble connecting to the server\n </ng-container>\n <ng-container *ngIf=\"hasAvayaLoginError\">\n Invalid extension or password!\n </ng-container>\n <ng-container *ngIf=\"hasAvayaLoginConflictError\">\n Another user is logged in with this extension\n </ng-container>\n <ng-container *ngIf=\"hasAvayaDeviceError\">\n We're having trouble accessing your device\n </ng-container>\n </p>\n </div>\n\n <div class=\"container_avaya_login_form\">\n <form [formGroup]=\"loginForm\" (ngSubmit)=\"onLogin()\">\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Extension</mat-label>\n <input matInput formControlName=\"ipoExtensionNo\" autocomplete=\"ipoExtensionNo\"\n (keypress)=\"restrictNumeric($event)\" />\n <mat-error\n *ngIf=\"loginForm.controls['ipoExtensionNo'].invalid && loginForm.controls['ipoExtensionNo'].touched\">\n <small *ngIf=\"loginForm.controls['ipoExtensionNo'].errors?.['required']\">\n Extension is required.\n </small>\n </mat-error>\n </mat-form-field>\n </div>\n\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Password</mat-label>\n <input matInput formControlName=\"ipoPassword\" autocomplete=\"avaya-ipo-password\"\n (keypress)=\"restrictNumeric($event)\" [type]=\"showLoginPassword ? 'text' : 'password'\" />\n <mat-icon matSuffix (click)=\"showLoginPassword = !showLoginPassword && !hasAvayaSocketError\">\n <ng-container *ngIf=\"showLoginPassword else hideAvayaIPOPassword\">\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye\"></i>\n </span>\n </ng-container>\n <ng-template #hideAvayaIPOPassword>\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye-slash\"></i>\n </span>\n </ng-template>\n </mat-icon>\n <mat-error\n *ngIf=\"loginForm.controls['ipoPassword'].invalid && loginForm.controls['ipoPassword'].touched\">\n <small *ngIf=\"loginForm.controls['ipoPassword'].errors?.['required']\">\n Password is required.\n </small>\n </mat-error>\n </mat-form-field>\n </div>\n\n <div class=\"avaya_login_button_area\">\n <button type=\"submit\" class=\"button_submit_login\"\n [ngClass]=\"{ 'button_submit_login_loader': showLoginLoader }\" [disabled]=\"showLoginLoader\">\n <span *ngIf=\"showLoginLoader else showLoginButton\">\n <span class=\"button_submit_loader\"></span>\n </span>\n <ng-template #showLoginButton>\n <span>Login</span>\n </ng-template>\n </button>\n </div>\n </form>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_avaya_footer\">© 2025 SNUG Technologies Pvt. Ltd.</div>\n</ng-container>\n\n<ng-template #showSoftphoneDiv>\n\n <ng-container *ngIf=\"!showActiveCall else showActiveCallDiv\">\n\n <div class=\"container_avaya_softphone_inner\">\n <!-- ------------------- Keypad work start ---------- -->\n <div class=\"tab-content_sd\" *ngIf=\"bottomActiveTab === 'keypad_sd'\">\n <div class=\"container_dialpad_header\">\n <div class=\"container_dialpad_header_inner2\">\n <div class=\"container_avaya_extension\">\n <div class=\"container_avaya_extension_left\">\n <div class=\"extension_label\">Extension</div>\n <div class=\"extension_number\">{{ extensionNumber }}</div>\n </div>\n <div class=\"container_avaya_extension_right\">\n <button title=\"Sign out\" (click)=\"onLogout()\">\n <svg width=\"16px\" fill=\"currentColor\" viewBox=\"0 0 512 512\">\n <path\n d=\"M377.9 105.9L500.7 228.7c7.2 7.2 11.3 17.1 11.3 27.3s-4.1 20.1-11.3 27.3L377.9 406.1c-6.4 6.4-15 9.9-24 9.9c-18.7 0-33.9-15.2-33.9-33.9l0-62.1-128 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l128 0 0-62.1c0-18.7 15.2-33.9 33.9-33.9c9 0 17.6 3.6 24 9.9zM160 96L96 96c-17.7 0-32 14.3-32 32l0 256c0 17.7 14.3 32 32 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-53 0-96-43-96-96L0 128C0 75 43 32 96 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"dialpad_container_sd\">\n<div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n<app-dialpad [contacts]=\"contacts\" (makeCallEv)=\"makeCall($event)\"></app-dialpad>\n<!-- to do list -->\n </div>\n</div>\n\n\n\n\n\n </div>\n\n </div>\n <!-- ------------------- Keypad work end ---------- -->\n\n <div class=\"tab-content_sd\" *ngIf=\"bottomActiveTab === 'recent_sd'\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div>\n\n <div class=\"tab-content_sd\" *ngIf=\"bottomActiveTab === 'settings_sd'\">\n <app-device-selector (change)=\"handleDeviceSelection($event)\"></app-device-selector>\n </div>\n </div>\n\n\n\n <div class=\"tabs_sd\">\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('recent_sd')\"\n [class.active]=\"bottomActiveTab === 'recent_sd'\">\n <span class=\"nav_icon\"><svg width=\"19px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg></span>\n <span class=\"nav_heading_sd\">Recent</span>\n </button>\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('keypad_sd')\"\n [class.active]=\"bottomActiveTab === 'keypad_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"20px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Keypad</span>\n </button>\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('settings_sd')\"\n [class.active]=\"bottomActiveTab === 'settings_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"19px\" viewBox=\"-0.03 0 16.079 16.079\">\n <g>\n <path fill=\"currentColor\"\n d=\"M8.182 1.083a6.99 6.99 0 0 0-6.248 3.493c-1.929 3.342-.776 7.629 2.57 9.562 3.346 1.934 7.634.792 9.562-2.55 1.929-3.343.776-7.634-2.57-9.567a6.98 6.98 0 0 0-3.314-.938zM8 2.08a6 6 0 0 1 6 6 6 6 0 0 1-6 6 6 6 0 0 1-6-6 6 6 0 0 1 6-6z\"\n style=\"line-height:normal;font-variant-ligatures:none;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;text-transform:none;isolation:auto;mix-blend-mode:normal;marker:none\"\n font-weight=\"400\" font-family=\"sans-serif\" white-space=\"normal\" overflow=\"visible\" />\n <path fill=\"currentColor\"\n d=\"M9.322 0L6.69.393v1.354a6.49 6.477 43.146 0 1 2.632.005V0zM3.937 1.19L1.93 2.897l.988 1.177a6.49 6.477 43.146 0 1 2.017-1.69zm8.128.013l-.993 1.184a6.49 6.477 43.146 0 1 .17.09 6.49 6.477 43.146 0 1 1.845 1.603l1.006-1.197zM.455 5.42l-.44 2.596 1.515.267a6.49 6.477 43.146 0 1 .455-2.593zm15.086.003l-1.523.269a6.49 6.477 43.146 0 1 .464 2.59l1.533-.27zM1.858 10.118l-1.351.78 1.33 2.271 1.339-.772a6.49 6.477 43.146 0 1-1.317-2.28zm12.301.003a6.49 6.477 43.146 0 1-.534 1.215 6.49 6.477 43.146 0 1-.774 1.069l1.338.773 1.302-2.288zm-9.557 3.471l-.534 1.47 2.48.884.525-1.446a6.49 6.477 43.146 0 1-2.303-.8 6.49 6.477 43.146 0 1-.168-.108zm6.814.016a6.49 6.477 43.146 0 1-2.475.897l.53 1.457 2.468-.917z\"\n style=\"marker:none\" overflow=\"visible\" />\n <path fill=\"currentColor\"\n d=\"M7.648 3.093a4.989 4.989 0 0 0-3.982 2.483 5.013 5.013 0 0 0 1.836 6.834 5.002 5.002 0 0 0 6.83-1.827 5.01 5.01 0 0 0-1.836-6.832 4.976 4.976 0 0 0-2.848-.658zM8 4.08a4 4 0 0 1 4 4 4 4 0 0 1-4 4 4 4 0 0 1-4-4 4 4 0 0 1 4-4z\"\n style=\"line-height:normal;font-variant-ligatures:none;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;text-transform:none;isolation:auto;mix-blend-mode:normal;marker:none\"\n font-weight=\"400\" font-family=\"sans-serif\" white-space=\"normal\" overflow=\"visible\" />\n </g>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">\n Preferences\n </span>\n </button>\n </div>\n </ng-container>\n\n <ng-template #showActiveCallDiv>\n\n <div class=\"container_call\">\n <div class=\"container_call_header\">\n <div class=\"container_call_header_inner\">\n <ng-container\n *ngIf=\"!conferenceParticipants || conferenceParticipants.length <= 1 else showConferenceCallDiv\">\n <ng-container>\n\n <!-- ------------ add call list swap and merge area start ---------------- -->\n\n <div class=\"container_swap_merge_list\" *ngIf=\"activeCalls.length > 1\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_swap_merge\">\n <ng-container *ngFor=\"let call of activeCalls; let i = index\">\n <ng-container *ngIf=\"i !== currentActiveCallIndex\">\n <div class=\"container_swap_merge_item\" (click)=\"swapLinesToIndex(i)\"\n [ngClass]=\"{ 'active-call': i === currentActiveCallIndex, 'other-call': i !== currentActiveCallIndex }\">\n <!-- Avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_swap_merge_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"50px\" width=\"50px\" version=\"1.1\" x=\"0px\"\n y=\"0px\" enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\" d=\"M173.561,171.615...\"></path>\n <path fill=\"#FFFFFF\" d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737...\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <!-- Call Info -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">{{ call.phoneNumber }}</div>\n <div class=\"onhold_st\" *ngIf=\"call.isOnHold\">On hold</div>\n </div>\n\n <!-- Action Buttons -->\n <div class=\"container_recent_item_right\">\n <!-- Merge Button -->\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <svg width=\"18\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l97.2 0c9.7 0 18.9 4.4 25 12L247 256 154.2 372c-6.1 7.6-15.3 12-25 12L32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l97.2 0c29.2 0 56.7-13.3 75-36l99.2-124 80.6 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c6-6 9.4-14.1 9.4-22.6s-3.4-16.6-9.4-22.6l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-80.6 0L204.2 100c-18.2-22.8-45.8-36-75-36L32 64z\">\n </path>\n </svg>\n </div>\n <div class=\"button_text\">Merge</div>\n </button>\n </div>\n\n <!-- Swap Button -->\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <svg width=\"22px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M150.6 73.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 173.3 96 320c0 53 43 96 96 96l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-146.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96zM336 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32 14.3 32 32l0 146.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L544 338.7 544 192c0-53-43-96-96-96L336 96z\">\n </path>\n </svg>\n </div>\n <div class=\"button_text\">Swap</div>\n </button>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- ------------ add call list swap and merge area end ---------------- -->\n\n <div class=\"container_call_info\" *ngIf=\"isCalling else showCallStateDiv\">Calling...</div>\n <ng-template #showCallStateDiv>\n <div class=\"container_call_info\" *ngIf=\"isactiveCall\">\n {{ formatTime(activeCalls[currentActiveCallIndex].duration)}}</div>\n <div class=\"container_call_info_blinker\" *ngIf=\"showCallDisconnected\">\n <svg width=\"18px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg> {{ this.istransfer ? 'Call Transferred' : 'Call ended' }}\n </div>\n </ng-template>\n\n <div class=\"container_call_ani\">\n <ng-container *ngIf=\"activeCalls.length >0; else disconnectedBlock\">\n <div class=\"container_call_ani_number\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.country?.flag }}\n {{ activeCalls[currentActiveCallIndex].phoneNumber }}\n </div>\n <div class=\"container_call_ani_name\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.phoneNumber?.location }}\n </div>\n </ng-container>\n\n <ng-template #disconnectedBlock>\n <div class=\"container_call_ani_number\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.country?.flag }}\n {{ lastDisconnectedCall?.phoneNumber }}\n </div>\n <div class=\"container_call_ani_name\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.phoneNumber?.location }}\n </div>\n </ng-template>\n\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\" [ngClass]=\"{ 'call_animation': isactiveCall }\">\n <svg viewBox=\"0 0 212 212\" height=\"85\" width=\"85\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"activeCalls.length>1\" style=\"display: none;\">\n <div *ngFor=\"let call of activeCalls; let i = index \"\n [ngClass]=\"{ 'active-call': i === currentActiveCallIndex, 'other-call': i !== currentActiveCallIndex }\"\n (click)=\"swapLinesToIndex(i)\">\n <div class=\"call-number\">{{ call.phoneNumber }}</div>\n <div class=\"call-duration\">{{ call.duration }}s</div>\n <div class=\"call-status\">\n <span *ngIf=\"call.isOnHold\">On Hold</span>\n <span *ngIf=\"call.isMuted\">Muted</span>\n </div>\n </div>\n </div>\n\n </ng-container>\n </ng-container>\n\n <!-- Placeholder for conference call code -->\n <ng-template #showConferenceCallDiv>\n <!-- <ng-container *ngTemplateOutlet=\"conferenceCallTemplate\"></ng-container> -->\n </ng-template>\n </div>\n </div>\n\n <div class=\"container_call_content\">\n <div class=\"container_call_dnis\" style=\"display: none;\">\n <span>Ext. {{ extensionNumber }}</span>\n </div>\n\n <div class=\"container_call_options\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall && activeCalls.length<4} \" (click)=\"onAddCall() \"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\">\n <svg fill=\"#000000\" width=\"20\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\"\n xml:space=\"preserve\">\n <path fill=\"currentColor\" d=\"M30,29h16.5c0.8,0,1.5-0.7,1.5-1.5v-3c0-0.8-0.7-1.5-1.5-1.5H30c-0.6,0-1-0.4-1-1V5.5C29,4.7,28.3,4,27.5,4\n h-3C23.7,4,23,4.7,23,5.5V22c0,0.6-0.4,1-1,1H5.5C4.7,23,4,23.7,4,24.5v3C4,28.3,4.7,29,5.5,29H22c0.6,0,1,0.4,1,1v16.5\n c0,0.8,0.7,1.5,1.5,1.5h3c0.8,0,1.5-0.7,1.5-1.5V30C29,29.4,29.4,29,30,29z\" />\n </svg>\n </div>\n <div class=\"button_text\">Add</div>\n </button>\n\n <button class=\"button_call_option\" [ngClass]=\"{ 'button_disabled': !isactiveCall }\" *ngIf=\"!isRecording\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\">\n <svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n <div class=\"button_text\">Record</div>\n </button>\n <button class=\"button_call_option\" [ngClass]=\"{ 'button_disabled': !isactiveCall }\" *ngIf=\"isRecording\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\">\n <svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n <div class=\"button_text\">Stop</div>\n </button>\n\n <button class=\"button_call_option\" [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\" (click)=\"isCallTransferOpen = !isCallTransferOpen\">\n <div class=\"button_icon\">\n <svg width=\"25px\" height=\"25px\" viewBox=\"0 0 48 48\" version=\"1\" enable-background=\"new 0 0 48 48\">\n <path fill=\"currentColor\"\n d=\"M39.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4h-4.8c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L41,8.4C40.5,7.9,39.7,7.9,39.2,8.4z\" />\n <path fill=\"currentColor\"\n d=\"M11.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4H8.5c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L13,8.4C12.5,7.9,11.7,7.9,11.2,8.4z\" />\n <g fill=\"currentColor\">\n <polygon points=\"25.3,18.6 30.7,24 25.3,29.4\" />\n <rect x=\"16\" y=\"22\" width=\"11\" height=\"4\" />\n </g>\n </svg>\n </div>\n <div class=\"button_text\">Transfer</div>\n </button>\n\n <ng-container *ngIf=\"isCallTransferOpen\">\n <ng-container *ngTemplateOutlet=\"callTransferTemplate\"></ng-container>\n </ng-container>\n </div>\n\n <div class=\"container_dialpad_row\">\n <button class=\"button_call_option button_elevated\"\n *ngIf=\"activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isMuted\"\n (click)=\"toggleMute()\" [ngClass]=\"{'button_disabled': showCallDisconnected}\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 384 512\" width=\"16\">\n <path fill=\"currentColor\"\n d=\"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40z\" />\n </svg>\n </div>\n <div class=\"button_text\">Mute</div>\n </button>\n <button class=\"button_call_option button_active button_elevated\"\n *ngIf=\"activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isMuted\"\n (click)=\"toggleMute()\">\n <div class=\"button_icon\">\n <svg width=\"26\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c15.2-26 23.9-56.3 23.9-88.7l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 21.2-5.1 41.1-14.2 58.7L416 300.8 416 96c0-53-43-96-96-96s-96 43-96 96l0 54.3L38.8 5.1zM344 430.4c20.4-2.8 39.7-9.1 57.3-18.2l-43.1-33.9C346.1 382 333.3 384 320 384c-70.7 0-128-57.3-128-128l0-8.7L144.7 210c-.5 1.9-.7 3.9-.7 6l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6z\" />\n </svg>\n </div>\n <div class=\"button_text\">Unmute</div>\n </button>\n <button class=\"button_call_option button_elevated\"\n *ngIf=\"activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isOnHold\"\n [ngClass]=\"{'button_disabled': !isactiveCall}\" [disabled]=\"!isactiveCall\" (click)=\"toggleHold()\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg>\n </div>\n <div class=\"button_text\">Hold</div>\n </button>\n <button class=\"button_call_option button_active button_elevated\"\n *ngIf=\"activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isOnHold\"\n (click)=\"toggleHold()\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg>\n </div>\n <div class=\"button_text\">Unhold</div>\n </button>\n <button class=\"button_call_option button_elevated\" [class.button_active]=\"isDailpadOpen\"\n (click)=\"menuDailpad()\" [ngClass]=\"{'button_disabled': showCallDisconnected}\">\n <div class=\"button_icon\">\n <svg width=\"22px\" height=\"22px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n </svg>\n </div>\n <div class=\"button_text\">{{ isDailpadOpen ? 'Hide' : 'Keypad' }}</div>\n </button>\n <div class=\"container_popup_dialpad\" *ngIf=\"isDailpadOpen\">\n <div class=\"container_popup_dialpad_inner\">\n\n <div [formGroup]=\"dtmfForm\">\n <div class=\"container_dtmf_input\">\n <input type=\"tel\" formControlName=\"dtmf\">\n </div>\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <button *ngIf=\"!showCallDisconnected || isCalling\" class=\"button_dialpad_digit button_call_red\"\n (click)=\"dropCurrentCall()\">\n <svg width=\"25\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg>\n </button>\n <button *ngIf=\"showCallDisconnected && !isCalling\" class=\"button_dialpad_digit button_call_green\"\n (click)=\"onRedial()\" [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n\n <ng-template #conferenceCallTemplate>\n <div class=\"container_active_call_header\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">Conference call</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">with {{ conferenceParticipants?.length }} people</div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"container_active_call_options\">\n <div class=\"button_active_call_options button_active_call_options_highlighted\">\n <span (click)=\"isConfereceList = !isConfereceList\" class=\"container_active_call_options_button\">\n <svg viewBox=\"0 0 448 512\" width=\"16px\">\n <path fill=\"currentColor\"\n d=\"M201.4 374.6c12.5 12.5 32.8 12.5 45.3 0l160-160c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 306.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160z\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n\n <!-- Conference List -->\n <div class=\"container_conference_contact_list\" *ngIf=\"isConfereceList\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox container_conference_contact_list_scrollbox\">\n <div class=\"scrollbox-content\">\n <ng-container *ngFor=\"let person of conferenceParticipants; let last = last\">\n <div class=\"container_conference_contact_item\">\n <!-- Avatar -->\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <!-- Name and Time -->\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ person.name }}</div>\n <div class=\"contact_field_green\">{{ person.duration }}</div>\n </div>\n </div>\n\n <!-- End Button -->\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <button class=\"button_disconnect_call\">\n <svg width=\"22\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\">\n </path>\n </svg>\n </button>\n </div>\n </div>\n </div>\n\n <!-- Divider -->\n <div *ngIf=\"!last\" class=\"container_separator\"></div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n\n <ng-template #callTransferTemplate>\n <div class=\"container_transfer_call\">\n <div class=\"container_transfer_call_inner\">\n <div class=\"container_button_close\">\n <span (click)=\"isCallTransferOpen = false\" title=\"Close\">\n <i class=\"fa-sharp fa-solid fa-xmark\"></i>\n </span>\n </div>\n\n <!-- First Div -->\n <div class=\"container_transfer_call_content\" *ngIf=\"currentView === 'transferListpage'\" @slideInOut>\n <div class=\"container_active_call_duration\">{{ formatTime(callDuration)}}</div>\n <div class=\"container_active_call_header margin_bottom_16 shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">{{ lookupPhoneNumber?.country?.flag }}\n {{ lookupPhoneNumber?.phoneNumber }}</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">Active call</div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">Ext. {{extensionNumber}}</span>\n </div>\n </div>\n </div>\n <div class=\"container_transfer_tab_buttons\">\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab1')\" [class.active]=\"activeTab === 'tab1'\">\n <svg width=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg> Recent</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab2')\" [class.active]=\"activeTab === 'tab2'\">\n <svg width=\"20px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\"\n d=\"M15.71,12.71a6,6,0,1,0-7.42,0,10,10,0,0,0-6.22,8.18,1,1,0,0,0,2,.22,8,8,0,0,1,15.9,0,1,1,0,0,0,1,.89h.11a1,1,0,0,0,.88-1.1A10,10,0,0,0,15.71,12.71ZM12,12a4,4,0,1,1,4-4A4,4,0,0,1,12,12Z\" />\n </svg> Internal</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab3')\" [class.active]=\"activeTab === 'tab3'\">\n <svg width=\"18px\" height=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" /></svg>\n Dail</button>\n </div>\n <div class=\"container_transfer_tab_content\" *ngIf=\"activeTab === 'tab1'\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div>\n\n <div class=\"container_transfer_tab_content\" *ngIf=\"activeTab === 'tab2'\">\n <div class=\"container_transfer_internal_search\">\n <input type=\"search\" placeholder=\"Type to search\">\n </div>\n <div class=\"container_transfer_contact_list\"> \n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_contact_item\"\n (click)=\"goToDiv('transferDetails');makeCallFromContact('0')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Lovish Snug</div>\n <div class=\"contact_field\">6283675354</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Agent</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 8002</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar</div>\n <div class=\"contact_field\">(888) 9876549</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Administrator</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Sohan singh</div>\n <div class=\"contact_field\">(876) 8800965</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Manger</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Pardeep mishra</div>\n <div class=\"contact_field\">(876) 8800965</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Agent</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Varun ji </div>\n <div class=\"contact_field\">(876) 8800965</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Manger</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_transfer_tab_content\" *ngIf=\"activeTab === 'tab3'\">\n <form [formGroup]=\"transferForm\">\n <div class=\"container_transfer_contact_list\">\n <div class=\"container_phone_number_input margin_bottom_16\">\n <button class=\"button_phonebook\" (click)=\"isDirectoryOpen = !isDirectoryOpen\">\n <svg fill=\"currentColor\" height=\"22px\" style=\"enable-background:new 0 0 611.985 611.986;\"\n version=\"1.1\" viewBox=\"0 0\n611.985 611.986\" width=\"40.985px\" routerLinkActive=\"active\" xml:space=\"preserve\">\n <g>\n <path d=\"M143.021,158.99c42.525,0,79.456-36.931,79.456-79.456S185.546,0.078,143.021,0.078\nS63.565,37.009,63.565,79.534S100.496,158.99,143.021,158.99z\" fill=\"currentColor\" />\n <path d=\"M278.097,381.467c0-127.13-65.98-190.695-139.048-190.695S0,254.338,0,381.467\n C0,468.583,278.097,468.583,278.097,381.467z\" fill=\"currentColor\" />\n <path d=\"M373.444,220.807c42.525,0,79.456-36.931,79.456-79.456s-36.931-79.456-79.456-79.456\n s-79.456,36.931-79.456,79.456S330.919,220.807,373.444,220.807z\" fill=\"currentColor\" />\n <path d=\"M369.471,252.59c-21.962,0-43.033,6.452-62.071,17.957c11.537,31.051,18.37,67.792,18.37,110.921\n c0,42.843-28.541,76.151-77.517,95.22c60.768,51.424,260.267,40.459,260.267-33.403\n C508.52,316.155,442.539,252.59,369.471,252.59z\" fill=\"currentColor\" />\n </g>\n </svg>\n </button>\n <input placeholder=\"Phone Number\" type=\"tel\" formControlName=\"target\">\n <button class=\"button_backspace\" (click)=\"onBackspace()\"></button>\n </div>\n <div class=\"container_transfer_internal_contact_list\" *ngIf=\"isDirectoryOpen\">\n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n <!-- <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Agent</span></div>\n </div> -->\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\" d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9\n 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7\n 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8\n 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32\n 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9\n 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38\n 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86\n 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\" d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3\n36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4\n26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9\n0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5\n69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1\n0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2\n384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64\n192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4\n19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg></button>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <!-- come here -->\n <button *ngIf=\"isAddingNewCall\" class=\"button_dialpad_digit button_call_green\"\n (click)=\"makeCall(this.transferForm.value.target)\" [disabled]=\"!phoneNumber\"\n [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n <button *ngIf=\"!isAddingNewCall\" type=\"submit\" class=\"button_dialpad_digit button_call_green\"\n (click)=\"onTransferCall()\">\n <svg height=\"20px\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\" xml:space=\"preserve\">\n <g>\n <path fill=\"currentColor\" d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8\n c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3\n c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\" />\n <path fill=\"currentColor\" d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0\n l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\" />\n </g>\n </svg>\n </button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n\n <!-- Second Div -->\n <div class=\"container_transfer_call_content\" *ngIf=\"currentView === 'transferDetails'\" @slideInOut>\n <div class=\"container_active_call_duration\">00:10</div>\n <div class=\"container_active_call_header shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">{{ lookupPhoneNumber?.country?.flag }}\n {{ lookupPhoneNumber?.phoneNumber }}</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_grey\">\n <svg viewBox=\"0 0 320 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\"></path>\n </svg>\n </div>\n <div class=\"container_active_call_status_grey\">On hold</div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content ng-tns-c3832626365-74\">Ext. {{extensionNumber}}</span>\n </div>\n </div>\n </div>\n <div class=\"container_transfer_call_details\">\n\n <div class=\"container_call_ani_number padding_top_nt\">+91 (654) 9876549</div>\n <div class=\"container_call_ani_name\">Rajeev kumar singh</div>\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"85\" width=\"85\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n </div>\n <div class=\"container_call_dnis\">\n <span>Ext. {{extensionNumber}}</span>\n </div>\n <div class=\"container_call_options margin_bottom_nt\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option\" (click)=\"mergeCall()\">\n <div class=\"button_icon\">\n <svg width=\"22\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l97.2 0c9.7 0 18.9 4.4 25 12L247 256 154.2 372c-6.1 7.6-15.3 12-25 12L32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l97.2 0c29.2 0 56.7-13.3 75-36l99.2-124 80.6 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c6-6 9.4-14.1 9.4-22.6s-3.4-16.6-9.4-22.6l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-80.6 0L204.2 100c-18.2-22.8-45.8-36-75-36L32 64z\" />\n </svg>\n </div>\n <div class=\"button_text\">Merge</div>\n </button>\n <button class=\"button_call_option\">\n <div class=\"button_icon\">\n <svg width=\"26px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M150.6 73.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 173.3 96 320c0 53 43 96 96 96l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-146.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96zM336 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32 14.3 32 32l0 146.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L544 338.7 544 192c0-53-43-96-96-96L336 96z\" />\n </svg>\n </div>\n <div class=\"button_text\">Swap</div>\n </button>\n <button class=\"button_call_option\">\n <div class=\"button_icon\">\n <svg width=\"19px\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\" xml:space=\"preserve\">\n <g>\n <path fill=\"currentColor\" d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8\n c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3\n c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\" />\n <path fill=\"currentColor\" d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0\n l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\" />\n </g>\n </svg>\n </div>\n <div class=\"button_text\">Transfer</div>\n </button>\n </div>\n </div>\n <div class=\"container_transfer_disconnect\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit button_call_red\" (click)=\"goToDiv('transferListpage')\">\n <svg width=\"36px\" viewBox=\"0 0 76 76\" version=\"1.1\" baseProfile=\"full\"\n enable-background=\"new 0 0 76.00 76.00\" xml:space=\"preserve\">\n <path fill=\"currentColor\" fill-opacity=\"1\" stroke-width=\"0.2\" stroke-linejoin=\"round\"\n d=\"M 16.2013,39.582L 15.4175,39.4096L 14.8094,38.9315L 14.4029,38.2193L 14.25,37.364L 14.25,34.9055C 14.25,33.184 14.6023,31.6057 15.3069,30.1704C 16.0116,28.7352 16.9698,27.4788 18.1818,26.4013C 19.3937,25.3237 20.8095,24.4424 22.429,23.7573C 24.0486,23.0722 25.7732,22.6277 27.6031,22.4239L 31.304,22.0792L 34.9918,21.8256L 39.109,21.715L 42.966,21.8451L 46.101,22.0987L 48.9628,22.489C 50.7276,22.7318 52.3883,23.199 53.945,23.8906C 55.5017,24.5822 56.8567,25.4625 58.0101,26.5313C 59.1635,27.6002 60.0752,28.8468 60.7451,30.2712C 61.4151,31.6956 61.75,33.2599 61.75,34.964L 61.75,37.4486L 61.5874,38.2681L 61.1386,38.9511L 60.4785,39.4096L 59.6752,39.582L 51.8897,39.582L 51.0994,39.4096L 50.4588,38.9413L 50.0327,38.2584L 49.8799,37.4226L 49.8799,32.1217L 49.7075,31.1656L 49.2295,30.3818L 48.5075,29.8452C 48.23,29.7108 47.9286,29.6436 47.6034,29.6436L 28.7413,29.6436C 28.4161,29.6436 28.0974,29.7108 27.7852,29.8452L 26.9722,30.3818L 26.4128,31.1851C 26.2697,31.4973 26.1982,31.8225 26.1982,32.1607L 26.1982,37.364L 26.0356,38.2193L 25.5803,38.9315L 24.9104,39.4096L 24.1038,39.582L 16.2013,39.582 Z M 34.8333,41.1667L 41.1666,41.1667L 41.1667,52.6458L 45.9167,47.8958L 45.9167,54.2292L 38,62.5417L 30.0833,54.2292L 30.0833,47.8958L 34.8333,52.6458L 34.8333,41.1667 Z \" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n\n</ng-template>\n\n<div id=\"videoPanel\" style=\"display: none\">\n <audio #rmtAudio id=\"rmtAudio\" autoplay></audio>\n <audio #lclAudio id=\"lclAudio\" autoplay muted></audio>\n <video #rmtVideo id=\"rmtVideo\" autoplay></video>\n <video #lclVideo id=\"lclVideo\" autoplay muted controls title=\"Local Video\"></video>\n</div>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Open+Sans:300,400,500,600,700,800\";@import\"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css\";:host{--sd-app-color: #ff6633;--sd-app-color-dark: #ff5805;--sd-app-color-light: #fe8c66;--sd-text-font-family: \"Open Sans\", \"sans-serif\", \"Helvetica Neue\", \"Helvetica\", \"Arial\";--sd-text-color: #666;--sd-text-color-inverse: #fff;--sd-text-color-light: #ccc;--sd-text-color-medium: #999;--sd-text-color-dark: #333;--sd-background-color: #fff;--sd-border-color-light: #e3e3e3;--sd-border-color-dark: #c9c9c9}.message_label{width:100%;font-size:13px;font-family:var(--sd-text-font-family);letter-spacing:-.25px;border-radius:4px;font-weight:600;border:1px solid #f5c6cb;padding:8px 11px;position:relative}.error_message{color:#e1143c;background-color:#f8d7da;border-color:#dfadb2}.success_message{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert_message{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.properties_form_field{width:100%;font-size:13px!important;font-family:var(--sd-text-font-family)!important;font-weight:600!important;letter-spacing:-.24px!important;color:#555!important}.container_avaya_login{width:100%;height:calc(100vh - 51px);padding:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.container_avaya_login_inner{margin:0 auto;width:100%;max-width:370px;padding:65px 20px 20px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex}.container_connection_status_overlay{width:100%;height:100%;position:absolute;left:0;right:0;bottom:0;background-color:#6669;display:flex;justify-content:center;z-index:9999999;padding:20px}.container_connection_status{width:100%;background:var(--sd-background-color);padding:0 10px;border-radius:8px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);display:flex;height:42px;align-items:center;position:relative;box-shadow:#32325d40 0 6px 12px -2px,#0000004d 0 3px 7px -3px}.container_connection_status span{padding:0 0 0 8px}.container_connection_status .fa-circle-dot{color:#f66060}.container_connection_status_loader{position:absolute;right:15px}.container_avaya_login_content{position:relative;width:100%}.container_avaya_logo{margin:0;padding:0 26px 24px;width:100%;text-align:center}.container_avaya_logo_image{margin:0 auto;width:120px;height:35px;background:var(--sd-background-color) url() center no-repeat;background-size:120px}.container_avaya_logo h3{margin:0;padding:6px 0 0;font-family:var(--sd-text-font-family);font-size:18px;font-weight:700;letter-spacing:-.45px;color:var(--sd-text-color-dark);position:relative}.container_avaya_logo h3 span{font-size:8px;position:absolute;top:8px}.container_avaya_login_error{width:100%;white-space:normal}.container_avaya_login_form{width:100%;margin:0;padding:26px 0 0;position:relative}.container_avaya_login_form form{width:100%;margin:0;padding:0}.container_avaya_login_form .form_field{margin:0;padding:0;width:100%}.avaya_login_button_area{padding:10px 0 0}.container_icon_eye{position:absolute;right:15px}.container_avaya_login_form .button_submit_login{font:14px / 48px var(--sd-text-font-family);display:inline-block;height:48px;background:#cd1f1e;color:var(--sd-text-color-inverse);border:1px solid #cd1f1e;font-weight:600;padding:0 12px;border-radius:4px;outline:none;letter-spacing:-.24px;cursor:pointer;width:100%;position:relative}.container_avaya_login_form .button_submit_login_loader{background:#cd1f1e!important;color:var(--sd-text-color-inverse)!important;border:1px solid #cd1f1e!important;cursor:auto}.container_avaya_login_form .button_submit_login:disabled{background:#f1f1f1;color:var(--sd-text-color-medium);border:1px solid #f1f1f1}.button_submit_loader:after{content:\"\";position:absolute;width:16px;height:16px;inset:0;margin:auto;border:3px solid transparent;border-top-color:#fff;border-radius:50%;animation:button_submit_loader_spinner 1s ease infinite}@keyframes button_submit_loader_spinner{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.container_avaya_softphone{width:100%;height:100%;position:relative}.container_avaya_softphone_inner{width:100%;position:absolute;top:0;left:0;right:0;padding:0;height:calc(100% - 51px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background:#000}.container_call{margin:0 auto;padding:0;position:relative;width:100%;height:100%;background:var(--sd-background-color)}.container_dialpad_header{width:100%;position:relative;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99999;background:var(--sd-background-color);padding:15px 15px 0}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px 15px 0;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_avaya_extension{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:8px 10px;border:1px solid var(--sd-border-color-light);border-radius:12px;margin-bottom:15px;background:#f0f0f0}.container_avaya_extension_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center}.container_avaya_extension_left .extension_label{display:flex;align-items:center;line-height:normal;text-align:left}.container_avaya_extension_left .extension_number{display:flex;align-items:center;line-height:20px}.container_avaya_extension_right{flex-basis:auto;flex-direction:column;flex-grow:1;text-align:right;justify-items:flex-end}.container_avaya_extension_right button{background:none;border:none;outline:none;color:#a6a6a6;font-weight:600;border-radius:50%;align-items:center;justify-content:center;-webkit-transition-duration:.3s;transition-duration:.3s;background:#f0f0f0;height:38px;width:38px}.container_avaya_extension_right button:hover{color:var(--sd-text-color-dark);background:var(--sd-border-color-light)}.dialpad_container_sd{position:absolute;width:100%;right:0;left:0;top:101px;height:calc(100vh - 101px);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}.container_call_header{width:100%;position:absolute;top:0;left:0;right:0;height:221px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_call_header_inner{width:100%;margin:0;padding:10px 15px 15px;position:relative}.container_call_info{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color)}.container_call_info_blinker{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:red;animation:blinker 1s linear infinite}@keyframes blinker{26%{opacity:0}}.container_call_ani{width:100%;margin:0;padding:0}.container_call_ani_number{text-align:center;font-size:20px;font-weight:600;padding-top:26px}.container_call_ani_name{text-align:center;font-size:13px;font-weight:600;padding-top:2px}.container_call_ani_image{margin:0;padding:24px 0 0;width:100%}.container_call_ani_image_inner{display:flex;align-items:center;flex:0 0 auto;padding:0;width:85px;height:85px;position:relative;margin:0 auto;border-radius:100%}.container_call_content{width:100%;position:absolute;top:221px;left:0;right:0;height:calc(100% - 221px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding-top:20px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_call_dnis{width:100%;text-align:center;padding-bottom:16px}.container_call_dnis span{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 16px}.container_call_options{width:100%;display:flex;justify-content:center;margin-bottom:16px;flex-direction:column}.button_call_option{display:block;width:80px;height:60px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative}.button_call_option .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_call_option .button_text{display:flex;justify-content:center;color:var(--sd-text-color)}.button_active{color:#67cc02}.button_elevated{position:relative;z-index:9999}.button_disabled{color:gray;cursor:not-allowed;pointer-events:none;opacity:.6}.container_popup_dialpad{position:absolute;z-index:999;left:0;right:0;bottom:0}.container_popup_dialpad_inner{background:#f1f1f1;background:linear-gradient(180deg,#f1f1f1 44%,#fff);margin:0 auto;padding:10px 15px 20px;border-radius:8px;width:88%;position:relative;height:475px}.container_popup_dialpad .button_close{position:absolute;right:-15px;top:-17px;z-index:9}.container_popup_dialpad .button_close span{width:32px;height:32px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.container_popup_dialpad .button_close span:hover{background:#f1f1f1;color:var(--sd-text-color-dark)}.container_popup_dialpad .button_close span .fa-xmark{font-size:1.4em;font-weight:400}.container_dtmf_input{width:100%;margin:0;padding:0 0 10px;position:relative}.container_dtmf_input input{width:100%;display:flex;height:38px;outline:none;text-align:center;align-items:center;border:1px solid #f1f1f1;font-size:26px;font-weight:400;color:transparent;text-shadow:0 0 0 #000;padding:0;background:#f1f1f1}.container_active_call_header{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:12px;overflow:hidden}.container_active_call_avatar{display:flex}@keyframes play1{0%{transform:scale(1)}15%{box-shadow:0 0 0 2px #57b84666}25%{box-shadow:0 0 0 3px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 5px #bde4a966,0 0 0 30px #fff3}}.container_active_call_avatar_inner{margin:0 auto;padding:0;width:50px;height:50px;background:#dfe6e8;color:var(--sd-text-color-dark);position:relative;animation:play1 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden;border-radius:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.container_active_call_info{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_active_call_info_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_active_call_duration{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color);margin-bottom:10px}.container_active_call_number{font-size:13px;margin-bottom:2px}.container_active_call_details{font-size:13px;color:#6c0;padding-top:2px}.container_active_call_details_inner{display:flex;margin:0;padding:0;justify-content:left}.container_active_call_icon_grey{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:var(--sd-text-color-medium)}.container_active_call_icon_green{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:#6c0}.container_active_call_status_green{display:flex;justify-content:center;align-items:center;color:#6c0;padding-left:6px;font-size:12px}.container_active_call_status_grey{display:flex;justify-content:center;align-items:center;color:var(--sd-text-color-medium);padding-left:6px;font-size:12px}.container_active_call_options{display:flex;flex-direction:row}.container_active_call_options .button_active_call_options{display:flex;flex-basis:auto;justify-content:right}.container_active_call_options .button_active_call_options_highlighted{font-size:16px;color:#29abe0}.container_active_call_options_button{display:flex;border-radius:26px;border:none;padding:0;font-size:11px;color:var(--sd-text-color);width:32px;height:32px;justify-content:center;align-items:center}.container_active_call_options_button:hover{background:#f1f1f1}.container_conference_contact_list{position:relative;width:100%;background:#f7f7f7;border-top:1px solid #eee;border-bottom:1px solid #eee;height:149px;padding:0;margin-top:16px}.container_swap_merge_contact_list{position:relative;width:100%;background:var(--sd-background-color);height:149px;padding:0;margin-top:32px}.container_conference_contact_list_inner{margin:0;padding:0;position:relative;width:100%;height:100%}.container_conference_contact_list_scrollbox{padding:12px 15px}.container_conference_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:0 10px;overflow:hidden;cursor:pointer}.button_disconnect_call{display:block;width:42px;height:42px;display:flex;margin:0;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;color:#e0261f;background:#f7f7f7;-webkit-transition-duration:.3s;transition-duration:.3s}.button_disconnect_call:hover{color:var(--sd-text-color-inverse);background:#e0261f;-webkit-transition-duration:.3s;transition-duration:.3s}.container_separator{height:1px;width:100%;background:#ededed;margin:11px 0}.container_transfer_call{position:absolute;z-index:99999;left:0;right:0;bottom:-51px;width:100%;background:var(--sd-background-color)}.container_transfer_call_inner{background:var(--sd-background-color);box-shadow:#11111a1a 0 4px 16px,#11111a0d 0 8px 32px;padding:20px 15px 10px;border-radius:0;width:100%;position:relative;height:596px;overflow:hidden}.container_transfer_call_inner h2{font-family:var(--sd-text-font-family);font-size:20px;font-weight:700;color:var(--sd-text-color-dark);letter-spacing:-1px;padding:0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_button_close{position:absolute;right:4px;top:4px}.container_button_close span{width:36px;height:36px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer}.container_button_close span:hover{background:var(--sd-background-color)}.container_button_close .fa-xmark{font-size:1.6em;font-weight:400;color:var(--sd-text-color-light)}.container_button_close span:hover .fa-xmark:hover{color:var(--sd-text-color-dark)}.container_transfer_call_content{margin:0;padding:5px 0 0;width:100%;background:var(--sd-background-color);min-height:485px}.container_transfer_call_content h3{font-family:var(--sd-text-font-family);font-size:14px;font-weight:700;color:var(--sd-text-color);letter-spacing:-.26px;padding:8px 0 0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_transfer_call_content h3 span{color:var(--sd-text-color-dark)}.container_transfer_call_details{width:100%;margin:0;padding:10px 15px 69px;position:relative}.container_transfer_tab_buttons{display:flex;gap:10px;align-items:center;margin-bottom:15px}.button_transfer_tab{padding:10px;border:none;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);background-color:var(--sd-border-color-light);cursor:pointer;width:105px;border-radius:28px;outline:none}.button_transfer_tab.active{background-color:var(--sd-app-color);color:#fff}.container_transfer_tab_content{margin:0;padding:0;width:100%}.container_transfer_internal_search{margin:0 0 15px;padding:0;width:100%}.container_transfer_internal_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:48px}.container_transfer_contact_list{width:100%;margin:0;padding:0;position:relative;height:336px}.container_transfer_contact_list_inner{width:100%;position:relative;height:100%}.container_transfer_internal_contact_list{position:absolute;width:100%;left:0;right:0;background:var(--sd-background-color);height:332px}.container_transfer_disconnect{width:100%;display:flex;justify-content:center;padding-top:3px;margin-bottom:6px}.container_avaya_footer{width:100%;padding:0;background:#f7f7f7;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color-medium);position:relative;display:flex;height:51px;justify-content:center;align-items:center;border-top:1px solid var(--sd-border-color-light);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:999;position:absolute;bottom:0;left:0}.margin_bottom_16{margin-bottom:16px}.margin_bottom_nt{margin-bottom:10px}.padding_top_nt{padding-top:7px}.shadow_st{box-shadow:#00000026 0 2px 8px}.call_animation{animation:play 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden}.mini-call-switcher{display:flex;justify-content:center;margin-top:10px}.mini-call{padding:6px 12px;margin:0 6px;background:#eaeaea;border-radius:8px;cursor:pointer;font-size:14px}.mini-call.active{background-color:#c6f6d5;font-weight:700}.history-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}.history-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--sd-background-color);padding:20px;z-index:1000;box-shadow:0 2px 10px #0000004d;border-radius:5px;width:600px;max-height:80vh;overflow-y:auto}.history-content{position:relative}.history-content h3{margin-top:0}.close-btn{background:transparent;border:none;font-size:1.5rem;position:absolute;top:0;right:0;cursor:pointer}.history-content table{width:100%;border-collapse:collapse;margin-top:1rem}.history-content th,.history-content td{padding:.5rem;border:1px solid var(--sd-text-color-light)}@keyframes play{0%{transform:scale(1)}15%{box-shadow:0 0 0 4px #57b84680}25%{box-shadow:0 0 0 5px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 10px #c2e5b180,0 0 0 30px #fff3}}::-webkit-input-placeholder{color:#ddd}::-moz-placeholder{color:var(--sd-text-color-dark)}:-ms-input-placeholder{color:var(--sd-text-color-dark)}:-moz-placeholder{color:var(--sd-text-color-dark)}.slide_st{left:-100px;-webkit-animation:slide .5s forwards;-webkit-animation-delay:2s;animation:slide .5s forwards;animation-delay:0s}@-webkit-keyframes slide{to{left:0}}@keyframes slide{to{left:0}}.tabs_sd{width:100%;position:absolute;bottom:0;left:0;right:0;display:flex;height:51px;border-top:1px solid var(--sd-border-color-light);background:#f9f9f9;z-index:999999}.tab_heading_btn{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;align-items:center;padding:0;border:none;cursor:pointer;width:25%;font-family:var(--sd-text-font-family);font-size:11px;font-weight:600;line-height:normal;color:var(--sd-text-color-medium);background:none;transition:background-color .3s linear;-webkit-transition:background-color .3s linear;-o-transition:background-color .3s linear;-ms-transition:background-color .3s linear}.nav_icon{display:flex;align-items:center;justify-content:center;height:22px;margin-bottom:1px}.nav_heading_sd{display:flex;align-items:center}.tab_heading_btn.active{color:var(--sd-app-color);background:url() top center no-repeat}.tab-content_sd{width:100%;height:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative}.container_transfer_fav_list{width:100%;margin:0;padding:0;position:relative;height:376px}.outer_container_swap_merge{width:100%;margin:0;padding:0}.container_swap_merge_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;border-radius:8px;overflow:hidden}.container_recent_item_image{display:flex;align-items:center}.container_swap_merge_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.onhold_st{font-family:var(--sd-text-font-family);font-size:12px;color:var(--sd-text-color-medium);font-weight:600}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.button_swap_merge{display:block;width:32px;height:45px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 0 0 28px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative;pointer-events:all;cursor:pointer}.button_swap_merge .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_swap_merge .button_text{display:flex;justify-content:center;color:var(--sd-text-color-dark)}@media only screen and (max-width: 767px){.previewcontent{width:95%!important}.bgSecWrap .numberArrow{left:0!important;top:-20px!important}}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i10.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i10.MatLabel, selector: "mat-label" }, { kind: "directive", type: i10.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i10.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i11.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "directive", type: i5.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }, { kind: "component", type: CallHistoryComponent, selector: "app-call-history", outputs: ["makeCallEv"] }, { kind: "component", type: DialpadComponent, selector: "app-dialpad", inputs: ["contacts"], outputs: ["makeCallEv"] }, { kind: "component", type: DeviceSelectorComponent, selector: "app-device-selector", inputs: ["selectedAudioInputId", "selectedAudioOutputId"], outputs: ["change"] }], animations: [
|
|
2448
|
+
createMixedStream(local, remote) {
|
|
2449
|
+
const audioContext = new AudioContext();
|
|
2450
|
+
const destination = audioContext.createMediaStreamDestination();
|
|
2451
|
+
// Local stream
|
|
2452
|
+
if (local) {
|
|
2453
|
+
const localSource = audioContext.createMediaStreamSource(local);
|
|
2454
|
+
localSource.connect(destination);
|
|
2455
|
+
}
|
|
2456
|
+
// Remote stream
|
|
2457
|
+
if (remote) {
|
|
2458
|
+
const remoteSource = audioContext.createMediaStreamSource(remote);
|
|
2459
|
+
remoteSource.connect(destination);
|
|
2460
|
+
}
|
|
2461
|
+
return destination.stream;
|
|
2462
|
+
}
|
|
2463
|
+
initTranscription() {
|
|
2464
|
+
const SpeechRecognition = window.SpeechRecognition ||
|
|
2465
|
+
window.webkitSpeechRecognition;
|
|
2466
|
+
if (!SpeechRecognition) {
|
|
2467
|
+
console.error('Web Speech API is not supported in this browser.');
|
|
2468
|
+
return;
|
|
2469
|
+
}
|
|
2470
|
+
this.recognition = new SpeechRecognition();
|
|
2471
|
+
this.recognition.lang = 'en-US'; // change as needed
|
|
2472
|
+
this.recognition.continuous = true;
|
|
2473
|
+
this.recognition.interimResults = true;
|
|
2474
|
+
this.recognition.onresult = (event) => {
|
|
2475
|
+
let interimTranscript = '';
|
|
2476
|
+
for (let i = event.resultIndex; i < event.results.length; ++i) {
|
|
2477
|
+
if (event.results[i].isFinal) {
|
|
2478
|
+
const text = event.results[i][0].transcript.trim();
|
|
2479
|
+
this.transcriptHistory.push(text);
|
|
2480
|
+
// ⬇️ ADD: store finals w/ timestamp for summary
|
|
2481
|
+
this.transcriptSegments.push({ ts: Date.now(), text });
|
|
2482
|
+
}
|
|
2483
|
+
else {
|
|
2484
|
+
interimTranscript += event.results[i][0].transcript;
|
|
2485
|
+
}
|
|
2486
|
+
}
|
|
2487
|
+
this.transcriptText = [...this.transcriptHistory, interimTranscript].join(' ');
|
|
2488
|
+
console.log('Live Transcription:', this.transcriptText, this.transcriptHistory);
|
|
2489
|
+
this.cdr.detectChanges();
|
|
2490
|
+
};
|
|
2491
|
+
this.recognition.onerror = (event) => {
|
|
2492
|
+
console.error('Transcription error:', event.error);
|
|
2493
|
+
};
|
|
2494
|
+
this.recognition.onend = () => {
|
|
2495
|
+
if (this.showTranscriptionPopup) {
|
|
2496
|
+
console.log('Recognition ended, restarting…');
|
|
2497
|
+
try {
|
|
2498
|
+
this.recognition.start();
|
|
2499
|
+
}
|
|
2500
|
+
catch (err) {
|
|
2501
|
+
console.warn('Error restarting recognition:', err);
|
|
2502
|
+
}
|
|
2503
|
+
}
|
|
2504
|
+
};
|
|
2505
|
+
// 👇 Manual keep-alive every 25s
|
|
2506
|
+
if (this.recognitionKeepAlive) {
|
|
2507
|
+
clearInterval(this.recognitionKeepAlive);
|
|
2508
|
+
}
|
|
2509
|
+
this.recognitionKeepAlive = setInterval(() => {
|
|
2510
|
+
if (this.showTranscriptionPopup && this.recognition) {
|
|
2511
|
+
console.log('Force restarting recognition (keep-alive)…');
|
|
2512
|
+
try {
|
|
2513
|
+
this.recognition.stop(); // will trigger onend → restart
|
|
2514
|
+
}
|
|
2515
|
+
catch (err) {
|
|
2516
|
+
console.warn('Error stopping recognition:', err);
|
|
2517
|
+
}
|
|
2518
|
+
}
|
|
2519
|
+
}, 10000);
|
|
2520
|
+
}
|
|
2521
|
+
stopTranscription(callId) {
|
|
2522
|
+
// mark end BEFORE clearing anything
|
|
2523
|
+
this.transcriptEndedAt = Date.now();
|
|
2524
|
+
if (this.recognitionKeepAlive) {
|
|
2525
|
+
clearInterval(this.recognitionKeepAlive);
|
|
2526
|
+
this.recognitionKeepAlive = null;
|
|
2527
|
+
}
|
|
2528
|
+
if (this.recognition) {
|
|
2529
|
+
try {
|
|
2530
|
+
this.recognition.onend = null; // prevent auto-restart during teardown
|
|
2531
|
+
this.recognition.stop();
|
|
2532
|
+
}
|
|
2533
|
+
catch { }
|
|
2534
|
+
}
|
|
2535
|
+
// ⬇️ NEW: build + download markdown summary (if there is content)
|
|
2536
|
+
if (this.autoDownloadSummaryOnEnd && this.transcriptSegments.length > 0) {
|
|
2537
|
+
this.generateAndDownloadSummary(callId);
|
|
2538
|
+
}
|
|
2539
|
+
// cleanup live state (leave segments cleared after download)
|
|
2540
|
+
this.transcriptText = '';
|
|
2541
|
+
this.transcriptHistory = [];
|
|
2542
|
+
this.transcriptSegments = [];
|
|
2543
|
+
this.transcriptStartedAt = 0;
|
|
2544
|
+
this.transcriptEndedAt = 0;
|
|
2545
|
+
this.showTranscriptionPopup = false;
|
|
2546
|
+
}
|
|
2547
|
+
// Build + download a Markdown summary using lightweight extractive heuristics
|
|
2548
|
+
generateAndDownloadSummary(callId) {
|
|
2549
|
+
const fullText = this.transcriptSegments.map(s => s.text).join(' ');
|
|
2550
|
+
if (!fullText.trim())
|
|
2551
|
+
return;
|
|
2552
|
+
const bullets = this.buildExtractiveSummary(fullText, 5); // 5 highlight bullets
|
|
2553
|
+
const actions = this.extractActionItems(fullText);
|
|
2554
|
+
const keyInfo = this.extractKeyInfo(fullText);
|
|
2555
|
+
const mdLines = [];
|
|
2556
|
+
mdLines.push('# Call Summary');
|
|
2557
|
+
mdLines.push(`**Call ID:** ${callId ?? '-'}`);
|
|
2558
|
+
mdLines.push(`**Agent:** ${this.extensionNumber} `);
|
|
2559
|
+
mdLines.push(`**Tenant:** ${this.tenantId}`);
|
|
2560
|
+
mdLines.push(`**Start:** ${this.transcriptStartedAt ? new Date(this.transcriptStartedAt).toISOString() : '-'}`);
|
|
2561
|
+
mdLines.push(`**End:** ${this.transcriptEndedAt ? new Date(this.transcriptEndedAt).toISOString() : '-'}`);
|
|
2562
|
+
const durMs = (this.transcriptStartedAt && this.transcriptEndedAt)
|
|
2563
|
+
? (this.transcriptEndedAt - this.transcriptStartedAt) : 0;
|
|
2564
|
+
mdLines.push(`**Duration:** ${this.fmtHMS(durMs)}`);
|
|
2565
|
+
mdLines.push('');
|
|
2566
|
+
mdLines.push('## Highlights');
|
|
2567
|
+
if (bullets.length)
|
|
2568
|
+
bullets.forEach(b => mdLines.push(`- ${b}`));
|
|
2569
|
+
else
|
|
2570
|
+
mdLines.push('- (no highlights)');
|
|
2571
|
+
if (actions.length) {
|
|
2572
|
+
mdLines.push('', '## Action Items');
|
|
2573
|
+
actions.forEach(a => mdLines.push(`- [ ] ${a}`));
|
|
2574
|
+
}
|
|
2575
|
+
if (keyInfo.length) {
|
|
2576
|
+
mdLines.push('', '## Key Info');
|
|
2577
|
+
keyInfo.forEach(k => mdLines.push(`- ${k}`));
|
|
2578
|
+
}
|
|
2579
|
+
// Optional appendix: full transcript with timestamps
|
|
2580
|
+
mdLines.push('', '## Transcript (final lines)');
|
|
2581
|
+
for (const seg of this.transcriptSegments) {
|
|
2582
|
+
const offset = seg.ts - (this.transcriptStartedAt || seg.ts);
|
|
2583
|
+
mdLines.push(`[${this.fmtHMS(offset)}] ${seg.text}`);
|
|
2584
|
+
}
|
|
2585
|
+
const mdBlob = new Blob([mdLines.join('\n')], { type: 'text/markdown;charset=utf-8' });
|
|
2586
|
+
const name = `call-${callId || 'unknown'}-summary.md`;
|
|
2587
|
+
this.downloadBlobFile(mdBlob, name);
|
|
2588
|
+
// store in memory if you also want to show it somewhere
|
|
2589
|
+
this.summaryText = mdLines.join('\n');
|
|
2590
|
+
}
|
|
2591
|
+
// === extractive “enough” summarizer ===
|
|
2592
|
+
buildExtractiveSummary(text, maxBullets = 5) {
|
|
2593
|
+
const sents = this.splitSentences(text);
|
|
2594
|
+
if (sents.length <= maxBullets)
|
|
2595
|
+
return sents;
|
|
2596
|
+
const stop = new Set(('i,me,my,myself,we,our,ours,ourselves,you,your,yours,' +
|
|
2597
|
+
'he,him,his,she,her,hers,it,its,they,them,their,theirs,what,which,who,whom,' +
|
|
2598
|
+
'this,that,these,those,am,is,are,was,were,be,been,being,have,has,had,do,does,' +
|
|
2599
|
+
'did,doing,a,an,the,and,but,if,or,because,as,until,while,of,at,by,for,with,' +
|
|
2600
|
+
'about,against,between,into,through,during,before,after,above,below,to,from,' +
|
|
2601
|
+
'up,down,in,out,on,off,over,under,again,further,then,once,here,there,when,' +
|
|
2602
|
+
'where,why,how,all,any,both,each,few,more,most,other,some,such,no,nor,not,' +
|
|
2603
|
+
'only,own,same,so,than,too,very,can,will,just,don,should,now').split(','));
|
|
2604
|
+
const tokenize = (s) => s.toLowerCase().replace(/[^a-z0-9\s]/g, ' ')
|
|
2605
|
+
.split(/\s+/).filter(w => w && !stop.has(w));
|
|
2606
|
+
const freq = new Map();
|
|
2607
|
+
for (const s of sents)
|
|
2608
|
+
for (const w of tokenize(s))
|
|
2609
|
+
freq.set(w, (freq.get(w) || 0) + 1);
|
|
2610
|
+
const scored = sents.map((s, i) => {
|
|
2611
|
+
const words = tokenize(s);
|
|
2612
|
+
const score = words.reduce((acc, w) => acc + (freq.get(w) || 0), 0) / Math.max(1, words.length);
|
|
2613
|
+
return { i, s, score };
|
|
2614
|
+
});
|
|
2615
|
+
return scored
|
|
2616
|
+
.sort((a, b) => b.score - a.score)
|
|
2617
|
+
.slice(0, maxBullets)
|
|
2618
|
+
.sort((a, b) => a.i - b.i)
|
|
2619
|
+
.map(x => x.s.trim());
|
|
2620
|
+
}
|
|
2621
|
+
splitSentences(text) {
|
|
2622
|
+
return text
|
|
2623
|
+
.replace(/\s+/g, ' ')
|
|
2624
|
+
.split(/(?<=[.!?])\s+(?=[A-Z0-9])/g)
|
|
2625
|
+
.map(s => s.trim())
|
|
2626
|
+
.filter(Boolean);
|
|
2627
|
+
}
|
|
2628
|
+
extractActionItems(text) {
|
|
2629
|
+
const sents = this.splitSentences(text);
|
|
2630
|
+
const pat = /(need to|please|send|share|call|schedule|arrange|follow up|email|whatsapp|provide|confirm|deliver|prepare|create|set up|book|assign|remind)/i;
|
|
2631
|
+
return sents.filter(s => pat.test(s)).slice(0, 12);
|
|
2632
|
+
}
|
|
2633
|
+
extractKeyInfo(text) {
|
|
2634
|
+
const out = [];
|
|
2635
|
+
const phones = text.match(/(?:\+?\d[\s-]?){8,15}\d/g) || [];
|
|
2636
|
+
const emails = text.match(/[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,}/gi) || [];
|
|
2637
|
+
const amounts = text.match(/(?:₹|\$|INR\s?)\s?\d[\d,]*(?:\.\d+)?/g) || [];
|
|
2638
|
+
const dates = text.match(/\b(?:\d{1,2}[-/]\d{1,2}[-/]\d{2,4}|(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)[a-z]*\s+\d{1,2}(?:,\s*\d{4})?)\b/gi) || [];
|
|
2639
|
+
if (phones.length)
|
|
2640
|
+
out.push(`Phones: ${Array.from(new Set(phones)).join(', ')}`);
|
|
2641
|
+
if (emails.length)
|
|
2642
|
+
out.push(`Emails: ${Array.from(new Set(emails)).join(', ')}`);
|
|
2643
|
+
if (amounts.length)
|
|
2644
|
+
out.push(`Amounts: ${Array.from(new Set(amounts)).join(', ')}`);
|
|
2645
|
+
if (dates.length)
|
|
2646
|
+
out.push(`Dates: ${Array.from(new Set(dates)).join(', ')}`);
|
|
2647
|
+
return out;
|
|
2648
|
+
}
|
|
2649
|
+
downloadBlobFile(blob, filename) {
|
|
2650
|
+
const url = URL.createObjectURL(blob);
|
|
2651
|
+
const a = document.createElement('a');
|
|
2652
|
+
a.href = url;
|
|
2653
|
+
a.download = filename;
|
|
2654
|
+
document.body.appendChild(a);
|
|
2655
|
+
a.click();
|
|
2656
|
+
a.remove();
|
|
2657
|
+
URL.revokeObjectURL(url);
|
|
2658
|
+
}
|
|
2659
|
+
fmtHMS(ms) {
|
|
2660
|
+
const totalSec = Math.floor(ms / 1000);
|
|
2661
|
+
const h = Math.floor(totalSec / 3600);
|
|
2662
|
+
const m = Math.floor((totalSec % 3600) / 60);
|
|
2663
|
+
const s = totalSec % 60;
|
|
2664
|
+
return (h > 0 ? String(h).padStart(2, '0') + ':' : '') +
|
|
2665
|
+
String(m).padStart(2, '0') + ':' + String(s).padStart(2, '0');
|
|
2666
|
+
}
|
|
2667
|
+
// add this method in the component class
|
|
2668
|
+
transferToFromHistory(item) {
|
|
2669
|
+
// prefer a previously-resolved dialable if you store one
|
|
2670
|
+
const prefer = (v) => (v ?? '').toString().replace(/\s+/g, '');
|
|
2671
|
+
let target = prefer(item.resolvedDialable) ||
|
|
2672
|
+
prefer(item.lookupPhoneNumber?.['local-number']) ||
|
|
2673
|
+
prefer(item.lookupPhoneNumber?.lookupPhoneNumber?.['local-number']) ||
|
|
2674
|
+
prefer(item.lookupPhoneNumber?.normalizedPhoneNumber) ||
|
|
2675
|
+
prefer(item.phoneNumber);
|
|
2676
|
+
if (!target) {
|
|
2677
|
+
console.warn('Transfer aborted: no dialable number found in recent item:', item);
|
|
2678
|
+
return;
|
|
2679
|
+
}
|
|
2680
|
+
// IMPORTANT: transfer, not makeCall
|
|
2681
|
+
this.avayaIPOService.transferCall(target, 'unAttended'); // or 'Blind'
|
|
2682
|
+
this.isCallTransferOpen = false; // close transfer UI if you want
|
|
2683
|
+
}
|
|
2684
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOWidgetComponent, deps: [{ token: i1.HttpClient }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1$1.FormBuilder }, { token: CountryService }, { token: PhoneNumberLookupService }, { token: AvayaIPOService }, { token: RecordingManagerService }, { token: CallSocketService }, { token: i8.SnugdeskAuthenticationService }, { token: i8.TenantService }, { token: i8.UserService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2685
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.9", type: AvayaIPOWidgetComponent, isStandalone: false, selector: "snugdesk-avaya-ipo-widget", inputs: { tenantId: "tenantId", userId: "userId", isVisible: "isVisible", containerHeightObservable: "containerHeightObservable", containerWidthObservable: "containerWidthObservable" }, outputs: { notificationEvent: "notificationEvent" }, ngImport: i0, template: "@if (isReconnectingInProgress || isFailoverInProgress || isFailbackInProgress) {\n <div class=\"container_connection_status_overlay\">\n <div class=\"container_connection_status\">\n <i class=\"fa-solid fa-circle-dot\"></i>\n\n @if (isReconnectingInProgress) {\n <span>Reconnecting to the server...</span>\n }\n\n @if (isFailoverInProgress) {\n <span>Failover in progress...</span>\n }\n\n @if (isFailbackInProgress) {\n <span>Failback in progress...</span>\n }\n\n <div class=\"container_connection_status_loader\">\n <div class=\"container_three_dot_loader\">\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n </div>\n </div>\n </div>\n </div>\n}\n\n\n\n@if (showLoginForm) {\n <!-- Login Form -->\n <div class=\"container_avaya_login\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_avaya_login_inner\">\n <div class=\"container_avaya_login_content\">\n\n <div class=\"container_avaya_logo\">\n <div class=\"container_avaya_logo_image\"></div>\n <h3>IP Office<span>TM</span></h3>\n </div>\n\n @if (hasAvayaSocketError || hasAvayaLoginError || hasAvayaLoginConflictError || hasAvayaDeviceError) {\n <div class=\"container_avaya_login_error\">\n <p class=\"message_label error_message\">\n @if (hasAvayaSocketError) {\n We're having trouble connecting to the server\n }\n @if (hasAvayaLoginError) {\n Invalid extension or password!\n }\n @if (hasAvayaLoginConflictError) {\n Another user is logged in with this extension\n }\n @if (hasAvayaDeviceError) {\n We're having trouble accessing your device\n }\n </p>\n </div>\n }\n\n <div class=\"container_avaya_login_form\">\n <form [formGroup]=\"loginForm\" (ngSubmit)=\"onLogin()\">\n\n <!-- Extension -->\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Extension</mat-label>\n <input matInput formControlName=\"ipoExtensionNo\" autocomplete=\"ipoExtensionNo\"\n (keypress)=\"restrictNumeric($event)\" />\n\n @if (loginForm.controls['ipoExtensionNo'].invalid && loginForm.controls['ipoExtensionNo'].touched) {\n <mat-error>\n @if (loginForm.controls['ipoExtensionNo'].errors?.['required']) {\n <small>Extension is required.</small>\n }\n </mat-error>\n }\n </mat-form-field>\n </div>\n\n <!-- Password -->\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Password</mat-label>\n <input matInput formControlName=\"ipoPassword\" autocomplete=\"avaya-ipo-password\"\n (keypress)=\"restrictNumeric($event)\" [type]=\"showLoginPassword ? 'text' : 'password'\" />\n\n <mat-icon matSuffix (click)=\"showLoginPassword = !showLoginPassword && !hasAvayaSocketError\">\n @if (showLoginPassword) {\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye\"></i>\n </span>\n } @else {\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye-slash\"></i>\n </span>\n }\n </mat-icon>\n\n @if (loginForm.controls['ipoPassword'].invalid && loginForm.controls['ipoPassword'].touched) {\n <mat-error>\n @if (loginForm.controls['ipoPassword'].errors?.['required']) {\n <small>Password is required.</small>\n }\n </mat-error>\n }\n </mat-form-field>\n </div>\n\n <!-- Login button -->\n <div class=\"avaya_login_button_area\">\n <button type=\"submit\" class=\"button_submit_login\"\n [ngClass]=\"{ 'button_submit_login_loader': showLoginLoader }\"\n [disabled]=\"showLoginLoader\">\n @if (showLoginLoader) {\n <span class=\"button_submit_loader\"></span>\n } @else {\n <span>Login</span>\n }\n </button>\n </div>\n\n </form>\n </div>\n\n </div>\n </div>\n </div>\n </div>\n </div>\n} @else {\n <!-- Softphone UI -->\n <ng-container *ngTemplateOutlet=\"showSoftphoneDiv\"></ng-container>\n}\n\n<!-- Footer (always visible) -->\n<div class=\"container_avaya_footer\">© 2025 SNUG Technologies Pvt. Ltd.\n\n\n\n</div>\n\n\n\n\n\n<ng-template #showSoftphoneDiv>\n\n@if (!showActiveCall) {\n <div class=\"container_avaya_softphone_inner\">\n <!-- ------------------- Keypad work start ---------- -->\n @if (bottomActiveTab === 'keypad_sd') {\n <div class=\"tab-content_sd\">\n <div class=\"container_dialpad_header\">\n <div class=\"container_dialpad_header_inner2\">\n <div class=\"container_avaya_extension\">\n <div class=\"container_avaya_extension_left\">\n <div class=\"extension_label\">Extension</div>\n <div class=\"extension_number\">{{ extensionNumber }}</div>\n </div>\n <div class=\"container_avaya_extension_right\">\n <button title=\"Sign out\" (click)=\"onLogout()\">\n <svg width=\"16px\" fill=\"currentColor\" viewBox=\"0 0 512 512\">\n <path\n d=\"M377.9 105.9L500.7 228.7c7.2 7.2 11.3 17.1 11.3 27.3s-4.1 20.1-11.3 27.3L377.9 406.1c-6.4 6.4-15 9.9-24 9.9c-18.7 0-33.9-15.2-33.9-33.9l0-62.1-128 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l128 0 0-62.1c0-18.7 15.2-33.9 33.9-33.9c9 0 17.6 3.6 24 9.9zM160 96L96 96c-17.7 0-32 14.3-32 32l0 256c0 17.7 14.3 32 32 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-53 0-96-43-96-96L0 128C0 75 43 32 96 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"dialpad_container_sd\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <app-dialpad [contacts]=\"contacts\" (makeCallEv)=\"makeCall($event)\"></app-dialpad>\n <!-- to do list -->\n </div>\n </div>\n </div>\n </div>\n }\n\n <!-- ------------------- Keypad work end ---------- -->\n\n @if (bottomActiveTab === 'recent_sd') {\n <div class=\"tab-content_sd\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div>\n }\n\n @if (bottomActiveTab === 'settings_sd') {\n <div class=\"tab-content_sd\">\n <app-device-selector (change)=\"handleDeviceSelection($event)\"></app-device-selector>\n </div>\n }\n </div>\n\n <div class=\"tabs_sd\">\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('recent_sd')\"\n [class.active]=\"bottomActiveTab === 'recent_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"19px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Recent</span>\n </button>\n\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('keypad_sd')\"\n [class.active]=\"bottomActiveTab === 'keypad_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"20px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Keypad</span>\n </button>\n\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('settings_sd')\"\n [class.active]=\"bottomActiveTab === 'settings_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"19px\" viewBox=\"-0.03 0 16.079 16.079\">\n <g>\n <path fill=\"currentColor\"\n d=\"M8.182 1.083a6.99 6.99 0 0 0-6.248 3.493c-1.929 3.342-.776 7.629 2.57 9.562 3.346 1.934 7.634.792 9.562-2.55 1.929-3.343.776-7.634-2.57-9.567a6.98 6.98 0 0 0-3.314-.938zM8 2.08a6 6 0 0 1 6 6 6 6 0 0 1-6 6 6 6 0 0 1-6-6 6 6 0 0 1 6-6z\" />\n <path fill=\"currentColor\"\n d=\"M9.322 0L6.69.393v1.354a6.49 6.477 43.146 0 1 2.632.005V0zM3.937 1.19L1.93 2.897l.988 1.177a6.49 6.477 43.146 0 1 2.017-1.69zm8.128.013l-.993 1.184a6.49 6.477 43.146 0 1 .17.09 6.49 6.477 43.146 0 1 1.845 1.603l1.006-1.197zM.455 5.42l-.44 2.596 1.515.267a6.49 6.477 43.146 0 1 .455-2.593zm15.086.003l-1.523.269a6.49 6.477 43.146 0 1 .464 2.59l1.533-.27zM1.858 10.118l-1.351.78 1.33 2.271 1.339-.772a6.49 6.477 43.146 0 1-1.317-2.28zm12.301.003a6.49 6.477 43.146 0 1-.534 1.215 6.49 6.477 43.146 0 1-.774 1.069l1.338.773 1.302-2.288zm-9.557 3.471l-.534 1.47 2.48.884.525-1.446a6.49 6.477 43.146 0 1-2.303-.8 6.49 6.477 43.146 0 1-.168-.108zm6.814.016a6.49 6.477 43.146 0 1-2.475.897l.53 1.457 2.468-.917z\" />\n <path fill=\"currentColor\"\n d=\"M7.648 3.093a4.989 4.989 0 0 0-3.982 2.483 5.013 5.013 0 0 0 1.836 6.834 5.002 5.002 0 0 0 6.83-1.827 5.01 5.01 0 0 0-1.836-6.832 4.976 4.976 0 0 0-2.848-.658zM8 4.08a4 4 0 0 1 4 4 4 4 0 0 1-4 4 4 4 0 0 1-4-4 4 4 0 0 1 4-4z\" />\n </g>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Preferences</span>\n </button>\n </div>\n} @else {\n <ng-container *ngTemplateOutlet=\"showActiveCallDiv\"></ng-container>\n}\n\n\n<!-- ////////////// -->\n\n <!-- Active Call Div -->\n \n <ng-template #showActiveCallDiv>\n\n\n @if (showTranscriptionPopup) {\n <div class=\"transcription-popup\">\n <div class=\"transcription-header\">\n <span>Live Transcription</span>\n <button class=\"close-btn\" (click)=\"showTranscriptionPopup = false\">\u00D7</button>\n </div>\n <div class=\"transcription-body\">\n <p>{{ transcriptText }}</p>\n </div>\n </div>\n}\n\n\n\n\n\n\n\n<div class=\"container_call\">\n <div class=\"container_call_header\">\n <div class=\"container_call_header_inner\">\n\n @if (!conferenceParticipants || conferenceParticipants.length <= 1) {\n <!-- ------------ add call list swap and merge area start ---------------- -->\n @if (activeCalls.length > 1) {\n <div class=\"container_swap_merge_list\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_swap_merge\">\n @for (call of activeCalls; track call.phoneNumber; let i = $index) {\n @if (i !== currentActiveCallIndex) {\n <div class=\"container_swap_merge_item\"\n (click)=\"swapLinesToIndex(i)\"\n [ngClass]=\"{ 'active-call': i === currentActiveCallIndex, 'other-call': i !== currentActiveCallIndex }\">\n\n <!-- Avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_swap_merge_item_image_inner\">\n <!-- svg avatar here -->\n </div>\n </div>\n\n <!-- Call Info -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">{{ call.phoneNumber }}</div>\n @if (call.isOnHold) {\n <div class=\"onhold_st\">On hold</div>\n }\n </div>\n\n <!-- Action Buttons -->\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <!-- merge svg -->\n </div>\n <div class=\"button_text\">Merge</div>\n </button>\n </div>\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <!-- swap svg -->\n </div>\n <div class=\"button_text\">Swap</div>\n </button>\n </div>\n </div>\n </div>\n </div>\n }\n }\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n <!-- ------------ add call list swap and merge area end ---------------- -->\n\n @if (isCalling) {\n <div class=\"container_call_info\">Calling...</div>\n } @else {\n @if (isactiveCall) {\n <div class=\"container_call_info\">\n {{ formatTime(activeCalls[currentActiveCallIndex].duration) }}\n </div>\n }\n @if (showCallDisconnected) {\n <div class=\"container_call_info_blinker\">\n <!-- disconnected svg -->\n {{ this.istransfer ? 'Call Transferred' : 'Call ended' }}\n </div>\n }\n }\n\n <div class=\"container_call_ani\">\n @if (isCalling && displayCallingNumber && activeCalls.length === 0) {\n <!-- show what the user dialed while call is spinning up -->\n <div class=\"container_call_ani_number\">\n {{ displayCallingNumber }}\n </div>} \n @else if (activeCalls.length > 0) {\n <div class=\"container_call_ani_number\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.country?.flag }}\n {{ activeCalls[currentActiveCallIndex].phoneNumber }}\n \n </div>\n <div class=\"container_call_ani_name\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.phoneNumber?.location }}\n </div>\n } @else {\n <div class=\"container_call_ani_number\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.country?.flag }}\n {{ lastDisconnectedCall?.phoneNumber }}\n </div>\n <div class=\"container_call_ani_name\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.phoneNumber?.location }}\n </div>\n }\n\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\" [ngClass]=\"{ 'call_animation': isactiveCall }\">\n <!-- big avatar svg -->\n </div>\n </div>\n </div>\n\n } @else {\n <!-- Conference Call Placeholder -->\n <!-- @if block can render conference call template here -->\n }\n\n </div>\n </div>\n\n <div class=\"container_call_content\">\n <div class=\"container_call_dnis\">\n <span>Ext. {{ extensionNumber }}</span>\n </div>\n\n <div class=\"container_call_options\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall && activeCalls.length < 4 }\"\n (click)=\"onAddCall()\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\"> \n <svg fill=\"#000000\" width=\"20\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\"\n xml:space=\"preserve\">\n <path fill=\"currentColor\" d=\"M30,29h16.5c0.8,0,1.5-0.7,1.5-1.5v-3c0-0.8-0.7-1.5-1.5-1.5H30c-0.6,0-1-0.4-1-1V5.5C29,4.7,28.3,4,27.5,4\n h-3C23.7,4,23,4.7,23,5.5V22c0,0.6-0.4,1-1,1H5.5C4.7,23,4,23.7,4,24.5v3C4,28.3,4.7,29,5.5,29H22c0.6,0,1,0.4,1,1v16.5\n c0,0.8,0.7,1.5,1.5,1.5h3c0.8,0,1.5-0.7,1.5-1.5V30C29,29.4,29.4,29,30,29z\" />\n </svg>\n </div>\n <div class=\"button_text\">Add</div>\n </button>\n\n @if (activeCalls.length > 0) {\n <button class=\"button_call_option\" (click)=\"onAddCall()\" type=\"button\">\n <div class=\"button_icon\"> <svg width=\"20\" viewBox=\"0 0 52 52\" aria-hidden=\"true\">\n <path fill=\"currentColor\"\n d=\"M30,29h16.5c0.8,0,1.5-0.7,1.5-1.5v-3c0-0.8-0.7-1.5-1.5-1.5H30c-0.6,0-1-0.4-1-1V5.5C29,4.7,28.3,4,27.5,4h-3\n C23.7,4,23,4.7,23,5.5V22c0,0.6-0.4,1-1,1H5.5C4.7,23,4,23.7,4,24.5v3C4,28.3,4.7,29,5.5,29H22c0.6,0,1,0.4,1,1v16.5\n c0,0.8,0.7,1.5,1.5,1.5h3c0.8,0,1.5-0.7,1.5-1.5V30C29,29.4,29.4,29,30,29z\"/>\n </svg></div>\n <div class=\"button_text\">Conference</div>\n </button>\n }\n\n @if (!isRecording) {\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\"> <svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n <div class=\"button_text\">Record</div>\n </button>\n } @else {\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\"><svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n <div class=\"button_text\">Stop</div>\n </button>\n }\n\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\"\n (click)=\"isCallTransferOpen = !isCallTransferOpen\">\n <div class=\"button_icon\"> <svg width=\"25px\" height=\"25px\" viewBox=\"0 0 48 48\" version=\"1\" enable-background=\"new 0 0 48 48\">\n <path fill=\"currentColor\"\n d=\"M39.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4h-4.8c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L41,8.4C40.5,7.9,39.7,7.9,39.2,8.4z\" />\n <path fill=\"currentColor\"\n d=\"M11.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4H8.5c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L13,8.4C12.5,7.9,11.7,7.9,11.2,8.4z\" />\n <g fill=\"currentColor\">\n <polygon points=\"25.3,18.6 30.7,24 25.3,29.4\" />\n <rect x=\"16\" y=\"22\" width=\"11\" height=\"4\" />\n </g>\n </svg></div>\n <div class=\"button_text\">Transfer</div>\n </button>\n\n @if (isCallTransferOpen) {\n <ng-container *ngTemplateOutlet=\"callTransferTemplate\"></ng-container>\n }\n </div>\n\n <!-- Mute / Unmute -->\n <div class=\"container_dialpad_row\">\n @if (activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isMuted) {\n <button class=\"button_call_option button_elevated\"\n (click)=\"toggleMute()\"\n [ngClass]=\"{ 'button_disabled': showCallDisconnected }\">\n <div class=\"button_icon\"> <svg viewBox=\"0 0 384 512\" width=\"16\">\n <path fill=\"currentColor\"\n d=\"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40z\" />\n </svg></div>\n <div class=\"button_text\">Mute</div>\n </button>\n } @else if (activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isMuted) {\n <button class=\"button_call_option button_active button_elevated\" (click)=\"toggleMute()\">\n <div class=\"button_icon\"> <svg width=\"26\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c15.2-26 23.9-56.3 23.9-88.7l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 21.2-5.1 41.1-14.2 58.7L416 300.8 416 96c0-53-43-96-96-96s-96 43-96 96l0 54.3L38.8 5.1zM344 430.4c20.4-2.8 39.7-9.1 57.3-18.2l-43.1-33.9C346.1 382 333.3 384 320 384c-70.7 0-128-57.3-128-128l0-8.7L144.7 210c-.5 1.9-.7 3.9-.7 6l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6z\" />\n </svg></div>\n <div class=\"button_text\">Unmute</div>\n </button>\n }\n\n <!-- Hold / Unhold -->\n @if (activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isOnHold) {\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\"\n (click)=\"toggleHold()\">\n <div class=\"button_icon\"> <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg></div>\n <div class=\"button_text\">Hold</div>\n </button>\n } @else if (activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isOnHold) {\n <button class=\"button_call_option button_active button_elevated\" (click)=\"toggleHold()\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg></div>\n <div class=\"button_text\">Unhold</div>\n </button>\n \n }\n\n <!-- Keypad -->\n <button class=\"button_call_option button_elevated\"\n [class.button_active]=\"isDailpadOpen\"\n (click)=\"menuDailpad()\"\n [ngClass]=\"{ 'button_disabled': showCallDisconnected }\">\n <div class=\"button_icon\"> <svg width=\"22px\" height=\"22px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n </svg></div>\n <div class=\"button_text\">{{ isDailpadOpen ? 'Hide' : 'Keypad' }}</div>\n </button>\n\n @if (isDailpadOpen) {\n <div class=\"container_popup_dialpad\">\n <div class=\"container_popup_dialpad_inner\">\n <div [formGroup]=\"dtmfForm\">\n <div class=\"container_dtmf_input\">\n <input type=\"tel\" formControlName=\"dtmf\">\n </div>\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n\n <!-- Call Control Buttons -->\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n @if (!showCallDisconnected || isCalling) {\n <button class=\"button_dialpad_digit button_call_red\" (click)=\"dropCurrentCall()\">\n <svg width=\"25\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg>\n </button>\n } @else if (showCallDisconnected && !isCalling) {\n <button class=\"button_dialpad_digit button_call_green\"\n (click)=\"onRedial()\"\n [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n }\n </div>\n </div>\n </div>\n</div>\n</ng-template>\n\n\n <!-- ////////////////// -->\n <!-- Conference Call Template -->\n <ng-template #conferenceCallTemplate>\n<div class=\"container_active_call_header\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">Conference call</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">\n with {{ conferenceParticipants?.length }} people\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"container_active_call_options\">\n <div class=\"button_active_call_options button_active_call_options_highlighted\">\n <span (click)=\"isConfereceList = !isConfereceList\" class=\"container_active_call_options_button\">\n <svg viewBox=\"0 0 448 512\" width=\"16px\">\n <path fill=\"currentColor\"\n d=\"M201.4 374.6c12.5 12.5 32.8 12.5 45.3 0l160-160c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 306.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160z\" />\n </svg>\n </span>\n </div>\n </div>\n</div>\n\n<!-- Conference List -->\n@if (isConfereceList) {\n <div class=\"container_conference_contact_list\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox container_conference_contact_list_scrollbox\">\n <div class=\"scrollbox-content\">\n\n @for (person of conferenceParticipants; track person.id) {\n <div class=\"container_conference_contact_item\">\n <!-- Avatar -->\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <!-- Name and Time -->\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ person.name }}</div>\n <div class=\"contact_field_green\">{{ person.duration }}</div>\n </div>\n </div>\n\n <!-- End Button -->\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <button class=\"button_disconnect_call\">\n <svg width=\"22\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\">\n </path>\n </svg>\n </button>\n </div>\n </div>\n </div>\n\n @if (!$last) {\n <div class=\"container_separator\"></div>\n }\n }\n\n </div>\n </div>\n </div>\n </div>\n}\n\n</ng-template>\n\n\n <ng-template #callTransferTemplate>\n <div class=\"container_transfer_call\">\n <div class=\"container_transfer_call_inner\">\n <div class=\"container_button_close\">\n <span (click)=\"isCallTransferOpen = false\" title=\"Close\">\n <i class=\"fa-sharp fa-solid fa-xmark\"></i>\n </span>\n </div>\n\n <!-- First Div -->\n <div class=\"container_transfer_call_content\" @slideInOut>\n @if (currentView === 'transferListpage') {\n <div class=\"container_active_call_duration\">{{ formatTime(callDuration)}}</div>\n\n <div class=\"container_active_call_header margin_bottom_16 shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">{{ lookupPhoneNumber?.country?.flag }}\n {{ lookupPhoneNumber?.phoneNumber }}</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">Active call</div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">Ext. {{extensionNumber}}</span>\n </div>\n </div>\n </div>\n\n <!-- Tabs -->\n <div class=\"container_transfer_tab_buttons\">\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab1')\" [class.active]=\"activeTab === 'tab1'\">\n <svg width=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg> Recent</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab2')\" [class.active]=\"activeTab === 'tab2'\">\n <svg width=\"20px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\"\n d=\"M15.71,12.71a6,6,0,1,0-7.42,0,10,10,0,0,0-6.22,8.18,1,1,0,0,0,2,.22,8,8,0,0,1,15.9,0,1,1,0,0,0,1,.89h.11a1,1,0,0,0,.88-1.1A10,10,0,0,0,15.71,12.71ZM12,12a4,4,0,1,1,4-4A4,4,0,0,1,12,12Z\" />\n </svg> Internal</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab3')\" [class.active]=\"activeTab === 'tab3'\">\n <svg width=\"18px\" height=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" /></svg>\n Dail</button>\n </div>\n\n <!-- Tab 1 -->\n @if (activeTab === 'tab1') {\n <!-- <div class=\"container_transfer_tab_content\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div> -->\n <div class=\"container_transfer_tab_content\">\n <app-call-history [mode]=\"'transfer'\" (transferEv)=\"transferToFromHistory($event)\"> </app-call-history>\n</div>\n }\n\n <!-- Tab 2 -->\n @if (activeTab === 'tab2') {\n <div class=\"container_transfer_tab_content\">\n <div class=\"container_transfer_internal_search\">\n <input type=\"search\" placeholder=\"Type to search\">\n </div>\n <div class=\"container_transfer_contact_list\">\n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <!-- Instead of repeating static contacts, render via array -->\n @for (contact of internalContacts; track contact.ext) {\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails'); makeCallFromContact(contact.phone)\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ contact.name }}</div>\n <div class=\"contact_field\">{{ contact.phone }}</div>\n @if (contact.role) {\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>{{ contact.role }}</span></div>\n </div>\n }\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. {{ contact.ext }}</span>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n\n <!-- Tab 3 -->\n @if (activeTab === 'tab3') {\n <div class=\"container_transfer_tab_content\">\n <form [formGroup]=\"transferForm\">\n <div class=\"container_transfer_contact_list\">\n <div class=\"container_phone_number_input margin_bottom_16\">\n <button class=\"button_phonebook\" (click)=\"isDirectoryOpen = !isDirectoryOpen\">\uD83D\uDCD6</button>\n <input placeholder=\"Phone Number\" type=\"tel\" formControlName=\"target\">\n <button class=\"button_backspace\" (click)=\"onBackspace()\"></button>\n </div>\n\n @if (isDirectoryOpen) {\n <div class=\"container_transfer_internal_contact_list\">\n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n @for (directoryContact of directoryContacts; track directoryContact.id) {\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ directoryContact.name }}</div>\n <div class=\"contact_field\">{{ directoryContact.phone }}</div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n @for (star of [1,2,3,4,5]; track $index) {\n <span [class.filled]=\"star <= directoryContact.rating\">\u2605</span>\n }\n </div>\n </span>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n }\n\n <!-- Dialpad -->\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\" d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9\n 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7\n 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8\n 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32\n 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9\n 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38\n 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86\n 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\" d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3\n36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4\n26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9\n0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5\n69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1\n0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2\n384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64\n192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4\n19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg></button>\n </div>\n </div>\n\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n @if (isAddingNewCall) {\n <button class=\"button_dialpad_digit button_call_green\"\n (click)=\"makeCall(transferForm.value.target)\"\n [disabled]=\"!phoneNumber\"\n [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n } @else {\n <button type=\"submit\" class=\"button_dialpad_digit button_call_green\" (click)=\"onTransferCall()\"> <svg height=\"20px\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\" xml:space=\"preserve\">\n <g>\n <path fill=\"currentColor\" d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8\n c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3\n c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\" />\n <path fill=\"currentColor\" d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0\n l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\" />\n </g>\n </svg></button>\n }\n </div>\n </div>\n </div>\n </form>\n </div>\n }\n }\n</div>\n\n <!-- Second Div -->\n @if (currentView === 'transferDetails') {\n <div class=\"container_transfer_call_content\" @slideInOut>\n <div class=\"container_active_call_duration\">00:10</div>\n <div class=\"container_active_call_header shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\"></path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 ...\"></path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 ...\"></path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">\n {{ lookupPhoneNumber?.country?.flag }} {{ lookupPhoneNumber?.phoneNumber }}\n </div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_grey\">\n <svg viewBox=\"0 0 320 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\"></path>\n </svg>\n </div>\n <div class=\"container_active_call_status_grey\">On hold</div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">Ext. {{ extensionNumber }}</span>\n </div>\n </div>\n </div>\n\n <div class=\"container_transfer_call_details\">\n <div class=\"container_call_ani_number padding_top_nt\">+91 (654) 9876549</div>\n <div class=\"container_call_ani_name\">Rajeev kumar singh</div>\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"85\" width=\"85\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\"></path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 ...\"></path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 ...\"></path>\n </g>\n </svg>\n </div>\n </div>\n </div>\n\n <div class=\"container_call_dnis\">\n <span>Ext. {{ extensionNumber }}</span>\n </div>\n\n <div class=\"container_call_options margin_bottom_nt\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option\" (click)=\"mergeCall()\">\n <div class=\"button_icon\"><svg width=\"22\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l97.2 0c9.7 0 18.9 4.4 25 12L247 256 154.2 372c-6.1 7.6-15.3 12-25 12L32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l97.2 0c29.2 0 56.7-13.3 75-36l99.2-124 80.6 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c6-6 9.4-14.1 9.4-22.6s-3.4-16.6-9.4-22.6l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-80.6 0L204.2 100c-18.2-22.8-45.8-36-75-36L32 64z\"></path>\n </svg></div>\n <div class=\"button_text\">Merge</div>\n </button>\n\n <button class=\"button_call_option\">\n <div class=\"button_icon\"> <svg width=\"26px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M150.6 73.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 173.3 96 320c0 53 43 96 96 96l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-146.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96zM336 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32-14.3 32-32l0 146.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L544 338.7 544 192c0-53-43-96-96-96L336 96z\"></path>\n </svg></div>\n <div class=\"button_text\">Swap</div>\n </button>\n\n <button class=\"button_call_option\">\n <div class=\"button_icon\"><svg width=\"19px\" viewBox=\"0 0 52 52\">\n <path fill=\"currentColor\"\n d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8 c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3 c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\"></path>\n <path fill=\"currentColor\"\n d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0 l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\"></path>\n </svg>\n</div>\n <div class=\"button_text\">Transfer</div>\n </button>\n </div>\n </div>\n\n <div class=\"container_transfer_disconnect\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit button_call_red\" (click)=\"goToDiv('transferListpage')\">\n <svg width=\"36px\" viewBox=\"0 0 76 76\">\n <path fill=\"currentColor\"\n d=\"M 16.2013,39.582L 15.4175,39.4096L 14.8094,38.9315L 14.4029,38.2193L 14.25,37.364L 14.25,34.9055C 14.25,33.184 14.6023,31.6057 15.3069,30.1704C 16.0116,28.7352 16.9698,27.4788 18.1818,26.4013C 19.3937,25.3237 20.8095,24.4424 22.429,23.7573C 24.0486,23.0722 25.7732,22.6277 27.6031,22.4239L 31.304,22.0792L 34.9918,21.8256L 39.109,21.715L 42.966,21.8451L 46.101,22.0987L 48.9628,22.489C 50.7276,22.7318 52.3883,23.199 53.945,23.8906C 55.5017,24.5822 56.8567,25.4625 58.0101,26.5313C 59.1635,27.6002 60.0752,28.8468 60.7451,30.2712C 61.4151,31.6956 61.75,33.2599 61.75,34.964L 61.75,37.4486L 61.5874,38.2681L 61.1386,38.9511L 60.4785,39.4096L 59.6752,39.582L 51.8897,39.582L 51.0994,39.4096L 50.4588,38.9413L 50.0327,38.2584L 49.8799,37.4226L 49.8799,32.1217L 49.7075,31.1656L 49.2295,30.3818L 48.5075,29.8452C 48.23,29.7108 47.9286,29.6436 47.6034,29.6436L 28.7413,29.6436C 28.4161,29.6436 28.0974,29.7108 27.7852,29.8452L 26.9722,30.3818L 26.4128,31.1851C 26.2697,31.4973 26.1982,31.8225 26.1982,32.1607L 26.1982,37.364L 26.0356,38.2193L 25.5803,38.9315L 24.9104,39.4096L 24.1038,39.582L 16.2013,39.582 Z M 34.8333,41.1667L 41.1666,41.1667L 41.1667,52.6458L 45.9167,47.8958L 45.9167,54.2292L 38,62.5417L 30.0833,54.2292L 30.0833,47.8958L 34.8333,52.6458L 34.8333,41.1667 Z \" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n}\n\n\n\n\n\n\n\n\n\n\n\n </div>\n </div>\n </ng-template>\n\n \n\n\n</ng-template>\n\n<div id=\"videoPanel\" style=\"display: none\">\n <audio #rmtAudio id=\"rmtAudio\" autoplay></audio>\n <audio #lclAudio id=\"lclAudio\" autoplay muted></audio>\n <video #rmtVideo id=\"rmtVideo\" autoplay></video>\n <video #lclVideo id=\"lclVideo\" autoplay muted controls title=\"Local Video\"></video>\n</div>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Open+Sans:300,400,500,600,700,800\";@import\"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css\";:host{--sd-app-color: #ff6633;--sd-app-color-dark: #ff5805;--sd-app-color-light: #fe8c66;--sd-text-font-family: \"Open Sans\", \"sans-serif\", \"Helvetica Neue\", \"Helvetica\", \"Arial\";--sd-text-color: #666;--sd-text-color-inverse: #fff;--sd-text-color-light: #ccc;--sd-text-color-medium: #999;--sd-text-color-dark: #333;--sd-background-color: #fff;--sd-border-color-light: #e3e3e3;--sd-border-color-dark: #c9c9c9}.message_label{width:100%;font-size:13px;font-family:var(--sd-text-font-family);letter-spacing:-.25px;border-radius:4px;font-weight:600;border:1px solid #f5c6cb;padding:8px 11px;position:relative}.error_message{color:#e1143c;background-color:#f8d7da;border-color:#dfadb2}.success_message{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert_message{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.properties_form_field{width:100%;font-size:13px!important;font-family:var(--sd-text-font-family)!important;font-weight:600!important;letter-spacing:-.24px!important;color:#555!important}.container_avaya_login{width:100%;height:calc(100vh - 51px);padding:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.container_avaya_login_inner{margin:0 auto;width:100%;max-width:370px;padding:65px 20px 20px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex}.container_connection_status_overlay{width:100%;height:100%;position:absolute;left:0;right:0;bottom:0;background-color:#6669;display:flex;justify-content:center;z-index:9999999;padding:20px}.container_connection_status{width:100%;background:var(--sd-background-color);padding:0 10px;border-radius:8px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);display:flex;height:42px;align-items:center;position:relative;box-shadow:#32325d40 0 6px 12px -2px,#0000004d 0 3px 7px -3px}.container_connection_status span{padding:0 0 0 8px}.container_connection_status .fa-circle-dot{color:#f66060}.container_connection_status_loader{position:absolute;right:15px}.container_avaya_login_content{position:relative;width:100%}.container_avaya_logo{margin:0;padding:0 26px 24px;width:100%;text-align:center}.container_avaya_logo_image{margin:0 auto;width:120px;height:35px;background:var(--sd-background-color) url() center no-repeat;background-size:120px}.container_avaya_logo h3{margin:0;padding:6px 0 0;font-family:var(--sd-text-font-family);font-size:18px;font-weight:700;letter-spacing:-.45px;color:var(--sd-text-color-dark);position:relative}.container_avaya_logo h3 span{font-size:8px;position:absolute;top:8px}.container_avaya_login_error{width:100%;white-space:normal}.container_avaya_login_form{width:100%;margin:0;padding:26px 0 0;position:relative}.container_avaya_login_form form{width:100%;margin:0;padding:0}.container_avaya_login_form .form_field{margin:0;padding:0;width:100%}.avaya_login_button_area{padding:10px 0 0}.container_icon_eye{position:absolute;right:15px}.container_avaya_login_form .button_submit_login{font:14px / 48px var(--sd-text-font-family);display:inline-block;height:48px;background:#cd1f1e;color:var(--sd-text-color-inverse);border:1px solid #cd1f1e;font-weight:600;padding:0 12px;border-radius:4px;outline:none;letter-spacing:-.24px;cursor:pointer;width:100%;position:relative}.container_avaya_login_form .button_submit_login_loader{background:#cd1f1e!important;color:var(--sd-text-color-inverse)!important;border:1px solid #cd1f1e!important;cursor:auto}.container_avaya_login_form .button_submit_login:disabled{background:#f1f1f1;color:var(--sd-text-color-medium);border:1px solid #f1f1f1}.button_submit_loader:after{content:\"\";position:absolute;width:16px;height:16px;inset:0;margin:auto;border:3px solid transparent;border-top-color:#fff;border-radius:50%;animation:button_submit_loader_spinner 1s ease infinite}@keyframes button_submit_loader_spinner{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.container_avaya_softphone{width:100%;height:100%;position:relative}.container_avaya_softphone_inner{width:100%;position:absolute;top:0;left:0;right:0;padding:0;height:calc(100% - 51px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background:#000}.container_call{margin:0 auto;padding:0;position:relative;width:100%;height:100%;background:var(--sd-background-color)}.container_dialpad_header{width:100%;position:relative;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99999;background:var(--sd-background-color);padding:15px 15px 0}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px 15px 0;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_avaya_extension{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:8px 10px;border:1px solid var(--sd-border-color-light);border-radius:12px;margin-bottom:15px;background:#f0f0f0}.container_avaya_extension_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center}.container_avaya_extension_left .extension_label{display:flex;align-items:center;line-height:normal;text-align:left}.container_avaya_extension_left .extension_number{display:flex;align-items:center;line-height:20px}.container_avaya_extension_right{flex-basis:auto;flex-direction:column;flex-grow:1;text-align:right;justify-items:flex-end}.container_avaya_extension_right button{background:none;border:none;outline:none;color:#a6a6a6;font-weight:600;border-radius:50%;align-items:center;justify-content:center;-webkit-transition-duration:.3s;transition-duration:.3s;background:#f0f0f0;height:38px;width:38px}.container_avaya_extension_right button:hover{color:var(--sd-text-color-dark);background:var(--sd-border-color-light)}.dialpad_container_sd{position:absolute;width:100%;right:0;left:0;top:101px;height:calc(100vh - 101px);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}.container_call_header{width:100%;position:absolute;top:0;left:0;right:0;height:221px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_call_header_inner{width:100%;margin:0;padding:10px 15px 15px;position:relative}.container_call_info{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color)}.container_call_info_blinker{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:red;animation:blinker 1s linear infinite}@keyframes blinker{26%{opacity:0}}.container_call_ani{width:100%;margin:0;padding:0}.container_call_ani_number{text-align:center;font-size:20px;font-weight:600;padding-top:26px}.container_call_ani_name{text-align:center;font-size:13px;font-weight:600;padding-top:2px}.container_call_ani_image{margin:0;padding:24px 0 0;width:100%}.container_call_ani_image_inner{display:flex;align-items:center;flex:0 0 auto;padding:0;width:85px;height:85px;position:relative;margin:0 auto;border-radius:100%}.container_call_content{width:100%;position:absolute;top:221px;left:0;right:0;height:calc(100% - 221px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding-top:20px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_call_dnis{width:100%;text-align:center;padding-bottom:16px}.container_call_dnis span{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 16px}.container_call_options{width:100%;display:flex;justify-content:center;margin-bottom:16px;flex-direction:column}.button_call_option{display:block;width:80px;height:60px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative}.button_call_option .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_call_option .button_text{display:flex;justify-content:center;color:var(--sd-text-color)}.button_active{color:#67cc02}.button_elevated{position:relative;z-index:9999}.button_disabled{color:gray;cursor:not-allowed;pointer-events:none;opacity:.6}.button_call_option[disabled],.button_disabled{opacity:.5;pointer-events:none;display:inline-flex}.container_popup_dialpad{position:absolute;z-index:999;left:0;right:0;bottom:0}.container_popup_dialpad_inner{background:#f1f1f1;background:linear-gradient(180deg,#f1f1f1 44%,#fff);margin:0 auto;padding:10px 15px 20px;border-radius:8px;width:88%;position:relative;height:475px}.container_popup_dialpad .button_close{position:absolute;right:-15px;top:-17px;z-index:9}.container_popup_dialpad .button_close span{width:32px;height:32px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.container_popup_dialpad .button_close span:hover{background:#f1f1f1;color:var(--sd-text-color-dark)}.container_popup_dialpad .button_close span .fa-xmark{font-size:1.4em;font-weight:400}.container_dtmf_input{width:100%;margin:0;padding:0 0 10px;position:relative}.container_dtmf_input input{width:100%;display:flex;height:38px;outline:none;text-align:center;align-items:center;border:1px solid #f1f1f1;font-size:26px;font-weight:400;color:transparent;text-shadow:0 0 0 #000;padding:0;background:#f1f1f1}.container_active_call_header{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:12px;overflow:hidden}.container_active_call_avatar{display:flex}@keyframes play1{0%{transform:scale(1)}15%{box-shadow:0 0 0 2px #57b84666}25%{box-shadow:0 0 0 3px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 5px #bde4a966,0 0 0 30px #fff3}}.container_active_call_avatar_inner{margin:0 auto;padding:0;width:50px;height:50px;background:#dfe6e8;color:var(--sd-text-color-dark);position:relative;animation:play1 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden;border-radius:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.container_active_call_info{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_active_call_info_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_active_call_duration{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color);margin-bottom:10px}.container_active_call_number{font-size:13px;margin-bottom:2px}.container_active_call_details{font-size:13px;color:#6c0;padding-top:2px}.container_active_call_details_inner{display:flex;margin:0;padding:0;justify-content:left}.container_active_call_icon_grey{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:var(--sd-text-color-medium)}.container_active_call_icon_green{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:#6c0}.container_active_call_status_green{display:flex;justify-content:center;align-items:center;color:#6c0;padding-left:6px;font-size:12px}.container_active_call_status_grey{display:flex;justify-content:center;align-items:center;color:var(--sd-text-color-medium);padding-left:6px;font-size:12px}.container_active_call_options{display:flex;flex-direction:row}.container_active_call_options .button_active_call_options{display:flex;flex-basis:auto;justify-content:right}.container_active_call_options .button_active_call_options_highlighted{font-size:16px;color:#29abe0}.container_active_call_options_button{display:flex;border-radius:26px;border:none;padding:0;font-size:11px;color:var(--sd-text-color);width:32px;height:32px;justify-content:center;align-items:center}.container_active_call_options_button:hover{background:#f1f1f1}.container_conference_contact_list{position:relative;width:100%;background:#f7f7f7;border-top:1px solid #eee;border-bottom:1px solid #eee;height:149px;padding:0;margin-top:16px}.container_swap_merge_contact_list{position:relative;width:100%;background:var(--sd-background-color);height:149px;padding:0;margin-top:32px}.container_conference_contact_list_inner{margin:0;padding:0;position:relative;width:100%;height:100%}.container_conference_contact_list_scrollbox{padding:12px 15px}.container_conference_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:0 10px;overflow:hidden;cursor:pointer}.button_disconnect_call{display:block;width:42px;height:42px;display:flex;margin:0;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;color:#e0261f;background:#f7f7f7;-webkit-transition-duration:.3s;transition-duration:.3s}.button_disconnect_call:hover{color:var(--sd-text-color-inverse);background:#e0261f;-webkit-transition-duration:.3s;transition-duration:.3s}.container_separator{height:1px;width:100%;background:#ededed;margin:11px 0}.container_transfer_call{position:absolute;z-index:99999;left:0;right:0;bottom:-51px;width:100%;background:var(--sd-background-color)}.container_transfer_call_inner{background:var(--sd-background-color);box-shadow:#11111a1a 0 4px 16px,#11111a0d 0 8px 32px;padding:20px 15px 10px;border-radius:0;width:100%;position:relative;height:596px;overflow:hidden}.container_transfer_call_inner h2{font-family:var(--sd-text-font-family);font-size:20px;font-weight:700;color:var(--sd-text-color-dark);letter-spacing:-1px;padding:0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_button_close{position:absolute;right:4px;top:4px}.container_button_close span{width:36px;height:36px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer}.container_button_close span:hover{background:var(--sd-background-color)}.container_button_close .fa-xmark{font-size:1.6em;font-weight:400;color:var(--sd-text-color-light)}.container_button_close span:hover .fa-xmark:hover{color:var(--sd-text-color-dark)}.container_transfer_call_content{margin:0;padding:5px 0 0;width:100%;background:var(--sd-background-color);min-height:485px}.container_transfer_call_content h3{font-family:var(--sd-text-font-family);font-size:14px;font-weight:700;color:var(--sd-text-color);letter-spacing:-.26px;padding:8px 0 0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_transfer_call_content h3 span{color:var(--sd-text-color-dark)}.container_transfer_call_details{width:100%;margin:0;padding:10px 15px 69px;position:relative}.container_transfer_tab_buttons{display:flex;gap:10px;align-items:center;margin-bottom:15px}.button_transfer_tab{padding:10px;border:none;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);background-color:var(--sd-border-color-light);cursor:pointer;width:105px;border-radius:28px;outline:none}.button_transfer_tab.active{background-color:var(--sd-app-color);color:#fff}.container_transfer_tab_content{margin:0;padding:0;width:100%}.container_transfer_internal_search{margin:0 0 15px;padding:0;width:100%}.container_transfer_internal_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:48px}.container_transfer_contact_list{width:100%;margin:0;padding:0;position:relative;height:336px}.container_transfer_contact_list_inner{width:100%;position:relative;height:100%}.container_transfer_internal_contact_list{position:absolute;width:100%;left:0;right:0;background:var(--sd-background-color);height:332px}.container_transfer_disconnect{width:100%;display:flex;justify-content:center;padding-top:3px;margin-bottom:6px}.container_avaya_footer{width:100%;padding:0;background:#f7f7f7;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color-medium);position:relative;display:flex;height:51px;justify-content:center;align-items:center;border-top:1px solid var(--sd-border-color-light);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:999;position:absolute;bottom:0;left:0}.margin_bottom_16{margin-bottom:16px}.margin_bottom_nt{margin-bottom:10px}.padding_top_nt{padding-top:7px}.shadow_st{box-shadow:#00000026 0 2px 8px}.call_animation{animation:play 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden}.mini-call-switcher{display:flex;justify-content:center;margin-top:10px}.mini-call{padding:6px 12px;margin:0 6px;background:#eaeaea;border-radius:8px;cursor:pointer;font-size:14px}.mini-call.active{background-color:#c6f6d5;font-weight:700}.history-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}.history-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--sd-background-color);padding:20px;z-index:1000;box-shadow:0 2px 10px #0000004d;border-radius:5px;width:600px;max-height:80vh;overflow-y:auto}.history-content{position:relative}.history-content h3{margin-top:0}.close-btn{background:transparent;border:none;font-size:1.5rem;position:absolute;top:0;right:0;cursor:pointer}.history-content table{width:100%;border-collapse:collapse;margin-top:1rem}.history-content th,.history-content td{padding:.5rem;border:1px solid var(--sd-text-color-light)}@keyframes play{0%{transform:scale(1)}15%{box-shadow:0 0 0 4px #57b84680}25%{box-shadow:0 0 0 5px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 10px #c2e5b180,0 0 0 30px #fff3}}::-webkit-input-placeholder{color:#ddd}::-moz-placeholder{color:var(--sd-text-color-dark)}:-ms-input-placeholder{color:var(--sd-text-color-dark)}:-moz-placeholder{color:var(--sd-text-color-dark)}.slide_st{left:-100px;-webkit-animation:slide .5s forwards;-webkit-animation-delay:2s;animation:slide .5s forwards;animation-delay:0s}@-webkit-keyframes slide{to{left:0}}@keyframes slide{to{left:0}}.tabs_sd{width:100%;position:absolute;bottom:0;left:0;right:0;display:flex;height:51px;border-top:1px solid var(--sd-border-color-light);background:#f9f9f9;z-index:999999}.tab_heading_btn{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;align-items:center;padding:0;border:none;cursor:pointer;width:25%;font-family:var(--sd-text-font-family);font-size:11px;font-weight:600;line-height:normal;color:var(--sd-text-color-medium);background:none;transition:background-color .3s linear;-webkit-transition:background-color .3s linear;-o-transition:background-color .3s linear;-ms-transition:background-color .3s linear}.nav_icon{display:flex;align-items:center;justify-content:center;height:22px;margin-bottom:1px}.nav_heading_sd{display:flex;align-items:center}.tab_heading_btn.active{color:var(--sd-app-color);background:url() top center no-repeat}.tab-content_sd{width:100%;height:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative}.container_transfer_fav_list{width:100%;margin:0;padding:0;position:relative;height:376px}.outer_container_swap_merge{width:100%;margin:0;padding:0}.container_swap_merge_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;border-radius:8px;overflow:hidden}.container_recent_item_image{display:flex;align-items:center}.container_swap_merge_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.onhold_st{font-family:var(--sd-text-font-family);font-size:12px;color:var(--sd-text-color-medium);font-weight:600}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.button_swap_merge{display:block;width:32px;height:45px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 0 0 28px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative;pointer-events:all;cursor:pointer}.button_swap_merge .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_swap_merge .button_text{display:flex;justify-content:center;color:var(--sd-text-color-dark)}@media only screen and (max-width: 767px){.previewcontent{width:95%!important}.bgSecWrap .numberArrow{left:0!important;top:-20px!important}.transcription-popup{position:fixed;bottom:20px;right:20px;width:320px;max-height:250px;background:#fff;border-radius:10px;box-shadow:0 4px 12px #0003;padding:12px;z-index:1000;display:flex;flex-direction:column}.transcription-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:14px;margin-bottom:8px}.transcription-body{overflow-y:auto;font-size:13px;line-height:1.4;color:#333}.close-btn{border:none;background:transparent;font-size:18px;cursor:pointer}}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i10.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i10.MatLabel, selector: "mat-label" }, { kind: "directive", type: i10.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i10.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i11.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "directive", type: i5.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }, { kind: "component", type: CallHistoryComponent, selector: "app-call-history", inputs: ["mode"], outputs: ["makeCallEv", "transferEv"] }, { kind: "component", type: DialpadComponent, selector: "app-dialpad", inputs: ["contacts"], outputs: ["makeCallEv"] }, { kind: "component", type: DeviceSelectorComponent, selector: "app-device-selector", inputs: ["selectedAudioInputId", "selectedAudioOutputId"], outputs: ["change"] }], animations: [
|
|
2027
2686
|
trigger('slideInOut', [
|
|
2028
2687
|
transition(':enter', [
|
|
2029
2688
|
style({ transform: 'translateX(100%)', opacity: 0 }),
|
|
@@ -2035,7 +2694,7 @@ class AvayaIPOWidgetComponent {
|
|
|
2035
2694
|
]),
|
|
2036
2695
|
] });
|
|
2037
2696
|
}
|
|
2038
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
2697
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOWidgetComponent, decorators: [{
|
|
2039
2698
|
type: Component,
|
|
2040
2699
|
args: [{ selector: 'snugdesk-avaya-ipo-widget', animations: [
|
|
2041
2700
|
trigger('slideInOut', [
|
|
@@ -2047,8 +2706,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.4", ngImpor
|
|
|
2047
2706
|
animate('300ms ease-out', style({ transform: 'translateX(-100%)', opacity: 0 })),
|
|
2048
2707
|
]),
|
|
2049
2708
|
]),
|
|
2050
|
-
], standalone: false, template: "<div class=\"container_connection_status_overlay\"\n *ngIf=\"isReconnectingInProgress || isFailoverInProgress || isFailbackInProgress\">\n <div class=\"container_connection_status\">\n <i class=\"fa-solid fa-circle-dot\"></i>\n <ng-container *ngIf=\"isReconnectingInProgress\">\n <span>Reconnecting to the server...</span>\n </ng-container>\n\n <ng-container *ngIf=\"isFailoverInProgress\">\n <span>Failover in progress...</span>\n </ng-container>\n\n <ng-container *ngIf=\"isFailbackInProgress\">\n <span>Failback in progress...</span>\n </ng-container>\n <div class=\"container_connection_status_loader\">\n <div class=\"container_three_dot_loader\">\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n </div>\n </div>\n </div>\n</div>\n\n<ng-container *ngIf=\"showLoginForm else showSoftphoneDiv\">\n <div class=\"container_avaya_login\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_avaya_login_inner\">\n <div class=\"container_avaya_login_content\">\n\n <div class=\"container_avaya_logo\">\n <div class=\"container_avaya_logo_image\"></div>\n <h3>IP Office<span>TM</span></h3>\n </div>\n\n <div class=\"container_avaya_login_error\"\n *ngIf=\"hasAvayaSocketError || hasAvayaLoginError || hasAvayaLoginConflictError || hasAvayaDeviceError\">\n <p class=\"message_label error_message\">\n <ng-container *ngIf=\"hasAvayaSocketError\">\n We're having trouble connecting to the server\n </ng-container>\n <ng-container *ngIf=\"hasAvayaLoginError\">\n Invalid extension or password!\n </ng-container>\n <ng-container *ngIf=\"hasAvayaLoginConflictError\">\n Another user is logged in with this extension\n </ng-container>\n <ng-container *ngIf=\"hasAvayaDeviceError\">\n We're having trouble accessing your device\n </ng-container>\n </p>\n </div>\n\n <div class=\"container_avaya_login_form\">\n <form [formGroup]=\"loginForm\" (ngSubmit)=\"onLogin()\">\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Extension</mat-label>\n <input matInput formControlName=\"ipoExtensionNo\" autocomplete=\"ipoExtensionNo\"\n (keypress)=\"restrictNumeric($event)\" />\n <mat-error\n *ngIf=\"loginForm.controls['ipoExtensionNo'].invalid && loginForm.controls['ipoExtensionNo'].touched\">\n <small *ngIf=\"loginForm.controls['ipoExtensionNo'].errors?.['required']\">\n Extension is required.\n </small>\n </mat-error>\n </mat-form-field>\n </div>\n\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Password</mat-label>\n <input matInput formControlName=\"ipoPassword\" autocomplete=\"avaya-ipo-password\"\n (keypress)=\"restrictNumeric($event)\" [type]=\"showLoginPassword ? 'text' : 'password'\" />\n <mat-icon matSuffix (click)=\"showLoginPassword = !showLoginPassword && !hasAvayaSocketError\">\n <ng-container *ngIf=\"showLoginPassword else hideAvayaIPOPassword\">\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye\"></i>\n </span>\n </ng-container>\n <ng-template #hideAvayaIPOPassword>\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye-slash\"></i>\n </span>\n </ng-template>\n </mat-icon>\n <mat-error\n *ngIf=\"loginForm.controls['ipoPassword'].invalid && loginForm.controls['ipoPassword'].touched\">\n <small *ngIf=\"loginForm.controls['ipoPassword'].errors?.['required']\">\n Password is required.\n </small>\n </mat-error>\n </mat-form-field>\n </div>\n\n <div class=\"avaya_login_button_area\">\n <button type=\"submit\" class=\"button_submit_login\"\n [ngClass]=\"{ 'button_submit_login_loader': showLoginLoader }\" [disabled]=\"showLoginLoader\">\n <span *ngIf=\"showLoginLoader else showLoginButton\">\n <span class=\"button_submit_loader\"></span>\n </span>\n <ng-template #showLoginButton>\n <span>Login</span>\n </ng-template>\n </button>\n </div>\n </form>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_avaya_footer\">© 2025 SNUG Technologies Pvt. Ltd.</div>\n</ng-container>\n\n<ng-template #showSoftphoneDiv>\n\n <ng-container *ngIf=\"!showActiveCall else showActiveCallDiv\">\n\n <div class=\"container_avaya_softphone_inner\">\n <!-- ------------------- Keypad work start ---------- -->\n <div class=\"tab-content_sd\" *ngIf=\"bottomActiveTab === 'keypad_sd'\">\n <div class=\"container_dialpad_header\">\n <div class=\"container_dialpad_header_inner2\">\n <div class=\"container_avaya_extension\">\n <div class=\"container_avaya_extension_left\">\n <div class=\"extension_label\">Extension</div>\n <div class=\"extension_number\">{{ extensionNumber }}</div>\n </div>\n <div class=\"container_avaya_extension_right\">\n <button title=\"Sign out\" (click)=\"onLogout()\">\n <svg width=\"16px\" fill=\"currentColor\" viewBox=\"0 0 512 512\">\n <path\n d=\"M377.9 105.9L500.7 228.7c7.2 7.2 11.3 17.1 11.3 27.3s-4.1 20.1-11.3 27.3L377.9 406.1c-6.4 6.4-15 9.9-24 9.9c-18.7 0-33.9-15.2-33.9-33.9l0-62.1-128 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l128 0 0-62.1c0-18.7 15.2-33.9 33.9-33.9c9 0 17.6 3.6 24 9.9zM160 96L96 96c-17.7 0-32 14.3-32 32l0 256c0 17.7 14.3 32 32 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-53 0-96-43-96-96L0 128C0 75 43 32 96 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"dialpad_container_sd\">\n<div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n<app-dialpad [contacts]=\"contacts\" (makeCallEv)=\"makeCall($event)\"></app-dialpad>\n<!-- to do list -->\n </div>\n</div>\n\n\n\n\n\n </div>\n\n </div>\n <!-- ------------------- Keypad work end ---------- -->\n\n <div class=\"tab-content_sd\" *ngIf=\"bottomActiveTab === 'recent_sd'\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div>\n\n <div class=\"tab-content_sd\" *ngIf=\"bottomActiveTab === 'settings_sd'\">\n <app-device-selector (change)=\"handleDeviceSelection($event)\"></app-device-selector>\n </div>\n </div>\n\n\n\n <div class=\"tabs_sd\">\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('recent_sd')\"\n [class.active]=\"bottomActiveTab === 'recent_sd'\">\n <span class=\"nav_icon\"><svg width=\"19px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg></span>\n <span class=\"nav_heading_sd\">Recent</span>\n </button>\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('keypad_sd')\"\n [class.active]=\"bottomActiveTab === 'keypad_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"20px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Keypad</span>\n </button>\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('settings_sd')\"\n [class.active]=\"bottomActiveTab === 'settings_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"19px\" viewBox=\"-0.03 0 16.079 16.079\">\n <g>\n <path fill=\"currentColor\"\n d=\"M8.182 1.083a6.99 6.99 0 0 0-6.248 3.493c-1.929 3.342-.776 7.629 2.57 9.562 3.346 1.934 7.634.792 9.562-2.55 1.929-3.343.776-7.634-2.57-9.567a6.98 6.98 0 0 0-3.314-.938zM8 2.08a6 6 0 0 1 6 6 6 6 0 0 1-6 6 6 6 0 0 1-6-6 6 6 0 0 1 6-6z\"\n style=\"line-height:normal;font-variant-ligatures:none;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;text-transform:none;isolation:auto;mix-blend-mode:normal;marker:none\"\n font-weight=\"400\" font-family=\"sans-serif\" white-space=\"normal\" overflow=\"visible\" />\n <path fill=\"currentColor\"\n d=\"M9.322 0L6.69.393v1.354a6.49 6.477 43.146 0 1 2.632.005V0zM3.937 1.19L1.93 2.897l.988 1.177a6.49 6.477 43.146 0 1 2.017-1.69zm8.128.013l-.993 1.184a6.49 6.477 43.146 0 1 .17.09 6.49 6.477 43.146 0 1 1.845 1.603l1.006-1.197zM.455 5.42l-.44 2.596 1.515.267a6.49 6.477 43.146 0 1 .455-2.593zm15.086.003l-1.523.269a6.49 6.477 43.146 0 1 .464 2.59l1.533-.27zM1.858 10.118l-1.351.78 1.33 2.271 1.339-.772a6.49 6.477 43.146 0 1-1.317-2.28zm12.301.003a6.49 6.477 43.146 0 1-.534 1.215 6.49 6.477 43.146 0 1-.774 1.069l1.338.773 1.302-2.288zm-9.557 3.471l-.534 1.47 2.48.884.525-1.446a6.49 6.477 43.146 0 1-2.303-.8 6.49 6.477 43.146 0 1-.168-.108zm6.814.016a6.49 6.477 43.146 0 1-2.475.897l.53 1.457 2.468-.917z\"\n style=\"marker:none\" overflow=\"visible\" />\n <path fill=\"currentColor\"\n d=\"M7.648 3.093a4.989 4.989 0 0 0-3.982 2.483 5.013 5.013 0 0 0 1.836 6.834 5.002 5.002 0 0 0 6.83-1.827 5.01 5.01 0 0 0-1.836-6.832 4.976 4.976 0 0 0-2.848-.658zM8 4.08a4 4 0 0 1 4 4 4 4 0 0 1-4 4 4 4 0 0 1-4-4 4 4 0 0 1 4-4z\"\n style=\"line-height:normal;font-variant-ligatures:none;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-feature-settings:normal;text-indent:0;text-align:start;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;text-transform:none;isolation:auto;mix-blend-mode:normal;marker:none\"\n font-weight=\"400\" font-family=\"sans-serif\" white-space=\"normal\" overflow=\"visible\" />\n </g>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">\n Preferences\n </span>\n </button>\n </div>\n </ng-container>\n\n <ng-template #showActiveCallDiv>\n\n <div class=\"container_call\">\n <div class=\"container_call_header\">\n <div class=\"container_call_header_inner\">\n <ng-container\n *ngIf=\"!conferenceParticipants || conferenceParticipants.length <= 1 else showConferenceCallDiv\">\n <ng-container>\n\n <!-- ------------ add call list swap and merge area start ---------------- -->\n\n <div class=\"container_swap_merge_list\" *ngIf=\"activeCalls.length > 1\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_swap_merge\">\n <ng-container *ngFor=\"let call of activeCalls; let i = index\">\n <ng-container *ngIf=\"i !== currentActiveCallIndex\">\n <div class=\"container_swap_merge_item\" (click)=\"swapLinesToIndex(i)\"\n [ngClass]=\"{ 'active-call': i === currentActiveCallIndex, 'other-call': i !== currentActiveCallIndex }\">\n <!-- Avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_swap_merge_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"50px\" width=\"50px\" version=\"1.1\" x=\"0px\"\n y=\"0px\" enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\" d=\"M173.561,171.615...\"></path>\n <path fill=\"#FFFFFF\" d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737...\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <!-- Call Info -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">{{ call.phoneNumber }}</div>\n <div class=\"onhold_st\" *ngIf=\"call.isOnHold\">On hold</div>\n </div>\n\n <!-- Action Buttons -->\n <div class=\"container_recent_item_right\">\n <!-- Merge Button -->\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <svg width=\"18\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l97.2 0c9.7 0 18.9 4.4 25 12L247 256 154.2 372c-6.1 7.6-15.3 12-25 12L32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l97.2 0c29.2 0 56.7-13.3 75-36l99.2-124 80.6 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c6-6 9.4-14.1 9.4-22.6s-3.4-16.6-9.4-22.6l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-80.6 0L204.2 100c-18.2-22.8-45.8-36-75-36L32 64z\">\n </path>\n </svg>\n </div>\n <div class=\"button_text\">Merge</div>\n </button>\n </div>\n\n <!-- Swap Button -->\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <svg width=\"22px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M150.6 73.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 173.3 96 320c0 53 43 96 96 96l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-146.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96zM336 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32 14.3 32 32l0 146.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L544 338.7 544 192c0-53-43-96-96-96L336 96z\">\n </path>\n </svg>\n </div>\n <div class=\"button_text\">Swap</div>\n </button>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- ------------ add call list swap and merge area end ---------------- -->\n\n <div class=\"container_call_info\" *ngIf=\"isCalling else showCallStateDiv\">Calling...</div>\n <ng-template #showCallStateDiv>\n <div class=\"container_call_info\" *ngIf=\"isactiveCall\">\n {{ formatTime(activeCalls[currentActiveCallIndex].duration)}}</div>\n <div class=\"container_call_info_blinker\" *ngIf=\"showCallDisconnected\">\n <svg width=\"18px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg> {{ this.istransfer ? 'Call Transferred' : 'Call ended' }}\n </div>\n </ng-template>\n\n <div class=\"container_call_ani\">\n <ng-container *ngIf=\"activeCalls.length >0; else disconnectedBlock\">\n <div class=\"container_call_ani_number\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.country?.flag }}\n {{ activeCalls[currentActiveCallIndex].phoneNumber }}\n </div>\n <div class=\"container_call_ani_name\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.phoneNumber?.location }}\n </div>\n </ng-container>\n\n <ng-template #disconnectedBlock>\n <div class=\"container_call_ani_number\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.country?.flag }}\n {{ lastDisconnectedCall?.phoneNumber }}\n </div>\n <div class=\"container_call_ani_name\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.phoneNumber?.location }}\n </div>\n </ng-template>\n\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\" [ngClass]=\"{ 'call_animation': isactiveCall }\">\n <svg viewBox=\"0 0 212 212\" height=\"85\" width=\"85\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"activeCalls.length>1\" style=\"display: none;\">\n <div *ngFor=\"let call of activeCalls; let i = index \"\n [ngClass]=\"{ 'active-call': i === currentActiveCallIndex, 'other-call': i !== currentActiveCallIndex }\"\n (click)=\"swapLinesToIndex(i)\">\n <div class=\"call-number\">{{ call.phoneNumber }}</div>\n <div class=\"call-duration\">{{ call.duration }}s</div>\n <div class=\"call-status\">\n <span *ngIf=\"call.isOnHold\">On Hold</span>\n <span *ngIf=\"call.isMuted\">Muted</span>\n </div>\n </div>\n </div>\n\n </ng-container>\n </ng-container>\n\n <!-- Placeholder for conference call code -->\n <ng-template #showConferenceCallDiv>\n <!-- <ng-container *ngTemplateOutlet=\"conferenceCallTemplate\"></ng-container> -->\n </ng-template>\n </div>\n </div>\n\n <div class=\"container_call_content\">\n <div class=\"container_call_dnis\" style=\"display: none;\">\n <span>Ext. {{ extensionNumber }}</span>\n </div>\n\n <div class=\"container_call_options\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall && activeCalls.length<4} \" (click)=\"onAddCall() \"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\">\n <svg fill=\"#000000\" width=\"20\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\"\n xml:space=\"preserve\">\n <path fill=\"currentColor\" d=\"M30,29h16.5c0.8,0,1.5-0.7,1.5-1.5v-3c0-0.8-0.7-1.5-1.5-1.5H30c-0.6,0-1-0.4-1-1V5.5C29,4.7,28.3,4,27.5,4\n h-3C23.7,4,23,4.7,23,5.5V22c0,0.6-0.4,1-1,1H5.5C4.7,23,4,23.7,4,24.5v3C4,28.3,4.7,29,5.5,29H22c0.6,0,1,0.4,1,1v16.5\n c0,0.8,0.7,1.5,1.5,1.5h3c0.8,0,1.5-0.7,1.5-1.5V30C29,29.4,29.4,29,30,29z\" />\n </svg>\n </div>\n <div class=\"button_text\">Add</div>\n </button>\n\n <button class=\"button_call_option\" [ngClass]=\"{ 'button_disabled': !isactiveCall }\" *ngIf=\"!isRecording\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\">\n <svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n <div class=\"button_text\">Record</div>\n </button>\n <button class=\"button_call_option\" [ngClass]=\"{ 'button_disabled': !isactiveCall }\" *ngIf=\"isRecording\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\">\n <svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n <div class=\"button_text\">Stop</div>\n </button>\n\n <button class=\"button_call_option\" [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\" (click)=\"isCallTransferOpen = !isCallTransferOpen\">\n <div class=\"button_icon\">\n <svg width=\"25px\" height=\"25px\" viewBox=\"0 0 48 48\" version=\"1\" enable-background=\"new 0 0 48 48\">\n <path fill=\"currentColor\"\n d=\"M39.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4h-4.8c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L41,8.4C40.5,7.9,39.7,7.9,39.2,8.4z\" />\n <path fill=\"currentColor\"\n d=\"M11.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4H8.5c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L13,8.4C12.5,7.9,11.7,7.9,11.2,8.4z\" />\n <g fill=\"currentColor\">\n <polygon points=\"25.3,18.6 30.7,24 25.3,29.4\" />\n <rect x=\"16\" y=\"22\" width=\"11\" height=\"4\" />\n </g>\n </svg>\n </div>\n <div class=\"button_text\">Transfer</div>\n </button>\n\n <ng-container *ngIf=\"isCallTransferOpen\">\n <ng-container *ngTemplateOutlet=\"callTransferTemplate\"></ng-container>\n </ng-container>\n </div>\n\n <div class=\"container_dialpad_row\">\n <button class=\"button_call_option button_elevated\"\n *ngIf=\"activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isMuted\"\n (click)=\"toggleMute()\" [ngClass]=\"{'button_disabled': showCallDisconnected}\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 384 512\" width=\"16\">\n <path fill=\"currentColor\"\n d=\"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40z\" />\n </svg>\n </div>\n <div class=\"button_text\">Mute</div>\n </button>\n <button class=\"button_call_option button_active button_elevated\"\n *ngIf=\"activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isMuted\"\n (click)=\"toggleMute()\">\n <div class=\"button_icon\">\n <svg width=\"26\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c15.2-26 23.9-56.3 23.9-88.7l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 21.2-5.1 41.1-14.2 58.7L416 300.8 416 96c0-53-43-96-96-96s-96 43-96 96l0 54.3L38.8 5.1zM344 430.4c20.4-2.8 39.7-9.1 57.3-18.2l-43.1-33.9C346.1 382 333.3 384 320 384c-70.7 0-128-57.3-128-128l0-8.7L144.7 210c-.5 1.9-.7 3.9-.7 6l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6z\" />\n </svg>\n </div>\n <div class=\"button_text\">Unmute</div>\n </button>\n <button class=\"button_call_option button_elevated\"\n *ngIf=\"activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isOnHold\"\n [ngClass]=\"{'button_disabled': !isactiveCall}\" [disabled]=\"!isactiveCall\" (click)=\"toggleHold()\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg>\n </div>\n <div class=\"button_text\">Hold</div>\n </button>\n <button class=\"button_call_option button_active button_elevated\"\n *ngIf=\"activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isOnHold\"\n (click)=\"toggleHold()\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg>\n </div>\n <div class=\"button_text\">Unhold</div>\n </button>\n <button class=\"button_call_option button_elevated\" [class.button_active]=\"isDailpadOpen\"\n (click)=\"menuDailpad()\" [ngClass]=\"{'button_disabled': showCallDisconnected}\">\n <div class=\"button_icon\">\n <svg width=\"22px\" height=\"22px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n </svg>\n </div>\n <div class=\"button_text\">{{ isDailpadOpen ? 'Hide' : 'Keypad' }}</div>\n </button>\n <div class=\"container_popup_dialpad\" *ngIf=\"isDailpadOpen\">\n <div class=\"container_popup_dialpad_inner\">\n\n <div [formGroup]=\"dtmfForm\">\n <div class=\"container_dtmf_input\">\n <input type=\"tel\" formControlName=\"dtmf\">\n </div>\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <button *ngIf=\"!showCallDisconnected || isCalling\" class=\"button_dialpad_digit button_call_red\"\n (click)=\"dropCurrentCall()\">\n <svg width=\"25\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg>\n </button>\n <button *ngIf=\"showCallDisconnected && !isCalling\" class=\"button_dialpad_digit button_call_green\"\n (click)=\"onRedial()\" [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n\n <ng-template #conferenceCallTemplate>\n <div class=\"container_active_call_header\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">Conference call</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">with {{ conferenceParticipants?.length }} people</div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"container_active_call_options\">\n <div class=\"button_active_call_options button_active_call_options_highlighted\">\n <span (click)=\"isConfereceList = !isConfereceList\" class=\"container_active_call_options_button\">\n <svg viewBox=\"0 0 448 512\" width=\"16px\">\n <path fill=\"currentColor\"\n d=\"M201.4 374.6c12.5 12.5 32.8 12.5 45.3 0l160-160c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 306.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160z\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n\n <!-- Conference List -->\n <div class=\"container_conference_contact_list\" *ngIf=\"isConfereceList\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox container_conference_contact_list_scrollbox\">\n <div class=\"scrollbox-content\">\n <ng-container *ngFor=\"let person of conferenceParticipants; let last = last\">\n <div class=\"container_conference_contact_item\">\n <!-- Avatar -->\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <!-- Name and Time -->\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ person.name }}</div>\n <div class=\"contact_field_green\">{{ person.duration }}</div>\n </div>\n </div>\n\n <!-- End Button -->\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <button class=\"button_disconnect_call\">\n <svg width=\"22\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\">\n </path>\n </svg>\n </button>\n </div>\n </div>\n </div>\n\n <!-- Divider -->\n <div *ngIf=\"!last\" class=\"container_separator\"></div>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n\n <ng-template #callTransferTemplate>\n <div class=\"container_transfer_call\">\n <div class=\"container_transfer_call_inner\">\n <div class=\"container_button_close\">\n <span (click)=\"isCallTransferOpen = false\" title=\"Close\">\n <i class=\"fa-sharp fa-solid fa-xmark\"></i>\n </span>\n </div>\n\n <!-- First Div -->\n <div class=\"container_transfer_call_content\" *ngIf=\"currentView === 'transferListpage'\" @slideInOut>\n <div class=\"container_active_call_duration\">{{ formatTime(callDuration)}}</div>\n <div class=\"container_active_call_header margin_bottom_16 shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">{{ lookupPhoneNumber?.country?.flag }}\n {{ lookupPhoneNumber?.phoneNumber }}</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">Active call</div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">Ext. {{extensionNumber}}</span>\n </div>\n </div>\n </div>\n <div class=\"container_transfer_tab_buttons\">\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab1')\" [class.active]=\"activeTab === 'tab1'\">\n <svg width=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg> Recent</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab2')\" [class.active]=\"activeTab === 'tab2'\">\n <svg width=\"20px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\"\n d=\"M15.71,12.71a6,6,0,1,0-7.42,0,10,10,0,0,0-6.22,8.18,1,1,0,0,0,2,.22,8,8,0,0,1,15.9,0,1,1,0,0,0,1,.89h.11a1,1,0,0,0,.88-1.1A10,10,0,0,0,15.71,12.71ZM12,12a4,4,0,1,1,4-4A4,4,0,0,1,12,12Z\" />\n </svg> Internal</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab3')\" [class.active]=\"activeTab === 'tab3'\">\n <svg width=\"18px\" height=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" /></svg>\n Dail</button>\n </div>\n <div class=\"container_transfer_tab_content\" *ngIf=\"activeTab === 'tab1'\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div>\n\n <div class=\"container_transfer_tab_content\" *ngIf=\"activeTab === 'tab2'\">\n <div class=\"container_transfer_internal_search\">\n <input type=\"search\" placeholder=\"Type to search\">\n </div>\n <div class=\"container_transfer_contact_list\"> \n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_contact_item\"\n (click)=\"goToDiv('transferDetails');makeCallFromContact('0')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Lovish Snug</div>\n <div class=\"contact_field\">6283675354</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Agent</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 8002</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rakesh kumar</div>\n <div class=\"contact_field\">(888) 9876549</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Administrator</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Sohan singh</div>\n <div class=\"contact_field\">(876) 8800965</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Manger</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Pardeep mishra</div>\n <div class=\"contact_field\">(876) 8800965</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Agent</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails')\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Varun ji </div>\n <div class=\"contact_field\">(876) 8800965</div>\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Manger</span></div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. 3005</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_transfer_tab_content\" *ngIf=\"activeTab === 'tab3'\">\n <form [formGroup]=\"transferForm\">\n <div class=\"container_transfer_contact_list\">\n <div class=\"container_phone_number_input margin_bottom_16\">\n <button class=\"button_phonebook\" (click)=\"isDirectoryOpen = !isDirectoryOpen\">\n <svg fill=\"currentColor\" height=\"22px\" style=\"enable-background:new 0 0 611.985 611.986;\"\n version=\"1.1\" viewBox=\"0 0\n611.985 611.986\" width=\"40.985px\" routerLinkActive=\"active\" xml:space=\"preserve\">\n <g>\n <path d=\"M143.021,158.99c42.525,0,79.456-36.931,79.456-79.456S185.546,0.078,143.021,0.078\nS63.565,37.009,63.565,79.534S100.496,158.99,143.021,158.99z\" fill=\"currentColor\" />\n <path d=\"M278.097,381.467c0-127.13-65.98-190.695-139.048-190.695S0,254.338,0,381.467\n C0,468.583,278.097,468.583,278.097,381.467z\" fill=\"currentColor\" />\n <path d=\"M373.444,220.807c42.525,0,79.456-36.931,79.456-79.456s-36.931-79.456-79.456-79.456\n s-79.456,36.931-79.456,79.456S330.919,220.807,373.444,220.807z\" fill=\"currentColor\" />\n <path d=\"M369.471,252.59c-21.962,0-43.033,6.452-62.071,17.957c11.537,31.051,18.37,67.792,18.37,110.921\n c0,42.843-28.541,76.151-77.517,95.22c60.768,51.424,260.267,40.459,260.267-33.403\n C508.52,316.155,442.539,252.59,369.471,252.59z\" fill=\"currentColor\" />\n </g>\n </svg>\n </button>\n <input placeholder=\"Phone Number\" type=\"tel\" formControlName=\"target\">\n <button class=\"button_backspace\" (click)=\"onBackspace()\"></button>\n </div>\n <div class=\"container_transfer_internal_contact_list\" *ngIf=\"isDirectoryOpen\">\n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n <!-- <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>Agent</span></div>\n </div> -->\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">Rajeev kumar singh</div>\n <div class=\"contact_field\">(654) 9876549</div>\n\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n <span *ngFor=\"let star of [1, 2, 3, 4, 5]\" [class.filled]=\"star <= rating\">\n \u2605\n </span>\n </div>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\" d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9\n 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7\n 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8\n 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32\n 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9\n 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38\n 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86\n 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\" d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3\n36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4\n26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9\n0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5\n69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1\n0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2\n384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64\n192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4\n19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg></button>\n </div>\n </div>\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n <!-- come here -->\n <button *ngIf=\"isAddingNewCall\" class=\"button_dialpad_digit button_call_green\"\n (click)=\"makeCall(this.transferForm.value.target)\" [disabled]=\"!phoneNumber\"\n [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n <button *ngIf=\"!isAddingNewCall\" type=\"submit\" class=\"button_dialpad_digit button_call_green\"\n (click)=\"onTransferCall()\">\n <svg height=\"20px\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\" xml:space=\"preserve\">\n <g>\n <path fill=\"currentColor\" d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8\n c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3\n c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\" />\n <path fill=\"currentColor\" d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0\n l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\" />\n </g>\n </svg>\n </button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n\n <!-- Second Div -->\n <div class=\"container_transfer_call_content\" *ngIf=\"currentView === 'transferDetails'\" @slideInOut>\n <div class=\"container_active_call_duration\">00:10</div>\n <div class=\"container_active_call_header shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">{{ lookupPhoneNumber?.country?.flag }}\n {{ lookupPhoneNumber?.phoneNumber }}</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_grey\">\n <svg viewBox=\"0 0 320 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\"></path>\n </svg>\n </div>\n <div class=\"container_active_call_status_grey\">On hold</div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content ng-tns-c3832626365-74\">Ext. {{extensionNumber}}</span>\n </div>\n </div>\n </div>\n <div class=\"container_transfer_call_details\">\n\n <div class=\"container_call_ani_number padding_top_nt\">+91 (654) 9876549</div>\n <div class=\"container_call_ani_name\">Rajeev kumar singh</div>\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"85\" width=\"85\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n </div>\n <div class=\"container_call_dnis\">\n <span>Ext. {{extensionNumber}}</span>\n </div>\n <div class=\"container_call_options margin_bottom_nt\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option\" (click)=\"mergeCall()\">\n <div class=\"button_icon\">\n <svg width=\"22\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l97.2 0c9.7 0 18.9 4.4 25 12L247 256 154.2 372c-6.1 7.6-15.3 12-25 12L32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l97.2 0c29.2 0 56.7-13.3 75-36l99.2-124 80.6 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c6-6 9.4-14.1 9.4-22.6s-3.4-16.6-9.4-22.6l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-80.6 0L204.2 100c-18.2-22.8-45.8-36-75-36L32 64z\" />\n </svg>\n </div>\n <div class=\"button_text\">Merge</div>\n </button>\n <button class=\"button_call_option\">\n <div class=\"button_icon\">\n <svg width=\"26px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M150.6 73.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 173.3 96 320c0 53 43 96 96 96l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-146.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96zM336 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32 14.3 32 32l0 146.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L544 338.7 544 192c0-53-43-96-96-96L336 96z\" />\n </svg>\n </div>\n <div class=\"button_text\">Swap</div>\n </button>\n <button class=\"button_call_option\">\n <div class=\"button_icon\">\n <svg width=\"19px\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\" xml:space=\"preserve\">\n <g>\n <path fill=\"currentColor\" d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8\n c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3\n c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\" />\n <path fill=\"currentColor\" d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0\n l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\" />\n </g>\n </svg>\n </div>\n <div class=\"button_text\">Transfer</div>\n </button>\n </div>\n </div>\n <div class=\"container_transfer_disconnect\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit button_call_red\" (click)=\"goToDiv('transferListpage')\">\n <svg width=\"36px\" viewBox=\"0 0 76 76\" version=\"1.1\" baseProfile=\"full\"\n enable-background=\"new 0 0 76.00 76.00\" xml:space=\"preserve\">\n <path fill=\"currentColor\" fill-opacity=\"1\" stroke-width=\"0.2\" stroke-linejoin=\"round\"\n d=\"M 16.2013,39.582L 15.4175,39.4096L 14.8094,38.9315L 14.4029,38.2193L 14.25,37.364L 14.25,34.9055C 14.25,33.184 14.6023,31.6057 15.3069,30.1704C 16.0116,28.7352 16.9698,27.4788 18.1818,26.4013C 19.3937,25.3237 20.8095,24.4424 22.429,23.7573C 24.0486,23.0722 25.7732,22.6277 27.6031,22.4239L 31.304,22.0792L 34.9918,21.8256L 39.109,21.715L 42.966,21.8451L 46.101,22.0987L 48.9628,22.489C 50.7276,22.7318 52.3883,23.199 53.945,23.8906C 55.5017,24.5822 56.8567,25.4625 58.0101,26.5313C 59.1635,27.6002 60.0752,28.8468 60.7451,30.2712C 61.4151,31.6956 61.75,33.2599 61.75,34.964L 61.75,37.4486L 61.5874,38.2681L 61.1386,38.9511L 60.4785,39.4096L 59.6752,39.582L 51.8897,39.582L 51.0994,39.4096L 50.4588,38.9413L 50.0327,38.2584L 49.8799,37.4226L 49.8799,32.1217L 49.7075,31.1656L 49.2295,30.3818L 48.5075,29.8452C 48.23,29.7108 47.9286,29.6436 47.6034,29.6436L 28.7413,29.6436C 28.4161,29.6436 28.0974,29.7108 27.7852,29.8452L 26.9722,30.3818L 26.4128,31.1851C 26.2697,31.4973 26.1982,31.8225 26.1982,32.1607L 26.1982,37.364L 26.0356,38.2193L 25.5803,38.9315L 24.9104,39.4096L 24.1038,39.582L 16.2013,39.582 Z M 34.8333,41.1667L 41.1666,41.1667L 41.1667,52.6458L 45.9167,47.8958L 45.9167,54.2292L 38,62.5417L 30.0833,54.2292L 30.0833,47.8958L 34.8333,52.6458L 34.8333,41.1667 Z \" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-template>\n\n</ng-template>\n\n<div id=\"videoPanel\" style=\"display: none\">\n <audio #rmtAudio id=\"rmtAudio\" autoplay></audio>\n <audio #lclAudio id=\"lclAudio\" autoplay muted></audio>\n <video #rmtVideo id=\"rmtVideo\" autoplay></video>\n <video #lclVideo id=\"lclVideo\" autoplay muted controls title=\"Local Video\"></video>\n</div>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Open+Sans:300,400,500,600,700,800\";@import\"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css\";:host{--sd-app-color: #ff6633;--sd-app-color-dark: #ff5805;--sd-app-color-light: #fe8c66;--sd-text-font-family: \"Open Sans\", \"sans-serif\", \"Helvetica Neue\", \"Helvetica\", \"Arial\";--sd-text-color: #666;--sd-text-color-inverse: #fff;--sd-text-color-light: #ccc;--sd-text-color-medium: #999;--sd-text-color-dark: #333;--sd-background-color: #fff;--sd-border-color-light: #e3e3e3;--sd-border-color-dark: #c9c9c9}.message_label{width:100%;font-size:13px;font-family:var(--sd-text-font-family);letter-spacing:-.25px;border-radius:4px;font-weight:600;border:1px solid #f5c6cb;padding:8px 11px;position:relative}.error_message{color:#e1143c;background-color:#f8d7da;border-color:#dfadb2}.success_message{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert_message{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.properties_form_field{width:100%;font-size:13px!important;font-family:var(--sd-text-font-family)!important;font-weight:600!important;letter-spacing:-.24px!important;color:#555!important}.container_avaya_login{width:100%;height:calc(100vh - 51px);padding:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.container_avaya_login_inner{margin:0 auto;width:100%;max-width:370px;padding:65px 20px 20px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex}.container_connection_status_overlay{width:100%;height:100%;position:absolute;left:0;right:0;bottom:0;background-color:#6669;display:flex;justify-content:center;z-index:9999999;padding:20px}.container_connection_status{width:100%;background:var(--sd-background-color);padding:0 10px;border-radius:8px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);display:flex;height:42px;align-items:center;position:relative;box-shadow:#32325d40 0 6px 12px -2px,#0000004d 0 3px 7px -3px}.container_connection_status span{padding:0 0 0 8px}.container_connection_status .fa-circle-dot{color:#f66060}.container_connection_status_loader{position:absolute;right:15px}.container_avaya_login_content{position:relative;width:100%}.container_avaya_logo{margin:0;padding:0 26px 24px;width:100%;text-align:center}.container_avaya_logo_image{margin:0 auto;width:120px;height:35px;background:var(--sd-background-color) url() center no-repeat;background-size:120px}.container_avaya_logo h3{margin:0;padding:6px 0 0;font-family:var(--sd-text-font-family);font-size:18px;font-weight:700;letter-spacing:-.45px;color:var(--sd-text-color-dark);position:relative}.container_avaya_logo h3 span{font-size:8px;position:absolute;top:8px}.container_avaya_login_error{width:100%;white-space:normal}.container_avaya_login_form{width:100%;margin:0;padding:26px 0 0;position:relative}.container_avaya_login_form form{width:100%;margin:0;padding:0}.container_avaya_login_form .form_field{margin:0;padding:0;width:100%}.avaya_login_button_area{padding:10px 0 0}.container_icon_eye{position:absolute;right:15px}.container_avaya_login_form .button_submit_login{font:14px / 48px var(--sd-text-font-family);display:inline-block;height:48px;background:#cd1f1e;color:var(--sd-text-color-inverse);border:1px solid #cd1f1e;font-weight:600;padding:0 12px;border-radius:4px;outline:none;letter-spacing:-.24px;cursor:pointer;width:100%;position:relative}.container_avaya_login_form .button_submit_login_loader{background:#cd1f1e!important;color:var(--sd-text-color-inverse)!important;border:1px solid #cd1f1e!important;cursor:auto}.container_avaya_login_form .button_submit_login:disabled{background:#f1f1f1;color:var(--sd-text-color-medium);border:1px solid #f1f1f1}.button_submit_loader:after{content:\"\";position:absolute;width:16px;height:16px;inset:0;margin:auto;border:3px solid transparent;border-top-color:#fff;border-radius:50%;animation:button_submit_loader_spinner 1s ease infinite}@keyframes button_submit_loader_spinner{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.container_avaya_softphone{width:100%;height:100%;position:relative}.container_avaya_softphone_inner{width:100%;position:absolute;top:0;left:0;right:0;padding:0;height:calc(100% - 51px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background:#000}.container_call{margin:0 auto;padding:0;position:relative;width:100%;height:100%;background:var(--sd-background-color)}.container_dialpad_header{width:100%;position:relative;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99999;background:var(--sd-background-color);padding:15px 15px 0}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px 15px 0;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_avaya_extension{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:8px 10px;border:1px solid var(--sd-border-color-light);border-radius:12px;margin-bottom:15px;background:#f0f0f0}.container_avaya_extension_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center}.container_avaya_extension_left .extension_label{display:flex;align-items:center;line-height:normal;text-align:left}.container_avaya_extension_left .extension_number{display:flex;align-items:center;line-height:20px}.container_avaya_extension_right{flex-basis:auto;flex-direction:column;flex-grow:1;text-align:right;justify-items:flex-end}.container_avaya_extension_right button{background:none;border:none;outline:none;color:#a6a6a6;font-weight:600;border-radius:50%;align-items:center;justify-content:center;-webkit-transition-duration:.3s;transition-duration:.3s;background:#f0f0f0;height:38px;width:38px}.container_avaya_extension_right button:hover{color:var(--sd-text-color-dark);background:var(--sd-border-color-light)}.dialpad_container_sd{position:absolute;width:100%;right:0;left:0;top:101px;height:calc(100vh - 101px);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}.container_call_header{width:100%;position:absolute;top:0;left:0;right:0;height:221px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_call_header_inner{width:100%;margin:0;padding:10px 15px 15px;position:relative}.container_call_info{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color)}.container_call_info_blinker{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:red;animation:blinker 1s linear infinite}@keyframes blinker{26%{opacity:0}}.container_call_ani{width:100%;margin:0;padding:0}.container_call_ani_number{text-align:center;font-size:20px;font-weight:600;padding-top:26px}.container_call_ani_name{text-align:center;font-size:13px;font-weight:600;padding-top:2px}.container_call_ani_image{margin:0;padding:24px 0 0;width:100%}.container_call_ani_image_inner{display:flex;align-items:center;flex:0 0 auto;padding:0;width:85px;height:85px;position:relative;margin:0 auto;border-radius:100%}.container_call_content{width:100%;position:absolute;top:221px;left:0;right:0;height:calc(100% - 221px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding-top:20px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_call_dnis{width:100%;text-align:center;padding-bottom:16px}.container_call_dnis span{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 16px}.container_call_options{width:100%;display:flex;justify-content:center;margin-bottom:16px;flex-direction:column}.button_call_option{display:block;width:80px;height:60px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative}.button_call_option .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_call_option .button_text{display:flex;justify-content:center;color:var(--sd-text-color)}.button_active{color:#67cc02}.button_elevated{position:relative;z-index:9999}.button_disabled{color:gray;cursor:not-allowed;pointer-events:none;opacity:.6}.container_popup_dialpad{position:absolute;z-index:999;left:0;right:0;bottom:0}.container_popup_dialpad_inner{background:#f1f1f1;background:linear-gradient(180deg,#f1f1f1 44%,#fff);margin:0 auto;padding:10px 15px 20px;border-radius:8px;width:88%;position:relative;height:475px}.container_popup_dialpad .button_close{position:absolute;right:-15px;top:-17px;z-index:9}.container_popup_dialpad .button_close span{width:32px;height:32px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.container_popup_dialpad .button_close span:hover{background:#f1f1f1;color:var(--sd-text-color-dark)}.container_popup_dialpad .button_close span .fa-xmark{font-size:1.4em;font-weight:400}.container_dtmf_input{width:100%;margin:0;padding:0 0 10px;position:relative}.container_dtmf_input input{width:100%;display:flex;height:38px;outline:none;text-align:center;align-items:center;border:1px solid #f1f1f1;font-size:26px;font-weight:400;color:transparent;text-shadow:0 0 0 #000;padding:0;background:#f1f1f1}.container_active_call_header{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:12px;overflow:hidden}.container_active_call_avatar{display:flex}@keyframes play1{0%{transform:scale(1)}15%{box-shadow:0 0 0 2px #57b84666}25%{box-shadow:0 0 0 3px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 5px #bde4a966,0 0 0 30px #fff3}}.container_active_call_avatar_inner{margin:0 auto;padding:0;width:50px;height:50px;background:#dfe6e8;color:var(--sd-text-color-dark);position:relative;animation:play1 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden;border-radius:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.container_active_call_info{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_active_call_info_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_active_call_duration{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color);margin-bottom:10px}.container_active_call_number{font-size:13px;margin-bottom:2px}.container_active_call_details{font-size:13px;color:#6c0;padding-top:2px}.container_active_call_details_inner{display:flex;margin:0;padding:0;justify-content:left}.container_active_call_icon_grey{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:var(--sd-text-color-medium)}.container_active_call_icon_green{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:#6c0}.container_active_call_status_green{display:flex;justify-content:center;align-items:center;color:#6c0;padding-left:6px;font-size:12px}.container_active_call_status_grey{display:flex;justify-content:center;align-items:center;color:var(--sd-text-color-medium);padding-left:6px;font-size:12px}.container_active_call_options{display:flex;flex-direction:row}.container_active_call_options .button_active_call_options{display:flex;flex-basis:auto;justify-content:right}.container_active_call_options .button_active_call_options_highlighted{font-size:16px;color:#29abe0}.container_active_call_options_button{display:flex;border-radius:26px;border:none;padding:0;font-size:11px;color:var(--sd-text-color);width:32px;height:32px;justify-content:center;align-items:center}.container_active_call_options_button:hover{background:#f1f1f1}.container_conference_contact_list{position:relative;width:100%;background:#f7f7f7;border-top:1px solid #eee;border-bottom:1px solid #eee;height:149px;padding:0;margin-top:16px}.container_swap_merge_contact_list{position:relative;width:100%;background:var(--sd-background-color);height:149px;padding:0;margin-top:32px}.container_conference_contact_list_inner{margin:0;padding:0;position:relative;width:100%;height:100%}.container_conference_contact_list_scrollbox{padding:12px 15px}.container_conference_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:0 10px;overflow:hidden;cursor:pointer}.button_disconnect_call{display:block;width:42px;height:42px;display:flex;margin:0;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;color:#e0261f;background:#f7f7f7;-webkit-transition-duration:.3s;transition-duration:.3s}.button_disconnect_call:hover{color:var(--sd-text-color-inverse);background:#e0261f;-webkit-transition-duration:.3s;transition-duration:.3s}.container_separator{height:1px;width:100%;background:#ededed;margin:11px 0}.container_transfer_call{position:absolute;z-index:99999;left:0;right:0;bottom:-51px;width:100%;background:var(--sd-background-color)}.container_transfer_call_inner{background:var(--sd-background-color);box-shadow:#11111a1a 0 4px 16px,#11111a0d 0 8px 32px;padding:20px 15px 10px;border-radius:0;width:100%;position:relative;height:596px;overflow:hidden}.container_transfer_call_inner h2{font-family:var(--sd-text-font-family);font-size:20px;font-weight:700;color:var(--sd-text-color-dark);letter-spacing:-1px;padding:0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_button_close{position:absolute;right:4px;top:4px}.container_button_close span{width:36px;height:36px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer}.container_button_close span:hover{background:var(--sd-background-color)}.container_button_close .fa-xmark{font-size:1.6em;font-weight:400;color:var(--sd-text-color-light)}.container_button_close span:hover .fa-xmark:hover{color:var(--sd-text-color-dark)}.container_transfer_call_content{margin:0;padding:5px 0 0;width:100%;background:var(--sd-background-color);min-height:485px}.container_transfer_call_content h3{font-family:var(--sd-text-font-family);font-size:14px;font-weight:700;color:var(--sd-text-color);letter-spacing:-.26px;padding:8px 0 0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_transfer_call_content h3 span{color:var(--sd-text-color-dark)}.container_transfer_call_details{width:100%;margin:0;padding:10px 15px 69px;position:relative}.container_transfer_tab_buttons{display:flex;gap:10px;align-items:center;margin-bottom:15px}.button_transfer_tab{padding:10px;border:none;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);background-color:var(--sd-border-color-light);cursor:pointer;width:105px;border-radius:28px;outline:none}.button_transfer_tab.active{background-color:var(--sd-app-color);color:#fff}.container_transfer_tab_content{margin:0;padding:0;width:100%}.container_transfer_internal_search{margin:0 0 15px;padding:0;width:100%}.container_transfer_internal_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:48px}.container_transfer_contact_list{width:100%;margin:0;padding:0;position:relative;height:336px}.container_transfer_contact_list_inner{width:100%;position:relative;height:100%}.container_transfer_internal_contact_list{position:absolute;width:100%;left:0;right:0;background:var(--sd-background-color);height:332px}.container_transfer_disconnect{width:100%;display:flex;justify-content:center;padding-top:3px;margin-bottom:6px}.container_avaya_footer{width:100%;padding:0;background:#f7f7f7;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color-medium);position:relative;display:flex;height:51px;justify-content:center;align-items:center;border-top:1px solid var(--sd-border-color-light);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:999;position:absolute;bottom:0;left:0}.margin_bottom_16{margin-bottom:16px}.margin_bottom_nt{margin-bottom:10px}.padding_top_nt{padding-top:7px}.shadow_st{box-shadow:#00000026 0 2px 8px}.call_animation{animation:play 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden}.mini-call-switcher{display:flex;justify-content:center;margin-top:10px}.mini-call{padding:6px 12px;margin:0 6px;background:#eaeaea;border-radius:8px;cursor:pointer;font-size:14px}.mini-call.active{background-color:#c6f6d5;font-weight:700}.history-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}.history-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--sd-background-color);padding:20px;z-index:1000;box-shadow:0 2px 10px #0000004d;border-radius:5px;width:600px;max-height:80vh;overflow-y:auto}.history-content{position:relative}.history-content h3{margin-top:0}.close-btn{background:transparent;border:none;font-size:1.5rem;position:absolute;top:0;right:0;cursor:pointer}.history-content table{width:100%;border-collapse:collapse;margin-top:1rem}.history-content th,.history-content td{padding:.5rem;border:1px solid var(--sd-text-color-light)}@keyframes play{0%{transform:scale(1)}15%{box-shadow:0 0 0 4px #57b84680}25%{box-shadow:0 0 0 5px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 10px #c2e5b180,0 0 0 30px #fff3}}::-webkit-input-placeholder{color:#ddd}::-moz-placeholder{color:var(--sd-text-color-dark)}:-ms-input-placeholder{color:var(--sd-text-color-dark)}:-moz-placeholder{color:var(--sd-text-color-dark)}.slide_st{left:-100px;-webkit-animation:slide .5s forwards;-webkit-animation-delay:2s;animation:slide .5s forwards;animation-delay:0s}@-webkit-keyframes slide{to{left:0}}@keyframes slide{to{left:0}}.tabs_sd{width:100%;position:absolute;bottom:0;left:0;right:0;display:flex;height:51px;border-top:1px solid var(--sd-border-color-light);background:#f9f9f9;z-index:999999}.tab_heading_btn{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;align-items:center;padding:0;border:none;cursor:pointer;width:25%;font-family:var(--sd-text-font-family);font-size:11px;font-weight:600;line-height:normal;color:var(--sd-text-color-medium);background:none;transition:background-color .3s linear;-webkit-transition:background-color .3s linear;-o-transition:background-color .3s linear;-ms-transition:background-color .3s linear}.nav_icon{display:flex;align-items:center;justify-content:center;height:22px;margin-bottom:1px}.nav_heading_sd{display:flex;align-items:center}.tab_heading_btn.active{color:var(--sd-app-color);background:url() top center no-repeat}.tab-content_sd{width:100%;height:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative}.container_transfer_fav_list{width:100%;margin:0;padding:0;position:relative;height:376px}.outer_container_swap_merge{width:100%;margin:0;padding:0}.container_swap_merge_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;border-radius:8px;overflow:hidden}.container_recent_item_image{display:flex;align-items:center}.container_swap_merge_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.onhold_st{font-family:var(--sd-text-font-family);font-size:12px;color:var(--sd-text-color-medium);font-weight:600}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.button_swap_merge{display:block;width:32px;height:45px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 0 0 28px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative;pointer-events:all;cursor:pointer}.button_swap_merge .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_swap_merge .button_text{display:flex;justify-content:center;color:var(--sd-text-color-dark)}@media only screen and (max-width: 767px){.previewcontent{width:95%!important}.bgSecWrap .numberArrow{left:0!important;top:-20px!important}}\n"] }]
|
|
2051
|
-
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type:
|
|
2709
|
+
], standalone: false, template: "@if (isReconnectingInProgress || isFailoverInProgress || isFailbackInProgress) {\n <div class=\"container_connection_status_overlay\">\n <div class=\"container_connection_status\">\n <i class=\"fa-solid fa-circle-dot\"></i>\n\n @if (isReconnectingInProgress) {\n <span>Reconnecting to the server...</span>\n }\n\n @if (isFailoverInProgress) {\n <span>Failover in progress...</span>\n }\n\n @if (isFailbackInProgress) {\n <span>Failback in progress...</span>\n }\n\n <div class=\"container_connection_status_loader\">\n <div class=\"container_three_dot_loader\">\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n <span class=\"dot\"></span>\n </div>\n </div>\n </div>\n </div>\n}\n\n\n\n@if (showLoginForm) {\n <!-- Login Form -->\n <div class=\"container_avaya_login\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"container_avaya_login_inner\">\n <div class=\"container_avaya_login_content\">\n\n <div class=\"container_avaya_logo\">\n <div class=\"container_avaya_logo_image\"></div>\n <h3>IP Office<span>TM</span></h3>\n </div>\n\n @if (hasAvayaSocketError || hasAvayaLoginError || hasAvayaLoginConflictError || hasAvayaDeviceError) {\n <div class=\"container_avaya_login_error\">\n <p class=\"message_label error_message\">\n @if (hasAvayaSocketError) {\n We're having trouble connecting to the server\n }\n @if (hasAvayaLoginError) {\n Invalid extension or password!\n }\n @if (hasAvayaLoginConflictError) {\n Another user is logged in with this extension\n }\n @if (hasAvayaDeviceError) {\n We're having trouble accessing your device\n }\n </p>\n </div>\n }\n\n <div class=\"container_avaya_login_form\">\n <form [formGroup]=\"loginForm\" (ngSubmit)=\"onLogin()\">\n\n <!-- Extension -->\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Extension</mat-label>\n <input matInput formControlName=\"ipoExtensionNo\" autocomplete=\"ipoExtensionNo\"\n (keypress)=\"restrictNumeric($event)\" />\n\n @if (loginForm.controls['ipoExtensionNo'].invalid && loginForm.controls['ipoExtensionNo'].touched) {\n <mat-error>\n @if (loginForm.controls['ipoExtensionNo'].errors?.['required']) {\n <small>Extension is required.</small>\n }\n </mat-error>\n }\n </mat-form-field>\n </div>\n\n <!-- Password -->\n <div class=\"form_field\">\n <mat-form-field class=\"properties_form_field mat-form-field-outline\">\n <mat-label class=\"mdc-floating-disabled\">Password</mat-label>\n <input matInput formControlName=\"ipoPassword\" autocomplete=\"avaya-ipo-password\"\n (keypress)=\"restrictNumeric($event)\" [type]=\"showLoginPassword ? 'text' : 'password'\" />\n\n <mat-icon matSuffix (click)=\"showLoginPassword = !showLoginPassword && !hasAvayaSocketError\">\n @if (showLoginPassword) {\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye\"></i>\n </span>\n } @else {\n <span class=\"container_icon_eye\">\n <i class=\"fa-solid fa-eye-slash\"></i>\n </span>\n }\n </mat-icon>\n\n @if (loginForm.controls['ipoPassword'].invalid && loginForm.controls['ipoPassword'].touched) {\n <mat-error>\n @if (loginForm.controls['ipoPassword'].errors?.['required']) {\n <small>Password is required.</small>\n }\n </mat-error>\n }\n </mat-form-field>\n </div>\n\n <!-- Login button -->\n <div class=\"avaya_login_button_area\">\n <button type=\"submit\" class=\"button_submit_login\"\n [ngClass]=\"{ 'button_submit_login_loader': showLoginLoader }\"\n [disabled]=\"showLoginLoader\">\n @if (showLoginLoader) {\n <span class=\"button_submit_loader\"></span>\n } @else {\n <span>Login</span>\n }\n </button>\n </div>\n\n </form>\n </div>\n\n </div>\n </div>\n </div>\n </div>\n </div>\n} @else {\n <!-- Softphone UI -->\n <ng-container *ngTemplateOutlet=\"showSoftphoneDiv\"></ng-container>\n}\n\n<!-- Footer (always visible) -->\n<div class=\"container_avaya_footer\">© 2025 SNUG Technologies Pvt. Ltd.\n\n\n\n</div>\n\n\n\n\n\n<ng-template #showSoftphoneDiv>\n\n@if (!showActiveCall) {\n <div class=\"container_avaya_softphone_inner\">\n <!-- ------------------- Keypad work start ---------- -->\n @if (bottomActiveTab === 'keypad_sd') {\n <div class=\"tab-content_sd\">\n <div class=\"container_dialpad_header\">\n <div class=\"container_dialpad_header_inner2\">\n <div class=\"container_avaya_extension\">\n <div class=\"container_avaya_extension_left\">\n <div class=\"extension_label\">Extension</div>\n <div class=\"extension_number\">{{ extensionNumber }}</div>\n </div>\n <div class=\"container_avaya_extension_right\">\n <button title=\"Sign out\" (click)=\"onLogout()\">\n <svg width=\"16px\" fill=\"currentColor\" viewBox=\"0 0 512 512\">\n <path\n d=\"M377.9 105.9L500.7 228.7c7.2 7.2 11.3 17.1 11.3 27.3s-4.1 20.1-11.3 27.3L377.9 406.1c-6.4 6.4-15 9.9-24 9.9c-18.7 0-33.9-15.2-33.9-33.9l0-62.1-128 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l128 0 0-62.1c0-18.7 15.2-33.9 33.9-33.9c9 0 17.6 3.6 24 9.9zM160 96L96 96c-17.7 0-32 14.3-32 32l0 256c0 17.7 14.3 32 32 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-53 0-96-43-96-96L0 128C0 75 43 32 96 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"dialpad_container_sd\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <app-dialpad [contacts]=\"contacts\" (makeCallEv)=\"makeCall($event)\"></app-dialpad>\n <!-- to do list -->\n </div>\n </div>\n </div>\n </div>\n }\n\n <!-- ------------------- Keypad work end ---------- -->\n\n @if (bottomActiveTab === 'recent_sd') {\n <div class=\"tab-content_sd\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div>\n }\n\n @if (bottomActiveTab === 'settings_sd') {\n <div class=\"tab-content_sd\">\n <app-device-selector (change)=\"handleDeviceSelection($event)\"></app-device-selector>\n </div>\n }\n </div>\n\n <div class=\"tabs_sd\">\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('recent_sd')\"\n [class.active]=\"bottomActiveTab === 'recent_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"19px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Recent</span>\n </button>\n\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('keypad_sd')\"\n [class.active]=\"bottomActiveTab === 'keypad_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"20px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\"></path>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Keypad</span>\n </button>\n\n <button class=\"tab_heading_btn\" (click)=\"bottomSelectTab('settings_sd')\"\n [class.active]=\"bottomActiveTab === 'settings_sd'\">\n <span class=\"nav_icon\">\n <svg width=\"19px\" viewBox=\"-0.03 0 16.079 16.079\">\n <g>\n <path fill=\"currentColor\"\n d=\"M8.182 1.083a6.99 6.99 0 0 0-6.248 3.493c-1.929 3.342-.776 7.629 2.57 9.562 3.346 1.934 7.634.792 9.562-2.55 1.929-3.343.776-7.634-2.57-9.567a6.98 6.98 0 0 0-3.314-.938zM8 2.08a6 6 0 0 1 6 6 6 6 0 0 1-6 6 6 6 0 0 1-6-6 6 6 0 0 1 6-6z\" />\n <path fill=\"currentColor\"\n d=\"M9.322 0L6.69.393v1.354a6.49 6.477 43.146 0 1 2.632.005V0zM3.937 1.19L1.93 2.897l.988 1.177a6.49 6.477 43.146 0 1 2.017-1.69zm8.128.013l-.993 1.184a6.49 6.477 43.146 0 1 .17.09 6.49 6.477 43.146 0 1 1.845 1.603l1.006-1.197zM.455 5.42l-.44 2.596 1.515.267a6.49 6.477 43.146 0 1 .455-2.593zm15.086.003l-1.523.269a6.49 6.477 43.146 0 1 .464 2.59l1.533-.27zM1.858 10.118l-1.351.78 1.33 2.271 1.339-.772a6.49 6.477 43.146 0 1-1.317-2.28zm12.301.003a6.49 6.477 43.146 0 1-.534 1.215 6.49 6.477 43.146 0 1-.774 1.069l1.338.773 1.302-2.288zm-9.557 3.471l-.534 1.47 2.48.884.525-1.446a6.49 6.477 43.146 0 1-2.303-.8 6.49 6.477 43.146 0 1-.168-.108zm6.814.016a6.49 6.477 43.146 0 1-2.475.897l.53 1.457 2.468-.917z\" />\n <path fill=\"currentColor\"\n d=\"M7.648 3.093a4.989 4.989 0 0 0-3.982 2.483 5.013 5.013 0 0 0 1.836 6.834 5.002 5.002 0 0 0 6.83-1.827 5.01 5.01 0 0 0-1.836-6.832 4.976 4.976 0 0 0-2.848-.658zM8 4.08a4 4 0 0 1 4 4 4 4 0 0 1-4 4 4 4 0 0 1-4-4 4 4 0 0 1 4-4z\" />\n </g>\n </svg>\n </span>\n <span class=\"nav_heading_sd\">Preferences</span>\n </button>\n </div>\n} @else {\n <ng-container *ngTemplateOutlet=\"showActiveCallDiv\"></ng-container>\n}\n\n\n<!-- ////////////// -->\n\n <!-- Active Call Div -->\n \n <ng-template #showActiveCallDiv>\n\n\n @if (showTranscriptionPopup) {\n <div class=\"transcription-popup\">\n <div class=\"transcription-header\">\n <span>Live Transcription</span>\n <button class=\"close-btn\" (click)=\"showTranscriptionPopup = false\">\u00D7</button>\n </div>\n <div class=\"transcription-body\">\n <p>{{ transcriptText }}</p>\n </div>\n </div>\n}\n\n\n\n\n\n\n\n<div class=\"container_call\">\n <div class=\"container_call_header\">\n <div class=\"container_call_header_inner\">\n\n @if (!conferenceParticipants || conferenceParticipants.length <= 1) {\n <!-- ------------ add call list swap and merge area start ---------------- -->\n @if (activeCalls.length > 1) {\n <div class=\"container_swap_merge_list\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <div class=\"outer_container_swap_merge\">\n @for (call of activeCalls; track call.phoneNumber; let i = $index) {\n @if (i !== currentActiveCallIndex) {\n <div class=\"container_swap_merge_item\"\n (click)=\"swapLinesToIndex(i)\"\n [ngClass]=\"{ 'active-call': i === currentActiveCallIndex, 'other-call': i !== currentActiveCallIndex }\">\n\n <!-- Avatar -->\n <div class=\"container_recent_item_image\">\n <div class=\"container_swap_merge_item_image_inner\">\n <!-- svg avatar here -->\n </div>\n </div>\n\n <!-- Call Info -->\n <div class=\"container_recent_item_left\">\n <div class=\"container_recent_item_left_inner\">\n <div class=\"contact_field\">{{ call.phoneNumber }}</div>\n @if (call.isOnHold) {\n <div class=\"onhold_st\">On hold</div>\n }\n </div>\n\n <!-- Action Buttons -->\n <div class=\"container_recent_item_right\">\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <!-- merge svg -->\n </div>\n <div class=\"button_text\">Merge</div>\n </button>\n </div>\n <div class=\"right_field\">\n <button class=\"button_swap_merge\">\n <div class=\"button_icon\">\n <!-- swap svg -->\n </div>\n <div class=\"button_text\">Swap</div>\n </button>\n </div>\n </div>\n </div>\n </div>\n }\n }\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n <!-- ------------ add call list swap and merge area end ---------------- -->\n\n @if (isCalling) {\n <div class=\"container_call_info\">Calling...</div>\n } @else {\n @if (isactiveCall) {\n <div class=\"container_call_info\">\n {{ formatTime(activeCalls[currentActiveCallIndex].duration) }}\n </div>\n }\n @if (showCallDisconnected) {\n <div class=\"container_call_info_blinker\">\n <!-- disconnected svg -->\n {{ this.istransfer ? 'Call Transferred' : 'Call ended' }}\n </div>\n }\n }\n\n <div class=\"container_call_ani\">\n @if (isCalling && displayCallingNumber && activeCalls.length === 0) {\n <!-- show what the user dialed while call is spinning up -->\n <div class=\"container_call_ani_number\">\n {{ displayCallingNumber }}\n </div>} \n @else if (activeCalls.length > 0) {\n <div class=\"container_call_ani_number\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.country?.flag }}\n {{ activeCalls[currentActiveCallIndex].phoneNumber }}\n \n </div>\n <div class=\"container_call_ani_name\">\n {{ activeCalls[currentActiveCallIndex].lookupPhoneNumber.phoneNumber?.location }}\n </div>\n } @else {\n <div class=\"container_call_ani_number\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.country?.flag }}\n {{ lastDisconnectedCall?.phoneNumber }}\n </div>\n <div class=\"container_call_ani_name\">\n {{ lastDisconnectedCall?.lookupPhoneNumber?.phoneNumber?.location }}\n </div>\n }\n\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\" [ngClass]=\"{ 'call_animation': isactiveCall }\">\n <!-- big avatar svg -->\n </div>\n </div>\n </div>\n\n } @else {\n <!-- Conference Call Placeholder -->\n <!-- @if block can render conference call template here -->\n }\n\n </div>\n </div>\n\n <div class=\"container_call_content\">\n <div class=\"container_call_dnis\">\n <span>Ext. {{ extensionNumber }}</span>\n </div>\n\n <div class=\"container_call_options\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall && activeCalls.length < 4 }\"\n (click)=\"onAddCall()\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\"> \n <svg fill=\"#000000\" width=\"20\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\"\n xml:space=\"preserve\">\n <path fill=\"currentColor\" d=\"M30,29h16.5c0.8,0,1.5-0.7,1.5-1.5v-3c0-0.8-0.7-1.5-1.5-1.5H30c-0.6,0-1-0.4-1-1V5.5C29,4.7,28.3,4,27.5,4\n h-3C23.7,4,23,4.7,23,5.5V22c0,0.6-0.4,1-1,1H5.5C4.7,23,4,23.7,4,24.5v3C4,28.3,4.7,29,5.5,29H22c0.6,0,1,0.4,1,1v16.5\n c0,0.8,0.7,1.5,1.5,1.5h3c0.8,0,1.5-0.7,1.5-1.5V30C29,29.4,29.4,29,30,29z\" />\n </svg>\n </div>\n <div class=\"button_text\">Add</div>\n </button>\n\n @if (activeCalls.length > 0) {\n <button class=\"button_call_option\" (click)=\"onAddCall()\" type=\"button\">\n <div class=\"button_icon\"> <svg width=\"20\" viewBox=\"0 0 52 52\" aria-hidden=\"true\">\n <path fill=\"currentColor\"\n d=\"M30,29h16.5c0.8,0,1.5-0.7,1.5-1.5v-3c0-0.8-0.7-1.5-1.5-1.5H30c-0.6,0-1-0.4-1-1V5.5C29,4.7,28.3,4,27.5,4h-3\n C23.7,4,23,4.7,23,5.5V22c0,0.6-0.4,1-1,1H5.5C4.7,23,4,23.7,4,24.5v3C4,28.3,4.7,29,5.5,29H22c0.6,0,1,0.4,1,1v16.5\n c0,0.8,0.7,1.5,1.5,1.5h3c0.8,0,1.5-0.7,1.5-1.5V30C29,29.4,29.4,29,30,29z\"/>\n </svg></div>\n <div class=\"button_text\">Conference</div>\n </button>\n }\n\n @if (!isRecording) {\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\"> <svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n <div class=\"button_text\">Record</div>\n </button>\n } @else {\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\">\n <div class=\"button_icon\"><svg width=\"22px\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path fill=\"currentColor\" d=\"M3 10L3 14M7.5 6L7.5 18M12 3V21M16.5 6V18M21 10V14\" stroke=\"#000000\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n <div class=\"button_text\">Stop</div>\n </button>\n }\n\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\"\n (click)=\"isCallTransferOpen = !isCallTransferOpen\">\n <div class=\"button_icon\"> <svg width=\"25px\" height=\"25px\" viewBox=\"0 0 48 48\" version=\"1\" enable-background=\"new 0 0 48 48\">\n <path fill=\"currentColor\"\n d=\"M39.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4h-4.8c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L41,8.4C40.5,7.9,39.7,7.9,39.2,8.4z\" />\n <path fill=\"currentColor\"\n d=\"M11.2,8.4l-1.8,1.8c-6.3,6.5-5.4,22,0,27.6l1.8,1.8c0.5,0.5,1.3,0.5,1.8,0l3.6-3.7c0.5-0.5,0.5-1.3,0-1.8 l-3.4-3.4H8.5c-1.3-1.3-1.3-12.1,0-13.4h4.8l3.3-3.4c0.5-0.5,0.5-1.3,0-1.8L13,8.4C12.5,7.9,11.7,7.9,11.2,8.4z\" />\n <g fill=\"currentColor\">\n <polygon points=\"25.3,18.6 30.7,24 25.3,29.4\" />\n <rect x=\"16\" y=\"22\" width=\"11\" height=\"4\" />\n </g>\n </svg></div>\n <div class=\"button_text\">Transfer</div>\n </button>\n\n @if (isCallTransferOpen) {\n <ng-container *ngTemplateOutlet=\"callTransferTemplate\"></ng-container>\n }\n </div>\n\n <!-- Mute / Unmute -->\n <div class=\"container_dialpad_row\">\n @if (activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isMuted) {\n <button class=\"button_call_option button_elevated\"\n (click)=\"toggleMute()\"\n [ngClass]=\"{ 'button_disabled': showCallDisconnected }\">\n <div class=\"button_icon\"> <svg viewBox=\"0 0 384 512\" width=\"16\">\n <path fill=\"currentColor\"\n d=\"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40z\" />\n </svg></div>\n <div class=\"button_text\">Mute</div>\n </button>\n } @else if (activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isMuted) {\n <button class=\"button_call_option button_active button_elevated\" (click)=\"toggleMute()\">\n <div class=\"button_icon\"> <svg width=\"26\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c15.2-26 23.9-56.3 23.9-88.7l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 21.2-5.1 41.1-14.2 58.7L416 300.8 416 96c0-53-43-96-96-96s-96 43-96 96l0 54.3L38.8 5.1zM344 430.4c20.4-2.8 39.7-9.1 57.3-18.2l-43.1-33.9C346.1 382 333.3 384 320 384c-70.7 0-128-57.3-128-128l0-8.7L144.7 210c-.5 1.9-.7 3.9-.7 6l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6z\" />\n </svg></div>\n <div class=\"button_text\">Unmute</div>\n </button>\n }\n\n <!-- Hold / Unhold -->\n @if (activeCalls.length > 0 && !this.activeCalls[this.currentActiveCallIndex].isOnHold) {\n <button class=\"button_call_option button_elevated\"\n [ngClass]=\"{ 'button_disabled': !isactiveCall }\"\n [disabled]=\"!isactiveCall\"\n (click)=\"toggleHold()\">\n <div class=\"button_icon\"> <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg></div>\n <div class=\"button_text\">Hold</div>\n </button>\n } @else if (activeCalls.length > 0 && this.activeCalls[this.currentActiveCallIndex].isOnHold) {\n <button class=\"button_call_option button_active button_elevated\" (click)=\"toggleHold()\">\n <div class=\"button_icon\">\n <svg viewBox=\"0 0 320 512\" width=\"14\">\n <path fill=\"currentColor\" d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\" />\n </svg></div>\n <div class=\"button_text\">Unhold</div>\n </button>\n \n }\n\n <!-- Keypad -->\n <button class=\"button_call_option button_elevated\"\n [class.button_active]=\"isDailpadOpen\"\n (click)=\"menuDailpad()\"\n [ngClass]=\"{ 'button_disabled': showCallDisconnected }\">\n <div class=\"button_icon\"> <svg width=\"22px\" height=\"22px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n </svg></div>\n <div class=\"button_text\">{{ isDailpadOpen ? 'Hide' : 'Keypad' }}</div>\n </button>\n\n @if (isDailpadOpen) {\n <div class=\"container_popup_dialpad\">\n <div class=\"container_popup_dialpad_inner\">\n <div [formGroup]=\"dtmfForm\">\n <div class=\"container_dtmf_input\">\n <input type=\"tel\" formControlName=\"dtmf\">\n </div>\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\"\n d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onSendDTMF('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\"\n d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n\n <!-- Call Control Buttons -->\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n @if (!showCallDisconnected || isCalling) {\n <button class=\"button_dialpad_digit button_call_red\" (click)=\"dropCurrentCall()\">\n <svg width=\"25\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\" />\n </svg>\n </button>\n } @else if (showCallDisconnected && !isCalling) {\n <button class=\"button_dialpad_digit button_call_green\"\n (click)=\"onRedial()\"\n [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n }\n </div>\n </div>\n </div>\n</div>\n</ng-template>\n\n\n <!-- ////////////////// -->\n <!-- Conference Call Template -->\n <ng-template #conferenceCallTemplate>\n<div class=\"container_active_call_header\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">Conference call</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">\n with {{ conferenceParticipants?.length }} people\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"container_active_call_options\">\n <div class=\"button_active_call_options button_active_call_options_highlighted\">\n <span (click)=\"isConfereceList = !isConfereceList\" class=\"container_active_call_options_button\">\n <svg viewBox=\"0 0 448 512\" width=\"16px\">\n <path fill=\"currentColor\"\n d=\"M201.4 374.6c12.5 12.5 32.8 12.5 45.3 0l160-160c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 306.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160z\" />\n </svg>\n </span>\n </div>\n </div>\n</div>\n\n<!-- Conference List -->\n@if (isConfereceList) {\n <div class=\"container_conference_contact_list\">\n <div class=\"container_conference_contact_list_inner\">\n <div class=\"scrollbox container_conference_contact_list_scrollbox\">\n <div class=\"scrollbox-content\">\n\n @for (person of conferenceParticipants; track person.id) {\n <div class=\"container_conference_contact_item\">\n <!-- Avatar -->\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n\n <!-- Name and Time -->\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ person.name }}</div>\n <div class=\"contact_field_green\">{{ person.duration }}</div>\n </div>\n </div>\n\n <!-- End Button -->\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <button class=\"button_disconnect_call\">\n <svg width=\"22\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M11.7 266.3l41.9 94.3c6.1 13.7 20.8 21.3 35.5 18.4l109.2-21.8c15-3 25.7-16.1 25.7-31.4V240c62.3-20.8 129.7-20.8 192 0v85.8c0 15.3 10.8 28.4 25.7 31.4L550.9 379c14.7 2.9 29.4-4.7 35.5-18.4l41.9-94.3c7.2-16.2 5.1-35.1-7.4-47.7C570.8 168.1 464.2 96 320 96S69.2 168.1 19.1 218.6c-12.5 12.6-14.6 31.5-7.4 47.7z\">\n </path>\n </svg>\n </button>\n </div>\n </div>\n </div>\n\n @if (!$last) {\n <div class=\"container_separator\"></div>\n }\n }\n\n </div>\n </div>\n </div>\n </div>\n}\n\n</ng-template>\n\n\n <ng-template #callTransferTemplate>\n <div class=\"container_transfer_call\">\n <div class=\"container_transfer_call_inner\">\n <div class=\"container_button_close\">\n <span (click)=\"isCallTransferOpen = false\" title=\"Close\">\n <i class=\"fa-sharp fa-solid fa-xmark\"></i>\n </span>\n </div>\n\n <!-- First Div -->\n <div class=\"container_transfer_call_content\" @slideInOut>\n @if (currentView === 'transferListpage') {\n <div class=\"container_active_call_duration\">{{ formatTime(callDuration)}}</div>\n\n <div class=\"container_active_call_header margin_bottom_16 shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">{{ lookupPhoneNumber?.country?.flag }}\n {{ lookupPhoneNumber?.phoneNumber }}</div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_green\">\n <svg viewBox=\"0 0 512 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </div>\n <div class=\"container_active_call_status_green\">Active call</div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">Ext. {{extensionNumber}}</span>\n </div>\n </div>\n </div>\n\n <!-- Tabs -->\n <div class=\"container_transfer_tab_buttons\">\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab1')\" [class.active]=\"activeTab === 'tab1'\">\n <svg width=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M464 256A208 208 0 1 1 48 256a208 208 0 1 1 416 0zM0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\" />\n </svg> Recent</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab2')\" [class.active]=\"activeTab === 'tab2'\">\n <svg width=\"20px\" viewBox=\"0 0 24 24\">\n <path fill=\"currentColor\"\n d=\"M15.71,12.71a6,6,0,1,0-7.42,0,10,10,0,0,0-6.22,8.18,1,1,0,0,0,2,.22,8,8,0,0,1,15.9,0,1,1,0,0,0,1,.89h.11a1,1,0,0,0,.88-1.1A10,10,0,0,0,15.71,12.71ZM12,12a4,4,0,1,1,4-4A4,4,0,0,1,12,12Z\" />\n </svg> Internal</button>\n <button class=\"button_transfer_tab\" (click)=\"selectTab('tab3')\" [class.active]=\"activeTab === 'tab3'\">\n <svg width=\"18px\" height=\"18px\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\" d=\"M256,400a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M256,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M384,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,272a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,144a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" />\n <path fill=\"currentColor\" d=\"M128,16a48,48,0,1,0,48,48,48,48,0,0,0-48-48Z\" /></svg>\n Dail</button>\n </div>\n\n <!-- Tab 1 -->\n @if (activeTab === 'tab1') {\n <!-- <div class=\"container_transfer_tab_content\">\n <app-call-history (makeCallEv)=\"makeCallFromContact($event)\"></app-call-history>\n </div> -->\n <div class=\"container_transfer_tab_content\">\n <app-call-history [mode]=\"'transfer'\" (transferEv)=\"transferToFromHistory($event)\"> </app-call-history>\n</div>\n }\n\n <!-- Tab 2 -->\n @if (activeTab === 'tab2') {\n <div class=\"container_transfer_tab_content\">\n <div class=\"container_transfer_internal_search\">\n <input type=\"search\" placeholder=\"Type to search\">\n </div>\n <div class=\"container_transfer_contact_list\">\n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n <!-- Instead of repeating static contacts, render via array -->\n @for (contact of internalContacts; track contact.ext) {\n <div class=\"container_contact_item\" (click)=\"goToDiv('transferDetails'); makeCallFromContact(contact.phone)\">\n <div class=\"container_contact_item_image\">\n <div class=\"container_contact_item_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"49px\" width=\"49px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\">\n </path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 c-0.964-1.144-2.024-2.326-3.184-3.527c-1.741-1.802-3.71-3.646-5.924-5.47c-2.952-2.431-6.339-4.824-10.204-7.026 c-1.877-1.07-3.873-2.092-5.98-3.055c-0.062-0.028-0.118-0.059-0.18-0.087c-9.792-4.44-22.106-7.529-37.416-7.529 s-27.624,3.089-37.416,7.529c-0.338,0.153-0.653,0.318-0.985,0.474c-1.431,0.674-2.806,1.376-4.128,2.101 c-0.716,0.393-1.417,0.792-2.101,1.197c-3.421,2.027-6.475,4.191-9.15,6.395c-2.213,1.823-4.182,3.668-5.924,5.47 c-1.161,1.201-2.22,2.384-3.184,3.527c-0.964,1.144-1.832,2.25-2.609,3.299c-0.778,1.049-1.464,2.04-2.065,2.955 c-0.557,0.848-1.033,1.622-1.447,2.324c-0.033,0.056-0.073,0.119-0.104,0.174c-0.435,0.744-0.79,1.392-1.07,1.926 c-0.559,1.068-0.818,1.678-0.818,1.678v0.398c18.285,17.927,43.322,28.985,70.945,28.985c27.678,0,52.761-11.103,71.055-29.095 v-0.289c0,0-0.619-1.45-1.992-3.778C174.594,173.238,174.117,172.463,173.561,171.615z\">\n </path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 c1.772-0.532,3.482-1.188,5.12-1.958c2.184-1.027,4.242-2.258,6.15-3.67c2.863-2.119,5.39-4.646,7.509-7.509 c0.706-0.954,1.367-1.945,1.98-2.971c0.919-1.539,1.729-3.155,2.422-4.84c0.462-1.123,0.872-2.277,1.226-3.458 c0.177-0.591,0.341-1.188,0.49-1.792c0.299-1.208,0.542-2.443,0.725-3.701c0.275-1.887,0.417-3.827,0.417-5.811 c0-1.984-0.142-3.925-0.417-5.811c-0.184-1.258-0.426-2.493-0.725-3.701c-0.15-0.604-0.313-1.202-0.49-1.793 c-0.354-1.181-0.764-2.335-1.226-3.458c-0.693-1.685-1.504-3.301-2.422-4.84c-0.613-1.026-1.274-2.017-1.98-2.971 c-2.119-2.863-4.646-5.39-7.509-7.509c-1.909-1.412-3.966-2.643-6.15-3.67c-1.638-0.77-3.348-1.426-5.12-1.958 c-1.181-0.355-2.39-0.655-3.624-0.896c-2.468-0.484-5.035-0.737-7.68-0.737c-21.162,0-37.345,16.183-37.345,37.345 C68.657,109.317,84.84,125.5,106.002,125.5z\">\n </path>\n </g>\n </svg>\n </div>\n </div>\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ contact.name }}</div>\n <div class=\"contact_field\">{{ contact.phone }}</div>\n @if (contact.role) {\n <div class=\"contact_field_grey\">\n <div class=\"contact_field_highlighted\"><span>{{ contact.role }}</span></div>\n </div>\n }\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field\">\n <span class=\"right_field_content\">Ext. {{ contact.ext }}</span>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n </div>\n }\n\n <!-- Tab 3 -->\n @if (activeTab === 'tab3') {\n <div class=\"container_transfer_tab_content\">\n <form [formGroup]=\"transferForm\">\n <div class=\"container_transfer_contact_list\">\n <div class=\"container_phone_number_input margin_bottom_16\">\n <button class=\"button_phonebook\" (click)=\"isDirectoryOpen = !isDirectoryOpen\">\uD83D\uDCD6</button>\n <input placeholder=\"Phone Number\" type=\"tel\" formControlName=\"target\">\n <button class=\"button_backspace\" (click)=\"onBackspace()\"></button>\n </div>\n\n @if (isDirectoryOpen) {\n <div class=\"container_transfer_internal_contact_list\">\n <div class=\"container_transfer_contact_list_inner\">\n <div class=\"scrollbox\">\n <div class=\"scrollbox-content\">\n @for (directoryContact of directoryContacts; track directoryContact.id) {\n <div class=\"container_contact_item\">\n <div class=\"container_contact_item_left\">\n <div class=\"container_contact_item_left_inner\">\n <div class=\"contact_field\">{{ directoryContact.name }}</div>\n <div class=\"contact_field\">{{ directoryContact.phone }}</div>\n </div>\n </div>\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">\n <div class=\"container_rating\">\n @for (star of [1,2,3,4,5]; track $index) {\n <span [class.filled]=\"star <= directoryContact.rating\">\u2605</span>\n }\n </div>\n </span>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n </div>\n </div>\n }\n\n <!-- Dialpad -->\n <div class=\"container_dialpad_digits\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('1')\">1</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('2')\">2</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('3')\">3</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('4')\">4</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('5')\">5</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('6')\">6</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('7')\">7</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('8')\">8</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('9')\">9</button>\n </div>\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('*')\">\n <svg viewBox=\"0 0 512 512\" height=\"17px\">\n <path fill=\"currentColor\" d=\"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9\n 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7\n 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8\n 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32\n 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9\n 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38\n 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86\n 102.4l122 70.4L208 32z\" />\n </svg>\n </button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('0')\">0</button>\n <button class=\"button_dialpad_digit\" (click)=\"onDigitClick('#')\">\n <svg height=\"19px\" viewBox=\"0 0 448 512\">\n <path fill=\"currentColor\" d=\"M181.3 32.4c17.4 2.9 29.2 19.4 26.3\n36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4\n26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9\n0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5\n69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1\n0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2\n384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64\n192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4\n19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\" />\n </svg></button>\n </div>\n </div>\n\n <div class=\"container_dialpad_buttons\">\n <div class=\"container_dialpad_row\">\n @if (isAddingNewCall) {\n <button class=\"button_dialpad_digit button_call_green\"\n (click)=\"makeCall(transferForm.value.target)\"\n [disabled]=\"!phoneNumber\"\n [ngClass]=\"{ 'button_call_disabled': !phoneNumber }\">\n <svg viewBox=\"0 0 512 512\" height=\"18px\">\n <path fill=\"currentColor\"\n d=\"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\" />\n </svg>\n </button>\n } @else {\n <button type=\"submit\" class=\"button_dialpad_digit button_call_green\" (click)=\"onTransferCall()\"> <svg height=\"20px\" viewBox=\"0 0 52 52\" enable-background=\"new 0 0 52 52\" xml:space=\"preserve\">\n <g>\n <path fill=\"currentColor\" d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8\n c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3\n c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\" />\n <path fill=\"currentColor\" d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0\n l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\" />\n </g>\n </svg></button>\n }\n </div>\n </div>\n </div>\n </form>\n </div>\n }\n }\n</div>\n\n <!-- Second Div -->\n @if (currentView === 'transferDetails') {\n <div class=\"container_transfer_call_content\" @slideInOut>\n <div class=\"container_active_call_duration\">00:10</div>\n <div class=\"container_active_call_header shadow_st\">\n <div class=\"container_active_call_avatar\">\n <div class=\"container_active_call_avatar_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"45px\" width=\"45px\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\"></path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 ...\"></path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 ...\"></path>\n </g>\n </svg>\n </div>\n </div>\n\n <div class=\"container_active_call_info\">\n <div class=\"container_active_call_info_inner\">\n <div class=\"container_active_call_number\">\n {{ lookupPhoneNumber?.country?.flag }} {{ lookupPhoneNumber?.phoneNumber }}\n </div>\n <div class=\"container_active_call_details\">\n <div class=\"container_active_call_details_inner\">\n <div class=\"container_active_call_icon_grey\">\n <svg viewBox=\"0 0 320 512\" width=\"12\">\n <path fill=\"currentColor\"\n d=\"M128 64L0 64 0 448l128 0 0-384zm192 0L192 64l0 384 128 0 0-384z\"></path>\n </svg>\n </div>\n <div class=\"container_active_call_status_grey\">On hold</div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"container_contact_item_right\">\n <div class=\"right_field right_field_highlighted\">\n <span class=\"right_field_content\">Ext. {{ extensionNumber }}</span>\n </div>\n </div>\n </div>\n\n <div class=\"container_transfer_call_details\">\n <div class=\"container_call_ani_number padding_top_nt\">+91 (654) 9876549</div>\n <div class=\"container_call_ani_name\">Rajeev kumar singh</div>\n <div class=\"container_call_ani_image\">\n <div class=\"container_call_ani_image_inner\">\n <svg viewBox=\"0 0 212 212\" height=\"85\" width=\"85\" version=\"1.1\" x=\"0px\" y=\"0px\"\n enable-background=\"new 0 0 212 212\">\n <path fill=\"#DFE5E7\"\n d=\"M106.251,0.5C164.653,0.5,212,47.846,212,106.25S164.653,212,106.25,212C47.846,212,0.5,164.654,0.5,106.25 S47.846,0.5,106.251,0.5z\"></path>\n <g>\n <path fill=\"#FFFFFF\"\n d=\"M173.561,171.615c-0.601-0.915-1.287-1.907-2.065-2.955c-0.777-1.049-1.645-2.155-2.608-3.299 ...\"></path>\n <path fill=\"#FFFFFF\"\n d=\"M106.002,125.5c2.645,0,5.212-0.253,7.68-0.737c1.234-0.242,2.443-0.542,3.624-0.896 ...\"></path>\n </g>\n </svg>\n </div>\n </div>\n </div>\n\n <div class=\"container_call_dnis\">\n <span>Ext. {{ extensionNumber }}</span>\n </div>\n\n <div class=\"container_call_options margin_bottom_nt\">\n <div class=\"container_dialpad_row margin_bottom_16\">\n <button class=\"button_call_option\" (click)=\"mergeCall()\">\n <div class=\"button_icon\"><svg width=\"22\" viewBox=\"0 0 512 512\">\n <path fill=\"currentColor\"\n d=\"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l97.2 0c9.7 0 18.9 4.4 25 12L247 256 154.2 372c-6.1 7.6-15.3 12-25 12L32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l97.2 0c29.2 0 56.7-13.3 75-36l99.2-124 80.6 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c6-6 9.4-14.1 9.4-22.6s-3.4-16.6-9.4-22.6l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-80.6 0L204.2 100c-18.2-22.8-45.8-36-75-36L32 64z\"></path>\n </svg></div>\n <div class=\"button_text\">Merge</div>\n </button>\n\n <button class=\"button_call_option\">\n <div class=\"button_icon\"> <svg width=\"26px\" viewBox=\"0 0 640 512\">\n <path fill=\"currentColor\"\n d=\"M150.6 73.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 173.3 96 320c0 53 43 96 96 96l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-146.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96zM336 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32-14.3 32-32l0 146.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L544 338.7 544 192c0-53-43-96-96-96L336 96z\"></path>\n </svg></div>\n <div class=\"button_text\">Swap</div>\n </button>\n\n <button class=\"button_call_option\">\n <div class=\"button_icon\"><svg width=\"19px\" viewBox=\"0 0 52 52\">\n <path fill=\"currentColor\"\n d=\"M48.5,37.9L42.4,33c-1.4-1.1-3.4-1.2-4.8-0.1l-5.2,3.8c-0.6,0.5-1.5,0.4-2.1-0.2l-7.8-7l-7-7.8 c-0.6-0.6-0.6-1.4-0.2-2.1l3.8-5.2c1.1-1.4,1-3.4-0.1-4.8l-4.9-6.1c-1.5-1.8-4.2-2-5.9-0.3L3,8.4c-0.8,0.8-1.2,1.9-1.2,3 c0.5,10.2,5.1,19.9,11.9,26.7S30.2,49.5,40.4,50c1.1,0.1,2.2-0.4,3-1.2l5.2-5.2C50.5,42.1,50.4,39.3,48.5,37.9z\"></path>\n <path fill=\"currentColor\"\n d=\"M48.4,2H33c-1,0-1.3,1.1-0.5,1.9l4.9,5l-9,9.1c-0.5,0.5-0.5,1.4,0,1.9l3.7,3.7c0.5,0.5,1.3,0.5,1.9,0 l9.1-9.1l5.1,4.9C48.9,20.3,50,20,50,19V3.7C50,3,49.1,2,48.4,2z\"></path>\n </svg>\n</div>\n <div class=\"button_text\">Transfer</div>\n </button>\n </div>\n </div>\n\n <div class=\"container_transfer_disconnect\">\n <div class=\"container_dialpad_row\">\n <button class=\"button_dialpad_digit button_call_red\" (click)=\"goToDiv('transferListpage')\">\n <svg width=\"36px\" viewBox=\"0 0 76 76\">\n <path fill=\"currentColor\"\n d=\"M 16.2013,39.582L 15.4175,39.4096L 14.8094,38.9315L 14.4029,38.2193L 14.25,37.364L 14.25,34.9055C 14.25,33.184 14.6023,31.6057 15.3069,30.1704C 16.0116,28.7352 16.9698,27.4788 18.1818,26.4013C 19.3937,25.3237 20.8095,24.4424 22.429,23.7573C 24.0486,23.0722 25.7732,22.6277 27.6031,22.4239L 31.304,22.0792L 34.9918,21.8256L 39.109,21.715L 42.966,21.8451L 46.101,22.0987L 48.9628,22.489C 50.7276,22.7318 52.3883,23.199 53.945,23.8906C 55.5017,24.5822 56.8567,25.4625 58.0101,26.5313C 59.1635,27.6002 60.0752,28.8468 60.7451,30.2712C 61.4151,31.6956 61.75,33.2599 61.75,34.964L 61.75,37.4486L 61.5874,38.2681L 61.1386,38.9511L 60.4785,39.4096L 59.6752,39.582L 51.8897,39.582L 51.0994,39.4096L 50.4588,38.9413L 50.0327,38.2584L 49.8799,37.4226L 49.8799,32.1217L 49.7075,31.1656L 49.2295,30.3818L 48.5075,29.8452C 48.23,29.7108 47.9286,29.6436 47.6034,29.6436L 28.7413,29.6436C 28.4161,29.6436 28.0974,29.7108 27.7852,29.8452L 26.9722,30.3818L 26.4128,31.1851C 26.2697,31.4973 26.1982,31.8225 26.1982,32.1607L 26.1982,37.364L 26.0356,38.2193L 25.5803,38.9315L 24.9104,39.4096L 24.1038,39.582L 16.2013,39.582 Z M 34.8333,41.1667L 41.1666,41.1667L 41.1667,52.6458L 45.9167,47.8958L 45.9167,54.2292L 38,62.5417L 30.0833,54.2292L 30.0833,47.8958L 34.8333,52.6458L 34.8333,41.1667 Z \" />\n </svg>\n </button>\n </div>\n </div>\n </div>\n}\n\n\n\n\n\n\n\n\n\n\n\n </div>\n </div>\n </ng-template>\n\n \n\n\n</ng-template>\n\n<div id=\"videoPanel\" style=\"display: none\">\n <audio #rmtAudio id=\"rmtAudio\" autoplay></audio>\n <audio #lclAudio id=\"lclAudio\" autoplay muted></audio>\n <video #rmtVideo id=\"rmtVideo\" autoplay></video>\n <video #lclVideo id=\"lclVideo\" autoplay muted controls title=\"Local Video\"></video>\n</div>\n", styles: ["@import\"https://fonts.googleapis.com/css?family=Open+Sans:300,400,500,600,700,800\";@import\"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css\";:host{--sd-app-color: #ff6633;--sd-app-color-dark: #ff5805;--sd-app-color-light: #fe8c66;--sd-text-font-family: \"Open Sans\", \"sans-serif\", \"Helvetica Neue\", \"Helvetica\", \"Arial\";--sd-text-color: #666;--sd-text-color-inverse: #fff;--sd-text-color-light: #ccc;--sd-text-color-medium: #999;--sd-text-color-dark: #333;--sd-background-color: #fff;--sd-border-color-light: #e3e3e3;--sd-border-color-dark: #c9c9c9}.message_label{width:100%;font-size:13px;font-family:var(--sd-text-font-family);letter-spacing:-.25px;border-radius:4px;font-weight:600;border:1px solid #f5c6cb;padding:8px 11px;position:relative}.error_message{color:#e1143c;background-color:#f8d7da;border-color:#dfadb2}.success_message{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert_message{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.properties_form_field{width:100%;font-size:13px!important;font-family:var(--sd-text-font-family)!important;font-weight:600!important;letter-spacing:-.24px!important;color:#555!important}.container_avaya_login{width:100%;height:calc(100vh - 51px);padding:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.container_avaya_login_inner{margin:0 auto;width:100%;max-width:370px;padding:65px 20px 20px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:flex}.container_connection_status_overlay{width:100%;height:100%;position:absolute;left:0;right:0;bottom:0;background-color:#6669;display:flex;justify-content:center;z-index:9999999;padding:20px}.container_connection_status{width:100%;background:var(--sd-background-color);padding:0 10px;border-radius:8px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);display:flex;height:42px;align-items:center;position:relative;box-shadow:#32325d40 0 6px 12px -2px,#0000004d 0 3px 7px -3px}.container_connection_status span{padding:0 0 0 8px}.container_connection_status .fa-circle-dot{color:#f66060}.container_connection_status_loader{position:absolute;right:15px}.container_avaya_login_content{position:relative;width:100%}.container_avaya_logo{margin:0;padding:0 26px 24px;width:100%;text-align:center}.container_avaya_logo_image{margin:0 auto;width:120px;height:35px;background:var(--sd-background-color) url() center no-repeat;background-size:120px}.container_avaya_logo h3{margin:0;padding:6px 0 0;font-family:var(--sd-text-font-family);font-size:18px;font-weight:700;letter-spacing:-.45px;color:var(--sd-text-color-dark);position:relative}.container_avaya_logo h3 span{font-size:8px;position:absolute;top:8px}.container_avaya_login_error{width:100%;white-space:normal}.container_avaya_login_form{width:100%;margin:0;padding:26px 0 0;position:relative}.container_avaya_login_form form{width:100%;margin:0;padding:0}.container_avaya_login_form .form_field{margin:0;padding:0;width:100%}.avaya_login_button_area{padding:10px 0 0}.container_icon_eye{position:absolute;right:15px}.container_avaya_login_form .button_submit_login{font:14px / 48px var(--sd-text-font-family);display:inline-block;height:48px;background:#cd1f1e;color:var(--sd-text-color-inverse);border:1px solid #cd1f1e;font-weight:600;padding:0 12px;border-radius:4px;outline:none;letter-spacing:-.24px;cursor:pointer;width:100%;position:relative}.container_avaya_login_form .button_submit_login_loader{background:#cd1f1e!important;color:var(--sd-text-color-inverse)!important;border:1px solid #cd1f1e!important;cursor:auto}.container_avaya_login_form .button_submit_login:disabled{background:#f1f1f1;color:var(--sd-text-color-medium);border:1px solid #f1f1f1}.button_submit_loader:after{content:\"\";position:absolute;width:16px;height:16px;inset:0;margin:auto;border:3px solid transparent;border-top-color:#fff;border-radius:50%;animation:button_submit_loader_spinner 1s ease infinite}@keyframes button_submit_loader_spinner{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.container_avaya_softphone{width:100%;height:100%;position:relative}.container_avaya_softphone_inner{width:100%;position:absolute;top:0;left:0;right:0;padding:0;height:calc(100% - 51px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background:#000}.container_call{margin:0 auto;padding:0;position:relative;width:100%;height:100%;background:var(--sd-background-color)}.container_dialpad_header{width:100%;position:relative;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99999;background:var(--sd-background-color);padding:15px 15px 0}.container_dialpad_header_inner2{width:100%;margin:0;padding:15px 15px 0;background:#f7f7f7;background:linear-gradient(180deg,#f7f7f7 72%,#fff);border-radius:12px 12px 0 0;position:relative}.container_avaya_extension{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:8px 10px;border:1px solid var(--sd-border-color-light);border-radius:12px;margin-bottom:15px;background:#f0f0f0}.container_avaya_extension_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center}.container_avaya_extension_left .extension_label{display:flex;align-items:center;line-height:normal;text-align:left}.container_avaya_extension_left .extension_number{display:flex;align-items:center;line-height:20px}.container_avaya_extension_right{flex-basis:auto;flex-direction:column;flex-grow:1;text-align:right;justify-items:flex-end}.container_avaya_extension_right button{background:none;border:none;outline:none;color:#a6a6a6;font-weight:600;border-radius:50%;align-items:center;justify-content:center;-webkit-transition-duration:.3s;transition-duration:.3s;background:#f0f0f0;height:38px;width:38px}.container_avaya_extension_right button:hover{color:var(--sd-text-color-dark);background:var(--sd-border-color-light)}.dialpad_container_sd{position:absolute;width:100%;right:0;left:0;top:101px;height:calc(100vh - 101px);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}.scrollbox{height:100%;overflow-y:scroll;overflow-x:hidden;visibility:hidden;padding:0 0 7px;position:relative;scroll-behavior:smooth;scrollbar-width:thin;width:100%}.scrollbox-content,.scrollbox:hover,.scrollbox:focus{visibility:visible}.container_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:8px;overflow:hidden;margin-bottom:10px;cursor:pointer}.container_contact_item_image{display:flex}.container_contact_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative}.container_contact_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_contact_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_contact_item_left .contact_field{font-size:13px;margin-bottom:2px}.contact_dark{color:var(--sd-text-color-dark)}.contact_gray{color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_grey{font-size:12px;color:var(--sd-text-color);padding-top:2px;display:flex}.container_contact_item_left .contact_field_green{font-size:13px;margin-bottom:2px;color:#6c0}.container_contact_item_left .contact_field_highlighted{display:flex;font-size:11px;color:var(--sd-text-color-medium)}.container_contact_item_left .contact_field_highlighted span{background:#6c0;border-radius:3px;text-transform:uppercase;color:var(--sd-text-color-inverse);font-size:9px;padding:2px 4px}.container_contact_item_right{display:flex;flex-direction:row}.container_contact_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.container_contact_item_right .right_field_highlighted{font-size:16px;color:#29abe0}.container_contact_item_right .right_field_content{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 8px;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .right_recent_content{display:inline-block;padding:0;font-size:11px;color:var(--sd-text-color)}.container_contact_item_right .container_rating{font-size:11px;cursor:pointer}.container_contact_item_right .container_rating span{color:gray;transition:color .3s}.container_contact_item_right .container_rating span.filled{color:gold}.container_dialpad_digits{width:100%;display:flex;justify-content:center;margin-bottom:10px;flex-direction:column}.container_dialpad_row{display:flex;column-gap:10px;flex-direction:row;flex-shrink:0;justify-content:center;margin-bottom:10px}.button_dialpad_digit{display:block;width:50px;height:50px;display:flex;column-gap:20px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;font-size:22px;font-weight:700;color:var(--sd-text-color-dark);background:var(--sd-background-color);-webkit-transition-duration:.3s;transition-duration:.3s;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.button_dialpad_digit:hover{background:#000;color:var(--sd-text-color-inverse)}.button_call_green{background:#6c0;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.button_call_green:hover{background:#5ab400;color:var(--sd-text-color-inverse);width:60px;height:60px}.button_call_red{background:#e0261f;color:var(--sd-text-color-inverse);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s;z-index:9999}.button_call_red:hover{background:#cf211a}.button_call_disabled{background:#eee;color:var(--sd-text-color-light);width:60px;height:60px;-webkit-transition-duration:.3s;transition-duration:.3s}.container_dialpad_buttons{width:100%;display:flex;justify-content:center;padding-top:0;margin-bottom:6px}.container_call_header{width:100%;position:absolute;top:0;left:0;right:0;height:221px;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);z-index:99;background:var(--sd-background-color)}.container_call_header_inner{width:100%;margin:0;padding:10px 15px 15px;position:relative}.container_call_info{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color)}.container_call_info_blinker{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:red;animation:blinker 1s linear infinite}@keyframes blinker{26%{opacity:0}}.container_call_ani{width:100%;margin:0;padding:0}.container_call_ani_number{text-align:center;font-size:20px;font-weight:600;padding-top:26px}.container_call_ani_name{text-align:center;font-size:13px;font-weight:600;padding-top:2px}.container_call_ani_image{margin:0;padding:24px 0 0;width:100%}.container_call_ani_image_inner{display:flex;align-items:center;flex:0 0 auto;padding:0;width:85px;height:85px;position:relative;margin:0 auto;border-radius:100%}.container_call_content{width:100%;position:absolute;top:221px;left:0;right:0;height:calc(100% - 221px);font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);padding-top:20px;display:flex;flex-basis:auto;flex-direction:column;align-items:center;justify-content:center}.container_call_dnis{width:100%;text-align:center;padding-bottom:16px}.container_call_dnis span{display:inline-block;border-radius:26px;border:1px solid #e5e5e5;padding:5px 16px}.container_call_options{width:100%;display:flex;justify-content:center;margin-bottom:16px;flex-direction:column}.button_call_option{display:block;width:80px;height:60px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 10px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative}.button_call_option .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_call_option .button_text{display:flex;justify-content:center;color:var(--sd-text-color)}.button_active{color:#67cc02}.button_elevated{position:relative;z-index:9999}.button_disabled{color:gray;cursor:not-allowed;pointer-events:none;opacity:.6}.button_call_option[disabled],.button_disabled{opacity:.5;pointer-events:none;display:inline-flex}.container_popup_dialpad{position:absolute;z-index:999;left:0;right:0;bottom:0}.container_popup_dialpad_inner{background:#f1f1f1;background:linear-gradient(180deg,#f1f1f1 44%,#fff);margin:0 auto;padding:10px 15px 20px;border-radius:8px;width:88%;position:relative;height:475px}.container_popup_dialpad .button_close{position:absolute;right:-15px;top:-17px;z-index:9}.container_popup_dialpad .button_close span{width:32px;height:32px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;box-shadow:#0000001a 0 0 5px,#0000001a 0 0 1px;border:1px solid #ebebeb}.container_popup_dialpad .button_close span:hover{background:#f1f1f1;color:var(--sd-text-color-dark)}.container_popup_dialpad .button_close span .fa-xmark{font-size:1.4em;font-weight:400}.container_dtmf_input{width:100%;margin:0;padding:0 0 10px;position:relative}.container_dtmf_input input{width:100%;display:flex;height:38px;outline:none;text-align:center;align-items:center;border:1px solid #f1f1f1;font-size:26px;font-weight:400;color:transparent;text-shadow:0 0 0 #000;padding:0;background:#f1f1f1}.container_active_call_header{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:10px;border:1px solid var(--sd-border-color-light);border-radius:12px;overflow:hidden}.container_active_call_avatar{display:flex}@keyframes play1{0%{transform:scale(1)}15%{box-shadow:0 0 0 2px #57b84666}25%{box-shadow:0 0 0 3px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 5px #bde4a966,0 0 0 30px #fff3}}.container_active_call_avatar_inner{margin:0 auto;padding:0;width:50px;height:50px;background:#dfe6e8;color:var(--sd-text-color-dark);position:relative;animation:play1 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden;border-radius:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.container_active_call_info{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1}.container_active_call_info_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_active_call_duration{display:flex;justify-content:center;font-size:14px;font-weight:600;width:100%;color:var(--sd-text-color);margin-bottom:10px}.container_active_call_number{font-size:13px;margin-bottom:2px}.container_active_call_details{font-size:13px;color:#6c0;padding-top:2px}.container_active_call_details_inner{display:flex;margin:0;padding:0;justify-content:left}.container_active_call_icon_grey{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:var(--sd-text-color-medium)}.container_active_call_icon_green{display:flex;width:18px;height:16px;justify-content:center;align-items:center;color:#6c0}.container_active_call_status_green{display:flex;justify-content:center;align-items:center;color:#6c0;padding-left:6px;font-size:12px}.container_active_call_status_grey{display:flex;justify-content:center;align-items:center;color:var(--sd-text-color-medium);padding-left:6px;font-size:12px}.container_active_call_options{display:flex;flex-direction:row}.container_active_call_options .button_active_call_options{display:flex;flex-basis:auto;justify-content:right}.container_active_call_options .button_active_call_options_highlighted{font-size:16px;color:#29abe0}.container_active_call_options_button{display:flex;border-radius:26px;border:none;padding:0;font-size:11px;color:var(--sd-text-color);width:32px;height:32px;justify-content:center;align-items:center}.container_active_call_options_button:hover{background:#f1f1f1}.container_conference_contact_list{position:relative;width:100%;background:#f7f7f7;border-top:1px solid #eee;border-bottom:1px solid #eee;height:149px;padding:0;margin-top:16px}.container_swap_merge_contact_list{position:relative;width:100%;background:var(--sd-background-color);height:149px;padding:0;margin-top:32px}.container_conference_contact_list_inner{margin:0;padding:0;position:relative;width:100%;height:100%}.container_conference_contact_list_scrollbox{padding:12px 15px}.container_conference_contact_item{width:100%;position:relative;display:flex;flex-direction:row;align-items:center;padding:0 10px;overflow:hidden;cursor:pointer}.button_disconnect_call{display:block;width:42px;height:42px;display:flex;margin:0;align-items:center;justify-content:center;line-height:normal;border-radius:50%;outline:none;border:none;color:#e0261f;background:#f7f7f7;-webkit-transition-duration:.3s;transition-duration:.3s}.button_disconnect_call:hover{color:var(--sd-text-color-inverse);background:#e0261f;-webkit-transition-duration:.3s;transition-duration:.3s}.container_separator{height:1px;width:100%;background:#ededed;margin:11px 0}.container_transfer_call{position:absolute;z-index:99999;left:0;right:0;bottom:-51px;width:100%;background:var(--sd-background-color)}.container_transfer_call_inner{background:var(--sd-background-color);box-shadow:#11111a1a 0 4px 16px,#11111a0d 0 8px 32px;padding:20px 15px 10px;border-radius:0;width:100%;position:relative;height:596px;overflow:hidden}.container_transfer_call_inner h2{font-family:var(--sd-text-font-family);font-size:20px;font-weight:700;color:var(--sd-text-color-dark);letter-spacing:-1px;padding:0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_button_close{position:absolute;right:4px;top:4px}.container_button_close span{width:36px;height:36px;background:var(--sd-background-color);display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer}.container_button_close span:hover{background:var(--sd-background-color)}.container_button_close .fa-xmark{font-size:1.6em;font-weight:400;color:var(--sd-text-color-light)}.container_button_close span:hover .fa-xmark:hover{color:var(--sd-text-color-dark)}.container_transfer_call_content{margin:0;padding:5px 0 0;width:100%;background:var(--sd-background-color);min-height:485px}.container_transfer_call_content h3{font-family:var(--sd-text-font-family);font-size:14px;font-weight:700;color:var(--sd-text-color);letter-spacing:-.26px;padding:8px 0 0;line-height:normal;text-transform:capitalize;margin-bottom:15px}.container_transfer_call_content h3 span{color:var(--sd-text-color-dark)}.container_transfer_call_details{width:100%;margin:0;padding:10px 15px 69px;position:relative}.container_transfer_tab_buttons{display:flex;gap:10px;align-items:center;margin-bottom:15px}.button_transfer_tab{padding:10px;border:none;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color);background-color:var(--sd-border-color-light);cursor:pointer;width:105px;border-radius:28px;outline:none}.button_transfer_tab.active{background-color:var(--sd-app-color);color:#fff}.container_transfer_tab_content{margin:0;padding:0;width:100%}.container_transfer_internal_search{margin:0 0 15px;padding:0;width:100%}.container_transfer_internal_search input{padding:0 16px;width:100%;outline:none;display:block;border:1px solid var(--sd-border-color-dark);color:var(--sd-text-color-medium);font-size:12px;letter-spacing:-.25px;font-family:var(--sd-text-font-family);background:var(--sd-background-color);font-style:italic;font-weight:400;position:relative;border-radius:27px;height:48px}.container_transfer_contact_list{width:100%;margin:0;padding:0;position:relative;height:336px}.container_transfer_contact_list_inner{width:100%;position:relative;height:100%}.container_transfer_internal_contact_list{position:absolute;width:100%;left:0;right:0;background:var(--sd-background-color);height:332px}.container_transfer_disconnect{width:100%;display:flex;justify-content:center;padding-top:3px;margin-bottom:6px}.container_avaya_footer{width:100%;padding:0;background:#f7f7f7;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;color:var(--sd-text-color-medium);position:relative;display:flex;height:51px;justify-content:center;align-items:center;border-top:1px solid var(--sd-border-color-light);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:999;position:absolute;bottom:0;left:0}.margin_bottom_16{margin-bottom:16px}.margin_bottom_nt{margin-bottom:10px}.padding_top_nt{padding-top:7px}.shadow_st{box-shadow:#00000026 0 2px 8px}.call_animation{animation:play 2s ease infinite;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden}.mini-call-switcher{display:flex;justify-content:center;margin-top:10px}.mini-call{padding:6px 12px;margin:0 6px;background:#eaeaea;border-radius:8px;cursor:pointer;font-size:14px}.mini-call.active{background-color:#c6f6d5;font-weight:700}.history-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}.history-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--sd-background-color);padding:20px;z-index:1000;box-shadow:0 2px 10px #0000004d;border-radius:5px;width:600px;max-height:80vh;overflow-y:auto}.history-content{position:relative}.history-content h3{margin-top:0}.close-btn{background:transparent;border:none;font-size:1.5rem;position:absolute;top:0;right:0;cursor:pointer}.history-content table{width:100%;border-collapse:collapse;margin-top:1rem}.history-content th,.history-content td{padding:.5rem;border:1px solid var(--sd-text-color-light)}@keyframes play{0%{transform:scale(1)}15%{box-shadow:0 0 0 4px #57b84680}25%{box-shadow:0 0 0 5px #98d48266,0 0 0 20px #fff3}25%{box-shadow:0 0 0 10px #c2e5b180,0 0 0 30px #fff3}}::-webkit-input-placeholder{color:#ddd}::-moz-placeholder{color:var(--sd-text-color-dark)}:-ms-input-placeholder{color:var(--sd-text-color-dark)}:-moz-placeholder{color:var(--sd-text-color-dark)}.slide_st{left:-100px;-webkit-animation:slide .5s forwards;-webkit-animation-delay:2s;animation:slide .5s forwards;animation-delay:0s}@-webkit-keyframes slide{to{left:0}}@keyframes slide{to{left:0}}.tabs_sd{width:100%;position:absolute;bottom:0;left:0;right:0;display:flex;height:51px;border-top:1px solid var(--sd-border-color-light);background:#f9f9f9;z-index:999999}.tab_heading_btn{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;align-items:center;padding:0;border:none;cursor:pointer;width:25%;font-family:var(--sd-text-font-family);font-size:11px;font-weight:600;line-height:normal;color:var(--sd-text-color-medium);background:none;transition:background-color .3s linear;-webkit-transition:background-color .3s linear;-o-transition:background-color .3s linear;-ms-transition:background-color .3s linear}.nav_icon{display:flex;align-items:center;justify-content:center;height:22px;margin-bottom:1px}.nav_heading_sd{display:flex;align-items:center}.tab_heading_btn.active{color:var(--sd-app-color);background:url() top center no-repeat}.tab-content_sd{width:100%;height:100%;font-family:var(--sd-text-font-family);font-size:13px;font-weight:600;line-height:normal;background:var(--sd-background-color);-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative}.container_transfer_fav_list{width:100%;margin:0;padding:0;position:relative;height:376px}.outer_container_swap_merge{width:100%;margin:0;padding:0}.container_swap_merge_item{width:100%;position:relative;display:flex;flex-direction:row;height:72px;border-radius:8px;overflow:hidden}.container_recent_item_image{display:flex;align-items:center}.container_swap_merge_item_image_inner{margin:0 auto;padding:0;width:50px;height:50px;position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sd-text-font-family);font-size:26px;color:var(--sd-text-color-inverse);font-weight:400}.container_recent_item_left{display:flex;flex-basis:auto;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;position:relative;border-top:1px solid #e9edef}.container_recent_item_left_inner{display:flex;flex-basis:1;flex-direction:column;padding:0 0 0 10px}.container_recent_item_left .contact_field{font-size:13px;color:var(--sd-text-color-dark);margin-bottom:2px}.onhold_st{font-family:var(--sd-text-font-family);font-size:12px;color:var(--sd-text-color-medium);font-weight:600}.container_recent_item_right{display:flex;flex-direction:row;position:absolute;right:0}.container_recent_item_right .right_field{display:flex;flex-basis:auto;justify-content:right}.button_swap_merge{display:block;width:32px;height:45px;display:flex;flex-direction:column;flex-shrink:0;column-gap:0px;margin:0 0 0 28px;align-items:center;justify-content:center;line-height:normal;outline:none;border:none;font-size:12px;font-weight:600;color:var(--sd-text-color-dark);background:none;-webkit-transition-duration:.3s;transition-duration:.3s;position:relative;pointer-events:all;cursor:pointer}.button_swap_merge .button_icon{display:flex;justify-content:center;align-items:center;height:40px}.button_swap_merge .button_text{display:flex;justify-content:center;color:var(--sd-text-color-dark)}@media only screen and (max-width: 767px){.previewcontent{width:95%!important}.bgSecWrap .numberArrow{left:0!important;top:-20px!important}.transcription-popup{position:fixed;bottom:20px;right:20px;width:320px;max-height:250px;background:#fff;border-radius:10px;box-shadow:0 4px 12px #0003;padding:12px;z-index:1000;display:flex;flex-direction:column}.transcription-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:14px;margin-bottom:8px}.transcription-body{overflow-y:auto;font-size:13px;line-height:1.4;color:#333}.close-btn{border:none;background:transparent;font-size:18px;cursor:pointer}}\n"] }]
|
|
2710
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i1$1.FormBuilder }, { type: CountryService }, { type: PhoneNumberLookupService }, { type: AvayaIPOService }, { type: RecordingManagerService }, { type: CallSocketService }, { type: i8.SnugdeskAuthenticationService }, { type: i8.TenantService }, { type: i8.UserService }], propDecorators: { tenantId: [{
|
|
2052
2711
|
type: Input,
|
|
2053
2712
|
args: ['tenantId']
|
|
2054
2713
|
}], userId: [{
|
|
@@ -2068,8 +2727,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.4", ngImpor
|
|
|
2068
2727
|
}] } });
|
|
2069
2728
|
|
|
2070
2729
|
class AvayaIPOWidgetModule {
|
|
2071
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.
|
|
2072
|
-
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.
|
|
2730
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOWidgetModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
2731
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOWidgetModule, declarations: [AvayaIPOWidgetComponent,
|
|
2073
2732
|
CallHistoryComponent,
|
|
2074
2733
|
DialpadComponent,
|
|
2075
2734
|
DeviceSelectorComponent], imports: [CommonModule,
|
|
@@ -2081,7 +2740,7 @@ class AvayaIPOWidgetModule {
|
|
|
2081
2740
|
MatFormField,
|
|
2082
2741
|
MatLabel,
|
|
2083
2742
|
NgxIntlTelInputModule], exports: [AvayaIPOWidgetComponent] });
|
|
2084
|
-
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.
|
|
2743
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOWidgetModule, imports: [CommonModule,
|
|
2085
2744
|
FormsModule,
|
|
2086
2745
|
ReactiveFormsModule,
|
|
2087
2746
|
MatFormFieldModule,
|
|
@@ -2089,7 +2748,7 @@ class AvayaIPOWidgetModule {
|
|
|
2089
2748
|
MatFormField,
|
|
2090
2749
|
NgxIntlTelInputModule] });
|
|
2091
2750
|
}
|
|
2092
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.
|
|
2751
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AvayaIPOWidgetModule, decorators: [{
|
|
2093
2752
|
type: NgModule,
|
|
2094
2753
|
args: [{
|
|
2095
2754
|
declarations: [
|