jormungandr-bite/src/client/app/common/scripts/compose-notification.ts

75 lines
1.6 KiB
TypeScript
Raw Normal View History

2018-07-07 04:19:00 -06:00
import getNoteSummary from '../../../../misc/get-note-summary';
import getReactionEmoji from '../../../../misc/get-reaction-emoji';
import getUserName from '../../../../misc/get-user-name';
2017-11-20 13:09:45 -07:00
type Notification = {
title: string;
body: string;
icon: string;
onclick?: any;
};
// TODO: i18n
export default function(type, data): Notification {
switch (type) {
case 'driveFileCreated':
2017-11-20 13:09:45 -07:00
return {
2019-02-28 04:57:38 -07:00
title: 'File uploaded',
2017-11-20 13:09:45 -07:00
body: data.name,
2018-07-24 08:43:14 -06:00
icon: data.url
2017-11-20 13:09:45 -07:00
};
case 'unreadMessagingMessage':
2017-11-20 13:09:45 -07:00
return {
2019-02-28 04:57:38 -07:00
title: `New message from ${getUserName(data.user)}`,
2017-11-20 13:09:45 -07:00
body: data.text, // TODO: getMessagingMessageSummary(data),
2018-07-24 08:43:14 -06:00
icon: data.user.avatarUrl
2017-11-20 13:09:45 -07:00
};
case 'reversiInvited':
2018-03-17 02:53:35 -06:00
return {
2019-02-28 04:57:38 -07:00
title: 'Play reversi with me',
body: `You got reversi invitation from ${getUserName(data.parent)}`,
2018-07-24 08:43:14 -06:00
icon: data.parent.avatarUrl
2018-03-17 02:53:35 -06:00
};
2018-06-20 20:35:28 -06:00
case 'notification':
switch (data.type) {
case 'mention':
return {
2019-02-28 04:57:38 -07:00
title: `${getUserName(data.user)}:`,
2018-06-20 20:35:28 -06:00
body: getNoteSummary(data),
2018-07-24 08:43:14 -06:00
icon: data.user.avatarUrl
2018-06-20 20:35:28 -06:00
};
case 'reply':
return {
2019-02-28 04:57:38 -07:00
title: `You got reply from ${getUserName(data.user)}:`,
2018-06-20 20:35:28 -06:00
body: getNoteSummary(data),
2018-07-24 08:43:14 -06:00
icon: data.user.avatarUrl
2018-06-20 20:35:28 -06:00
};
case 'quote':
return {
2019-02-28 04:57:38 -07:00
title: `${getUserName(data.user)}:`,
2018-06-20 20:35:28 -06:00
body: getNoteSummary(data),
2018-07-24 08:43:14 -06:00
icon: data.user.avatarUrl
2018-06-20 20:35:28 -06:00
};
case 'reaction':
return {
title: `${getUserName(data.user)}: ${getReactionEmoji(data.reaction)}:`,
body: getNoteSummary(data.note),
2018-07-24 08:43:14 -06:00
icon: data.user.avatarUrl
2018-06-20 20:35:28 -06:00
};
default:
return null;
}
2017-11-20 13:09:45 -07:00
default:
return null;
}
}