eval(atob("let historyId = '';

const chatboxHTMLgTCb7YkbSh = `
  <div class="chatboxgTCb7YkbSh" id="chatboxgTCb7YkbSh">
    <div class="chatbox-containergTCb7YkbSh chatbox-leavegTCb7YkbSh hidden" id="chatbox-containergTCb7YkbSh">
      <div class="headergTCb7YkbSh">
        <div class="avatargTCb7YkbSh">
          <img src='https://www.passisto.com/uploads/passisto_icon.svg' alt="" />
        </div>
        <div class="titlegTCb7YkbSh">
          <h3 style='color: #223828'>Passisto</h3>
          <span>AI Assistant</span>
        </div>
      </div>
      <div class="messagesgTCb7YkbSh" id="messagesgTCb7YkbSh"></div>
      <div class="footergTCb7YkbSh">
        <input type="text" id="userInputgTCb7YkbSh" placeholder="Type your message..." />
        <button id="sendButtongTCb7YkbSh">
          <svg width="15px" height="15px" viewBox="0 0 24 24">
            <path fill='#223828' d="M2.345 2.245a1 1 0 0 1 1.102-.14l18 9a1 1 0 0 1 0 1.79l-18 9a1 1 0 0 1-1.396-1.211L4.613 13H10a1 1 0 1 0 0-2H4.613L2.05 3.316a1 1 0 0 1 .294-1.071z" />
          </svg>
        </button>
      </div>
    </div>
    <div class="chat-buttongTCb7YkbSh" id="chatToggleButtongTCb7YkbSh">
      <img src='https://www.passisto.com/uploads/passisto_icon.svg' />
    </div>
  </div>
`;

const chatboxElementgTCb7YkbSh = document.createElement("div");
chatboxElementgTCb7YkbSh.innerHTML = chatboxHTMLgTCb7YkbSh;
document.body.appendChild(chatboxElementgTCb7YkbSh);

const styleElementgTCb7YkbSh = document.createElement("style");
const cssCodegTCb7YkbSh = `
  .hidden { display: none !important; }
  .chatboxgTCb7YkbSh { z-index: 9999999; position: fixed; bottom: 80px; right: 20px; font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif; }
  
  .chatbox-containergTCb7YkbSh { 
    box-shadow: 1px 1px 100px 2px rgba(0, 0, 0, 0.22); 
    border-radius: 10px; 
    width: 350px; 
    background-color: #fff; 
    transition: all 0.3s ease-in-out; 
    display: flex;
    flex-direction: column;
    height: 500px; /* You can adjust this value as needed */
    justify-content: space-between; /* Ensure the footer is at the bottom */
    max-height: 80vh;
  }
  
  .headergTCb7YkbSh { 
    color: #333; 
    padding: 10px 20px; 
    border-radius: 10px 10px 0px 0px; 
    display: flex; 
    align-items: center; 
    flex-direction: row; 
    border-bottom: 1px solid #cccccc54; 
    flex-shrink: 0; /* Ensure the header doesn't shrink */
  }

  .headergTCb7YkbSh h3 { margin: 0; font-size: 20px; }
  .headergTCb7YkbSh span { font-size: 12px; }
  .headergTCb7YkbSh .avatargTCb7YkbSh img { width: 70px; }
  .headergTCb7YkbSh .titlegTCb7YkbSh { margin-left: 10px; }
  
  .messagesgTCb7YkbSh { 
    flex-grow: 1; /* Allow the messages container to grow and take up available space */
    overflow-y: auto; /* Make it scrollable when content exceeds available space */
    padding: 10px; 
  }

  .messagesgTCb7YkbSh::-webkit-scrollbar { display: none; }
  
  .footergTCb7YkbSh { 
    border-top: 1px solid #cccccc54; 
    display: flex; 
    flex-direction: row; 
    align-items: center; 
    flex-shrink: 0; /* Ensure the footer doesn't shrink */
    padding: 5px; /* Add padding for better spacing */
  }

  #userInputgTCb7YkbSh { 
    font-size: 16px; 
    padding: 10px; 
    margin: 5px; 
    border: 0; 
    color: black;
    width: calc(100% - 60px); 
  }
  
  #userInputgTCb7YkbSh:focus-visible { outline: 0; }
  
  #sendButtongTCb7YkbSh { 
    padding: 15px; 
    background-color: transparent; 
    border: none; 
    cursor: pointer; 
    transition: opacity 0.3s, cursor 0.3s; 
  }

  #sendButtongTCb7YkbSh:disabled { 
    opacity: 0.5; /* Makes the button appear grayed out */ 
    cursor: not-allowed; /* Changes the cursor to indicate it's disabled */ 
  }
  
  .msggTCb7YkbSh { width: 90%; margin: 5px 0; }
  
  .msggTCb7YkbSh.user-msggTCb7YkbSh { float: right; text-align: right; }
  
  .msggTCb7YkbSh.user-msggTCb7YkbSh span { 
    word-wrap: break-word; 
    overflow-wrap: break-word; 
    background-color: #223828; 
    color: white; 
    padding: 10px; 
    border-radius: 10px; 
    max-width: 80%; 
    display: inline-block; 
  }
  
  .msggTCb7YkbSh.bot-msggTCb7YkbSh { float: left; }
  
  .msggTCb7YkbSh.bot-msggTCb7YkbSh span { 
    word-wrap: break-word; 
    overflow-wrap: break-word; 
    background-color: #e0e0e0; 
    color: black; 
    padding: 10px; 
    border-radius: 10px; 
    max-width: 80%; 
    display: inline-block; 
  }

  .chat-buttongTCb7YkbSh { 
    border: none; 
    border-radius: 5%; 
    width: 50px; 
    height: 50px; 
    cursor: pointer; 
    display: flex; 
    justify-content: center; 
    align-items: center; 
    position: fixed; 
    bottom: 20px; 
    right: 20px; 
    z-index: 10000000; 
  }

  .chat-buttongTCb7YkbSh img { width: 100%; height: 100%; border-radius: 5%; }

  /* Loading dots animation */
  .lds-ellipsisgTCb7YkbSh { display: inline-block; position: relative; width: 74px; height: 18px; }
  .lds-ellipsisgTCb7YkbSh div { position: absolute; top: 8px; width: 8px; height: 8px; border-radius: 50%; background: #333; animation-timing-function: cubic-bezier(0, 1, 1, 0); }
  .lds-ellipsisgTCb7YkbSh div:nth-child(1) { left: 8px; animation: lds-ellipsis1gTCb7YkbSh 0.6s infinite; }
  .lds-ellipsisgTCb7YkbSh div:nth-child(2) { left: 8px; animation: lds-ellipsis2gTCb7YkbSh 0.6s infinite; }
  .lds-ellipsisgTCb7YkbSh div:nth-child(3) { left: 32px; animation: lds-ellipsis2gTCb7YkbSh 0.6s infinite; }
  .lds-ellipsisgTCb7YkbSh div:nth-child(4) { left: 56px; animation: lds-ellipsis3gTCb7YkbSh 0.6s infinite; }
  @keyframes lds-ellipsis1gTCb7YkbSh { 0% { transform: scale(0); } 100% { transform: scale(1); } }
  @keyframes lds-ellipsis3gTCb7YkbSh { 0% { transform: scale(1); } 100% { transform: scale(0); } }
  @keyframes lds-ellipsis2gTCb7YkbSh { 0% { transform: translate(0, 0); } 100% { transform: translate(24px, 0); } }

  /* Enter and Leave animations */
  .chatbox-entergTCb7YkbSh { animation: slideInRightgTCb7YkbSh 1s forwards; }
  .chatbox-leavegTCb7YkbSh { animation: slideOutRightgTCb7YkbSh 1s forwards; }
  @keyframes slideInRightgTCb7YkbSh { 0% { transform: translateX(100%); opacity: 0; } 100% { transform: translateX(0); opacity: 1); } }
  @keyframes slideOutRightgTCb7YkbSh { 0% { transform: translateX(0); opacity: 1; } 100% { transform: translateX(100%); opacity: 0; } }

  /* Responsive styling */
  @media only screen and (max-width: 768px) {
    .chatbox-containergTCb7YkbSh {
      width: 90vw; /* Full width on mobile */
      height: 80vh; /* Full height on mobile */
      border-radius: 0; /* Remove border-radius on mobile */
    }
    .messagesgTCb7YkbSh {
      height: calc(100vh - 150px); /* Dynamic height for mobile */
    }
  }
.helpful-links-button {
    background-color: #223828;
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    transition: background-color 0.3s;
}

.resource-box {
    background-color: #f0f0f0;
    border: 1px solid #ccc;
    padding: 5px;
    border-radius: 5px;
    flex: 1 1 calc(25% - 20px); /* Adjust width to fit multiple boxes per row */
    max-width: calc(25% - 20px); /* Ensure it doesn't exceed the parent width */
    box-sizing: border-box;
    text-align: center;
    transition: box-shadow 0.3s;
}

.resource-box:hover {
    box-shadow: 0 0 10px rgba(0, 123, 255, 0.5);
}

.resource-box a {
    text-decoration: none;
    color: #223828;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    word-wrap: break-word; /* Wraps long words to prevent overflow */
    overflow-wrap: break-word; /* Ensures words break appropriately */
}

.helpful-links-button:hover {
    background-color: #0056b3;
}

.arrow-icon {
    margin-left: auto;
}

.resources-container {
    display: flex;           
    flex-wrap: wrap;         
    gap: 10px;         
    margin-top: 10px;        
}

.resources-header {
    font-weight: bold;
    margin-bottom: 5px;
}

.resources-list {
    list-style-type: none;
    padding-left: 0;
    margin: 0;
}

.resource-item {
    margin-bottom: 8px;
    font-size: 14px;
}

.resource-item a {
    color: #223828;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 5px;
}

.resource-item a:hover {
    text-decoration: underline;
}

/* Styling for the tooltip */
.tooltip {
    position: absolute;
    background-color: #333;
    color: #fff;
    padding: 5px;
    border-radius: 3px;
    font-size: 12px;
    white-space: nowrap;
    z-index: 1000;
    pointer-events: none; /* Allows mouse events to pass through */
    opacity: 0;
    transition: opacity 0.2s;
}

/* Show tooltip with a fade-in effect */
.tooltip-visible {
    opacity: 1;
}
`;

// Create a link element for the Font Awesome stylesheet
var fontAwesomeLink = document.createElement("link");
fontAwesomeLink.rel = "stylesheet";
fontAwesomeLink.href = "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css";


styleElementgTCb7YkbSh.textContent = cssCodegTCb7YkbSh;
document.head.appendChild(styleElementgTCb7YkbSh);

function waitForElement(id, callback) {
  const element = document.getElementById(id);
  if (element) {
    callback(element);
  } else {
    const interval = setInterval(() => {
      const el = document.getElementById(id);
      if (el) {
        clearInterval(interval);
        callback(el);
      }
    }, 100);
  }
}

(function () {
  waitForElement("chatToggleButtongTCb7YkbSh", (chatToggleButton) => {
    waitForElement("chatbox-containergTCb7YkbSh", (chatboxContainer) => {
      waitForElement("messagesgTCb7YkbSh", (messagesDiv) => {
        waitForElement("userInputgTCb7YkbSh", (userInput) => {
          waitForElement("sendButtongTCb7YkbSh", (sendButton) => {
            chatboxContainer.classList.add("hidden");

            chatToggleButton.addEventListener("click", function () {
              if (chatboxContainer.classList.contains("hidden")) {
                chatboxContainer.classList.remove("hidden");
                chatboxContainer.classList.remove("chatbox-leavegTCb7YkbSh");
                chatboxContainer.classList.add("chatbox-entergTCb7YkbSh");
              } else {
                chatboxContainer.classList.remove("chatbox-entergTCb7YkbSh");
                chatboxContainer.classList.add("chatbox-leavegTCb7YkbSh");
                chatboxContainer.addEventListener("animationend", function handler() {
                  chatboxContainer.classList.add("hidden");
                  chatboxContainer.removeEventListener("animationend", handler);
                });
              }
            });

            sendButton.addEventListener("click", function () {
              const userMessage = userInput.value.trim();
              if (userMessage !== "") {
                addMessage("user", userMessage, []);
                askChatbot(userMessage);
                userInput.value = "";
              }
            });

            userInput.addEventListener("keydown", function (event) {
              if (event.key === "Enter") {
                event.preventDefault();
                sendButton.click();
              }
            });

            function showTooltip(event, text) {
              const chatbox = document.getElementById("messagesgTCb7YkbSh");
              let tooltip = document.querySelector(".tooltip");

              if (!tooltip) {
                tooltip = document.createElement("div");
                tooltip.className = "tooltip";
                chatbox.appendChild(tooltip);
              }

              tooltip.textContent = text;
              tooltip.classList.add("tooltip-visible");

              const chatboxRect = chatbox.getBoundingClientRect();
              const tooltipRect = tooltip.getBoundingClientRect();

              let left = event.clientX - chatboxRect.left + 10;
              let top = event.clientY - chatboxRect.top + 10;

              if (left + tooltipRect.width > chatboxRect.width) {
                left = chatboxRect.width - tooltipRect.width - 10;
              }

              if (top + tooltipRect.height > chatboxRect.height) {
                top = chatboxRect.height - tooltipRect.height - 10;
              }

              tooltip.style.left = `${left}px`;
              tooltip.style.top = `${top}px`;
            }

            // Function to remove the tooltip
            function hideTooltip() {
              const tooltip = document.querySelector(".tooltip");
              if (tooltip) {
                tooltip.remove();
              }
            }

            addMessage("bot", 'Hi, My name is Passisto. How can I help You today?', []);

            async function fetchExtraData() {
              try {
                const response = await fetch('https://freeipapi.com/api/json');
                const data = await response.json();
                return {
                  _extra_id: data.ipAddress,
                  _extra_ci: data.cityName,
                  _extra_rg: data.regionName,
                  _extra_co: data.countryName,
                };
              } catch (err) {
                console.error('Something went wrong:', err);
                return null;
              }
            }

            function addMessage(sender, message, sources = []) {
              return new Promise((resolve, reject) => {
                const messageDiv = document.createElement("div");
                if (sender === "bot") {
                  messageDiv.className = "msggTCb7YkbSh bot-msggTCb7YkbSh";
                  messageDiv.innerHTML = "<span></span>";
                  messagesDiv.appendChild(messageDiv);
                  messagesDiv.scrollTop = messagesDiv.scrollHeight;

                  if (sources.length !== 0 ){   // Create the button dynamically
                    const button = document.createElement("button");
                    button.className = "helpful-links-button";
                    button.innerHTML = `
                        <i class="fas fa-link"></i> Helpful Links 
                        <i class="fas fa-chevron-down arrow-icon"></i>
                    `;
                    messageDiv.appendChild(button);
                    
                    // Create the resources container dynamically
                    const resourcesContainer = document.createElement("div");
                    resourcesContainer.className = "resources-container";
                    resourcesContainer.style.display = "none";

                    // Create resource boxes dynamically
                    sources.forEach((source, index) => {
                        const resourceBox = document.createElement("div");
                        resourceBox.className = "resource-box";
                        resourceBox.innerHTML = `
                            <a href="${source}" target="_blank">
                                <i class="fas fa-external-link-alt"></i> link${index+1}
                            </a>
                        `;
                        // Event listeners for showing and hiding the tooltip                
                        resourceBox.addEventListener("mouseenter", (event) => showTooltip(event, source));
                        resourceBox.addEventListener("mouseleave", hideTooltip);
                        resourcesContainer.appendChild(resourceBox);
                    });
                    messageDiv.appendChild(resourcesContainer);

                    // Add event listener for button click
                    button.addEventListener('click', () => {
                        const arrowIcon = button.querySelector('.arrow-icon');
                        if (resourcesContainer.style.display === 'none' || resourcesContainer.style.display === '') {
                            resourcesContainer.style.display = 'flex';
                            arrowIcon.className = 'fas fa-chevron-up arrow-icon'; // Change arrow to up
                        } else {
                            resourcesContainer.style.display = 'none';
                            arrowIcon.className = 'fas fa-chevron-down arrow-icon'; // Change arrow to down
                        }
                    });
                  }
                  const span = messageDiv.querySelector("span");
                  const letters = message.split("");
                  letters.forEach((letter, i) => {
                    setTimeout(() => {
                      span.innerHTML += letter;
                      messagesDiv.scrollTop = messagesDiv.scrollHeight;
                      if (i === letters.length - 1) {
                        resolve(); // Resolve after last letter
                      }
                    }, 50 * i);
                  });
                } else {
                  messageDiv.className = "msggTCb7YkbSh user-msggTCb7YkbSh";
                  messageDiv.innerHTML = `<span>${message}</span>`;
                  messagesDiv.appendChild(messageDiv);
                  messagesDiv.scrollTop = messagesDiv.scrollHeight;
                  resolve(); // Resolve immediately for user messages
                }
              });
            }

            function addLoadingMsg() {
              const messageDiv = document.createElement("div");
              messageDiv.className = "msggTCb7YkbSh bot-msggTCb7YkbSh";
              messageDiv.id = "loadingMsggTCb7YkbSh";
              messageDiv.innerHTML = '<span><div class="lds-ellipsisgTCb7YkbSh"><div></div><div></div><div></div><div></div></div></span>';
              messagesDiv.appendChild(messageDiv);
              messagesDiv.scrollTop = messagesDiv.scrollHeight;
            }

            function removeLoadingMsg() {
              const loadingMsg = document.getElementById("loadingMsggTCb7YkbSh");
              if (loadingMsg) {
                loadingMsg.remove();
              }
            }

            function getCookie(name) {
              const cookies = document.cookie.split("; ");
              for (let cookie of cookies) {
                const [key, value] = cookie.split("=");
                if (key === name) return value;
              }
              return null;
            }

            async function askChatbot(message) {

              historyId = getCookie("historyId");

              const _extra = await fetchExtraData();
              const data = {
                chatbot_name: 'Passisto',
                message: message,
                opensearch_alias: '4badab0c-cb28-4c04-b707-59e64e430c1f',
                user_location: _extra,
                historyId: historyId,
              };
              addLoadingMsg();
              userInput.disabled = true;
              sendButton.disabled = true; // Disable send button
              try {
                const response = await fetch('https://www.passisto.com/chatbot', {
                  method: "POST",
                  headers: { "Content-Type": "application/json" },
                  body: JSON.stringify(data),
                });
                const responseData = await response.json();

                historyId = responseData.historyId;

                if (responseData.historyId) {
                  document.cookie = `historyId=${responseData.historyId}; path=/; max-age=3600`;
                }

                removeLoadingMsg();
                await addMessage("bot", responseData.answer, responseData.sourceDocuments); // Wait for typing animation to complete
                userInput.disabled = false;
                sendButton.disabled = false; // Re-enable send button
              } catch (error) {
                console.error("Error:", error);
                removeLoadingMsg();
                userInput.disabled = false;
                sendButton.disabled = false; // Re-enable send button
              }
            }
          });
        });
      });
    });
  });
})();"))