@chat21/chat21-ionic 3.0.60 → 3.0.61-rc11

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 (148) hide show
  1. package/CHANGELOG.md +75 -0
  2. package/README.md +2 -0
  3. package/angular.json +3 -0
  4. package/config.xml +5 -5
  5. package/deploy_pre.sh +10 -10
  6. package/deploy_prod.sh +5 -1
  7. package/env.sample +3 -1
  8. package/package.json +12 -7
  9. package/resources/{Android → android}/icon/drawable-hdpi-icon.png +0 -0
  10. package/resources/{Android → android}/icon/drawable-ldpi-icon.png +0 -0
  11. package/resources/{Android → android}/icon/drawable-mdpi-icon.png +0 -0
  12. package/resources/{Android → android}/icon/drawable-xhdpi-icon.png +0 -0
  13. package/resources/{Android → android}/icon/drawable-xxhdpi-icon.png +0 -0
  14. package/resources/{Android → android}/icon/drawable-xxxhdpi-icon.png +0 -0
  15. package/resources/{Android → android}/icon.png +0 -0
  16. package/resources/{Android → android}/splash/drawable-land-hdpi-screen.png +0 -0
  17. package/resources/{Android → android}/splash/drawable-land-ldpi-screen.png +0 -0
  18. package/resources/{Android → android}/splash/drawable-land-mdpi-screen.png +0 -0
  19. package/resources/{Android → android}/splash/drawable-land-xhdpi-screen.png +0 -0
  20. package/resources/{Android → android}/splash/drawable-land-xxhdpi-screen.png +0 -0
  21. package/resources/{Android → android}/splash/drawable-land-xxxhdpi-screen.png +0 -0
  22. package/resources/{Android → android}/splash/drawable-port-hdpi-screen.png +0 -0
  23. package/resources/{Android → android}/splash/drawable-port-ldpi-screen.png +0 -0
  24. package/resources/{Android → android}/splash/drawable-port-mdpi-screen.png +0 -0
  25. package/resources/{Android → android}/splash/drawable-port-xhdpi-screen.png +0 -0
  26. package/resources/{Android → android}/splash/drawable-port-xxhdpi-screen.png +0 -0
  27. package/resources/{Android → android}/splash/drawable-port-xxxhdpi-screen.png +0 -0
  28. package/resources/{Android → android}/splash.png +0 -0
  29. package/src/app/app-routing.module.ts +10 -0
  30. package/src/app/app.component.html +14 -4
  31. package/src/app/app.component.scss +18 -1
  32. package/src/app/app.component.ts +50 -16
  33. package/src/app/app.module.ts +7 -1
  34. package/src/app/chatlib/list-conversations-component/ion-list-conversations/ion-list-conversations.component.html +7 -2
  35. package/src/app/chatlib/list-conversations-component/ion-list-conversations/ion-list-conversations.component.ts +103 -12
  36. package/src/app/components/conversation-detail/header-conversation-detail/header-conversation-detail.component.html +39 -36
  37. package/src/app/components/conversation-detail/header-conversation-detail/header-conversation-detail.component.scss +5 -1
  38. package/src/app/components/conversation-detail/header-conversation-detail/header-conversation-detail.component.ts +147 -65
  39. package/src/app/components/conversation-detail/message-text-area/message-text-area.component.html +3 -3
  40. package/src/app/components/conversation-detail/message-text-area/message-text-area.component.ts +12 -2
  41. package/src/app/components/ddp-header/ddp-header.component.html +20 -6
  42. package/src/app/components/ddp-header/ddp-header.component.scss +4 -0
  43. package/src/app/components/ddp-header/ddp-header.component.ts +104 -10
  44. package/src/app/components/project-item/project-item.component.html +8 -7
  45. package/src/app/components/project-item/project-item.component.scss +6 -1
  46. package/src/app/components/project-item/project-item.component.ts +15 -2
  47. package/src/app/components/sidebar/sidebar.component.html +274 -0
  48. package/src/app/components/sidebar/sidebar.component.scss +79 -0
  49. package/src/app/components/sidebar/sidebar.component.spec.ts +24 -0
  50. package/src/app/components/sidebar/sidebar.component.ts +493 -0
  51. package/src/app/components/sidebar-user-details/sidebar-user-details.component.html +110 -0
  52. package/src/app/components/sidebar-user-details/sidebar-user-details.component.scss +318 -0
  53. package/src/app/components/sidebar-user-details/sidebar-user-details.component.spec.ts +24 -0
  54. package/src/app/components/sidebar-user-details/sidebar-user-details.component.ts +486 -0
  55. package/src/app/pages/conversation-detail/conversation-detail.module.ts +2 -1
  56. package/src/app/pages/conversation-detail/conversation-detail.page.html +7 -5
  57. package/src/app/pages/conversation-detail/conversation-detail.page.ts +1285 -790
  58. package/src/app/pages/conversations-list/conversations-list.module.ts +2 -1
  59. package/src/app/pages/conversations-list/conversations-list.page.html +18 -9
  60. package/src/app/pages/conversations-list/conversations-list.page.scss +9 -1
  61. package/src/app/pages/conversations-list/conversations-list.page.ts +753 -428
  62. package/src/app/pages/create-requester/create-requester-routing.module.ts +17 -0
  63. package/src/app/pages/create-requester/create-requester.module.ts +28 -0
  64. package/src/app/pages/create-requester/create-requester.page.html +67 -0
  65. package/src/app/pages/create-requester/create-requester.page.scss +30 -0
  66. package/src/app/pages/create-requester/create-requester.page.spec.ts +24 -0
  67. package/src/app/pages/create-requester/create-requester.page.ts +137 -0
  68. package/src/app/pages/create-ticket/create-ticket-routing.module.ts +17 -0
  69. package/src/app/pages/create-ticket/create-ticket.module.ts +28 -0
  70. package/src/app/pages/create-ticket/create-ticket.page.html +171 -0
  71. package/src/app/pages/create-ticket/create-ticket.page.scss +52 -0
  72. package/src/app/pages/create-ticket/create-ticket.page.spec.ts +24 -0
  73. package/src/app/pages/create-ticket/create-ticket.page.ts +423 -0
  74. package/src/app/pages/loader-preview/loader-preview.page.ts +226 -166
  75. package/src/app/pages/profile-info/profile-info.page.html +2 -2
  76. package/src/app/pages/profile-info/profile-info.page.scss +1 -1
  77. package/src/app/pages/profile-info/profile-info.page.ts +23 -21
  78. package/src/app/services/tiledesk/tiledesk.service.ts +181 -0
  79. package/src/app/shared/shared.module.ts +13 -0
  80. package/src/app/utils/scrollbar-theme.directive.ts +58 -24
  81. package/src/assets/i18n/de.json +55 -13
  82. package/src/assets/i18n/en.json +48 -6
  83. package/src/assets/i18n/es.json +47 -5
  84. package/src/assets/i18n/fr.json +50 -8
  85. package/src/assets/i18n/it.json +47 -5
  86. package/src/assets/i18n/pt.json +47 -5
  87. package/src/assets/i18n/ru.json +48 -6
  88. package/src/assets/i18n/sr.json +251 -0
  89. package/src/assets/i18n/tr.json +47 -5
  90. package/src/assets/images/default-avatar-x-select.png +0 -0
  91. package/src/assets/images/language_flag/ar.png +0 -0
  92. package/src/assets/images/language_flag/bg.png +0 -0
  93. package/src/assets/images/language_flag/ca.png +0 -0
  94. package/src/assets/images/language_flag/cs.png +0 -0
  95. package/src/assets/images/language_flag/da.png +0 -0
  96. package/src/assets/images/language_flag/de.png +0 -0
  97. package/src/assets/images/language_flag/el.png +0 -0
  98. package/src/assets/images/language_flag/en.png +0 -0
  99. package/src/assets/images/language_flag/es.png +0 -0
  100. package/src/assets/images/language_flag/fa.png +0 -0
  101. package/src/assets/images/language_flag/fi.png +0 -0
  102. package/src/assets/images/language_flag/fr.png +0 -0
  103. package/src/assets/images/language_flag/he.png +0 -0
  104. package/src/assets/images/language_flag/hi.png +0 -0
  105. package/src/assets/images/language_flag/hr.png +0 -0
  106. package/src/assets/images/language_flag/hu.png +0 -0
  107. package/src/assets/images/language_flag/id.png +0 -0
  108. package/src/assets/images/language_flag/it.png +0 -0
  109. package/src/assets/images/language_flag/ja.png +0 -0
  110. package/src/assets/images/language_flag/ko.png +0 -0
  111. package/src/assets/images/language_flag/ml-IN.png +0 -0
  112. package/src/assets/images/language_flag/ne-NP.png +0 -0
  113. package/src/assets/images/language_flag/nl.png +0 -0
  114. package/src/assets/images/language_flag/no.png +0 -0
  115. package/src/assets/images/language_flag/pl.png +0 -0
  116. package/src/assets/images/language_flag/pt-BR.png +0 -0
  117. package/src/assets/images/language_flag/pt.png +0 -0
  118. package/src/assets/images/language_flag/ro.png +0 -0
  119. package/src/assets/images/language_flag/ru.png +0 -0
  120. package/src/assets/images/language_flag/sk.png +0 -0
  121. package/src/assets/images/language_flag/sl.png +0 -0
  122. package/src/assets/images/language_flag/sr.png +0 -0
  123. package/src/assets/images/language_flag/sv-SE.png +0 -0
  124. package/src/assets/images/language_flag/ta.png +0 -0
  125. package/src/assets/images/language_flag/th.png +0 -0
  126. package/src/assets/images/language_flag/tr.png +0 -0
  127. package/src/assets/images/language_flag/uk.png +0 -0
  128. package/src/assets/images/language_flag/vi.png +0 -0
  129. package/src/assets/images/language_flag/zh-CN.png +0 -0
  130. package/src/assets/images/language_flag/zh-TW.png +0 -0
  131. package/src/assets/images/no_image_user.png +0 -0
  132. package/src/assets/images/priority_icons/high.svg +3 -0
  133. package/src/assets/images/priority_icons/high_v2.svg +14 -0
  134. package/src/assets/images/priority_icons/low.svg +10 -0
  135. package/src/assets/images/priority_icons/low_v2.svg +14 -0
  136. package/src/assets/images/priority_icons/medium.svg +16 -0
  137. package/src/assets/images/priority_icons/medium_v2.svg +11 -0
  138. package/src/assets/images/priority_icons/urgent.svg +4 -0
  139. package/src/assets/images/priority_icons/urgent_v2.svg +16 -0
  140. package/src/assets/tiledesk-solo-logo.png +0 -0
  141. package/src/chat-config-pre-test.json +3 -1
  142. package/src/chat-config-template.json +3 -1
  143. package/src/chat-config.json +4 -2
  144. package/src/chat21-core/utils/constants.ts +6 -1
  145. package/src/global.scss +397 -3
  146. package/src/index.html +7 -0
  147. package/publish_pre.sh +0 -33
  148. package/publish_prod.sh +0 -33
@@ -0,0 +1,486 @@
1
+ import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnInit, Output } from '@angular/core';
2
+ import { LoggerInstance } from 'src/chat21-core/providers/logger/loggerInstance';
3
+ import { LoggerService } from 'src/chat21-core/providers/abstract/logger.service';
4
+ import { TranslateService } from '@ngx-translate/core';
5
+ import { TiledeskAuthService } from 'src/chat21-core/providers/tiledesk/tiledesk-auth.service';
6
+ import { ImageRepoService } from 'src/chat21-core/providers/abstract/image-repo.service';
7
+ import { AppStorageService } from 'src/chat21-core/providers/abstract/app-storage.service';
8
+ import { MessagingAuthService } from 'src/chat21-core/providers/abstract/messagingAuth.service';
9
+ import { WebsocketService } from 'src/app/services/websocket/websocket.service';
10
+ import { skip } from 'rxjs/operators';
11
+ import { AppConfigProvider } from 'src/app/services/app-config';
12
+ import { EventsService } from 'src/app/services/events-service';
13
+ import { tranlatedLanguage } from '../../../chat21-core/utils/constants';
14
+ import { avatarPlaceholder, getColorBck} from 'src/chat21-core/utils/utils-user';
15
+ @Component({
16
+ selector: 'app-sidebar-user-details',
17
+ templateUrl: './sidebar-user-details.component.html',
18
+ styleUrls: ['./sidebar-user-details.component.scss'],
19
+ })
20
+ export class SidebarUserDetailsComponent implements OnInit, OnChanges {
21
+ // HAS_CLICKED_OPEN_USER_DETAIL: boolean = false;
22
+ // @Output() onCloseUserDetailsSidebar = new EventEmitter();
23
+
24
+
25
+ public browserLang: string;
26
+ private logger: LoggerService = LoggerInstance.getInstance()
27
+ chat_lang: string
28
+ flag_url: string;
29
+ photo_profile_URL: string;
30
+ IS_BUSY: boolean;
31
+ IS_AVAILABLE: boolean;
32
+ USER_ROLE: boolean;
33
+ USER_ROLE_LABEL: string;
34
+ IS_BUSY_msg: string;
35
+ IS_AVAILABLE_msg: string;
36
+ IS_UNAVAILABLE_msg: string;
37
+ SUBSCRIPTION_PAYMENT_PROBLEM_msg: string;
38
+ THE_PLAN_HAS_EXPIRED_msg: string;
39
+ PAYD_PLAN_NAME_PRO_msg: string;
40
+ PAYD_PLAN_NAME_ENTERPRISE_msg: string;
41
+ PRO_PLAN_TRIAL_msg: string;
42
+ FREE_PLAN_msg: string;
43
+ profile_name_translated: string;
44
+ SubscriptionPaymentProblem: string;
45
+ user: any
46
+ projectID: any
47
+ tiledeskToken: string;
48
+ prjct_name: string;
49
+ plan_type: string;
50
+ _prjct_profile_name: string;
51
+
52
+ isVisiblePAY: boolean;
53
+ public_Key: any
54
+ plan_name: string;
55
+ plan_subscription_is_active: boolean;
56
+ USER_PHOTO_PROFILE_EXIST: boolean;
57
+
58
+ constructor(
59
+ private translate: TranslateService,
60
+ public tiledeskAuthService: TiledeskAuthService,
61
+ public imageRepoService: ImageRepoService,
62
+ public appStorageService: AppStorageService,
63
+ private messagingAuthService: MessagingAuthService,
64
+ public wsService: WebsocketService,
65
+ public appConfigProvider: AppConfigProvider,
66
+ public events: EventsService,
67
+ private eRef: ElementRef,
68
+ ) { }
69
+
70
+ ngOnInit() {
71
+ this.getCurrentChatLangAndTranslateLabels();
72
+ this.subcribeToAuthStateChanged();
73
+ this.listenTocurrentProjectUserUserAvailability$();
74
+ this.getCurrentStoredProject();
75
+ this.getOSCODE();
76
+ // this.listenOpenUserSidebarEvent();
77
+ }
78
+
79
+ subcribeToAuthStateChanged() {
80
+ this.messagingAuthService.BSAuthStateChanged.subscribe((state) => {
81
+ this.logger.log('[SIDEBAR-USER-DETAILS] BSAuthStateChanged ', state)
82
+
83
+ if (state === 'online') {
84
+ const currentUser = JSON.parse(this.appStorageService.getItem('currentUser'));
85
+ this.logger.log('[SIDEBAR-USER-DETAILS] currentUser ', currentUser)
86
+ if (currentUser) {
87
+ this.user = currentUser;
88
+ this.createUserAvatar(this.user)
89
+ this.photo_profile_URL = this.imageRepoService.getImagePhotoUrl(currentUser.uid)
90
+ this.logger.log('[SIDEBAR-USER-DETAILS] photo_profile_URL ', this.photo_profile_URL);
91
+ this.checkIfExistPhotoProfile(this.photo_profile_URL)
92
+ }
93
+ }
94
+ })
95
+ }
96
+
97
+ checkIfExistPhotoProfile(imageUrl) {
98
+ this.verifyImageURL(imageUrl, (imageExists) => {
99
+
100
+ if (imageExists === true) {
101
+ this.USER_PHOTO_PROFILE_EXIST = true;
102
+ this.logger.log('[SIDEBAR-USER-DETAILS] photo_profile_URL IMAGE EXIST ', imageExists)
103
+
104
+ } else {
105
+ this.USER_PHOTO_PROFILE_EXIST = false;
106
+ this.logger.log('[SIDEBAR-USER-DETAILS] photo_profile_URL IMAGE EXIST ', imageExists)
107
+ }
108
+ })
109
+ }
110
+
111
+
112
+ createUserAvatar(currentUser) {
113
+ this.logger.log('[SIDEBAR-USER-DETAILS] - createProjectUserAvatar ', currentUser)
114
+ let fullname = ''
115
+ if (currentUser && currentUser.firstname && currentUser.lastname) {
116
+ fullname = currentUser.firstname + ' ' + currentUser.lastname
117
+ currentUser['fullname_initial'] = avatarPlaceholder(fullname)
118
+ currentUser['fillColour'] = getColorBck(fullname)
119
+ } else if (currentUser && currentUser.firstname) {
120
+ fullname = currentUser.firstname
121
+ currentUser['fullname_initial'] = avatarPlaceholder(fullname)
122
+ currentUser['fillColour'] = getColorBck(fullname)
123
+ } else {
124
+ currentUser['fullname_initial'] = 'N/A'
125
+ currentUser['fillColour'] = 'rgb(98, 100, 167)'
126
+ }
127
+ }
128
+
129
+ verifyImageURL(image_url, callBack) {
130
+ const img = new Image();
131
+ img.src = image_url;
132
+ img.onload = function () {
133
+ callBack(true);
134
+ };
135
+ img.onerror = function () {
136
+ callBack(false);
137
+ };
138
+ }
139
+
140
+ // listenOpenUserSidebarEvent() {
141
+ // this.events.subscribe('userdetailsidebar:opened', (openUserDetailsSidebar) => {
142
+ // this.logger.log('[SIDEBAR-USER-DETAILS] - listenOpenUserSidebarEvent - openUserDetailsSidebar', openUserDetailsSidebar);
143
+ // this.HAS_CLICKED_OPEN_USER_DETAIL = true;
144
+ // });
145
+ // }
146
+
147
+ @HostListener('document:click', ['$event'])
148
+ clickout(event) {
149
+ this.logger.log('[SIDEBAR-USER-DETAILSS-CHAT] clickout event.target)', event.target)
150
+ this.logger.log('[SIDEBAR-USER-DETAILSS-CHAT] clickout event.target)', event.target.id)
151
+ const clicked_element_id = event.target.id
152
+ if (this.eRef.nativeElement.contains(event.target)) {
153
+ // this.logger.log('[SIDEBAR-USER-DETAILS] clicked inside')
154
+ } else {
155
+ if (!clicked_element_id.startsWith("sidebaravatar")) {
156
+ this.closeUserDetailSidePanel();
157
+ }
158
+ // this.logger.log('[SIDEBAR-USER-DETAILS] clicked outside')
159
+
160
+ }
161
+ }
162
+
163
+ closeUserDetailSidePanel() {
164
+ var element = document.getElementById('user-details');
165
+ element.classList.remove("active");
166
+ this.logger.log('[SIDEBAR-USER-DETAILS] element', element);
167
+ // this.HAS_CLICKED_OPEN_USER_DETAIL === true
168
+ // this.onCloseUserDetailsSidebar.emit(false);
169
+ }
170
+
171
+
172
+ getCurrentChatLangAndTranslateLabels() {
173
+ this.browserLang = this.translate.getBrowserLang();
174
+ const currentUser = JSON.parse(this.appStorageService.getItem('currentUser'));
175
+ this.logger.log('[SIDEBAR-USER-DETAILS] - ngOnInit - currentUser ', currentUser)
176
+ this.logger.log('[SIDEBAR-USER-DETAILS] - ngOnInit - browserLang ', this.browserLang)
177
+ let currentUserId = ''
178
+ if (currentUser) {
179
+ currentUserId = currentUser.uid
180
+ this.logger.log('[SIDEBAR-USER-DETAILS] - ngOnInit - currentUserId ', currentUserId)
181
+ }
182
+
183
+ const stored_preferred_lang = localStorage.getItem(currentUserId + '_lang');
184
+ this.logger.log('[SIDEBAR-USER-DETAILS] stored_preferred_lang: ', stored_preferred_lang);
185
+
186
+
187
+ this.chat_lang = ''
188
+ if (this.browserLang && !stored_preferred_lang) {
189
+ this.chat_lang = this.browserLang
190
+ // this.flag_url = "assets/images/language_flag/" + this.chat_lang + ".png"
191
+
192
+ this.logger.log('[SIDEBAR-USER-DETAILS] flag_url: ', this.flag_url);
193
+ this.logger.log('[SIDEBAR-USER-DETAILS] chat_lang: ', this.chat_lang);
194
+ } else if (this.browserLang && stored_preferred_lang) {
195
+ this.chat_lang = stored_preferred_lang
196
+ // this.flag_url = "assets/images/language_flag/" + this.chat_lang + ".png"
197
+ this.logger.log('[SIDEBAR-USER-DETAILS] flag_url: ', this.flag_url);
198
+ this.logger.log('[SIDEBAR-USER-DETAILS] chat_lang: ', this.chat_lang);
199
+ }
200
+
201
+
202
+ if (tranlatedLanguage.includes(this.chat_lang)) {
203
+ this.logger.log('[SIDEBAR-USER-DETAILS] tranlatedLanguage includes', this.chat_lang, ': ', tranlatedLanguage.includes(this.chat_lang))
204
+ this.translate.use(this.chat_lang);
205
+ this.flag_url = "assets/images/language_flag/" + this.chat_lang + ".png"
206
+ } else {
207
+ this.logger.log('[SIDEBAR-USER-DETAILS] tranlatedLanguage includes', this.chat_lang, ': ', tranlatedLanguage.includes(this.chat_lang))
208
+ this.translate.use('en');
209
+ this.flag_url = "assets/images/language_flag/en.png"
210
+ this.chat_lang = 'en'
211
+ }
212
+ this.translateLabels()
213
+ }
214
+
215
+ translateLabels() {
216
+ this.getAvailableTranslation();
217
+ this.getUnavailableTranslation();
218
+ this.getIsBusyTranslation();
219
+ this.getSubscriptionPaymentProblemTranslation();
220
+ this.getThePlanHasExpiredTranslation();
221
+ }
222
+
223
+
224
+ getOSCODE() {
225
+ this.public_Key = this.appConfigProvider.getConfig().t2y12PruGU9wUtEGzBJfolMIgK;
226
+ this.logger.log('[SIDEBAR-USER-DETAILS] AppConfigService getAppConfig public_Key', this.public_Key);
227
+ this.logger.log('[SIDEBAR-USER-DETAILS] AppConfigService getAppConfig', this.appConfigProvider.getConfig());
228
+ if (this.public_Key) {
229
+ let keys = this.public_Key.split("-");
230
+ this.logger.log('[SIDEBAR-USER-DETAILS] PUBLIC-KEY - public_Key keys', keys)
231
+
232
+ keys.forEach(key => {
233
+ if (key.includes("PAY")) {
234
+
235
+ let pay = key.split(":");
236
+
237
+ if (pay[1] === "F") {
238
+ this.isVisiblePAY = false;
239
+ } else {
240
+ this.isVisiblePAY = true;
241
+ }
242
+ }
243
+ });
244
+
245
+ if (!this.public_Key.includes("PAY")) {
246
+ this.isVisiblePAY = false;
247
+ }
248
+ } else {
249
+ this.isVisiblePAY = false;
250
+ }
251
+ }
252
+
253
+ getAvailableTranslation() {
254
+ this.translate.get('Available')
255
+ .subscribe((text: string) => {
256
+
257
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
258
+ this.IS_AVAILABLE_msg = text
259
+ });
260
+ }
261
+ getUnavailableTranslation() {
262
+ this.translate.get('Unavailable')
263
+ .subscribe((text: string) => {
264
+
265
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
266
+ this.IS_UNAVAILABLE_msg = text
267
+ });
268
+ }
269
+
270
+ getIsBusyTranslation() {
271
+ this.translate.get('Busy')
272
+ .subscribe((text: string) => {
273
+
274
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
275
+ this.IS_BUSY_msg = text
276
+ });
277
+ }
278
+
279
+ getSubscriptionPaymentProblemTranslation() {
280
+ this.translate.get('SubscriptionPaymentProblem')
281
+ .subscribe((text: string) => {
282
+
283
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
284
+ this.SUBSCRIPTION_PAYMENT_PROBLEM_msg = text
285
+ });
286
+ }
287
+
288
+ getThePlanHasExpiredTranslation() {
289
+ this.translate.get('ThePlanHasExpired')
290
+ .subscribe((text: string) => {
291
+
292
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
293
+ this.THE_PLAN_HAS_EXPIRED_msg = text
294
+ });
295
+ }
296
+
297
+
298
+ getCurrentStoredProject() {
299
+ try {
300
+ const project = localStorage.getItem('last_project')
301
+ if (project) {
302
+ const projectObjct = JSON.parse(localStorage.getItem('last_project'))
303
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT ', projectObjct)
304
+
305
+ this.projectID = projectObjct['id_project']['_id']
306
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT > PROJECT ID ', this.projectID);
307
+
308
+ this.prjct_name = projectObjct['id_project']['name']
309
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT > PROJECT NAME ', this.prjct_name);
310
+
311
+ this.plan_type = projectObjct['id_project']['profile']['type'];
312
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT > PLAN TYPE ', this.plan_type);
313
+
314
+ const trial_expired = projectObjct['id_project']['trialExpired']
315
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT > TRIAL EXPIRED ', trial_expired);
316
+
317
+ const profile_name = projectObjct['id_project']['profile']['name'];
318
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT > PROFILE NAME ', profile_name);
319
+
320
+ this.plan_name = projectObjct['id_project']['profile']['name'];
321
+ this.plan_subscription_is_active = projectObjct['id_project']['isActiveSubscription'];
322
+
323
+ if (this.plan_type === 'free') {
324
+
325
+ if (trial_expired === false) {
326
+ this.getProPlanTrialTranslation();
327
+ } else if (trial_expired === true) {
328
+ this.getFreePlanTranslation();
329
+ }
330
+ } else if (this.plan_type === 'payment' && profile_name === 'pro') {
331
+ this.getProPlanTranslation();
332
+ } else if (this.plan_type === 'payment' && profile_name === 'enterprise') {
333
+ this.getEnterprisePlanTranslation();
334
+ }
335
+
336
+ }
337
+
338
+ } catch (err) {
339
+ this.logger.error('[SIDEBAR-USER-DETAILS] - GET STORED PROJECT ERR ', err)
340
+ }
341
+
342
+ try {
343
+ this.tiledeskToken = this.appStorageService.getItem('tiledeskToken');
344
+ // console.log('[SIDEBAR-USER-DETAILS] - GET STORED TOKEN ', this.tiledeskToken)
345
+ } catch (err) {
346
+ this.logger.error('[SIDEBAR-USER-DETAILS] - GET STORED TOKEN ', err)
347
+ }
348
+ }
349
+
350
+
351
+ getProPlanTrialTranslation() {
352
+ // this.profile_name_translated = this.PRO_PLAN_TRIAL_msg;
353
+ this.translate.get('ProPlanTrial')
354
+ .subscribe((text: string) => {
355
+
356
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
357
+ this.profile_name_translated = text
358
+ });
359
+ }
360
+
361
+ getFreePlanTranslation() {
362
+ // this.profile_name_translated = this.FREE_PLAN_msg;
363
+ this.translate.get('FreePlan')
364
+ .subscribe((text: string) => {
365
+
366
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
367
+ this.profile_name_translated = text
368
+ });
369
+ }
370
+
371
+ getProPlanTranslation() {
372
+ // this.profile_name_translated = this.PAYD_PLAN_NAME_PRO_msg;
373
+ this.translate.get('PaydPlanNamePro')
374
+ .subscribe((text: string) => {
375
+ // this.deleteContact_msg = text;
376
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
377
+ this.profile_name_translated = text
378
+ });
379
+ }
380
+
381
+ getEnterprisePlanTranslation() {
382
+ // this.profile_name_translated = this.PAYD_PLAN_NAME_ENTERPRISE_msg;
383
+ this.translate.get('PaydPlanNameEnterprise')
384
+ .subscribe((text: string) => {
385
+ // this.deleteContact_msg = text;
386
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
387
+ this.profile_name_translated = text
388
+ });
389
+ }
390
+
391
+
392
+
393
+ listenTocurrentProjectUserUserAvailability$() {
394
+ this.wsService.currentProjectUserAvailability$
395
+ .pipe(skip(1))
396
+ .subscribe((projectUser) => {
397
+ this.logger.log('[SIDEBAR-USER-DETAILS] - $UBSC TO WS USER AVAILABILITY & BUSY STATUS RES ', projectUser);
398
+
399
+ if (projectUser) {
400
+ this.IS_AVAILABLE = projectUser['user_available']
401
+ this.IS_BUSY = projectUser['isBusy']
402
+ this.USER_ROLE = projectUser['role']
403
+ // console.log('[SIDEBAR-USER-DETAILS] -translateUserRole 1', this.USER_ROLE)
404
+ this.translateUserRole(this.USER_ROLE)
405
+ }
406
+
407
+
408
+
409
+ }, (error) => {
410
+ this.logger.error('[SIDEBAR-USER-DETAILS] - $UBSC TO WS USER AVAILABILITY & BUSY STATUS error ', error);
411
+ }, () => {
412
+ this.logger.log('[SIDEBAR-USER-DETAILS] - $UBSC TO WS USER AVAILABILITY & BUSY STATUS * COMPLETE *');
413
+ })
414
+ }
415
+
416
+ translateUserRole(role) {
417
+ // console.log('[SIDEBAR-USER-DETAILS] -translateUserRole ', role)
418
+ this.translate.get(role)
419
+ .subscribe((text: string) => {
420
+
421
+ // console.log('[SIDEBAR-USER-DETAILS] - GET GTTTTTN ', text)
422
+ this.USER_ROLE_LABEL = text
423
+ });
424
+
425
+
426
+ }
427
+
428
+
429
+ ngOnChanges() {
430
+ // console.log('[SIDEBAR-USER-DETAILS] HAS_CLICKED_OPEN_USER_DETAIL', this.HAS_CLICKED_OPEN_USER_DETAIL)
431
+ // var element = document.getElementById('user-details');
432
+ // // console.log('[SIDEBAR-USER-DETAILS] element', element)
433
+ // if (this.HAS_CLICKED_OPEN_USER_DETAIL === true) {
434
+ // element.classList.add("active");
435
+ // }
436
+ }
437
+
438
+
439
+
440
+ // closeUserDetailSidePanel() {
441
+ // var element = document.getElementById('user-details');
442
+ // element.classList.remove("active");
443
+ // this.logger.log('[SIDEBAR-USER-DETAILS] element', element);
444
+ // this.HAS_CLICKED_OPEN_USER_DETAIL === true
445
+ // // this.onCloseUserDetailsSidebar.emit(false);
446
+ // }
447
+
448
+
449
+
450
+ changeAvailabilityStateInUserDetailsSidebar(available) {
451
+ this.logger.log('[SIDEBAR-USER-DETAILS] - changeAvailabilityState projectid', this.projectID, ' available 1: ', available);
452
+
453
+ // available = !available
454
+ // console.log('[SIDEBAR-USER-DETAILS] - changeAvailabilityState projectid', this.projectID, ' available 2 : ', available);
455
+
456
+ this.wsService.updateCurrentUserAvailability(this.tiledeskToken, this.projectID, available)
457
+ .subscribe((projectUser: any) => {
458
+
459
+ this.logger.log('[SIDEBAR-USER-DETAILS] - PROJECT-USER UPDATED ', projectUser)
460
+
461
+ // NOTIFY TO THE USER SERVICE WHEN THE AVAILABLE / UNAVAILABLE BUTTON IS CLICKED
462
+ // this.usersService.availability_btn_clicked(true)
463
+
464
+ // if (this.project['id_project']._id === projectUser.id_project) {
465
+ // this.project['ws_projct_user_available'] = projectUser.user_available;
466
+ // // this.project['ws_projct_user_isBusy'] = projectUser['isBusy']
467
+ // }
468
+
469
+ }, (error) => {
470
+ this.logger.error('[SIDEBAR-USER-DETAILS] - PROJECT-USER UPDATED - ERROR ', error);
471
+
472
+ }, () => {
473
+ this.logger.log('[SIDEBAR-USER-DETAILS] - PROJECT-USER UPDATED * COMPLETE *');
474
+
475
+ });
476
+ }
477
+
478
+ public onLogout() {
479
+ // this.authService.logout();
480
+ this.closeUserDetailSidePanel()
481
+ // pubblico evento
482
+ this.events.publish('profileInfoButtonClick:logout', true);
483
+ }
484
+
485
+
486
+ }
@@ -34,7 +34,7 @@ import { InfoGroupComponent } from 'src/app/components/conversation-info/info-gr
34
34
  import { SharedModule } from 'src/app/shared/shared.module';
35
35
  // import { SharedConversationInfoModule } from 'src/app/shared/shared-conversation-info.module';
36
36
  import { NgxLinkifyjsModule } from 'ngx-linkifyjs';
37
-
37
+ import { ScrollbarThemeModule } from '../../utils/scrollbar-theme.directive';
38
38
  @NgModule({
39
39
  imports: [
40
40
  CommonModule,
@@ -42,6 +42,7 @@ import { NgxLinkifyjsModule } from 'ngx-linkifyjs';
42
42
  IonicModule,
43
43
  TooltipModule,
44
44
  ConversationDetailPageRoutingModule,
45
+ ScrollbarThemeModule,
45
46
  TranslateModule.forChild({
46
47
  loader: {
47
48
  provide: TranslateLoader,
@@ -1,7 +1,7 @@
1
1
  <span *ngIf="conversationWith && loggedUser; then showConversation else showPlaceholder"></span>
2
2
  <ng-template #showPlaceholder>
3
3
  <!-- class="splash-page" -->
4
- <ion-content padding>
4
+ <ion-content padding >
5
5
  <!-- <div padding class="image-splash-page"></div>
6
6
  <div padding class="title-splash-page">
7
7
  text new conversation + button
@@ -34,10 +34,11 @@
34
34
  <app-header-conversation-detail [isMobile]="isMobile" [idLoggedUser]="loggedUser.uid"
35
35
  [conversationAvatar]="conversationAvatar" [translationMap]="translationMap"
36
36
  (eventOpenCloseInfoConversation)="returnOpenCloseInfoConversation($event)"
37
- [isOpenInfoConversation]="isOpenInfoConversation">
37
+ [isOpenInfoConversation]="isOpenInfoConversation"
38
+ [conv_type]="conv_type">
38
39
  </app-header-conversation-detail>
39
40
 
40
- <ion-content>
41
+ <ion-content id="conv-details">
41
42
  <ion-grid class="grid_content">
42
43
  <ion-row class="row_content">
43
44
  <ion-col id="chatArea" [class.mobile]="isMobile" [class.open]="openInfoConversation">
@@ -91,7 +92,7 @@
91
92
  </ng-template>
92
93
 
93
94
  <ng-template #content_messages>
94
- <ion-content #ionContentChatArea class="ionContentChatArea" (drop)="drop($event)"
95
+ <ion-content #ionContentChatArea appScrollbarTheme class="ionContentChatArea" (drop)="drop($event)"
95
96
  (dragover)="allowDrop($event)" (dragleave)="drag($event)" [scrollEvents]="true"
96
97
  (ionScrollStart)="logScrollStart($event)" (ionScroll)="logScrolling($event)"
97
98
  (ionScrollEnd)="logScrollEnd($event)" [class.active]="showIonContent">
@@ -162,7 +163,8 @@
162
163
  (eventSendMessage)="returnSendMessage($event)" [translationMap]="translationMap"
163
164
  [fileUploadAccept]="appConfigProvider.getConfig().fileUploadAccept"
164
165
  [isOpenInfoConversation]="isOpenInfoConversation" [dropEvent]="dropEvent"
165
- (onPresentModalScrollToBottom)="onPresentModalScrollToBottom($event)">
166
+ (onPresentModalScrollToBottom)="onPresentModalScrollToBottom($event)"
167
+ [disableTextarea]="disableTextarea">
166
168
  </app-message-text-area>
167
169
  <!-- [events]="eventsReplaceTexareaText.asObservable()" -->
168
170
  </ion-row>