@chat21/chat21-ionic 3.4.31 → 3.4.32-rc2

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 (82) hide show
  1. package/CHANGELOG.md +133 -2
  2. package/angular.json +1 -0
  3. package/package.json +1 -1
  4. package/src/app/app.component.html +3 -1
  5. package/src/app/app.component.ts +72 -11
  6. package/src/app/chatlib/list-conversations-component/ion-list-conversations/ion-list-conversations.component.html +14 -2
  7. package/src/app/chatlib/list-conversations-component/ion-list-conversations/ion-list-conversations.component.scss +39 -2
  8. package/src/app/chatlib/list-conversations-component/list-conversations.module.ts +14 -0
  9. package/src/app/components/canned-response/canned-response.component.html +26 -23
  10. package/src/app/components/canned-response/canned-response.component.scss +0 -2
  11. package/src/app/components/canned-response/canned-response.component.ts +3 -1
  12. package/src/app/components/conversation-detail/message-text-area/message-text-area.component.html +24 -1
  13. package/src/app/components/conversation-detail/message-text-area/message-text-area.component.scss +30 -0
  14. package/src/app/components/conversation-detail/message-text-area/message-text-area.component.ts +29 -7
  15. package/src/app/components/conversation-info/info-content/info-content.component.ts +2 -2
  16. package/src/app/components/conversation-info/info-group/info-group.component.ts +23 -21
  17. package/src/app/components/conversations-list/header-conversations-list/header-conversations-list.component.html +1 -1
  18. package/src/app/components/conversations-list/header-conversations-list/header-conversations-list.component.ts +5 -1
  19. package/src/app/components/navbar/navbar.component.html +35 -9
  20. package/src/app/components/navbar/navbar.component.scss +64 -0
  21. package/src/app/components/navbar/navbar.component.ts +100 -42
  22. package/src/app/components/project-item/project-item.component.ts +79 -52
  23. package/src/app/components/sidebar/sidebar.component.html +65 -45
  24. package/src/app/components/sidebar/sidebar.component.ts +110 -117
  25. package/src/app/components/sidebar-user-details/sidebar-user-details.component.html +3 -3
  26. package/src/app/components/sidebar-user-details/sidebar-user-details.component.ts +15 -22
  27. package/src/app/modals/create-ticket/create-ticket.page.ts +4 -2
  28. package/src/app/pages/conversation-detail/conversation-detail.page.html +7 -3
  29. package/src/app/pages/conversation-detail/conversation-detail.page.ts +89 -5
  30. package/src/app/pages/conversations-list/conversations-list.module.ts +3 -5
  31. package/src/app/pages/conversations-list/conversations-list.page.html +2 -0
  32. package/src/app/pages/conversations-list/conversations-list.page.ts +51 -11
  33. package/src/app/pages/unassigned-conversations/unassigned-conversations.module.ts +16 -4
  34. package/src/app/pages/unassigned-conversations/unassigned-conversations.page.html +43 -17
  35. package/src/app/pages/unassigned-conversations/unassigned-conversations.page.scss +25 -1
  36. package/src/app/pages/unassigned-conversations/unassigned-conversations.page.ts +114 -9
  37. package/src/app/services/global-settings/global-settings.service.ts +11 -3
  38. package/src/app/services/nav-proxy.service.ts +0 -1
  39. package/src/app/services/project_users/project-users.service.spec.ts +16 -0
  40. package/src/app/services/project_users/project-users.service.ts +63 -0
  41. package/src/app/services/projects/project.service.ts +2 -1
  42. package/src/app/services/tiledesk/tiledesk.service.ts +21 -16
  43. package/src/app/services/triggerEvents/triggerEvents.ts +28 -0
  44. package/src/app/services/websocket/websocket-js.ts +59 -534
  45. package/src/app/services/websocket/websocket-js_old.ts +578 -0
  46. package/src/app/services/websocket/websocket.service.ts +67 -14
  47. package/src/app/services/websocket/websocket.worker.ts +242 -0
  48. package/src/app/shared/shared.module.ts +11 -2
  49. package/src/app/utils/globals.ts +2 -0
  50. package/src/app/utils/permissions.constants.ts +138 -0
  51. package/src/app/utils/project-utils.ts +2 -2
  52. package/src/app/utils/utils.ts +18 -1
  53. package/src/assets/i18n/ar.json +11 -1
  54. package/src/assets/i18n/az.json +11 -1
  55. package/src/assets/i18n/de.json +11 -1
  56. package/src/assets/i18n/en.json +11 -1
  57. package/src/assets/i18n/es.json +11 -1
  58. package/src/assets/i18n/fr.json +11 -1
  59. package/src/assets/i18n/it.json +13 -3
  60. package/src/assets/i18n/kk.json +11 -1
  61. package/src/assets/i18n/pt.json +11 -1
  62. package/src/assets/i18n/ru.json +11 -1
  63. package/src/assets/i18n/sr.json +11 -1
  64. package/src/assets/i18n/sv.json +11 -1
  65. package/src/assets/i18n/tr.json +11 -1
  66. package/src/assets/i18n/uk.json +11 -1
  67. package/src/assets/i18n/uz.json +12 -1
  68. package/src/assets/js/agentDesktop-sdk.js +55 -0
  69. package/src/assets/js/chat21client.js +36 -0
  70. package/src/assets/js/mqtt-keepalive-worker.js +53 -0
  71. package/src/assets/test.html +5 -2
  72. package/src/chat-config-template.json +1 -0
  73. package/src/chat-config.json +1 -0
  74. package/src/chat21-core/models/projectUsers.ts +19 -0
  75. package/src/chat21-core/models/project_user.ts +2 -1
  76. package/src/chat21-core/providers/firebase/firebase-conversation-handler.ts +1 -1
  77. package/src/chat21-core/providers/mqtt/mqtt-conversation-handler.ts +1 -1
  78. package/src/chat21-core/providers/tiledesk/tiledesk-auth.service.ts +3 -0
  79. package/src/chat21-core/utils/constants.ts +5 -0
  80. package/src/chat21-core/utils/convertRequestToConversation.ts +1 -1
  81. package/src/chat21-core/utils/utils.ts +53 -3
  82. package/src/variables.scss +3 -0
@@ -225,6 +225,10 @@
225
225
  "admin": "Administrator",
226
226
  "agent": "Agent",
227
227
  "Conversations": "Gespräche",
228
+ "Monitor": "Monitor",
229
+ "Flows": "Flows",
230
+ "Knowledgebases": "Wissensdatenbanken",
231
+ "Whatsappbroadcasts": "WhatsApp-Broadcasts",
228
232
  "Apps": "Anwendungen",
229
233
  "Analytics": "Analytik",
230
234
  "Activities": "Aktivitäten",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Nachricht auch per E-Mail gesendet 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji nicht erlaubt",
309
- "DOMAIN_NOT_ALLOWED": "Die URL enthält eine nicht erlaubte Domain"
313
+ "DOMAIN_NOT_ALLOWED": "Die URL enthält eine nicht erlaubte Domain",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Ticket öffnen",
316
+ "DESCRIPTION": "Bestätigen Sie, dass Sie ein Ticket für dieses Gespräch eröffnen möchten?",
317
+ "CONFIRM": "Bestätigen",
318
+ "CLOSE": "Schließen"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Administrator",
226
226
  "agent": "Agent",
227
227
  "Conversations": "Conversations",
228
+ "Monitor":"Monitor",
229
+ "Flows": "Flows",
230
+ "Knowledgebases": "Knowledge Bases",
231
+ "Whatsappbroadcasts": "WhatsApp Broadcasts",
228
232
  "Apps": "Apps",
229
233
  "Analytics": "Analytics",
230
234
  "Activities": "Activities",
@@ -314,5 +318,11 @@
314
318
  "HOW_CAN_I_HELP_YOU":"How can i help you?"
315
319
  },
316
320
  "EMOJI_NOT_ELLOWED":"Emoji not allowed",
317
- "DOMAIN_NOT_ALLOWED":"URL contains a non-allowed domain"
321
+ "DOMAIN_NOT_ALLOWED":"URL contains a non-allowed domain",
322
+ "TICKET": {
323
+ "OPEN_TICKET": "Open Ticket",
324
+ "DESCRIPTION": "Do you confirm you want to open a ticket for this conversation?",
325
+ "CONFIRM": "Confirm",
326
+ "CLOSE": "Close"
327
+ }
318
328
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Administrador",
226
226
  "agent": "Agente",
227
227
  "Conversations": "Conversaciones",
228
+ "Monitor": "Monitor",
229
+ "Flows": "Flujos",
230
+ "Knowledgebases": "Bases de Conocimiento",
231
+ "Whatsappbroadcasts": "Difusiones de WhatsApp",
228
232
  "Apps":"Aplicaciones",
229
233
  "Analytics":"Analíticas",
230
234
  "Activities": "Actividades",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Mensaje también enviado por correo electrónico 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji no permitido",
309
- "DOMAIN_NOT_ALLOWED": "La URL contiene un dominio no permitido"
313
+ "DOMAIN_NOT_ALLOWED": "La URL contiene un dominio no permitido",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Abrir Ticket",
316
+ "DESCRIPTION": "¿Confirmas que deseas abrir un ticket para esta conversación?",
317
+ "CONFIRM": "Confirmar",
318
+ "CLOSE": "Cerrar"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Administrateur",
226
226
  "agent": "Agent",
227
227
  "Conversations": "Conversations",
228
+ "Monitor": "Moniteur",
229
+ "Flows": "Flux",
230
+ "Knowledgebases": "Bases de Connaissances",
231
+ "Whatsappbroadcasts": "Diffusions WhatsApp",
228
232
  "Apps":"Applications",
229
233
  "Analytics":"Analytique",
230
234
  "Activities": "Activités",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Message également envoyé par mail 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji non autorisé",
309
- "DOMAIN_NOT_ALLOWED": "L'URL contient un domaine non autorisé"
313
+ "DOMAIN_NOT_ALLOWED": "L'URL contient un domaine non autorisé",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Ouvrir un Ticket",
316
+ "DESCRIPTION": "Confirmez-vous vouloir ouvrir un ticket pour cette conversation ?",
317
+ "CONFIRM": "Confirmer",
318
+ "CLOSE": "Fermer"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Amministratore",
226
226
  "agent": "Agente",
227
227
  "Conversations": "Conversazioni",
228
+ "Monitor": "Monitor",
229
+ "Flows": "Flussi",
230
+ "Knowledgebases": "Basi di Conoscenza",
231
+ "Whatsappbroadcasts": "Trasmissioni WhatsApp",
228
232
  "Apps":"App",
229
233
  "Analytics":"Analitica",
230
234
  "Activities": "Attività",
@@ -312,7 +316,13 @@
312
316
  "NO_SUGGESTIONS_PRESENT":"Nessun suggerimento trovato",
313
317
  "INSERT_PROMPT_HERE":"Inserisci un prompt qui",
314
318
  "HOW_CAN_I_HELP_YOU":"Come posso aiutarti?"
315
- },
316
- "EMOJI_NOT_ELLOWED": "Emoji non consentite",
317
- "DOMAIN_NOT_ALLOWED": "L'URL contiene un dominio non consentito"
319
+ },
320
+ "EMOJI_NOT_ELLOWED": "Emoji non consentite",
321
+ "DOMAIN_NOT_ALLOWED": "L'URL contiene un dominio non consentito",
322
+ "TICKET": {
323
+ "OPEN_TICKET": "Apri Ticket",
324
+ "DESCRIPTION": "Confermi di voler aprire un ticket per questa conversazione?",
325
+ "CONFIRM": "Conferma",
326
+ "CLOSE": "Chiudi"
327
+ }
318
328
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Әкімші",
226
226
  "agent": "Агент",
227
227
  "Conversations": "Әңгімелер",
228
+ "Monitor": "Монитор",
229
+ "Flows": "Ағындар",
230
+ "Knowledgebases": "Білім базалары",
231
+ "Whatsappbroadcasts": "WhatsApp хабарламалары",
228
232
  "Apps": "Қолданбалар",
229
233
  "Analytics": "Аналитика",
230
234
  "Activities": "Іс-шаралар",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Хабарлама электрондық пошта арқылы да жіберілді 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Эмодзи рұқсат етілмеген",
309
- "DOMAIN_NOT_ALLOWED": "URL рұқсат етілмеген доменді қамтиды"
313
+ "DOMAIN_NOT_ALLOWED": "URL рұқсат етілмеген доменді қамтиды",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Тапсырма ашу",
316
+ "DESCRIPTION": "Осы әңгіме үшін тапсырма ашқыңыз келетінін растайсыз ба?",
317
+ "CONFIRM": "Растау",
318
+ "CLOSE": "Жабу"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Administrador",
226
226
  "agent": "Agente",
227
227
  "Conversations": "Conversas",
228
+ "Monitor": "Monitor",
229
+ "Flows": "Fluxos",
230
+ "Knowledgebases": "Bases de Conhecimento",
231
+ "Whatsappbroadcasts": "Transmissões do WhatsApp",
228
232
  "Apps":"Aplicativos",
229
233
  "Analytics":"Análise",
230
234
  "Activities": "Atividades",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Mensagem também enviada por e-mail 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji não permitido",
309
- "DOMAIN_NOT_ALLOWED": "O URL contém um domínio não permitido"
313
+ "DOMAIN_NOT_ALLOWED": "O URL contém um domínio não permitido",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Abrir Ticket",
316
+ "DESCRIPTION": "Confirma que deseja abrir um ticket para esta conversa?",
317
+ "CONFIRM": "Confirmar",
318
+ "CLOSE": "Fechar"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Администратор",
226
226
  "agent": "Агент",
227
227
  "Conversations": "Разговоры",
228
+ "Monitor": "Монитор",
229
+ "Flows": "Потоки",
230
+ "Knowledgebases": "Базы знаний",
231
+ "Whatsappbroadcasts": "WhatsApp-рассылки",
228
232
  "Apps":"Приложения",
229
233
  "Analytics":"Аналитика",
230
234
  "Activities": "Виды деятельности",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Сообщение также отправлено по электронной почте 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Эмодзи не разрешены",
309
- "DOMAIN_NOT_ALLOWED": "URL содержит недопустимый домен"
313
+ "DOMAIN_NOT_ALLOWED": "URL содержит недопустимый домен",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Открыть тикет",
316
+ "DESCRIPTION": "Вы подтверждаете, что хотите открыть тикет для этого разговора?",
317
+ "CONFIRM": "Подтвердить",
318
+ "CLOSE": "Закрыть"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Aдминистратор",
226
226
  "agent": "Агент",
227
227
  "Conversations": "Разговори",
228
+ "Monitor": "Монитор",
229
+ "Flows": "Токови",
230
+ "Knowledgebases": "Baze znanja",
231
+ "Whatsappbroadcasts": "WhatsApp emitovanja",
228
232
  "Apps":"Аппс",
229
233
  "Analytics":"Аналитика",
230
234
  "Activities": "Активности",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Порука је такође послата е-поштом 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emodžiji nisu dozvoljeni",
309
- "DOMAIN_NOT_ALLOWED": "URL sadrži nedozvoljenu domenu"
313
+ "DOMAIN_NOT_ALLOWED": "URL sadrži nedozvoljenu domenu",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Otvori tiket",
316
+ "DESCRIPTION": "Da li potvrđujete da želite da otvorite tiket za ovaj razgovor?",
317
+ "CONFIRM": "Potvrdi",
318
+ "CLOSE": "Zatvori"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Administratör",
226
226
  "agent": "Ombud",
227
227
  "Conversations": "Samtal",
228
+ "Monitor": "Monitor",
229
+ "Flows": "Flöden",
230
+ "Knowledgebases": "Kunskapsbaser",
231
+ "Whatsappbroadcasts": "WhatsApp-sändningar",
228
232
  "Apps": "Appar",
229
233
  "Analytics": "Analytics",
230
234
  "Activities": "Aktiviteter",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Meddelande skickas även via mail 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji är inte tillåtna",
309
- "DOMAIN_NOT_ALLOWED": "URL:en innehåller en otillåten domän"
313
+ "DOMAIN_NOT_ALLOWED": "URL:en innehåller en otillåten domän",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Öppna Ärende",
316
+ "DESCRIPTION": "Bekräftar du att du vill öppna ett ärende för den här konversationen?",
317
+ "CONFIRM": "Bekräfta",
318
+ "CLOSE": "Stäng"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Yönetici",
226
226
  "agent": "Ajan",
227
227
  "Conversations": "Konuşmalar",
228
+ "Monitor": "Monitör",
229
+ "Flows": "Akışlar",
230
+ "Knowledgebases": "Bilgi Tabanları",
231
+ "Whatsappbroadcasts": "WhatsApp Yayınları",
228
232
  "Apps":"Uygulamalar",
229
233
  "Analytics":"Analitik",
230
234
  "Activities": "Faaliyetler",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Mesaj ayrıca e-posta ile gönderilir 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji'ye izin verilmiyor",
309
- "DOMAIN_NOT_ALLOWED": "URL izin verilmeyen bir alan adı içeriyor"
313
+ "DOMAIN_NOT_ALLOWED": "URL izin verilmeyen bir alan adı içeriyor",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Bilet Aç",
316
+ "DESCRIPTION": "Bu görüşme için bir bilet açmak istediğinizi onaylıyor musunuz?",
317
+ "CONFIRM": "Onayla",
318
+ "CLOSE": "Kapat"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Адміністратор",
226
226
  "agent": "Агент",
227
227
  "Conversations": "Бесіди",
228
+ "Monitor": "Монітор",
229
+ "Flows": "Потоки",
230
+ "Knowledgebases": "Бази знань",
231
+ "Whatsappbroadcasts": "WhatsApp-розсилки",
228
232
  "Apps": "Програми",
229
233
  "Analytics": "Аналітика",
230
234
  "Activities": "Діяльність",
@@ -306,5 +310,11 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Повідомлення також надіслано електронною поштою 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Емодзі не дозволені",
309
- "DOMAIN_NOT_ALLOWED": "URL містить недозволений домен"
313
+ "DOMAIN_NOT_ALLOWED": "URL містить недозволений домен",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Відкрити тікет",
316
+ "DESCRIPTION": "Підтверджуєте, що хочете відкрити тікет для цієї розмови?",
317
+ "CONFIRM": "Підтвердити",
318
+ "CLOSE": "Закрити"
319
+ }
310
320
  }
@@ -225,6 +225,10 @@
225
225
  "admin": "Administrator",
226
226
  "agent": "Agent",
227
227
  "Conversations": "Suhbatlar",
228
+ "Monitor": "Monitor",
229
+ "Flows": "Oqimlar",
230
+ "Knowledgebases": "Bilim bazalari",
231
+ "Whatsappbroadcasts": "WhatsApp efirlarini yuborish",
228
232
  "Apps": "Ilovalar",
229
233
  "Analytics": "Analitika",
230
234
  "Activities": "Faoliyatlar",
@@ -306,5 +310,12 @@
306
310
  "SEND_EMAIL_SUCCESS_OFFLINE_MESSAGE":"Xabar elektron pochta orqali ham yuborildi 📩"
307
311
  },
308
312
  "EMOJI_NOT_ELLOWED": "Emoji'ga ruxsat berilmagan",
309
- "DOMAIN_NOT_ALLOWED": "URL ruxsat etilmagan domenni o'z ichiga oladi"
313
+ "DOMAIN_NOT_ALLOWED": "URL ruxsat etilmagan domenni o'z ichiga oladi",
314
+ "TICKET": {
315
+ "OPEN_TICKET": "Chiptani ochish",
316
+ "DESCRIPTION": "Ushbu suhbat uchun chipta ochmoqchi ekanligingizni tasdiqlaysizmi?",
317
+ "CONFIRM": "Tasdiqlash",
318
+ "CLOSE": "Yopish"
319
+ }
320
+
310
321
  }
@@ -0,0 +1,55 @@
1
+ function loadAgentDesktopScript() {
2
+ if (document.getElementById('agentdesktop-sdk')) {
3
+ return;
4
+ }
5
+
6
+ const script = document.createElement('script');
7
+ script.id = 'agentdesktop-sdk';
8
+ script.type = 'text/javascript';
9
+ script.src = 'https://devcti.aruba.it/AD/widget/agentdesktop_widget.js';
10
+ script.async = true;
11
+
12
+ script.onload = () => {
13
+ console.log('AgentDesktop SDK caricato');
14
+ window.agentDesktopLoaded = true;
15
+ };
16
+
17
+ script.onerror = (error) => {
18
+ console.error('Errore nel caricamento AgentDesktop SDK', error);
19
+ };
20
+
21
+
22
+
23
+
24
+
25
+
26
+ if (document.body) {
27
+ document.body.appendChild(script);
28
+ } else {
29
+ window.addEventListener('DOMContentLoaded', function() {
30
+ document.body.appendChild(script);
31
+ });
32
+ }
33
+ }
34
+
35
+
36
+ function openTicketOnHDA(requestId){
37
+ console.log('openTicketOnHDA called with requestId:', requestId);
38
+ const message = { companyID: "1", sourceID: "CHAT", tiledeskID: requestId, target: "HDA", origin: "Tiledesk" }
39
+ if(window && window.parent){
40
+ window.parent.postMessage(message, 'https://devhda2bo.aruba.it/HDAPortal/');
41
+ window.postMessage(message, 'https://devhda2bo.aruba.it/HDAPortal/');
42
+ console.log('Message posted to parent window and current window');
43
+ }
44
+
45
+ if(window['AGENTDESKTOP']){
46
+ console.log('AGENTDESKTOP exist. Sending message . . .');
47
+ window['AGENTDESKTOP']['WIDGET'].sendDataToWidget('PAT', JSON.stringify(message)); // invia il messaggio ad HDA
48
+ AGENTDESKTOP.TAB.GoTo('PAT'); // dà il focus ad HDA
49
+ console.log('Message sent to AGENTDESKTOP widget');
50
+ }
51
+
52
+
53
+ }
54
+
55
+ loadAgentDesktopScript();
@@ -1010,6 +1010,7 @@ class Chat21Client {
1010
1010
  this.start( () => {
1011
1011
  // callback();
1012
1012
  });
1013
+ this.initKeepAliveWorker()
1013
1014
  }
1014
1015
  this.client.publish(
1015
1016
  this.presence_topic,
@@ -1027,6 +1028,36 @@ class Chat21Client {
1027
1028
  console.error("Chat client error event", error);
1028
1029
  }
1029
1030
  );
1031
+
1032
+
1033
+ }
1034
+
1035
+
1036
+ initKeepAliveWorker(){
1037
+ this.worker= new Worker('assets/js/mqtt-keepalive-worker.js');
1038
+ if (this.log) {
1039
+ console.log("Chat21Client - initKeepAliveWorker() - worker created", this.worker);
1040
+ }
1041
+ // this.worker.postMessage({
1042
+ // action: 'start',
1043
+ // user_id: this.user_id,
1044
+ // client_id: this.client_id,
1045
+ // jwt: this.jwt,
1046
+ // endpoint: this.endpoint
1047
+ // });
1048
+ this.worker.onmessage = (event) => {
1049
+ if (event.data.action === 'ping') {
1050
+ if (this.client && this.client.connected) {
1051
+ // questo non causa refresh di niente
1052
+ this.client.publish(
1053
+ `apps/tilechat/users/${this.user_id}/keepalive`,
1054
+ JSON.stringify({ ts: Date.now() })
1055
+ );
1056
+ }
1057
+ }
1058
+ };
1059
+
1060
+ this.worker.postMessage({ action: 'ping' });
1030
1061
  }
1031
1062
 
1032
1063
  onDisconnect(callback){
@@ -1041,6 +1072,11 @@ class Chat21Client {
1041
1072
  this.connected = false
1042
1073
  if (this.log) {console.log("Chat client close event");}
1043
1074
  callback('close')
1075
+ if (this.worker) {
1076
+ this.worker.postMessage({ action: 'stop' });
1077
+ this.worker.terminate();
1078
+ this.worker = null;
1079
+ }
1044
1080
  }
1045
1081
  );
1046
1082
  this.client.on('offline',
@@ -0,0 +1,53 @@
1
+ importScripts('https://unpkg.com/mqtt/dist/mqtt.min.js');
2
+
3
+ let client = null;
4
+ let user_id = null;
5
+ let pingIntervalId = null;
6
+ self.onmessage = function(event) {
7
+ const data = event.data;
8
+
9
+ // console.log('MQTT KEEPALIVE WORKER - received message ', data);
10
+ if (data.action === 'start') {
11
+ user_id = data.user_id;
12
+ const endpoint = data.endpoint;
13
+ const jwt = data.jwt;
14
+
15
+ const options = {
16
+ keepalive: 3, // basso keepalive
17
+ reconnectPeriod: 1000,
18
+ clientId: data.client_id,
19
+ username: 'JWT',
20
+ password: jwt,
21
+ rejectUnauthorized: false
22
+ };
23
+
24
+ client = mqtt.connect(endpoint, options);
25
+
26
+ client.on('connect', () => {
27
+ // start ping
28
+ pingIntervalId = setInterval(() => {
29
+ if (client && client.connected) {
30
+ // console.log('MQTT KEEPALIVE WORKER - sending keepalive ping for user ', user_id);
31
+ client.publish(`apps/tilechat/users/${user_id}/keepalive`,
32
+ JSON.stringify({ ts: new Date().getTime() }));
33
+ }
34
+ }, 3000);
35
+ });
36
+
37
+ client.on('close', () => {
38
+ clearInterval(pingIntervalId);
39
+ pingIntervalId = null;
40
+ });
41
+ }else if (data.action === 'ping') {
42
+ if (self.timer) return;
43
+
44
+ self.timer = setInterval(() => {
45
+ postMessage({ action: 'ping' });
46
+ }, 3000);
47
+ }
48
+
49
+ if (data.action === 'stop') {
50
+ if (pingIntervalId) clearInterval(pingIntervalId);
51
+ if (client) client.end();
52
+ }
53
+ };
@@ -4,7 +4,7 @@
4
4
  <head>
5
5
  <meta charset="utf-8">
6
6
  <meta name="viewport" content="width=device-width">
7
- <title>replit</title>
7
+ <title>Iframe test</title>
8
8
  </head>
9
9
 
10
10
  <body style="height: 100%;">
@@ -20,7 +20,10 @@
20
20
  </div>
21
21
 
22
22
  <iframe id="myIFrame" frameBorder="0" width="100%" style="display: flex; height: 95vh" onload="onLoad()"
23
- src="http://localhost:8080/#/conversation-detail?tiledesk_supportMode=true&jwt=JWT eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJfaWQiOiI1ZmQzNGU0MjQ5NjEwZTAwMzQ5ODUwNzgiLCJlbWFpbCI6ImdhYnJpZWxlLnBhbmljb0Bmcm9udGllcmUyMS5pdCIsImZpcnN0bmFtZSI6IkdhYnJpZWxlMiIsImxhc3RuYW1lIjoiUGFuaWNvIC1wcmUiLCJlbWFpbHZlcmlmaWVkIjp0cnVlLCJpYXQiOjE2OTgzMzYyMTMsImF1ZCI6Imh0dHBzOi8vdGlsZWRlc2suY29tIiwiaXNzIjoiaHR0cHM6Ly90aWxlZGVzay5jb20iLCJzdWIiOiJ1c2VyIiwianRpIjoiNjAzZGY3NDQtZWY0OS00Mjg2LWJlMWQtYWM5OGYyYTNkMTJiIn0.bof5QPQP262yCQfpeSjqyoYPkSCttg5NQFkcV8d634xzeq7wJBdhtiO7IJY6hS81a1YyXrAsxlK7RiNS-UZdYiTXR81UXurQd1fnE9jtaggB82tyNL8vmiZEOs6xh4TqO3-kkBzRxQIp74bY53fk_mu5RmNbAjIgUWEufaNDiv8"></iframe>
23
+ src="http://localhost:8080/#/conversation-detail?tiledesk_supportMode=true&jwt=JWT eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJfaWQiOiI2NWM1ZjM1OTlmYWYyZDA0Y2Q3ZGE1MjgiLCJlbWFpbCI6Imdpb3Zhbm5pQHRpbGVkZXNrLmNvbSIsImZpcnN0bmFtZSI6Ikdpb3Zhbm5pIiwibGFzdG5hbWUiOiJUcm9pc2kgQWRtIiwiZW1haWx2ZXJpZmllZCI6dHJ1ZSwiaWF0IjoxNzY0NjAyMTQxLCJhdWQiOiJodHRwczovL3RpbGVkZXNrLmNvbSIsImlzcyI6Imh0dHBzOi8vdGlsZWRlc2suY29tIiwic3ViIjoidXNlciIsImp0aSI6IjIwNzZjYmMxLTI0NzgtNGU4MC1iZjFmLTBiZTA3MTQ3MjQ3MSJ9.R60xZC5M2n-hc-mRIMpA9KaUFxnBQHA_FrLyL9cCiqxeCitfCfbfA3_EKXWbWg3rDztmOR7SVjEO8Gyw_hdhKyjpx-OpaDAILw0dSsuBHB0R4h0F4fN2J_JJ60UIItXxoAq1AI9ML2cRGoRNAtfl6PMjpHXdbpdBAGcBYoGqGv3xWPlM7wOdIhGasnWT932DiscF3I_ltcFkS3naebQQfsgztlbU-UF7EcFjDc-mMzMxqnE1MYKzyqUAR9J9zFmqiUlCsl_J0TNhAjqUw-0GHXpzLQJN9dutVyH4y_MZxt_p6qAIzNo9LpMi-a5bfvQvpJjSuc9POvmlmWFAmwoQGw"
24
+ allow="autoplay; fullscreen; geolocation; microphone; camera; display-capture; encrypted-media; clipboard-read; clipboard-write;"
25
+ loading="eager" importance="high">
26
+ </iframe>
24
27
 
25
28
  <script>
26
29
  // window.addEventListener('message', event => {
@@ -37,6 +37,7 @@
37
37
  "wsUrlRel": "${WS_URL_RELATIVE}",
38
38
  "storage_prefix": "${CHAT_STORAGE_PREFIX}",
39
39
  "emailSection": "${EMAIL_SECTION}",
40
+ "ticketSection": "${TICKET_SECTION}",
40
41
  "whatsappTemplatesSection":"${WHATSAPP_TEMPLATES_SECTION}",
41
42
  "googleMapsApiKey":"${GOOGLE_MAPS_APIKEY}"
42
43
  }
@@ -37,6 +37,7 @@
37
37
  "writeToButton": false,
38
38
  "archivedButton": false,
39
39
  "emailSection": true,
40
+ "ticketSection": false,
40
41
  "whatsappTemplatesSection":true,
41
42
  "googleMapsApiKey":"CHANGEIT"
42
43
  }
@@ -0,0 +1,19 @@
1
+ export interface ProjectUser {
2
+ _id?: string;
3
+ updatedAt?: any;
4
+ createdAt?: any;
5
+ id_project?: string;
6
+ user_available?: boolean;
7
+ role?: string;
8
+ createdBy?: string;
9
+ is_group_member?: boolean;
10
+ // id_user?: string;
11
+ isAuthenticated?: boolean;
12
+ isBusy?: boolean;
13
+ status?: string;
14
+ id_user?: any;
15
+ rolePermissions?: string[];
16
+ profileStatus?: string;
17
+ presence?: { [key: string]: string}
18
+ __v?: any;
19
+ }
@@ -3,7 +3,7 @@ export interface ProjectUser {
3
3
  createdAt?: string;
4
4
  createdBy?: string;
5
5
  id?:string;
6
- id_project?: string;
6
+ id_project?: any;
7
7
  id_user?: any;
8
8
  isAuthenticated?: boolean;
9
9
  isBusy?: boolean;
@@ -22,4 +22,5 @@ export interface ProjectUser {
22
22
  is_group_member?: boolean;
23
23
  __v?: any;
24
24
  _id?: string;
25
+ teammateStatus?: any;
25
26
  }
@@ -387,7 +387,7 @@ export class FirebaseConversationHandler extends ConversationHandlerService {
387
387
  } else {
388
388
 
389
389
  if (message.attributes.messagelabel.parameters.firstname) {
390
- // other user has been added to the group (and he has a firstname)
390
+ // other user has been added to the group (and he has a fullname)
391
391
  subject = message.attributes.messagelabel.parameters.firstname;
392
392
  verb = INFO_SUPPORT_USER_ADDED_VERB;
393
393
  complement = INFO_SUPPORT_USER_ADDED_COMPLEMENT;
@@ -365,7 +365,7 @@ export class MQTTConversationHandler extends ConversationHandlerService {
365
365
  complement = INFO_SUPPORT_USER_ADDED_COMPLEMENT;
366
366
  } else {
367
367
  if (message.attributes.messagelabel.parameters.firstname) {
368
- // other user has been added to the group (and he has a firstname)
368
+ // other user has been added to the group (and he has a fullname)
369
369
  subject = message.attributes.messagelabel.parameters.firstname;
370
370
  verb = INFO_SUPPORT_USER_ADDED_VERB;
371
371
  complement = INFO_SUPPORT_USER_ADDED_COMPLEMENT;
@@ -121,6 +121,7 @@ export class TiledeskAuthService {
121
121
  this.http.post(this.URL_TILEDESK_SIGNIN_WITH_CUSTOM_TOKEN, null, requestOptions).subscribe((data) => {
122
122
  if (data['success'] && data['token']) {
123
123
  that.tiledeskToken = data['token'];
124
+ data['user'].token = tiledeskToken; // mantengo il token custom nell'oggetto user
124
125
  that.createCompleteUser(data['user']);
125
126
  this.checkAndSetInStorageTiledeskToken(that.tiledeskToken)
126
127
  this.BS_IsONLINE.next(true)
@@ -177,6 +178,8 @@ export class TiledeskAuthService {
177
178
  this.currentUser = member;
178
179
  this.logger.log('[TILEDESK-AUTH] - createCompleteUser member ', member);
179
180
  this.appStorage.setItem('currentUser', JSON.stringify(this.currentUser));
181
+ const { iat, aud, iss, jti, ...cleanUser } = user; //destructuring and rest user object
182
+ localStorage.setItem('user', JSON.stringify(cleanUser));
180
183
 
181
184
  } catch (err) {
182
185
  this.logger.error('[TILEDESK-AUTH]- createCompleteUser ERR ', err)
@@ -148,5 +148,10 @@ export enum PLAN_NAME {
148
148
 
149
149
  export const tranlatedLanguage = ['it', 'en', 'de', 'es', 'pt', 'fr', 'ru', 'tr', 'sr', 'ar', 'uk', 'sv', 'az', 'kk', 'uz']
150
150
 
151
+ export const TEAMMATE_STATUS = [
152
+ { id: 1, name: 'Available', avatar: 'assets/img/teammate-status/avaible.svg', label: "LABEL_AVAILABLE" },
153
+ { id: 2, name: 'Unavailable', avatar: 'assets/img/teammate-status/unavaible.svg', label: "LABEL_NOT_AVAILABLE" },
154
+ { id: 3, name: 'Inactive', avatar: 'assets/img/teammate-status/inactive.svg', label: "LABEL_INACTIVE" },
155
+ ];
151
156
 
152
157
 
@@ -29,7 +29,7 @@ export class ConvertRequestToConversation {
29
29
  request.requester_id,
30
30
  '',
31
31
  request.lead && request.lead.fullname ? request.lead.fullname: null,
32
- '0',
32
+ request.status || '0',
33
33
  moment(request.createdAt).unix(),
34
34
  getColorBck(request.lead.fullname),
35
35
  avatarPlaceholder(request.lead.fullname),