Azure Bot Framework, использующий React, имеет проблемы - PullRequest
0 голосов
/ 17 июня 2019

Ниже мой код написан для фреймворка ботов, я ссылался на документацию в git hub, а также следил за большим количеством статей и постами из переполнения стека, похоже, он выдает ошибку при отображении бота в строке WebChat.Чат, вот также ссылка из сообщения в stackoverlfow:

declare var require: any
var React = require('react');
var ReactDOM = require('react-dom');
var DirectLine  = require('botframework-directlinejs');
//import * as WebChat from 'botframework-webchat';
var WebChat = require('botframework-webchat');


export class Hello extends React.Component {
    constructor() {
        super();
        this.state = { data: [] };
        this.variableValue = { dataValue: [] };

    }
    async componentDidMount() {
        const response = await fetch('https://directline.botframework.com/v3/directline/tokens/generate', {
            method: 'POST',
            headers: {
                'Authorization': 'Bearer secretvalue',
                'Accept': 'application/json',
                'Content-Type': 'application/json',
            },
            body: JSON.stringify({
                accessLevel: 'View',
                allowSaveAs: 'false',
            })
        });
        // const { token } = await res.json();
        const { token } = await response.json();
        console.log(token);
        this.setState({ data: token });
        // 
    }
    render() {
        const {
            state: { data }
        } = this

        return (

            //<div>
            //    <p>Hello there1</p>
            //    <ul>
            //        {data}
            //    </ul>
            //</div>
            <WebChat.Chat
                directLine={{
                   data,
                    webSocket: false
                }}
                style={{
                    height: '100%',
                    width: '100%'
                }}
                //user={{
                //    id: 'default-user',
                //    name: 'Some User'
                //}}
            />



        );
    }

}

ReactDOM.render(<Hello />, document.getElementById('root'));

Я могу получить токен с помощью вызова rest, но получаю сообщение об ошибке при отображении бота,использование WebChat.Chat directLine Ниже приведена ошибка: enter image description here enter image description here

РЕДАКТИРОВАТЬ Мне удалось запустить код в HTMLфайл с помощьюact и babel, ниже приведен код ....

<!DOCTYPE html>
<html lang="en-US">
  <head>
    <title>Web Chat: Integrate with React</title>
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!--
      For simplicity and code clarity, we are using Babel and React from unpkg.com.
    -->
    <script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>
    <script src="https://unpkg.com/react@16.5.0/umd/react.development.js"></script>
    <script src="https://unpkg.com/react-dom@16.5.0/umd/react-dom.development.js"></script>
    <!--
      For demonstration purposes, we are using the development branch of Web Chat at "/master/webchat.js".
      When you are using Web Chat for production, you should use the latest stable release at "/latest/webchat.js",
      or lock down on a specific version with the following format: "/4.1.0/webchat.js".
    -->
    <script src="https://cdn.botframework.com/botframework-webchat/master/webchat.js"></script>
    <style>
      html, body { height: 100% }
      body { margin: 0 }

      #webchat {
        height: 100%;
        width: 100%;
      }
    </style>
  </head>
  <body>
    <div id="webchat" role="main"></div>
    <script type="text/babel">
        (async function () {
        // In this demo, we are using Direct Line token from MockBot.
        // To talk to your bot, you should use the token exchanged using your Direct Line secret.
        // You should never put the Direct Line secret in the browser or client app.
        // https://docs.microsoft.com/en-us/azure/bot-service/rest-api/bot-framework-rest-direct-line-3-0-authentication
        const headers = {"Authorization": "Bearer rngzqJ7rkng.cwA.A8k.xg_Jb-NbNs4Kq8O2CcF-vnNxy8nlCMPMPYaXL0oROr0"}
        const body = {"accessLevel": "View"}
        //const res = await fetch('https://directline.botframework.com/v3/directline/tokens/generate', { method: 'POST' }, {Headers:headers},{Body:body});
        //const res = await fetch('https://webchat-mockbot.azurewebsites.net/directline/token', { method: 'POST' });

        const res = await fetch('https://directline.botframework.com/v3/directline/tokens/generate', {
        method: 'POST',
        headers: {
        'Authorization': 'Bearer secretvalue',
        'Accept': 'application/json',
        'Content-Type': 'application/json',
        },
        body: JSON.stringify({
        accessLevel: 'View',
        allowSaveAs: 'false',
        })
        });

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

        document.querySelector('#webchat > *').focus();
        })().catch(err => console.error(err));
    </script>
  </body>
</html>

Но когда я использую его в приложении узла js, при использовании WebCHat.Chat возникают проблемы.

1 Ответ

3 голосов
/ 17 июня 2019

Существует две версии веб-чата - v3 и v4.Проблема StackOverflow, на которую вы ссылались, использует Web Chat v3, а используемая вами зависимость - v4.Посмотрите на фрагмент кода ниже, чтобы узнать, как должна выглядеть ваша реализация Web Chat v4 с Node.

import React from 'react';

import ReactWebChat, { createDirectLine } from 'botframework-webchat';

export default class extends React.Component {
  constructor(props) {
    super(props);

    this.state = {
      directLine: null
    };
  }

  componentDidMount() {
    this.fetchToken();
  }

  async fetchToken() {
    const res = await fetch('https://webchat-mockbot.azurewebsites.net/directline/token', { method: 'POST' });
    const { token } = await res.json();

    this.setState(() => ({
      directLine: createDirectLine({ token })
    }));
  }

  render() {
    return (
      this.state.directLine ?
        <ReactWebChat
          className="chat"
          directLine={ this.state.directLine }
        />
      :
        <div>Connecting to bot&hellip;</div>
    );
  }
}

Для получения более подробной информации, посмотрите samples на GitHub Repo -Пример 17 - хороший пример для реализации Node.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...