Work on !invite styles
This commit is contained in:
parent
ff056def4a
commit
1040bf581a
2 changed files with 75 additions and 44 deletions
|
@ -5,10 +5,12 @@ import { snowflakeToTimestamp } from "../../../utils/snowflakeToTimestamp";
|
||||||
import moment from "moment-timezone";
|
import moment from "moment-timezone";
|
||||||
import humanizeDuration from "humanize-duration";
|
import humanizeDuration from "humanize-duration";
|
||||||
import {
|
import {
|
||||||
|
embedPadding,
|
||||||
emptyEmbedValue,
|
emptyEmbedValue,
|
||||||
formatNumber,
|
formatNumber,
|
||||||
isRESTGroupDMInvite,
|
isRESTGroupDMInvite,
|
||||||
isRESTGuildInvite,
|
isRESTGuildInvite,
|
||||||
|
preEmbedPadding,
|
||||||
resolveInvite,
|
resolveInvite,
|
||||||
trimLines,
|
trimLines,
|
||||||
} from "../../../utils";
|
} from "../../../utils";
|
||||||
|
@ -27,54 +29,72 @@ export async function getInviteInfoEmbed(
|
||||||
fields: [],
|
fields: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
embed.author = {
|
||||||
|
name: `Server Invite - ${invite.guild.name}`,
|
||||||
|
url: `https://discord.gg/${invite.code}`,
|
||||||
|
};
|
||||||
|
|
||||||
if (invite.guild.icon) {
|
if (invite.guild.icon) {
|
||||||
embed.thumbnail = {
|
embed.author.icon_url = `https://cdn.discordapp.com/icons/${invite.guild.id}/${invite.guild.icon}.png?size=256`;
|
||||||
url: `https://cdn.discordapp.com/icons/${invite.guild.id}/${invite.guild.icon}.png?size=256`,
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
embed.title = `Server Invite - ${invite.guild.name}`;
|
if (invite.guild.description) {
|
||||||
embed.url = `https://discord.gg/${invite.code}`;
|
embed.description = invite.guild.description;
|
||||||
|
}
|
||||||
|
|
||||||
embed.fields.push({
|
const serverCreatedAtTimestamp = snowflakeToTimestamp(invite.guild.id);
|
||||||
name: "Server ID",
|
const serverCreatedAt = moment(serverCreatedAtTimestamp, "x");
|
||||||
value: `\`${invite.guild.id}\``,
|
const serverAge = humanizeDuration(Date.now() - serverCreatedAtTimestamp, {
|
||||||
inline: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
embed.fields.push({
|
|
||||||
name: "Channel",
|
|
||||||
value:
|
|
||||||
invite.channel.type === Constants.ChannelTypes.GUILD_VOICE
|
|
||||||
? `🔉 ${invite.channel.name}\n\`${invite.channel.id}\``
|
|
||||||
: `#${invite.channel.name}\n\`${invite.channel.id}\``,
|
|
||||||
});
|
|
||||||
|
|
||||||
const createdAtTimestamp = snowflakeToTimestamp(invite.guild.id);
|
|
||||||
const createdAt = moment(createdAtTimestamp, "x");
|
|
||||||
const serverAge = humanizeDuration(Date.now() - createdAtTimestamp, {
|
|
||||||
largest: 2,
|
largest: 2,
|
||||||
round: true,
|
round: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
embed.fields.push({
|
embed.fields.push({
|
||||||
name: "Server age",
|
name: preEmbedPadding + "Server information",
|
||||||
value: serverAge,
|
value: trimLines(`
|
||||||
|
Name: **${invite.guild.name}**
|
||||||
|
ID: \`${invite.guild.id}\`
|
||||||
|
Created: **${serverAge} ago**
|
||||||
|
Members: **${formatNumber(invite.memberCount)}** (${formatNumber(invite.presenceCount)} online)
|
||||||
|
`),
|
||||||
|
inline: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const channelName =
|
||||||
|
invite.channel.type === Constants.ChannelTypes.GUILD_VOICE
|
||||||
|
? `🔉 ${invite.channel.name}`
|
||||||
|
: `#${invite.channel.name}`;
|
||||||
|
|
||||||
|
const channelCreatedAtTimestamp = snowflakeToTimestamp(invite.channel.id);
|
||||||
|
const channelCreatedAt = moment(channelCreatedAtTimestamp, "x");
|
||||||
|
const channelAge = humanizeDuration(Date.now() - channelCreatedAtTimestamp, {
|
||||||
|
largest: 2,
|
||||||
|
round: true,
|
||||||
|
});
|
||||||
|
|
||||||
|
let channelInfo = trimLines(`
|
||||||
|
Name: **${channelName}**
|
||||||
|
ID: \`${invite.channel.id}\`
|
||||||
|
Created: **${channelAge} ago**
|
||||||
|
`);
|
||||||
|
|
||||||
|
if (invite.channel.type !== Constants.ChannelTypes.GUILD_VOICE) {
|
||||||
|
channelInfo += `\nMention: <#${invite.channel.id}>`;
|
||||||
|
}
|
||||||
|
|
||||||
embed.fields.push({
|
embed.fields.push({
|
||||||
name: "Members",
|
name: preEmbedPadding + "Channel information",
|
||||||
value: `**${formatNumber(invite.memberCount)}** (${formatNumber(invite.presenceCount)} online)`,
|
value: channelInfo,
|
||||||
inline: true,
|
inline: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
if (invite.inviter) {
|
if (invite.inviter) {
|
||||||
embed.fields.push({
|
embed.fields.push({
|
||||||
name: "Invite creator",
|
name: preEmbedPadding + "Invite creator",
|
||||||
value: trimLines(`
|
value: trimLines(`
|
||||||
<@!${invite.inviter.id}>
|
Name: **${invite.inviter.username}#${invite.inviter.discriminator}**
|
||||||
${invite.inviter.username}#${invite.inviter.discriminator}
|
ID: \`${invite.inviter.id}\`
|
||||||
\`${invite.inviter.id}\`
|
Mention: <@!${invite.inviter.id}>
|
||||||
`),
|
`),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -87,32 +107,42 @@ export async function getInviteInfoEmbed(
|
||||||
fields: [],
|
fields: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
embed.author = {
|
||||||
|
name: invite.channel.name ? `Group DM Invite - ${invite.channel.name}` : `Group DM Invite`,
|
||||||
|
url: `https://discord.gg/${invite.code}`,
|
||||||
|
};
|
||||||
|
|
||||||
if (invite.channel.icon) {
|
if (invite.channel.icon) {
|
||||||
embed.thumbnail = {
|
embed.author.icon_url = `https://cdn.discordapp.com/channel-icons/${invite.channel.id}/${invite.channel.icon}.png?size=256`;
|
||||||
url: `https://cdn.discordapp.com/channel-icons/${invite.channel.id}/${invite.channel.icon}.png?size=256`,
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
embed.title = invite.channel.name ? `Group DM Invite - ${invite.channel.name}` : `Group DM Invite`;
|
const channelCreatedAtTimestamp = snowflakeToTimestamp(invite.channel.id);
|
||||||
|
const channelCreatedAt = moment(channelCreatedAtTimestamp, "x");
|
||||||
embed.fields.push({
|
const channelAge = humanizeDuration(Date.now() - channelCreatedAtTimestamp, {
|
||||||
name: "Channel ID",
|
largest: 2,
|
||||||
value: `\`${invite.channel.id}\``,
|
round: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
embed.fields.push({
|
embed.fields.push({
|
||||||
name: "Members",
|
name: preEmbedPadding + "Group DM information",
|
||||||
value: formatNumber((invite as any).memberCount),
|
value: trimLines(`
|
||||||
|
Name: ${invite.channel.name ? `**${invite.channel.name}**` : `_Unknown_`}
|
||||||
|
ID: \`${invite.channel.id}\`
|
||||||
|
Created: **${channelAge} ago**
|
||||||
|
Members: **${formatNumber((invite as any).memberCount)}**
|
||||||
|
`),
|
||||||
|
inline: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
if (invite.inviter) {
|
if (invite.inviter) {
|
||||||
embed.fields.push({
|
embed.fields.push({
|
||||||
name: "Invite creator",
|
name: preEmbedPadding + "Invite creator",
|
||||||
value: trimLines(`
|
value: trimLines(`
|
||||||
<@!${invite.inviter.id}>
|
Name: **${invite.inviter.username}#${invite.inviter.discriminator}**
|
||||||
${invite.inviter.username}#${invite.inviter.discriminator}
|
ID: \`${invite.inviter.id}\`
|
||||||
\`${invite.inviter.id}\`
|
Mention: <@!${invite.inviter.id}>
|
||||||
`),
|
`),
|
||||||
|
inline: true,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -539,6 +539,7 @@ export function indentLines(str: string, indentLength: number) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const emptyEmbedValue = "\u200b";
|
export const emptyEmbedValue = "\u200b";
|
||||||
|
export const preEmbedPadding = emptyEmbedValue + "\n";
|
||||||
export const embedPadding = "\n" + emptyEmbedValue;
|
export const embedPadding = "\n" + emptyEmbedValue;
|
||||||
|
|
||||||
export const userMentionRegex = /<@!?([0-9]+)>/g;
|
export const userMentionRegex = /<@!?([0-9]+)>/g;
|
||||||
|
|
Loading…
Add table
Reference in a new issue