3
0
Fork 0
mirror of https://github.com/ZeppelinBot/Zeppelin.git synced 2025-03-14 21:31:50 +00:00

feat: use a standard custom ID format in role buttons

This commit is contained in:
Dragory 2022-04-23 17:45:47 +03:00
parent 784c54b22a
commit b64611dd01
No known key found for this signature in database
GPG key ID: 5F387BA66DF8AAC1
4 changed files with 30 additions and 3 deletions

View file

@ -3,16 +3,22 @@ import { RoleButtonsPluginType, TRoleButtonOption } from "../types";
import { RoleManagerPlugin } from "../../RoleManager/RoleManagerPlugin";
import { GuildMember } from "discord.js";
import { getAllRolesInButtons } from "../functions/getAllRolesInButtons";
import { parseCustomId } from "../../../utils/parseCustomId";
export const onButtonInteraction = typedGuildEventListener<RoleButtonsPluginType>()({
event: "interactionCreate",
async listener({ pluginData, args }) {
if (!args.interaction.isButton() || !args.interaction.customId.startsWith("roleButtons:")) {
if (!args.interaction.isButton()) {
return;
}
const { namespace, data } = parseCustomId(args.interaction.customId);
if (namespace !== "roleButtons") {
return;
}
const config = pluginData.config.get();
const [, name, optionIndex] = args.interaction.customId.split(":");
const { name, index: optionIndex } = data;
// For some reason TS's type inference fails here so using a type annotation
const buttons = config.buttons[name];
const option: TRoleButtonOption | undefined = buttons?.options[optionIndex];

View file

@ -5,6 +5,7 @@ import { LogsPlugin } from "../../Logs/LogsPlugin";
import { Message, MessageButton, MessageEditOptions, MessageOptions, Snowflake } from "discord.js";
import { RoleButtonsItem } from "../../../data/entities/RoleButtonsItem";
import { splitButtonsIntoRows } from "./splitButtonsIntoRows";
import { buildCustomId } from "../../../utils/buildCustomId";
const channelMessageRegex = new RegExp(`^(${snowflakeRegex.source})-(${snowflakeRegex.source})$`);
@ -107,7 +108,7 @@ export async function applyRoleButtons(
const button = new MessageButton()
.setLabel(opt.label ?? "")
.setStyle(opt.style ?? "PRIMARY")
.setCustomId(`roleButtons:${configItem.name}:${index}:${Math.round(Date.now() / 1000)}`);
.setCustomId(buildCustomId("roleButtons", { name: configItem.name, index }));
if (opt.emoji) {
const emo = pluginData.client.emojis.resolve(opt.emoji as Snowflake) ?? opt.emoji;

View file

@ -0,0 +1,3 @@
export function buildCustomId(namespace: string, data: any = {}) {
return `${namespace}:${Date.now()}:${JSON.stringify(data)}`;
}

View file

@ -0,0 +1,17 @@
const customIdFormat = /^([^:]+):\d+:(.*)$/;
export function parseCustomId(customId: string): { namespace: string; data: any } {
const parts = customId.match(customIdFormat);
if (!parts) {
return {
namespace: "",
data: null,
};
}
return {
namespace: parts[1],
// Skipping timestamp
data: JSON.parse(parts[2]),
};
}