forked from EVOgeek/Vmeda.Online
		
	MOBILE-2927 notifications: Make push simulation use new delegate
This commit is contained in:
		
							parent
							
								
									1146eea0fa
								
							
						
					
					
						commit
						b9aa0e0a90
					
				| @ -20,13 +20,11 @@ import { AddonNotificationsSettingsHandler } from './providers/settings-handler' | ||||
| import { AddonNotificationsCronHandler } from './providers/cron-handler'; | ||||
| import { AddonNotificationsPushClickHandler } from './providers/push-click-handler'; | ||||
| import { CoreAppProvider } from '@providers/app'; | ||||
| import { CoreContentLinksHelperProvider } from '@core/contentlinks/providers/helper'; | ||||
| import { CoreInitDelegate } from '@providers/init'; | ||||
| import { CoreMainMenuDelegate } from '@core/mainmenu/providers/delegate'; | ||||
| import { CoreSettingsDelegate } from '@core/settings/providers/delegate'; | ||||
| import { CoreCronDelegate } from '@providers/cron'; | ||||
| import { CoreLocalNotificationsProvider } from '@providers/local-notifications'; | ||||
| import { CoreSitesProvider } from '@providers/sites'; | ||||
| import { CoreUtilsProvider } from '@providers/utils/utils'; | ||||
| import { CorePushNotificationsDelegate } from '@core/pushnotifications/providers/delegate'; | ||||
| 
 | ||||
| // List of providers (without handlers).
 | ||||
| @ -53,9 +51,8 @@ export class AddonNotificationsModule { | ||||
|     constructor(mainMenuDelegate: CoreMainMenuDelegate, mainMenuHandler: AddonNotificationsMainMenuHandler, | ||||
|             settingsDelegate: CoreSettingsDelegate, settingsHandler: AddonNotificationsSettingsHandler, | ||||
|             cronDelegate: CoreCronDelegate, cronHandler: AddonNotificationsCronHandler, zone: NgZone, | ||||
|             appProvider: CoreAppProvider, utils: CoreUtilsProvider, sitesProvider: CoreSitesProvider, | ||||
|             notificationsProvider: AddonNotificationsProvider, localNotifications: CoreLocalNotificationsProvider, | ||||
|             linkHelper: CoreContentLinksHelperProvider, pushNotificationsDelegate: CorePushNotificationsDelegate, | ||||
|             appProvider: CoreAppProvider, localNotifications: CoreLocalNotificationsProvider, | ||||
|             initDelegate: CoreInitDelegate, pushNotificationsDelegate: CorePushNotificationsDelegate, | ||||
|             pushClickHandler: AddonNotificationsPushClickHandler) { | ||||
| 
 | ||||
|         mainMenuDelegate.registerHandler(mainMenuHandler); | ||||
| @ -63,22 +60,13 @@ export class AddonNotificationsModule { | ||||
|         cronDelegate.register(cronHandler); | ||||
|         pushNotificationsDelegate.registerClickHandler(pushClickHandler); | ||||
| 
 | ||||
|         const notificationClicked = (notification: any): void => { | ||||
|             sitesProvider.isFeatureDisabled('CoreMainMenuDelegate_AddonNotifications', notification.site).then((disabled) => { | ||||
|                 if (disabled) { | ||||
|                     // Notifications are disabled, stop.
 | ||||
|                     return; | ||||
|                 } | ||||
| 
 | ||||
|                 notificationsProvider.invalidateNotificationsList().finally(() => { | ||||
|                     linkHelper.goInSite(undefined, 'AddonNotificationsListPage', undefined, notification.site); | ||||
|                 }); | ||||
|             }); | ||||
|         }; | ||||
| 
 | ||||
|         if (appProvider.isDesktop()) { | ||||
|             // Listen for clicks in simulated push notifications.
 | ||||
|             localNotifications.registerClick(AddonNotificationsProvider.PUSH_SIMULATION_COMPONENT, notificationClicked); | ||||
|             localNotifications.registerClick(AddonNotificationsProvider.PUSH_SIMULATION_COMPONENT, (notification) => { | ||||
|                 initDelegate.ready().then(() => { | ||||
|                     pushNotificationsDelegate.clicked(notification); | ||||
|                 }); | ||||
|             }); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -105,7 +105,7 @@ export class AddonNotificationsCronHandler implements CoreCronHandler { | ||||
|      */ | ||||
|     protected getTitleAndText(notification: any): Promise<any> { | ||||
|         const data = { | ||||
|             title: notification.userfromfullname, | ||||
|             title: notification.subject || notification.userfromfullname, | ||||
|             text: notification.mobiletext.replace(/-{4,}/ig, '') | ||||
|         }; | ||||
|         data.text = this.textUtils.replaceNewLines(data.text, '<br>'); | ||||
|  | ||||
| @ -73,7 +73,9 @@ export class AddonNotificationsProvider { | ||||
|                 }); | ||||
|             } | ||||
| 
 | ||||
|             notification.moodlecomponent = notification.component; | ||||
|             notification.notification = 1; | ||||
|             notification.notif = 1; | ||||
|             if (typeof read != 'undefined') { | ||||
|                 notification.read = read; | ||||
|             } | ||||
|  | ||||
| @ -40,7 +40,9 @@ export class AddonNotificationsPushClickHandler implements CorePushNotifications | ||||
|     handles(notification: any): boolean | Promise<boolean> { | ||||
|         if (this.utils.isTrueOrOne(notification.notif)) { | ||||
|             // Notification clicked, mark as read. Don't block for this.
 | ||||
|             this.notificationsProvider.markNotificationRead(notification.savedmessageid, notification.site).then(() => { | ||||
|             const notifId = notification.savedmessageid || notification.id; | ||||
| 
 | ||||
|             this.notificationsProvider.markNotificationRead(notifId, notification.site).then(() => { | ||||
|                 this.eventsProvider.trigger(AddonNotificationsProvider.READ_CHANGED_EVENT, null, notification.site); | ||||
|             }).catch(() => { | ||||
|                 // Ignore errors.
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user