mirror of
https://github.com/Burn-E99/GroupUp.git
synced 2026-01-06 19:37:54 -05:00
Handle TODO for rejecting a promotion
This commit is contained in:
32
src/buttons/live-event/leaveViaDM.ts
Normal file
32
src/buttons/live-event/leaveViaDM.ts
Normal file
@ -0,0 +1,32 @@
|
||||
import { Bot, Interaction } from '../../../deps.ts';
|
||||
import { dbClient, queries } from '../../db.ts';
|
||||
import { somethingWentWrong } from '../../commandUtils.ts';
|
||||
import utils from '../../utils.ts';
|
||||
import { removeMemberFromEvent } from './utils.ts';
|
||||
import { pathIdxEnder, idSeparator, pathIdxSeparator } from '../eventUtils.ts';
|
||||
|
||||
export const customId = 'leaveEventViaDM';
|
||||
|
||||
const execute = async (bot: Bot, interaction: Interaction) => {
|
||||
if (interaction.data?.customId) {
|
||||
// Light Telemetry
|
||||
dbClient.execute(queries.callIncCnt('btn-leaveEventViaDM')).catch((e) => utils.commonLoggers.dbError('leaveEventViaDM.ts', 'call sproc INC_CNT on', e));
|
||||
|
||||
const [evtGuildId, evtChannelId, evtMessageId] = (interaction.data.customId.replaceAll(pathIdxEnder, '').split(idSeparator)[1] || '').split(pathIdxSeparator).map((id) => BigInt(id || '0'));
|
||||
const eventMessage = await bot.helpers.getMessage(evtChannelId, evtMessageId).catch((e: Error) => utils.commonLoggers.messageGetError('editActivity.ts', 'get eventMessage', e));
|
||||
|
||||
if (eventMessage && eventMessage.embeds[0]) {
|
||||
// Remove user from event
|
||||
removeMemberFromEvent(bot, interaction, eventMessage.embeds[0], evtMessageId, evtChannelId, interaction.user.id, evtGuildId, true);
|
||||
} else {
|
||||
somethingWentWrong(bot, interaction, 'getEventFailInLeaveEventViaDMButton');
|
||||
}
|
||||
} else {
|
||||
somethingWentWrong(bot, interaction, 'noDataFromLeaveEventViaDMButton');
|
||||
}
|
||||
};
|
||||
|
||||
export const leaveEventViaDMButton = {
|
||||
customId,
|
||||
execute,
|
||||
};
|
||||
@ -1,10 +1,11 @@
|
||||
import { ActionRow, ApplicationCommandFlags, Bot, ButtonStyles, Embed, Interaction, InteractionResponseTypes, MessageComponentTypes } from '../../../deps.ts';
|
||||
import { LFGMember, UrlIds } from '../../types/commandTypes.ts';
|
||||
import { infoColor1, safelyDismissMsg, sendDirectMessage, somethingWentWrong, successColor } from '../../commandUtils.ts';
|
||||
import { generateAlternateList, generateMemberList, generateMemberTitle, idSeparator, leaveEventBtnStr, LfgEmbedIndexes, noMembersStr } from '../eventUtils.ts';
|
||||
import { generateAlternateList, generateMemberList, generateMemberTitle, idSeparator, leaveEventBtnStr, LfgEmbedIndexes, noMembersStr, pathIdxSeparator } from '../eventUtils.ts';
|
||||
import { selfDestructMessage } from '../tokenCleanup.ts';
|
||||
import { approveStr, customId as joinRequestCustomId, denyStr } from './joinRequest.ts';
|
||||
import { customId as updateEventCustomId } from './updateEvent.ts';
|
||||
import { customId as leaveViaDMCustomId } from './leaveViaDM.ts';
|
||||
import utils from '../../utils.ts';
|
||||
|
||||
// Join status map to prevent spamming the system
|
||||
@ -206,7 +207,7 @@ export const removeMemberFromEvent = async (
|
||||
type: MessageComponentTypes.Button,
|
||||
label: leaveEventBtnStr,
|
||||
style: ButtonStyles.Danger,
|
||||
customId: 'leaveEventCustomId', // TODO: fix
|
||||
customId: `${leaveViaDMCustomId}${idSeparator}${evtGuildId}${pathIdxSeparator}${evtChannelId}${pathIdxSeparator}${evtMessageId}`,
|
||||
}],
|
||||
}],
|
||||
}).catch((e: Error) => utils.commonLoggers.messageSendError('utils.ts', 'user promotion dm', e));
|
||||
|
||||
Reference in New Issue
Block a user