mirror of
https://github.com/aydenjahola/discord-multipurpose-bot.git
synced 2024-11-22 00:35:56 +00:00
add tft endpoint
This commit is contained in:
parent
5cbee0bed5
commit
299ee23d32
2 changed files with 92 additions and 2 deletions
89
commands/stats/tft.js
Normal file
89
commands/stats/tft.js
Normal file
|
@ -0,0 +1,89 @@
|
|||
const { SlashCommandBuilder, EmbedBuilder } = require("discord.js");
|
||||
const axios = require("axios");
|
||||
|
||||
module.exports = {
|
||||
data: new SlashCommandBuilder()
|
||||
.setName("tftstats")
|
||||
.setDescription("Fetches TFT player stats.")
|
||||
.addStringOption((option) =>
|
||||
option
|
||||
.setName("username")
|
||||
.setDescription(
|
||||
"The TFT username to fetch stats for (e.g., Shitter#1234"
|
||||
)
|
||||
.setRequired(true)
|
||||
),
|
||||
|
||||
async execute(interaction) {
|
||||
const username = interaction.options.getString("username");
|
||||
|
||||
// Convert the username by replacing "#" with "%23"
|
||||
const formattedUsername = username.replace("#", "%23");
|
||||
|
||||
const apiUrl = process.env.TRACKER_API_URL;
|
||||
const apiKey = process.env.TRACKER_API_KEY;
|
||||
|
||||
const url = `https://${apiUrl}/tft/player/${formattedUsername}`;
|
||||
|
||||
try {
|
||||
await interaction.deferReply();
|
||||
|
||||
// Fetch data from the API
|
||||
const response = await axios.get(url, {
|
||||
headers: {
|
||||
"X-API-Key": apiKey,
|
||||
},
|
||||
});
|
||||
|
||||
const data = response.data;
|
||||
|
||||
const statsEmbed = new EmbedBuilder()
|
||||
.setColor("#ff4500")
|
||||
.setTitle(`${data.username}'s TFT Stats`)
|
||||
.addFields(
|
||||
{
|
||||
name: "🏆 Current Rank",
|
||||
value: data.current_rank,
|
||||
},
|
||||
{
|
||||
name: "📈 LP",
|
||||
value: `${data.lp}`,
|
||||
},
|
||||
{
|
||||
name: "🎮 Matches Played",
|
||||
value: `${data.matches_played}`,
|
||||
},
|
||||
{
|
||||
name: "🏅 Wins",
|
||||
value: `${data.wins}`,
|
||||
},
|
||||
{
|
||||
name: "💔 Losses",
|
||||
value: `${data.losses}`,
|
||||
},
|
||||
{
|
||||
name: "📊 Win Percentage",
|
||||
value: `${data.win_percentage}%`,
|
||||
}
|
||||
)
|
||||
.setTimestamp()
|
||||
.setFooter({
|
||||
text: "TFT Stats API made by Ayden",
|
||||
iconURL: interaction.guild.iconURL(),
|
||||
});
|
||||
|
||||
return interaction.editReply({ embeds: [statsEmbed] });
|
||||
} catch (error) {
|
||||
console.error("Error fetching player stats:", error);
|
||||
if (error.response) {
|
||||
return interaction.editReply(
|
||||
`Error: ${error.response.data.message || error.response.statusText}`
|
||||
);
|
||||
} else {
|
||||
return interaction.editReply(
|
||||
"An error occurred while fetching player stats."
|
||||
);
|
||||
}
|
||||
}
|
||||
},
|
||||
};
|
|
@ -29,10 +29,11 @@ module.exports = {
|
|||
|
||||
// Convert the username by replacing "#" with "%23"
|
||||
const formattedUsername = username.replace("#", "%23");
|
||||
const apiKeyUrl = process.env.TRACKER_API_URL;
|
||||
|
||||
const apiUrl = process.env.TRACKER_API_URL;
|
||||
const apiKey = process.env.TRACKER_API_KEY;
|
||||
|
||||
const url = `https://${apiKeyUrl}/valorant/player/${formattedUsername}/${statsType}`;
|
||||
const url = `https://${apiUrl}/valorant/player/${formattedUsername}/${statsType}`;
|
||||
|
||||
try {
|
||||
await interaction.deferReply();
|
||||
|
|
Loading…
Reference in a new issue