forked from EVOgeek/Vmeda.Online
270 lines
8.1 KiB
TypeScript
270 lines
8.1 KiB
TypeScript
// (C) Copyright 2015 Moodle Pty Ltd.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
import { Component, OnDestroy, OnInit } from '@angular/core';
|
|
import { IonRefresher } from '@ionic/angular';
|
|
import { CoreSites } from '@services/sites';
|
|
import {
|
|
AddonMessagesProvider,
|
|
AddonMessagesGetContactsWSResponse,
|
|
AddonMessagesSearchContactsContact,
|
|
AddonMessagesGetContactsContact,
|
|
AddonMessages,
|
|
} from '../../services/messages';
|
|
import { CoreDomUtils } from '@services/utils/dom';
|
|
import { CoreApp } from '@services/app';
|
|
import { CoreEventObserver, CoreEvents } from '@singletons/events';
|
|
import { ActivatedRoute, Params } from '@angular/router';
|
|
import { Translate } from '@singletons';
|
|
import { CoreScreen } from '@services/screen';
|
|
import { CoreNavigator } from '@services/navigator';
|
|
|
|
/**
|
|
* Page that displays the list of contacts.
|
|
*/
|
|
@Component({
|
|
selector: 'addon-messages-contacts',
|
|
templateUrl: 'contacts.html',
|
|
styleUrls: ['../../messages-common.scss'],
|
|
})
|
|
export class AddonMessagesContacts35Page implements OnInit, OnDestroy {
|
|
|
|
protected searchingMessages: string;
|
|
protected loadingMessages: string;
|
|
protected siteId: string;
|
|
protected noSearchTypes = ['online', 'offline', 'blocked', 'strangers'];
|
|
protected memberInfoObserver: CoreEventObserver;
|
|
|
|
loaded = false;
|
|
discussionUserId?: number;
|
|
contactTypes = ['online', 'offline', 'blocked', 'strangers'];
|
|
searchType = 'search';
|
|
loadingMessage = '';
|
|
hasContacts = false;
|
|
contacts: AddonMessagesGetContactsFormatted = {
|
|
online: [],
|
|
offline: [],
|
|
strangers: [],
|
|
search: [],
|
|
};
|
|
|
|
searchString = '';
|
|
|
|
constructor(
|
|
protected route: ActivatedRoute,
|
|
) {
|
|
this.siteId = CoreSites.getCurrentSiteId();
|
|
this.searchingMessages = Translate.instant('core.searching');
|
|
this.loadingMessages = Translate.instant('core.loading');
|
|
this.loadingMessage = this.loadingMessages;
|
|
|
|
// Refresh the list when a contact request is confirmed.
|
|
this.memberInfoObserver = CoreEvents.on(
|
|
AddonMessagesProvider.MEMBER_INFO_CHANGED_EVENT,
|
|
(data) => {
|
|
if (data.contactRequestConfirmed) {
|
|
this.refreshData();
|
|
}
|
|
},
|
|
CoreSites.getCurrentSiteId(),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Component loaded.
|
|
*/
|
|
async ngOnInit(): Promise<void> {
|
|
const discussionUserId = CoreNavigator.getRouteNumberParam('discussionUserId') ||
|
|
CoreNavigator.getRouteNumberParam('userId') || undefined;
|
|
|
|
if (this.loaded && this.discussionUserId == discussionUserId) {
|
|
return;
|
|
}
|
|
|
|
this.discussionUserId = discussionUserId;
|
|
|
|
if (this.discussionUserId) {
|
|
// There is a discussion to load, open the discussion in a new state.
|
|
this.gotoDiscussion(this.discussionUserId);
|
|
}
|
|
|
|
try {
|
|
await this.fetchData();
|
|
if (!this.discussionUserId && this.hasContacts && CoreScreen.isTablet) {
|
|
let contact: AddonMessagesGetContactsContact | undefined;
|
|
for (const x in this.contacts) {
|
|
if (this.contacts[x].length > 0) {
|
|
contact = this.contacts[x][0];
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (contact) {
|
|
// Take first and load it.
|
|
this.gotoDiscussion(contact.id);
|
|
}
|
|
}
|
|
} finally {
|
|
this.loaded = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Refresh the data.
|
|
*
|
|
* @param refresher Refresher.
|
|
* @return Promise resolved when done.
|
|
*/
|
|
async refreshData(refresher?: IonRefresher): Promise<void> {
|
|
try {
|
|
if (this.searchString) {
|
|
// User has searched, update the search.
|
|
await this.performSearch(this.searchString);
|
|
} else {
|
|
// Update contacts.
|
|
await AddonMessages.invalidateAllContactsCache();
|
|
await this.fetchData();
|
|
}
|
|
} finally {
|
|
refresher?.complete();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Fetch contacts.
|
|
*
|
|
* @return Promise resolved when done.
|
|
*/
|
|
protected async fetchData(): Promise<void> {
|
|
this.loadingMessage = this.loadingMessages;
|
|
|
|
try {
|
|
const contacts = await AddonMessages.getAllContacts();
|
|
for (const x in contacts) {
|
|
if (contacts[x].length > 0) {
|
|
this.contacts[x] = this.sortUsers(contacts[x]);
|
|
} else {
|
|
this.contacts[x] = [];
|
|
}
|
|
}
|
|
|
|
this.clearSearch();
|
|
} catch (error) {
|
|
CoreDomUtils.showErrorModalDefault(error, 'addon.messages.errorwhileretrievingcontacts', true);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Sort user list by fullname
|
|
*
|
|
* @param list List to sort.
|
|
* @return Sorted list.
|
|
*/
|
|
protected sortUsers(list: AddonMessagesSearchContactsContact[]): AddonMessagesSearchContactsContact[] {
|
|
return list.sort((a, b) => {
|
|
const compareA = a.fullname.toLowerCase();
|
|
const compareB = b.fullname.toLowerCase();
|
|
|
|
return compareA.localeCompare(compareB);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Clear search and show all contacts again.
|
|
*/
|
|
clearSearch(): void {
|
|
this.searchString = ''; // Reset searched string.
|
|
this.contactTypes = this.noSearchTypes;
|
|
|
|
this.hasContacts = false;
|
|
for (const x in this.contacts) {
|
|
if (this.contacts[x].length > 0) {
|
|
this.hasContacts = true;
|
|
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Search users from the UI.
|
|
*
|
|
* @param query Text to search for.
|
|
* @return Resolved when done.
|
|
*/
|
|
search(query: string): Promise<void> {
|
|
CoreApp.closeKeyboard();
|
|
|
|
this.loaded = false;
|
|
this.loadingMessage = this.searchingMessages;
|
|
|
|
return this.performSearch(query).finally(() => {
|
|
this.loaded = true;
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Perform the search of users.
|
|
*
|
|
* @param query Text to search for.
|
|
* @return Resolved when done.
|
|
*/
|
|
protected async performSearch(query: string): Promise<void> {
|
|
try {
|
|
const result = await AddonMessages.searchContacts(query);
|
|
this.hasContacts = result.length > 0;
|
|
this.searchString = query;
|
|
this.contactTypes = ['search'];
|
|
|
|
this.contacts.search = this.sortUsers(result);
|
|
} catch (error) {
|
|
CoreDomUtils.showErrorModalDefault(error, 'addon.messages.errorwhileretrievingcontacts', true);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Navigate to a particular discussion.
|
|
*
|
|
* @param discussionUserId Discussion Id to load.
|
|
*/
|
|
gotoDiscussion(discussionUserId: number): void {
|
|
this.discussionUserId = discussionUserId;
|
|
|
|
const params: Params = {
|
|
userId: discussionUserId,
|
|
};
|
|
|
|
const splitViewLoaded = CoreNavigator.isCurrentPathInTablet('**/messages/contacts-35/discussion');
|
|
const path = (splitViewLoaded ? '../' : '') + 'discussion';
|
|
|
|
// @todo Check why this is failing on ngInit.
|
|
CoreNavigator.navigate(path, { params });
|
|
}
|
|
|
|
/**
|
|
* Component destroyed.
|
|
*/
|
|
ngOnDestroy(): void {
|
|
this.memberInfoObserver?.off();
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Contacts with some calculated data.
|
|
*/
|
|
export type AddonMessagesGetContactsFormatted = AddonMessagesGetContactsWSResponse & {
|
|
search?: AddonMessagesSearchContactsContact[]; // Calculated in the app. Result of searching users.
|
|
};
|