2021-01-21 15:00:38 +01:00
|
|
|
<ion-header>
|
|
|
|
<ion-toolbar>
|
|
|
|
<ion-buttons slot="start">
|
2021-04-27 15:21:09 +02:00
|
|
|
<ion-back-button [text]="'core.back' | translate"></ion-back-button>
|
2021-01-21 15:00:38 +01:00
|
|
|
</ion-buttons>
|
2021-05-20 11:00:24 +02:00
|
|
|
<h1>{{ 'addon.messages.searchcombined' | translate }}</h1>
|
2021-01-21 15:00:38 +01:00
|
|
|
<ion-buttons slot="end">
|
2021-01-28 17:23:57 +01:00
|
|
|
<!-- Add an empty context menu so discussion page can add items in split view,
|
|
|
|
otherwise the menu disappears in some cases. -->
|
2021-01-21 15:00:38 +01:00
|
|
|
<core-context-menu></core-context-menu>
|
|
|
|
</ion-buttons>
|
|
|
|
</ion-toolbar>
|
|
|
|
</ion-header>
|
|
|
|
<ion-content>
|
2021-01-26 12:39:48 +01:00
|
|
|
<core-split-view>
|
2021-01-28 17:23:57 +01:00
|
|
|
<core-search-box (onSubmit)="search($event)" (onClear)="clearSearch()" [disabled]="disableSearch" autocorrect="off"
|
2021-05-13 14:12:42 +02:00
|
|
|
[spellcheck]="false" [autoFocus]="true" [lengthCheck]="1" searchArea="AddonMessagesSearch"></core-search-box>
|
2021-01-21 15:00:38 +01:00
|
|
|
|
2021-01-26 12:39:48 +01:00
|
|
|
<core-loading [hideUntil]="!displaySearching" [message]="'core.searching' | translate">
|
|
|
|
<ion-list *ngIf="displayResults">
|
|
|
|
<ng-container *ngTemplateOutlet="resultsTemplate; context: {item: contacts}"></ng-container>
|
|
|
|
<ng-container *ngTemplateOutlet="resultsTemplate; context: {item: nonContacts}"></ng-container>
|
|
|
|
<ng-container *ngTemplateOutlet="resultsTemplate; context: {item: messages}"></ng-container>
|
|
|
|
<!-- The infinite loading cannot be inside the ng-template, it fails because it doesn't find ion-content. -->
|
|
|
|
<core-infinite-loading [enabled]="messages.canLoadMore" (action)="search(query, 'messages', $event)"
|
|
|
|
[error]="messages.loadMoreError"></core-infinite-loading>
|
|
|
|
</ion-list>
|
2021-01-21 15:00:38 +01:00
|
|
|
|
2021-01-26 12:39:48 +01:00
|
|
|
<core-empty-box
|
|
|
|
*ngIf="displayResults && !contacts.results.length && !nonContacts.results.length && !messages.results.length"
|
|
|
|
icon="fas-search" [message]="'core.noresults' | translate">
|
|
|
|
</core-empty-box>
|
|
|
|
</core-loading>
|
|
|
|
</core-split-view>
|
2021-01-21 15:00:38 +01:00
|
|
|
</ion-content>
|
|
|
|
|
|
|
|
<!-- Template to render a list of results -->
|
|
|
|
<ng-template #resultsTemplate let-item="item">
|
|
|
|
<ng-container *ngIf="item.results.length > 0">
|
|
|
|
<ion-item-divider class="ion-text-wrap">
|
2021-05-06 14:52:50 +02:00
|
|
|
<ion-label><h2>{{ item.titleString | translate }}</h2></ion-label>
|
2021-01-21 15:00:38 +01:00
|
|
|
</ion-item-divider>
|
|
|
|
|
|
|
|
<!-- List of results -->
|
2021-04-29 13:52:38 +02:00
|
|
|
<ion-item class="addon-message-discussion ion-text-wrap" *ngFor="let result of item.results" [attr.aria-label]="result.fullname"
|
2021-05-13 14:12:42 +02:00
|
|
|
(click)="openConversation(result)" [attr.aria-current]="result == selectedResult ? 'page' : 'false'" detail="true"
|
2021-04-29 13:52:38 +02:00
|
|
|
button>
|
2021-01-21 15:00:38 +01:00
|
|
|
<core-user-avatar slot="start" [user]="result" [checkOnline]="true" [linkProfile]="false"></core-user-avatar>
|
|
|
|
<ion-label>
|
2021-05-20 09:56:54 +02:00
|
|
|
<p class="item-heading">
|
2021-04-27 13:14:31 +02:00
|
|
|
<core-format-text [text]="result.fullname" [highlight]="result.highlightName" [filter]="false">
|
|
|
|
</core-format-text>
|
|
|
|
<ion-icon name="fa-ban" *ngIf="result.isblocked"
|
|
|
|
[attr.aria-label]="'addon.messages.contactblocked' | translate">
|
2021-01-21 15:00:38 +01:00
|
|
|
</ion-icon>
|
2021-05-20 09:56:54 +02:00
|
|
|
</p>
|
2021-01-21 15:00:38 +01:00
|
|
|
<ion-note *ngIf="result.lastmessagedate > 0">
|
|
|
|
{{result.lastmessagedate | coreDateDayOrTime}}
|
|
|
|
</ion-note>
|
|
|
|
<p class="addon-message-last-message">
|
2021-01-28 17:23:57 +01:00
|
|
|
<span *ngIf="result.sentfromcurrentuser" class="addon-message-last-message-user">
|
|
|
|
{{ 'addon.messages.you' | translate }}
|
|
|
|
</span>
|
|
|
|
<core-format-text clean="true" singleLine="true" [text]="result.lastmessage"
|
|
|
|
[highlight]="result.highlightMessage" contextLevel="system" [contextInstanceId]="0"
|
|
|
|
class="addon-message-last-message-text"></core-format-text>
|
2021-01-21 15:00:38 +01:00
|
|
|
</p>
|
|
|
|
</ion-label>
|
|
|
|
</ion-item>
|
|
|
|
|
|
|
|
<!-- Load more button for contacts and non-contacts -->
|
|
|
|
<ng-container *ngIf="item.type != 'messages'">
|
|
|
|
<div class="ion-padding-horizontal" *ngIf="item.canLoadMore && !item.loadingMore">
|
|
|
|
<ion-button expand="block" color="light" (click)="search(query, item.type)">
|
|
|
|
{{ 'core.loadmore' | translate }}
|
|
|
|
</ion-button>
|
|
|
|
</div>
|
|
|
|
<div *ngIf="item.loadingMore" class="ion-padding ion-text-center">
|
2021-06-11 13:13:15 +02:00
|
|
|
<ion-spinner [attr.aria-label]="'core.loading' | translate"></ion-spinner>
|
2021-01-21 15:00:38 +01:00
|
|
|
</div>
|
|
|
|
</ng-container>
|
|
|
|
</ng-container>
|
|
|
|
</ng-template>
|