mirror of
https://github.com/warengroup/eximiabots-radiox.git
synced 2025-04-19 08:04:50 +00:00
81 lines
3.4 KiB
JavaScript
81 lines
3.4 KiB
JavaScript
import { ActionRowBuilder, ButtonBuilder, ButtonStyle, EmbedBuilder } from "discord.js";
|
|
|
|
module.exports = async function play(client, interaction, guild, station) {
|
|
let message = {};
|
|
const radio = client.radio.get(guild.id);
|
|
const audioPlayer = client.streamer.listen(station);
|
|
radio.connection.subscribe(audioPlayer);
|
|
client.funcs.logger('Radio', guild.id + " / " + "Play" + " / " + radio.station.name);
|
|
|
|
message.nowplayingDescription = client.messages.nowplayingDescription.replace("%radio.station.name%", radio.station.name);
|
|
message.nowplayingDescription = message.nowplayingDescription.replace("%radio.station.owner%", radio.station.name != radio.station.owner ? radio.station.owner + "\n" : "");
|
|
message.nowplayingDescription = message.nowplayingDescription.replace("%client.funcs.msToTime(completed)%", "");
|
|
message.nowplayingDescription = message.nowplayingDescription.replace("**", "");
|
|
message.nowplayingDescription = message.nowplayingDescription.replace("**", "");
|
|
|
|
const embed = new EmbedBuilder()
|
|
.setTitle(client.user.username)
|
|
.setThumbnail((radio.station.logo || "https://cdn.discordapp.com/emojis/" + client.messageEmojis["play"].replace(/[^0-9]+/g, '')))
|
|
.setColor(client.config.embedColor)
|
|
.addFields({
|
|
name: client.messages.nowplayingTitle,
|
|
value: message.nowplayingDescription
|
|
})
|
|
.setImage('https://waren.io/berriabot-temp-sa7a36a9xm6837br/images/empty-3.png')
|
|
.setFooter({
|
|
text: client.messages.footerText,
|
|
iconURL: "https://cdn.discordapp.com/emojis/" + client.messageEmojis["eximiabots"].replace(/[^0-9]+/g, '')
|
|
});
|
|
|
|
const buttons = new ActionRowBuilder()
|
|
.addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId('list')
|
|
.setEmoji(client.messageEmojis["list"])
|
|
.setStyle(ButtonStyle.Secondary)
|
|
)
|
|
.addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId('prev')
|
|
.setEmoji(client.messageEmojis["prev"])
|
|
.setStyle(ButtonStyle.Secondary)
|
|
)
|
|
.addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId('stop')
|
|
.setEmoji(client.messageEmojis["stop"])
|
|
.setStyle(ButtonStyle.Secondary)
|
|
)
|
|
.addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId('next')
|
|
.setEmoji(client.messageEmojis["next"])
|
|
.setStyle(ButtonStyle.Secondary)
|
|
)
|
|
.addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId('statistics')
|
|
.setEmoji(client.messageEmojis["statistics"])
|
|
.setStyle(ButtonStyle.Secondary)
|
|
);
|
|
|
|
if(!radio.message){
|
|
radio.message = await radio.textChannel?.send({ embeds: [embed], components: [buttons] });
|
|
} else {
|
|
if(radio.textChannel.id == radio.message.channel.id){
|
|
radio.message.edit({ embeds: [embed], components: [buttons] });
|
|
} else {
|
|
radio.message?.delete();
|
|
radio.message = await radio.textChannel?.send({ embeds: [embed], components: [buttons] });
|
|
}
|
|
}
|
|
|
|
message.play = client.messages.play.replace("%radio.station.name%", radio.station.name);
|
|
|
|
interaction?.reply({
|
|
content: client.messageEmojis["play"] + message.play,
|
|
ephemeral: true
|
|
});
|
|
|
|
}
|