Skip to content

Commit

Permalink
erm hehe
Browse files Browse the repository at this point in the history
  • Loading branch information
yofukashino committed Mar 20, 2024
1 parent a6327ed commit f8da399
Show file tree
Hide file tree
Showing 7 changed files with 167 additions and 82 deletions.
54 changes: 50 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,62 @@ Make your experience better with spotify links.

Like Playing directly or adding in queue. (Also opening directly in app)

Direct Download Link: [dev.tharki.Distify.asar](https://github.com/YofukashiNo/Distify/releases/latest/download/dev.tharki.Distify.asar)
Direct Download Link:
[![dev.yofukashino.Distify.asar](https://img.shields.io/github/downloads/YofukashiNo/MessageLinkEmbeds/total.svg?style=social&label=Direct%20Download)](https://github.com/YofukashiNo/Distify/releases/latest/download/dev.yofukashino.Distify.asar)

Install Link:
[![Safe](https://img.shields.io/github/downloads/YofukashiNo/MessageLinkEmbeds/total.svg?style=social&label=Install%20in%20Replugged&logo=)](https://replugged.dev/install?identifier=YofukashiNo/Distify&source=github)

![distify](https://i.imgur.com/i7r0j9L.png)

[![Install in Replugged](https://img.shields.io/badge/-Install%20in%20Replugged-blue?style=for-the-badge&logo=none)](https://replugged.dev/install?identifier=YofukashiNo/Distify&source=github)
---

![image](https://i.imgur.com/i7r0j9L.png)
# FAQ

### How to install a plugin?
<details open>
<summary>Automatic</summary>

- Simply click on install link and thats all <3
</details>
<details>
<summary>Manual</summary>

> For Contributing: [Make a pr thats all.]
- Click on Direct Download Link and save the file
- Open Replugged Plugin Settings
- Click on "Open Plugins Folder" button
- Paste downloaded file in folder that opened
</details>

### How Do I contribute?
- Just make a pull request

### How Do I support without pull request?
- You Can Donate on my [ko-fi](https://ko-fi.com/yofukashino) or UPI at `yofukashi.no.singh@fam`

[![Buy Me a Coffee at ko-fi.com](https://storage.ko-fi.com/cdn/kofi3.png?v=3)](https://ko-fi.com/yofukashino)

### Where can I find other plugins by you?

You can find them [here](https://github.com/YofukashiNo/RepluggedPlugins)

### This plugin isn't listed in the all plugin list?

PRs are appreciated or just make an issue on the [repo](https://github.com/YofukashiNo/RepluggedPlugins)


### Where can I find the support?

~~You can make post in support channel of replugged server and ping me.~~

OR

There is support server for all the plugins. You can join it here:

[![Support Server](https://discordapp.com/api/guilds/919649417005506600/widget.png?style=banner3)](https://discord.gg/SgKSKyh9gY)



# Who is the author of these plugins?

[![Discord Presence](https://lanyard.cnrad.dev/api/1121961711080050780?hideDiscrim=true&idleMessage=Leave%20the%20kid%20alone...)](https://discordapp.com/users/1121961711080050780)
6 changes: 3 additions & 3 deletions manifest.json
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
{
"id": "dev.tharki.Distify",
"id": "dev.yofukashino.Distify",
"name": "Distify",
"description": "Make your experience better with spotify links.",
"author": {
"name": "Ahlawat",
"name": "Nanakusa",
"discordID": "1121961711080050780",
"github": "YofukashiNo"
},
"version": "1.0.3",
"updater": {
"type": "store",
"id": "dev.tharki.Distify"
"id": "dev.yofukashino.Distify"
},
"license": "MIT",
"type": "replugged-plugin",
Expand Down
25 changes: 8 additions & 17 deletions src/Components/MenuItems.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import { ContextMenu } from "replugged/components";
import { PluginLogger } from "../index";
import Utils from "../lib/utils";
import Icons from "./Icons";
import Types from "../types";

export const noAccounts = (): React.ReactElement => {
return (
Expand All @@ -17,10 +16,7 @@ export const noAccounts = (): React.ReactElement => {
);
};

export const addToQueue = (
SpotifyLinks: string[][],
SpotifyAccount: Types.SpotifyAccounts,
): React.ReactElement => {
export const addToQueue = (SpotifyLinks: string[][]): React.ReactElement => {
if (SpotifyLinks.length === 1) {
const [, type, id, name] = SpotifyLinks[0];
return (
Expand All @@ -32,7 +28,7 @@ export const addToQueue = (
icon={() => <Icons.queue width="16" height="16" />}
action={async () => {
try {
await Utils.queue(type, id, SpotifyAccount.accessToken);
await Utils.queue(type, id);
ToastUtils.toast("Successfully Queued on Spotify", ToastUtils.Kind.SUCCESS, {
duration: 5000,
});
Expand All @@ -54,8 +50,7 @@ export const addToQueue = (
icon={() => <Icons.queue width="16" height="16" />}
action={async () => {
try {
for (const [, type, id] of SpotifyLinks)
await Utils.queue(type, id, SpotifyAccount.accessToken);
for (const [, type, id] of SpotifyLinks) await Utils.queue(type, id);
ToastUtils.toast("Successfully Queued on Spotify", ToastUtils.Kind.SUCCESS, {
duration: 5000,
});
Expand All @@ -75,7 +70,7 @@ export const addToQueue = (
icon={() => <Icons.queue width="16" height="16" />}
action={async () => {
try {
await Utils.queue(type, id, SpotifyAccount.accessToken);
await Utils.queue(type, id);
ToastUtils.toast("Successfully Queued on Spotify", ToastUtils.Kind.SUCCESS, {
duration: 5000,
});
Expand All @@ -93,10 +88,7 @@ export const addToQueue = (
);
};

export const play = (
SpotifyLinks: string[][],
SpotifyAccount: Types.SpotifyAccounts,
): React.ReactElement => {
export const play = (SpotifyLinks: string[][]): React.ReactElement => {
if (SpotifyLinks.length === 1) {
const [, type, id, name] = SpotifyLinks[0];
return (
Expand All @@ -108,7 +100,7 @@ export const play = (
icon={() => <Icons.play width="16" height="16" />}
action={async () => {
try {
await Utils.play(type, id, SpotifyAccount.accessToken);
await Utils.play(type, id);
ToastUtils.toast("Successfully Played on Spotify", ToastUtils.Kind.SUCCESS, {
duration: 5000,
});
Expand All @@ -130,8 +122,7 @@ export const play = (
icon={() => <Icons.play width="16" height="16" />}
action={async () => {
try {
for (const [, type, id] of SpotifyLinks)
await Utils.play(type, id, SpotifyAccount.accessToken);
for (const [, type, id] of SpotifyLinks) await Utils.play(type, id);
ToastUtils.toast("Successfully Played on Spotify", ToastUtils.Kind.SUCCESS, {
duration: 5000,
});
Expand All @@ -151,7 +142,7 @@ export const play = (
icon={() => <Icons.play width="16" height="16" />}
action={async () => {
try {
await Utils.play(type, id, SpotifyAccount.accessToken);
await Utils.play(type, id);
ToastUtils.toast("Successfully Played on Spotify", ToastUtils.Kind.SUCCESS, {
duration: 5000,
});
Expand Down
2 changes: 2 additions & 0 deletions src/lib/requiredModules.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,5 @@ export const ConnectedAccountsStore =
webpack.getByStoreName<Types.ConnectedAccountsStore>("ConnectedAccountsStore");

export const ElementParser = webpack.getByProps<Types.ElementParser>("sanitizeUrl", "sanitizeText");

export const SpotifyStore = webpack.getByStoreName<Types.SpotifyStore>("SpotifyStore");
101 changes: 54 additions & 47 deletions src/lib/utils.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,44 @@ import { contextMenu as ContextMenuUtils, React } from "replugged/common";
import { ContextMenu } from "replugged/components";
import { PluginLogger } from "../index";
import { BASE_URL, BASE_URL_PLAYER } from "./consts";
import { ConnectedAccountsStore } from "./requiredModules";
import { ConnectedAccountsStore, SpotifyStore } from "./requiredModules";
import MenuItems from "../Components/MenuItems";
import Types from "../types";
export const customCacheSpotifyMeta = new Map<string, string[]>();
export const ensureSpotifyPlayer = (): Promise<{
socket?: Types.SpotifySocket;
device?: Types.SpotifyDevice;
}> => {
const activePlayer = SpotifyStore.getActiveSocketAndDevice();
if (activePlayer) return Promise.resolve(activePlayer);
const playableDevices = SpotifyStore.getPlayableComputerDevices();
if (playableDevices.length > 0) {
const [{ socket, device }] = playableDevices;
return Promise.resolve({
socket,
device,
});
}
return new Promise((res) => {
const timer = { timeout: null };
const changeListerner = () => {
const playableDevices = SpotifyStore.getPlayableComputerDevices();
const [{ socket, device }] = playableDevices;
clearTimeout(timer?.timeout);
SpotifyStore.removeChangeListener(changeListerner);
res({
socket,
device,
});
};
SpotifyStore.addChangeListener(changeListerner);
timer.timeout = setTimeout(() => {
SpotifyStore.removeChangeListener(changeListerner);
res({});
}, 2500);
open("spotify:");
});
};
export const error = async (res): Promise<Error> => {
switch (res.status) {
case 401:
Expand All @@ -21,13 +55,14 @@ export const error = async (res): Promise<Error> => {
return new Error("Unknown Error, Check the console and report the dev");
}
};
export const play = async (type: string, id: string, accessToken: string): Promise<void> => {
if (!accessToken) {
export const play = async (type: string, id: string): Promise<void> => {
const { socket, device } = await ensureSpotifyPlayer();
if (!socket?.accessToken) {
PluginLogger.error("Please link your Spotify to Discord in Settings > Connections");
return;
}

const SpotifyResponse = await fetch(`${BASE_URL_PLAYER}/play`, {
const SpotifyResponse = await fetch(`${BASE_URL_PLAYER}/play?device_id=${device.id}`, {
method: "PUT",
body: JSON.stringify(
type === "track"
Expand All @@ -36,7 +71,7 @@ export const play = async (type: string, id: string, accessToken: string): Promi
),
headers: {
"Content-Type": "application/json",
Authorization: `Bearer ${accessToken}`,
Authorization: `Bearer ${socket?.accessToken}`,
},
});
if (SpotifyResponse.ok) {
Expand All @@ -45,19 +80,21 @@ export const play = async (type: string, id: string, accessToken: string): Promi
throw await error(SpotifyResponse);
};

export const queue = async (type: string, id: string, accessToken: string): Promise<void> => {
if (!accessToken) {
export const queue = async (type: string, id: string): Promise<void> => {
const { socket, device } = await ensureSpotifyPlayer();
if (!socket?.accessToken) {
PluginLogger.error("Please link your Spotify to Discord in Settings > Connections");
return;
}

const SpotifyResponse = await fetch(
`${BASE_URL_PLAYER}/queue?uri=${encodeURIComponent(`spotify:${type}:${id}`)}`,
`${BASE_URL_PLAYER}/queue?uri=${encodeURIComponent(`spotify:${type}:${id}`)}&device_id=${
device.id
}`,
{
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: `Bearer ${accessToken}`,
Authorization: `Bearer ${socket?.accessToken}`,
},
},
);
Expand Down Expand Up @@ -104,7 +141,6 @@ export const mapMenuItems = (
})
.then((res) => res.json())
.catch(() => ({ name: "Error Fetching Name" }));
console.log(SpotifyResponse);
if (SpotifyResponse?.name)
customCacheSpotifyMeta.set(id, [_, type, id, SpotifyResponse?.name]);
return [_, type, id, SpotifyResponse?.name ?? "Error Fetching Name"];
Expand All @@ -131,24 +167,10 @@ export const mapMenuItems = (
if ((type as { data: boolean }).data) {
return SpotifyMeta;
}
if (SpotifyAccounts.length === 1) {
return [
type.play && MenuItems.play(SpotifyMeta, SpotifyAccounts[0]),
type.queue && MenuItems.addToQueue(SpotifyMeta, SpotifyAccounts[0]),
];
}
return SpotifyAccounts.map((SpotifyAccount) => {
return (
<ContextMenu.MenuItem
label={SpotifyAccount.name}
id={`spotify-account-${SpotifyAccount.name}`}>
{...[
type.play && MenuItems.play(SpotifyMeta, SpotifyAccount),
type.queue && MenuItems.addToQueue(SpotifyMeta, SpotifyAccount),
]}
</ContextMenu.MenuItem>
);
});
return [
type.play && MenuItems.play(SpotifyMeta),
type.queue && MenuItems.addToQueue(SpotifyMeta),
];
} catch {
return [];
}
Expand Down Expand Up @@ -179,13 +201,12 @@ export const manipulateMenu = (
message: Types.Message,
menu: { children: React.ReactElement[] },
): React.ReactElement | void => {
console.log(menu);
const MenuGroup = menu?.children?.find?.((c) => c?.props?.id === "distify") ?? (
<ContextMenu.MenuGroup />
);
MenuGroup.props.id = "distify";
if (!menu?.children?.some?.((c) => c?.props?.id === "distify"))
menu?.children.splice(1, 0, MenuGroup);
menu?.children.splice(-1, 0, MenuGroup);
const SpotifyLinks = Array.from(
message.content.matchAll(/open.spotify.com\/(album|track|playlist)\/([^?]+)/g) as string[][] &
IterableIterator<RegExpMatchArray>,
Expand All @@ -198,22 +219,8 @@ export const manipulateMenu = (
data: true,
}) as string[][];
if (SpotifyLinks.length <= 0) return;
if (SpotifyMeta && SpotifyAccounts.length === 1) {
MenuGroup.props.children = [
MenuItems.play(SpotifyMeta, SpotifyAccounts[0]),
MenuItems.addToQueue(SpotifyMeta, SpotifyAccounts[0]),
];
} else if (SpotifyMeta) {
MenuGroup.props.children = SpotifyAccounts.map((SpotifyAccount) => (
<ContextMenu.MenuItem
label={SpotifyAccount.name}
id={`spotify-account-${SpotifyAccount.name}`}>
{...[
MenuItems.play(SpotifyMeta, SpotifyAccount),
MenuItems.addToQueue(SpotifyMeta, SpotifyAccount),
]}
</ContextMenu.MenuItem>
));
if (SpotifyMeta) {
MenuGroup.props.children = [MenuItems.play(SpotifyMeta), MenuItems.addToQueue(SpotifyMeta)];
}
};

Expand Down
Loading

0 comments on commit f8da399

Please sign in to comment.