如何在单击一次时禁用自适应卡片?

How to disable Adaptive Cards on clicking once?

我在 MSTeams Bot 中使用自适应卡片,点击一次我想禁用提交按钮以防止用户再次点击它,因为按钮点击事件的后端是 运行。

自适应卡代码-

async specialRewards() {
const specialRewardCard = CardFactory.adaptiveCard({
  '$schema': 'http://adaptivecards.io/schemas/adaptive-card.json',
  'version': '1.2',
  'type': 'AdaptiveCard',
  'body': [
    {
      'type': 'TextBlock',
      'text': "Hey there! \n\n",
      'wrap': true,
    },
    {
      'type': 'TextBlock',
      'text': 'Your birthday :',
      'weight': 'Bolder',
      'wrap': true,
    },
    {
      'type': 'Input.Date',
      'id': 'birthday',
      'placeholder': 'Enter a date',
      'spacing': 'Padding',
    },
    {
      'type': 'TextBlock',
      'text': 'Your work anniversary :',
      'weight': 'Bolder',
      'wrap': true,
    },
    {
      'type': 'Input.Date',
      'id': 'anniversary',
      'placeholder': 'Enter a date',
      'spacing': 'Padding',
    },
  ],
  'actions': [
    {
      'type': 'Action.Submit',
      'title': 'Submit',
      'isPrimary': true,
    },
  ],
});
return specialRewardCard;

}

这是它在 MSTeams 上的样子

我目前正在处理类似的场景,我发现 updateActivity() 函数运行良好。

  // Update the adaptive card so it cannot be used again
  async followUp() {
  const card = CardFactory.heroCard(
     'Your card results',
     '<b>Birthday:</b> ' + birthday + '<br>' + '<b>Anniversary:</b> ' + anniversary,
     null
     );
     card.id = step.context.activity.replyToId;
     const message = MessageFactory.attachment(card);
     message.id = step.context.activity.replyToId;
     await step.context.updateActivity(message);
   }