MOBILE-3811 notifications: Apply new icons to notifications
parent
2eea8a3413
commit
272f65a8a5
|
@ -1,6 +1,25 @@
|
||||||
@import "~theme/globals";
|
@import "~theme/globals";
|
||||||
|
|
||||||
:host {
|
:host {
|
||||||
|
::ng-deep {
|
||||||
|
core-user-avatar .core-avatar-extra {
|
||||||
|
margin: 0 !important;
|
||||||
|
position: absolute;
|
||||||
|
right: -4px;
|
||||||
|
bottom: -4px;
|
||||||
|
}
|
||||||
|
core-user-avatar img.core-avatar-extra {
|
||||||
|
background: none;
|
||||||
|
width: 24px;
|
||||||
|
height: 24px;
|
||||||
|
border-radius: 0 !important;
|
||||||
|
}
|
||||||
|
core-user-avatar core-mod-icon.core-avatar-extra {
|
||||||
|
--size: 16px;
|
||||||
|
padding: 0.2rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.core-notification-icon {
|
.core-notification-icon {
|
||||||
width: 34px;
|
width: 34px;
|
||||||
height: 34px;
|
height: 34px;
|
||||||
|
|
|
@ -32,7 +32,13 @@
|
||||||
: 'addon.notifications.unreadnotification' | translate: {$a: notification.subject}">
|
: 'addon.notifications.unreadnotification' | translate: {$a: notification.subject}">
|
||||||
<core-user-avatar *ngIf="notification.useridfrom > 0" [user]="notification" slot="start"
|
<core-user-avatar *ngIf="notification.useridfrom > 0" [user]="notification" slot="start"
|
||||||
[profileUrl]="notification.profileimageurlfrom" [fullname]="notification.userfromfullname"
|
[profileUrl]="notification.profileimageurlfrom" [fullname]="notification.userfromfullname"
|
||||||
[userId]="notification.useridfrom" [extraIcon]="notification.iconurl"></core-user-avatar>
|
[userId]="notification.useridfrom">
|
||||||
|
<img *ngIf="notification.iconurl && !notification.modname" [src]="notification.iconurl" alt="" role="presentation"
|
||||||
|
class="core-avatar-extra">
|
||||||
|
<core-mod-icon *ngIf="notification.modname" [modicon]="notification.iconurl" [modname]="notification.modname"
|
||||||
|
[showAlt]="false" class="core-avatar-extra">
|
||||||
|
</core-mod-icon>
|
||||||
|
</core-user-avatar>
|
||||||
|
|
||||||
<img *ngIf="notification.useridfrom <= 0 && notification.iconurl" [src]="notification.iconurl" alt="" role="presentation"
|
<img *ngIf="notification.useridfrom <= 0 && notification.iconurl" [src]="notification.iconurl" alt="" role="presentation"
|
||||||
class="core-notification-icon" slot="start">
|
class="core-notification-icon" slot="start">
|
||||||
|
|
|
@ -53,7 +53,7 @@ export class AddonNotificationsListPage implements OnInit, OnDestroy {
|
||||||
protected pendingRefresh = false;
|
protected pendingRefresh = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Component being initialized.
|
* @inheritdoc
|
||||||
*/
|
*/
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
this.fetchNotifications();
|
this.fetchNotifications();
|
||||||
|
@ -221,7 +221,7 @@ export class AddonNotificationsListPage implements OnInit, OnDestroy {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Page destroyed.
|
* @inheritdoc
|
||||||
*/
|
*/
|
||||||
ngOnDestroy(): void {
|
ngOnDestroy(): void {
|
||||||
this.cronObserver?.off();
|
this.cronObserver?.off();
|
||||||
|
|
|
@ -12,7 +12,11 @@
|
||||||
<core-loading [hideUntil]="loaded">
|
<core-loading [hideUntil]="loaded">
|
||||||
<ion-item class="ion-text-wrap" lines="none" [attr.aria-label]="subject">
|
<ion-item class="ion-text-wrap" lines="none" [attr.aria-label]="subject">
|
||||||
<core-user-avatar *ngIf="userIdFrom > 0" slot="start" [userId]="userIdFrom" [profileUrl]="profileImageUrlFrom"
|
<core-user-avatar *ngIf="userIdFrom > 0" slot="start" [userId]="userIdFrom" [profileUrl]="profileImageUrlFrom"
|
||||||
[fullname]="userFromFullName" [extraIcon]="iconUrl"></core-user-avatar>
|
[fullname]="userFromFullName">
|
||||||
|
<img *ngIf="iconUrl && !modname" [src]="iconUrl" alt="" role="presentation" class="core-avatar-extra">
|
||||||
|
<core-mod-icon *ngIf="modname" [modicon]="iconUrl" [modname]="modname" [showAlt]="false" class="core-avatar-extra">
|
||||||
|
</core-mod-icon>
|
||||||
|
</core-user-avatar>
|
||||||
|
|
||||||
<img *ngIf="userIdFrom <= 0 && iconUrl" [src]="iconUrl" alt="" role="presentation" class="core-notification-icon" slot="start">
|
<img *ngIf="userIdFrom <= 0 && iconUrl" [src]="iconUrl" alt="" role="presentation" class="core-notification-icon" slot="start">
|
||||||
|
|
||||||
|
|
|
@ -39,6 +39,7 @@ export class AddonNotificationsNotificationPage implements OnInit {
|
||||||
profileImageUrlFrom?: string; // Avatar of the user who sent the notification.
|
profileImageUrlFrom?: string; // Avatar of the user who sent the notification.
|
||||||
userFromFullName?: string; // Name of the user who sent the notification.
|
userFromFullName?: string; // Name of the user who sent the notification.
|
||||||
iconUrl?: string; // Icon URL.
|
iconUrl?: string; // Icon URL.
|
||||||
|
modname?: string; // Module name.
|
||||||
loaded = false;
|
loaded = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -77,6 +78,13 @@ export class AddonNotificationsNotificationPage implements OnInit {
|
||||||
this.profileImageUrlFrom = notification.profileimageurlfrom;
|
this.profileImageUrlFrom = notification.profileimageurlfrom;
|
||||||
this.userFromFullName = notification.userfromfullname;
|
this.userFromFullName = notification.userfromfullname;
|
||||||
this.iconUrl = notification.iconurl;
|
this.iconUrl = notification.iconurl;
|
||||||
|
if (notification.moodlecomponent?.startsWith('mod_') && notification.iconurl) {
|
||||||
|
const modname = notification.moodlecomponent.substring(4);
|
||||||
|
if (notification.iconurl.match('/theme/image.php/[^/]+/' + modname + '/[-0-9]*/') ||
|
||||||
|
notification.iconurl.match('/theme/image.php/[^/]+/' + notification.moodlecomponent + '/[-0-9]*/')) {
|
||||||
|
this.modname = modname;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
this.subject = notification.title || '';
|
this.subject = notification.title || '';
|
||||||
this.content = notification.message || '';
|
this.content = notification.message || '';
|
||||||
|
|
|
@ -41,7 +41,16 @@ export class AddonNotificationsHelperProvider {
|
||||||
notification: AddonNotificationsNotificationMessageFormatted,
|
notification: AddonNotificationsNotificationMessageFormatted,
|
||||||
): AddonNotificationsNotificationToRender {
|
): AddonNotificationsNotificationToRender {
|
||||||
const formattedNotification: AddonNotificationsNotificationToRender = notification;
|
const formattedNotification: AddonNotificationsNotificationToRender = notification;
|
||||||
formattedNotification.iconurl = formattedNotification.iconurl || undefined; // Make sure the property exists.
|
|
||||||
|
if (notification.moodlecomponent?.startsWith('mod_') && notification.iconurl) {
|
||||||
|
const modname = notification.moodlecomponent.substring(4);
|
||||||
|
if (notification.iconurl.match('/theme/image.php/[^/]+/' + modname + '/[-0-9]*/') ||
|
||||||
|
notification.iconurl.match('/theme/image.php/[^/]+/' + notification.moodlecomponent + '/[-0-9]*/')) {
|
||||||
|
formattedNotification.modname = modname;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
formattedNotification.iconurl = formattedNotification.iconurl || undefined; // Make sure the property exists.
|
||||||
|
}
|
||||||
|
|
||||||
return formattedNotification;
|
return formattedNotification;
|
||||||
}
|
}
|
||||||
|
@ -172,4 +181,5 @@ export type AddonNotificationsPreferencesProcessorFormatted = AddonNotifications
|
||||||
*/
|
*/
|
||||||
export type AddonNotificationsNotificationToRender = AddonNotificationsNotificationMessageFormatted & {
|
export type AddonNotificationsNotificationToRender = AddonNotificationsNotificationMessageFormatted & {
|
||||||
iconurl?: string;
|
iconurl?: string;
|
||||||
|
modname?: string;
|
||||||
};
|
};
|
||||||
|
|
|
@ -53,6 +53,10 @@ export class CoreModIconComponent implements OnInit, OnChanges {
|
||||||
// Guess module from the icon url.
|
// Guess module from the icon url.
|
||||||
const matches = this.modicon.match('/theme/image.php/[^/]+/([^/]+)/[-0-9]*/');
|
const matches = this.modicon.match('/theme/image.php/[^/]+/([^/]+)/[-0-9]*/');
|
||||||
this.modname = (matches && matches[1]) || '';
|
this.modname = (matches && matches[1]) || '';
|
||||||
|
|
||||||
|
if (this.modname.startsWith('mod_')) {
|
||||||
|
this.modname = this.modname.substring(4);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.modNameTranslated = this.modname ? CoreCourse.translateModuleName(this.modname) || '' : '';
|
this.modNameTranslated = this.modname ? CoreCourse.translateModuleName(this.modname) || '' : '';
|
||||||
|
|
|
@ -9,6 +9,4 @@
|
||||||
<span *ngIf="checkOnline && isOnline()" class="contact-status online" role="status" [attr.aria-label]="'core.online' | translate">
|
<span *ngIf="checkOnline && isOnline()" class="contact-status online" role="status" [attr.aria-label]="'core.online' | translate">
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
<img *ngIf="extraIcon" [src]="extraIcon" alt="" role="presentation" class="core-avatar-extra-icon">
|
|
||||||
|
|
||||||
<ng-content></ng-content>
|
<ng-content></ng-content>
|
||||||
|
|
|
@ -44,7 +44,7 @@
|
||||||
max-height: var(--core-header-toolbar-button-image-size);
|
max-height: var(--core-header-toolbar-button-image-size);
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
display: block;
|
display: block;
|
||||||
|
|
||||||
img {
|
img {
|
||||||
padding: 4px;
|
padding: 4px;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
|
@ -63,17 +63,6 @@
|
||||||
background-color: var(--core-online-color);
|
background-color: var(--core-online-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.core-avatar-extra-icon {
|
|
||||||
margin: 0 !important;
|
|
||||||
border-radius: 0 !important;
|
|
||||||
background: none;
|
|
||||||
position: absolute;
|
|
||||||
right: -4px;
|
|
||||||
bottom: -4px;
|
|
||||||
width: 24px;
|
|
||||||
height: 24px;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
:host-context(.toolbar) .contact-status {
|
:host-context(.toolbar) .contact-status {
|
||||||
|
@ -89,4 +78,4 @@
|
||||||
:host-context(ion-item) {
|
:host-context(ion-item) {
|
||||||
margin-top: 12px;
|
margin-top: 12px;
|
||||||
margin-bottom: 12px;
|
margin-bottom: 12px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,6 @@ export class CoreUserAvatarComponent implements OnInit, OnChanges, OnDestroy {
|
||||||
@Input() userId?: number; // If provided or found it will be used to link the image to the profile.
|
@Input() userId?: number; // If provided or found it will be used to link the image to the profile.
|
||||||
@Input() courseId?: number;
|
@Input() courseId?: number;
|
||||||
@Input() checkOnline = false; // If want to check and show online status.
|
@Input() checkOnline = false; // If want to check and show online status.
|
||||||
@Input() extraIcon?: string; // Extra icon to show near the avatar.
|
|
||||||
|
|
||||||
avatarUrl?: string;
|
avatarUrl?: string;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue