2018-02-09 10:02:14 +01:00
|
|
|
// (C) Copyright 2015 Martin Dougiamas
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
2018-03-14 10:32:05 +01:00
|
|
|
import { Injectable } from '@angular/core';
|
2018-02-09 10:02:14 +01:00
|
|
|
import { AddonMessagesProvider } from './messages';
|
2018-02-23 13:02:56 +01:00
|
|
|
import { CoreMainMenuDelegate, CoreMainMenuHandler, CoreMainMenuHandlerToDisplay } from '@core/mainmenu/providers/delegate';
|
|
|
|
import { CoreCronHandler } from '@providers/cron';
|
|
|
|
import { CoreSitesProvider } from '@providers/sites';
|
|
|
|
import { CoreEventsProvider } from '@providers/events';
|
|
|
|
import { CoreAppProvider } from '@providers/app';
|
|
|
|
import { CoreTextUtilsProvider } from '@providers/utils/text';
|
2018-03-01 16:55:49 +01:00
|
|
|
import { CoreUtilsProvider } from '@providers/utils/utils';
|
2018-02-23 13:02:56 +01:00
|
|
|
import { CoreLocalNotificationsProvider } from '@providers/local-notifications';
|
2018-02-23 14:44:17 +01:00
|
|
|
import { AddonPushNotificationsProvider } from '@addon/pushnotifications/providers/pushnotifications';
|
2018-03-01 16:55:49 +01:00
|
|
|
import { AddonPushNotificationsDelegate } from '@addon/pushnotifications/providers/delegate';
|
2018-02-09 10:02:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Handler to inject an option into main menu.
|
|
|
|
*/
|
|
|
|
@Injectable()
|
2018-02-22 15:21:22 +01:00
|
|
|
export class AddonMessagesMainMenuHandler implements CoreMainMenuHandler, CoreCronHandler {
|
2018-02-09 10:02:14 +01:00
|
|
|
name = 'AddonMessages';
|
2018-02-28 17:02:39 +01:00
|
|
|
priority = 800;
|
2018-03-14 11:29:22 +01:00
|
|
|
protected handler: CoreMainMenuHandlerToDisplay = {
|
|
|
|
icon: 'chatbubbles',
|
|
|
|
title: 'addon.messages.messages',
|
|
|
|
page: 'AddonMessagesIndexPage',
|
|
|
|
class: 'addon-messages-handler',
|
|
|
|
showBadge: true, // Do not check isMessageCountEnabled because we'll use fallback it not enabled.
|
|
|
|
badge: '',
|
|
|
|
loading: true
|
|
|
|
};
|
2018-02-09 10:02:14 +01:00
|
|
|
|
2018-02-22 15:21:22 +01:00
|
|
|
constructor(private messagesProvider: AddonMessagesProvider, private sitesProvider: CoreSitesProvider,
|
|
|
|
private eventsProvider: CoreEventsProvider, private appProvider: CoreAppProvider,
|
2018-02-23 14:44:17 +01:00
|
|
|
private localNotificationsProvider: CoreLocalNotificationsProvider, private textUtils: CoreTextUtilsProvider,
|
2018-03-01 16:55:49 +01:00
|
|
|
private pushNotificationsProvider: AddonPushNotificationsProvider, utils: CoreUtilsProvider,
|
|
|
|
pushNotificationsDelegate: AddonPushNotificationsDelegate) {
|
2018-02-22 15:21:22 +01:00
|
|
|
|
|
|
|
eventsProvider.on(AddonMessagesProvider.READ_CHANGED_EVENT, (data) => {
|
|
|
|
this.updateBadge(data.siteId);
|
|
|
|
});
|
|
|
|
|
|
|
|
eventsProvider.on(AddonMessagesProvider.READ_CRON_EVENT, (data) => {
|
|
|
|
this.updateBadge(data.siteId);
|
|
|
|
});
|
|
|
|
|
|
|
|
// Reset info on logout.
|
|
|
|
eventsProvider.on(CoreEventsProvider.LOGOUT, (data) => {
|
2018-03-14 11:29:22 +01:00
|
|
|
this.handler.badge = '';
|
|
|
|
this.handler.loading = true;
|
2018-02-22 15:21:22 +01:00
|
|
|
});
|
2018-03-01 16:55:49 +01:00
|
|
|
|
|
|
|
// If a message push notification is received, refresh the count.
|
2018-03-08 13:25:20 +01:00
|
|
|
pushNotificationsDelegate.on('receive').subscribe((notification) => {
|
2018-03-01 16:55:49 +01:00
|
|
|
// New message received. If it's from current site, refresh the data.
|
|
|
|
if (utils.isFalseOrZero(notification.notif) && this.sitesProvider.isCurrentSite(notification.site)) {
|
|
|
|
this.updateBadge(notification.site);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Register Badge counter.
|
2018-03-08 13:25:20 +01:00
|
|
|
pushNotificationsDelegate.registerCounterHandler('AddonMessages');
|
2018-02-22 15:21:22 +01:00
|
|
|
}
|
2018-02-09 10:02:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the handler is enabled on a site level.
|
|
|
|
*
|
|
|
|
* @return {boolean} Whether or not the handler is enabled on a site level.
|
|
|
|
*/
|
|
|
|
isEnabled(): boolean | Promise<boolean> {
|
|
|
|
return this.messagesProvider.isPluginEnabled();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the data needed to render the handler.
|
|
|
|
*
|
2018-02-22 15:21:22 +01:00
|
|
|
* @return {CoreMainMenuHandlerToDisplay} Data needed to render the handler.
|
2018-02-09 10:02:14 +01:00
|
|
|
*/
|
2018-02-22 15:21:22 +01:00
|
|
|
getDisplayData(): CoreMainMenuHandlerToDisplay {
|
2018-03-14 11:29:22 +01:00
|
|
|
if (this.handler.loading) {
|
2018-02-22 15:21:22 +01:00
|
|
|
this.updateBadge();
|
|
|
|
}
|
|
|
|
|
2018-03-14 11:29:22 +01:00
|
|
|
return this.handler;
|
2018-02-22 15:21:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Triggers an update for the badge number and loading status. Mandatory if showBadge is enabled.
|
|
|
|
*
|
|
|
|
* @param {string} siteId Site ID or current Site if undefined.
|
|
|
|
*/
|
|
|
|
updateBadge(siteId?: string): void {
|
|
|
|
siteId = siteId || this.sitesProvider.getCurrentSiteId();
|
|
|
|
if (!siteId) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.messagesProvider.getUnreadConversationsCount(undefined, siteId).then((unread) => {
|
|
|
|
// Leave badge enter if there is a 0+ or a 0.
|
2018-03-14 11:29:22 +01:00
|
|
|
this.handler.badge = parseInt(unread, 10) > 0 ? unread : '';
|
2018-02-22 15:21:22 +01:00
|
|
|
// Update badge.
|
2018-03-08 13:25:20 +01:00
|
|
|
this.pushNotificationsProvider.updateAddonCounter('AddonMessages', unread, siteId);
|
2018-02-22 15:21:22 +01:00
|
|
|
}).catch(() => {
|
2018-03-14 11:29:22 +01:00
|
|
|
this.handler.badge = '';
|
2018-02-22 15:21:22 +01:00
|
|
|
}).finally(() => {
|
2018-03-14 11:29:22 +01:00
|
|
|
this.handler.loading = false;
|
2018-02-22 15:21:22 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the process.
|
|
|
|
* Receives the ID of the site affected, undefined for all sites.
|
|
|
|
*
|
|
|
|
* @param {string} [siteId] ID of the site affected, undefined for all sites.
|
|
|
|
* @return {Promise<any>} Promise resolved when done, rejected if failure.
|
|
|
|
*/
|
|
|
|
execute(siteId?: string): Promise<any> {
|
|
|
|
if (this.sitesProvider.isCurrentSite(siteId)) {
|
|
|
|
this.eventsProvider.trigger(AddonMessagesProvider.READ_CRON_EVENT, undefined, siteId);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.appProvider.isDesktop() && this.localNotificationsProvider.isAvailable()) {
|
2018-03-01 16:55:49 +01:00
|
|
|
// @todo
|
2018-02-22 15:21:22 +01:00
|
|
|
/*$mmEmulatorHelper.checkNewNotifications(
|
|
|
|
AddonMessagesProvider.PUSH_SIMULATION_COMPONENT, this.fetchMessages, this.getTitleAndText, siteId);*/
|
|
|
|
}
|
|
|
|
|
|
|
|
return Promise.resolve();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the time between consecutive executions.
|
|
|
|
*
|
|
|
|
* @return {number} Time between consecutive executions (in ms).
|
|
|
|
*/
|
|
|
|
getInterval(): number {
|
|
|
|
return this.appProvider.isDesktop() ? 60000 : 600000; // 1 or 10 minutes.
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether it's a synchronization process or not.
|
|
|
|
*
|
|
|
|
* @return {boolean} True if is a sync process, false otherwise.
|
|
|
|
*/
|
|
|
|
isSync(): boolean {
|
|
|
|
// This is done to use only wifi if using the fallback function.
|
|
|
|
// In desktop it is always sync, since it fetches messages to see if there's a new one.
|
|
|
|
return !this.messagesProvider.isMessageCountEnabled() || this.appProvider.isDesktop();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the process should be executed during a manual sync.
|
|
|
|
*
|
|
|
|
* @return {boolean} True if is a manual sync process, false otherwise.
|
|
|
|
*/
|
|
|
|
canManualSync(): boolean {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the latest unread received messages from a site.
|
|
|
|
*
|
|
|
|
* @param {string} [siteId] Site ID. Default current.
|
|
|
|
* @return {Promise<any>} Promise resolved with the notifications.
|
|
|
|
*/
|
|
|
|
protected fetchMessages(siteId?: string): Promise<any> {
|
|
|
|
return this.messagesProvider.getUnreadReceivedMessages(true, false, true, siteId).then((response) => {
|
|
|
|
return response.messages;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Given a message, return the title and the text for the message.
|
|
|
|
*
|
|
|
|
* @param {any} message Message.
|
|
|
|
* @return {Promise<any>} Promise resolved with an object with title and text.
|
|
|
|
*/
|
|
|
|
protected getTitleAndText(message: any): Promise<any> {
|
|
|
|
const data = {
|
|
|
|
title: message.userfromfullname,
|
2018-02-09 10:02:14 +01:00
|
|
|
};
|
2018-02-22 15:21:22 +01:00
|
|
|
|
|
|
|
return this.textUtils.formatText(message.text, true, true).catch(() => {
|
|
|
|
return message.text;
|
|
|
|
}).then((formattedText) => {
|
|
|
|
data['text'] = formattedText;
|
|
|
|
|
|
|
|
return data;
|
|
|
|
});
|
2018-02-09 10:02:14 +01:00
|
|
|
}
|
|
|
|
}
|