@chat21/chat21-ionic 3.0.107-rc.3 → 3.0.107-rc.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +14 -0
- package/package.json +1 -1
- package/src/app/app.component.ts +99 -29
- package/src/app/chatlib/conversation-detail/conversation-content/conversation-content.component.scss +0 -1
- package/src/app/chatlib/conversation-detail/ion-conversation-detail/ion-conversation-detail.component.scss +9 -9
- package/src/app/chatlib/conversation-detail/message/info-message/info-message.component.scss +5 -7
- package/src/app/chatlib/conversation-detail/message/options/options.component.scss +2 -2
- package/src/app/chatlib/conversation-detail/message/return-receipt/return-receipt.component.scss +1 -1
- package/src/app/chatlib/list-conversations-component/ion-list-conversations/ion-list-conversations.component.html +1 -1
- package/src/app/chatlib/list-conversations-component/ion-list-conversations/ion-list-conversations.component.scss +22 -55
- package/src/app/components/canned-response/canned-response.component.scss +9 -2
- package/src/app/components/contacts-directory/contacts-directory.component.scss +4 -56
- package/src/app/components/conversation-detail/header-conversation-detail/header-conversation-detail.component.scss +5 -6
- package/src/app/components/conversation-detail/message-text-area/message-text-area.component.scss +16 -5
- package/src/app/components/conversation-detail/message-text-area/message-text-area.component.ts +5 -0
- package/src/app/components/conversation-info/advanced-info-accordion/advanced-info-accordion.component.html +11 -19
- package/src/app/components/conversation-info/advanced-info-accordion/advanced-info-accordion.component.scss +15 -19
- package/src/app/components/conversation-info/info-direct/info-direct.component.scss +6 -5
- package/src/app/components/conversation-info/info-group/info-group.component.html +2 -2
- package/src/app/components/conversation-info/info-group/info-group.component.scss +11 -2
- package/src/app/components/conversation-info/info-support-group/info-support-group.component.html +2 -1
- package/src/app/components/conversation-info/info-support-group/info-support-group.component.ts +46 -3
- package/src/app/components/conversations-list/header-conversations-list/header-conversations-list.component.html +2 -1
- package/src/app/components/conversations-list/header-conversations-list/header-conversations-list.component.scss +3 -2
- package/src/app/components/conversations-list/header-conversations-list-archived/header-conversations-list-archived.component.scss +5 -3
- package/src/app/components/conversations-list/header-conversations-list-unassigned/header-conversations-list-unassigned.component.scss +5 -3
- package/src/app/components/navbar/navbar.component.html +10 -14
- package/src/app/components/navbar/navbar.component.scss +33 -17
- package/src/app/components/sidebar/sidebar.component.html +49 -67
- package/src/app/components/sidebar/sidebar.component.scss +44 -29
- package/src/app/components/sidebar-user-details/sidebar-user-details.component.html +5 -5
- package/src/app/components/sidebar-user-details/sidebar-user-details.component.scss +47 -93
- package/src/app/components/sidebar-user-details/sidebar-user-details.component.ts +11 -13
- package/src/app/modals/create-canned-response/create-canned-response.page.html +2 -20
- package/src/app/modals/create-canned-response/create-canned-response.page.scss +44 -27
- package/src/app/modals/create-ticket/create-ticket.page.html +4 -4
- package/src/app/modals/create-ticket/create-ticket.page.scss +34 -1
- package/src/app/modals/json-message/json-message.page.scss +15 -1
- package/src/app/modals/loader-preview/loader-preview.page.html +1 -1
- package/src/app/modals/loader-preview/loader-preview.page.scss +19 -1
- package/src/app/modals/maps/maps.page.scss +18 -0
- package/src/app/modals/send-email/send-email.page.scss +30 -7
- package/src/app/modals/send-whatsapp-template/send-whatsapp-template.page.html +1 -1
- package/src/app/modals/send-whatsapp-template/send-whatsapp-template.page.scss +18 -0
- package/src/app/pages/contacts-directory/contacts-directory.page.html +9 -10
- package/src/app/pages/contacts-directory/contacts-directory.page.scss +5 -3
- package/src/app/pages/contacts-directory/contacts-directory.page.ts +0 -15
- package/src/app/pages/conversation-detail/conversation-detail.page.scss +5 -5
- package/src/app/pages/conversation-detail/conversation-detail.page.ts +10 -11
- package/src/app/pages/conversations-list/conversations-list.page.html +0 -1
- package/src/app/pages/conversations-list/conversations-list.page.scss +6 -17
- package/src/app/pages/conversations-list/conversations-list.page.ts +9 -18
- package/src/app/pages/profile-info/profile-info.page.html +4 -4
- package/src/app/pages/profile-info/profile-info.page.scss +43 -25
- package/src/app/pages/profile-info/profile-info.page.ts +2 -1
- package/src/app/pages/unassigned-conversations/unassigned-conversations.page.html +5 -5
- package/src/app/pages/unassigned-conversations/unassigned-conversations.page.scss +2 -2
- package/src/app/pages/unassigned-conversations/unassigned-conversations.page.ts +48 -1
- package/src/assets/customStyle.css +39 -0
- package/src/assets/test.html +38 -4
- package/src/chat21-core/providers/firebase/firebase-conversations-handler.ts +1 -0
- package/src/chat21-core/providers/mqtt/mqtt-conversations-handler.ts +2 -1
- package/src/chat21-core/providers/native/native-upload-service.ts +1 -1
- package/src/chat21-core/providers/tiledesk/tiledesk-auth.service.ts +21 -9
- package/src/global.scss +52 -137
- package/src/index.html +1 -1
- package/src/theme/variables.scss +276 -149
- package/src/variables.scss +115 -21
|
@@ -1,3 +1,20 @@
|
|
|
1
|
+
ion-toolbar{
|
|
2
|
+
--background: var(--modal-header-background);
|
|
3
|
+
&:not(.mobile){
|
|
4
|
+
// --background: var(--list-bkg-color);
|
|
5
|
+
border: none;
|
|
6
|
+
}
|
|
7
|
+
&.mobile{
|
|
8
|
+
border-bottom: 1px solid rgba(0, 0, 0, 0.05);
|
|
9
|
+
}
|
|
10
|
+
ion-button,
|
|
11
|
+
ion-title{
|
|
12
|
+
--color: var(--modal-icon-color);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
ion-content{
|
|
16
|
+
--background: var(--modal-content-background);
|
|
17
|
+
}
|
|
1
18
|
|
|
2
19
|
.content-container{
|
|
3
20
|
padding-top: 40px;
|
|
@@ -61,6 +78,11 @@ ion-input{
|
|
|
61
78
|
width: 100%;
|
|
62
79
|
}
|
|
63
80
|
|
|
81
|
+
.field-wrapper input:focus-visible,
|
|
82
|
+
.field-wrapper textarea:focus-visible{
|
|
83
|
+
outline: var(--border-focus-color) auto 1px;
|
|
84
|
+
}
|
|
85
|
+
|
|
64
86
|
.field-wrapper .field-placeholder{
|
|
65
87
|
font-size: 16px;
|
|
66
88
|
position: absolute;
|
|
@@ -80,17 +102,18 @@ ion-input{
|
|
|
80
102
|
}
|
|
81
103
|
|
|
82
104
|
.field-wrapper .field-placeholder span{
|
|
83
|
-
background: #ffffff;
|
|
84
|
-
padding: 0px 8px;
|
|
105
|
+
// background: #ffffff;
|
|
106
|
+
// padding: 0px 8px;
|
|
85
107
|
}
|
|
86
108
|
|
|
87
109
|
.field-wrapper input:not([disabled]):focus~.field-placeholder,
|
|
88
110
|
.field-placeholder:target,
|
|
89
111
|
.field-wrapper.hasValue input:not([disabled])~.field-placeholder{
|
|
90
|
-
-webkit-transform: scale(.75) translateY(-
|
|
91
|
-
transform: scale(.75) translateY(-
|
|
92
|
-
color:
|
|
112
|
+
-webkit-transform: scale(.75) translateY(-50px) translateX(-30px);
|
|
113
|
+
transform: scale(.75) translateY(-50px) translateX(-30px);
|
|
114
|
+
color:var(--title-focus-color);
|
|
93
115
|
font-weight: bold;
|
|
116
|
+
font-size: 18px;
|
|
94
117
|
}
|
|
95
118
|
|
|
96
119
|
.field-wrapper-email{
|
|
@@ -147,8 +170,8 @@ ion-label.message-placeholder{
|
|
|
147
170
|
justify-content: center;
|
|
148
171
|
|
|
149
172
|
ion-button{
|
|
150
|
-
background-color:
|
|
151
|
-
color
|
|
173
|
+
background-color:var(--button-background-color);
|
|
174
|
+
color:var(--button-text-color);
|
|
152
175
|
border-radius: 4px;
|
|
153
176
|
font-size: 18px;
|
|
154
177
|
height: 46px;
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
<ion-content *ngIf="selectionView && !displayError" class="content-container">
|
|
14
14
|
|
|
15
15
|
|
|
16
|
-
<ion-list lines="full">
|
|
16
|
+
<ion-list lines="full" color="none">
|
|
17
17
|
<ion-item *ngFor="let template of templates" button detail="true" (click)="selectTemplate(template.id)">
|
|
18
18
|
<ion-label>
|
|
19
19
|
<div class="label-container">
|
|
@@ -1,3 +1,21 @@
|
|
|
1
|
+
ion-toolbar{
|
|
2
|
+
--background: var(--modal-header-background);
|
|
3
|
+
&:not(.mobile){
|
|
4
|
+
// --background: var(--list-bkg-color);
|
|
5
|
+
border: none;
|
|
6
|
+
}
|
|
7
|
+
&.mobile{
|
|
8
|
+
border-bottom: 1px solid rgba(0, 0, 0, 0.05);
|
|
9
|
+
}
|
|
10
|
+
ion-button,
|
|
11
|
+
ion-title{
|
|
12
|
+
--color: var(--modal-icon-color);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
ion-content{
|
|
16
|
+
--background: var(--modal-content-background);
|
|
17
|
+
}
|
|
18
|
+
|
|
1
19
|
.error-container {
|
|
2
20
|
margin-top: 70px;
|
|
3
21
|
display: flex;
|
|
@@ -1,15 +1,14 @@
|
|
|
1
|
-
<ion-
|
|
2
|
-
<ion-
|
|
3
|
-
<ion-title>{{ 'LABEL_NEW_CHAT' | translate }}</ion-title>
|
|
1
|
+
<ion-toolbar [class.mobile]="isMobile">
|
|
2
|
+
<ion-title>{{ 'LABEL_NEW_CHAT' | translate }}</ion-title>
|
|
4
3
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
4
|
+
<ion-buttons slot="end">
|
|
5
|
+
<ion-button ion-button fill="clear" (click)="onClose()">
|
|
6
|
+
<ion-icon slot="icon-only" name="close"></ion-icon>
|
|
7
|
+
</ion-button>
|
|
8
|
+
</ion-buttons>
|
|
9
|
+
|
|
10
|
+
</ion-toolbar>
|
|
10
11
|
|
|
11
|
-
</ion-toolbar>
|
|
12
|
-
</ion-header>
|
|
13
12
|
|
|
14
13
|
<ion-content>
|
|
15
14
|
<component-contacts-directory
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
ion-toolbar {
|
|
2
2
|
height: var(--header-height);
|
|
3
|
+
--background: transparent;
|
|
3
4
|
&:not(.mobile){
|
|
4
|
-
--background: var(--list-bkg-color);
|
|
5
|
+
// --background: var(--list-bkg-color);
|
|
5
6
|
border: none;
|
|
6
7
|
}
|
|
7
8
|
&.mobile{
|
|
8
9
|
border-bottom: 1px solid rgba(0, 0, 0, 0.05);
|
|
9
10
|
}
|
|
10
11
|
|
|
11
|
-
ion-button
|
|
12
|
-
|
|
12
|
+
ion-button,
|
|
13
|
+
ion-title{
|
|
14
|
+
--color: var(--icon-color);
|
|
13
15
|
}
|
|
14
16
|
}
|
|
15
17
|
|
|
@@ -83,21 +83,6 @@ export class ContactsDirectoryPage implements OnInit {
|
|
|
83
83
|
});
|
|
84
84
|
}
|
|
85
85
|
|
|
86
|
-
/** */
|
|
87
|
-
getTokenFromLocalStorage() {
|
|
88
|
-
let token = localStorage.getItem('tiledeskToken'); // ??? NN CREDO SIA USATO
|
|
89
|
-
this.logger.log('[CONTACT-DIRECTORY-PAGE] getTokenFromLocalStorage token ', token);
|
|
90
|
-
const user = JSON.parse(localStorage.getItem('user'));
|
|
91
|
-
if (user) {
|
|
92
|
-
this.logger.log('[CONTACT-DIRECTORY-PAGE] DSHBRD STORED USER: ', user);
|
|
93
|
-
if (user.token) {
|
|
94
|
-
token = user.token;
|
|
95
|
-
this.logger.log('[CONTACTS-DIRECTORY] DSHBRD STORED USER > TOKEN: ', user.token);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
return token;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
86
|
/** */
|
|
102
87
|
async onClose() {
|
|
103
88
|
this.logger.log('[CONTACT-DIRECTORY-PAGE] - onClose MODAL')
|
|
@@ -60,7 +60,7 @@ ion-content {
|
|
|
60
60
|
&#conv-details:not(.mobile){
|
|
61
61
|
--background: var(--list-bkg-color);
|
|
62
62
|
}
|
|
63
|
-
--background:
|
|
63
|
+
--background: transparent;;
|
|
64
64
|
|
|
65
65
|
ion-item {
|
|
66
66
|
--padding-end: 0px;
|
|
@@ -86,7 +86,7 @@ ion-content {
|
|
|
86
86
|
position: absolute;
|
|
87
87
|
top: 0;
|
|
88
88
|
overflow: hidden;
|
|
89
|
-
background-color:
|
|
89
|
+
background-color: var(--conversation-detail-background);
|
|
90
90
|
|
|
91
91
|
&:not(.mobile){
|
|
92
92
|
border-radius: var(--border-radius-content);;
|
|
@@ -105,7 +105,6 @@ ion-content {
|
|
|
105
105
|
}
|
|
106
106
|
.row_message_text_area {
|
|
107
107
|
min-height: 50px;
|
|
108
|
-
background-color: white;
|
|
109
108
|
position: absolute;
|
|
110
109
|
bottom: 0;
|
|
111
110
|
width: calc(100% - 0px);
|
|
@@ -119,6 +118,7 @@ ion-content {
|
|
|
119
118
|
height: 100%;
|
|
120
119
|
margin: 0;
|
|
121
120
|
padding: 0;
|
|
121
|
+
background: transparent;
|
|
122
122
|
&.open {
|
|
123
123
|
max-width: auto;
|
|
124
124
|
min-width: calc(100% - 320px);
|
|
@@ -136,7 +136,7 @@ ion-content {
|
|
|
136
136
|
padding: 0;
|
|
137
137
|
margin: 0;
|
|
138
138
|
border-left-style: solid;
|
|
139
|
-
border-color: var(--
|
|
139
|
+
border-color: var(--border-color-base);
|
|
140
140
|
border-left-width: thin;
|
|
141
141
|
display: block;
|
|
142
142
|
overflow: hidden;
|
|
@@ -229,7 +229,7 @@ ion-content {
|
|
|
229
229
|
|
|
230
230
|
.ionContentChatArea {
|
|
231
231
|
opacity: 0;
|
|
232
|
-
--background:
|
|
232
|
+
--background: var(--conversation-detail-background);
|
|
233
233
|
&.active {
|
|
234
234
|
opacity: 1;
|
|
235
235
|
}
|
|
@@ -531,7 +531,6 @@ export class ConversationDetailPage implements OnInit, OnDestroy, AfterViewInit
|
|
|
531
531
|
this.addEventsKeyboard()
|
|
532
532
|
this.updateConversationBadge() // AGGIORNO STATO DELLA CONVERSAZIONE A 'LETTA' (is_new = false)
|
|
533
533
|
|
|
534
|
-
|
|
535
534
|
}
|
|
536
535
|
|
|
537
536
|
_getProjectIdByConversationWith(conversationWith: string) {
|
|
@@ -742,16 +741,16 @@ export class ConversationDetailPage implements OnInit, OnDestroy, AfterViewInit
|
|
|
742
741
|
// .set('buttonTextColor', 'var(--buttonTextColor)')
|
|
743
742
|
// .set('buttonHoverBackgroundColor', 'var(--buttonHoverBackgroundColor)')
|
|
744
743
|
// .set('buttonHoverTextColor', 'var(--buttonHoverTextColor)')
|
|
745
|
-
this.styleMap.set('themeColor', '
|
|
746
|
-
.set('bubbleReceivedBackground', '
|
|
747
|
-
.set('bubbleReceivedTextColor', '
|
|
748
|
-
.set('bubbleSentBackground', '
|
|
749
|
-
.set('bubbleSentTextColor', '
|
|
750
|
-
.set('buttonFontSize', '
|
|
751
|
-
.set('buttonBackgroundColor', '
|
|
752
|
-
.set('buttonTextColor', '
|
|
753
|
-
.set('buttonHoverBackgroundColor', '
|
|
754
|
-
.set('buttonHoverTextColor', '
|
|
744
|
+
this.styleMap.set('themeColor', 'var(--basic-blue)')
|
|
745
|
+
.set('bubbleReceivedBackground', 'var(--bck-msg-received)')
|
|
746
|
+
.set('bubbleReceivedTextColor', 'var(--col-msg-received)')
|
|
747
|
+
.set('bubbleSentBackground', 'var(--bck-msg-sent)')
|
|
748
|
+
.set('bubbleSentTextColor', 'var(--col-msg-sent)')
|
|
749
|
+
.set('buttonFontSize', 'var(--button-in-msg-font-size)')
|
|
750
|
+
.set('buttonBackgroundColor', 'var(--buttonBackgroundColor)')
|
|
751
|
+
.set('buttonTextColor', 'var(--buttonTextColor)')
|
|
752
|
+
.set('buttonHoverBackgroundColor', 'var(--buttonHoverBackgroundColor)')
|
|
753
|
+
.set('buttonHoverTextColor', 'var(--buttonHoverTextColor)')
|
|
755
754
|
|
|
756
755
|
}
|
|
757
756
|
// -------------------------------------------------------------------------------------
|
|
@@ -43,6 +43,12 @@ ion-content {
|
|
|
43
43
|
}
|
|
44
44
|
}
|
|
45
45
|
|
|
46
|
+
app-project-item{
|
|
47
|
+
width: 100%;
|
|
48
|
+
margin: 0px 8px;
|
|
49
|
+
border-bottom: 1px dashed var(--border-color-base);
|
|
50
|
+
}
|
|
51
|
+
|
|
46
52
|
ion-list {
|
|
47
53
|
display: block;
|
|
48
54
|
margin-block-start: 1em;
|
|
@@ -119,23 +125,6 @@ ion-list {
|
|
|
119
125
|
font-family: Helvetica, Helvetica, Arial, sans-serif;
|
|
120
126
|
line-height: 1.28;
|
|
121
127
|
text-rendering: optimizeLegibility;
|
|
122
|
-
.conversation_with {
|
|
123
|
-
color: rgba(0, 0, 0, 1);
|
|
124
|
-
font-size: 15px;
|
|
125
|
-
font-weight: 400;
|
|
126
|
-
line-height: 1.4;
|
|
127
|
-
}
|
|
128
|
-
.conversation_message {
|
|
129
|
-
p {
|
|
130
|
-
color: rgba(153, 153, 153, 1);
|
|
131
|
-
font-size: 13px;
|
|
132
|
-
font-weight: 400;
|
|
133
|
-
height: 18px;
|
|
134
|
-
&.not-read {
|
|
135
|
-
font-weight: bold;
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
128
|
}
|
|
140
129
|
ion-note {
|
|
141
130
|
position: absolute;
|
|
@@ -52,6 +52,7 @@ import { WebsocketService } from 'src/app/services/websocket/websocket.service';
|
|
|
52
52
|
import { Globals } from 'src/app/utils/globals';
|
|
53
53
|
import { TriggerEvents } from 'src/app/services/triggerEvents/triggerEvents';
|
|
54
54
|
import { MessageModel } from 'src/chat21-core/models/message';
|
|
55
|
+
import { Project } from 'src/chat21-core/models/projects';
|
|
55
56
|
|
|
56
57
|
@Component({
|
|
57
58
|
selector: 'app-conversations-list',
|
|
@@ -102,7 +103,7 @@ export class ConversationListPage implements OnInit {
|
|
|
102
103
|
public isInitialized: boolean = false;
|
|
103
104
|
|
|
104
105
|
// PROJECT AVAILABILITY INFO: start
|
|
105
|
-
project:
|
|
106
|
+
project: Project
|
|
106
107
|
profile_name_translated: string;
|
|
107
108
|
selectedStatus: any;
|
|
108
109
|
teammateStatus = [
|
|
@@ -475,35 +476,25 @@ export class ConversationListPage implements OnInit {
|
|
|
475
476
|
this.project = {
|
|
476
477
|
_id: projectObjct['id_project']['_id'],
|
|
477
478
|
name: projectObjct['id_project']['name'],
|
|
478
|
-
|
|
479
|
+
profile: projectObjct['id_project']['profile'],
|
|
479
480
|
isActiveSubscription: projectObjct['id_project']['isActiveSubscription'],
|
|
480
|
-
|
|
481
|
+
trialExpired: projectObjct['id_project']['trialExpired']
|
|
481
482
|
}
|
|
482
483
|
|
|
483
|
-
|
|
484
|
-
const profile_name = projectObjct['id_project']['profile']['name'];
|
|
485
|
-
|
|
486
|
-
if (this.project.type === 'free') {
|
|
484
|
+
if (this.project.profile.type === 'free') {
|
|
487
485
|
|
|
488
|
-
if (
|
|
486
|
+
if (this.project.trialExpired === false) {
|
|
489
487
|
this.profile_name_translated = this.translationMapHeader.get('ProPlanTrial');
|
|
490
|
-
} else if (
|
|
488
|
+
} else if (this.project.trialExpired === true) {
|
|
491
489
|
this.profile_name_translated = this.translationMapHeader.get('FreePlan');
|
|
492
490
|
}
|
|
493
|
-
} else if (this.project.type === 'payment' &&
|
|
491
|
+
} else if (this.project.profile.type === 'payment' && this.project.profile.name === 'pro') {
|
|
494
492
|
this.profile_name_translated = this.translationMapHeader.get('PaydPlanNamePro');
|
|
495
|
-
} else if (this.project.type === 'payment' &&
|
|
493
|
+
} else if (this.project.profile.type === 'payment' && this.project.profile.name === 'enterprise') {
|
|
496
494
|
this.profile_name_translated = this.translationMapHeader.get('PaydPlanNameEnterprise');
|
|
497
495
|
}
|
|
498
496
|
}
|
|
499
497
|
})
|
|
500
|
-
|
|
501
|
-
try {
|
|
502
|
-
// this.tiledeskToken = this.appStorageService.getItem('tiledeskToken');
|
|
503
|
-
// console.log('[SIDEBAR-USER-DETAILS] - GET STORED TOKEN ', this.tiledeskToken)
|
|
504
|
-
} catch (err) {
|
|
505
|
-
this.logger.error('[CONVS-LIST-PAGE] - GET STORED TOKEN ', err)
|
|
506
|
-
}
|
|
507
498
|
}
|
|
508
499
|
|
|
509
500
|
listenTocurrentProjectUserUserAvailability$() {
|
|
@@ -108,17 +108,17 @@
|
|
|
108
108
|
<span class="material-icons user-details-plan-icon">apps</span>
|
|
109
109
|
<span>
|
|
110
110
|
<div> {{project?.name}} </div>
|
|
111
|
-
<div style="
|
|
111
|
+
<div style="margin-left: 26px;"> {{ profile_name_translated }} </div>
|
|
112
112
|
|
|
113
|
-
<div *ngIf="project?.type === 'payment' && project?.isActiveSubscription === false"
|
|
113
|
+
<div *ngIf="project?.profile?.type === 'payment' && project?.isActiveSubscription === false"
|
|
114
114
|
style="color:#f44336; position:relative; top: -1px;display: inline-block;">
|
|
115
|
-
<i *ngIf="project?.
|
|
115
|
+
<i *ngIf="project?.profile?.name !== 'enterprise'" class="material-icons" style="vertical-align: middle; color:#f44336; cursor:pointer;
|
|
116
116
|
font-size: 16px;" matTooltipClass="custom-mat-tooltip"
|
|
117
117
|
matTooltip="{{ translationsMap.get('SubscriptionPaymentProblem') }}" #tooltip="matTooltip" matTooltipPosition='right'
|
|
118
118
|
matTooltipHideDelay="100">
|
|
119
119
|
error_outline
|
|
120
120
|
</i>
|
|
121
|
-
<i *ngIf="project?.
|
|
121
|
+
<i *ngIf="project?.profile?.name === 'enterprise'" class="material-icons" style="vertical-align: middle; color:#f44336; cursor:pointer;
|
|
122
122
|
font-size: 16px;" matTooltipClass="custom-mat-tooltip" matTooltip="{{ translationsMap.get('ThePlanHasExpired') }}"
|
|
123
123
|
#tooltip="matTooltip" matTooltipPosition='right' matTooltipHideDelay="100">
|
|
124
124
|
error_outline
|
|
@@ -71,13 +71,20 @@
|
|
|
71
71
|
ion-toolbar{
|
|
72
72
|
position: absolute;
|
|
73
73
|
z-index: 2;
|
|
74
|
-
--
|
|
74
|
+
--background: transparent;
|
|
75
|
+
|
|
76
|
+
ion-icon{
|
|
77
|
+
color: var(--sidebar-icon-color);
|
|
78
|
+
&:hover {
|
|
79
|
+
opacity: 0.8 !important;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
75
82
|
}
|
|
76
83
|
|
|
77
84
|
.availability-section {
|
|
78
85
|
// top: 320px;
|
|
79
86
|
text-align: center;
|
|
80
|
-
background-color:
|
|
87
|
+
background-color: var(--user-detail-select-background);
|
|
81
88
|
padding: 4px 0px;
|
|
82
89
|
width: 192px;
|
|
83
90
|
border-radius: 4px;
|
|
@@ -91,14 +98,14 @@ ion-toolbar{
|
|
|
91
98
|
.first-divider {
|
|
92
99
|
// margin-top: 365px;
|
|
93
100
|
border: 0;
|
|
94
|
-
border-top: 1px solid
|
|
101
|
+
border-top: 1px solid var(--border-color-base);
|
|
95
102
|
margin-bottom: 20px;
|
|
96
103
|
}
|
|
97
104
|
|
|
98
105
|
.user-details-plan-info {
|
|
99
106
|
font-size: 13px;
|
|
100
107
|
text-transform: capitalize;
|
|
101
|
-
color:
|
|
108
|
+
color: var(--sidebar-user-detail-color);
|
|
102
109
|
font-weight: 500;
|
|
103
110
|
line-height: 21px;
|
|
104
111
|
}
|
|
@@ -125,12 +132,15 @@ ion-toolbar{
|
|
|
125
132
|
z-index: 1;
|
|
126
133
|
// bottom: 50px;
|
|
127
134
|
// bottom: 55px;
|
|
135
|
+
:hover .user-details-logout-icon,
|
|
136
|
+
:hover .user-details-logout-text{
|
|
137
|
+
color: var(--sidebar-hover-icon-color);
|
|
138
|
+
}
|
|
128
139
|
|
|
129
140
|
}
|
|
130
141
|
|
|
131
142
|
.logout-btn-wpr {
|
|
132
143
|
cursor: pointer;
|
|
133
|
-
color: #fff;
|
|
134
144
|
}
|
|
135
145
|
|
|
136
146
|
.footer-margin-top-pricing-no-visible {
|
|
@@ -138,13 +148,16 @@ ion-toolbar{
|
|
|
138
148
|
}
|
|
139
149
|
|
|
140
150
|
.user-details-logout-icon {
|
|
141
|
-
color:
|
|
151
|
+
color: var(--sidebar-icon-color);
|
|
142
152
|
font-size: 30px;
|
|
143
153
|
// margin-top: 30px;
|
|
144
154
|
}
|
|
145
155
|
|
|
146
156
|
.user-details-logout-icon:hover {
|
|
147
|
-
color:
|
|
157
|
+
color: var(--sidebar-icon-color);
|
|
158
|
+
}
|
|
159
|
+
.user-details-logout-text{
|
|
160
|
+
color: var(--sidebar-icon-color);
|
|
148
161
|
}
|
|
149
162
|
|
|
150
163
|
|
|
@@ -152,7 +165,7 @@ ion-toolbar{
|
|
|
152
165
|
width: 100%;
|
|
153
166
|
height: 100%;
|
|
154
167
|
font-family: "Poppins";
|
|
155
|
-
--ion-background-color
|
|
168
|
+
--ion-background-color:var(--sidebar-background-color);
|
|
156
169
|
|
|
157
170
|
.buttons-header{
|
|
158
171
|
position: absolute;
|
|
@@ -161,7 +174,6 @@ ion-toolbar{
|
|
|
161
174
|
}
|
|
162
175
|
|
|
163
176
|
.content-user-profile {
|
|
164
|
-
background-color: #2d323e;
|
|
165
177
|
width: 100%;
|
|
166
178
|
height: 230px;
|
|
167
179
|
.user {
|
|
@@ -173,23 +185,31 @@ ion-toolbar{
|
|
|
173
185
|
min-height: 160px;
|
|
174
186
|
max-height: 160px;
|
|
175
187
|
display: block;
|
|
176
|
-
background-color:
|
|
177
|
-
color:
|
|
188
|
+
background-color: var(--sidebar-header-background);
|
|
189
|
+
color: var(--sidebar-color);
|
|
178
190
|
padding-top: 40px;
|
|
179
191
|
}
|
|
180
192
|
.email {
|
|
181
|
-
|
|
182
|
-
font-size: 13px;
|
|
193
|
+
font-size: 14px;
|
|
183
194
|
margin-top: 5px;
|
|
184
|
-
font-
|
|
185
|
-
|
|
186
|
-
|
|
195
|
+
font-family: "Poppins";
|
|
196
|
+
font-weight: 400;
|
|
197
|
+
line-height: 19px;
|
|
198
|
+
white-space: nowrap;
|
|
199
|
+
white-space: nowrap;
|
|
200
|
+
overflow: hidden;
|
|
201
|
+
text-overflow: ellipsis;
|
|
187
202
|
}
|
|
188
203
|
.username {
|
|
189
204
|
font-size: 16px;
|
|
190
|
-
font-
|
|
205
|
+
font-family: "Poppins";
|
|
206
|
+
font-weight: 500;
|
|
207
|
+
line-height: 24px;
|
|
208
|
+
white-space: nowrap;
|
|
191
209
|
margin-top: 15px;
|
|
192
210
|
margin-bottom: 5px;
|
|
211
|
+
overflow: hidden;
|
|
212
|
+
text-overflow: ellipsis;
|
|
193
213
|
}
|
|
194
214
|
|
|
195
215
|
// ion-toolbar {
|
|
@@ -203,8 +223,8 @@ ion-toolbar{
|
|
|
203
223
|
}
|
|
204
224
|
|
|
205
225
|
.avatar-container {
|
|
206
|
-
background-color:
|
|
207
|
-
color:
|
|
226
|
+
background-color: var(--sidebar-header-background);
|
|
227
|
+
color: var(--sidebar-color);
|
|
208
228
|
text-align: center;
|
|
209
229
|
position: absolute;
|
|
210
230
|
top: 110px;
|
|
@@ -215,9 +235,7 @@ ion-toolbar{
|
|
|
215
235
|
left: 50%;
|
|
216
236
|
min-width: 100px;
|
|
217
237
|
min-height: 100px;
|
|
218
|
-
border
|
|
219
|
-
border-style: solid;
|
|
220
|
-
border-width: 2px;
|
|
238
|
+
border: 2px solid var(--sidebar-header-background);
|
|
221
239
|
line-height: 100px;
|
|
222
240
|
font-size: 32px;
|
|
223
241
|
}
|
|
@@ -333,11 +351,11 @@ ion-toolbar{
|
|
|
333
351
|
|
|
334
352
|
}
|
|
335
353
|
ion-footer{
|
|
336
|
-
--
|
|
354
|
+
background-color: var(--sidebar-background-color);
|
|
337
355
|
.content-chat-version {
|
|
338
|
-
color:
|
|
356
|
+
color: var(--sidebar-color);;
|
|
339
357
|
padding: 20px;
|
|
340
|
-
|
|
358
|
+
text-align: center;
|
|
341
359
|
}
|
|
342
360
|
.chat-title{
|
|
343
361
|
font-size: 14px;
|
|
@@ -22,6 +22,7 @@ import { LoggerService } from 'src/chat21-core/providers/abstract/logger.service
|
|
|
22
22
|
import { LoggerInstance } from 'src/chat21-core/providers/logger/loggerInstance';
|
|
23
23
|
import { WebsocketService } from 'src/app/services/websocket/websocket.service';
|
|
24
24
|
import { checkPlatformIsMobile, setLastDateWithLabels } from 'src/chat21-core/utils/utils';
|
|
25
|
+
import { Project } from 'src/chat21-core/models/projects';
|
|
25
26
|
|
|
26
27
|
@Component({
|
|
27
28
|
selector: 'app-profile-info',
|
|
@@ -45,7 +46,7 @@ export class ProfileInfoPage implements OnInit {
|
|
|
45
46
|
@Input() selectedStatus: number;
|
|
46
47
|
@Input() profile_name_translated: string;
|
|
47
48
|
@Input() token: string;
|
|
48
|
-
@Input() project:
|
|
49
|
+
@Input() project: Project;
|
|
49
50
|
|
|
50
51
|
isVisiblePAY: boolean;
|
|
51
52
|
teammateStatus = [
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
<ion-header>
|
|
2
2
|
<ion-toolbar [class.mobile]="isMobile">
|
|
3
|
+
<ion-buttons slot="start">
|
|
4
|
+
<ion-button ion-button fill="clear" (click)="onClose()">
|
|
5
|
+
<ion-icon slot="icon-only" name="close"></ion-icon>
|
|
6
|
+
</ion-button>
|
|
7
|
+
</ion-buttons>
|
|
3
8
|
<ion-title *ngIf="callerBtn !== 'pinbtn'" style="font-size: 16px;">
|
|
4
9
|
{{translationMap?.get('UnassignedConversations') }}
|
|
5
10
|
</ion-title>
|
|
6
11
|
<ion-title *ngIf="callerBtn === 'pinbtn'" style="font-size: 16px;">
|
|
7
12
|
{{translationMap?.get('PIN_A_PROJECT') }}
|
|
8
13
|
</ion-title>
|
|
9
|
-
<ion-buttons slot="end">
|
|
10
|
-
<ion-button ion-button fill="clear" (click)="onClose()">
|
|
11
|
-
<ion-icon slot="icon-only" name="close"></ion-icon>
|
|
12
|
-
</ion-button>
|
|
13
|
-
</ion-buttons>
|
|
14
14
|
</ion-toolbar>
|
|
15
15
|
</ion-header>
|
|
16
16
|
|
|
@@ -9,7 +9,7 @@ ion-toolbar {
|
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
ion-button{
|
|
12
|
-
--color: var(--
|
|
12
|
+
--color: var(--icon-color);
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
|
|
@@ -18,7 +18,7 @@ ion-content {
|
|
|
18
18
|
--overflow: hidden;
|
|
19
19
|
overflow: scroll;
|
|
20
20
|
&:not(.mobile){
|
|
21
|
-
background: var(--list-bkg-color);
|
|
21
|
+
--background: var(--list-bkg-color);
|
|
22
22
|
}
|
|
23
23
|
|
|
24
24
|
&::-webkit-scrollbar {
|