Files
doneit-web/src/app/pages/chat/chat.page.html
T

154 lines
6.8 KiB
HTML
Raw Normal View History

2021-03-04 18:50:26 +01:00
<ion-header class="ion-no-border">
<app-header></app-header>
</ion-header>
2020-09-10 09:48:37 +01:00
2021-03-04 15:24:47 +01:00
<ion-content class="height-100">
2021-06-03 16:23:18 +01:00
<ion-refresher name="refresher" slot="fixed" (ionRefresh)="doRefresh()">
2021-01-27 16:01:49 +01:00
<ion-progress-bar type="indeterminate" *ngIf="showLoader"></ion-progress-bar>
<ion-refresher-content>
</ion-refresher-content>
</ion-refresher>
2021-03-05 11:58:59 +01:00
<div class="main-content d-flex height-100">
<!-- Aside left -->
2021-05-19 12:53:50 +01:00
<div class="aside-wrapper d-flex flex-column pt-25 flex-grow-1">
2021-03-05 16:43:07 +01:00
<!-- <p class="text-center mt-0 aside-title px-20">Chat</p> -->
<div class="title-content">
<div class="div-title">
<ion-label class="title">Chat</ion-label>
</div>
<div class="div-icon">
2021-04-09 08:59:22 +01:00
<button class="btn-no-color" (click)="openContactsPage()">
<ion-icon slot="end" src="assets/images/icons-chat-new-conversation.svg"></ion-icon>
</button>
<button class="btn-no-color" (click)="openNewGroupPage()">
<ion-icon slot="end" src="assets/images/icons-chat-new-group.svg" ></ion-icon>
</button>
2021-06-17 16:43:18 +01:00
<button *ngIf="hideRefreshBtn" class="btn-no-color" (click)="doRefresh()">
2021-04-09 09:31:01 +01:00
<ion-icon class="title-icon" name="reload-circle"></ion-icon>
</button>
2021-03-05 16:43:07 +01:00
</div>
</div>
<ion-toolbar>
2021-03-04 15:24:47 +01:00
<ion-segment [(ngModel)]="segment" (ionChange)="onSegmentChange()">
<ion-segment-button value="Contactos">
Conversas
</ion-segment-button>
<ion-segment-button value="Grupos">
Grupos
</ion-segment-button>
</ion-segment>
</ion-toolbar>
2021-05-25 15:54:30 +01:00
<div class="overflow-y-auto d-flex flex-wrap flex-grow-1">
2021-03-05 11:58:59 +01:00
<div class="width-100" [ngSwitch]="segment">
2021-03-04 15:24:47 +01:00
<ion-list *ngSwitchCase="'Contactos'">
<ion-item-group>
<ion-item-sliding>
2021-07-26 20:46:14 +01:00
<ion-item class="item width-100 d-flex" *ngFor="let dm of userDirectMessages">
2021-03-04 15:24:47 +01:00
<div class="item-icon">
<ion-icon class="icon" slot="start" src="assets/images/icons-chat-chat-40.svg"></ion-icon>
</div>
2021-05-21 11:20:15 +01:00
<div (click)="openMessagesPage(dm._id)" class="item-content flex-grow-1"><!-- (click)="openMessages(dm)" -->
2021-03-04 15:24:47 +01:00
<div class="item-title-time">
<div class="item-title">
<ion-label *ngFor="let user of dm.usernames">
2021-06-04 11:37:56 +01:00
<span *ngIf="user !=loggedUserChat.me.username">
2021-03-04 15:24:47 +01:00
{{user}}
</span>
</ion-label>
</div>
<div class="item-date">{{dm._updatedAt | date: 'HH:mm'}}</div>
</div>
<div class="item-description">
<ion-label *ngIf="dm.lastMessage">{{dm.lastMessage.msg}}</ion-label>
</div>
</div>
2021-07-26 20:46:14 +01:00
</ion-item>
2021-03-04 15:24:47 +01:00
</ion-item-sliding>
</ion-item-group>
</ion-list>
<ion-list *ngSwitchCase="'Grupos'" >
<ion-item-group>
<ion-item-sliding>
2021-05-21 11:20:15 +01:00
<div *ngFor="let group of allGroups" class="item d-flex">
2021-03-04 15:24:47 +01:00
<div class="item-icon">
<ion-icon class="icon" slot="start" src="assets/images/icons-chat-group-chat-40.svg"></ion-icon>
</div>
2021-05-21 11:20:15 +01:00
<div (click)="openGroupMessagesPage(group._id)" class="item-content flex-grow-1">
2021-03-04 15:24:47 +01:00
<div class="item-title-time">
<div class="item-title">
<ion-label>{{group.name.split('-').join(' ')}}</ion-label>
</div>
<div class="item-date" *ngIf="group.lastMessage">{{group.lastMessage._updatedAt | date: 'HH:mm'}}</div>
</div>
<div class="item-description" *ngIf="group.lastMessage">
<ion-label>{{group.lastMessage.u.name}}: {{group.lastMessage.msg}}</ion-label>
</div>
</div>
2021-07-22 17:11:41 +01:00
</div>
2021-03-04 15:24:47 +01:00
</ion-item-sliding>
</ion-item-group>
2021-07-22 17:11:41 +01:00
2021-03-04 15:24:47 +01:00
</ion-list>
</div>
2021-07-22 17:11:41 +01:00
<!-- <button (click)="sendMsg()" style="height: 41px;">Send message</button> -->
2021-03-04 15:24:47 +01:00
</div>
</div>
2021-03-05 11:58:59 +01:00
<!-- Aside right -->
2021-03-11 16:21:09 +01:00
<div class="aside-content d-none flex-column height-100">
2021-07-22 17:11:41 +01:00
<app-empty-chat [texto]="emptyTextDescription"
class="height-100 flex-column"
2021-07-16 21:17:34 +01:00
[style.display]="showEmptyComponent ? 'flex' : 'none'"
#messagecontainer>
2021-04-16 11:25:10 +01:00
</app-empty-chat>
2021-07-22 17:11:41 +01:00
<app-messages class=" height-100 flex-column"
2021-07-26 12:12:59 +01:00
*ngIf="showMessages"
[style.display]="showMessages ? 'flex' : 'none'"
2021-07-26 13:01:13 +01:00
(closeAllDesktopComponents)="closeAllDesktopComponents()"
(showEmptyContainer)="showEmptyContainer()"
[style.display]="showMessages ? 'flex' : 'none'"
2021-07-26 19:31:19 +01:00
[roomId]="roomId"
[showMessages]="showMessages" #messagecontainer>
2021-04-16 11:25:10 +01:00
</app-messages>
2021-07-22 17:11:41 +01:00
<app-contacts
(openMessage)="openMessagesPage($event)"
2021-07-26 12:12:59 +01:00
*ngIf="showContacts"
2021-07-16 21:17:34 +01:00
[style.display]="showContacts ? 'flex' : 'none'"
class=" height-100 flex-column">
2021-04-16 11:25:10 +01:00
</app-contacts>
2021-07-22 17:11:41 +01:00
<app-new-group
(addGroupMessage)="openGroupContactsPage($event)"
2021-07-16 21:17:34 +01:00
[style.display]="showNewGroup ? 'flex' : 'none'"
class=" height-100 flex-column">
2021-04-16 11:25:10 +01:00
</app-new-group>
<app-edit-group [roomId]="roomId"
(closeAllDesktopComponents)="closeAllDesktopComponents()"
2021-07-16 21:17:34 +01:00
(openGroupMessage)="openGroupMessagesPage($event)"
2021-07-26 12:12:59 +01:00
*ngIf="showEditGroup"
2021-07-16 21:17:34 +01:00
[style.display]="showEditGroup ? 'flex' : 'none'"
class="height-100 flex-column">
2021-04-16 11:25:10 +01:00
</app-edit-group>
2021-07-22 17:11:41 +01:00
<app-group-contacts
(openGroupMessage)="openGroupMessagesPage($event)"
2021-07-26 12:12:59 +01:00
*ngIf="showGroupContacts"
2021-07-16 21:17:34 +01:00
[style.display]="showGroupContacts ? 'flex' : 'none'"
2021-07-22 17:11:41 +01:00
[roomId]="groupRoomId" class=" height-100 flex-column"
2021-07-16 21:17:34 +01:00
>
2021-04-16 11:25:10 +01:00
</app-group-contacts>
2021-04-15 23:57:14 +01:00
<app-group-messages
2021-07-26 12:12:59 +01:00
*ngIf="showGroupMessages"
2021-07-16 21:17:34 +01:00
[style.display]="showEmptyComponent ? 'flex' : 'none'"
2021-04-15 23:57:14 +01:00
(closeAllDesktopComponents)="closeAllDesktopComponents()"
(showEmptyContainer)="showEmptyContainer()"
2021-04-16 11:25:10 +01:00
(openGroupContacts)="openGroupContactsPage($event)"
(openEditGroupPage)="openEditGroupPage($event)"
2021-07-16 21:17:34 +01:00
[style.display]="showGroupMessages ? 'flex' : 'none'"
2021-07-22 17:11:41 +01:00
class=" height-100 flex-column"
2021-04-16 11:25:10 +01:00
[roomId]="roomId" #messagecontainer>
</app-group-messages>
2021-03-04 15:24:47 +01:00
</div>
</div>
2020-09-10 09:48:37 +01:00
</ion-content>
2020-12-28 10:11:00 +01:00