aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/plugins/sendify.ts123
-rw-r--r--src/utils/constants.ts5
2 files changed, 127 insertions, 1 deletions
diff --git a/src/plugins/sendify.ts b/src/plugins/sendify.ts
new file mode 100644
index 0000000..21d63b4
--- /dev/null
+++ b/src/plugins/sendify.ts
@@ -0,0 +1,123 @@
+import definePlugin from "../utils/types";
+import { lazyWebpack } from "../utils";
+import { filters } from "../webpack";
+import { ApplicationCommandInputType, sendBotMessage } from "../api/Commands";
+import { Devs } from "../utils/constants";
+import { PartialDeep } from "type-fest";
+import { Message } from "discord-types/general";
+import { FluxDispatcher } from "../webpack/common";
+
+interface Album {
+ id: string
+ image: {
+ height: number
+ width: number
+ url: string
+ }
+ name: string
+}
+
+interface Artist {
+ external_urls: {
+ spotify: string
+ }
+ href: string
+ id: string
+ name: string
+ type: "artist" | string
+ uri: string
+}
+
+interface Track {
+ id: string
+ album: Album
+ artists: Artist[]
+ duration: number
+ isLocal: boolean
+ name: string
+}
+
+const Spotify = lazyWebpack(filters.byProps(["getPlayerState"]));
+const MessageCreator = lazyWebpack(filters.byProps(["getSendMessageOptionsForReply", "sendMessage"]));
+const PendingReplyStore = lazyWebpack(filters.byProps(["getPendingReply"]));
+
+function sendMessage(channelId, message) {
+ message = {
+ // The following are required to prevent Discord from throwing an error
+ invalidEmojis: [],
+ tts: false,
+ validNonShortcutEmojis: [],
+ ...message
+ };
+ const reply = PendingReplyStore.getPendingReply(channelId);
+ MessageCreator.sendMessage(channelId, message, void 0, MessageCreator.getSendMessageOptionsForReply(reply))
+ .then(() => {
+ if (reply) {
+ FluxDispatcher.dispatch({ type: "DELETE_PENDING_REPLY", channelId });
+ }
+ });
+}
+
+export default definePlugin({
+ name: "Sendify",
+ description: "Send your current Spotify music to chat",
+ authors: [Devs.katlyn],
+ dependencies: ["CommandsAPI"],
+ commands: [
+ {
+ name: "track",
+ description: "Send your current Spotify track to chat",
+ inputType: ApplicationCommandInputType.BUILT_IN,
+ options: [],
+ execute: (_, ctx) => {
+ const track: Track | null = Spotify.getTrack();
+ if (track === null) {
+ sendBotMessage(ctx.channel.id, {
+ content: "You're not listening to any music."
+ });
+ return;
+ }
+ // Note: Due to how Discord handles commands, we need to manually create and send the message
+ sendMessage(ctx.channel.id, {
+ content: `https://open.spotify.com/track/${track.id}`
+ });
+ }
+ },
+ {
+ name: "album",
+ description: "Send your current Spotify album to chat",
+ inputType: ApplicationCommandInputType.BUILT_IN,
+ options: [],
+ execute: (_, ctx) => {
+ const track: Track | null = Spotify.getTrack();
+ if (track === null) {
+ sendBotMessage(ctx.channel.id, {
+ content: "You're not listening to any music."
+ });
+ return;
+ }
+ sendMessage(ctx.channel.id, {
+ content: `https://open.spotify.com/album/${track.album.id}`
+ });
+ }
+ },
+ {
+ name: "artist",
+ description: "Send your current Spotify artist to chat",
+ inputType: ApplicationCommandInputType.BUILT_IN,
+ options: [],
+ execute: (_, ctx) => {
+ const track: Track | null = Spotify.getTrack();
+ if (track === null) {
+ sendBotMessage(ctx.channel.id, {
+ content: "You're not listening to any music."
+ });
+ return;
+ }
+ sendMessage(ctx.channel.id, {
+ content: track.artists[0].external_urls.spotify
+ });
+ }
+ }
+ ]
+});
diff --git a/src/utils/constants.ts b/src/utils/constants.ts
index 987cc4f..63bc01e 100644
--- a/src/utils/constants.ts
+++ b/src/utils/constants.ts
@@ -51,5 +51,8 @@ export const Devs = Object.freeze({
name: "ECHO",
id: 712639419785412668n
},
-
+ katlyn: {
+ name: "katlyn",
+ id: 250322741406859265n
+ }
});