@vgroup/dialbox 0.0.5 → 0.0.7
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.
- package/esm2020/lib/components/call-progress/call-progress.component.mjs +438 -0
- package/esm2020/lib/components/call-progress/incoming-call/incoming-call.component.mjs +191 -0
- package/esm2020/lib/components/caller-id-dialog/caller-id-dialog.component.mjs +56 -0
- package/esm2020/lib/dialbox.component.mjs +3 -3
- package/esm2020/lib/dialbox.module.mjs +18 -3
- package/esm2020/lib/shared/global-constant.mjs +6 -0
- package/esm2020/public-api.mjs +4 -1
- package/fesm2015/vgroup-dialbox.mjs +706 -8
- package/fesm2015/vgroup-dialbox.mjs.map +1 -1
- package/fesm2020/vgroup-dialbox.mjs +689 -8
- package/fesm2020/vgroup-dialbox.mjs.map +1 -1
- package/lib/components/call-progress/call-progress.component.d.ts +80 -0
- package/lib/components/call-progress/incoming-call/incoming-call.component.d.ts +41 -0
- package/lib/components/caller-id-dialog/caller-id-dialog.component.d.ts +25 -0
- package/lib/dialbox.module.d.ts +8 -5
- package/lib/shared/global-constant.d.ts +5 -0
- package/package.json +3 -2
- package/public-api.d.ts +3 -0
|
@@ -0,0 +1,438 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { Device } from '@twilio/voice-sdk';
|
|
3
|
+
import { environment } from '../../environments/environments';
|
|
4
|
+
import swal from 'sweetalert2';
|
|
5
|
+
import { keypad } from '../../../keypad';
|
|
6
|
+
import { interval } from 'rxjs';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../service/extension.service";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
import * as i3 from "@angular/forms";
|
|
11
|
+
import * as i4 from "./incoming-call/incoming-call.component";
|
|
12
|
+
export class CallProgressComponent {
|
|
13
|
+
constructor(extensionService, cdr) {
|
|
14
|
+
this.extensionService = extensionService;
|
|
15
|
+
this.cdr = cdr;
|
|
16
|
+
this.endCallEvent = new EventEmitter();
|
|
17
|
+
this.incomingCallsNewInfo = new EventEmitter();
|
|
18
|
+
this.minimiseEvent = new EventEmitter();
|
|
19
|
+
this.showRingAnimation = false;
|
|
20
|
+
this.timer = '00:00';
|
|
21
|
+
this.showKeypad = false;
|
|
22
|
+
this.keypadVal = keypad;
|
|
23
|
+
this.callInput = '';
|
|
24
|
+
this.isMute = false;
|
|
25
|
+
this.disbaleEndCallBtn = true;
|
|
26
|
+
this.showClearBtn = false;
|
|
27
|
+
this.isCollops = false;
|
|
28
|
+
// Incoming call variables
|
|
29
|
+
this.incomingCallDiv = false;
|
|
30
|
+
this.showCallProgressEvent = new EventEmitter();
|
|
31
|
+
this.incomingCallInitiated = new EventEmitter();
|
|
32
|
+
this.isRecording = false;
|
|
33
|
+
this.isPaused = false;
|
|
34
|
+
this.timeElapsed = 0; // in seconds
|
|
35
|
+
this.recordCall = false;
|
|
36
|
+
this.callStatus = 'ringing';
|
|
37
|
+
this.isMinimised = false;
|
|
38
|
+
}
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
console.log('Call Progress Component');
|
|
41
|
+
}
|
|
42
|
+
ngOnChanges(changes) {
|
|
43
|
+
console.log('Call Progress Component ngOnChanges');
|
|
44
|
+
if (changes['callData']) {
|
|
45
|
+
console.log('Call Progress Component ngOnChanges callData', changes['callData']);
|
|
46
|
+
if (changes['callData'].currentValue.isIncomingCall) {
|
|
47
|
+
this.incomingCallDiv = true;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
//for outgoing call
|
|
51
|
+
this.startCall(changes['callData'].currentValue);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (changes['newIncomingCallData']) {
|
|
55
|
+
try {
|
|
56
|
+
if (changes['newIncomingCallData'].currentValue) {
|
|
57
|
+
if (this.call && (this.call.status() == 'open')) {
|
|
58
|
+
this.call.disconnect();
|
|
59
|
+
this.call = changes['newIncomingCallData'].currentValue;
|
|
60
|
+
this.call?.accept();
|
|
61
|
+
this.callData.phone = this.call?.parameters['From'];
|
|
62
|
+
this.callData.name = this.call?.customParameters.get('name');
|
|
63
|
+
this.callData.img = this.call?.customParameters.get('image') || 'assets/images/user.jpg';
|
|
64
|
+
this.incomingCallInitiated.emit();
|
|
65
|
+
this.startTimer();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
console.log(e);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
ngAfterViewInit() { }
|
|
75
|
+
async startCall(callData) {
|
|
76
|
+
try {
|
|
77
|
+
this.showRingAnimation = true;
|
|
78
|
+
const payload = {
|
|
79
|
+
channelId: environment.channelId,
|
|
80
|
+
userId: localStorage.getItem('userId'),
|
|
81
|
+
to: callData.phone,
|
|
82
|
+
scope: 'local',
|
|
83
|
+
fromNumber: callData.from
|
|
84
|
+
};
|
|
85
|
+
const response = await this.initiateCall(payload);
|
|
86
|
+
if (response.status == 200) {
|
|
87
|
+
const { id: callAuthId, recordCall } = await this.getCallAuthId(response);
|
|
88
|
+
this.getUserInformation(callAuthId);
|
|
89
|
+
this.recordCall = recordCall; // Store the recordCall value
|
|
90
|
+
const tokenData = await this.getOutgoingCallToken(callAuthId);
|
|
91
|
+
await this.connectToDevice(tokenData.token, callData);
|
|
92
|
+
// Poll the status for 30-45 seconds
|
|
93
|
+
this.pollCallStatus(callAuthId);
|
|
94
|
+
}
|
|
95
|
+
else if (response.status == 201) {
|
|
96
|
+
swal("Error", response.message.join("<br/>"), "error");
|
|
97
|
+
this.endCall();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
catch (error) {
|
|
101
|
+
this.showRingAnimation = false;
|
|
102
|
+
this.handleError(error);
|
|
103
|
+
this.endCall();
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
async initiateCall(payload) {
|
|
107
|
+
return await this.extensionService.initiateCall(payload).toPromise();
|
|
108
|
+
}
|
|
109
|
+
async getCallAuthId(response) {
|
|
110
|
+
return {
|
|
111
|
+
id: response.callauth.id,
|
|
112
|
+
recordCall: response.callauth.recordCall
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
async getOutgoingCallToken(callAuthId) {
|
|
116
|
+
return await this.extensionService.getOutgoingCallToken({ authId: callAuthId }).toPromise();
|
|
117
|
+
}
|
|
118
|
+
async connectToDevice(token, callData) {
|
|
119
|
+
const options = {
|
|
120
|
+
codecPreferences: ['opus', 'pcmu'],
|
|
121
|
+
closeProtection: true,
|
|
122
|
+
};
|
|
123
|
+
this.device = new Device(token.value, options);
|
|
124
|
+
this.call = await this.device.connect({
|
|
125
|
+
params: {
|
|
126
|
+
From: callData.from,
|
|
127
|
+
To: callData.phone,
|
|
128
|
+
Env: environment.abb,
|
|
129
|
+
Token: token.id,
|
|
130
|
+
Ext: callData.extNum
|
|
131
|
+
},
|
|
132
|
+
rtcConstraints: { audio: { deviceId: 'default' } },
|
|
133
|
+
});
|
|
134
|
+
this.setupEventListeners();
|
|
135
|
+
}
|
|
136
|
+
setupEventListeners() {
|
|
137
|
+
this.startTimer();
|
|
138
|
+
this.device?.on('error', (err) => {
|
|
139
|
+
console.log(err);
|
|
140
|
+
this.showRingAnimation = false;
|
|
141
|
+
this.stopTimer();
|
|
142
|
+
});
|
|
143
|
+
this.call?.on('error', (error) => {
|
|
144
|
+
this.showRingAnimation = false;
|
|
145
|
+
this.stopTimer();
|
|
146
|
+
});
|
|
147
|
+
this.call?.on('disconnect', () => {
|
|
148
|
+
this.endCall();
|
|
149
|
+
});
|
|
150
|
+
this.call?.on('ringing', () => {
|
|
151
|
+
});
|
|
152
|
+
this.call?.on('reject', () => {
|
|
153
|
+
this.endCall();
|
|
154
|
+
});
|
|
155
|
+
this.call?.on('accept', () => {
|
|
156
|
+
this.showRingAnimation = false;
|
|
157
|
+
this.disbaleEndCallBtn = false;
|
|
158
|
+
// Start recording if recordCall is true and call is accepted for 30 seconds
|
|
159
|
+
// if (this.recordCall) {
|
|
160
|
+
// setTimeout(() => {
|
|
161
|
+
// if (this.isRecording) return; // If already recording, skip
|
|
162
|
+
// this.startRecording();
|
|
163
|
+
// }, 30000);
|
|
164
|
+
// } else {
|
|
165
|
+
// this.stopRecording();
|
|
166
|
+
// }
|
|
167
|
+
});
|
|
168
|
+
this.call?.on('messageReceived', (message) => {
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
startTimer() {
|
|
172
|
+
let seconds = 0;
|
|
173
|
+
this.intervalId = setInterval(() => {
|
|
174
|
+
seconds++;
|
|
175
|
+
this.timer = this.formatTime(seconds);
|
|
176
|
+
}, 1000);
|
|
177
|
+
}
|
|
178
|
+
stopTimer() {
|
|
179
|
+
clearInterval(this.intervalId);
|
|
180
|
+
this.timer = '00:00';
|
|
181
|
+
}
|
|
182
|
+
formatTime(totalSeconds) {
|
|
183
|
+
const minutes = Math.floor(totalSeconds / 60);
|
|
184
|
+
const seconds = totalSeconds % 60;
|
|
185
|
+
return `${this.pad(minutes)}:${this.pad(seconds)}`;
|
|
186
|
+
}
|
|
187
|
+
pad(value) {
|
|
188
|
+
return value < 10 ? `0${value}` : `${value}`;
|
|
189
|
+
}
|
|
190
|
+
handleError(error) {
|
|
191
|
+
swal("Error", error, "error");
|
|
192
|
+
}
|
|
193
|
+
endCall() {
|
|
194
|
+
this.endCallEvent.emit();
|
|
195
|
+
if (this.call) {
|
|
196
|
+
this.call.disconnect();
|
|
197
|
+
}
|
|
198
|
+
this.showRingAnimation = false;
|
|
199
|
+
this.stopTimer();
|
|
200
|
+
this.maximiseDialpad();
|
|
201
|
+
}
|
|
202
|
+
toggleMute() {
|
|
203
|
+
this.isMute = !this.isMute;
|
|
204
|
+
this.call?.mute(this.isMute);
|
|
205
|
+
}
|
|
206
|
+
toggleKeypad() {
|
|
207
|
+
this.showKeypad = !this.showKeypad;
|
|
208
|
+
this.callInput = '';
|
|
209
|
+
}
|
|
210
|
+
onCallInputs(num) {
|
|
211
|
+
try {
|
|
212
|
+
if (Number.isInteger(num) || num == '+' || num == '*' || num == '#') {
|
|
213
|
+
if (num == '#') {
|
|
214
|
+
new Audio(`/assets/dial-tones/dtmf/dtmf-hash-.mp3`).play();
|
|
215
|
+
}
|
|
216
|
+
else if (num == '*') {
|
|
217
|
+
new Audio(`/assets/dial-tones/dtmf/dtmf-star-.mp3`).play();
|
|
218
|
+
}
|
|
219
|
+
else {
|
|
220
|
+
new Audio(`/assets/dial-tones/dtmf/dtmf-${num}-.mp3`).play();
|
|
221
|
+
}
|
|
222
|
+
this.callInput = this.callInput + String(num);
|
|
223
|
+
this.showClearBtn = true;
|
|
224
|
+
}
|
|
225
|
+
let str = String(num);
|
|
226
|
+
this.call?.sendDigits(str);
|
|
227
|
+
}
|
|
228
|
+
catch (e) {
|
|
229
|
+
console.log(e);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
onCallInputEnter(ev) {
|
|
233
|
+
try {
|
|
234
|
+
this.call?.sendDigits(String(ev.key));
|
|
235
|
+
}
|
|
236
|
+
catch (e) {
|
|
237
|
+
console.log(e);
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
closeIncomingCall(data) {
|
|
241
|
+
// this.incomingCallDiv = false;
|
|
242
|
+
if (data.show) {
|
|
243
|
+
//this.showCallProgressEvent.emit()
|
|
244
|
+
// handle incoming call accepted
|
|
245
|
+
this.startTimer();
|
|
246
|
+
this.disbaleEndCallBtn = false;
|
|
247
|
+
this.call = data.call;
|
|
248
|
+
const incomingDetail = this.extensionService.getCallSid();
|
|
249
|
+
this.incomingRecordCall = incomingDetail.recordCall;
|
|
250
|
+
// Start recording if the call is answered and recording is enabled
|
|
251
|
+
if (this.incomingRecordCall) {
|
|
252
|
+
this.startRecording();
|
|
253
|
+
}
|
|
254
|
+
else {
|
|
255
|
+
this.isRecording = false;
|
|
256
|
+
}
|
|
257
|
+
this.cdr.detectChanges();
|
|
258
|
+
}
|
|
259
|
+
else {
|
|
260
|
+
// incoming call rejected
|
|
261
|
+
this.endCallEvent.emit();
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
clearInputs() {
|
|
265
|
+
this.callInput = this.callInput.slice(0, -1);
|
|
266
|
+
}
|
|
267
|
+
minimiseDialpad() {
|
|
268
|
+
this.minimiseEvent.emit(true);
|
|
269
|
+
this.isMinimised = true;
|
|
270
|
+
}
|
|
271
|
+
maximiseDialpad() {
|
|
272
|
+
this.minimiseEvent.emit(false);
|
|
273
|
+
this.isMinimised = false;
|
|
274
|
+
}
|
|
275
|
+
toggleRecording() {
|
|
276
|
+
if (this.isRecording) {
|
|
277
|
+
this.stopRecording();
|
|
278
|
+
}
|
|
279
|
+
else {
|
|
280
|
+
this.startRecording();
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
startRecording() {
|
|
284
|
+
let sid;
|
|
285
|
+
const details = this.extensionService.getCallSid();
|
|
286
|
+
this.incomingCallSid = details.callSid;
|
|
287
|
+
this.incomingRecordCall = details.recordCall;
|
|
288
|
+
sid = this.incomingCallSid ? this.incomingCallSid : this.callSid;
|
|
289
|
+
// if (!this.incomingRecordCall && !this.recordCall) {
|
|
290
|
+
// return;
|
|
291
|
+
// }
|
|
292
|
+
this.extensionService.getCallRecording(sid).subscribe(response => {
|
|
293
|
+
this.isRecording = true;
|
|
294
|
+
this.isPaused = false;
|
|
295
|
+
this.timeElapsed = 0;
|
|
296
|
+
this.startTimer1();
|
|
297
|
+
}, error => {
|
|
298
|
+
console.error('Error starting recording', error);
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
stopRecording() {
|
|
302
|
+
// if (!this.incomingRecordCall && !this.recordCall) {
|
|
303
|
+
// return;
|
|
304
|
+
// }
|
|
305
|
+
this.isRecording = false;
|
|
306
|
+
this.isPaused = false;
|
|
307
|
+
if (this.timerSubscription) {
|
|
308
|
+
this.timerSubscription.unsubscribe();
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
pauseRecording() {
|
|
312
|
+
const details = this.extensionService.getCallSid();
|
|
313
|
+
this.incomingCallSid = details.callSid;
|
|
314
|
+
this.incomingRecordCall = details.recordCall;
|
|
315
|
+
const sid = this.incomingCallSid ? this.incomingCallSid : this.callSid;
|
|
316
|
+
// if (!this.incomingRecordCall && !this.recordCall) {
|
|
317
|
+
// return;
|
|
318
|
+
// }
|
|
319
|
+
this.extensionService.pauseOrResumeRecording(sid, 'pause').subscribe(response => {
|
|
320
|
+
this.stopRecordingTimer();
|
|
321
|
+
this.isPaused = true;
|
|
322
|
+
}, error => {
|
|
323
|
+
console.error('Error pausing recording:', error);
|
|
324
|
+
// Consider updating the UI to show the error state
|
|
325
|
+
});
|
|
326
|
+
}
|
|
327
|
+
resumeRecording() {
|
|
328
|
+
let sid;
|
|
329
|
+
const details = this.extensionService.getCallSid();
|
|
330
|
+
this.incomingCallSid = details.callSid;
|
|
331
|
+
this.incomingRecordCall = details.recordCall;
|
|
332
|
+
sid = this.incomingCallSid ? this.incomingCallSid : this.callSid;
|
|
333
|
+
// if (!this.incomingRecordCall && !this.recordCall) {
|
|
334
|
+
// return; // Skip if recording is not enabled
|
|
335
|
+
// }
|
|
336
|
+
this.extensionService.pauseOrResumeRecording(sid, 'resume').subscribe(response => {
|
|
337
|
+
this.isPaused = false;
|
|
338
|
+
this.startTimer1();
|
|
339
|
+
}, error => {
|
|
340
|
+
console.error('Error resuming recording', error);
|
|
341
|
+
});
|
|
342
|
+
}
|
|
343
|
+
startTimer1() {
|
|
344
|
+
this.timerSubscription = interval(1000).subscribe(() => {
|
|
345
|
+
this.timeElapsed++;
|
|
346
|
+
});
|
|
347
|
+
}
|
|
348
|
+
stopRecordingTimer() {
|
|
349
|
+
if (this.timerSubscription) {
|
|
350
|
+
this.timerSubscription.unsubscribe(); // Pause the timer
|
|
351
|
+
this.timerSubscription = undefined; // Optionally reset the subscription
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
getFormattedTime() {
|
|
355
|
+
const minutes = Math.floor(this.timeElapsed / 60);
|
|
356
|
+
const seconds = this.timeElapsed % 60;
|
|
357
|
+
return `${minutes}:${seconds < 10 ? '0' : ''}${seconds}`;
|
|
358
|
+
}
|
|
359
|
+
pollCallStatus(callAuthId) {
|
|
360
|
+
const maxTime = 30000; // Poll for up to 30 seconds
|
|
361
|
+
const pollInterval = 3000; // Poll every 3 seconds
|
|
362
|
+
let elapsedTime = 0;
|
|
363
|
+
const intervalId = setInterval(async () => {
|
|
364
|
+
elapsedTime += pollInterval;
|
|
365
|
+
try {
|
|
366
|
+
const statusResponse = await this.extensionService.getCallStatus(callAuthId).toPromise();
|
|
367
|
+
if (statusResponse && statusResponse.callDetails) {
|
|
368
|
+
this.callStatus = statusResponse.callDetails.callStatus;
|
|
369
|
+
if (this.callStatus === 'in-progress') {
|
|
370
|
+
this.callSid = statusResponse.callDetails.callSid;
|
|
371
|
+
if (this.recordCall && !this.isRecording) {
|
|
372
|
+
this.startRecording();
|
|
373
|
+
}
|
|
374
|
+
clearInterval(intervalId);
|
|
375
|
+
}
|
|
376
|
+
else if (this.callStatus === 'completed') {
|
|
377
|
+
clearInterval(intervalId);
|
|
378
|
+
this.endCall();
|
|
379
|
+
this.stopRecording();
|
|
380
|
+
}
|
|
381
|
+
else if (this.callStatus === 'ringing') {
|
|
382
|
+
// Continue polling; do not clear the interval yet
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
catch (error) {
|
|
387
|
+
clearInterval(intervalId);
|
|
388
|
+
}
|
|
389
|
+
if (elapsedTime >= maxTime) {
|
|
390
|
+
// console.log('Max polling time reached. Stopping poll.');
|
|
391
|
+
clearInterval(intervalId);
|
|
392
|
+
}
|
|
393
|
+
}, pollInterval);
|
|
394
|
+
}
|
|
395
|
+
getUserInformation(id) {
|
|
396
|
+
this.extensionService.getUserInformation(id).subscribe(response => {
|
|
397
|
+
console.log(response);
|
|
398
|
+
}, error => {
|
|
399
|
+
console.error('Error starting recording', error);
|
|
400
|
+
});
|
|
401
|
+
}
|
|
402
|
+
incomingCallsNewList(data) {
|
|
403
|
+
this.newIncomingCallsList = data;
|
|
404
|
+
this.incomingCallsNewInfo.emit(this.newIncomingCallsList);
|
|
405
|
+
}
|
|
406
|
+
selectedIncomingCallInfo(data) {
|
|
407
|
+
this.selectedIncomingCall = data;
|
|
408
|
+
}
|
|
409
|
+
ngOnDestroy() {
|
|
410
|
+
this.callData.dial = false;
|
|
411
|
+
if (this.timerSubscription) {
|
|
412
|
+
this.timerSubscription.unsubscribe();
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
CallProgressComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CallProgressComponent, deps: [{ token: i1.ExtensionService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
417
|
+
CallProgressComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CallProgressComponent, selector: "lib-call-progress", inputs: { callData: "callData", newIncomingCallData: "newIncomingCallData", newIncomingCallsList: "newIncomingCallsList" }, outputs: { endCallEvent: "endCallEvent", incomingCallsNewInfo: "incomingCallsNewInfo", minimiseEvent: "minimiseEvent", showCallProgressEvent: "showCallProgressEvent", incomingCallInitiated: "incomingCallInitiated" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"call-container\" *ngIf=\"!isMinimised\" [ngClass]=\"{'collops': isCollops, 'incoming-call-container': selectedIncomingCall?.isClickExpand}\">\n <div id=\"minimize-btn-div\">\n <span class=\"material-symbols-outlined minimize-btn\" (click)=\"minimiseDialpad()\">\n minimize\n </span>\n </div>\n <lib-incoming-call *ngIf=\"incomingCallDiv\" [incomingCallData]=\"callData\" [newIncomingCallsList]=\"newIncomingCallsList\" (closeIncomingCallDiv)=\"closeIncomingCall($event)\" \n (incomingCallsNewList)=\"incomingCallsNewList($event)\" (selectedIncomingCallInfo)=\"selectedIncomingCallInfo($event)\"></lib-incoming-call>\n <div style=\"display: flex; flex-direction: column;position: relative; width: 100%;\">\n \n <div class=\"call-animation\" [ngClass]=\"{'call-animation-play': showRingAnimation}\">\n <img class=\"avatar-img\" [src]=\"callData.img\" alt=\"\" width=\"120\" />\n </div>\n <div class=\"callerDetails\">\n <h1 [ngStyle]=\"{'margin-top': showKeypad ? '0': '8px'}\">{{callData.name}}</h1>\n <p>{{callData.displayNum ? callData.displayNum : callData.phone }}</p>\n <h4 style=\"margin-top: 4px\">{{timer}}</h4>\n </div>\n <div class=\"record-action-btns\" [ngStyle]=\"{'margin-top': showKeypad ? '0': '20px'}\">\n <div class=\"record-btn-container\">\n <button class=\"record-btn start-stop\" *ngIf=\"!isRecording\" [ngClass]=\"{'recording': isRecording, 'stopped': !isRecording}\" (click)=\"toggleRecording()\" [title]=\"isRecording ? 'Stop Recording' : 'Start Recording'\" [disabled]=\"disbaleEndCallBtn\">\n <span class=\"recording-icon\"></span>\n </button>\n <div class=\"pause-resume-btns\">\n <button class=\"record-btn pause-resume\" *ngIf=\"isRecording && !isPaused\" (click)=\"pauseRecording()\">\n <span class=\"material-symbols-outlined\"> pause </span>\n </button>\n <button class=\"record-btn pause-resume\" *ngIf=\"isPaused\" (click)=\"resumeRecording()\">\n <span class=\"material-symbols-outlined\"> play_arrow </span>\n </button>\n </div>\n </div>\n <div *ngIf=\"isRecording\" class=\"timer-display\">\n {{ getFormattedTime() }}\n </div>\n </div>\n <div *ngIf=\"showKeypad\" class=\"sendDigit\">\n <input type=\"text\" name=\"call-inputs\" id=\"call-input\" [(ngModel)]=\"callInput\" (keyup)=\"onCallInputEnter($event)\">\n <span class=\"material-symbols-outlined input-clear-btn\" *ngIf=\"callInput\" (click)=\"clearInputs()\">close_small</span>\n </div>\n <div class=\"btn-container justify-content-center\" *ngIf=\"showKeypad\">\n <div class=\"key-btn\" *ngFor=\"let key of keypadVal\" (click)=\"onCallInputs(key.num)\">\n {{key.num}}\n <span class=\"btn-albhabets\">{{key.text ? key.text : ' '}}</span>\n </div>\n </div>\n <div class=\"call-action-btns\" [ngStyle]=\"{'margin-top': showKeypad ? '0': '160px'}\">\n <button class=\"call-sec-btn\" [disabled]=\"disbaleEndCallBtn\" [ngStyle]=\"{'top': showKeypad ? '0': '-70px'}\" (click)=\"toggleMute()\">\n <span class=\"material-symbols-outlined\" *ngIf=\"isMute\"> mic_off </span>\n <span class=\"material-symbols-outlined\" *ngIf=\"!isMute\"> mic </span>\n\n </button>\n <button class=\"call-btn end-call-btn\" [disabled]=\"disbaleEndCallBtn\" (click)=\"endCall()\">\n <span class=\"material-symbols-outlined\"> call_end </span>\n </button>\n <button class=\"call-sec-btn\" [ngStyle]=\"{'top': showKeypad ? '0': '-70px'}\" [disabled]=\"disbaleEndCallBtn\">\n <span class=\"material-symbols-outlined\" (click)=\"toggleKeypad()\"> transition_dissolve </span>\n </button>\n </div>\n <!-- <div class=\"mt-2 px-3 call-info-wrapper \" [ngClass]=\"{'open-collops': isCollops}\">\n <div class=\"text-center\" >\n <i class=\"fa fa-angle-down\" *ngIf=\"isCollops\" (click)=\"isCollops = !isCollops\"></i>\n <i class=\"fa fa-angle-up\" *ngIf=\"!isCollops\" (click)=\"isCollops = !isCollops\"></i>\n </div>\n <ng-container *ngIf=\"isCollops\">\n <div class=\"row mb-2\">\n <div class=\"col-6\">\n <div >First Name:</div>\n <div >test ttttt</div>\n </div>\n <div class=\"col-6\">\n <div>Last Name:</div>\n <div>tetst test </div>\n </div>\n </div>\n <div class=\"mb-2\">\n <div class=\"\">Email:</div>\n <div class=\"\">abcdeft@vgroup.com</div>\n </div>\n <div class=\"row mb-2\">\n <div class=\"col-6\">\n <div class=\"\">Number:</div>\n <div class=\"\">63545985264225</div>\n </div>\n <div class=\"col-6\">\n <div class=\"\">Language:</div>\n <div class=\"\">English</div>\n </div>\n </div>\n <div class=\"row mb-2\">\n <div class=\"col-6\">\n <div class=\"\">Image :</div>\n <div class=\"\">test.jpg </div>\n </div>\n <div class=\"col-6\">\n <div class=\"\">Extension :</div>\n <div class=\"\">4596</div>\n </div>\n </div>\n <div class=\" mb-2\">\n <div class=\"\">Note :</div>\n <div class=\"\">tes test test </div>\n </div>\n <div class=\" mb-2\">\n <div class=\"\">\n <div class=\"\">Subject:</div>\n <div class=\"\">hello world | test</div>\n </div>\n </div>\n <div class=\" mb-4\">\n <div class=\"\">\n <div class=\"\">Message:</div>\n <div class=\"\">test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test </div>\n </div>\n </div>\n </ng-container>\n </div> -->\n </div>\n\n <div class=\"wave-container\">\n <svg class=\"waves\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n viewBox=\"0 24 150 28\" preserveAspectRatio=\"none\" shape-rendering=\"auto\">\n <defs>\n <path id=\"gentle-wave\" d=\"M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z\" />\n </defs>\n <g class=\"parallax\">\n <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"0\" fill=\"rgba(255,255,255,0.7)\" />\n <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"3\" fill=\"rgba(255,255,255,0.5)\" />\n <!-- <use\n xlink:href=\"#gentle-wave\"\n x=\"48\"\n y=\"5\"\n fill=\"rgba(255,255,255,0.3)\"\n /> -->\n <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"7\" fill=\"#fff\" />\n </g>\n </svg>\n </div>\n</div>\n\n<div class=\"min-call-container\" *ngIf=\"isMinimised\">\n <span class=\"material-symbols-outlined fullscreen\" (click)=\"maximiseDialpad()\"> open_in_full </span>\n <div style=\"display: flex; width: 100%\">\n <div>\n <div class=\"min-call-animation\" id=\"call-avatar\">\n <img class=\"min-avatar-img\" [src]=\"callData.img\" alt=\"\" />\n </div>\n </div>\n <div>\n <div class=\"min-callerDetails\">\n <div class=\"name\">\n {{callData.name}}\n </div>\n <p style=\"margin: 0\">{{callData.displayNum ? callData.displayNum : callData.phone }}</p>\n </div>\n </div>\n </div>\n <div class=\"min-btn-container\">\n <div class=\"min-timer\">{{timer}}</div>\n <button class=\"min-call-sec-btn\" (click)=\"toggleMute()\" [disabled]=\"disbaleEndCallBtn\">\n <span class=\"material-symbols-outlined\" *ngIf=\"isMute\"> mic_off </span>\n <span class=\"material-symbols-outlined\" *ngIf=\"!isMute\"> mic </span>\n </button>\n <button class=\"min-call-btn end-call-btn\" [disabled]=\"disbaleEndCallBtn\" (click)=\"endCall()\">\n <span class=\"material-symbols-outlined\"> call_end </span>\n </button>\n </div>\n</div>", styles: [".call-container{width:385px;height:646px;margin:auto;border-radius:30px;box-shadow:6px 6px 10px -1px #00000026,-5px -4px 10px -1px #00000026;display:flex;box-sizing:border-box;position:relative;overflow:hidden;justify-content:center;align-items:center}.collops{height:660px!important}.incoming-call-container{width:752px!important}.call-animation{background:#fff;width:100px;height:100px;position:relative;margin:20px auto 0;border-radius:100%;border:solid 4px #fff;display:flex;align-items:center;justify-content:center}.call-animation:before{position:absolute;content:\"\";top:0;left:0;width:100%;height:100%;backface-visibility:hidden;border-radius:50%}.call-animation-play{animation:play 3s linear infinite}.call-info-wrapper{height:20px;overflow-y:auto;background:white;transition:height 1s}.open-collops{height:180px!important}.avatar-img{width:94px;height:94px;border-radius:100%}@keyframes play{0%{transform:scale(1)}15%{box-shadow:0 0 0 2px #fff6}25%{box-shadow:0 0 0 4px #fff6,0 0 0 8px #fff3}25%{box-shadow:0 0 0 8px #fff6,0 0 0 16px #fff3}50%{box-shadow:0 0 0 10px #fff6,0 0 0 20px #fff3}to{box-shadow:0 0 0 10px #fff6,0 0 0 20px #fff3;transform:scale(1.1);opacity:0}}.callerDetails{margin-top:8px;color:#fff;display:flex;flex-direction:column;align-items:center}.callerDetails h1{width:230px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:12px 0 0;color:#fff;text-transform:capitalize;text-align:center}.callerDetails h4{margin:0;color:#fff}.callerDetails p{margin-top:-3px;margin-bottom:0;color:#fff}.call-sec-btn{position:relative;box-sizing:border-box;border:1px solid #cccbcb;background-color:transparent;border-radius:25px;padding:12px;box-shadow:6px 6px 10px -1px #bebebe26,-5px -4px 10px -1px #d2d2d226}.call-sec-btn span{color:#cccbcb}.call-btn{width:60px;height:60px;background-color:#fff;border-radius:30px;box-sizing:border-box;border:2px solid white;margin:0 16px}.end-call-btn{background-color:#e14e4e}.end-call-btn span{color:#fff!important}.call-btn span{color:#234de8}.btn-container{display:flex;flex-wrap:wrap;padding:0 30px}.key-btn{width:50px;height:50px;background-color:transparent;text-align:center;box-sizing:border-box;margin:0 18px;font-size:22px;display:flex;flex-direction:column;justify-content:center;align-items:center;font-family:Lato,sans-serif;font-weight:900;font-style:normal;color:#d3d3d3;cursor:pointer;opacity:.8}.call-action-btns{text-align:center}#call-input{background-color:transparent;border:none;outline:none;text-align:center;color:#fff}.sendDigit{position:relative;text-align:center;width:80%;margin:auto;background-color:#ffffff1a;padding:2px 0;border-radius:3px}.input-clear-btn{position:absolute;right:6px;color:#fff;cursor:pointer}#minimize-btn-div{position:absolute;right:14px;top:12px;z-index:10}.minimize-btn{color:#fff;cursor:pointer}.wave-container{position:absolute;bottom:0}.waves{width:660px;position:relative;margin-bottom:-7px;height:40px;min-height:40px}.parallax>use{animation:move-forever 25s cubic-bezier(.55,.5,.45,.5) infinite}.parallax>use:nth-child(1){animation-delay:-2s;animation-duration:7s}.parallax>use:nth-child(2){animation-delay:-3s;animation-duration:10s}.parallax>use:nth-child(3){animation-delay:-4s;animation-duration:13s}.parallax>use:nth-child(4){animation-delay:-5s;animation-duration:20s}@keyframes move-forever{0%{transform:translate3d(-90px,0,0)}to{transform:translate3d(85px,0,0)}}.animated-margin{transition:margin-top .5s ease}app-incoming-call{position:absolute;top:0;left:0;width:100%;height:100%;background-color:transparent;z-index:1001}.min-call-container{width:320px;height:124px;border-radius:30px;box-shadow:6px 6px 10px -1px #00000026,-5px -4px 10px -1px #00000026;display:flex;flex-direction:column;box-sizing:border-box;position:relative;overflow:hidden;margin:auto;align-items:center;padding:12px 16px;color:#fff}.min-call-animation{background:#fff;width:48px;height:48px;position:relative;margin:0 12px 0 auto;border-radius:100%;border:solid 2px #fff}.min-avatar-img{width:46px;height:46px;border-radius:100%;position:absolute;left:0;top:0}.min-callerDetails{color:#fff;display:flex;flex-direction:column;align-items:flex-start}.name{width:170px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:20px;margin:0;color:#fff}.min-callerDetails p{margin:0;color:#fff}.min-btn-container{position:relative;display:flex;width:100%;justify-content:flex-start;align-items:center;margin-top:6px}.min-call-sec-btn{width:40px;height:40px;box-sizing:border-box;border:1px solid #cccbcb;background-color:transparent;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-right:12px;box-shadow:6px 6px 10px -1px #bebebe26,-5px -4px 10px -1px #d2d2d226}.min-call-sec-btn span{color:#cccbcb}.min-call-btn{width:40px;height:40px;border-radius:20px;box-sizing:border-box;border:2px solid white;display:flex;align-items:center;justify-content:center}.fullscreen{position:absolute;right:18px;top:14px;color:#e8e8e8;font-size:18px;cursor:pointer}.btn-container{display:flex;flex-wrap:wrap;padding:0 24px}.dial-btn{width:40px;height:40px;background-color:transparent;text-align:center;box-sizing:border-box;margin:4px 25px;font-size:24px;display:flex;flex-direction:column;justify-content:center;align-items:center;font-family:Lato,sans-serif;font-weight:900;font-style:normal;color:#b5b5b5;cursor:pointer}.btn-albhabets{font-family:Lato,sans-serif;font-size:12px;font-weight:400}.min-timer{width:50px;font-size:18px;margin-right:10px;border-radius:4px;height:35px;display:flex;align-items:center}.record-action-btns{display:flex;flex-direction:column;align-items:center}.record-btn-container{position:relative}.record-btn{border:none;border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0 5px;position:relative;overflow:hidden}.record-btn.start-stop .recording-icon{width:50%;height:50%;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.record-btn.start-stop.recording .recording-icon{background-color:#000}.record-btn.start-stop.recording{border:3px solid #000}.record-btn.start-stop.stopped .recording-icon{background-color:red;border:3px solid #ff0000;border-radius:50%;position:absolute}.record-btn.start-stop.stopped{border:3px solid #ff0000}.record-btn.start-stop.stopped .recording-icon{width:40%;height:40%;border-radius:0;background-color:red}.pause-resume-btns{display:flex;flex-direction:column;align-items:center;margin-top:10px}.record-btn.pause-resume{border:none;border-radius:50%;width:50px;height:50px;background:white;display:flex;align-items:center;justify-content:center;margin:5px 0}.record-btn.pause-resume .material-symbols-outlined{font-size:20px;color:#000}.timer-display{font-size:1.2em;margin-top:10px;color:#000}.w-40{width:40%}.w-60{width:60%}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.IncomingCallComponent, selector: "lib-incoming-call", inputs: ["incomingCallData", "newIncomingCallsList"], outputs: ["closeIncomingCallDiv", "incomingCallsNewList", "selectedIncomingCallInfo"] }] });
|
|
418
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CallProgressComponent, decorators: [{
|
|
419
|
+
type: Component,
|
|
420
|
+
args: [{ selector: 'lib-call-progress', template: "<div class=\"call-container\" *ngIf=\"!isMinimised\" [ngClass]=\"{'collops': isCollops, 'incoming-call-container': selectedIncomingCall?.isClickExpand}\">\n <div id=\"minimize-btn-div\">\n <span class=\"material-symbols-outlined minimize-btn\" (click)=\"minimiseDialpad()\">\n minimize\n </span>\n </div>\n <lib-incoming-call *ngIf=\"incomingCallDiv\" [incomingCallData]=\"callData\" [newIncomingCallsList]=\"newIncomingCallsList\" (closeIncomingCallDiv)=\"closeIncomingCall($event)\" \n (incomingCallsNewList)=\"incomingCallsNewList($event)\" (selectedIncomingCallInfo)=\"selectedIncomingCallInfo($event)\"></lib-incoming-call>\n <div style=\"display: flex; flex-direction: column;position: relative; width: 100%;\">\n \n <div class=\"call-animation\" [ngClass]=\"{'call-animation-play': showRingAnimation}\">\n <img class=\"avatar-img\" [src]=\"callData.img\" alt=\"\" width=\"120\" />\n </div>\n <div class=\"callerDetails\">\n <h1 [ngStyle]=\"{'margin-top': showKeypad ? '0': '8px'}\">{{callData.name}}</h1>\n <p>{{callData.displayNum ? callData.displayNum : callData.phone }}</p>\n <h4 style=\"margin-top: 4px\">{{timer}}</h4>\n </div>\n <div class=\"record-action-btns\" [ngStyle]=\"{'margin-top': showKeypad ? '0': '20px'}\">\n <div class=\"record-btn-container\">\n <button class=\"record-btn start-stop\" *ngIf=\"!isRecording\" [ngClass]=\"{'recording': isRecording, 'stopped': !isRecording}\" (click)=\"toggleRecording()\" [title]=\"isRecording ? 'Stop Recording' : 'Start Recording'\" [disabled]=\"disbaleEndCallBtn\">\n <span class=\"recording-icon\"></span>\n </button>\n <div class=\"pause-resume-btns\">\n <button class=\"record-btn pause-resume\" *ngIf=\"isRecording && !isPaused\" (click)=\"pauseRecording()\">\n <span class=\"material-symbols-outlined\"> pause </span>\n </button>\n <button class=\"record-btn pause-resume\" *ngIf=\"isPaused\" (click)=\"resumeRecording()\">\n <span class=\"material-symbols-outlined\"> play_arrow </span>\n </button>\n </div>\n </div>\n <div *ngIf=\"isRecording\" class=\"timer-display\">\n {{ getFormattedTime() }}\n </div>\n </div>\n <div *ngIf=\"showKeypad\" class=\"sendDigit\">\n <input type=\"text\" name=\"call-inputs\" id=\"call-input\" [(ngModel)]=\"callInput\" (keyup)=\"onCallInputEnter($event)\">\n <span class=\"material-symbols-outlined input-clear-btn\" *ngIf=\"callInput\" (click)=\"clearInputs()\">close_small</span>\n </div>\n <div class=\"btn-container justify-content-center\" *ngIf=\"showKeypad\">\n <div class=\"key-btn\" *ngFor=\"let key of keypadVal\" (click)=\"onCallInputs(key.num)\">\n {{key.num}}\n <span class=\"btn-albhabets\">{{key.text ? key.text : ' '}}</span>\n </div>\n </div>\n <div class=\"call-action-btns\" [ngStyle]=\"{'margin-top': showKeypad ? '0': '160px'}\">\n <button class=\"call-sec-btn\" [disabled]=\"disbaleEndCallBtn\" [ngStyle]=\"{'top': showKeypad ? '0': '-70px'}\" (click)=\"toggleMute()\">\n <span class=\"material-symbols-outlined\" *ngIf=\"isMute\"> mic_off </span>\n <span class=\"material-symbols-outlined\" *ngIf=\"!isMute\"> mic </span>\n\n </button>\n <button class=\"call-btn end-call-btn\" [disabled]=\"disbaleEndCallBtn\" (click)=\"endCall()\">\n <span class=\"material-symbols-outlined\"> call_end </span>\n </button>\n <button class=\"call-sec-btn\" [ngStyle]=\"{'top': showKeypad ? '0': '-70px'}\" [disabled]=\"disbaleEndCallBtn\">\n <span class=\"material-symbols-outlined\" (click)=\"toggleKeypad()\"> transition_dissolve </span>\n </button>\n </div>\n <!-- <div class=\"mt-2 px-3 call-info-wrapper \" [ngClass]=\"{'open-collops': isCollops}\">\n <div class=\"text-center\" >\n <i class=\"fa fa-angle-down\" *ngIf=\"isCollops\" (click)=\"isCollops = !isCollops\"></i>\n <i class=\"fa fa-angle-up\" *ngIf=\"!isCollops\" (click)=\"isCollops = !isCollops\"></i>\n </div>\n <ng-container *ngIf=\"isCollops\">\n <div class=\"row mb-2\">\n <div class=\"col-6\">\n <div >First Name:</div>\n <div >test ttttt</div>\n </div>\n <div class=\"col-6\">\n <div>Last Name:</div>\n <div>tetst test </div>\n </div>\n </div>\n <div class=\"mb-2\">\n <div class=\"\">Email:</div>\n <div class=\"\">abcdeft@vgroup.com</div>\n </div>\n <div class=\"row mb-2\">\n <div class=\"col-6\">\n <div class=\"\">Number:</div>\n <div class=\"\">63545985264225</div>\n </div>\n <div class=\"col-6\">\n <div class=\"\">Language:</div>\n <div class=\"\">English</div>\n </div>\n </div>\n <div class=\"row mb-2\">\n <div class=\"col-6\">\n <div class=\"\">Image :</div>\n <div class=\"\">test.jpg </div>\n </div>\n <div class=\"col-6\">\n <div class=\"\">Extension :</div>\n <div class=\"\">4596</div>\n </div>\n </div>\n <div class=\" mb-2\">\n <div class=\"\">Note :</div>\n <div class=\"\">tes test test </div>\n </div>\n <div class=\" mb-2\">\n <div class=\"\">\n <div class=\"\">Subject:</div>\n <div class=\"\">hello world | test</div>\n </div>\n </div>\n <div class=\" mb-4\">\n <div class=\"\">\n <div class=\"\">Message:</div>\n <div class=\"\">test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test </div>\n </div>\n </div>\n </ng-container>\n </div> -->\n </div>\n\n <div class=\"wave-container\">\n <svg class=\"waves\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n viewBox=\"0 24 150 28\" preserveAspectRatio=\"none\" shape-rendering=\"auto\">\n <defs>\n <path id=\"gentle-wave\" d=\"M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z\" />\n </defs>\n <g class=\"parallax\">\n <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"0\" fill=\"rgba(255,255,255,0.7)\" />\n <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"3\" fill=\"rgba(255,255,255,0.5)\" />\n <!-- <use\n xlink:href=\"#gentle-wave\"\n x=\"48\"\n y=\"5\"\n fill=\"rgba(255,255,255,0.3)\"\n /> -->\n <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"7\" fill=\"#fff\" />\n </g>\n </svg>\n </div>\n</div>\n\n<div class=\"min-call-container\" *ngIf=\"isMinimised\">\n <span class=\"material-symbols-outlined fullscreen\" (click)=\"maximiseDialpad()\"> open_in_full </span>\n <div style=\"display: flex; width: 100%\">\n <div>\n <div class=\"min-call-animation\" id=\"call-avatar\">\n <img class=\"min-avatar-img\" [src]=\"callData.img\" alt=\"\" />\n </div>\n </div>\n <div>\n <div class=\"min-callerDetails\">\n <div class=\"name\">\n {{callData.name}}\n </div>\n <p style=\"margin: 0\">{{callData.displayNum ? callData.displayNum : callData.phone }}</p>\n </div>\n </div>\n </div>\n <div class=\"min-btn-container\">\n <div class=\"min-timer\">{{timer}}</div>\n <button class=\"min-call-sec-btn\" (click)=\"toggleMute()\" [disabled]=\"disbaleEndCallBtn\">\n <span class=\"material-symbols-outlined\" *ngIf=\"isMute\"> mic_off </span>\n <span class=\"material-symbols-outlined\" *ngIf=\"!isMute\"> mic </span>\n </button>\n <button class=\"min-call-btn end-call-btn\" [disabled]=\"disbaleEndCallBtn\" (click)=\"endCall()\">\n <span class=\"material-symbols-outlined\"> call_end </span>\n </button>\n </div>\n</div>", styles: [".call-container{width:385px;height:646px;margin:auto;border-radius:30px;box-shadow:6px 6px 10px -1px #00000026,-5px -4px 10px -1px #00000026;display:flex;box-sizing:border-box;position:relative;overflow:hidden;justify-content:center;align-items:center}.collops{height:660px!important}.incoming-call-container{width:752px!important}.call-animation{background:#fff;width:100px;height:100px;position:relative;margin:20px auto 0;border-radius:100%;border:solid 4px #fff;display:flex;align-items:center;justify-content:center}.call-animation:before{position:absolute;content:\"\";top:0;left:0;width:100%;height:100%;backface-visibility:hidden;border-radius:50%}.call-animation-play{animation:play 3s linear infinite}.call-info-wrapper{height:20px;overflow-y:auto;background:white;transition:height 1s}.open-collops{height:180px!important}.avatar-img{width:94px;height:94px;border-radius:100%}@keyframes play{0%{transform:scale(1)}15%{box-shadow:0 0 0 2px #fff6}25%{box-shadow:0 0 0 4px #fff6,0 0 0 8px #fff3}25%{box-shadow:0 0 0 8px #fff6,0 0 0 16px #fff3}50%{box-shadow:0 0 0 10px #fff6,0 0 0 20px #fff3}to{box-shadow:0 0 0 10px #fff6,0 0 0 20px #fff3;transform:scale(1.1);opacity:0}}.callerDetails{margin-top:8px;color:#fff;display:flex;flex-direction:column;align-items:center}.callerDetails h1{width:230px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:12px 0 0;color:#fff;text-transform:capitalize;text-align:center}.callerDetails h4{margin:0;color:#fff}.callerDetails p{margin-top:-3px;margin-bottom:0;color:#fff}.call-sec-btn{position:relative;box-sizing:border-box;border:1px solid #cccbcb;background-color:transparent;border-radius:25px;padding:12px;box-shadow:6px 6px 10px -1px #bebebe26,-5px -4px 10px -1px #d2d2d226}.call-sec-btn span{color:#cccbcb}.call-btn{width:60px;height:60px;background-color:#fff;border-radius:30px;box-sizing:border-box;border:2px solid white;margin:0 16px}.end-call-btn{background-color:#e14e4e}.end-call-btn span{color:#fff!important}.call-btn span{color:#234de8}.btn-container{display:flex;flex-wrap:wrap;padding:0 30px}.key-btn{width:50px;height:50px;background-color:transparent;text-align:center;box-sizing:border-box;margin:0 18px;font-size:22px;display:flex;flex-direction:column;justify-content:center;align-items:center;font-family:Lato,sans-serif;font-weight:900;font-style:normal;color:#d3d3d3;cursor:pointer;opacity:.8}.call-action-btns{text-align:center}#call-input{background-color:transparent;border:none;outline:none;text-align:center;color:#fff}.sendDigit{position:relative;text-align:center;width:80%;margin:auto;background-color:#ffffff1a;padding:2px 0;border-radius:3px}.input-clear-btn{position:absolute;right:6px;color:#fff;cursor:pointer}#minimize-btn-div{position:absolute;right:14px;top:12px;z-index:10}.minimize-btn{color:#fff;cursor:pointer}.wave-container{position:absolute;bottom:0}.waves{width:660px;position:relative;margin-bottom:-7px;height:40px;min-height:40px}.parallax>use{animation:move-forever 25s cubic-bezier(.55,.5,.45,.5) infinite}.parallax>use:nth-child(1){animation-delay:-2s;animation-duration:7s}.parallax>use:nth-child(2){animation-delay:-3s;animation-duration:10s}.parallax>use:nth-child(3){animation-delay:-4s;animation-duration:13s}.parallax>use:nth-child(4){animation-delay:-5s;animation-duration:20s}@keyframes move-forever{0%{transform:translate3d(-90px,0,0)}to{transform:translate3d(85px,0,0)}}.animated-margin{transition:margin-top .5s ease}app-incoming-call{position:absolute;top:0;left:0;width:100%;height:100%;background-color:transparent;z-index:1001}.min-call-container{width:320px;height:124px;border-radius:30px;box-shadow:6px 6px 10px -1px #00000026,-5px -4px 10px -1px #00000026;display:flex;flex-direction:column;box-sizing:border-box;position:relative;overflow:hidden;margin:auto;align-items:center;padding:12px 16px;color:#fff}.min-call-animation{background:#fff;width:48px;height:48px;position:relative;margin:0 12px 0 auto;border-radius:100%;border:solid 2px #fff}.min-avatar-img{width:46px;height:46px;border-radius:100%;position:absolute;left:0;top:0}.min-callerDetails{color:#fff;display:flex;flex-direction:column;align-items:flex-start}.name{width:170px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:20px;margin:0;color:#fff}.min-callerDetails p{margin:0;color:#fff}.min-btn-container{position:relative;display:flex;width:100%;justify-content:flex-start;align-items:center;margin-top:6px}.min-call-sec-btn{width:40px;height:40px;box-sizing:border-box;border:1px solid #cccbcb;background-color:transparent;border-radius:20px;display:flex;align-items:center;justify-content:center;margin-right:12px;box-shadow:6px 6px 10px -1px #bebebe26,-5px -4px 10px -1px #d2d2d226}.min-call-sec-btn span{color:#cccbcb}.min-call-btn{width:40px;height:40px;border-radius:20px;box-sizing:border-box;border:2px solid white;display:flex;align-items:center;justify-content:center}.fullscreen{position:absolute;right:18px;top:14px;color:#e8e8e8;font-size:18px;cursor:pointer}.btn-container{display:flex;flex-wrap:wrap;padding:0 24px}.dial-btn{width:40px;height:40px;background-color:transparent;text-align:center;box-sizing:border-box;margin:4px 25px;font-size:24px;display:flex;flex-direction:column;justify-content:center;align-items:center;font-family:Lato,sans-serif;font-weight:900;font-style:normal;color:#b5b5b5;cursor:pointer}.btn-albhabets{font-family:Lato,sans-serif;font-size:12px;font-weight:400}.min-timer{width:50px;font-size:18px;margin-right:10px;border-radius:4px;height:35px;display:flex;align-items:center}.record-action-btns{display:flex;flex-direction:column;align-items:center}.record-btn-container{position:relative}.record-btn{border:none;border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0 5px;position:relative;overflow:hidden}.record-btn.start-stop .recording-icon{width:50%;height:50%;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.record-btn.start-stop.recording .recording-icon{background-color:#000}.record-btn.start-stop.recording{border:3px solid #000}.record-btn.start-stop.stopped .recording-icon{background-color:red;border:3px solid #ff0000;border-radius:50%;position:absolute}.record-btn.start-stop.stopped{border:3px solid #ff0000}.record-btn.start-stop.stopped .recording-icon{width:40%;height:40%;border-radius:0;background-color:red}.pause-resume-btns{display:flex;flex-direction:column;align-items:center;margin-top:10px}.record-btn.pause-resume{border:none;border-radius:50%;width:50px;height:50px;background:white;display:flex;align-items:center;justify-content:center;margin:5px 0}.record-btn.pause-resume .material-symbols-outlined{font-size:20px;color:#000}.timer-display{font-size:1.2em;margin-top:10px;color:#000}.w-40{width:40%}.w-60{width:60%}\n"] }]
|
|
421
|
+
}], ctorParameters: function () { return [{ type: i1.ExtensionService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { callData: [{
|
|
422
|
+
type: Input
|
|
423
|
+
}], newIncomingCallData: [{
|
|
424
|
+
type: Input
|
|
425
|
+
}], newIncomingCallsList: [{
|
|
426
|
+
type: Input
|
|
427
|
+
}], endCallEvent: [{
|
|
428
|
+
type: Output
|
|
429
|
+
}], incomingCallsNewInfo: [{
|
|
430
|
+
type: Output
|
|
431
|
+
}], minimiseEvent: [{
|
|
432
|
+
type: Output
|
|
433
|
+
}], showCallProgressEvent: [{
|
|
434
|
+
type: Output
|
|
435
|
+
}], incomingCallInitiated: [{
|
|
436
|
+
type: Output
|
|
437
|
+
}] } });
|
|
438
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"call-progress.component.js","sourceRoot":"","sources":["../../../../../../projects/dialbox/src/lib/components/call-progress/call-progress.component.ts","../../../../../../projects/dialbox/src/lib/components/call-progress/call-progress.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { Call, Device } from '@twilio/voice-sdk';\nimport { ExtensionService } from '../../service/extension.service';\nimport { environment } from '../../environments/environments';\nimport swal from 'sweetalert2';\nimport { keypad } from '../../../keypad';\nimport { interval, Subscription } from 'rxjs';\n\ninterface CallDetails {\n  callSid: string;\n  callStatus: string;\n}\ninterface CallStatusResponse {\n  callDetails: CallDetails;\n  response: string;\n  errorType: number;\n  message: string;\n  status: number;\n}\n\n@Component({\n  selector: 'lib-call-progress',\n  templateUrl: './call-progress.component.html',\n  styleUrls: ['./call-progress.component.css']\n})\nexport class CallProgressComponent implements OnInit, OnChanges, AfterViewInit {\n  @Input() callData: any;\n  @Input() newIncomingCallData?:Call;\n  @Input() newIncomingCallsList?:Call;  \n  @Output() endCallEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() incomingCallsNewInfo: EventEmitter<any> = new EventEmitter<any>();\n  \n  @Output() minimiseEvent: EventEmitter<boolean> = new EventEmitter<boolean>();\n  device?: Device;\n  call?: Call;\n  showRingAnimation: boolean = false;\n  timer: string = '00:00';\n  intervalId: any;\n  showKeypad: boolean = false;\n  keypadVal = keypad;\n  callInput: string = '';\n  isMute: boolean = false;\n  disbaleEndCallBtn: boolean = true;\n  showClearBtn:boolean = false;\n  isCollops= false;\n\n  // Incoming call variables\n  incomingCallDiv: boolean = false;\n  @Output() showCallProgressEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() incomingCallInitiated: EventEmitter<void> = new EventEmitter<void>();\n\n  // Recording variables\n  callSid: any;\n  isRecording: boolean = false;\n  isPaused: boolean = false;\n  timerSubscription?: Subscription;\n  timeElapsed = 0; // in seconds\n  recordCall: boolean = false;\n  incomingCallSid: any;\n  callStatus: string = 'ringing';\n  incomingRecordCall: any;\n  selectedIncomingCall: any;\n  constructor(private extensionService: ExtensionService, private cdr: ChangeDetectorRef) { }\n\n  ngOnInit() {\n    console.log('Call Progress Component');\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    console.log('Call Progress Component ngOnChanges');\n    if (changes['callData']) {\n      console.log('Call Progress Component ngOnChanges callData', changes['callData']);\n      if (changes['callData'].currentValue.isIncomingCall) {\n        this.incomingCallDiv = true;\n      } else {\n        //for outgoing call\n        this.startCall(changes['callData'].currentValue);\n      }\n    }\n    if (changes['newIncomingCallData']) {\n      try {\n        if (changes['newIncomingCallData'].currentValue) {\n          if (this.call && (this.call.status() == 'open')) {\n            this.call.disconnect();\n            this.call = changes['newIncomingCallData'].currentValue;\n            this.call?.accept();\n            this.callData.phone = this.call?.parameters['From'];\n            this.callData.name = this.call?.customParameters.get('name');\n            this.callData.img = this.call?.customParameters.get('image') || 'assets/images/user.jpg';\n            this.incomingCallInitiated.emit();\n            this.startTimer();\n          }\n        }\n      } catch (e) {\n        console.log(e);\n      }\n    }\n  }\n\n  ngAfterViewInit() { }\n\n  async startCall(callData: any) {\n    try {\n      this.showRingAnimation = true;\n      const payload = {\n        channelId: environment.channelId,\n        userId: localStorage.getItem('userId'),\n        to: callData.phone,\n        scope: 'local',\n        fromNumber: callData.from\n      };\n\n      const response = await this.initiateCall(payload);\n      if (response.status == 200) {\n        const { id: callAuthId, recordCall } = await this.getCallAuthId(response);\n        this.getUserInformation(callAuthId)\n        this.recordCall = recordCall; // Store the recordCall value\n        const tokenData: any = await this.getOutgoingCallToken(callAuthId);\n        await this.connectToDevice(tokenData.token, callData);\n\n        // Poll the status for 30-45 seconds\n        this.pollCallStatus(callAuthId);\n      } else if (response.status == 201) {\n        swal(\"Error\", response.message.join(\"<br/>\"), \"error\");\n        this.endCall();\n      }\n      \n    } catch (error) {\n      this.showRingAnimation = false;\n      this.handleError(error);\n      this.endCall();\n    }\n  }\n\n  private async initiateCall(payload: any) {\n    return await this.extensionService.initiateCall(payload).toPromise();\n  }\n\n  private async getCallAuthId(response: any) {\n    return {\n      id: response.callauth.id,\n      recordCall: response.callauth.recordCall\n    };\n  }\n\n  private async getOutgoingCallToken(callAuthId: string) {\n    return await this.extensionService.getOutgoingCallToken({ authId: callAuthId }).toPromise();\n  }\n\n  private async connectToDevice(token: any, callData: any) {\n    const options: any = {\n      codecPreferences: ['opus', 'pcmu'],\n      closeProtection: true,\n    };\n\n    this.device = new Device(token.value, options);\n    this.call = await this.device.connect({\n      params: {\n        From: callData.from,\n        To: callData.phone,\n        Env: environment.abb,\n        Token: token.id,\n        Ext: callData.extNum\n      },\n      rtcConstraints: { audio: { deviceId: 'default' } },\n    });\n    this.setupEventListeners();\n  }\n\n  private setupEventListeners() {\n\n    this.startTimer();\n    this.device?.on('error', (err) => {\n      console.log(err);\n      this.showRingAnimation = false;\n      this.stopTimer();\n    });\n\n    this.call?.on('error', (error) => {\n      this.showRingAnimation = false;\n      this.stopTimer();\n    });\n\n    this.call?.on('disconnect', () => {\n      this.endCall();\n    });\n\n    this.call?.on('ringing', () => {\n    });\n\n    this.call?.on('reject', () => {\n      this.endCall();\n    });\n\n    this.call?.on('accept', () => {\n      this.showRingAnimation = false;\n      this.disbaleEndCallBtn = false;\n      // Start recording if recordCall is true and call is accepted for 30 seconds\n      // if (this.recordCall) {\n      //   setTimeout(() => {\n      //     if (this.isRecording) return; // If already recording, skip\n      //     this.startRecording();\n      //   }, 30000);\n      // } else {\n      //   this.stopRecording();\n      // }\n    });\n    this.call?.on('messageReceived', (message) => {\n    });\n  }\n\n  private startTimer() {\n    let seconds = 0;\n    this.intervalId = setInterval(() => {\n      seconds++;\n      this.timer = this.formatTime(seconds);\n    }, 1000);\n  }\n\n  private stopTimer() {\n    clearInterval(this.intervalId);\n    this.timer = '00:00';\n  }\n\n  private formatTime(totalSeconds: number): string {\n    const minutes = Math.floor(totalSeconds / 60);\n    const seconds = totalSeconds % 60;\n    return `${this.pad(minutes)}:${this.pad(seconds)}`;\n  }\n\n  private pad(value: number): string {\n    return value < 10 ? `0${value}` : `${value}`;\n  }\n  private handleError(error: any) {\n    swal(\"Error\", error, \"error\");\n  }\n\n  endCall() {\n    this.endCallEvent.emit();\n    if (this.call) {\n      this.call.disconnect();\n    }\n\n    this.showRingAnimation = false;\n    this.stopTimer();\n    this.maximiseDialpad();\n  }\n\n  toggleMute() {\n    this.isMute = !this.isMute;\n    this.call?.mute(this.isMute);\n  }\n  toggleKeypad() {\n    this.showKeypad = !this.showKeypad;\n    this.callInput = '';\n  }\n  onCallInputs(num: any) {\n    try {\n      if (Number.isInteger(num) || num == '+' || num == '*' || num == '#') {\n        if (num == '#') {\n          new Audio(`/assets/dial-tones/dtmf/dtmf-hash-.mp3`).play();\n        } else if (num == '*') {\n          new Audio(`/assets/dial-tones/dtmf/dtmf-star-.mp3`).play();\n        } else {\n          new Audio(`/assets/dial-tones/dtmf/dtmf-${num}-.mp3`).play();\n        }\n\n        this.callInput = this.callInput + String(num);\n        this.showClearBtn = true;\n      }\n      let str = String(num);\n      this.call?.sendDigits(str);\n    } catch (e) {\n      console.log(e);\n    }\n  }\n  onCallInputEnter(ev: any) {\n    try {\n      this.call?.sendDigits(String(ev.key));\n    } catch (e) {\n      console.log(e);\n    }\n  }\n  closeIncomingCall(data: any) {\n    // this.incomingCallDiv = false;\n    if (data.show) {\n      //this.showCallProgressEvent.emit()\n      // handle incoming call accepted\n      this.startTimer();\n      this.disbaleEndCallBtn = false;\n      this.call = data.call;\n    \n      const incomingDetail = this.extensionService.getCallSid();\n      this.incomingRecordCall = incomingDetail.recordCall;\n\n      // Start recording if the call is answered and recording is enabled\n      if (this.incomingRecordCall) {\n        this.startRecording();\n      } else {\n        this.isRecording = false;\n      }\n      this.cdr.detectChanges();\n    } else {\n      // incoming call rejected\n      this.endCallEvent.emit();\n    }\n  }\n  clearInputs(){\n    this.callInput = this.callInput.slice(0, -1);\n  }\n  isMinimised:boolean = false;\n  minimiseDialpad(){\n    this.minimiseEvent.emit(true);\n    this.isMinimised = true;\n  }\n  maximiseDialpad(){\n    this.minimiseEvent.emit(false);\n    this.isMinimised = false;\n  }\n  toggleRecording() {\n    if (this.isRecording) {\n      this.stopRecording();\n    } else {\n      this.startRecording();\n    }\n  }\n  startRecording() {\n    let sid;\n    const details = this.extensionService.getCallSid();\n    this.incomingCallSid = details.callSid;\n    this.incomingRecordCall = details.recordCall;\n    sid = this.incomingCallSid ? this.incomingCallSid : this.callSid;\n\n    // if (!this.incomingRecordCall && !this.recordCall) {\n    //   return;\n    // }\n    this.extensionService.getCallRecording(sid).subscribe(response => {\n      this.isRecording = true;\n      this.isPaused = false;\n      this.timeElapsed = 0;\n      this.startTimer1();\n    }, error => {\n      console.error('Error starting recording', error);\n    });\n  }\n  stopRecording() {\n    // if (!this.incomingRecordCall && !this.recordCall) {\n    //   return;\n    // }\n    this.isRecording = false;\n    this.isPaused = false;\n    if (this.timerSubscription) {\n      this.timerSubscription.unsubscribe();\n    }\n  }\n  pauseRecording() {\n    const details = this.extensionService.getCallSid();\n    this.incomingCallSid = details.callSid;\n    this.incomingRecordCall = details.recordCall;\n    const sid = this.incomingCallSid ? this.incomingCallSid : this.callSid;\n\n    // if (!this.incomingRecordCall && !this.recordCall) {\n    //   return;\n    // }\n\n    this.extensionService.pauseOrResumeRecording(sid, 'pause').subscribe(\n      response => {\n        this.stopRecordingTimer();\n        this.isPaused = true;\n      },\n      error => {\n        console.error('Error pausing recording:', error);\n        // Consider updating the UI to show the error state\n      }\n    );\n  }\n  resumeRecording() {\n    let sid;\n    const details = this.extensionService.getCallSid();\n    this.incomingCallSid = details.callSid;\n    this.incomingRecordCall = details.recordCall;\n    sid = this.incomingCallSid ? this.incomingCallSid : this.callSid;\n\n    // if (!this.incomingRecordCall && !this.recordCall) {\n    //   return; // Skip if recording is not enabled\n    // }\n    this.extensionService.pauseOrResumeRecording(sid, 'resume').subscribe(response => {\n      this.isPaused = false;\n      this.startTimer1();\n    }, error => {\n      console.error('Error resuming recording', error);\n    });\n  }\n  startTimer1() {\n    this.timerSubscription = interval(1000).subscribe(() => {\n      this.timeElapsed++;\n    });\n  }\n  stopRecordingTimer() {\n    if (this.timerSubscription) {\n      this.timerSubscription.unsubscribe(); // Pause the timer\n      this.timerSubscription = undefined;        // Optionally reset the subscription\n    }\n  }\n  getFormattedTime() {\n    const minutes = Math.floor(this.timeElapsed / 60);\n    const seconds = this.timeElapsed % 60;\n    return `${minutes}:${seconds < 10 ? '0' : ''}${seconds}`;\n  }\n  pollCallStatus(callAuthId: string) {\n    const maxTime = 30000; // Poll for up to 30 seconds\n    const pollInterval = 3000; // Poll every 3 seconds\n    let elapsedTime = 0;\n    const intervalId = setInterval(async () => {\n      elapsedTime += pollInterval;\n      try {\n        const statusResponse = await this.extensionService.getCallStatus(callAuthId).toPromise() as CallStatusResponse;\n        if (statusResponse && statusResponse.callDetails) {\n          this.callStatus = statusResponse.callDetails.callStatus;\n          if (this.callStatus === 'in-progress') {\n            this.callSid = statusResponse.callDetails.callSid;\n            if (this.recordCall && !this.isRecording) { \n             \n              this.startRecording();\n            }\n            clearInterval(intervalId);\n          } else if (this.callStatus === 'completed') {\n            clearInterval(intervalId);\n            this.endCall();\n            this.stopRecording();\n          } else if (this.callStatus === 'ringing') {\n            // Continue polling; do not clear the interval yet\n          }\n        }\n      } catch (error) {\n        clearInterval(intervalId);\n      }\n      if (elapsedTime >= maxTime) {\n        // console.log('Max polling time reached. Stopping poll.');\n        clearInterval(intervalId);\n      }\n    }, pollInterval);\n  }\n\n  getUserInformation(id:any) {\n    this.extensionService.getUserInformation(id).subscribe(\n    response => {\n      console.log(response)\n    }, error => {\n      console.error('Error starting recording', error);\n    });\n  }\n  incomingCallsNewList(data:any){\n    this.newIncomingCallsList = data;\n    this.incomingCallsNewInfo.emit(this.newIncomingCallsList);\n  }\n  selectedIncomingCallInfo(data:any){\n    this.selectedIncomingCall = data;\n  }\n  ngOnDestroy() {\n    this.callData.dial = false;\n    if (this.timerSubscription) {\n      this.timerSubscription.unsubscribe();\n    }\n  }\n}","<div class=\"call-container\" *ngIf=\"!isMinimised\" [ngClass]=\"{'collops': isCollops, 'incoming-call-container': selectedIncomingCall?.isClickExpand}\">\n    <div id=\"minimize-btn-div\">\n        <span class=\"material-symbols-outlined minimize-btn\" (click)=\"minimiseDialpad()\">\n            minimize\n        </span>\n    </div>\n        <lib-incoming-call *ngIf=\"incomingCallDiv\" [incomingCallData]=\"callData\" [newIncomingCallsList]=\"newIncomingCallsList\" (closeIncomingCallDiv)=\"closeIncomingCall($event)\" \n        (incomingCallsNewList)=\"incomingCallsNewList($event)\" (selectedIncomingCallInfo)=\"selectedIncomingCallInfo($event)\"></lib-incoming-call>\n        <div style=\"display: flex; flex-direction: column;position: relative; width: 100%;\">\n            \n        <div class=\"call-animation\" [ngClass]=\"{'call-animation-play': showRingAnimation}\">\n            <img class=\"avatar-img\" [src]=\"callData.img\" alt=\"\" width=\"120\" />\n        </div>\n        <div class=\"callerDetails\">\n            <h1 [ngStyle]=\"{'margin-top': showKeypad ? '0': '8px'}\">{{callData.name}}</h1>\n            <p>{{callData.displayNum ? callData.displayNum : callData.phone }}</p>\n            <h4 style=\"margin-top: 4px\">{{timer}}</h4>\n        </div>\n        <div class=\"record-action-btns\" [ngStyle]=\"{'margin-top': showKeypad ? '0': '20px'}\">\n            <div class=\"record-btn-container\">\n                <button class=\"record-btn start-stop\" *ngIf=\"!isRecording\" [ngClass]=\"{'recording': isRecording, 'stopped': !isRecording}\" (click)=\"toggleRecording()\" [title]=\"isRecording ? 'Stop Recording' : 'Start Recording'\" [disabled]=\"disbaleEndCallBtn\">\n                    <span class=\"recording-icon\"></span>\n                </button>\n                <div class=\"pause-resume-btns\">\n                    <button class=\"record-btn pause-resume\" *ngIf=\"isRecording && !isPaused\" (click)=\"pauseRecording()\">\n                        <span class=\"material-symbols-outlined\"> pause </span>\n                    </button>\n                    <button class=\"record-btn pause-resume\" *ngIf=\"isPaused\" (click)=\"resumeRecording()\">\n                        <span class=\"material-symbols-outlined\"> play_arrow </span>\n                    </button>\n                </div>\n            </div>\n            <div *ngIf=\"isRecording\" class=\"timer-display\">\n                {{ getFormattedTime() }}\n              </div>\n        </div>\n        <div *ngIf=\"showKeypad\" class=\"sendDigit\">\n            <input type=\"text\" name=\"call-inputs\" id=\"call-input\" [(ngModel)]=\"callInput\" (keyup)=\"onCallInputEnter($event)\">\n            <span class=\"material-symbols-outlined input-clear-btn\" *ngIf=\"callInput\" (click)=\"clearInputs()\">close_small</span>\n        </div>\n        <div class=\"btn-container justify-content-center\" *ngIf=\"showKeypad\">\n            <div class=\"key-btn\" *ngFor=\"let key of keypadVal\" (click)=\"onCallInputs(key.num)\">\n                {{key.num}}\n                <span class=\"btn-albhabets\">{{key.text ? key.text : '&nbsp;'}}</span>\n            </div>\n        </div>\n        <div class=\"call-action-btns\" [ngStyle]=\"{'margin-top': showKeypad ? '0': '160px'}\">\n            <button class=\"call-sec-btn\" [disabled]=\"disbaleEndCallBtn\" [ngStyle]=\"{'top': showKeypad ? '0': '-70px'}\" (click)=\"toggleMute()\">\n                <span class=\"material-symbols-outlined\" *ngIf=\"isMute\"> mic_off </span>\n                <span class=\"material-symbols-outlined\" *ngIf=\"!isMute\"> mic </span>\n\n            </button>\n            <button class=\"call-btn end-call-btn\" [disabled]=\"disbaleEndCallBtn\" (click)=\"endCall()\">\n                <span class=\"material-symbols-outlined\"> call_end </span>\n            </button>\n            <button class=\"call-sec-btn\" [ngStyle]=\"{'top': showKeypad ? '0': '-70px'}\" [disabled]=\"disbaleEndCallBtn\">\n                <span class=\"material-symbols-outlined\" (click)=\"toggleKeypad()\"> transition_dissolve </span>\n            </button>\n        </div>\n        <!-- <div class=\"mt-2 px-3 call-info-wrapper \"  [ngClass]=\"{'open-collops': isCollops}\">\n            <div class=\"text-center\" >\n                <i class=\"fa fa-angle-down\" *ngIf=\"isCollops\" (click)=\"isCollops = !isCollops\"></i>\n                <i class=\"fa fa-angle-up\" *ngIf=\"!isCollops\" (click)=\"isCollops = !isCollops\"></i>\n            </div>\n            <ng-container *ngIf=\"isCollops\">\n                <div class=\"row mb-2\">\n                    <div class=\"col-6\">\n                        <div >First Name:</div>\n                        <div >test ttttt</div>\n                    </div>\n                    <div class=\"col-6\">\n                        <div>Last Name:</div>\n                        <div>tetst test </div>\n                    </div>\n                </div>\n                <div class=\"mb-2\">\n                    <div class=\"\">Email:</div>\n                    <div class=\"\">abcdeft@vgroup.com</div>\n                </div>\n                <div class=\"row mb-2\">\n                    <div class=\"col-6\">\n                        <div class=\"\">Number:</div>\n                        <div class=\"\">63545985264225</div>\n                    </div>\n                    <div class=\"col-6\">\n                        <div class=\"\">Language:</div>\n                        <div class=\"\">English</div>\n                    </div>\n                </div>\n                <div class=\"row mb-2\">\n                    <div class=\"col-6\">\n                        <div class=\"\">Image :</div>\n                        <div class=\"\">test.jpg </div>\n                    </div>\n                    <div class=\"col-6\">\n                        <div class=\"\">Extension :</div>\n                        <div class=\"\">4596</div>\n                    </div>\n                </div>\n                <div class=\" mb-2\">\n                    <div class=\"\">Note :</div>\n                    <div class=\"\">tes test test </div>\n                </div>\n                <div class=\" mb-2\">\n                    <div class=\"\">\n                        <div class=\"\">Subject:</div>\n                        <div class=\"\">hello world | test</div>\n                    </div>\n                </div>\n                <div class=\" mb-4\">\n                    <div class=\"\">\n                        <div class=\"\">Message:</div>\n                        <div class=\"\">test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test test </div>\n                    </div>\n                </div>\n            </ng-container>\n        </div> -->\n    </div>\n\n    <div class=\"wave-container\">\n        <svg class=\"waves\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            viewBox=\"0 24 150 28\" preserveAspectRatio=\"none\" shape-rendering=\"auto\">\n            <defs>\n                <path id=\"gentle-wave\" d=\"M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z\" />\n            </defs>\n            <g class=\"parallax\">\n                <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"0\" fill=\"rgba(255,255,255,0.7)\" />\n                <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"3\" fill=\"rgba(255,255,255,0.5)\" />\n                <!-- <use\n                xlink:href=\"#gentle-wave\"\n                x=\"48\"\n                y=\"5\"\n                fill=\"rgba(255,255,255,0.3)\"\n              /> -->\n                <use xlink:href=\"#gentle-wave\" x=\"48\" y=\"7\" fill=\"#fff\" />\n            </g>\n        </svg>\n    </div>\n</div>\n\n<div class=\"min-call-container\" *ngIf=\"isMinimised\">\n    <span class=\"material-symbols-outlined fullscreen\" (click)=\"maximiseDialpad()\"> open_in_full </span>\n    <div style=\"display: flex; width: 100%\">\n        <div>\n            <div class=\"min-call-animation\" id=\"call-avatar\">\n                <img class=\"min-avatar-img\" [src]=\"callData.img\" alt=\"\" />\n            </div>\n        </div>\n        <div>\n            <div class=\"min-callerDetails\">\n                <div class=\"name\">\n                    {{callData.name}}\n                </div>\n                <p style=\"margin: 0\">{{callData.displayNum ? callData.displayNum : callData.phone }}</p>\n            </div>\n        </div>\n    </div>\n    <div class=\"min-btn-container\">\n        <div class=\"min-timer\">{{timer}}</div>\n        <button class=\"min-call-sec-btn\" (click)=\"toggleMute()\" [disabled]=\"disbaleEndCallBtn\">\n            <span class=\"material-symbols-outlined\" *ngIf=\"isMute\"> mic_off </span>\n            <span class=\"material-symbols-outlined\" *ngIf=\"!isMute\"> mic </span>\n        </button>\n        <button class=\"min-call-btn end-call-btn\" [disabled]=\"disbaleEndCallBtn\" (click)=\"endCall()\">\n            <span class=\"material-symbols-outlined\"> call_end </span>\n        </button>\n    </div>\n</div>"]}
|