@webex/contact-center 3.9.0 → 3.10.0-next.10

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.
Files changed (115) hide show
  1. package/dist/cc.js +207 -47
  2. package/dist/cc.js.map +1 -1
  3. package/dist/constants.js +1 -0
  4. package/dist/constants.js.map +1 -1
  5. package/dist/index.js +9 -0
  6. package/dist/index.js.map +1 -1
  7. package/dist/logger-proxy.js +24 -1
  8. package/dist/logger-proxy.js.map +1 -1
  9. package/dist/metrics/MetricsManager.js +1 -1
  10. package/dist/metrics/MetricsManager.js.map +1 -1
  11. package/dist/metrics/behavioral-events.js +89 -0
  12. package/dist/metrics/behavioral-events.js.map +1 -1
  13. package/dist/metrics/constants.js +32 -2
  14. package/dist/metrics/constants.js.map +1 -1
  15. package/dist/services/AddressBook.js +271 -0
  16. package/dist/services/AddressBook.js.map +1 -0
  17. package/dist/services/EntryPoint.js +227 -0
  18. package/dist/services/EntryPoint.js.map +1 -0
  19. package/dist/services/Queue.js +261 -0
  20. package/dist/services/Queue.js.map +1 -0
  21. package/dist/services/config/constants.js +36 -2
  22. package/dist/services/config/constants.js.map +1 -1
  23. package/dist/services/config/index.js +29 -21
  24. package/dist/services/config/index.js.map +1 -1
  25. package/dist/services/config/types.js +33 -1
  26. package/dist/services/config/types.js.map +1 -1
  27. package/dist/services/core/GlobalTypes.js.map +1 -1
  28. package/dist/services/core/Utils.js +181 -2
  29. package/dist/services/core/Utils.js.map +1 -1
  30. package/dist/services/core/aqm-reqs.js +0 -4
  31. package/dist/services/core/aqm-reqs.js.map +1 -1
  32. package/dist/services/core/constants.js +17 -1
  33. package/dist/services/core/constants.js.map +1 -1
  34. package/dist/services/core/websocket/WebSocketManager.js +0 -4
  35. package/dist/services/core/websocket/WebSocketManager.js.map +1 -1
  36. package/dist/services/task/TaskManager.js +151 -7
  37. package/dist/services/task/TaskManager.js.map +1 -1
  38. package/dist/services/task/TaskUtils.js +104 -0
  39. package/dist/services/task/TaskUtils.js.map +1 -0
  40. package/dist/services/task/constants.js +26 -1
  41. package/dist/services/task/constants.js.map +1 -1
  42. package/dist/services/task/contact.js +86 -0
  43. package/dist/services/task/contact.js.map +1 -1
  44. package/dist/services/task/index.js +428 -91
  45. package/dist/services/task/index.js.map +1 -1
  46. package/dist/services/task/types.js +12 -0
  47. package/dist/services/task/types.js.map +1 -1
  48. package/dist/types/cc.d.ts +121 -35
  49. package/dist/types/constants.d.ts +1 -0
  50. package/dist/types/index.d.ts +4 -3
  51. package/dist/types/metrics/constants.d.ts +25 -1
  52. package/dist/types/services/AddressBook.d.ts +74 -0
  53. package/dist/types/services/EntryPoint.d.ts +67 -0
  54. package/dist/types/services/Queue.d.ts +76 -0
  55. package/dist/types/services/config/constants.d.ts +35 -1
  56. package/dist/types/services/config/index.d.ts +6 -9
  57. package/dist/types/services/config/types.d.ts +79 -58
  58. package/dist/types/services/core/GlobalTypes.d.ts +25 -0
  59. package/dist/types/services/core/Utils.d.ts +55 -1
  60. package/dist/types/services/core/constants.d.ts +14 -0
  61. package/dist/types/services/task/TaskUtils.d.ts +42 -0
  62. package/dist/types/services/task/constants.d.ts +23 -0
  63. package/dist/types/services/task/contact.d.ts +10 -0
  64. package/dist/types/services/task/index.d.ts +85 -4
  65. package/dist/types/services/task/types.d.ts +245 -21
  66. package/dist/types/types.d.ts +162 -0
  67. package/dist/types/utils/PageCache.d.ts +173 -0
  68. package/dist/types.js +17 -0
  69. package/dist/types.js.map +1 -1
  70. package/dist/utils/PageCache.js +192 -0
  71. package/dist/utils/PageCache.js.map +1 -0
  72. package/dist/webex.js +1 -1
  73. package/package.json +10 -9
  74. package/src/cc.ts +232 -52
  75. package/src/constants.ts +1 -0
  76. package/src/index.ts +17 -2
  77. package/src/logger-proxy.ts +24 -1
  78. package/src/metrics/MetricsManager.ts +1 -1
  79. package/src/metrics/behavioral-events.ts +94 -0
  80. package/src/metrics/constants.ts +37 -1
  81. package/src/services/AddressBook.ts +291 -0
  82. package/src/services/EntryPoint.ts +241 -0
  83. package/src/services/Queue.ts +277 -0
  84. package/src/services/config/constants.ts +42 -2
  85. package/src/services/config/index.ts +30 -30
  86. package/src/services/config/types.ts +59 -58
  87. package/src/services/core/GlobalTypes.ts +27 -0
  88. package/src/services/core/Utils.ts +215 -1
  89. package/src/services/core/aqm-reqs.ts +0 -5
  90. package/src/services/core/constants.ts +16 -0
  91. package/src/services/core/websocket/WebSocketManager.ts +0 -4
  92. package/src/services/task/TaskManager.ts +182 -9
  93. package/src/services/task/TaskUtils.ts +113 -0
  94. package/src/services/task/constants.ts +25 -0
  95. package/src/services/task/contact.ts +80 -0
  96. package/src/services/task/index.ts +497 -71
  97. package/src/services/task/types.ts +264 -20
  98. package/src/types.ts +180 -0
  99. package/src/utils/PageCache.ts +252 -0
  100. package/test/unit/spec/cc.ts +282 -85
  101. package/test/unit/spec/metrics/MetricsManager.ts +0 -1
  102. package/test/unit/spec/metrics/behavioral-events.ts +42 -0
  103. package/test/unit/spec/services/AddressBook.ts +332 -0
  104. package/test/unit/spec/services/EntryPoint.ts +259 -0
  105. package/test/unit/spec/services/Queue.ts +323 -0
  106. package/test/unit/spec/services/config/index.ts +279 -65
  107. package/test/unit/spec/services/core/Utils.ts +282 -1
  108. package/test/unit/spec/services/core/aqm-reqs.ts +1 -3
  109. package/test/unit/spec/services/core/websocket/WebSocketManager.ts +0 -4
  110. package/test/unit/spec/services/task/TaskManager.ts +760 -2
  111. package/test/unit/spec/services/task/TaskUtils.ts +131 -0
  112. package/test/unit/spec/services/task/contact.ts +31 -1
  113. package/test/unit/spec/services/task/index.ts +873 -163
  114. package/umd/contact-center.min.js +2 -2
  115. package/umd/contact-center.min.js.map +1 -1
@@ -15,6 +15,7 @@ var _loggerProxy = _interopRequireDefault(require("../../logger-proxy"));
15
15
  var _ = _interopRequireDefault(require("."));
16
16
  var _MetricsManager = _interopRequireDefault(require("../../metrics/MetricsManager"));
17
17
  var _constants3 = require("../../metrics/constants");
18
+ var _TaskUtils = require("./TaskUtils");
18
19
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
20
  /** @internal */
20
21
  class TaskManager extends _events.default {
@@ -42,6 +43,18 @@ class TaskManager extends _events.default {
42
43
  setWrapupData(wrapupData) {
43
44
  this.wrapupData = wrapupData;
44
45
  }
46
+ setAgentId(agentId) {
47
+ this.agentId = agentId;
48
+ }
49
+
50
+ /**
51
+ * Gets the current agent ID
52
+ * @returns {string} The agent ID set for this task manager instance
53
+ * @public
54
+ */
55
+ getAgentId() {
56
+ return this.agentId;
57
+ }
45
58
  handleIncomingWebCall = call => {
46
59
  const currentTask = Object.values(this.taskCollection).find(task => task.data.interaction.mediaType === 'telephony');
47
60
  if (currentTask) {
@@ -94,8 +107,9 @@ class TaskManager extends _events.default {
94
107
  });
95
108
  task = new _.default(this.contact, this.webCallingService, {
96
109
  ...payload.data,
97
- wrapUpRequired: payload.data.interaction?.participants?.[payload.data.agentId]?.isWrapUp || false
98
- }, this.wrapupData);
110
+ wrapUpRequired: payload.data.interaction?.participants?.[this.agentId]?.isWrapUp || false,
111
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(payload.data)
112
+ }, this.wrapupData, this.agentId);
99
113
  this.taskCollection[payload.data.interactionId] = task;
100
114
  // Condition 1: The state is=new i.e it is a incoming task
101
115
  if (payload.data.interaction.state === 'new') {
@@ -120,7 +134,7 @@ class TaskManager extends _events.default {
120
134
  task = new _.default(this.contact, this.webCallingService, {
121
135
  ...payload.data,
122
136
  isConsulted: false
123
- }, this.wrapupData); // Ensure isConsulted prop exists
137
+ }, this.wrapupData, this.agentId);
124
138
  this.taskCollection[payload.data.interactionId] = task;
125
139
  if (this.webCallingService.loginOption !== _types3.LoginOption.BROWSER || task.data.interaction.mediaType !== _types.MEDIA_CHANNEL.TELEPHONY // for digital channels
126
140
  ) {
@@ -181,12 +195,18 @@ class TaskManager extends _events.default {
181
195
  break;
182
196
  }
183
197
  case _types2.CC_EVENTS.CONTACT_ENDED:
198
+ // Update task data
184
199
  task = this.updateTaskData(task, {
185
200
  ...payload.data,
186
- wrapUpRequired: payload.data.interaction.state !== 'new'
201
+ wrapUpRequired: payload.data.interaction.state !== 'new' && !(0, _TaskUtils.isSecondaryEpDnAgent)(payload.data.interaction)
187
202
  });
203
+
204
+ // Handle cleanup based on whether task should be deleted
188
205
  this.handleTaskCleanup(task);
189
- task.emit(_types.TASK_EVENTS.TASK_END, task);
206
+ task?.emit(_types.TASK_EVENTS.TASK_END, task);
207
+ break;
208
+ case _types2.CC_EVENTS.CONTACT_MERGED:
209
+ task = this.handleContactMerged(task, payload.data);
190
210
  break;
191
211
  case _types2.CC_EVENTS.AGENT_CONTACT_HELD:
192
212
  // As soon as the main interaction is held, we need to emit TASK_HOLD
@@ -229,6 +249,7 @@ class TaskManager extends _events.default {
229
249
  break;
230
250
  case _types2.CC_EVENTS.AGENT_CONSULTING:
231
251
  // Received when agent is in an active consult state
252
+ // TODO: Check if we can use backend consult state instead of isConsulted
232
253
  task = this.updateTaskData(task, payload.data);
233
254
  if (task.data.isConsulted) {
234
255
  // Fire only if you are the agent who received the consult request
@@ -285,6 +306,84 @@ class TaskManager extends _events.default {
285
306
  task = this.updateTaskData(task, payload.data);
286
307
  task.emit(_types.TASK_EVENTS.TASK_RECORDING_RESUME_FAILED, task);
287
308
  break;
309
+ case _types2.CC_EVENTS.AGENT_CONSULT_CONFERENCING:
310
+ // Conference is being established - update task state and emit establishing event
311
+ task = this.updateTaskData(task, payload.data);
312
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_ESTABLISHING, task);
313
+ break;
314
+ case _types2.CC_EVENTS.AGENT_CONSULT_CONFERENCED:
315
+ // Conference started successfully - update task state and emit event
316
+ task = this.updateTaskData(task, payload.data);
317
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_STARTED, task);
318
+ break;
319
+ case _types2.CC_EVENTS.AGENT_CONSULT_CONFERENCE_FAILED:
320
+ // Conference failed - update task state and emit failure event
321
+ task = this.updateTaskData(task, payload.data);
322
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_FAILED, task);
323
+ break;
324
+ case _types2.CC_EVENTS.AGENT_CONSULT_CONFERENCE_ENDED:
325
+ // Conference ended - update task state and emit event
326
+ task = this.updateTaskData(task, payload.data);
327
+ if (!task || (0, _TaskUtils.isPrimary)(task, this.agentId) || (0, _TaskUtils.isParticipantInMainInteraction)(task, this.agentId)) {
328
+ _loggerProxy.default.log('Primary or main interaction participant leaving conference');
329
+ } else {
330
+ this.removeTaskFromCollection(task);
331
+ }
332
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_ENDED, task);
333
+ break;
334
+ case _types2.CC_EVENTS.PARTICIPANT_JOINED_CONFERENCE:
335
+ {
336
+ task = this.updateTaskData(task, {
337
+ ...payload.data,
338
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(payload.data)
339
+ });
340
+ task.emit(_types.TASK_EVENTS.TASK_PARTICIPANT_JOINED, task);
341
+ break;
342
+ }
343
+ case _types2.CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE:
344
+ {
345
+ // Conference ended - update task state and emit event
346
+
347
+ task = this.updateTaskData(task, {
348
+ ...payload.data,
349
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(payload.data)
350
+ });
351
+ if ((0, _TaskUtils.checkParticipantNotInInteraction)(task, this.agentId)) {
352
+ if ((0, _TaskUtils.isParticipantInMainInteraction)(task, this.agentId) || (0, _TaskUtils.isPrimary)(task, this.agentId)) {
353
+ _loggerProxy.default.log('Primary or main interaction participant leaving conference');
354
+ } else {
355
+ this.removeTaskFromCollection(task);
356
+ }
357
+ }
358
+ task.emit(_types.TASK_EVENTS.TASK_PARTICIPANT_LEFT, task);
359
+ break;
360
+ }
361
+ case _types2.CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE_FAILED:
362
+ // Conference exit failed - update task state and emit failure event
363
+ task = this.updateTaskData(task, payload.data);
364
+ task.emit(_types.TASK_EVENTS.TASK_PARTICIPANT_LEFT_FAILED, task);
365
+ break;
366
+ case _types2.CC_EVENTS.AGENT_CONSULT_CONFERENCE_END_FAILED:
367
+ // Conference end failed - update task state with error details and emit failure event
368
+ task = this.updateTaskData(task, payload.data);
369
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_END_FAILED, task);
370
+ break;
371
+ case _types2.CC_EVENTS.AGENT_CONFERENCE_TRANSFERRED:
372
+ // Conference was transferred - update task state and emit transfer success event
373
+ // Note: Backend should provide hasLeft and wrapUpRequired status
374
+ task = this.updateTaskData(task, payload.data);
375
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_TRANSFERRED, task);
376
+ break;
377
+ case _types2.CC_EVENTS.AGENT_CONFERENCE_TRANSFER_FAILED:
378
+ // Conference transfer failed - update task state with error details and emit failure event
379
+ task = this.updateTaskData(task, payload.data);
380
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_TRANSFER_FAILED, task);
381
+ break;
382
+ case _types2.CC_EVENTS.PARTICIPANT_POST_CALL_ACTIVITY:
383
+ // Post-call activity for participant - update task state with activity details
384
+ task = this.updateTaskData(task, payload.data);
385
+ task.emit(_types.TASK_EVENTS.TASK_POST_CALL_ACTIVITY, task);
386
+ break;
288
387
  default:
289
388
  break;
290
389
  }
@@ -317,6 +416,44 @@ class TaskManager extends _events.default {
317
416
  return task;
318
417
  }
319
418
  }
419
+
420
+ /**
421
+ * Handles CONTACT_MERGED event logic
422
+ * @param task - The task to process
423
+ * @param taskData - The task data from the event payload
424
+ * @returns Updated or newly created task
425
+ * @private
426
+ */
427
+ handleContactMerged(task, taskData) {
428
+ if (taskData.childInteractionId) {
429
+ // remove the child task from collection
430
+ this.removeTaskFromCollection(this.taskCollection[taskData.childInteractionId]);
431
+ }
432
+ if (this.taskCollection[taskData.interactionId]) {
433
+ _loggerProxy.default.log(`Got CONTACT_MERGED: Task already exists in collection`, {
434
+ module: _constants.TASK_MANAGER_FILE,
435
+ method: _constants2.METHODS.REGISTER_TASK_LISTENERS,
436
+ interactionId: taskData.interactionId
437
+ });
438
+ // update the task data
439
+ task = this.updateTaskData(task, taskData);
440
+ } else {
441
+ // Case2 : Task is not present in taskCollection
442
+ _loggerProxy.default.log(`Got CONTACT_MERGED : Creating new task in taskManager`, {
443
+ module: _constants.TASK_MANAGER_FILE,
444
+ method: _constants2.METHODS.REGISTER_TASK_LISTENERS,
445
+ interactionId: taskData.interactionId
446
+ });
447
+ task = new _.default(this.contact, this.webCallingService, {
448
+ ...taskData,
449
+ wrapUpRequired: taskData.interaction?.participants?.[this.agentId]?.isWrapUp || false,
450
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(taskData)
451
+ }, this.wrapupData, this.agentId);
452
+ this.taskCollection[taskData.interactionId] = task;
453
+ }
454
+ this.emit(_types.TASK_EVENTS.TASK_MERGED, task);
455
+ return task;
456
+ }
320
457
  removeTaskFromCollection(task) {
321
458
  if (task?.data?.interactionId) {
322
459
  delete this.taskCollection[task.data.interactionId];
@@ -327,13 +464,20 @@ class TaskManager extends _events.default {
327
464
  });
328
465
  }
329
466
  }
467
+
468
+ /**
469
+ * Handles cleanup of task resources including Desktop/WebRTC call cleanup and task removal
470
+ * @param task - The task to clean up
471
+ * @private
472
+ */
330
473
  handleTaskCleanup(task) {
474
+ // Clean up Desktop/WebRTC calling resources for browser-based telephony tasks
331
475
  if (this.webCallingService.loginOption === _types3.LoginOption.BROWSER && task.data.interaction.mediaType === 'telephony') {
332
476
  task.unregisterWebCallListeners();
333
477
  this.webCallingService.cleanUpCall();
334
478
  }
335
- if (task.data.interaction.state === 'new') {
336
- // Only remove tasks in 'new' state immediately. For other states,
479
+ if (task.data.interaction.state === 'new' || (0, _TaskUtils.isSecondaryEpDnAgent)(task.data.interaction)) {
480
+ // Only remove tasks in 'new' state or isSecondaryEpDnAgent immediately. For other states,
337
481
  // retain tasks until they complete wrap-up, unless the task disconnected before being answered.
338
482
  this.removeTaskFromCollection(task);
339
483
  }
@@ -1 +1 @@
1
- {"version":3,"names":["_events","_interopRequireDefault","require","_calling","_types","_constants","_constants2","_types2","_types3","_loggerProxy","_","_MetricsManager","_constants3","obj","__esModule","default","TaskManager","EventEmitter","constructor","contact","webCallingService","webSocketManager","taskCollection","metricsManager","MetricsManager","getInstance","registerTaskListeners","registerIncomingCallEvent","setWrapupData","wrapupData","handleIncomingWebCall","call","currentTask","Object","values","find","task","data","interaction","mediaType","mapCallToTask","getCallId","interactionId","LoggerProxy","log","module","TASK_MANAGER_FILE","method","METHODS","HANDLE_INCOMING_WEB_CALL","emit","TASK_EVENTS","TASK_INCOMING","on","LINE_EVENTS","INCOMING_CALL","unregisterIncomingCallEvent","off","event","payload","JSON","parse","type","CC_TASK_EVENTS","includes","info","REGISTER_TASK_LISTENERS","CC_EVENTS","AGENT_CONTACT","Task","wrapUpRequired","participants","agentId","isWrapUp","state","TASK_HYDRATE","AGENT_CONTACT_RESERVED","isConsulted","loginOption","LoginOption","BROWSER","MEDIA_CHANNEL","TELEPHONY","AGENT_OFFER_CONTACT","updateTaskData","TASK_OFFER_CONTACT","AGENT_OUTBOUND_FAILED","removeTaskFromCollection","AGENT_CONTACT_ASSIGNED","TASK_ASSIGNED","AGENT_CONTACT_UNASSIGNED","TASK_END","AGENT_CONTACT_OFFER_RONA","AGENT_CONTACT_ASSIGN_FAILED","AGENT_INVITE_FAILED","eventTypeToMetricMap","metricEventName","trackEvent","METRIC_EVENT_NAMES","getCommonTrackingFieldForAQMResponse","taskId","reason","handleTaskCleanup","TASK_REJECT","CONTACT_ENDED","AGENT_CONTACT_HELD","TASK_HOLD","AGENT_CONTACT_UNHELD","TASK_RESUME","AGENT_VTEAM_TRANSFERRED","AGENT_CTQ_CANCEL_FAILED","TASK_CONSULT_QUEUE_FAILED","AGENT_CONSULT_CREATED","TASK_CONSULT_CREATED","AGENT_OFFER_CONSULT","TASK_OFFER_CONSULT","AGENT_CONSULTING","TASK_CONSULT_ACCEPTED","TASK_CONSULTING","AGENT_CONSULT_FAILED","AGENT_CONSULT_ENDED","TASK_CONSULT_END","AGENT_CTQ_CANCELLED","TASK_CONSULT_QUEUE_CANCELLED","AGENT_WRAPUP","AGENT_WRAPPEDUP","cancelAutoWrapupTimer","TASK_WRAPPEDUP","CONTACT_RECORDING_PAUSED","TASK_RECORDING_PAUSED","CONTACT_RECORDING_PAUSE_FAILED","TASK_RECORDING_PAUSE_FAILED","CONTACT_RECORDING_RESUMED","TASK_RECORDING_RESUMED","CONTACT_RECORDING_RESUME_FAILED","TASK_RECORDING_RESUME_FAILED","taskData","undefined","warn","UPDATE_TASK_DATA","error","REMOVE_TASK_FROM_COLLECTION","unregisterWebCallListeners","cleanUpCall","getTask","getAllTasks","getTaskManager","taskManager","exports"],"sources":["TaskManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {ICall, LINE_EVENTS} from '@webex/calling';\nimport {WebSocketManager} from '../core/websocket/WebSocketManager';\nimport routingContact from './contact';\nimport WebCallingService from '../WebCallingService';\nimport {ITask, MEDIA_CHANNEL, TASK_EVENTS, TaskData, TaskId} from './types';\nimport {TASK_MANAGER_FILE} from '../../constants';\nimport {METHODS} from './constants';\nimport {CC_EVENTS, CC_TASK_EVENTS, WrapupData} from '../config/types';\nimport {LoginOption} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport Task from '.';\nimport MetricsManager from '../../metrics/MetricsManager';\nimport {METRIC_EVENT_NAMES} from '../../metrics/constants';\n\n/** @internal */\nexport default class TaskManager extends EventEmitter {\n private call: ICall;\n private contact: ReturnType<typeof routingContact>;\n /**\n * Collection of tasks indexed by TaskId\n * @type {Record<TaskId, ITask>}\n * @private\n */\n private taskCollection: Record<TaskId, ITask>;\n private webCallingService: WebCallingService;\n private webSocketManager: WebSocketManager;\n private metricsManager: MetricsManager;\n private static taskManager;\n private wrapupData: WrapupData;\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n constructor(\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ) {\n super();\n this.contact = contact;\n this.taskCollection = {};\n this.webCallingService = webCallingService;\n this.webSocketManager = webSocketManager;\n this.metricsManager = MetricsManager.getInstance();\n this.registerTaskListeners();\n this.registerIncomingCallEvent();\n }\n\n public setWrapupData(wrapupData: WrapupData) {\n this.wrapupData = wrapupData;\n }\n\n private handleIncomingWebCall = (call: ICall) => {\n const currentTask = Object.values(this.taskCollection).find(\n (task) => task.data.interaction.mediaType === 'telephony'\n );\n\n if (currentTask) {\n this.webCallingService.mapCallToTask(call.getCallId(), currentTask.data.interactionId);\n LoggerProxy.log(`Call mapped to task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.HANDLE_INCOMING_WEB_CALL,\n interactionId: currentTask.data.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_INCOMING, currentTask);\n }\n this.call = call;\n };\n\n public registerIncomingCallEvent() {\n this.webCallingService.on(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n public unregisterIncomingCallEvent() {\n this.webCallingService.off(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n private registerTaskListeners() {\n this.webSocketManager.on('message', (event) => {\n const payload = JSON.parse(event);\n // Re-emit the task events to the task object\n let task: ITask;\n if (payload.data?.type) {\n if (Object.values(CC_TASK_EVENTS).includes(payload.data.type)) {\n task = this.taskCollection[payload.data.interactionId];\n }\n LoggerProxy.info(`Handling task event ${payload.data?.type}`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n switch (payload.data.type) {\n case CC_EVENTS.AGENT_CONTACT:\n // Case1 : Task is already present in taskCollection\n if (this.taskCollection[payload.data.interactionId]) {\n LoggerProxy.log(`Got AGENT_CONTACT: Task already exists in collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n break;\n } else if (!this.taskCollection[payload.data.interactionId]) {\n // Case2 : Task is not present in taskCollection\n LoggerProxy.log(`Got AGENT_CONTACT : Creating new task in taskManager`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n wrapUpRequired:\n payload.data.interaction?.participants?.[payload.data.agentId]?.isWrapUp ||\n false,\n },\n this.wrapupData\n );\n this.taskCollection[payload.data.interactionId] = task;\n // Condition 1: The state is=new i.e it is a incoming task\n if (payload.data.interaction.state === 'new') {\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=new, sending TASK_INCOMING event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else {\n // Condition 2: The state is anything else i.e the task was connected\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=${payload.data.interaction.state}, sending TASK_HYDRATE event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_HYDRATE, task);\n }\n }\n break;\n case CC_EVENTS.AGENT_CONTACT_RESERVED:\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n isConsulted: false,\n },\n this.wrapupData\n ); // Ensure isConsulted prop exists\n this.taskCollection[payload.data.interactionId] = task;\n if (\n this.webCallingService.loginOption !== LoginOption.BROWSER ||\n task.data.interaction.mediaType !== MEDIA_CHANNEL.TELEPHONY // for digital channels\n ) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else if (this.call) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n }\n break;\n case CC_EVENTS.AGENT_OFFER_CONTACT:\n // We don't have to emit any event here since this will be result of promise.\n task = this.updateTaskData(task, payload.data);\n LoggerProxy.log(`Agent offer contact received for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_OFFER_CONTACT, task);\n break;\n case CC_EVENTS.AGENT_OUTBOUND_FAILED:\n // We don't have to emit any event here since this will be result of promise.\n if (task.data) {\n this.removeTaskFromCollection(task);\n }\n LoggerProxy.log(`Agent outbound failed for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n break;\n case CC_EVENTS.AGENT_CONTACT_ASSIGNED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_ASSIGNED, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNASSIGNED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_OFFER_RONA:\n case CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED:\n case CC_EVENTS.AGENT_INVITE_FAILED: {\n task = this.updateTaskData(task, payload.data);\n\n const eventTypeToMetricMap: Record<string, keyof typeof METRIC_EVENT_NAMES> = {\n [CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED]: 'AGENT_CONTACT_ASSIGN_FAILED',\n [CC_EVENTS.AGENT_INVITE_FAILED]: 'AGENT_INVITE_FAILED',\n };\n const metricEventName: keyof typeof METRIC_EVENT_NAMES =\n eventTypeToMetricMap[payload.data.type] || 'AGENT_RONA';\n\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES[metricEventName],\n {\n ...MetricsManager.getCommonTrackingFieldForAQMResponse(payload.data),\n taskId: payload.data.interactionId,\n reason: payload.data.reason,\n },\n ['behavioral', 'operational']\n );\n this.handleTaskCleanup(task);\n task.emit(TASK_EVENTS.TASK_REJECT, payload.data.reason);\n break;\n }\n case CC_EVENTS.CONTACT_ENDED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: payload.data.interaction.state !== 'new',\n });\n this.handleTaskCleanup(task);\n task.emit(TASK_EVENTS.TASK_END, task);\n\n break;\n case CC_EVENTS.AGENT_CONTACT_HELD:\n // As soon as the main interaction is held, we need to emit TASK_HOLD\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_HOLD, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNHELD:\n // As soon as the main interaction is unheld, we need to emit TASK_RESUME\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RESUME, task);\n break;\n case CC_EVENTS.AGENT_VTEAM_TRANSFERRED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCEL_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CREATED:\n // Received when self agent initiates a consult\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: false, // This ensures that the task consult status is always reset\n });\n task.emit(TASK_EVENTS.TASK_CONSULT_CREATED, task);\n break;\n case CC_EVENTS.AGENT_OFFER_CONSULT:\n // Received when other agent sends us a consult offer\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: true, // This ensures that the task is marked as us being requested for a consult\n });\n task.emit(TASK_EVENTS.TASK_OFFER_CONSULT, task);\n break;\n case CC_EVENTS.AGENT_CONSULTING:\n // Received when agent is in an active consult state\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // Fire only if you are the agent who received the consult request\n task.emit(TASK_EVENTS.TASK_CONSULT_ACCEPTED, task);\n } else {\n // Fire only if you are the agent who initiated the consult\n task.emit(TASK_EVENTS.TASK_CONSULTING, task);\n }\n break;\n case CC_EVENTS.AGENT_CONSULT_FAILED:\n // This can only be received by the agent who initiated the consult.\n // We need not emit any event here since this will be result of promise\n task = this.updateTaskData(task, payload.data);\n break;\n case CC_EVENTS.AGENT_CONSULT_ENDED:\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // This will be the end state of the task as soon as we end the consult in case of\n // us being offered a consult\n this.removeTaskFromCollection(task);\n }\n task.emit(TASK_EVENTS.TASK_CONSULT_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCELLED:\n // This event is received when the consult using queue is cancelled using API\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_CANCELLED, task);\n break;\n case CC_EVENTS.AGENT_WRAPUP:\n task = this.updateTaskData(task, {...payload.data, wrapUpRequired: true});\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_WRAPPEDUP:\n task.cancelAutoWrapupTimer();\n this.removeTaskFromCollection(task);\n task.emit(TASK_EVENTS.TASK_WRAPPEDUP, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSE_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSE_FAILED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUMED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUMED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUME_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUME_FAILED, task);\n break;\n default:\n break;\n }\n if (task) {\n task.emit(payload.data.type, payload.data);\n }\n }\n });\n }\n\n private updateTaskData(task: ITask, taskData: TaskData): ITask {\n if (!task) {\n return undefined;\n }\n\n if (!taskData?.interactionId) {\n LoggerProxy.warn('Received task update with missing interactionId', {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n });\n }\n\n try {\n const currentTask = task.updateTaskData(taskData);\n this.taskCollection[taskData.interactionId] = currentTask;\n\n return currentTask;\n } catch (error) {\n LoggerProxy.error(`Failed to update task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n interactionId: taskData.interactionId,\n });\n\n return task;\n }\n }\n\n private removeTaskFromCollection(task: ITask) {\n if (task?.data?.interactionId) {\n delete this.taskCollection[task.data.interactionId];\n LoggerProxy.info(`Task removed from collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REMOVE_TASK_FROM_COLLECTION,\n interactionId: task.data.interactionId,\n });\n }\n }\n\n private handleTaskCleanup(task: ITask) {\n if (\n this.webCallingService.loginOption === LoginOption.BROWSER &&\n task.data.interaction.mediaType === 'telephony'\n ) {\n task.unregisterWebCallListeners();\n this.webCallingService.cleanUpCall();\n }\n if (task.data.interaction.state === 'new') {\n // Only remove tasks in 'new' state immediately. For other states,\n // retain tasks until they complete wrap-up, unless the task disconnected before being answered.\n this.removeTaskFromCollection(task);\n }\n }\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getTask = (taskId: string) => {\n return this.taskCollection[taskId];\n };\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getAllTasks = (): Record<TaskId, ITask> => {\n return this.taskCollection;\n };\n\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n public static getTaskManager = (\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ): TaskManager => {\n if (!this.taskManager) {\n this.taskManager = new TaskManager(contact, webCallingService, webSocketManager);\n }\n\n return this.taskManager;\n };\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_events","_interopRequireDefault","require","_calling","_types","_constants","_constants2","_types2","_types3","_loggerProxy","_","_MetricsManager","_constants3","_TaskUtils","obj","__esModule","default","TaskManager","EventEmitter","constructor","contact","webCallingService","webSocketManager","taskCollection","metricsManager","MetricsManager","getInstance","registerTaskListeners","registerIncomingCallEvent","setWrapupData","wrapupData","setAgentId","agentId","getAgentId","handleIncomingWebCall","call","currentTask","Object","values","find","task","data","interaction","mediaType","mapCallToTask","getCallId","interactionId","LoggerProxy","log","module","TASK_MANAGER_FILE","method","METHODS","HANDLE_INCOMING_WEB_CALL","emit","TASK_EVENTS","TASK_INCOMING","on","LINE_EVENTS","INCOMING_CALL","unregisterIncomingCallEvent","off","event","payload","JSON","parse","type","CC_TASK_EVENTS","includes","info","REGISTER_TASK_LISTENERS","CC_EVENTS","AGENT_CONTACT","Task","wrapUpRequired","participants","isWrapUp","isConferenceInProgress","getIsConferenceInProgress","state","TASK_HYDRATE","AGENT_CONTACT_RESERVED","isConsulted","loginOption","LoginOption","BROWSER","MEDIA_CHANNEL","TELEPHONY","AGENT_OFFER_CONTACT","updateTaskData","TASK_OFFER_CONTACT","AGENT_OUTBOUND_FAILED","removeTaskFromCollection","AGENT_CONTACT_ASSIGNED","TASK_ASSIGNED","AGENT_CONTACT_UNASSIGNED","TASK_END","AGENT_CONTACT_OFFER_RONA","AGENT_CONTACT_ASSIGN_FAILED","AGENT_INVITE_FAILED","eventTypeToMetricMap","metricEventName","trackEvent","METRIC_EVENT_NAMES","getCommonTrackingFieldForAQMResponse","taskId","reason","handleTaskCleanup","TASK_REJECT","CONTACT_ENDED","isSecondaryEpDnAgent","CONTACT_MERGED","handleContactMerged","AGENT_CONTACT_HELD","TASK_HOLD","AGENT_CONTACT_UNHELD","TASK_RESUME","AGENT_VTEAM_TRANSFERRED","AGENT_CTQ_CANCEL_FAILED","TASK_CONSULT_QUEUE_FAILED","AGENT_CONSULT_CREATED","TASK_CONSULT_CREATED","AGENT_OFFER_CONSULT","TASK_OFFER_CONSULT","AGENT_CONSULTING","TASK_CONSULT_ACCEPTED","TASK_CONSULTING","AGENT_CONSULT_FAILED","AGENT_CONSULT_ENDED","TASK_CONSULT_END","AGENT_CTQ_CANCELLED","TASK_CONSULT_QUEUE_CANCELLED","AGENT_WRAPUP","AGENT_WRAPPEDUP","cancelAutoWrapupTimer","TASK_WRAPPEDUP","CONTACT_RECORDING_PAUSED","TASK_RECORDING_PAUSED","CONTACT_RECORDING_PAUSE_FAILED","TASK_RECORDING_PAUSE_FAILED","CONTACT_RECORDING_RESUMED","TASK_RECORDING_RESUMED","CONTACT_RECORDING_RESUME_FAILED","TASK_RECORDING_RESUME_FAILED","AGENT_CONSULT_CONFERENCING","TASK_CONFERENCE_ESTABLISHING","AGENT_CONSULT_CONFERENCED","TASK_CONFERENCE_STARTED","AGENT_CONSULT_CONFERENCE_FAILED","TASK_CONFERENCE_FAILED","AGENT_CONSULT_CONFERENCE_ENDED","isPrimary","isParticipantInMainInteraction","TASK_CONFERENCE_ENDED","PARTICIPANT_JOINED_CONFERENCE","TASK_PARTICIPANT_JOINED","PARTICIPANT_LEFT_CONFERENCE","checkParticipantNotInInteraction","TASK_PARTICIPANT_LEFT","PARTICIPANT_LEFT_CONFERENCE_FAILED","TASK_PARTICIPANT_LEFT_FAILED","AGENT_CONSULT_CONFERENCE_END_FAILED","TASK_CONFERENCE_END_FAILED","AGENT_CONFERENCE_TRANSFERRED","TASK_CONFERENCE_TRANSFERRED","AGENT_CONFERENCE_TRANSFER_FAILED","TASK_CONFERENCE_TRANSFER_FAILED","PARTICIPANT_POST_CALL_ACTIVITY","TASK_POST_CALL_ACTIVITY","taskData","undefined","warn","UPDATE_TASK_DATA","error","childInteractionId","TASK_MERGED","REMOVE_TASK_FROM_COLLECTION","unregisterWebCallListeners","cleanUpCall","getTask","getAllTasks","getTaskManager","taskManager","exports"],"sources":["TaskManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {ICall, LINE_EVENTS} from '@webex/calling';\nimport {WebSocketManager} from '../core/websocket/WebSocketManager';\nimport routingContact from './contact';\nimport WebCallingService from '../WebCallingService';\nimport {ITask, MEDIA_CHANNEL, TASK_EVENTS, TaskData, TaskId} from './types';\nimport {TASK_MANAGER_FILE} from '../../constants';\nimport {METHODS} from './constants';\nimport {CC_EVENTS, CC_TASK_EVENTS, WrapupData} from '../config/types';\nimport {LoginOption} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport Task from '.';\nimport MetricsManager from '../../metrics/MetricsManager';\nimport {METRIC_EVENT_NAMES} from '../../metrics/constants';\nimport {\n checkParticipantNotInInteraction,\n getIsConferenceInProgress,\n isParticipantInMainInteraction,\n isPrimary,\n isSecondaryEpDnAgent,\n} from './TaskUtils';\n\n/** @internal */\nexport default class TaskManager extends EventEmitter {\n private call: ICall;\n private contact: ReturnType<typeof routingContact>;\n /**\n * Collection of tasks indexed by TaskId\n * @type {Record<TaskId, ITask>}\n * @private\n */\n private taskCollection: Record<TaskId, ITask>;\n private webCallingService: WebCallingService;\n private webSocketManager: WebSocketManager;\n private metricsManager: MetricsManager;\n private static taskManager;\n private wrapupData: WrapupData;\n private agentId: string;\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n constructor(\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ) {\n super();\n this.contact = contact;\n this.taskCollection = {};\n this.webCallingService = webCallingService;\n this.webSocketManager = webSocketManager;\n this.metricsManager = MetricsManager.getInstance();\n this.registerTaskListeners();\n this.registerIncomingCallEvent();\n }\n\n public setWrapupData(wrapupData: WrapupData) {\n this.wrapupData = wrapupData;\n }\n\n public setAgentId(agentId: string) {\n this.agentId = agentId;\n }\n\n /**\n * Gets the current agent ID\n * @returns {string} The agent ID set for this task manager instance\n * @public\n */\n public getAgentId(): string {\n return this.agentId;\n }\n\n private handleIncomingWebCall = (call: ICall) => {\n const currentTask = Object.values(this.taskCollection).find(\n (task) => task.data.interaction.mediaType === 'telephony'\n );\n\n if (currentTask) {\n this.webCallingService.mapCallToTask(call.getCallId(), currentTask.data.interactionId);\n LoggerProxy.log(`Call mapped to task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.HANDLE_INCOMING_WEB_CALL,\n interactionId: currentTask.data.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_INCOMING, currentTask);\n }\n this.call = call;\n };\n\n public registerIncomingCallEvent() {\n this.webCallingService.on(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n public unregisterIncomingCallEvent() {\n this.webCallingService.off(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n private registerTaskListeners() {\n this.webSocketManager.on('message', (event) => {\n const payload = JSON.parse(event);\n // Re-emit the task events to the task object\n let task: ITask;\n if (payload.data?.type) {\n if (Object.values(CC_TASK_EVENTS).includes(payload.data.type)) {\n task = this.taskCollection[payload.data.interactionId];\n }\n LoggerProxy.info(`Handling task event ${payload.data?.type}`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n switch (payload.data.type) {\n case CC_EVENTS.AGENT_CONTACT:\n // Case1 : Task is already present in taskCollection\n if (this.taskCollection[payload.data.interactionId]) {\n LoggerProxy.log(`Got AGENT_CONTACT: Task already exists in collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n break;\n } else if (!this.taskCollection[payload.data.interactionId]) {\n // Case2 : Task is not present in taskCollection\n LoggerProxy.log(`Got AGENT_CONTACT : Creating new task in taskManager`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n wrapUpRequired:\n payload.data.interaction?.participants?.[this.agentId]?.isWrapUp || false,\n isConferenceInProgress: getIsConferenceInProgress(payload.data),\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[payload.data.interactionId] = task;\n // Condition 1: The state is=new i.e it is a incoming task\n if (payload.data.interaction.state === 'new') {\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=new, sending TASK_INCOMING event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else {\n // Condition 2: The state is anything else i.e the task was connected\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=${payload.data.interaction.state}, sending TASK_HYDRATE event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_HYDRATE, task);\n }\n }\n break;\n\n case CC_EVENTS.AGENT_CONTACT_RESERVED:\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n isConsulted: false,\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[payload.data.interactionId] = task;\n if (\n this.webCallingService.loginOption !== LoginOption.BROWSER ||\n task.data.interaction.mediaType !== MEDIA_CHANNEL.TELEPHONY // for digital channels\n ) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else if (this.call) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n }\n break;\n case CC_EVENTS.AGENT_OFFER_CONTACT:\n // We don't have to emit any event here since this will be result of promise.\n task = this.updateTaskData(task, payload.data);\n LoggerProxy.log(`Agent offer contact received for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_OFFER_CONTACT, task);\n break;\n case CC_EVENTS.AGENT_OUTBOUND_FAILED:\n // We don't have to emit any event here since this will be result of promise.\n if (task.data) {\n this.removeTaskFromCollection(task);\n }\n LoggerProxy.log(`Agent outbound failed for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n break;\n case CC_EVENTS.AGENT_CONTACT_ASSIGNED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_ASSIGNED, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNASSIGNED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_OFFER_RONA:\n case CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED:\n case CC_EVENTS.AGENT_INVITE_FAILED: {\n task = this.updateTaskData(task, payload.data);\n\n const eventTypeToMetricMap: Record<string, keyof typeof METRIC_EVENT_NAMES> = {\n [CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED]: 'AGENT_CONTACT_ASSIGN_FAILED',\n [CC_EVENTS.AGENT_INVITE_FAILED]: 'AGENT_INVITE_FAILED',\n };\n const metricEventName: keyof typeof METRIC_EVENT_NAMES =\n eventTypeToMetricMap[payload.data.type] || 'AGENT_RONA';\n\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES[metricEventName],\n {\n ...MetricsManager.getCommonTrackingFieldForAQMResponse(payload.data),\n taskId: payload.data.interactionId,\n reason: payload.data.reason,\n },\n ['behavioral', 'operational']\n );\n this.handleTaskCleanup(task);\n task.emit(TASK_EVENTS.TASK_REJECT, payload.data.reason);\n break;\n }\n case CC_EVENTS.CONTACT_ENDED:\n // Update task data\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired:\n payload.data.interaction.state !== 'new' &&\n !isSecondaryEpDnAgent(payload.data.interaction),\n });\n\n // Handle cleanup based on whether task should be deleted\n this.handleTaskCleanup(task);\n\n task?.emit(TASK_EVENTS.TASK_END, task);\n\n break;\n case CC_EVENTS.CONTACT_MERGED:\n task = this.handleContactMerged(task, payload.data);\n break;\n case CC_EVENTS.AGENT_CONTACT_HELD:\n // As soon as the main interaction is held, we need to emit TASK_HOLD\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_HOLD, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNHELD:\n // As soon as the main interaction is unheld, we need to emit TASK_RESUME\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RESUME, task);\n break;\n case CC_EVENTS.AGENT_VTEAM_TRANSFERRED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCEL_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CREATED:\n // Received when self agent initiates a consult\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: false, // This ensures that the task consult status is always reset\n });\n task.emit(TASK_EVENTS.TASK_CONSULT_CREATED, task);\n break;\n case CC_EVENTS.AGENT_OFFER_CONSULT:\n // Received when other agent sends us a consult offer\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: true, // This ensures that the task is marked as us being requested for a consult\n });\n task.emit(TASK_EVENTS.TASK_OFFER_CONSULT, task);\n break;\n case CC_EVENTS.AGENT_CONSULTING:\n // Received when agent is in an active consult state\n // TODO: Check if we can use backend consult state instead of isConsulted\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // Fire only if you are the agent who received the consult request\n task.emit(TASK_EVENTS.TASK_CONSULT_ACCEPTED, task);\n } else {\n // Fire only if you are the agent who initiated the consult\n task.emit(TASK_EVENTS.TASK_CONSULTING, task);\n }\n break;\n case CC_EVENTS.AGENT_CONSULT_FAILED:\n // This can only be received by the agent who initiated the consult.\n // We need not emit any event here since this will be result of promise\n task = this.updateTaskData(task, payload.data);\n break;\n case CC_EVENTS.AGENT_CONSULT_ENDED:\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // This will be the end state of the task as soon as we end the consult in case of\n // us being offered a consult\n this.removeTaskFromCollection(task);\n }\n task.emit(TASK_EVENTS.TASK_CONSULT_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCELLED:\n // This event is received when the consult using queue is cancelled using API\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_CANCELLED, task);\n break;\n case CC_EVENTS.AGENT_WRAPUP:\n task = this.updateTaskData(task, {...payload.data, wrapUpRequired: true});\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_WRAPPEDUP:\n task.cancelAutoWrapupTimer();\n this.removeTaskFromCollection(task);\n task.emit(TASK_EVENTS.TASK_WRAPPEDUP, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSE_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSE_FAILED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUMED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUMED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUME_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUME_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCING:\n // Conference is being established - update task state and emit establishing event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_ESTABLISHING, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCED:\n // Conference started successfully - update task state and emit event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_STARTED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_FAILED:\n // Conference failed - update task state and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_ENDED:\n // Conference ended - update task state and emit event\n task = this.updateTaskData(task, payload.data);\n if (\n !task ||\n isPrimary(task, this.agentId) ||\n isParticipantInMainInteraction(task, this.agentId)\n ) {\n LoggerProxy.log('Primary or main interaction participant leaving conference');\n } else {\n this.removeTaskFromCollection(task);\n }\n task.emit(TASK_EVENTS.TASK_CONFERENCE_ENDED, task);\n break;\n case CC_EVENTS.PARTICIPANT_JOINED_CONFERENCE: {\n task = this.updateTaskData(task, {\n ...payload.data,\n isConferenceInProgress: getIsConferenceInProgress(payload.data),\n });\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_JOINED, task);\n break;\n }\n case CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE: {\n // Conference ended - update task state and emit event\n\n task = this.updateTaskData(task, {\n ...payload.data,\n isConferenceInProgress: getIsConferenceInProgress(payload.data),\n });\n if (checkParticipantNotInInteraction(task, this.agentId)) {\n if (\n isParticipantInMainInteraction(task, this.agentId) ||\n isPrimary(task, this.agentId)\n ) {\n LoggerProxy.log('Primary or main interaction participant leaving conference');\n } else {\n this.removeTaskFromCollection(task);\n }\n }\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_LEFT, task);\n break;\n }\n case CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE_FAILED:\n // Conference exit failed - update task state and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_LEFT_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_END_FAILED:\n // Conference end failed - update task state with error details and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_END_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONFERENCE_TRANSFERRED:\n // Conference was transferred - update task state and emit transfer success event\n // Note: Backend should provide hasLeft and wrapUpRequired status\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_TRANSFERRED, task);\n break;\n case CC_EVENTS.AGENT_CONFERENCE_TRANSFER_FAILED:\n // Conference transfer failed - update task state with error details and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_TRANSFER_FAILED, task);\n break;\n case CC_EVENTS.PARTICIPANT_POST_CALL_ACTIVITY:\n // Post-call activity for participant - update task state with activity details\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_POST_CALL_ACTIVITY, task);\n break;\n default:\n break;\n }\n if (task) {\n task.emit(payload.data.type, payload.data);\n }\n }\n });\n }\n\n private updateTaskData(task: ITask, taskData: TaskData): ITask {\n if (!task) {\n return undefined;\n }\n\n if (!taskData?.interactionId) {\n LoggerProxy.warn('Received task update with missing interactionId', {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n });\n }\n\n try {\n const currentTask = task.updateTaskData(taskData);\n this.taskCollection[taskData.interactionId] = currentTask;\n\n return currentTask;\n } catch (error) {\n LoggerProxy.error(`Failed to update task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n interactionId: taskData.interactionId,\n });\n\n return task;\n }\n }\n\n /**\n * Handles CONTACT_MERGED event logic\n * @param task - The task to process\n * @param taskData - The task data from the event payload\n * @returns Updated or newly created task\n * @private\n */\n private handleContactMerged(task: ITask, taskData: TaskData): ITask {\n if (taskData.childInteractionId) {\n // remove the child task from collection\n this.removeTaskFromCollection(this.taskCollection[taskData.childInteractionId]);\n }\n\n if (this.taskCollection[taskData.interactionId]) {\n LoggerProxy.log(`Got CONTACT_MERGED: Task already exists in collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: taskData.interactionId,\n });\n // update the task data\n task = this.updateTaskData(task, taskData);\n } else {\n // Case2 : Task is not present in taskCollection\n LoggerProxy.log(`Got CONTACT_MERGED : Creating new task in taskManager`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: taskData.interactionId,\n });\n\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...taskData,\n wrapUpRequired: taskData.interaction?.participants?.[this.agentId]?.isWrapUp || false,\n isConferenceInProgress: getIsConferenceInProgress(taskData),\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[taskData.interactionId] = task;\n }\n\n this.emit(TASK_EVENTS.TASK_MERGED, task);\n\n return task;\n }\n\n private removeTaskFromCollection(task: ITask) {\n if (task?.data?.interactionId) {\n delete this.taskCollection[task.data.interactionId];\n LoggerProxy.info(`Task removed from collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REMOVE_TASK_FROM_COLLECTION,\n interactionId: task.data.interactionId,\n });\n }\n }\n\n /**\n * Handles cleanup of task resources including Desktop/WebRTC call cleanup and task removal\n * @param task - The task to clean up\n * @private\n */\n private handleTaskCleanup(task: ITask) {\n // Clean up Desktop/WebRTC calling resources for browser-based telephony tasks\n if (\n this.webCallingService.loginOption === LoginOption.BROWSER &&\n task.data.interaction.mediaType === 'telephony'\n ) {\n task.unregisterWebCallListeners();\n this.webCallingService.cleanUpCall();\n }\n\n if (task.data.interaction.state === 'new' || isSecondaryEpDnAgent(task.data.interaction)) {\n // Only remove tasks in 'new' state or isSecondaryEpDnAgent immediately. For other states,\n // retain tasks until they complete wrap-up, unless the task disconnected before being answered.\n this.removeTaskFromCollection(task);\n }\n }\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getTask = (taskId: string) => {\n return this.taskCollection[taskId];\n };\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getAllTasks = (): Record<TaskId, ITask> => {\n return this.taskCollection;\n };\n\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n public static getTaskManager = (\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ): TaskManager => {\n if (!this.taskManager) {\n this.taskManager = new TaskManager(contact, webCallingService, webSocketManager);\n }\n\n return this.taskManager;\n };\n}\n"],"mappings":"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"}
@@ -0,0 +1,104 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.isSecondaryEpDnAgent = exports.isSecondaryAgent = exports.isPrimary = exports.isParticipantInMainInteraction = exports.getIsConferenceInProgress = exports.checkParticipantNotInInteraction = void 0;
7
+ /* eslint-disable import/prefer-default-export */
8
+
9
+ /**
10
+ * Determines if the given agent is the primary agent (owner) of the task
11
+ * @param task - The task to check
12
+ * @param agentId - The agent ID to check for primary status
13
+ * @returns true if the agent is the primary agent, false otherwise
14
+ */
15
+ const isPrimary = (task, agentId) => {
16
+ if (!task.data?.interaction?.owner) {
17
+ // Fall back to checking data.agentId when owner is not set
18
+ return task.data.agentId === agentId;
19
+ }
20
+ return task.data.interaction.owner === agentId;
21
+ };
22
+
23
+ /**
24
+ * Checks if the given agent is a participant in the main interaction (mainCall)
25
+ * @param task - The task to check
26
+ * @param agentId - The agent ID to check for participation
27
+ * @returns true if the agent is a participant in the main interaction, false otherwise
28
+ */
29
+ exports.isPrimary = isPrimary;
30
+ const isParticipantInMainInteraction = (task, agentId) => {
31
+ if (!task?.data?.interaction?.media) {
32
+ return false;
33
+ }
34
+ return Object.values(task.data.interaction.media).some(mediaObj => mediaObj && mediaObj.mType === 'mainCall' && mediaObj.participants?.includes(agentId));
35
+ };
36
+
37
+ /**
38
+ * Checks if the given agent is not in the interaction or has left the interaction
39
+ * @param task - The task to check
40
+ * @param agentId - The agent ID to check
41
+ * @returns true if the agent is not in the interaction or has left, false otherwise
42
+ */
43
+ exports.isParticipantInMainInteraction = isParticipantInMainInteraction;
44
+ const checkParticipantNotInInteraction = (task, agentId) => {
45
+ if (!task?.data?.interaction?.participants) {
46
+ return true;
47
+ }
48
+ const {
49
+ data
50
+ } = task;
51
+ return !(agentId in data.interaction.participants) || agentId in data.interaction.participants && data.interaction.participants[agentId].hasLeft;
52
+ };
53
+
54
+ /**
55
+ * Determines if a conference is currently in progress based on the number of active agent participants
56
+ * @param TaskData - The payLoad data to check for conference status
57
+ * @returns true if there are 2 or more active agent participants in the main call, false otherwise
58
+ */
59
+ exports.checkParticipantNotInInteraction = checkParticipantNotInInteraction;
60
+ const getIsConferenceInProgress = data => {
61
+ const mediaMainCall = data.interaction.media?.[data?.interactionId];
62
+ const participantsInMainCall = new Set(mediaMainCall?.participants);
63
+ const participants = data.interaction.participants;
64
+ const agentParticipants = new Set();
65
+ if (participantsInMainCall.size > 0) {
66
+ participantsInMainCall.forEach(participantId => {
67
+ const participant = participants?.[participantId];
68
+ if (participant && participant.pType !== 'Customer' && participant.pType !== 'Supervisor' && !participant.hasLeft && participant.pType !== 'VVA') {
69
+ agentParticipants.add(participantId);
70
+ }
71
+ });
72
+ }
73
+ return agentParticipants.size >= 2;
74
+ };
75
+
76
+ /**
77
+ * Checks if the current agent is a secondary agent in a consultation scenario.
78
+ * Secondary agents are those who were consulted (not the original call owner).
79
+ * @param task - The task object containing interaction details
80
+ * @returns true if this is a secondary agent (consulted party), false otherwise
81
+ */
82
+ exports.getIsConferenceInProgress = getIsConferenceInProgress;
83
+ const isSecondaryAgent = interaction => {
84
+ if (!interaction.callProcessingDetails) {
85
+ return false;
86
+ }
87
+ return interaction.callProcessingDetails.relationshipType === 'consult' && !!interaction.callProcessingDetails.parentInteractionId && interaction.callProcessingDetails.parentInteractionId !== interaction.interactionId;
88
+ };
89
+
90
+ /**
91
+ * Checks if the current agent is a secondary EP-DN (Entry Point Dial Number) agent.
92
+ * This is specifically for telephony consultations to external numbers/entry points.
93
+ * @param task - The task object containing interaction details
94
+ * @returns true if this is a secondary EP-DN agent in telephony consultation, false otherwise
95
+ */
96
+ exports.isSecondaryAgent = isSecondaryAgent;
97
+ const isSecondaryEpDnAgent = interaction => {
98
+ if (!interaction) {
99
+ return false;
100
+ }
101
+ return interaction.mediaType === 'telephony' && isSecondaryAgent(interaction);
102
+ };
103
+ exports.isSecondaryEpDnAgent = isSecondaryEpDnAgent;
104
+ //# sourceMappingURL=TaskUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["isPrimary","task","agentId","data","interaction","owner","exports","isParticipantInMainInteraction","media","Object","values","some","mediaObj","mType","participants","includes","checkParticipantNotInInteraction","hasLeft","getIsConferenceInProgress","mediaMainCall","interactionId","participantsInMainCall","Set","agentParticipants","size","forEach","participantId","participant","pType","add","isSecondaryAgent","callProcessingDetails","relationshipType","parentInteractionId","isSecondaryEpDnAgent","mediaType"],"sources":["TaskUtils.ts"],"sourcesContent":["/* eslint-disable import/prefer-default-export */\nimport {Interaction, ITask, TaskData} from './types';\n\n/**\n * Determines if the given agent is the primary agent (owner) of the task\n * @param task - The task to check\n * @param agentId - The agent ID to check for primary status\n * @returns true if the agent is the primary agent, false otherwise\n */\nexport const isPrimary = (task: ITask, agentId: string): boolean => {\n if (!task.data?.interaction?.owner) {\n // Fall back to checking data.agentId when owner is not set\n return task.data.agentId === agentId;\n }\n\n return task.data.interaction.owner === agentId;\n};\n\n/**\n * Checks if the given agent is a participant in the main interaction (mainCall)\n * @param task - The task to check\n * @param agentId - The agent ID to check for participation\n * @returns true if the agent is a participant in the main interaction, false otherwise\n */\nexport const isParticipantInMainInteraction = (task: ITask, agentId: string): boolean => {\n if (!task?.data?.interaction?.media) {\n return false;\n }\n\n return Object.values(task.data.interaction.media).some(\n (mediaObj) =>\n mediaObj && mediaObj.mType === 'mainCall' && mediaObj.participants?.includes(agentId)\n );\n};\n\n/**\n * Checks if the given agent is not in the interaction or has left the interaction\n * @param task - The task to check\n * @param agentId - The agent ID to check\n * @returns true if the agent is not in the interaction or has left, false otherwise\n */\nexport const checkParticipantNotInInteraction = (task: ITask, agentId: string): boolean => {\n if (!task?.data?.interaction?.participants) {\n return true;\n }\n const {data} = task;\n\n return (\n !(agentId in data.interaction.participants) ||\n (agentId in data.interaction.participants && data.interaction.participants[agentId].hasLeft)\n );\n};\n\n/**\n * Determines if a conference is currently in progress based on the number of active agent participants\n * @param TaskData - The payLoad data to check for conference status\n * @returns true if there are 2 or more active agent participants in the main call, false otherwise\n */\nexport const getIsConferenceInProgress = (data: TaskData): boolean => {\n const mediaMainCall = data.interaction.media?.[data?.interactionId];\n const participantsInMainCall = new Set(mediaMainCall?.participants);\n const participants = data.interaction.participants;\n\n const agentParticipants = new Set();\n if (participantsInMainCall.size > 0) {\n participantsInMainCall.forEach((participantId: string) => {\n const participant = participants?.[participantId];\n if (\n participant &&\n participant.pType !== 'Customer' &&\n participant.pType !== 'Supervisor' &&\n !participant.hasLeft &&\n participant.pType !== 'VVA'\n ) {\n agentParticipants.add(participantId);\n }\n });\n }\n\n return agentParticipants.size >= 2;\n};\n\n/**\n * Checks if the current agent is a secondary agent in a consultation scenario.\n * Secondary agents are those who were consulted (not the original call owner).\n * @param task - The task object containing interaction details\n * @returns true if this is a secondary agent (consulted party), false otherwise\n */\nexport const isSecondaryAgent = (interaction: Interaction): boolean => {\n if (!interaction.callProcessingDetails) {\n return false;\n }\n\n return (\n interaction.callProcessingDetails.relationshipType === 'consult' &&\n !!interaction.callProcessingDetails.parentInteractionId &&\n interaction.callProcessingDetails.parentInteractionId !== interaction.interactionId\n );\n};\n\n/**\n * Checks if the current agent is a secondary EP-DN (Entry Point Dial Number) agent.\n * This is specifically for telephony consultations to external numbers/entry points.\n * @param task - The task object containing interaction details\n * @returns true if this is a secondary EP-DN agent in telephony consultation, false otherwise\n */\nexport const isSecondaryEpDnAgent = (interaction: Interaction): boolean => {\n if (!interaction) {\n return false;\n }\n\n return interaction.mediaType === 'telephony' && isSecondaryAgent(interaction);\n};\n"],"mappings":";;;;;;AAAA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMA,SAAS,GAAGA,CAACC,IAAW,EAAEC,OAAe,KAAc;EAClE,IAAI,CAACD,IAAI,CAACE,IAAI,EAAEC,WAAW,EAAEC,KAAK,EAAE;IAClC;IACA,OAAOJ,IAAI,CAACE,IAAI,CAACD,OAAO,KAAKA,OAAO;EACtC;EAEA,OAAOD,IAAI,CAACE,IAAI,CAACC,WAAW,CAACC,KAAK,KAAKH,OAAO;AAChD,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AALAI,OAAA,CAAAN,SAAA,GAAAA,SAAA;AAMO,MAAMO,8BAA8B,GAAGA,CAACN,IAAW,EAAEC,OAAe,KAAc;EACvF,IAAI,CAACD,IAAI,EAAEE,IAAI,EAAEC,WAAW,EAAEI,KAAK,EAAE;IACnC,OAAO,KAAK;EACd;EAEA,OAAOC,MAAM,CAACC,MAAM,CAACT,IAAI,CAACE,IAAI,CAACC,WAAW,CAACI,KAAK,CAAC,CAACG,IAAI,CACnDC,QAAQ,IACPA,QAAQ,IAAIA,QAAQ,CAACC,KAAK,KAAK,UAAU,IAAID,QAAQ,CAACE,YAAY,EAAEC,QAAQ,CAACb,OAAO,CACxF,CAAC;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AALAI,OAAA,CAAAC,8BAAA,GAAAA,8BAAA;AAMO,MAAMS,gCAAgC,GAAGA,CAACf,IAAW,EAAEC,OAAe,KAAc;EACzF,IAAI,CAACD,IAAI,EAAEE,IAAI,EAAEC,WAAW,EAAEU,YAAY,EAAE;IAC1C,OAAO,IAAI;EACb;EACA,MAAM;IAACX;EAAI,CAAC,GAAGF,IAAI;EAEnB,OACE,EAAEC,OAAO,IAAIC,IAAI,CAACC,WAAW,CAACU,YAAY,CAAC,IAC1CZ,OAAO,IAAIC,IAAI,CAACC,WAAW,CAACU,YAAY,IAAIX,IAAI,CAACC,WAAW,CAACU,YAAY,CAACZ,OAAO,CAAC,CAACe,OAAQ;AAEhG,CAAC;;AAED;AACA;AACA;AACA;AACA;AAJAX,OAAA,CAAAU,gCAAA,GAAAA,gCAAA;AAKO,MAAME,yBAAyB,GAAIf,IAAc,IAAc;EACpE,MAAMgB,aAAa,GAAGhB,IAAI,CAACC,WAAW,CAACI,KAAK,GAAGL,IAAI,EAAEiB,aAAa,CAAC;EACnE,MAAMC,sBAAsB,GAAG,IAAIC,GAAG,CAACH,aAAa,EAAEL,YAAY,CAAC;EACnE,MAAMA,YAAY,GAAGX,IAAI,CAACC,WAAW,CAACU,YAAY;EAElD,MAAMS,iBAAiB,GAAG,IAAID,GAAG,CAAC,CAAC;EACnC,IAAID,sBAAsB,CAACG,IAAI,GAAG,CAAC,EAAE;IACnCH,sBAAsB,CAACI,OAAO,CAAEC,aAAqB,IAAK;MACxD,MAAMC,WAAW,GAAGb,YAAY,GAAGY,aAAa,CAAC;MACjD,IACEC,WAAW,IACXA,WAAW,CAACC,KAAK,KAAK,UAAU,IAChCD,WAAW,CAACC,KAAK,KAAK,YAAY,IAClC,CAACD,WAAW,CAACV,OAAO,IACpBU,WAAW,CAACC,KAAK,KAAK,KAAK,EAC3B;QACAL,iBAAiB,CAACM,GAAG,CAACH,aAAa,CAAC;MACtC;IACF,CAAC,CAAC;EACJ;EAEA,OAAOH,iBAAiB,CAACC,IAAI,IAAI,CAAC;AACpC,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AALAlB,OAAA,CAAAY,yBAAA,GAAAA,yBAAA;AAMO,MAAMY,gBAAgB,GAAI1B,WAAwB,IAAc;EACrE,IAAI,CAACA,WAAW,CAAC2B,qBAAqB,EAAE;IACtC,OAAO,KAAK;EACd;EAEA,OACE3B,WAAW,CAAC2B,qBAAqB,CAACC,gBAAgB,KAAK,SAAS,IAChE,CAAC,CAAC5B,WAAW,CAAC2B,qBAAqB,CAACE,mBAAmB,IACvD7B,WAAW,CAAC2B,qBAAqB,CAACE,mBAAmB,KAAK7B,WAAW,CAACgB,aAAa;AAEvF,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AALAd,OAAA,CAAAwB,gBAAA,GAAAA,gBAAA;AAMO,MAAMI,oBAAoB,GAAI9B,WAAwB,IAAc;EACzE,IAAI,CAACA,WAAW,EAAE;IAChB,OAAO,KAAK;EACd;EAEA,OAAOA,WAAW,CAAC+B,SAAS,KAAK,WAAW,IAAIL,gBAAgB,CAAC1B,WAAW,CAAC;AAC/E,CAAC;AAACE,OAAA,CAAA4B,oBAAA,GAAAA,oBAAA"}
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.WRAPUP = exports.UNHOLD = exports.TRANSFER = exports.TASK_MESSAGE_TYPE = exports.TASK_MANAGER_FILE = exports.TASK_FILE = exports.TASK_API = exports.RESUME = exports.PAUSE = exports.METHODS = exports.HOLD = exports.END = exports.CONSULT_TRANSFER = exports.CONSULT_END = exports.CONSULT_ACCEPT = exports.CONSULT = void 0;
6
+ exports.WRAPUP = exports.UNHOLD = exports.TRANSFER = exports.TASK_MESSAGE_TYPE = exports.TASK_MANAGER_FILE = exports.TASK_FILE = exports.TASK_API = exports.RESUME = exports.PRESERVED_TASK_DATA_FIELDS = exports.PAUSE = exports.METHODS = exports.KEYS_TO_NOT_DELETE = exports.HOLD = exports.END = exports.CONSULT_TRANSFER = exports.CONSULT_END = exports.CONSULT_CONFERENCE = exports.CONSULT_ACCEPT = exports.CONSULT = exports.CONFERENCE_TRANSFER = exports.CONFERENCE_EXIT = void 0;
7
7
  /**
8
8
  * Constants for Task Service
9
9
  * @module @webex/contact-center/services/task/constants
@@ -23,9 +23,31 @@ const PAUSE = exports.PAUSE = '/record/pause';
23
23
  const RESUME = exports.RESUME = '/record/resume';
24
24
  const WRAPUP = exports.WRAPUP = '/wrapup';
25
25
  const END = exports.END = '/end';
26
+ const CONSULT_CONFERENCE = exports.CONSULT_CONFERENCE = '/consult/conference';
27
+ const CONFERENCE_EXIT = exports.CONFERENCE_EXIT = '/conference/exit';
28
+ const CONFERENCE_TRANSFER = exports.CONFERENCE_TRANSFER = '/conference/transfer';
26
29
  const TASK_MANAGER_FILE = exports.TASK_MANAGER_FILE = 'taskManager';
27
30
  const TASK_FILE = exports.TASK_FILE = 'task';
28
31
 
32
+ /**
33
+ * Task data field names that should be preserved during reconciliation
34
+ * These fields are retained even if not present in new data during updates
35
+ */
36
+ const PRESERVED_TASK_DATA_FIELDS = exports.PRESERVED_TASK_DATA_FIELDS = {
37
+ /** Indicates if the task is in consultation state */
38
+ IS_CONSULTED: 'isConsulted',
39
+ /** Indicates if wrap-up is required for this task */
40
+ WRAP_UP_REQUIRED: 'wrapUpRequired',
41
+ /** Indicates if a conference is currently in progress (2+ active agents) */
42
+ IS_CONFERENCE_IN_PROGRESS: 'isConferenceInProgress'
43
+ };
44
+
45
+ /**
46
+ * Array of task data field names that should not be deleted during reconciliation
47
+ * Used by reconcileData method to preserve important task state fields
48
+ */
49
+ const KEYS_TO_NOT_DELETE = exports.KEYS_TO_NOT_DELETE = Object.values(PRESERVED_TASK_DATA_FIELDS);
50
+
29
51
  // METHOD NAMES
30
52
  const METHODS = exports.METHODS = {
31
53
  // Task class methods
@@ -42,6 +64,9 @@ const METHODS = exports.METHODS = {
42
64
  END_CONSULT: 'endConsult',
43
65
  TRANSFER: 'transfer',
44
66
  CONSULT_TRANSFER: 'consultTransfer',
67
+ CONSULT_CONFERENCE: 'consultConference',
68
+ EXIT_CONFERENCE: 'exitConference',
69
+ TRANSFER_CONFERENCE: 'transferConference',
45
70
  UPDATE_TASK_DATA: 'updateTaskData',
46
71
  RECONCILE_DATA: 'reconcileData',
47
72
  // TaskManager class methods
@@ -1 +1 @@
1
- {"version":3,"names":["TASK_MESSAGE_TYPE","exports","TASK_API","HOLD","UNHOLD","CONSULT","CONSULT_ACCEPT","CONSULT_END","TRANSFER","CONSULT_TRANSFER","PAUSE","RESUME","WRAPUP","END","TASK_MANAGER_FILE","TASK_FILE","METHODS","ACCEPT","TOGGLE_MUTE","DECLINE","PAUSE_RECORDING","RESUME_RECORDING","END_CONSULT","UPDATE_TASK_DATA","RECONCILE_DATA","HANDLE_INCOMING_WEB_CALL","REGISTER_TASK_LISTENERS","REMOVE_TASK_FROM_COLLECTION","HANDLE_TASK_CLEANUP","GET_TASK","GET_ALL_TASKS","GET_TASK_MANAGER","SETUP_AUTO_WRAPUP_TIMER","CANCEL_AUTO_WRAPUP_TIMER"],"sources":["constants.ts"],"sourcesContent":["/**\n * Constants for Task Service\n * @module @webex/contact-center/services/task/constants\n * @ignore\n */\n\nexport const TASK_MESSAGE_TYPE = 'RoutingMessage';\nexport const TASK_API = '/v1/tasks/';\nexport const HOLD = '/hold';\nexport const UNHOLD = '/unhold';\nexport const CONSULT = '/consult';\nexport const CONSULT_ACCEPT = '/consult/accept';\nexport const CONSULT_END = '/consult/end';\nexport const TRANSFER = '/transfer';\nexport const CONSULT_TRANSFER = '/consult/transfer';\nexport const PAUSE = '/record/pause';\nexport const RESUME = '/record/resume';\nexport const WRAPUP = '/wrapup';\nexport const END = '/end';\nexport const TASK_MANAGER_FILE = 'taskManager';\nexport const TASK_FILE = 'task';\n\n// METHOD NAMES\nexport const METHODS = {\n // Task class methods\n ACCEPT: 'accept',\n TOGGLE_MUTE: 'toggleMute',\n DECLINE: 'decline',\n HOLD: 'hold',\n RESUME: 'resume',\n END: 'end',\n WRAPUP: 'wrapup',\n PAUSE_RECORDING: 'pauseRecording',\n RESUME_RECORDING: 'resumeRecording',\n CONSULT: 'consult',\n END_CONSULT: 'endConsult',\n TRANSFER: 'transfer',\n CONSULT_TRANSFER: 'consultTransfer',\n UPDATE_TASK_DATA: 'updateTaskData',\n RECONCILE_DATA: 'reconcileData',\n\n // TaskManager class methods\n HANDLE_INCOMING_WEB_CALL: 'handleIncomingWebCall',\n REGISTER_TASK_LISTENERS: 'registerTaskListeners',\n REMOVE_TASK_FROM_COLLECTION: 'removeTaskFromCollection',\n HANDLE_TASK_CLEANUP: 'handleTaskCleanup',\n GET_TASK: 'getTask',\n GET_ALL_TASKS: 'getAllTasks',\n GET_TASK_MANAGER: 'getTaskManager',\n SETUP_AUTO_WRAPUP_TIMER: 'setupAutoWrapupTimer',\n CANCEL_AUTO_WRAPUP_TIMER: 'cancelAutoWrapupTimer',\n};\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;;AAEO,MAAMA,iBAAiB,GAAAC,OAAA,CAAAD,iBAAA,GAAG,gBAAgB;AAC1C,MAAME,QAAQ,GAAAD,OAAA,CAAAC,QAAA,GAAG,YAAY;AAC7B,MAAMC,IAAI,GAAAF,OAAA,CAAAE,IAAA,GAAG,OAAO;AACpB,MAAMC,MAAM,GAAAH,OAAA,CAAAG,MAAA,GAAG,SAAS;AACxB,MAAMC,OAAO,GAAAJ,OAAA,CAAAI,OAAA,GAAG,UAAU;AAC1B,MAAMC,cAAc,GAAAL,OAAA,CAAAK,cAAA,GAAG,iBAAiB;AACxC,MAAMC,WAAW,GAAAN,OAAA,CAAAM,WAAA,GAAG,cAAc;AAClC,MAAMC,QAAQ,GAAAP,OAAA,CAAAO,QAAA,GAAG,WAAW;AAC5B,MAAMC,gBAAgB,GAAAR,OAAA,CAAAQ,gBAAA,GAAG,mBAAmB;AAC5C,MAAMC,KAAK,GAAAT,OAAA,CAAAS,KAAA,GAAG,eAAe;AAC7B,MAAMC,MAAM,GAAAV,OAAA,CAAAU,MAAA,GAAG,gBAAgB;AAC/B,MAAMC,MAAM,GAAAX,OAAA,CAAAW,MAAA,GAAG,SAAS;AACxB,MAAMC,GAAG,GAAAZ,OAAA,CAAAY,GAAA,GAAG,MAAM;AAClB,MAAMC,iBAAiB,GAAAb,OAAA,CAAAa,iBAAA,GAAG,aAAa;AACvC,MAAMC,SAAS,GAAAd,OAAA,CAAAc,SAAA,GAAG,MAAM;;AAE/B;AACO,MAAMC,OAAO,GAAAf,OAAA,CAAAe,OAAA,GAAG;EACrB;EACAC,MAAM,EAAE,QAAQ;EAChBC,WAAW,EAAE,YAAY;EACzBC,OAAO,EAAE,SAAS;EAClBhB,IAAI,EAAE,MAAM;EACZQ,MAAM,EAAE,QAAQ;EAChBE,GAAG,EAAE,KAAK;EACVD,MAAM,EAAE,QAAQ;EAChBQ,eAAe,EAAE,gBAAgB;EACjCC,gBAAgB,EAAE,iBAAiB;EACnChB,OAAO,EAAE,SAAS;EAClBiB,WAAW,EAAE,YAAY;EACzBd,QAAQ,EAAE,UAAU;EACpBC,gBAAgB,EAAE,iBAAiB;EACnCc,gBAAgB,EAAE,gBAAgB;EAClCC,cAAc,EAAE,eAAe;EAE/B;EACAC,wBAAwB,EAAE,uBAAuB;EACjDC,uBAAuB,EAAE,uBAAuB;EAChDC,2BAA2B,EAAE,0BAA0B;EACvDC,mBAAmB,EAAE,mBAAmB;EACxCC,QAAQ,EAAE,SAAS;EACnBC,aAAa,EAAE,aAAa;EAC5BC,gBAAgB,EAAE,gBAAgB;EAClCC,uBAAuB,EAAE,sBAAsB;EAC/CC,wBAAwB,EAAE;AAC5B,CAAC"}
1
+ {"version":3,"names":["TASK_MESSAGE_TYPE","exports","TASK_API","HOLD","UNHOLD","CONSULT","CONSULT_ACCEPT","CONSULT_END","TRANSFER","CONSULT_TRANSFER","PAUSE","RESUME","WRAPUP","END","CONSULT_CONFERENCE","CONFERENCE_EXIT","CONFERENCE_TRANSFER","TASK_MANAGER_FILE","TASK_FILE","PRESERVED_TASK_DATA_FIELDS","IS_CONSULTED","WRAP_UP_REQUIRED","IS_CONFERENCE_IN_PROGRESS","KEYS_TO_NOT_DELETE","Object","values","METHODS","ACCEPT","TOGGLE_MUTE","DECLINE","PAUSE_RECORDING","RESUME_RECORDING","END_CONSULT","EXIT_CONFERENCE","TRANSFER_CONFERENCE","UPDATE_TASK_DATA","RECONCILE_DATA","HANDLE_INCOMING_WEB_CALL","REGISTER_TASK_LISTENERS","REMOVE_TASK_FROM_COLLECTION","HANDLE_TASK_CLEANUP","GET_TASK","GET_ALL_TASKS","GET_TASK_MANAGER","SETUP_AUTO_WRAPUP_TIMER","CANCEL_AUTO_WRAPUP_TIMER"],"sources":["constants.ts"],"sourcesContent":["/**\n * Constants for Task Service\n * @module @webex/contact-center/services/task/constants\n * @ignore\n */\n\nexport const TASK_MESSAGE_TYPE = 'RoutingMessage';\nexport const TASK_API = '/v1/tasks/';\nexport const HOLD = '/hold';\nexport const UNHOLD = '/unhold';\nexport const CONSULT = '/consult';\nexport const CONSULT_ACCEPT = '/consult/accept';\nexport const CONSULT_END = '/consult/end';\nexport const TRANSFER = '/transfer';\nexport const CONSULT_TRANSFER = '/consult/transfer';\nexport const PAUSE = '/record/pause';\nexport const RESUME = '/record/resume';\nexport const WRAPUP = '/wrapup';\nexport const END = '/end';\nexport const CONSULT_CONFERENCE = '/consult/conference';\nexport const CONFERENCE_EXIT = '/conference/exit';\nexport const CONFERENCE_TRANSFER = '/conference/transfer';\nexport const TASK_MANAGER_FILE = 'taskManager';\nexport const TASK_FILE = 'task';\n\n/**\n * Task data field names that should be preserved during reconciliation\n * These fields are retained even if not present in new data during updates\n */\nexport const PRESERVED_TASK_DATA_FIELDS = {\n /** Indicates if the task is in consultation state */\n IS_CONSULTED: 'isConsulted',\n /** Indicates if wrap-up is required for this task */\n WRAP_UP_REQUIRED: 'wrapUpRequired',\n /** Indicates if a conference is currently in progress (2+ active agents) */\n IS_CONFERENCE_IN_PROGRESS: 'isConferenceInProgress',\n};\n\n/**\n * Array of task data field names that should not be deleted during reconciliation\n * Used by reconcileData method to preserve important task state fields\n */\nexport const KEYS_TO_NOT_DELETE: string[] = Object.values(PRESERVED_TASK_DATA_FIELDS);\n\n// METHOD NAMES\nexport const METHODS = {\n // Task class methods\n ACCEPT: 'accept',\n TOGGLE_MUTE: 'toggleMute',\n DECLINE: 'decline',\n HOLD: 'hold',\n RESUME: 'resume',\n END: 'end',\n WRAPUP: 'wrapup',\n PAUSE_RECORDING: 'pauseRecording',\n RESUME_RECORDING: 'resumeRecording',\n CONSULT: 'consult',\n END_CONSULT: 'endConsult',\n TRANSFER: 'transfer',\n CONSULT_TRANSFER: 'consultTransfer',\n CONSULT_CONFERENCE: 'consultConference',\n EXIT_CONFERENCE: 'exitConference',\n TRANSFER_CONFERENCE: 'transferConference',\n UPDATE_TASK_DATA: 'updateTaskData',\n RECONCILE_DATA: 'reconcileData',\n\n // TaskManager class methods\n HANDLE_INCOMING_WEB_CALL: 'handleIncomingWebCall',\n REGISTER_TASK_LISTENERS: 'registerTaskListeners',\n REMOVE_TASK_FROM_COLLECTION: 'removeTaskFromCollection',\n HANDLE_TASK_CLEANUP: 'handleTaskCleanup',\n GET_TASK: 'getTask',\n GET_ALL_TASKS: 'getAllTasks',\n GET_TASK_MANAGER: 'getTaskManager',\n SETUP_AUTO_WRAPUP_TIMER: 'setupAutoWrapupTimer',\n CANCEL_AUTO_WRAPUP_TIMER: 'cancelAutoWrapupTimer',\n};\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;;AAEO,MAAMA,iBAAiB,GAAAC,OAAA,CAAAD,iBAAA,GAAG,gBAAgB;AAC1C,MAAME,QAAQ,GAAAD,OAAA,CAAAC,QAAA,GAAG,YAAY;AAC7B,MAAMC,IAAI,GAAAF,OAAA,CAAAE,IAAA,GAAG,OAAO;AACpB,MAAMC,MAAM,GAAAH,OAAA,CAAAG,MAAA,GAAG,SAAS;AACxB,MAAMC,OAAO,GAAAJ,OAAA,CAAAI,OAAA,GAAG,UAAU;AAC1B,MAAMC,cAAc,GAAAL,OAAA,CAAAK,cAAA,GAAG,iBAAiB;AACxC,MAAMC,WAAW,GAAAN,OAAA,CAAAM,WAAA,GAAG,cAAc;AAClC,MAAMC,QAAQ,GAAAP,OAAA,CAAAO,QAAA,GAAG,WAAW;AAC5B,MAAMC,gBAAgB,GAAAR,OAAA,CAAAQ,gBAAA,GAAG,mBAAmB;AAC5C,MAAMC,KAAK,GAAAT,OAAA,CAAAS,KAAA,GAAG,eAAe;AAC7B,MAAMC,MAAM,GAAAV,OAAA,CAAAU,MAAA,GAAG,gBAAgB;AAC/B,MAAMC,MAAM,GAAAX,OAAA,CAAAW,MAAA,GAAG,SAAS;AACxB,MAAMC,GAAG,GAAAZ,OAAA,CAAAY,GAAA,GAAG,MAAM;AAClB,MAAMC,kBAAkB,GAAAb,OAAA,CAAAa,kBAAA,GAAG,qBAAqB;AAChD,MAAMC,eAAe,GAAAd,OAAA,CAAAc,eAAA,GAAG,kBAAkB;AAC1C,MAAMC,mBAAmB,GAAAf,OAAA,CAAAe,mBAAA,GAAG,sBAAsB;AAClD,MAAMC,iBAAiB,GAAAhB,OAAA,CAAAgB,iBAAA,GAAG,aAAa;AACvC,MAAMC,SAAS,GAAAjB,OAAA,CAAAiB,SAAA,GAAG,MAAM;;AAE/B;AACA;AACA;AACA;AACO,MAAMC,0BAA0B,GAAAlB,OAAA,CAAAkB,0BAAA,GAAG;EACxC;EACAC,YAAY,EAAE,aAAa;EAC3B;EACAC,gBAAgB,EAAE,gBAAgB;EAClC;EACAC,yBAAyB,EAAE;AAC7B,CAAC;;AAED;AACA;AACA;AACA;AACO,MAAMC,kBAA4B,GAAAtB,OAAA,CAAAsB,kBAAA,GAAGC,MAAM,CAACC,MAAM,CAACN,0BAA0B,CAAC;;AAErF;AACO,MAAMO,OAAO,GAAAzB,OAAA,CAAAyB,OAAA,GAAG;EACrB;EACAC,MAAM,EAAE,QAAQ;EAChBC,WAAW,EAAE,YAAY;EACzBC,OAAO,EAAE,SAAS;EAClB1B,IAAI,EAAE,MAAM;EACZQ,MAAM,EAAE,QAAQ;EAChBE,GAAG,EAAE,KAAK;EACVD,MAAM,EAAE,QAAQ;EAChBkB,eAAe,EAAE,gBAAgB;EACjCC,gBAAgB,EAAE,iBAAiB;EACnC1B,OAAO,EAAE,SAAS;EAClB2B,WAAW,EAAE,YAAY;EACzBxB,QAAQ,EAAE,UAAU;EACpBC,gBAAgB,EAAE,iBAAiB;EACnCK,kBAAkB,EAAE,mBAAmB;EACvCmB,eAAe,EAAE,gBAAgB;EACjCC,mBAAmB,EAAE,oBAAoB;EACzCC,gBAAgB,EAAE,gBAAgB;EAClCC,cAAc,EAAE,eAAe;EAE/B;EACAC,wBAAwB,EAAE,uBAAuB;EACjDC,uBAAuB,EAAE,uBAAuB;EAChDC,2BAA2B,EAAE,0BAA0B;EACvDC,mBAAmB,EAAE,mBAAmB;EACxCC,QAAQ,EAAE,SAAS;EACnBC,aAAa,EAAE,aAAa;EAC5BC,gBAAgB,EAAE,gBAAgB;EAClCC,uBAAuB,EAAE,sBAAsB;EAC/CC,wBAAwB,EAAE;AAC5B,CAAC"}