GithubHelp home page GithubHelp logo

Comments (3)

InfinytRam avatar InfinytRam commented on June 9, 2024 1

Hi @ajishanv, I'm investigating.

from botframework-directlinejs.

InfinytRam avatar InfinytRam commented on June 9, 2024

Hi @ajishanv,

I'm not able to reproduce this issue. I was able to send a message from the client to the bot with the ability to include attachments.

I tested the .postMessageWithAttachments method in WebChat Client.

Exaple:

  1. Creates a new instance of the DirectLine object from the botframework-directlinejs library
 const directLine = window.WebChat.createDirectLine({
      token: token
  });

Sharing the WebChat's createDirectLine method implementation detail.

  1. Call .postMessageWithAttachments method
directLine.postMessageWithAttachments({......})

Sharing full WebChat/DirectLine client code:

<!DOCTYPE html>
<html>

<head>
    <script src="https://cdn.botframework.com/botframework-webchat/latest/webchat.js"></script>
<style type="text/css">
    html,
    body {
        background-color: #f7f7f7;
        height: 100%;
    }

    body {
        background-image: url(/images/BotServices-Translucent.svg);
        background-position: 100% 100%;
        background-repeat: no-repeat;
        background-size: auto 50%;
        margin: 0;
    }

    #webchat {
        border-radius: 4px;
        box-shadow: 0 0 8px rgba(0, 0, 0, 0.08);
        height: calc(100% - 20px);
        left: 10px;
        overflow: hidden;
        position: fixed;
        top: 10px;
        width: 360px;
    }
</style>
</head>

<body>
    <div id="webchat"></div>
    <script>
        async function fetchToken() {
            const res = await fetch('http://localhost:5001/api/directline/token', { method: 'GET' });
            const { token } = await res.json();
            console.log("Token is: ", token);
            return token;
        }

        async function initializeWebChat() {
            const token = await fetchToken();

            const directLine = window.WebChat.createDirectLine({
                token: token
            });

            const files = {
                attachments : [
                    ""
                ]
            }

            window.WebChat.renderWebChat({
                directLine: directLine,
                userID: 'YOUR_USER_ID',
                username: 'Web Chat User',
                locale: 'en-US'
            }, document.getElementById('webchat'));

            directLine.postMessageWithAttachments({
                type: "message",
                text: "Testing",
                from: {
                    id: "YOUR_USER_ID",
                    name: "Web Chat User",
                    role: "agent"
                },
                attachments: [
                    {
                        contentType: "image/png",
                        contentUrl: files.attachments[0], // base64 encoded image
                        name: "test"
                    }
                ]
            })
                .subscribe(
                    id => console.log(`Posted activity with attachment, assigned ID ${id}`),
                    error => console.log(`Error posting activity with attachment ${error}`)
                );
        }

        initializeWebChat();
    </script>
</body>

</html>

and the C# on message activity handler code for the bot:

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Bot.Builder;
using Microsoft.Bot.Schema;

namespace Microsoft.BotBuilderSamples.Bots
{
    public class EchoBot : ActivityHandler
    {
        protected override async Task OnMessageActivityAsync(ITurnContext<IMessageActivity> turnContext, CancellationToken cancellationToken)
        {
            var replyActivity = MessageFactory.Text($"You sent '{turnContext.Activity.Text}'");

            if (turnContext.Activity.Attachments != null && turnContext.Activity.Attachments.Any())
            {
                // Add a text to the reply indicating that an attachment was received
                replyActivity.Text += "\nAnd you've sent an attachment.";

                // Iterate over the attachments
                foreach (var attachment in turnContext.Activity.Attachments)
                {
                    // Echo back the attachment
                    replyActivity.Attachments.Add(attachment);
                }
            }

            await turnContext.SendActivityAsync(replyActivity, cancellationToken);
        }

    }
}

Webchat client output:
image

from botframework-directlinejs.

InfinytRam avatar InfinytRam commented on June 9, 2024

@ajishanv,

If you are still experiencing this issue, could you please provide minimal reproducible .zip sample?

from botframework-directlinejs.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.