2017-02-10 141 views
0

我正在使用Node.js SDK为使用Microsoft bot框架的Skype创建bot。显示CardAction和消息(node.js SDK - skype频道)

我正在尝试几种不同的行为,我遇到了一些问题。

例如,我创建了一组带有图像,文本和3个按钮的ThumbNails卡片。一个按钮打开一个网页。另外两个在Prompt.choice中用于继续进行对话。 问题是我相信我需要显示提示符工作的标签。 这是正确的吗? 因为标签可能很长/或者用户再次看到他按下的内容可能没有任何意义。

我尝试粘贴一些代码,试图更好地解释:

bot.dialog('/mydialog', [ 
    function (session) { 
    // Ask the user to select an item from a carousel. 
    var msg = new builder.Message(session) 
     .textFormat(builder.TextFormat.xml) 
     .attachmentLayout(builder.AttachmentLayout.carousel) 
     .attachments([ 
      new builder.ThumbnailCard(session) 
       .title("Card number 1") 
       .text("Description first card") 
       .images([ 
       builder.CardImage.create(session, "https://www.example.org/img1.gif") 
         .tap(builder.CardAction.showImage(session, "ttps://www.example.org/img1.gif")), 
      ]) 
       .buttons([ 
        builder.CardAction.openUrl(session, "https://google.com", "Website"), 
        builder.CardAction.imBack(session, "select:100", "button 1"), 
        builder.CardAction.imBack(session, "select:101", "Button2") 

       ]), 
      new builder.ThumbnailCard(session) 
       .title("Card 2") 
       .text("Description card 2") 
       .images([ 
        builder.CardImage.create(session, "https://image.jpg") 
         .tap(builder.CardAction.showImage(session, "https://image.jpg")), 
       ]) 
       .buttons([ 
        builder.CardAction.openUrl(session, "https://google.com", "Website"), 
        builder.CardAction.imBack(session, "select:200", "button3"), 
        builder.CardAction.imBack(session, "select:201", "button4") 
       ]), 
      ]); 

    builder.Prompts.choice(session, msg, "select:100|select:101|select:200|select:201"); 
}, 
function (session, results) { 
    var action, item; 
    var kvPair = results.response.entity.split(':'); 
    switch (kvPair[0]) { 
     case 'select': 
      action = 'selected'; 
      break; 
    } 
    switch (kvPair[1]) { 
     case '100': 
      item ="/dialog1"; 
      break; 
     case '101': 
      item ="/dialog2"; 
      break; 
     case '200': 
      item ="/dialog3"; 
      break; 
     case '201': 
      item ="/dialog4"; 
      break; 

    } 

      session.beginDialog(item); 
} 

]); 

回答

0

在你的情况下,它会更好地使用对话的行动。当卡片中的按钮被按下时,它将启动相应的对话框。完成后,它将返回到当前对话框。请注意,您可以在显示卡后随时按下卡上的按钮。所以,这可能会在任何时候发生,这就是为什么对话行为在这里是更好的选择。

bot.beginDialogAction("select:100:action:just:unique:name", 
     "/dialog1", { matches: "select:100"}); 
bot.beginDialogAction("select:101:action:just:unique:name", 
     "/dialog2", { matches: "select:101"}); 
// and so on. 

请注意,如果你不想select:100显示在聊天过程中,你可以使用 builder.CardAction.postBack代替imBack(不支持所有平台)。

+0

嗨谢谢,非常感谢您的回答。 你说得对,可以随时按下,这可能是一个问题。 – jsabina

+0

问题是他们想要卡内的按钮..我会尝试postBack建议,谢谢! – jsabina