我创建了一个系统,允许用户在频道中发送投票,并希望在私人消息中为他们提供额外的选项。为此,我尝试在用户使用表情符号对此私人消息做出反应时切换投票选项。服务器部分工作得很好,但我无法让私人消息反应按预期工作。
总结:当用户对带有表情符号的私人消息做出反应时,我正在尝试做一些事情。对于服务器频道,我已经很好地工作了。
为了测试这一点,我尝试了以下方法:
第一个似乎没有被私人消息调用。
client.on('messageReactionAdd', (reaction, user) => {
console.log("added response");
});
client.on('messageReactionRemove', (reaction, user) => {
console.log("removed response");
});
第二个是响应“!beep”命令运行的测试代码。然而显示了一些问题:
过滤器永远不会通过,“收集”永远不会被记录。
过滤器仅在添加反应后才起作用(我认为这是因为异步,但我希望用户能够在按下反应时切换选项)
删除反应时不会触发代码(我认为这是因为 awaitReactions 不支持该功能,但我希望用户能够在按下反应时切换选项,无论他们是添加还是删除它)
我尝试删除错误位,该位在时间结束后记录“已收集”。但我希望它具有响应性,因此是即时的,而且我还希望它可以重复使用,以便用户可以打开和关闭它。
const reactions = ["0️⃣", "1️⃣", "2️⃣", "3️⃣", "4️⃣", "5️⃣", "6️⃣", "7️⃣", "8️⃣", "9️⃣", "🔟"];
message.channel.send('@here Boop :robot:')
.then(async (sentMessage) => {
for (var i=0; i < reactions.length; i++) {
await sentMessage.react(reactions[i]);
}
/////////////// TEST CODE!!!!
const filter = (reaction, user) => {
console.log("filter called");
return true;
};
sentMessage.awaitReactions(filter, { time: 33000, errors: ['time'] })
.then(collected => {
console.log("collected");
const reaction = collected.first();
console.log(reaction.emoji);
})
.catch(collected => {
console.log("Time's up");
});
});;
TLDR:我想在私人消息中向用户提供投票配置面板,允许所述用户通过单击对所述配置面板的反应来切换选项。
我试过的东西没有用。难道我做错了什么?还有其他方法可以做到这一点吗?或者这根本不可能?
qq_笑_17
慕慕森
随时随地看视频慕课网APP
相关分类