Greasy Fork is available in English.

Chat Box Section

Creates a separated section for the chat box

// ==UserScript==
// @name        Chat Box Section
// @namespace   Violentmonkey Scripts
// @match       https://web.simple-mmo.com/*
// @grant       none
// @license     GPL-v3
// @version     1.4.7
// @author      Freaky Fingers
// @description Creates a separated section for the chat box
// ==/UserScript==
//Startup Sequence Variables
let smmoChat

document.querySelectorAll("[x-init]").forEach(xinit => {
  if (xinit.outerHTML.includes("chat:false,chatSrc:'about:blank;'")){
    return smmoChat = xinit
  }
})

if (!smmoChat) return;
smmoChat.style.cssText = "position: fixed; height: 100%; margin-top: 4rem";

//Script Variables
const chatWidth = 20
const newButton = document.createElement("button")
const newHTML = document.createElement("div")
const chatButton = document.getElementById("show_hide_chat_btn")

newButton.style.cssText = "position: fixed; padding: 0.5rem; background-color: #000; border: 2px solid #C0C0C0; border-radius: 0.5rem; color: #C0C0C0; z-index: 30; font-size: 0.8rem";
document.getElementById("chatBox").style.cssText = `position: relative; height: calc(100% - 4rem); width: ${chatWidth}vw; padding: 0rem`;
chatButton.style.display = 'none';

//Functions
function ButtonPos() {
  if (!newButton) return;
  if (window.innerWidth > 1740) {
    newButton.style.removeProperty('left');
    newButton.style.removeProperty('bottom');
    newButton.style.right = "5rem";
    newButton.style.top = "0.6rem";
    return
  }
  newButton.style.removeProperty('top');
  newButton.style.removeProperty('right');
  newButton.style.bottom = "1rem";
  if (docCookies.getItem('web_app_menu')) {newButton.style.left = "4.5rem"; return}
  newButton.style.left = "17rem"
}

ButtonPos();
window.addEventListener('resize',ButtonPos);

newButton.onmousedown = () => {
  newHTML.style.display = newHTML.style.display === "none" ? "block" : "none";
  chatButton.click();
};

//Main Script
newButton.innerHTML = "Show/Hide Chat";
newHTML.style.cssText = `background-color: rgb(17 17 17 / var(--tw-bg-opacity)); height: 94vh; width: ${chatWidth}vw; float: right; position: sticky; z-index: 1; display: none`;

document.onkeydown = event => {
  if (event.code === 'NumpadEnter') {
    newButton.onmousedown()
  }
}

if(docCookies.getItem('show_chat') === 'true') {
  newHTML.style.display = "block"
}

document.body.querySelector('.h-screen.flex.overflow-hidden.bg-gray-100').style.cssText = `z-index: 2; position: relative`;

document.getElementById("app").insertAdjacentElement(`afterbegin`, newHTML);
document.querySelector(".web-app-container").insertAdjacentElement(`afterbegin`, newButton);
newHTML.appendChild(smmoChat);