/jovo-starter-web-chatwidget

Fully customizable open source chat widget that can be added to any website.

Primary LanguageVue

Jovo Web Starter: Chat Widget

Fully customizable open source chat widget that can be added to any website.

Built with the Jovo Framework, Vue.js, and Tailwind CSS.

Demo: jovo.tech/demos/starter-web-chatwidget.

Jovo Chat Widget

Support Jovo by starring our main repo or joining our Open Collective.

Getting Started

  1. Download starter

    Use the Jovo CLI to create a new project based on this starter:

    # Install latest version of the Jovo CLI
    $ npm i -g jovo-cli
    
    # This will download the template and install the dependencies
    $ jovo new my-chatwidget --template starter-web-chatwidget
    
    $ cd my-chatwidget

    Alternatively, you can clone this repository and run npm install.

  2. Start client (Vue.js)

     $ cd client
    
     # Start Vue frontend
     $ npm run serve
  3. Start app (Jovo) In a new tab:

    $ cd app
    
    # Start Jovo development server
    $ jovo run

    The first time, jovo run will compile the TypeScript code. After making changes, make sure to compile with npm run tsc and then start the Jovo development server again.

  4. Open the starter in your browser at http://localhost:8080.

How it works

Jovo Web Client to App

This repository contains:

Customization

The starter was built for you to have a working example as well as an entry point to get started with the Jovo Web integration.

The following documentation will help you understand how the starter is structured and which components take care of which tasks.

Client

The client is a Vue.js project that consists of a single component "ChatWidget" which is styled in Tailwind CSS.

If you are new to Vue.js and want to develop your website starting with this project, you can take a look at the Vue.js guide here. This will give you a quick start to how Vue.js works, so you can start creating right away.

Component: ChatWidget

The ChatWidget component implements a fully functioning chat body where the user can type in their request and receive a response from the Jovo app. handles the registration for multiple event listeners, namely ClientEvent.Request, ClientEvent.Response, and ClientEvent.Action.

TODO: add links to docs and more info

  • ClientEvent.Request: triggered before the request is sent out to the Jovo app. In this case, it is used to display the user's input in the chat body.
  • ClientEvent.Response: triggered when the client receives the Jovo app's response. In this case, it is used to display the app's response in the chat body.
  • ClientEvent.Action: triggered when the app's response contains an action. In our case, we expect quick replies that are displayed as buttons on top of text input. It also listens for a custom action that opens a link to a new tab.

App

The Jovo app utilizes the new Jovo Web Platform integration as well as NLP.js as its NLU. It implements a simple interaction where the user can be redirected to the Jovo Framework's documentation.

Language Model

The language model consists of two intents, HelloWorldIntent and YesIntent, used to implement the sample interaction.

app.ts

The app.ts file contains the initialization of the app and its plugins as well as the basic logic for the sample interaction. It makes use of the Web integrations Custom Actions to send a redirect action used to open a link in a new tab.

Deployment

Client

Take a look at the Vue deployment docs here.

To integrate the Jovo Chat Widget into your existing project, you can use the npm script build inside of the client/ directory. This will produce a bundle in a dedicated dist/ directory, containing the whole Vue.js client with minified HTML, CSS and JavaScript, ready for dynamic integration into any website.

App

You can host your Jovo app on almost any platform, whether you choose a hosting provider or to build your own Node.js-based HTTP server. Here are a few examples:

About Jovo

Jovo is the most popular development framework for voice, including platforms like Alexa, Google Assistant, and the web.