summaryrefslogtreecommitdiff
path: root/packages
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-01-22 08:00:42 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-01-22 08:00:42 +0900
commit26ae2dfc0f494c377abd878c00044049fcd2bf37 (patch)
treeadd01058b60209a990ba4aabe9487e784fc9ea83 /packages
parent13.1.3 (diff)
downloadmisskey-26ae2dfc0f494c377abd878c00044049fcd2bf37.tar.gz
misskey-26ae2dfc0f494c377abd878c00044049fcd2bf37.tar.bz2
misskey-26ae2dfc0f494c377abd878c00044049fcd2bf37.zip
add achievement
Diffstat (limited to 'packages')
-rw-r--r--packages/backend/src/core/AchievementService.ts3
-rw-r--r--packages/backend/src/server/api/endpoints/notes/favorites/create.ts6
-rw-r--r--packages/frontend/src/scripts/achievements.ts6
3 files changed, 14 insertions, 1 deletions
diff --git a/packages/backend/src/core/AchievementService.ts b/packages/backend/src/core/AchievementService.ts
index 26dd356d36..be763e4629 100644
--- a/packages/backend/src/core/AchievementService.ts
+++ b/packages/backend/src/core/AchievementService.ts
@@ -44,6 +44,7 @@ const ACHIEVEMENT_TYPES = [
'loggedInOnNewYearsDay',
'noteClipped1',
'noteFavorited1',
+ 'myNoteFavorited1',
'profileFilled',
'markedAsCat',
'following1',
@@ -94,7 +95,7 @@ export class AchievementService {
@bindThis
public async create(
userId: User['id'],
- type: string,
+ type: typeof ACHIEVEMENT_TYPES[number],
): Promise<void> {
if (!ACHIEVEMENT_TYPES.includes(type)) return;
diff --git a/packages/backend/src/server/api/endpoints/notes/favorites/create.ts b/packages/backend/src/server/api/endpoints/notes/favorites/create.ts
index acf22a5ad4..e423f0f109 100644
--- a/packages/backend/src/server/api/endpoints/notes/favorites/create.ts
+++ b/packages/backend/src/server/api/endpoints/notes/favorites/create.ts
@@ -6,6 +6,7 @@ import { Endpoint } from '@/server/api/endpoint-base.js';
import { GetterService } from '@/server/api/GetterService.js';
import { DI } from '@/di-symbols.js';
import { ApiError } from '../../../error.js';
+import { AchievementService } from '@/core/AchievementService.js';
export const meta = {
tags: ['notes', 'favorites'],
@@ -51,6 +52,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
private idService: IdService,
private getterService: GetterService,
+ private achievementService: AchievementService,
) {
super(meta, paramDef, async (ps, me) => {
// Get favoritee
@@ -76,6 +78,10 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
noteId: note.id,
userId: me.id,
});
+
+ if (note.userHost == null) {
+ this.achievementService.create(note.userId, 'myNoteFavorited1');
+ }
});
}
}
diff --git a/packages/frontend/src/scripts/achievements.ts b/packages/frontend/src/scripts/achievements.ts
index c97358e880..f511fce3ea 100644
--- a/packages/frontend/src/scripts/achievements.ts
+++ b/packages/frontend/src/scripts/achievements.ts
@@ -40,6 +40,7 @@ export const ACHIEVEMENT_TYPES = [
'loggedInOnNewYearsDay',
'noteClipped1',
'noteFavorited1',
+ 'myNoteFavorited1',
'profileFilled',
'markedAsCat',
'following1',
@@ -240,6 +241,11 @@ export const ACHIEVEMENT_BADGES = {
bg: null,
frame: 'bronze',
},
+ 'myNoteFavorited1': {
+ img: '/fluent-emoji/1f320.png',
+ bg: null,
+ frame: 'silver',
+ },
'profileFilled': {
img: '/fluent-emoji/1f44c.png',
bg: 'linear-gradient(0deg, rgb(187 183 59), rgb(255 143 77))',