diff options
| author | Hazelnoot <acomputerdog@gmail.com> | 2025-03-24 14:26:25 -0400 |
|---|---|---|
| committer | Hazelnoot <acomputerdog@gmail.com> | 2025-03-27 19:51:43 -0400 |
| commit | 58cdee77d5d7a8dceef39683695d33947a614070 (patch) | |
| tree | c68d2544191043adc30d60a57795ea5e0ad67a09 /packages/megalodon/src | |
| parent | don't render CW as HTML for mastodon (diff) | |
| download | sharkey-58cdee77d5d7a8dceef39683695d33947a614070.tar.gz sharkey-58cdee77d5d7a8dceef39683695d33947a614070.tar.bz2 sharkey-58cdee77d5d7a8dceef39683695d33947a614070.zip | |
convert notification types in mastodon API
Diffstat (limited to 'packages/megalodon/src')
| -rw-r--r-- | packages/megalodon/src/index.ts | 2 | ||||
| -rw-r--r-- | packages/megalodon/src/mastodon/notification.ts | 33 | ||||
| -rw-r--r-- | packages/megalodon/src/misskey/api_client.ts | 3 | ||||
| -rw-r--r-- | packages/megalodon/src/notification.ts | 48 |
4 files changed, 66 insertions, 20 deletions
diff --git a/packages/megalodon/src/index.ts b/packages/megalodon/src/index.ts index 621f007ccf..7a4f10ab02 100644 --- a/packages/megalodon/src/index.ts +++ b/packages/megalodon/src/index.ts @@ -6,7 +6,7 @@ import { MegalodonInterface, WebSocketInterface } from './megalodon' import { detector } from './detector' import Misskey from './misskey' import Entity from './entity' -import NotificationType from './notification' +import * as NotificationType from './notification' import FilterContext from './filter_context' import Converter from './converter' import MastodonEntity from './mastodon/entity'; diff --git a/packages/megalodon/src/mastodon/notification.ts b/packages/megalodon/src/mastodon/notification.ts new file mode 100644 index 0000000000..9c51f9698d --- /dev/null +++ b/packages/megalodon/src/mastodon/notification.ts @@ -0,0 +1,33 @@ +export const Mention = 'mention' as const; +export const Reblog = 'reblog' as const; +export const Favourite = 'favourite' as const; +export const Follow = 'follow' as const; +export const Poll = 'poll' as const; +export const FollowRequest = 'follow_request' as const; +export const Status = 'status' as const; +export const Update = 'update' as const; +export const AdminSignup = 'admin.sign_up' as const; +export const AdminReport = 'admin.report' as const; +export const Reaction = 'reaction' as const; +export const ModerationWarning = 'moderation_warning' as const; +export const SeveredRelationships = 'severed_relationships' as const; +export const AnnualReport = 'annual_report' as const; + +export const mastodonNotificationTypes = [ + Mention, + Reblog, + Favourite, + Follow, + Poll, + FollowRequest, + Status, + Update, + AdminSignup, + AdminReport, + Reaction, + ModerationWarning, + SeveredRelationships, + AnnualReport, +]; + +export type MastodonNotificationType = typeof mastodonNotificationTypes[number]; diff --git a/packages/megalodon/src/misskey/api_client.ts b/packages/megalodon/src/misskey/api_client.ts index 4c975c4dfa..6dfa59f132 100644 --- a/packages/megalodon/src/misskey/api_client.ts +++ b/packages/megalodon/src/misskey/api_client.ts @@ -9,7 +9,8 @@ import MisskeyEntity from './entity' import MegalodonEntity from '../entity' import WebSocket from './web_socket' import MisskeyNotificationType from './notification' -import NotificationType, { UnknownNotificationTypeError } from '../notification' +import * as NotificationType from '../notification' +import { UnknownNotificationTypeError } from '../notification'; namespace MisskeyAPI { export namespace Entity { diff --git a/packages/megalodon/src/notification.ts b/packages/megalodon/src/notification.ts index 7c08c5d47f..846d79c6d7 100644 --- a/packages/megalodon/src/notification.ts +++ b/packages/megalodon/src/notification.ts @@ -1,20 +1,16 @@ -import Entity from './entity' - -namespace NotificationType { - export const Follow: Entity.NotificationType = 'follow' - export const Favourite: Entity.NotificationType = 'favourite' - export const Reblog: Entity.NotificationType = 'reblog' - export const Mention: Entity.NotificationType = 'mention' - export const EmojiReaction: Entity.NotificationType = 'emoji_reaction' - export const FollowRequest: Entity.NotificationType = 'follow_request' - export const Status: Entity.NotificationType = 'status' - export const PollVote: Entity.NotificationType = 'poll_vote' - export const PollExpired: Entity.NotificationType = 'poll_expired' - export const Update: Entity.NotificationType = 'update' - export const Move: Entity.NotificationType = 'move' - export const AdminSignup: Entity.NotificationType = 'admin.sign_up' - export const AdminReport: Entity.NotificationType = 'admin.report' -} +export const Follow = 'follow' as const; +export const Favourite = 'favourite' as const; +export const Reblog = 'reblog' as const; +export const Mention = 'mention' as const; +export const EmojiReaction = 'emoji_reaction' as const; +export const FollowRequest = 'follow_request' as const; +export const Status = 'status' as const; +export const PollVote = 'poll_vote' as const; +export const PollExpired = 'poll_expired' as const; +export const Update = 'update' as const; +export const Move = 'move' as const; +export const AdminSignup = 'admin.sign_up' as const; +export const AdminReport = 'admin.report' as const; export class UnknownNotificationTypeError extends Error { constructor() { @@ -23,4 +19,20 @@ export class UnknownNotificationTypeError extends Error { } } -export default NotificationType +export const notificationTypes = [ + Follow, + Favourite, + Reblog, + Mention, + EmojiReaction, + FollowRequest, + Status, + PollVote, + PollExpired, + Update, + Move, + AdminSignup, + AdminReport, +]; + +export type NotificationType = typeof notificationTypes[number]; |