let COLOR_CODE='#b034d9';
let API_KEY = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRlVGltZSI6MTc0OTU1MjI5Mzc0MSwidV9pZCI6IjUxMS0xNzQ5NTUyMjkzNzQxIiwicF9pZCI6MiwidHlwZSI6ImNvbnZlcnNhdGlvblVzZXIiLCJhX2lkIjoiMSIsImlhdCI6MTc0OTU1MjI5M30.9RCALteUWyUTVMl2-SEovOkbZDeFRX5GsV-DyuDi6dA';
let host = 'https://chat.pura-ai.com';
let chatbotName='511';
let welcomeMessage='Hello and welcome to 511 Digital Marketing. I am your digital marketing specialist today. It is great to connect with you. ';
let botLogo='';window.onload = function () {
renderChatBot()
localStorage.removeItem('chatbot-tok')
// if (localStorage.getItem('chatbot-tok')) {
// API_KEY = localStorage.getItem('chatbot-tok')
// } else {
// localStorage.setItem('chatbot-tok', API_KEY)
// }
// console.log(localStorage.getItem('chatbot-tok'))
}
var socket;
let chatType = 'agent'
let createChatLi,openExternalPage1, chatbotToggler, closeBtn, refreshBtn, chatbox, chatInput, sendChatBtn, isEmoticons = false, branchListData = [], formVariableList, projectListData = [], productListData = [], utm_params;
let userMessage = null;
let puraBotSlideIndex = 1;
let carosalImageList = []
async function renderChatBot() {
console.log('start')
let newDiv = document.createElement('div');
newDiv.id = 'webChatBot'
document.body.appendChild(newDiv);
var script = document.createElement('script');
script.src = `${host}/socket.io/socket.io.js`;
document.head.appendChild(script);
setTimeout(() => {
console.log('hi')
createChatBot();
loadEmoticons();
}, 1000)
setTimeout(() => { loadTriggerKey() }, 2000)
let url = new URL(window.location.href);
utm_params = url.searchParams.toString()
}
let aiCount = 0
function createChatBot() {
let htmlData = `
mode_commentclose
Chat with
${chatbotName}
close
${welcomeMessage}
Contact Us
Submit
moodsend
`
let dat = document.getElementById('webChatBot')
dat.innerHTML = htmlData
chatbotToggler = document.querySelector(".chatbot-toggler");
closeBtn = document.querySelector(".close-btn");
refreshBtn = document.querySelector(".refresh-btn")
chatbox = document.querySelector(".chatbox");
chatboxUserForm = document.querySelector(".chatbox .userform");
chatInput = document.querySelector(".chat-input textarea");
sendChatBtn = document.querySelector(".chat-input .sent-btn");
if (localStorage.getItem('chatbot_token')) {
API_KEY = localStorage.getItem('chatbot_token')
} else {
localStorage.setItem('chatbot_token',API_KEY)
}
// Variable to store user's message
// const API_KEY = "PASTE-YOUR-API-KEY"; // Paste your API key here
const inputInitHeight = chatInput.scrollHeight;
createChatLi = (message, className) => {
// Create a chat
element with passed message and className
const chatLi = document.createElement("li");
chatLi.classList.add("chat", `${className}`);
let chatContent = className === "outgoing" ? ` ` : `
support_agent
`;
chatLi.innerHTML = chatContent;
chatLi.querySelector("p").innerHTML = message;
return chatLi; // return chat
element
}
const generateResponse = (chatElement) => {
const API_URL = `${host}/aiChat`;
const messageElement = chatElement.querySelector("p");
// Define the properties and message for the API request
const requestOptions = {
method: "POST",
headers: {
"Content-Type": "application/json",
"Authorization": `${API_KEY}`
},
body: JSON.stringify({
message: userMessage,
})
}
// Send POST request to API, get response and set the reponse as paragraph text
fetch(API_URL, requestOptions).then(res => res.json()).then(data => {
messageElement.textContent = data.message;
}).catch(() => {
messageElement.classList.add("error");
messageElement.textContent = "Oops! Something went wrong. Please try again.";
}).finally(() => chatbox.scrollTo(0, chatbox.scrollHeight));
}
const handleChat = () => {
userMessage = chatInput.value.trim();
console.log('handleChat',userMessage,chatType)// Get user entered message and remove extra whitespace
if (!userMessage) return;
// Clear the input textarea and set its height to default
chatInput.value = "";
// chatInput.style.height = `${inputInitHeight}px`;
conversationalBot(userMessage)
}
chatInput.addEventListener("input", () => {
// Adjust the height of the input textarea based on its content
chatInput.style.height = `${inputInitHeight}px`;
chatInput.style.height = `${chatInput.scrollHeight}px`;
});
window.addEventListener("message", function (event) {
console.log('sd', event)
let eventData = JSON.parse(event.data)
// if (event.origin !== "http://localhost:9000") return;
if (eventData.type === "appointment_submitted") {
console.log(" Appointment was submitted!");
chatbox.appendChild(createChatLi(eventData.data.userMsg, "outgoing"));
chatbox.appendChild(createChatLi(eventData.data.agentMsg, "incoming"));
chatbox.scrollTo(0, chatbox.scrollHeight);
}
});
chatInput.addEventListener("keydown", (e) => {
// If Enter key is pressed without Shift key and the window
// width is greater than 800px, handle the chat
if (e.key === "Enter" && !e.shiftKey && window.innerWidth > 800) {
e.preventDefault();
handleChat();
}
});
sendChatBtn.addEventListener("click", handleChat);
closeBtn.addEventListener("click", () => document.body.classList.remove("show-chatbot"));
refreshBtn.addEventListener("click", () => { reloadChat() })
chatbotToggler.addEventListener("click", () => document.body.classList.toggle("show-chatbot"));
}
function openExternalPage(url) {
console.log('openExternalPage',url)
window.open(url,'_blank')
}
function showHideEmoticon() {
if (isEmoticons) {
document.getElementById('emoticonsContainer').style.display = 'none';
isEmoticons = false
} else {
document.getElementById('emoticonsContainer').style.display = 'flex';
isEmoticons = true
}
}
function appendMessage(emoticon) {
let val = chatInput.value.trim()
chatInput.value = val + ' ' + emoticon
}
function reloadChat() {
let htmlData = `