let COLOR_CODE='#A3852E'; let API_KEY = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJkYXRlVGltZSI6MTczODcyODMwMzkxOCwidXNlcklkIjoiVGFqIFNreSBWaWV3IFJlc2lkZW5jZXMtMTczODcyODMwMzkxOCIsInByb2plY3RJZCI6NCwidHlwZSI6IndlYlVzZXIiLCJhcHBDb2RlIjo5LCJpYXQiOjE3Mzg3MjgzMDN9.uMUFlWtBiBCZab4aJAmh1h6fT9VY3AjkjXTfgVDcNmw'; let host = 'https://chat.pura-ai.com'; let chatbotName='Taj Sky View Residences'; let welcomeMessage='Welcome to Taj Sky View Residences! '; 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, 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() { 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(() => { createChatBot(); loadEmoticons(); }, 1000) setTimeout(() => { loadTriggerKey() }, 2000) let url = new URL(window.location.href); console.log() utm_params = url.searchParams.toString() } let aiCount = 0 function createChatBot() { let htmlData = `
${welcomeMessage}
${welcomeMessage}
` for (let i = 0; i < data.triggerKey.length; i++) { buttonList += `` } buttonList += '
' const chatLi = document.createElement("li"); chatLi.classList.add("chat", `incomingBtn`); chatLi.innerHTML = buttonList; chatbox.appendChild(chatLi); chatbox.scrollTo(0, chatbox.scrollHeight); }).catch(() => { console.log(err) }).finally(() => chatbox.scrollTo(0, chatbox.scrollHeight)); } function processMessage(data) { let messageList = data.messageList for (let i = 0; i < messageList.length; i++) { if (messageList[i].type === 'message') { chatbox.appendChild(createChatLi(messageList[i].message, "incoming")); chatbox.scrollTo(0, chatbox.scrollHeight); chatType = 'agent' } else if (messageList[i].type === 'agent') { document.getElementById('textBoxData').style.display = "flex"; createSocket() } else if (messageList[i].type === 'btnMsg') { chatbox.appendChild(createChatLi(messageList[i].message, "incoming")); chatbox.scrollTo(0, chatbox.scrollHeight); let buttonList = `` for (let j = 0; j < messageList[i].buttonList.length; j++) { buttonList += `` } buttonList += '
' const chatLi = document.createElement("li"); chatLi.classList.add("chat", `incomingBtn`); chatLi.innerHTML = buttonList; chatbox.appendChild(chatLi); chatbox.scrollTo(0, chatbox.scrollHeight); document.getElementById('textBoxData').style.display = "none"; } else if (messageList[i].type === 'End') { chatbox.appendChild(createChatLi(messageList[i].message, "incoming")); document.getElementById('textBoxData').style.display = "none"; } else if (messageList[i].type === 'AI') { chatType = 'ai'; document.getElementById('textBoxData').style.display = "flex"; } else if (messageList[i].type === 'userInput') { chatType = 'userInput'; chatbox.appendChild(createChatLi(messageList[i].message, "incoming")); chatbox.scrollTo(0, chatbox.scrollHeight); document.getElementById('textBoxData').style.display = "flex"; } else if (messageList[i].type === 'documentButton') { const chatLi = document.createElement("li"); chatLi.classList.add("chat", `incoming`); let chatContent = '' if (messageList[i].fileType.split('/')[0] === 'image') { chatContent = ``; } else { chatContent = ``; } chatLi.innerHTML = chatContent; chatbox.appendChild(chatLi); chatbox.scrollTo(0, chatbox.scrollHeight); let buttonList = `` for (let j = 0; j < messageList[i].buttonList.length; j++) { buttonList += `` } buttonList += '
' const chatLi1 = document.createElement("li"); chatLi1.classList.add("chat", `incomingBtn`); chatLi1.innerHTML = buttonList; chatbox.appendChild(chatLi1); chatbox.scrollTo(0, chatbox.scrollHeight); document.getElementById('textBoxData').style.display = "none"; } else if (messageList[i].type === 'document') { const chatLi = document.createElement("li"); chatLi.classList.add("chat", `incoming`); let chatContent = '' if (messageList[i].fileType.split('/')[0] === 'image') { chatContent = ``; } else { chatContent = ``; } chatLi.innerHTML = chatContent; chatbox.appendChild(chatLi); chatbox.scrollTo(0, chatbox.scrollHeight); } else if (messageList[i].type === 'userForm') { document.getElementById('textBoxData').style.display = "none"; let chatContent = `${messageList[i].title}
`
formVariableList = messageList[i].formList
for (let j = 0; j < formVariableList.length; j++) {
chatContent += `
`
if (formVariableList[j].type === 'Text') {
chatContent += `
`
}
if (formVariableList[j].type === 'Number') {
chatContent += `
`
}
if (formVariableList[j].type === 'Email') {
chatContent += `
`
}
if (formVariableList[j].type === 'Date') {
chatContent += `
`
}
if (formVariableList[j].type === 'Time') {
chatContent += `
`
}
if (formVariableList[j].type === 'Date Range') {
chatContent += `
`
}
if (formVariableList[j].type === 'Time Range') {
chatContent += `
`
}
}
chatContent += `
` for (let j = 0; j < messageList[i].buttonList.length; j++) { buttonList += `` } buttonList += '
' const chatLi1 = document.createElement("li"); chatLi1.classList.add("chat", `incomingBtn`); chatLi1.innerHTML = buttonList; chatbox.appendChild(chatLi1); chatbox.scrollTo(0, chatbox.scrollHeight); } else if (messageList[i].type === 'Location') { console.log('Location') const chatLi = document.createElement("li"); chatLi.classList.add("chat", `incoming`); let chatContent = ``; chatLi.innerHTML = chatContent; chatbox.appendChild(chatLi); chatbox.scrollTo(0, chatbox.scrollHeight); } else if (messageList[i].type === 'callToAction') { chatbox.appendChild(createChatLi(messageList[i].message, "incoming")); chatbox.scrollTo(0, chatbox.scrollHeight); const chatLi1 = document.createElement("li"); chatLi1.classList.add("chat", `incomingBtn`); chatLi1.innerHTML = ``; chatbox.appendChild(chatLi1); chatbox.scrollTo(0, chatbox.scrollHeight); } else if (messageList[i].type === 'clickToCall') { const chatLi1 = document.createElement("li"); chatLi1.classList.add("chat", `incomingBtn`); chatLi1.innerHTML = ``; chatbox.appendChild(chatLi1); chatbox.scrollTo(0, chatbox.scrollHeight); } else if (messageList[i].type === 'conversationAi') { chatType = 'conversationalAI'; document.getElementById('textBoxData').style.display = "flex"; } } } async function getAppointmentDate(selectedDate) { try { console.log(selectedDate.value) document.getElementById('puraBotBookingSlotDiv').innerHTML = "Checking Available Slot"; fetch(host + '/getAppointmentAvailabiltySlot', { method: "POST", headers: { "Content-Type": "application/json", "Authorization": `${API_KEY}` }, body: JSON.stringify({ branchId: (document.getElementById('selectedBranch').value), appointmentDate: selectedDate.value }) }).then(res => res.json()).then(data => { console.log(data) if (data.status === 'failed') { document.getElementById('puraBotBookingSlotDiv').innerHTML = "Slot Not available Kindly choose another date"; } else { let optionList = data.timeList.map(val => { return `` }) let htmlData = `${codeList[i]};
` } document.getElementById('emoticonsContainer').innerHTML = htmlData }