Discord.js awaitReactions 或在 messageReaction 上添加私信

我创建了一个系统,允许用户在频道中发送投票,并希望在私人消息中为他们提供额外的选项。为此,我尝试在用户使用表情符号对此私人消息做出反应时切换投票选项。服务器部分工作得很好,但我无法让私人消息反应按预期工作。


总结:当用户对带有表情符号的私人消息做出反应时,我正在尝试做一些事情。对于服务器频道,我已经很好地工作了。


为了测试这一点,我尝试了以下方法:


第一个似乎没有被私人消息调用。


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
浏览 178回答 1
1回答

慕慕森

在调试了更多之后,我发现了问题,因此以防万一有人在这里遇到问题;这些确实有效,我只是有一个 if 语句妨碍了我 XD。client.on('messageReactionAdd', (reaction, user) => {&nbsp; &nbsp; console.log("added response");});client.on('messageReactionRemove', (reaction, user) => {&nbsp; &nbsp; console.log("removed response");});
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript