Frappe Technologies
Screenshot 2023-10-25 at 10.48.41 PM.png
Introducing DoppioBot Template: Build AI Chatbot Experiences for Frappe
DoppioBot brings ChatGPT to Frappe's desk interface, powered by Frappe's Custom Page feature and React.
image7f7d4e.png

By

Hussain Nagaria

·

24 April 2023

·

6

min read

Introduction

AI. ChatGPT. OpenAI. That’s all over the internet these days. I presume you are being bombarded with AI tools from every direction too 😅. But it is not just hype, they are really powerful. Period.

Recently, I came across this YouTube teaser showing a ChatGPT integration with ERPNext and its mind blowing. I had a chat with Raaj, the developer of this integration to discuss more and turns out, he has much more in the works! Shortly after this, I received a message from another community member showing interest in building a similar AI powered tool for the Frappe ecosystem. The hype is real.

Raaj was not happy with the current UI/UX of the bot and he was not able to do much about it because he is not that much into UI. So, it struck to me! There are going to be many use cases for AI in the ecosystem. Why not build a template for such integrations/bots?! So, here it is: DoppioBot. You can use DoppioBot for interacting with ChatGPT right in the desk or use it as a starting point for building your own AI experiences for Frappe.

In this blog, we will start by covering how to install and use the app as is, then I will show you how it’s built and we will conclude by getting an overview of how you can customise/extend the app for your own specific needs. Let’s start!

Using DoppioBot

🚧 DoppioBot requires Frappe version ≥ v14.32.0

DoppioBot is MIT licensed and open source on GitHub. Just like any other Frappe app, if you have bench installed, you can execute the following commands to install the DoppioBot app on your Frappe site:

$ bench get-app NagariaHussain/doppio_bot
$ bench --site <your-site> install-app doppio_bot

Then add your OpenAI API key to the site_config.json (of the site you have installed the app on):

"openai_api_key": "sk-your-secret-api-key"

And that’s it! You can now navigate to your site, search for Ask DoppioBot using the awesome bar and start talking to your friendly AI bot:

The Features

DoppioBot Feature Preview Image

Here is a summary of some note-worthy features:

  • Session Chat history management with Redis
  • Formatting of markdown responses including tables and lists
  • Code block responses are syntax-highlighted and have a click to copy button!
  • A sleek loading skeleton is shown while the message is being fetched
  • The prompt can be submitted through mouse as well as keyboard (Cmd + Enter)

… and more!

Building DoppioBot

Let me walk you through how I went about developing this thing!

DoppioBot has two core components: the ChatBot UI and the API. Thanks to LangChain, the API was very straightforward to implement. But the meat of this template is the feature-rich Chat UI built using Frappe custom pages and React.

Custom Pages in Frappe Framework

In my opinion, custom pages are one of the most underrated and underused feature of Frappe Framework. Don’t confuse them with Portal (web) pages. Custom Pages, created though the Page doctype, can help you build really custom UI experiences right in the Desk (the admin interface). If you have used the Print Format Builder or the Role Permissions Manager, you have already used a custom page.

Of course, you can customize the Form View or List View, but you can only go so far.. Custom Pages give you complete control. For example, the Print Format Builder (or even the new DocType Form builder) mount a Vue 3 application to its custom page!

The Ask DoppioBot Page

My first task was to get a React application running on a custom page. This can be done in two steps:

Setting Up The Page

In order to create a custom page, we just need to create a new Page document. Give it a title, module, and make sure Standard is set to Yes.

DoppioBot Page Form View

Once we save this document/page, a few files will be generated in our custom app (based on what Module you selected for the page). In case of DoppioBot, you can see those files in page/doppio_bot directory:

Screenshot of VSCode directory and files for custom page

The most important file here is the doppio_bot.js. When you open up this file, you will see there are a few things going over here, but focus on the below annotated lines:

Annotated JavaScript Code Screenshot

  1. We are using frappe.require to load a JavaScript bundle file named doppiobot_ui.bundle.jsx
  2. After the script is successfully loaded, we are creating an instance of a class called DoppioBotUI

frappe.require is a powerful utility function that can help you load JavaScript bundles on the fly. Here, I am loading a bundle file that contains our React application and then I am initialising an instance of a class which triggers the mounting of that React application. You can find the source of this bundle file on GitHub here.

Setting Up The React Application

As you have seen in the previous step, we were loading a JavaScript bundle file from the backend and it does all the magic of mounting and rendering our Chat interface.

Open up the public/js/doppiobot_ui.bundle.jsx file and have a look. Since, we already have a build system in place (esbuild) in Frappe Framework, it was as easy as installing the npm packages and importing React in the bundle file. When you run bench build , the .jsx files will be compiled and bundled properly to be served to our custom page.

After this, it was just a matter of writing React code. I have used ChakraUI, so I don’t have to write UI components from scratch and also the components are very polished, accessible and customisable.

A Powerful Thing

One more supercool thing about custom pages: you have access to the frappe namespace in your React application! So, you can write this type of code in your React components and it will work flawlessly:

const ChatView = ({ sessionID }) => {
  // from Frappe!
  const userImageURL = frappe.user.image();
  const userFullname = frappe.user.full_name();

  const toast = useToast();
    // ...
}

You can follow the trail from the bundle file to explore the React application in depth.

The API

The API call can be found in the ChatView.jsx file:

frappe
    .call("doppio_bot.api.get_chatbot_response", {
      prompt_message: promptMessage,
      session_id: sessionID,
    })
    .then((response) => {...}

This code makes an API call to get the response based on the given prompt and processes the response.

If you open up the api.py file (here), you will be able to see the surprisingly few lines of code that power this bot. Instead of directly calling the OpenAI API, managing message history and prompts, I have used LangChain python library, which makes it super easy and composable to build AI applications based on LLMs (like GPT):

llm = OpenAI(temperature=0, openai_api_key=opeai_api_key)

# For tracking chat message history
# Session ID is stored in the frontend
message_history = RedisChatMessageHistory(session_id=session_id)
memory = ConversationBufferMemory(memory_key="history", chat_memory=message_history)

conversation_chain = ConversationChain(llm=llm, memory=memory, prompt=prompt_template)
return conversation_chain.run(prompt_message)

Build Your Own!

Now that you know how DoppioBot works and how it is structured, you can extend it to build your own AI experiences for Frappe. Here are some of the ways you can get started:

  1. Change the API function’s code to get your desired results
  2. Customise the frontend (React) code to match your theme
  3. Take inspiration and rewrite the whole this, if you want!

You can either copy over the code for the page or fork the doppio_bot to extend it according to your requirements. If you are editing the UI/React code, you can get live reload by running the following command in apps/frappe directory:

$ yarn run watch --apps doppio_bot --live-reload

There are a variety of ways you can extend this, but I have included a “simple” example in the README file, that uses a custom tool to create ToDo documents on user’s behalf!

Conclusion

You can find the GitHub repo here. Please feel free to create an issue if you find one. If you end up using this as template, I will love to hear from you or even if just want to have a chat, don’t hesitate to reach me out on twitter @NagariaHussain.

Now it is time for you to explore! Have fun tinkering!

Published by

Hussain Nagaria

on

24 April 2023
6

Share

Add your comment

Success!

Error

Comments

C
CA. B.C.Chjechani

· 

May 8, 2023

Excellent, Expecting Articles how to customize chatbot(openai) to be used with Frappe

Hussain Nagaria

· 

April 25, 2023

Hi Ramki!

Pushed a fix, update to the latest version and the problem should go away!

R
Ramki

· 

April 25, 2023

In my redis.conf file I already blocked port 6379 and using port 11000. Can i use the same port for these or how to do sir? explain it. Thank you

R
Ramki

· 

April 25, 2023

Hi @Nagaria Hussain

I tried doppio bot in my frappe app. I installed successfully i have redis error.

``

Response Data { "exception": "redis.exceptions.ConnectionError: Error 111 connecting to localhost:6379. Connection refused." }

For my frappe app /etc/redis/redis.conf it's running in port 11000

port 6379

port 11000

How to solve the error

Thank you

N
Nitin Chintamani

· 

April 25, 2023

Nice work... Certainly opened up new doors. Would like to see more happening in this area.

A
APOORV SORAL

· 

April 25, 2023

I am very impressed with the quick turnaround on this app. Claps for the good work you have put in and also thanks for sharing this knowledge on the post. Great work!

Discussion

image7f7d4e.png

Paul Mugambi

·

3 days

ago

Beautiful read, and an insight into an individual I respect and have learned a lot from. Am inspired to trust the process and never give up.

image4c43d6.png

Anna Dane

·

5 days

ago

I must say this is a really amazing post, and for some of my friends who provide Best British Assignment Help, I must recommend this post to them.

Add your comment

Comment