MOBILE-4574 badges: Support links to badges by hash
parent
e49f10e988
commit
4a3fd0f85b
|
@ -0,0 +1,33 @@
|
||||||
|
// (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 { NgModule } from '@angular/core';
|
||||||
|
import { RouterModule, Routes } from '@angular/router';
|
||||||
|
|
||||||
|
import { AddonBadgesIssuedBadgePage } from './pages/issued-badge/issued-badge';
|
||||||
|
|
||||||
|
const routes: Routes = [
|
||||||
|
{
|
||||||
|
path: ':badgeHash',
|
||||||
|
component: AddonBadgesIssuedBadgePage,
|
||||||
|
data: { usesSwipeNavigation: false },
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports: [
|
||||||
|
RouterModule.forChild(routes),
|
||||||
|
],
|
||||||
|
})
|
||||||
|
export class AddonBadgeLazyModule {}
|
|
@ -31,6 +31,7 @@ const mobileRoutes: Routes = [
|
||||||
{
|
{
|
||||||
path: ':badgeHash',
|
path: ':badgeHash',
|
||||||
component: AddonBadgesIssuedBadgePage,
|
component: AddonBadgesIssuedBadgePage,
|
||||||
|
data: { usesSwipeNavigation: true },
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -42,6 +43,7 @@ const tabletRoutes: Routes = [
|
||||||
{
|
{
|
||||||
path: ':badgeHash',
|
path: ':badgeHash',
|
||||||
component: AddonBadgesIssuedBadgePage,
|
component: AddonBadgesIssuedBadgePage,
|
||||||
|
data: { usesSwipeNavigation: true },
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
@ -59,7 +61,6 @@ const routes: Routes = [
|
||||||
],
|
],
|
||||||
declarations: [
|
declarations: [
|
||||||
AddonBadgesUserBadgesPage,
|
AddonBadgesUserBadgesPage,
|
||||||
AddonBadgesIssuedBadgePage,
|
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class AddonBadgesLazyModule {}
|
export class AddonBadgesLazyModule {}
|
||||||
|
|
|
@ -40,6 +40,10 @@ export async function getBadgesServices(): Promise<Type<unknown>[]> {
|
||||||
}
|
}
|
||||||
|
|
||||||
const mainMenuRoutes: Routes = [
|
const mainMenuRoutes: Routes = [
|
||||||
|
{
|
||||||
|
path: 'badge',
|
||||||
|
loadChildren: () => import('./badge-lazy.module').then(m => m.AddonBadgeLazyModule),
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: 'badges',
|
path: 'badges',
|
||||||
loadChildren: () => import('./badges-lazy.module').then(m => m.AddonBadgesLazyModule),
|
loadChildren: () => import('./badges-lazy.module').then(m => m.AddonBadgesLazyModule),
|
||||||
|
|
|
@ -25,15 +25,14 @@
|
||||||
</ion-item>
|
</ion-item>
|
||||||
</ion-item-group>
|
</ion-item-group>
|
||||||
|
|
||||||
<ion-item *ngIf="user">
|
|
||||||
<ion-label>
|
|
||||||
<p class="item-heading">
|
|
||||||
{{ 'addon.badges.awardedto' | translate: {$a: user.fullname } }}
|
|
||||||
</p>
|
|
||||||
</ion-label>
|
|
||||||
</ion-item>
|
|
||||||
|
|
||||||
<ng-container *ngIf="badge">
|
<ng-container *ngIf="badge">
|
||||||
|
<ion-item>
|
||||||
|
<ion-label>
|
||||||
|
<p class="item-heading">
|
||||||
|
{{ 'addon.badges.awardedto' | translate: {$a: badge.recipientfullname } }}
|
||||||
|
</p>
|
||||||
|
</ion-label>
|
||||||
|
</ion-item>
|
||||||
<ion-item-group>
|
<ion-item-group>
|
||||||
<ion-item-divider>
|
<ion-item-divider>
|
||||||
<ion-label>
|
<ion-label>
|
||||||
|
|
|
@ -16,7 +16,7 @@ import { Component, OnDestroy, OnInit } from '@angular/core';
|
||||||
import { CoreTimeUtils } from '@services/utils/time';
|
import { CoreTimeUtils } from '@services/utils/time';
|
||||||
import { CoreDomUtils } from '@services/utils/dom';
|
import { CoreDomUtils } from '@services/utils/dom';
|
||||||
import { CoreSites } from '@services/sites';
|
import { CoreSites } from '@services/sites';
|
||||||
import { CoreUser, CoreUserProfile } from '@features/user/services/user';
|
import { CoreUser } from '@features/user/services/user';
|
||||||
import { AddonBadges, AddonBadgesUserBadge } from '../../services/badges';
|
import { AddonBadges, AddonBadgesUserBadge } from '../../services/badges';
|
||||||
import { CoreUtils } from '@services/utils/utils';
|
import { CoreUtils } from '@services/utils/utils';
|
||||||
import { CoreCourses, CoreEnrolledCourseData } from '@features/courses/services/courses';
|
import { CoreCourses, CoreEnrolledCourseData } from '@features/courses/services/courses';
|
||||||
|
@ -27,6 +27,7 @@ import { AddonBadgesUserBadgesSource } from '@addons/badges/classes/user-badges-
|
||||||
import { CoreRoutedItemsManagerSourcesTracker } from '@classes/items-management/routed-items-manager-sources-tracker';
|
import { CoreRoutedItemsManagerSourcesTracker } from '@classes/items-management/routed-items-manager-sources-tracker';
|
||||||
import { CoreAnalytics, CoreAnalyticsEventType } from '@services/analytics';
|
import { CoreAnalytics, CoreAnalyticsEventType } from '@services/analytics';
|
||||||
import { CoreTime } from '@singletons/time';
|
import { CoreTime } from '@singletons/time';
|
||||||
|
import { CoreSharedModule } from '@/core/shared.module';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Page that displays the list of calendar events.
|
* Page that displays the list of calendar events.
|
||||||
|
@ -34,6 +35,10 @@ import { CoreTime } from '@singletons/time';
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'page-addon-badges-issued-badge',
|
selector: 'page-addon-badges-issued-badge',
|
||||||
templateUrl: 'issued-badge.html',
|
templateUrl: 'issued-badge.html',
|
||||||
|
standalone: true,
|
||||||
|
imports: [
|
||||||
|
CoreSharedModule,
|
||||||
|
],
|
||||||
})
|
})
|
||||||
export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
||||||
|
|
||||||
|
@ -42,10 +47,9 @@ export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
||||||
protected logView: (badge: AddonBadgesUserBadge) => void;
|
protected logView: (badge: AddonBadgesUserBadge) => void;
|
||||||
|
|
||||||
courseId = 0;
|
courseId = 0;
|
||||||
user?: CoreUserProfile;
|
|
||||||
course?: CoreEnrolledCourseData;
|
course?: CoreEnrolledCourseData;
|
||||||
badge?: AddonBadgesUserBadge;
|
badge?: AddonBadgesUserBadge;
|
||||||
badges: CoreSwipeNavigationItemsManager;
|
badges?: CoreSwipeNavigationItemsManager;
|
||||||
badgeLoaded = false;
|
badgeLoaded = false;
|
||||||
currentTime = 0;
|
currentTime = 0;
|
||||||
|
|
||||||
|
@ -54,12 +58,15 @@ export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
||||||
this.userId = CoreNavigator.getRouteNumberParam('userId') || CoreSites.getRequiredCurrentSite().getUserId();
|
this.userId = CoreNavigator.getRouteNumberParam('userId') || CoreSites.getRequiredCurrentSite().getUserId();
|
||||||
this.badgeHash = CoreNavigator.getRouteParam('badgeHash') || '';
|
this.badgeHash = CoreNavigator.getRouteParam('badgeHash') || '';
|
||||||
|
|
||||||
const source = CoreRoutedItemsManagerSourcesTracker.getOrCreateSource(
|
const routeData = CoreNavigator.getRouteData(this.route);
|
||||||
AddonBadgesUserBadgesSource,
|
if (routeData.usesSwipeNavigation) {
|
||||||
[this.courseId, this.userId],
|
const source = CoreRoutedItemsManagerSourcesTracker.getOrCreateSource(
|
||||||
);
|
AddonBadgesUserBadgesSource,
|
||||||
|
[this.courseId, this.userId],
|
||||||
|
);
|
||||||
|
|
||||||
this.badges = new CoreSwipeNavigationItemsManager(source);
|
this.badges = new CoreSwipeNavigationItemsManager(source);
|
||||||
|
}
|
||||||
|
|
||||||
this.logView = CoreTime.once((badge) => {
|
this.logView = CoreTime.once((badge) => {
|
||||||
CoreAnalytics.logEvent({
|
CoreAnalytics.logEvent({
|
||||||
|
@ -80,14 +87,14 @@ export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
||||||
this.badgeLoaded = true;
|
this.badgeLoaded = true;
|
||||||
});
|
});
|
||||||
|
|
||||||
this.badges.start();
|
this.badges?.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @inheritdoc
|
* @inheritdoc
|
||||||
*/
|
*/
|
||||||
ngOnDestroy(): void {
|
ngOnDestroy(): void {
|
||||||
this.badges.destroy();
|
this.badges?.destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -96,16 +103,29 @@ export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
||||||
* @returns Promise resolved when done.
|
* @returns Promise resolved when done.
|
||||||
*/
|
*/
|
||||||
async fetchIssuedBadge(): Promise<void> {
|
async fetchIssuedBadge(): Promise<void> {
|
||||||
|
const site = CoreSites.getRequiredCurrentSite();
|
||||||
this.currentTime = CoreTimeUtils.timestamp();
|
this.currentTime = CoreTimeUtils.timestamp();
|
||||||
|
|
||||||
this.user = await CoreUser.getProfile(this.userId, this.courseId, true);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
// Search the badge in the user badges.
|
||||||
const badges = await AddonBadges.getUserBadges(this.courseId, this.userId);
|
const badges = await AddonBadges.getUserBadges(this.courseId, this.userId);
|
||||||
const badge = badges.find((badge) => this.badgeHash == badge.uniquehash);
|
let badge = badges.find((badge) => this.badgeHash == badge.uniquehash);
|
||||||
|
|
||||||
if (!badge) {
|
if (badge) {
|
||||||
return;
|
if (!site.isVersionGreaterEqualThan('4.5')) {
|
||||||
|
// Web service does not return the name of the recipient.
|
||||||
|
const user = await CoreUser.getProfile(this.userId, this.courseId, true);
|
||||||
|
badge.recipientfullname = user.fullname;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// The badge is awarded to another user, try to fetch the badge by hash.
|
||||||
|
if (site.isVersionGreaterEqualThan('4.5')) {
|
||||||
|
badge = await AddonBadges.getUserBadgeByHash(this.badgeHash);
|
||||||
|
}
|
||||||
|
if (!badge) {
|
||||||
|
// Should never happen. The app opens the badge in the browser if it can't be fetched.
|
||||||
|
throw new Error('Error getting badge data.');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.badge = badge;
|
this.badge = badge;
|
||||||
|
@ -130,9 +150,10 @@ export class AddonBadgesIssuedBadgePage implements OnInit, OnDestroy {
|
||||||
* @param refresher Refresher.
|
* @param refresher Refresher.
|
||||||
*/
|
*/
|
||||||
async refreshBadges(refresher?: HTMLIonRefresherElement): Promise<void> {
|
async refreshBadges(refresher?: HTMLIonRefresherElement): Promise<void> {
|
||||||
await CoreUtils.ignoreErrors(Promise.all([
|
await CoreUtils.allPromisesIgnoringErrors([
|
||||||
AddonBadges.invalidateUserBadges(this.courseId, this.userId),
|
AddonBadges.invalidateUserBadges(this.courseId, this.userId),
|
||||||
]));
|
AddonBadges.invalidateUserBadgeByHash(this.badgeHash),
|
||||||
|
]);
|
||||||
|
|
||||||
await CoreUtils.ignoreErrors(Promise.all([
|
await CoreUtils.ignoreErrors(Promise.all([
|
||||||
this.fetchIssuedBadge(),
|
this.fetchIssuedBadge(),
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
// (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 { Injectable } from '@angular/core';
|
||||||
|
|
||||||
|
import { makeSingleton } from '@singletons';
|
||||||
|
import { AddonBadges } from './badges';
|
||||||
|
import { CoreSites } from '@services/sites';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper service that provides some features for badges.
|
||||||
|
*/
|
||||||
|
@Injectable({ providedIn: 'root' })
|
||||||
|
export class AddonBadgesHelperProvider {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return whether the badge can be opened in the app.
|
||||||
|
*
|
||||||
|
* @param badgeHash Badge hash.
|
||||||
|
* @param siteId Site ID. If not defined, current site.
|
||||||
|
* @returns Whether the badge can be opened in the app.
|
||||||
|
*/
|
||||||
|
async canOpenBadge(badgeHash: string, siteId?: string): Promise<boolean> {
|
||||||
|
if (!AddonBadges.isPluginEnabled(siteId)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const site = await CoreSites.getSite(siteId);
|
||||||
|
|
||||||
|
if (site.isVersionGreaterEqualThan('4.5')) {
|
||||||
|
// The WS to fetch a badge by hash is available and it returns the name of the recipient.
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Open in app if badge is one of the user badges.
|
||||||
|
const badges = await AddonBadges.getUserBadges(0, site.getUserId());
|
||||||
|
const badge = badges.find((badge) => badgeHash == badge.uniquehash);
|
||||||
|
|
||||||
|
return badge !== undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
export const AddonBadgesHelper = makeSingleton(AddonBadgesHelperProvider);
|
|
@ -106,6 +106,58 @@ export class AddonBadgesProvider {
|
||||||
await site.invalidateWsCacheForKey(this.getBadgesCacheKey(courseId, userId));
|
await site.invalidateWsCacheForKey(this.getBadgesCacheKey(courseId, userId));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the cache key for the get badge by hash WS call.
|
||||||
|
*
|
||||||
|
* @param hash Badge issued hash.
|
||||||
|
* @returns Cache key.
|
||||||
|
*/
|
||||||
|
protected getUserBadgeByHashCacheKey(hash: string): string {
|
||||||
|
return ROOT_CACHE_KEY + 'badge:' + hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get issued badge by hash.
|
||||||
|
*
|
||||||
|
* @param hash Badge issued hash.
|
||||||
|
* @returns Promise to be resolved when the badge is retrieved.
|
||||||
|
* @since 4.5 with the recpient name, 4.3 without the recipient name.
|
||||||
|
*/
|
||||||
|
async getUserBadgeByHash(hash: string, siteId?: string): Promise<AddonBadgesUserBadge> {
|
||||||
|
const site = await CoreSites.getSite(siteId);
|
||||||
|
const data: AddonBadgesGetUserBadgeByHashWSParams = {
|
||||||
|
hash,
|
||||||
|
};
|
||||||
|
const preSets = {
|
||||||
|
cacheKey: this.getUserBadgeByHashCacheKey(hash),
|
||||||
|
updateFrequency: CoreSite.FREQUENCY_RARELY,
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await site.read<AddonBadgesGetUserBadgeByHashWSResponse>(
|
||||||
|
'core_badges_get_user_badge_by_hash',
|
||||||
|
data,
|
||||||
|
preSets,
|
||||||
|
);
|
||||||
|
if (!response || !response.badge?.[0]) {
|
||||||
|
throw new CoreError('Invalid badge response');
|
||||||
|
}
|
||||||
|
|
||||||
|
return response.badge[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Invalidate get badge by hash WS call.
|
||||||
|
*
|
||||||
|
* @param hash Badge issued hash.
|
||||||
|
* @param siteId Site ID. If not defined, current site.
|
||||||
|
* @returns Promise resolved when data is invalidated.
|
||||||
|
*/
|
||||||
|
async invalidateUserBadgeByHash(hash: string, siteId?: string): Promise<void> {
|
||||||
|
const site = await CoreSites.getSite(siteId);
|
||||||
|
|
||||||
|
await site.invalidateWsCacheForKey(this.getUserBadgeByHashCacheKey(hash));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export const AddonBadges = makeSingleton(AddonBadgesProvider);
|
export const AddonBadges = makeSingleton(AddonBadgesProvider);
|
||||||
|
@ -167,6 +219,8 @@ export type AddonBadgesUserBadge = {
|
||||||
dateissued: number; // Date issued.
|
dateissued: number; // Date issued.
|
||||||
dateexpire: number; // Date expire.
|
dateexpire: number; // Date expire.
|
||||||
visible?: number; // Visible.
|
visible?: number; // Visible.
|
||||||
|
recipientid?: number; // @since 4.5. Id of the awarded user.
|
||||||
|
recipientfullname?: string; // @since 4.5. Full name of the awarded user.
|
||||||
email?: string; // @since 3.6. User email.
|
email?: string; // @since 3.6. User email.
|
||||||
version?: string; // @since 3.6. Version.
|
version?: string; // @since 3.6. Version.
|
||||||
language?: string; // @since 3.6. Language.
|
language?: string; // @since 3.6. Language.
|
||||||
|
@ -211,3 +265,18 @@ export type AddonBadgesUserBadge = {
|
||||||
type?: number; // Type.
|
type?: number; // Type.
|
||||||
}[];
|
}[];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Params of core_badges_get_user_badge_by_hash WS.
|
||||||
|
*/
|
||||||
|
type AddonBadgesGetUserBadgeByHashWSParams = {
|
||||||
|
hash: string; // Badge issued hash.
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Data returned by core_badges_get_user_badge_by_hash WS.
|
||||||
|
*/
|
||||||
|
type AddonBadgesGetUserBadgeByHashWSResponse = {
|
||||||
|
badge: AddonBadgesUserBadge[];
|
||||||
|
warnings?: CoreWSExternalWarning[];
|
||||||
|
};
|
||||||
|
|
|
@ -18,7 +18,7 @@ import { CoreContentLinksHandlerBase } from '@features/contentlinks/classes/base
|
||||||
import { CoreContentLinksAction } from '@features/contentlinks/services/contentlinks-delegate';
|
import { CoreContentLinksAction } from '@features/contentlinks/services/contentlinks-delegate';
|
||||||
import { CoreNavigator } from '@services/navigator';
|
import { CoreNavigator } from '@services/navigator';
|
||||||
import { makeSingleton } from '@singletons';
|
import { makeSingleton } from '@singletons';
|
||||||
import { AddonBadges } from '../badges';
|
import { AddonBadgesHelper } from '../badges-helper';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handler to treat links to user participants page.
|
* Handler to treat links to user participants page.
|
||||||
|
@ -36,7 +36,7 @@ export class AddonBadgesBadgeLinkHandlerService extends CoreContentLinksHandlerB
|
||||||
|
|
||||||
return [{
|
return [{
|
||||||
action: async (siteId: string): Promise<void> => {
|
action: async (siteId: string): Promise<void> => {
|
||||||
await CoreNavigator.navigateToSitePath(`/badges/${params.hash}`, { siteId });
|
await CoreNavigator.navigateToSitePath(`/badge/${params.hash}`, { siteId });
|
||||||
},
|
},
|
||||||
}];
|
}];
|
||||||
}
|
}
|
||||||
|
@ -44,8 +44,8 @@ export class AddonBadgesBadgeLinkHandlerService extends CoreContentLinksHandlerB
|
||||||
/**
|
/**
|
||||||
* @inheritdoc
|
* @inheritdoc
|
||||||
*/
|
*/
|
||||||
isEnabled(siteId: string): Promise<boolean> {
|
async isEnabled(siteId: string, url: string, params: Record<string, string>): Promise<boolean> {
|
||||||
return AddonBadges.isPluginEnabled(siteId);
|
return AddonBadgesHelper.canOpenBadge(params.hash, siteId);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,7 @@ import { AddonBadges } from '../badges';
|
||||||
import { makeSingleton } from '@singletons';
|
import { makeSingleton } from '@singletons';
|
||||||
import { CorePushNotificationsNotificationBasicData } from '@features/pushnotifications/services/pushnotifications';
|
import { CorePushNotificationsNotificationBasicData } from '@features/pushnotifications/services/pushnotifications';
|
||||||
import { CoreNavigator } from '@services/navigator';
|
import { CoreNavigator } from '@services/navigator';
|
||||||
|
import { AddonBadgesHelper } from '../badges-helper';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handler for badges push notifications clicks.
|
* Handler for badges push notifications clicks.
|
||||||
|
@ -42,6 +43,10 @@ export class AddonBadgesPushClickHandlerService implements CorePushNotifications
|
||||||
|
|
||||||
if (CoreUtils.isTrueOrOne(notification.notif) && notification.moodlecomponent == 'moodle' &&
|
if (CoreUtils.isTrueOrOne(notification.notif) && notification.moodlecomponent == 'moodle' &&
|
||||||
(notification.name == 'badgerecipientnotice' || (notification.name == 'badgecreatornotice' && data.hash))) {
|
(notification.name == 'badgerecipientnotice' || (notification.name == 'badgecreatornotice' && data.hash))) {
|
||||||
|
if (notification.customdata?.hash) {
|
||||||
|
return await AddonBadgesHelper.canOpenBadge(String(notification.customdata?.hash), notification.site);
|
||||||
|
}
|
||||||
|
|
||||||
return AddonBadges.isPluginEnabled(notification.site);
|
return AddonBadges.isPluginEnabled(notification.site);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +64,7 @@ export class AddonBadgesPushClickHandlerService implements CorePushNotifications
|
||||||
|
|
||||||
if (data.hash) {
|
if (data.hash) {
|
||||||
// We have the hash, open the badge directly.
|
// We have the hash, open the badge directly.
|
||||||
await CoreNavigator.navigateToSitePath(`/badges/${data.hash}`, {
|
await CoreNavigator.navigateToSitePath(`/badge/${data.hash}`, {
|
||||||
siteId: notification.site,
|
siteId: notification.site,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue