禁用用户输入文本框 c#

Vys*_*avi 1 bots chatbot botframework

是否可以在任何频道的 V4 机器人框架中禁用用户键入输入文本区域?我将此作为客户要求的一部分 有人可以帮助我吗

在此处输入图片说明

Ste*_*erg 6

您所指的邮箱称为发送邮箱。如果您正在使用BotFramework-Web Chat,您可以通过styleOptions像这样传递值来禁用它:

<script>
  (async function () {

    const styleOptions = {
      hideSendBox = true
    }

    [...]

    window.ReactDOM.render(
      <ReactWebChat
        directLine={directLine},
        styleOptions={styleOptions}
      />,
      document.getElementById( 'webchat' )
    );
  })
</script>
Run Code Online (Sandbox Code Playgroud)

如果您使用的是 Web Chat 的 iFrame 嵌入式版本,则它是不可配置的。

希望得到帮助!


编辑

如果您希望发送框根据从机器人接收到的活动类型做出响应,那么您将需要使用该activityMiddleware()功能以及事件发射器/侦听器的组合。在下面的示例中,当suggestedActions是活动属性时,我将隐藏/显示发送框。

请注意,数据值应为“none”和“flex”。尤其是后者的值时,它不是suggestedActions为了维护当前代码。

<script>
  (async function () {

    [...]

    const activityMiddleware = () => next => card => {
      const { activity: { suggestedActions } } = card;
      const toggleSendBoxEvent = new Event('ToggleSendBoxEvent')
      if (suggestedActions) {
        toggleSendBoxEvent.data = "none";
        window.dispatchEvent(toggleSendBoxEvent);
      } else {
        toggleSendBoxEvent.data = "flex";
        window.dispatchEvent(toggleSendBoxEvent);
      }
  
      return next(card);
    )

    [...]

    window.ReactDOM.render(
      <ReactWebChat
        directLine={ window.WebChat.createDirectLine({ token }) }
        activityMiddleware={ activityMiddleware }
      />,
      document.getElementById( 'webchat' )
    );

    window.addEventListener('ToggleSendBoxEvent', ( { data } ) => {
      const sendBoxes = document.getElementsByClassName("main");
      let send_Box;
      for (let sendBox of sendBoxes) {
        send_Box = sendBox;
      }
      send_Box.setAttribute('style', `display:${ data }`)
    })

  });
</script>
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

希望得到帮助!