TINYCHAT ROOMTHEME

Editing Overall Theme of Tinychat. Install and refresh.

// ==UserScript==
// @name         TINYCHAT ROOMTHEME
// @namespace
// @version      2019.119
// @description  Editing Overall Theme of Tinychat. Install and refresh.
// @author       LogicalStoner
 //@match         https://tinychat.com/*
// @match        https://tinychat.com/room/*
// @exclude      https://tinychat.com/room/*?1
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_listValues

// @namespace https://greasyfork.org/users/394583
// ==/UserScript==
/* jshint -W097 */

wsdata = [];
chatlogMain = "";
userlistLog = {};
userlistLogQuits = {};
function tcl(m) { console.log(m); };
newline = `
`;

(function () {
	WebSocket.prototype._send = WebSocket.prototype.send;
	WebSocket.prototype.send = function (data) {
		this._send(data);
		this.addEventListener('message', function (msg) {
			try{
			if (msg.data.includes('"tc":"msg"') && msg.data.includes('"handle"')) {
				var messageArr = JSON.parse(msg.data);
				var handle = messageArr["handle"];
				chatlogAdd(userlistLog[handle]["nick"] + ": " + messageArr["text"]);
			}
			if (msg.data.includes('"item"')) {
				if (msg.data.includes('tc":"yut_play"')) {
					var youtubeArr = JSON.parse(msg.data);
					var id = youtubeArr["item"]["id"];
					chatlogAdd("- YouTube video started: " + "https://youtube.com/watch?v=" + id);
				}
				if (msg.data.includes('tc":"yut_stop"')) chatlogAdd("- YouTube video stopped.");
			}
			if (msg.data.match(/"tc":"(?:un)?publish"/)) {
				var publishArr = JSON.parse(msg.data);
				var action = (publishArr["tc"] == "publish") ? "is" : "stopped";
				var handle = publishArr["handle"];

				if (userlistLog[handle]) var nick = userlistLog[handle]["nick"];
				else var nick = userlistLogQuits[handle]["nick"];

				chatlogAdd("- " + nick + " " + action + " broadcasting.");
			}
			if (msg.data.includes('"tc":"sysmsg"')) {
				var systext = JSON.parse(msg.data)["text"];
				chatlogAdd("-- " + systext);
			}
			if (msg.data.includes('"tc":"userlist"')) {
				userlistArr = JSON.parse(msg.data)["users"];
				for (i=0; i < userlistArr.length; i++) {
					var nick = userlistArr[i]["nick"];
					var handle = userlistArr[i]["handle"];
					var username = userlistArr[i]["username"];
					userlistLog[handle] = {"nick":nick, "username":username};
				}
			}
			if (msg.data.includes('"tc":"join","username":"')) {
				var userArr = JSON.parse(msg.data)
				var nick = userArr["nick"];
				var handle = userArr["handle"];
				var username = userArr["username"];
				userlistLog[handle] = {"nick":nick, "username":username};
			}
			if (msg.data.includes('"tc":"quit"')) {
				var userArr = JSON.parse(msg.data);
				var handle = userArr["handle"];
				userlistLogQuits[handle] = userlistLog[handle];
				delete userlistLog[handle];
			}
			if (msg.data.includes('"tc":"nick"')) {
				var userArr = JSON.parse(msg.data);
				var handle = userArr["handle"];
				var nick = userArr["nick"];
				userlistLog[handle]["nick"] = nick;
			}
			}catch(e){console.log("TES error WS: " + e.message);}
		}, false);
		this.send = function (data) {
			this._send(data);
			wsdata.push(data);
		};
		wsdata.push(data);

	}

	function chatlogAdd(arg) {
		var timestamp = new Date().toLocaleTimeString('en-US', { hour12: false });
		chatlogMain += "[" + timestamp + "] " + arg + newline;
	}
})();

var initInterval = setInterval(waitForInit, 500);
function waitForInit(){
	if (document.querySelector("tinychat-webrtc-app").shadowRoot) {
		clearInterval(initInterval);
		(function() {

// Actual userscript starts here //

browserFirefox = (navigator.userAgent.includes("Firefox/") ? true : false);

var bodyElem = document.querySelector("body");

var webappElem = document.querySelector("tinychat-webrtc-app").shadowRoot;

var chatlogOuter = webappElem.querySelector("#room-content");
var chatlogOuter2 = webappElem.querySelector("#room-content");
var chatlogElem = webappElem.querySelector("tc-chatlog").shadowRoot;
var titleElem = webappElem.querySelector("tc-title").shadowRoot;
var sidemenuElem = webappElem.querySelector("tc-sidemenu").shadowRoot;
var videomoderationElem = sidemenuElem.querySelector("tc-video-moderation").shadowRoot;
var videolistElem = webappElem.querySelector("tc-videolist").shadowRoot;
var themeCSS = titleElem.querySelector("#tes-themes");
var chatlistElem = sidemenuElem.querySelector("tc-chatlist").shadowRoot;
var userlistElem = sidemenuElem.querySelector("tc-userlist").shadowRoot;
var userContextmenuElem = userlistElem.querySelector("tc-user-contextmenu").shadowRoot;

var chatlogCSS = chatlogElem.querySelector("#chat-wrapper");
var sidemenuCSS = sidemenuElem.querySelector("#sidemenu");
var videomoderationCSS = videomoderationElem.querySelector("#moderatorlist");
var webappCSS = webappElem.querySelector("#room");
var chatlistCSS = chatlistElem.querySelector("#chatlist");
var userlistCSS = userlistElem.querySelector("#userlist");
var userContextmenuCSS = userContextmenuElem.querySelector("#main");
var titleCSS = titleElem.querySelector("#room-header");
var videolistCSS = videolistElem.querySelector("#videolist");
var bodyCSS = document.querySelector("body");

var resourceDirectory = document.querySelector('link[rel="manifest"]').getAttribute("href").split("manifest")[0]; // \/([\d\.\-])+\/

var audioPop = new Audio(resourceDirectory + 'sound/pop.mp3');
var settingMentions = [];
var giftsElemWidth = 127;
var freshInstall = (GM_listValues().length == 0);
var isModerator = (!userlistElem.querySelector("#button-banlist").classList.contains("hidden"));
var isPaidAccount = (sidemenuElem.querySelector("#sidemenu-wider"));

var messageQueryString = "#chat-content .message";
var camQueryString = ".videos-items:last-child > .js-video";

var urlAddress = new URL(window.location.href);
var urlPars = urlAddress.searchParams;

var roomName = document.querySelector("tinychat-webrtc-app").getAttribute("roomname");
var joinTime = getFormattedDateTime(new Date(), "time");
var joinDate = getFormattedDateTime(new Date());
document.title = roomName + " - Tinychat";


var userinfoCont = sidemenuElem.querySelector("#user-info > div");
if (userinfoCont.hasAttribute("title")) {
	bodyCSS.classList.add("logged-in");
	sidemenuElem.querySelector("#sidemenu").classList.add("logged-in");
}
if (isModerator) {
	userlistElem.querySelector("#userlist").classList.add("tes-mod");
	chatlistElem.querySelector("#chatlist").classList.add("tes-mod");
}


var settingsQuick = {
	"Autoscroll" : (GM_getValue("tes-Autoscroll") == "true" || GM_getValue("tes-Autoscroll") == undefined),
	"MentionsMonitor" : (GM_getValue("tes-MentionsMonitor") == "true" || GM_getValue("tes-MentionsMonitor") == undefined),
	"NotificationsOff" : (GM_getValue("tes-NotificationsOff") == "true"),
	"ChangeFont" : (GM_getValue("tes-ChangeFont") == "true" || GM_getValue("tes-ChangeFont") == undefined),
	"MaxedCamLeft" : (GM_getValue("tes-MaxedCamLeft") == "true" || GM_getValue("tes-MaxedCamLeft") == undefined),

	"NightMode" : (GM_getValue("tes-NightMode") == "true"),
	"NightModeBlack" : (GM_getValue("tes-NightModeBlack") == "true" || GM_getValue("tes-NightModeBlack") == undefined),

    "DefaultMode" : (GM_getValue("tes-NighModeBlack") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "PinkMode" : (GM_getValue("tes-PinkMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "BlueMode" : (GM_getValue("tes-BlueMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "GreenMode" : (GM_getValue("tes-GreenMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "PurpleMode" : (GM_getValue("tes-PurpleMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "DarkPurpleMode" : (GM_getValue("tes-DarkPurpleMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "OrangeMode" : (GM_getValue("tes-OrangeMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "RedMode" : (GM_getValue("tes-RedMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "WhiteMode" : (GM_getValue("tes-WhiteMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "FeatureOneMode" : (GM_getValue("tes-FeatureOneMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "FeatureTwoMode" : (GM_getValue("tes-FeatureTwoMode") == "true" || GM_getValue("tes-DarkMode") == "false"),
    "FeatureThreeMode" : (GM_getValue("tes-FeatureThreeMode") == "true" || GM_getValue("tes-DarkMode") == "false"),




	"MaxedCamLeft" : (GM_getValue("tes-MaxedCamLeft") == "true" || GM_getValue("tes-MaxedCamLeft") == undefined),
	"BorderlessCams" : (GM_getValue("tes-BorderlessCams") == "true"),
    "ChatBelow" : (GM_getValue("tes-ChatBelow") == "true" || GM_getValue("tes-ChatBelow") == undefined)
};
if (settingsQuick["ChangeFont"]) bodyElem.classList.add("tes-changefont");
if (settingsQuick["MaxedCamLeft"]) videolistCSS.classList.add("tes-leftcam");
if (settingsQuick["NightMode"]) nightmodeToggle(true);

if (settingsQuick["DefaultMode"]) defaultmodeToggle(true) && whitemodeToggle(false)  && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && purplemodeToggle(false) && orangemodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["PinkMode"]) pinkmodeToggle(true) && whitemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && purplemodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["BlueMode"]) bluemodeToggle(true) && whitemodeToggle(false) && greenmodeToggle(false) && pinkmodeToggle(false) && purplemodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["GreenMode"]) greenmodeToggle(true) && whitemodeToggle(false) && pinkmodeToggle(false) && bluemodeToggle(false) && purplemodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["PurpleMode"]) purplemodeToggle(true) && whitemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["DarkPurpleMode"]) darkpurplemodeToggle(true) && whitemodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["OrangeMode"]) orangemodeToggle(true) && whitemodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && redmodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["RedMode"]) redmodeToggle(true) && whitemodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && featureonemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["FeatureOneMode"]) featureonemodeToggle(true) && whitemodeToggle(false) && redmodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && featuretwomodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["FeatureTwoMode"]) featuretwomodeToggle(true) && whitemodeToggle(false) && redmodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && featureonemodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);
if (settingsQuick["FeatureThreeMode"]) featurethreemodeToggle(true) && featuretwomodeToggle(false) && whitemodeToggle(false) && redmodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && featureonemodeToggle(false) && darkpurplemodeToggle(false);
if (settingsQuick["WhiteMode"]) whitemodeToggle(true) && featuretwomodeToggle(false) && redmodeToggle(false) && purplemodeToggle(false) && greenmodeToggle(false) && bluemodeToggle(false) && pinkmodeToggle(false) && defaultmodeToggle(false) && orangemodeToggle(false) && featureonemodeToggle(false) && darkpurplemodeToggle(false) && featurethreemodeToggle(false);


if (settingsQuick["ChatBelow"]) chatBelowToggle(true);
if (browserFirefox) {
	titleElem.querySelector("#room-header-info").insertAdjacentHTML("afterend", `
	<div id="tes-firefoxwarning" class="style-scope tinychat-title"
	style="font-size: .75em; background: white; color: grey; width: 200px; padding: 5px; line-height: 13px;vertical-align: middle;border: #ddd 1px solid;border-width: 0px 1px 0px 1px;">
		<div class="style-scope tinychat-title" style="display: table;height: 100%;">
			<span style="display: table-cell; vertical-align: middle;top: 16%;" class="style-scope tinychat-title">
			Tinychat Enhancement Suite only supports Chrome. Support for Firefox is coming, but for now it only has autoscrolling.
			</span>
		</div>
	</div>
	`);
}


function waitForSettings() {
	if (browserFirefox) {
		clearInterval(settingsWaitInterval);
		return;
	}
	settingsVisible = false;
	if (titleElem.querySelector("#room-header-gifts") != null) {
		clearInterval(settingsWaitInterval);

		giftsElemWidth = titleElem.querySelector("#room-header-gifts").offsetWidth;
		if (titleElem.querySelector("#room-header-gifts-items") == null) {
			giftsElemWidth1000 = giftsElemWidth + 45;
		}
		else { giftsElemWidth1000 = giftsElemWidth; }
		if (titleCSS.querySelector("#titleCSS")) {
			titleCSS.querySelector("#titleCSS").innerHTML += `
				#tes-settings {
					right: ` + giftsElemWidth + `px;
				}
			`;
		}

		settingsElem = titleElem.querySelector("#room-header-gifts").insertAdjacentHTML("beforebegin", `
		<div id="tes-settings">
			<div id="tes-settingsBox" class="hidden">
                 <p id="title">Theme Settings</p>
				<div id="tes-settings-mentions" class="tes-setting-container">
					<input type="checkbox">

					</span>
					<div class="inputcontainer">
						<input class="text"><button class="save blue-button">save</button>
					</div>
				</div>
				<div id="tes-settings-autoscroll" class="tes-setting-container">
					<input type="checkbox">
					<span class="label">
						Autoscroll
					</span>
				</div>
				<div id="tes-settings-notifications" class="tes-setting-container">
					<input type="checkbox">
					<span class="label">
						Hide notifications
					</span>
				</div>
				<div id="tes-settings-changefont" class="tes-setting-container">
					<input type="checkbox">
					<span class="label">
						Improve font
						<span class="info" data-title='The default font is too thin in some browsers'>?</span>
					</span>
				</div>
				<div id="tes-settings-chatbelow" class="tes-setting-container">
					<input type="checkbox">
					</span>
				</div>
				<div id="tes-settings-nightmode" class="tes-setting-container">
					<input type="checkbox">
					<span class="label">
						Remove Borders
					</span>
				</div>


<!-- RIGHT SIDE -->


<div id="modes"  class="tes-setting-container right">
		<div id="Theme Modes">
					<div class="head">
						Theme Modes
					</div>
				</div>
<div id="tes-settings-defaultmode"><label>
					<input type="checkbox">
<span class="checkmark"></span>
					<span class="label">
<div class="foo default">Dark</div></label>
					</span>
				</div>
			<div id="tes-settings-pinkmode"><label>
					<input type="checkbox">
<span class="checkmark"></span>
					<span class="label">
<div class="foo pink">PINK</div></label>
					</span>
				</div>
			<div id="tes-settings-greenmode"><label>
					<input type="checkbox">
<span class="checkmark"></span>
					<span class="label">
<div class="foo green">GREEN</div></label>
					</span>
				</div>
			<div id="tes-settings-bluemode"><label>
					<input type="checkbox">
<span class="checkmark"></span>
					<span class="label">
<div class="foo blue">BLUE</div></label>
					</span>
				</div>
			<div id="tes-settings-purplemode"><label>
					<input type="checkbox">
<span class="checkmark"></span>
					<span class="label">
<div class="foo purple">PURPLE</div></label>
					</span>
				</div>
</div>

				<!--
					<div id="tes-settings-messageanim" class="tes-setting-container">
						<input type="checkbox">
						<span class="label">
							Disable message animation
						</span>
					</div>
				-->
			</div>


<div id="tes-updateNotifier"><a class="tes-closeButtonSmall">?</a><span>New Feature : Color Modes!</span></div>
			<div id="tes-settingsGear" title="Settings"><span><img src="https://cdn.pixabay.com/photo/2014/03/24/17/20/gear-295455_960_720.png" width="40px"></span></div>
</div>
</div>





		`);

		titleElem.getElementById("tes-settingsGear").addEventListener("click", toggleSettingsDisplay);
        titleElem.getElementById("tes-updateNotifier").addEventListener("click", function(){toggleSettingsDisplay("updateNotifier");} );
		if (!freshInstall && GM_getValue("tes-updateNotifSeen") != "2018.112") titleElem.getElementById("tes-updateNotifier").classList.add("visible");
		titleElem.querySelector("#tes-settings #tes-settings-mentions button.save").addEventListener("click", function(){mentionsManager("save");} );
		!browserFirefox ? mentionsManager("load") : void(0);

		settingsCheckboxUpdate();
		titleElem.querySelector("#tes-settings-autoscroll input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-autoscroll");});
		titleElem.querySelector("#tes-settings-mentions input:first-of-type").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-mentions");});
		titleElem.querySelector("#tes-settings-notifications input:first-of-type").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-notifications");});
		titleElem.querySelector("#tes-settings-changefont input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-changefont");});
        titleElem.querySelector("#tes-settings-nightmode input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-nightmode");});
        titleElem.querySelector("#tes-settings-pinkmode input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-pinkmode");});
        titleElem.querySelector("#tes-settings-greenmode input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-greenmode");});
        titleElem.querySelector("#tes-settings-bluemode input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-bluemode");});
        titleElem.querySelector("#tes-settings-purplemode input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-purplemode");});
        titleElem.querySelector("#tes-settings-defaultmode input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-defaultmode");});
        titleElem.querySelector("#tes-settings-chatbelow input").addEventListener("click", function(){settingsCheckboxUpdate("tes-settings-chatbelow");});

		notificationHider();
	}

}
function nightmodeToggle(arg) {
	try{
	var nightmodeClasses = ["tes-nightmode"];

	if (settingsQuick["NightModeBlack"]) nightmodeClasses.push("blacknight");

	if (arg == true) {
		bodyElem.classList.add(...nightmodeClasses);
		titleCSS.classList.add(...nightmodeClasses);
		sidemenuCSS.classList.add(...nightmodeClasses);
		userlistCSS.classList.add(...nightmodeClasses);
		webappCSS.classList.add(...nightmodeClasses);
		videolistCSS.classList.add(...nightmodeClasses);
		videomoderationCSS.classList.add(...nightmodeClasses);
		chatlistCSS.classList.add(...nightmodeClasses);
		chatlogCSS.classList.add(...nightmodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.add(...nightmodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.add(...nightmodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.add(...nightmodeClasses);

				if (camItemCSS.querySelector("#camItemCSS") == null) camItemCSS.insertAdjacentHTML("afterbegin", camItemCSShtml);
			}
		}
	}
	if (arg == false) {
		if (!settingsQuick["NightModeBlack"] && settingsQuick["NightMode"]) nightmodeClasses = ["blacknight"];

		bodyElem.classList.remove(...nightmodeClasses);
		titleCSS.classList.remove(...nightmodeClasses);
		sidemenuCSS.classList.remove(...nightmodeClasses);
		userlistCSS.classList.remove(...nightmodeClasses);
		webappCSS.classList.remove(...nightmodeClasses);
		videolistCSS.classList.remove(...nightmodeClasses);
		videomoderationCSS.classList.remove(...nightmodeClasses);
		chatlistCSS.classList.remove(...nightmodeClasses);
		chatlogCSS.classList.remove(...nightmodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.remove(...nightmodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.remove(...nightmodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.remove(...nightmodeClasses);
			}
		}
	}
	}catch(e){tcl("error nightmodeToggle: " + e.message);}
}




function pinkmodeToggle(arg) {
	try{
	var pinkmodeClasses = ["tes-pinkmode"];

	if (settingsQuick["PinkModeBlack"]) pinkmodeClasses.push("pinknight");

	if (arg == true) {
		bodyElem.classList.add(...pinkmodeClasses);
		titleCSS.classList.add(...pinkmodeClasses);
		sidemenuCSS.classList.add(...pinkmodeClasses);
		userlistCSS.classList.add(...pinkmodeClasses);
		webappCSS.classList.add(...pinkmodeClasses);
		videolistCSS.classList.add(...pinkmodeClasses);
		videomoderationCSS.classList.add(...pinkmodeClasses);
		chatlistCSS.classList.add(...pinkmodeClasses);
		chatlogCSS.classList.add(...pinkmodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.add(...pinkmodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.add(...pinkmodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.add(...pinkmodeClasses);

				if (camItemCSS.querySelector("#camItemCSS") == null) camItemCSS.insertAdjacentHTML("afterbegin", camItemCSShtml);
			}
		}
	}
	if (arg == false) {
		if (!settingsQuick["PinkModeBlack"] && settingsQuick["PinkMode"]) nightmodeClasses = ["pinknight"];

		bodyElem.classList.remove(...pinkmodeClasses);
		titleCSS.classList.remove(...pinkmodeClasses);
		sidemenuCSS.classList.remove(...pinkmodeClasses);
		userlistCSS.classList.remove(...pinkmodeClasses);
		webappCSS.classList.remove(...pinkmodeClasses);
		videolistCSS.classList.remove(...pinkmodeClasses);
		videomoderationCSS.classList.remove(...pinkmodeClasses);
		chatlistCSS.classList.remove(...pinkmodeClasses);
		chatlogCSS.classList.remove(...pinkmodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.remove(...pinkmodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.remove(...pinkmodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.remove(...pinkmodeClasses);
			}
		}
	}
	}catch(e){tcl("error pinkmodeToggle: " + e.message);}
}

function greenmodeToggle(arg) {
	try{
	var greenmodeClasses = ["tes-greenmode"];

	if (settingsQuick["GreenModeBlack"]) greenmodeClasses.push("greennight");

	if (arg == true) {
		bodyElem.classList.add(...greenmodeClasses);
		titleCSS.classList.add(...greenmodeClasses);
		sidemenuCSS.classList.add(...greenmodeClasses);
		userlistCSS.classList.add(...greenmodeClasses);
		webappCSS.classList.add(...greenmodeClasses);
		videolistCSS.classList.add(...greenmodeClasses);
		videomoderationCSS.classList.add(...greenmodeClasses);
		chatlistCSS.classList.add(...greenmodeClasses);
		chatlogCSS.classList.add(...greenmodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.add(...greenmodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.add(...greenmodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.add(...greenmodeClasses);

				if (camItemCSS.querySelector("#camItemCSS") == null) camItemCSS.insertAdjacentHTML("afterbegin", camItemCSShtml);
			}
		}
	}
	if (arg == false) {
		if (!settingsQuick["GreenModeBlack"] && settingsQuick["GreenMode"]) nightmodeClasses = ["greennight"];

		bodyElem.classList.remove(...greenmodeClasses);
		titleCSS.classList.remove(...greenmodeClasses);
		sidemenuCSS.classList.remove(...greenmodeClasses);
		userlistCSS.classList.remove(...greenmodeClasses);
		webappCSS.classList.remove(...greenmodeClasses);
		videolistCSS.classList.remove(...greenmodeClasses);
		videomoderationCSS.classList.remove(...greenmodeClasses);
		chatlistCSS.classList.remove(...greenmodeClasses);
		chatlogCSS.classList.remove(...greenmodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.remove(...greenmodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.remove(...greenmodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.remove(...greenmodeClasses);
			}
		}
	}
	}catch(e){tcl("error greenmodeToggle: " + e.message);}
}

function bluemodeToggle(arg) {
	try{
	var bluemodeClasses = ["tes-bluemode"];

	if (settingsQuick["BlueModeBlack"]) bluemodeClasses.push("bluenight");

	if (arg == true) {
		bodyElem.classList.add(...bluemodeClasses);
		titleCSS.classList.add(...bluemodeClasses);
		sidemenuCSS.classList.add(...bluemodeClasses);
		userlistCSS.classList.add(...bluemodeClasses);
		webappCSS.classList.add(...bluemodeClasses);
		videolistCSS.classList.add(...bluemodeClasses);
		videomoderationCSS.classList.add(...bluemodeClasses);
		chatlistCSS.classList.add(...bluemodeClasses);
		chatlogCSS.classList.add(...bluemodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.add(...bluemodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.add(...bluemodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.add(...bluemodeClasses);

				if (camItemCSS.querySelector("#camItemCSS") == null) camItemCSS.insertAdjacentHTML("afterbegin", camItemCSShtml);
			}
		}
	}
	if (arg == false) {
		if (!settingsQuick["BlueModeBlack"] && settingsQuick["BlueMode"]) nightmodeClasses = ["bluenight"];

		bodyElem.classList.remove(...bluemodeClasses);
		titleCSS.classList.remove(...bluemodeClasses);
		sidemenuCSS.classList.remove(...bluemodeClasses);
		userlistCSS.classList.remove(...bluemodeClasses);
		webappCSS.classList.remove(...bluemodeClasses);
		videolistCSS.classList.remove(...bluemodeClasses);
		videomoderationCSS.classList.remove(...bluemodeClasses);
		chatlistCSS.classList.remove(...bluemodeClasses);
		chatlogCSS.classList.remove(...bluemodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.remove(...bluemodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.remove(...bluemodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.remove(...bluemodeClasses);
			}
		}
	}
	}catch(e){tcl("error bluemodeToggle: " + e.message);}
}

function purplemodeToggle(arg) {
	try{
	var purplemodeClasses = ["tes-purplemode"];

	if (settingsQuick["PurpleModeBlack"]) purplemodeClasses.push("purplenight");

	if (arg == true) {
		bodyElem.classList.add(...purplemodeClasses);
		titleCSS.classList.add(...purplemodeClasses);
		sidemenuCSS.classList.add(...purplemodeClasses);
		userlistCSS.classList.add(...purplemodeClasses);
		webappCSS.classList.add(...purplemodeClasses);
		videolistCSS.classList.add(...purplemodeClasses);
		videomoderationCSS.classList.add(...purplemodeClasses);
		chatlistCSS.classList.add(...purplemodeClasses);
		chatlogCSS.classList.add(...purplemodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.add(...purplemodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.add(...purplemodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.add(...purplemodeClasses);

				if (camItemCSS.querySelector("#camItemCSS") == null) camItemCSS.insertAdjacentHTML("afterbegin", camItemCSShtml);
			}
		}
	}
	if (arg == false) {
		if (!settingsQuick["PurpleModeBlack"] && settingsQuick["PurpleMode"]) nightmodeClasses = ["purplenight"];

		bodyElem.classList.remove(...purplemodeClasses);
		titleCSS.classList.remove(...purplemodeClasses);
		sidemenuCSS.classList.remove(...purplemodeClasses);
		userlistCSS.classList.remove(...purplemodeClasses);
		webappCSS.classList.remove(...purplemodeClasses);
		videolistCSS.classList.remove(...purplemodeClasses);
		videomoderationCSS.classList.remove(...purplemodeClasses);
		chatlistCSS.classList.remove(...purplemodeClasses);
		chatlogCSS.classList.remove(...purplemodeClasses);
		chatlogElem.querySelector("#chat-wider").classList.remove(...purplemodeClasses);
		// Messages:
		if (chatlogElem.querySelector(messageQueryString) != null) {
			var messageElems = chatlogElem.querySelectorAll(messageQueryString);
			for (i=0; i < messageElems.length; i++) {
				var messageItem = messageElems[i].querySelector("tc-message-html").shadowRoot;
				var messageItemCSS = messageItem.querySelector(".message");
				messageItemCSS.classList.remove(...purplemodeClasses);
			}
		}
		// Cams:
		if (videolistElem.querySelector(camQueryString) != null) {
			var camElems = videolistElem.querySelectorAll(camQueryString);
			for (i=0; i < camElems.length; i++) {
				var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
				var camItemCSS = camItem.querySelector(".video");
				camItemCSS.classList.remove(...purplemodeClasses);
			}
		}
	}
	}catch(e){tcl("error purplemodeToggle: " + e.message);}
}


function toggleSettingsDisplay(arg) {
	if (arg == "updateNotifier") {
		titleElem.querySelector("#tes-updateNotifier").classList.remove("visible");
		GM_setValue("tes-updateNotifSeen", "2018.112");
	}

	if (settingsVisible == true) {
		titleElem.getElementById("tes-settingsBox").classList.add("hidden");
		titleElem.getElementById("tes-settings").classList.remove("tes-open");
		settingsVisible = false;
	}

	else {
		titleElem.getElementById("tes-settingsBox").classList.remove("hidden");
		titleElem.getElementById("tes-settings").classList.add("tes-open");
		settingsVisible = true;
	}

}

function settingsCheckboxUpdate(settingName=null, value=null) {
	if (settingName == null && value == null) {
		titleElem.getElementById("tes-settings-autoscroll").querySelector("input").checked = settingsQuick["Autoscroll"];
		titleElem.getElementById("tes-settings-mentions").querySelector("input").checked = settingsQuick["MentionsMonitor"];
		titleElem.getElementById("tes-settings-notifications").querySelector("input").checked = settingsQuick["NotificationsOff"];
		titleElem.getElementById("tes-settings-changefont").querySelector("input").checked = settingsQuick["ChangeFont"];
        titleElem.getElementById("tes-settings-nightmode").querySelector("input").checked = settingsQuick["NightMode"];
        titleElem.getElementById("tes-settings-defaultmode").querySelector("input").checked = settingsQuick["DefaultMode"];
        titleElem.getElementById("tes-settings-chatbelow").querySelector("input").checked = settingsQuick["ChatBelow"];

        titleElem.getElementById("tes-settings-defaultmode").querySelector("input").checked = settingsQuick["DefaultMode"];
        titleElem.getElementById("tes-settings-pinkmode").querySelector("input").checked = settingsQuick["PinkMode"];
        titleElem.getElementById("tes-settings-greenmode").querySelector("input").checked = settingsQuick["GreenMode"];
        titleElem.getElementById("tes-settings-bluemode").querySelector("input").checked = settingsQuick["BlueMode"];
        titleElem.getElementById("tes-settings-purplemode").querySelector("input").checked = settingsQuick["PurpleMode"];

		return;
	}
        if (settingName == "tes-settings-chatbelow") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-chatbelow").querySelector("input").checked;
			settingsQuick["ChatBelow"] = newValue;
			GM_setValue("tes-ChatBelow", newValue.toString());
            chatBelowToggle(newValue);
		}
	}
	if (settingName == "tes-settings-autoscroll") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-autoscroll").querySelector("input").checked;
			settingsQuick["Autoscroll"] = newValue;
			GM_setValue("tes-Autoscroll", newValue.toString());
		}
	}
	if (settingName == "tes-settings-mentions") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-mentions").querySelector("input:first-of-type").checked;
			// if (newValue) {
				// titleElem.getElementById("tes-settings-mentions").getAttribute("class").includes("setting-disabled");
			// }
			settingsQuick["MentionsMonitor"] = newValue;
			GM_setValue("tes-MentionsMonitor", newValue.toString());
		}
	}
	if (settingName == "tes-settings-notifications") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-notifications").querySelector("input").checked;
			settingsQuick["NotificationsOff"] = newValue;
			GM_setValue("tes-NotificationsOff", newValue.toString());
			notificationHider();
		}
	}
	if (settingName == "tes-settings-changefont") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-changefont").querySelector("input").checked;
			settingsQuick["ChangeFont"] = newValue;
			GM_setValue("tes-ChangeFont", newValue.toString());
			fontToggle(newValue);
		}
	}
	if (settingName == "tes-settings-nightmode") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-nightmode").querySelector("input").checked;
			settingsQuick["NightMode"] = newValue;
			GM_setValue("tes-NightMode", newValue.toString());
			nightmodeToggle(newValue);
		}
	}
    	if (settingName == "tes-settings-pinkmode") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-pinkmode").querySelector("input").checked;
            titleElem.querySelector("#tes-settings-greenmode input").checked = null;
            titleElem.querySelector("#tes-settings-bluemode input").checked = null;
            titleElem.querySelector("#tes-settings-purplemode input").checked = null;
            titleElem.querySelector("#tes-settings-defaultmode input").checked = (!newValue);
			settingsQuick["PinkMode"] = newValue;
			GM_setValue("tes-PinkMode", newValue.toString());
			pinkmodeToggle(newValue);
			pinkmodeToggle(true);
            greenmodeToggle(false);
            bluemodeToggle(false);
            purplemodeToggle(false);
		}
	}
        if (settingName == "tes-settings-greenmode") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-greenmode").querySelector("input").checked;
            titleElem.querySelector("#tes-settings-pinkmode input").checked = null;
            titleElem.querySelector("#tes-settings-bluemode input").checked = null;
            titleElem.querySelector("#tes-settings-purplemode input").checked = null;
            titleElem.querySelector("#tes-settings-defaultmode input").checked = (!newValue);
			settingsQuick["GreenMode"] = newValue;
			GM_setValue("tes-GreenMode", newValue.toString());
			greenmodeToggle(newValue);
			greenmodeToggle(true);
            pinkmodeToggle(false);
            bluemodeToggle(false);
            purplemodeToggle(false);
		}
	}
            if (settingName == "tes-settings-bluemode") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-bluemode").querySelector("input").checked;
            titleElem.querySelector("#tes-settings-pinkmode input").checked = null;
            titleElem.querySelector("#tes-settings-greenmode input").checked = null;
            titleElem.querySelector("#tes-settings-purplemode input").checked = null;
            titleElem.querySelector("#tes-settings-defaultmode input").checked = (!newValue);
			settingsQuick["BlueMode"] = newValue;
			GM_setValue("tes-BlueMode", newValue.toString());
			bluemodeToggle(newValue);
			bluemodeToggle(true);
            purplemodeToggle(false);
            pinkmodeToggle(false);
            greenmodeToggle(false);
		}
	}
            if (settingName == "tes-settings-purplemode") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-purplemode").querySelector("input").checked;
            titleElem.querySelector("#tes-settings-pinkmode input").checked = null;
            titleElem.querySelector("#tes-settings-greenmode input").checked = null;
            titleElem.querySelector("#tes-settings-bluemode input").checked = null;
            titleElem.querySelector("#tes-settings-defaultmode input").checked = (!newValue);
			settingsQuick["PurpleMode"] = newValue;
			GM_setValue("tes-PurpleMode", newValue.toString());
			purplemodeToggle(newValue);
			purplemodeToggle(true);
            pinkmodeToggle(false);
            greenmodeToggle(false);
            bluemodeToggle(false);
		}
}
            if (settingName == "tes-settings-defaultmode") {
		if (value == null) {
			var newValue = titleElem.getElementById("tes-settings-defaultmode").querySelector("input").checked;
            titleElem.querySelector("#tes-settings-purplemode input").checked = null;
            titleElem.querySelector("#tes-settings-pinkmode input").checked = null;
            titleElem.querySelector("#tes-settings-greenmode input").checked = null;
            titleElem.querySelector("#tes-settings-bluemode input").checked = null;
			settingsQuick["DefaultMode"] = newValue;
			GM_setValue("tes-DefaultMode", newValue.toString());
            purplemodeToggle(false);
            pinkmodeToggle(false);
            greenmodeToggle(false);
            bluemodeToggle(false);
		}
	}
}


var settingsWaitInterval = setInterval(waitForSettings,1000);

function fontToggle(arg) {
	arg ? bodyElem.classList.add("tes-changefont") : bodyElem.classList.remove("tes-changefont");
}
function maxCamPositionToggle(arg) {
	try{
	arg ? videolistCSS.classList.add("tes-leftcam") : videolistCSS.classList.remove("tes-leftcam");
	}catch(e){tcl("error maxCamPositionToggle: " + e.message);}
}
function notificationHider() {
	chatlogContainer = chatlogElem.querySelector("#chat-content");
	settingsQuick["NotificationsOff"] ? chatlogContainer.classList.add("tes-notif-off") : chatlogContainer.classList.remove("tes-notif-off");
}

function chatBelowToggle(arg) {
			arg ? chatlogOuter.classList.add("tes-chatbelow") : chatlogOuter.classList.remove("tes-chatbelow");
}

function copyChatlog(opt=null) {
	try{
	if (opt == "close") {
		chatlogDisplayElem.classList.remove("show");
		chatlogDisplayClose.classList.remove("show");
		setTimeout(function(){chatlogDisplayCont.classList.remove("show");}, 300);
		return;
	}

	var filename = "tinychat_" + roomName + "_" + joinDate + "_" + joinTime.replace(/:/g, ".") + "-chatlog.log";
	var chatlogText = "Tinychat room " + roomName + " on " + joinDate + " " + joinTime + newline + chatlogMain;

	var downloadLink = 'data:text/plain;charset=utf-8,' + encodeURIComponent(chatlogText);
	var downloadElem = document.createElement('a');
	downloadElem.setAttribute("href", downloadLink);

	downloadElem.setAttribute("download", filename);

	if (opt == "download") downloadElem.click();
	if (opt == "view" || opt == null) {
		if (typeof chatlogDisplayCont == "undefined") {
			chatlogDisplayCont = chatlogElem.querySelector("#tes-chatlogDisplay");
			chatlogDisplayElem = chatlogDisplayCont.querySelector("textarea");
			chatlogDisplayClose = chatlogDisplayCont.querySelector("#close");
		}
		chatlogDisplayElem.value = chatlogText;
		chatlogDisplayCont.classList.add("show");
		setTimeout(function(){
			chatlogDisplayElem.classList.add("show");
			chatlogDisplayClose.classList.add("show");
		}, 50);
		chatlogDisplayElem.scrollTop = chatlogDisplayElem.scrollHeight;
	}
	}catch(e){console.log("TES error copyChatlog: " + e.message);}
}

function getFormattedDateTime(d, opt=null) {
	if (opt == "time") return d.toLocaleTimeString('en-US', { hour12: false });
	else return d.toLocaleDateString('zh-CN', {'year':'numeric', 'month':'2-digit', 'day':'2-digit'}).replace(/\//g, "-");
}
function mentionsManager(mode) {
	var inputElem = titleElem.querySelector("#tes-settings #tes-settings-mentions input.text");
	// phrases = inputElem.value.split(",");
	var phrase = inputElem.value;
	if (phrase.endsWith(",")) { phrase = phrase.slice(0, -1); }
	if (phrase.startsWith(",")) { phrase = phrase.slice(1); }

	if (mode == "save") {
		GM_setValue("tes-Mentions", phrase);
		settingMentions = phrase.split(",");
		inputElem.value = phrase;
	}
	if (mode == "load") {
		var loadedMentions = GM_getValue("tes-Mentions");
		if (loadedMentions != undefined) {
			inputElem.value = loadedMentions;
			settingMentions = loadedMentions.split(",");
		}
	}
						 return;

	var phrase = phrase.toString();
	if (mode == "save") {
		settingMentions.push(phrases);
		GM_setValue("tes-Mentions", JSON.stringify(setting_Mentions));
		console.log("Mention add:" + phrases);
	}
	if (mode == "load") {
		var mentions = JSON.parse(GM_getValue("tes-Mentions"));
		console.log("Mention load:" + mentions);
		settingMentions = mentions;
		inputElem.value = settingMentions.join();
	}
}

!browserFirefox ? injectCSS() : void(0);
function injectCSS(cssName=null) {
	// Indenting is purposely wrong, for readability
	var insertPosition = "beforeend";

	if (browserFirefox) {
		headElem = document.querySelector("head");
		titleCSS = videolistCSS = chatlistCSS = userlistCSS = userContextmenuCSS = bodyCSS = chatlogCSS = sidemenuCSS = videomoderationCSS = webappCSS = headElem;
		headElem.querySelector('[scope="tinychat-title"]').innerHTML += `         #room-header {     min-height: 10%;     max-height: 10%; }      `;
	}

	if (cssName == "titleCSS" || cssName == null) {
	titleCSShtml = `
	<style id="titleCSS" scope="tinychat-title">

#tes-ColorChoice {position:absolute;top:10pxbackground-color:#00ff00;}



.foo {
    float: left;
    width: 100px;
    height: 17px;
    margin-left: 25px;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: 10px;
    text-align: center;
    font-weight: bold;
}


.pink {
  background: #e76bb6;
}

.green {
  background: #042500;
}

.blue {
  background: #2a388b;
}

.purple {
  background: #BF8FE5;
}
.default {
  background: #111111;
}

		@keyframes ease-to-left {
			0% {right: -50px; opacity: 0;}
			100% {right: 0; opacity: 1;}
		}
		@keyframes ease-to-right {
			0% {right:auto;}
			100% {right:0;}
		}
		@keyframes ease-to-bottom-21px {
			0% {top:-300px; opacity: 0;}
			100% {top:0; opacity: 1;}
		}
	   #content {
		   padding: -20px;
background-color:#111111;
	   }
#room-header-gifts-buttons > #get-coins {
    background-color: #111111;
    border-color: #313131;
    color: #313131;
}
#room-header-gifts-buttons > #get-coins:hover {
    background-color: #313131;
    border-color: #111111;
    color: #111111;
}

#room-header-gifts-buttons > a
{
    background-color: #111111;
    border-color: #313131;
    color: #313131;
}
#room-header-gifts-buttons > a:hover {
    background-color: #313131;
    border-color: #111111;
    color: #111111;
}
		#tes-header-grabber {
         position: absolute;
         top: 7rem;
         right: 23rem;
         width: 27px;
         height: 20px;
         border: #313131 1px solid;
         border-radius: 1px;
         text-align: center;
         color: #b4c1c5;
         cursor: pointer;
         transition: all .5s ease-in-out;
         background-color: #111111;
         box-shadow: 0 0 1.9px 1px white;
		}

		#tes-fullscreen-grabber {
		    position: absolute;
			top: 50px;
			right: 18%;#room-header *
			background: white;
			width: 20px;
			height: 20px;
			border: #313131 1px solid;
			border-radius: 19px;
			text-align: center;
			color: #b4c1c5;
			cursor: pointer;
			transition: all .4s ease-in-out;
background-color:#111111;
		}
#tes-header-grabber:before{    content: '';
    position: absolute;
    display: block;
    height: 0;
    width: 0;
    top: 50%;
    left: 50%;
    margin: -7px 0 0 -2px;
    border-width: 4px 4px 4px 0;
    border-style: solid;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid transparent;
    transition: .2s;
}
.tes-headerCollapsed #tes-header-grabber:before {
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    top: 12px;
}

		.tes-headerCollapsed #tes-header-grabber {
			top: 0px;
			background: #111111;
			border-top: 0;
			z-index: 9;
			border-radius: 0px;
			line-height: 15px;
			border-top-left-radius: 0;
			border-top-right-radius: 0;
			height: 15px;
		}
		.tes-headerCollapsed:hover #tes-header-grabber {
			height: 29px;
            border-radius: 0px;
			line-height: 43px;
		}


		.tes-nightmode #tes-settings > div#tes-updateNotifier { border-color: #5d7883; }
		.tes-nightmode #tes-settings > div#tes-updateNotifier {
			background-color: transparent;
			border-color: #145876;
			color:#191919;
			top: -100px;
		}

-------

		#tes-settings > div#tes-updateNotifier {
			top: -200px;
			margin-right: -33px;
			float: left;
			border: #53b6ef 1px solid;
			border-radius: 8px 0 0px 8px;
			padding: 5px;
			padding-right: 32px;
			height: auto;
			transition: visibility 0s, opacity 0.5s linear;
			background: white;
		}
		#tes-settings.tes-open > div#tes-updateNotifier {
			visibility: hidden;
			opacity: 0;
			width: 0;
			height: 0;
			padding: 0;
		}
		#tes-settings > div#tes-updateNotifier:hover { cursor: pointer; }
		.tes-closeButtonSmall {
			float: left;
			padding-right: 5px;
			color: #191919;
			padding-left: 5px;
            background-color: #fff;
            border-radius: 50px;
            height: 20px;
            margin-right: 7px;
            position: relative;
            top: -5px;
            font-size: 12pt;
            font-weight: bold;
		}
		#tes-settings > div#tes-updateNotifier.visible {
		    top: 38px;
            color: #ffffff !important;
            text-transform: uppercase;
            background-color: #002F3E;
            padding: 5px;
            padding-top: 10px;
            padding-right: 40px;
            padding-bottom: 10px;
            border-radius: 20px; }
		.tes-closeButtonSmall:hover { color: #7ccefe; background-color: #2b2b2b;
         border-radius: 50px;
    height: 20px;
    margin-right: 7px;}


------

		input {
			border: 1px solid #c4d4dc;
			line-height: 16px;
			padding-left: 3px;
		}
		.label ~ input {
			border-bottom-left-radius: 6px;
			border-top-left-radius: 6px;
		}
		input ~ button {
			border-bottom-right-radius: 6px;
			border-top-right-radius: 6px;
		}
		input[type="button"], button {
			display: inline;
			padding: 0 15px;
			border: 0;
			box-sizing: border-box;
			letter-spacing: 1px;
			font-size: 12px;
			font-weight: bold;
			line-height: 20px;
			text-align: center;
			transition: .2s;
			outline: none;
		}
		.blue-button {
			color: #fff;
			background-color: #333333;
		}
		.blue-button:hover {
		    background-color: #54ccf3;
		}
		.blue-button:active {
		    background-color: #38a8dd;
		}
		.tes-setting-container {
			line-height: initial;
		}
		#tes-settings > div {
			/*animation: ease-to-bottom-21px .2s ease 0s 1;*/
			position: relative;
			top:1.5rem;
            left: -1rem;
		}
		@media screen and (max-width: 0px) {
			#tes-settings > div {
				height: 0px;
			}
		}
		#tes-settings .hidden { display: none; }
		#tes-settings #title { font-weight: bold;
color:#ffffff;lll
text-transform:uppercase; }
		#tes-settings {
		    width:28rem;
			transition: all .4s ease-in-out;
			animation: ease-to-bottom-21px .2s ease 0s 1;
			/*max-height: 10%;*/
			font-size: 11px;
			flex: none;
			z-index: 9;
			position: absolute;
			top: 25px;
		/*	right: ` + (giftsElemWidth + 10).toString() + `px; */

		}
		@media screen and (max-width: 1000%) {
			#tes-settings {
				right: -7px!important;
				top: -11px;
			}
			#tes-settings.tes-open {
				top: 6px;
			}
			#tes-settingsGear {
				font-size: 52px!important;
			}

#room-header-gifts-items {
    padding: 0 11px;
    border-radius: 12px;
    background-color: #2a2a2a;
    font-size: 0;
    text-align: center;
    white-space: nowrap;
}
		}
		@media screen and (max-width: 600px) {
			#tes-settings {
				right: -4px!important;
    			top: 19px;
			}
		}
		#tes-settings:hover {
			overflow: visible;
		}
		#tes-settings-mentions .inputcontainer {
			float: right;
			position: relative;
			top: -3px;
            opacity: 0;
		}
		#tes-settingsGear {
			font-size: 55px;
			color: #53b6ef;
			float: right;


		}
		#tes-settingsGear:hover {
			cursor: pointer;
			color: #7ccefe;
		}
		.tes-open #tes-settingsGear {
			background:#00000000;
			border-bottom-right-radius: 0px;
			border-top-right-radius: 0px;
			border: #53b6ef 1px solid;
			border-left: 0;
            top: -6rem;
		}
.tes-open #tes-settingsGear span img{
  fill: red;}
			/*transition: all .2s linear;*/
			}
		#tes-settingsGear span {
			display: block;
			transition: transform 0.4s ease-in-out;
		}
		.tes-open #tes-settingsGear span {
			transform: rotate(90deg);
  fill: red;
		}
	#tes-settingsBox {
    background: #111111;
    border: #53b6ef 1px solid;
    border-bottom-right-radius: 0px;
    border-top-right-radius: 0px;
    right: 27rem;
    width:28em;
    transition: all .4s ease-in-out;
    animation: ease-to-bottom-21px .2s ease 0s 1;
    font-size: 0.9rem;
    flex: none;
    z-index: 9;
		}
		#tes-settingsBox.hidden {
			animation: ease-to-right .2s ease 0s 1;
			display: visible;
			/*position: relative; right: -1000px;*/
		}

		/*** Inline with header ***/
		#tes-settingsBox {
    border-bottom-left-radius: 0px;
    border-top-left-radius: 0px;
		}
		#tes-settingsGear {
			display: table;
		}
		#tes-settingsGear span {
			display: table-cell;
			vertical-align: middle;
		}
		/*** *************   ***/

		#tes-settings .right {
			position: absolute;
			left: 189px;
            top:72px;
		}
		#tes-settings .right .label {
			margin-left: unset;
		}
#tes-settings .right .head {
    position: relative;
    top: -5px;
    left: 12px;
    width: 7rem;
    align-items: center;
    overflow: hidden;
    color: #000;
    background-color: #fff;
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
    text-transform: uppercase;
    text-align: center;
    font-weight: bold;
}
#tes-settings-defaultmode {
    top: 77px !important;
}
#tes-settings-pinkmode {
    top: 95px !important;
}
#tes-settings-greenmode {
    top: 113px !important;
}
#tes-settings-bluemode {
    top: 131px !important;
}
#tes-settings-purplemode {
    top: 149px !important;
}
#tes-settings-nightmode {
    top: 92px !important;
}


#tes-settings-defaultmode > label > input[type=checkbox],#tes-settings-purplemode > label > input[type=checkbox],#tes-settings-bluemode > label > input[type=checkbox],#tes-settings-greenmode > label > input[type=checkbox],#tes-settings-pinkmode > label > input[type=checkbox]
{  position: absolute;
  opacity: 0;
  cursor: pointer;
}

#tes-settings-defaultmode > label > span.checkmark:after,#tes-settings-purplemode > label > span.checkmark:after,#tes-settings-bluemode > label > span.checkmark:after,#tes-settings-greenmode > label > span.checkmark:after,#tes-settings-pinkmode > label > span.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}


/* Show the checkmark when checked */
#tes-settings .tes-setting-container input:checked ~ .checkmark:after {
  display: block;
}

#tes-settings-defaultmode > label > span.checkmark:after,#tes-settings-purplemode > label > span.checkmark:after, #tes-settings-bluemode > label > span.checkmark:after, #tes-settings-greenmode > label > span.checkmark:after, #tes-settings-pinkmode > label > span.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

#tes-settings-defaultmode > label > span.checkmark:after,#tes-settings-purplemode > label > span.checkmark:after, #tes-settings-bluemode > label > span.checkmark:after, #tes-settings-greenmode > label > span.checkmark:after, #tes-settings-pinkmode > label > span.checkmark:after {
    left: 15px;
    width: 5px;
    height: 10px;
    border: solid white;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}


label {
 border:0px solid #ccc;
 padding:0px;
 display:block;
}
label:hover {
 background:#53b6ef;
border-radius:10px;
 cursor:pointer;
}



#modes {
    padding: 5px;
    background-color: #111111;
    border: #ffffff 1px solid;
    border-radius: 10px;
    box-shadow: 0 4px 8px 0 rgba(255,255,255,0.27), 0 6px 20px 0 rgba(255,255,255,0.27);
}
.tes-pinkmode #modes {
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
.tes-greenmode #modes {
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
.tes-bluemode #modes {
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

		#tes-settings .tes-setting-container input[type=checkbox] {
			margin: 0;
			margin-right: 1px;
			float: left;
			position: absolute;
			left: 8px;
		}
		#tes-settings .label{
			margin-right: 17px;
			margin-left: 26px;
color:#ffffff;
    position: relative;
    top: -5px;
		}
		#tes-settings .info{
			margin-left: 3px;
			color: #0d94e3;
			font-weight: bold;
			font-family: Arial;
			border: #0d94e3 1px solid;
			border-radius: 16px;
			height: 1em;
			width: 1em;
			text-align: center;
			display: inline-block;
		}
		#tes-settings .info:hover:after{
			font-weight: normal;
			padding: 4px 7px 4px 7px;
			border-radius: 7px;
			color: white;
			background: #61787f;
			content: attr(data-title);
			display: inline-block;
			position: absolute;
			top: 52px;
			left: 0;
			z-index: 9;
		}
		/*#tes-settings .label:hover:before{
			border: solid;
			border-color: #61787f transparent;
			border-width: 0px 6px 6px 6px;
			top: 10px;
			content: "";
			left: 8%;
			position: relative;
			display: inline-block;
		}*/

		}
		#tes-settings a:hover {
			color: #53b6ef;
		}

		#room-header {
            align-self:auto;
            max-height: 1%;
            min-height: 1%;
			transition: all .4s ease-in-out;
            background-color:#00000000;


		}
#room-header-gifts-items {
    padding: 0 11px;
    border-radius: 12px;
    background-color: transparent;
    font-size: 0;
    text-align: center;
    white-space: nowrap;
}
#room-header-gifts-items > a > img {
    height: 75%;
    width: 75%;
    border-radius: 50px;
    border: 4px solid #313131;
}
		#room-header.tes-headerCollapsed {
			margin-top: -10px;
            margin-top: -150px;
            width:100%;
		}
		#room-header.tes-headerCollapsed:hover {
		/*	height: 25px;*/
		}
		@media screen and (max-width: 1000px) {
			#room-header {
				min-height: inherit;
				max-height: inherit;
			}
		}
		#room-header-info {
			padding: 0;
            color: #ffffff;
		}
		#room-header-info > h1 {
         color: #ffffff;
         align-self: auto;
         text-transform: uppercase;
         font-family: inherit;
         left: 0.1rem;
          text-shadow: 0 0 4px #00c4ff;

		}
		#room-header-info > h1:after {
			visibility: hidden;
			hidden: none;
		}
#room-header-info-text:after{
			visibility: hidden;
			hidden: none;
		}
		#room-header-info-text {
         position: relative;
         font-family: sans-serif;
         left: 0.3rem;
         color: white;
         font-size: 0.7rem;
         line-height: 0.9rem;
         letter-spacing: 0.1rem;
         overflow: hidden;
         align-self: auto;
         cursor: default;
         text-shadow: 0 0 2px #00c4ff;
		}
#room-header-info-details > a {
    color: #dcdcdc;
    cursor: pointer;
    text-shadow: 0 0 2px #00c4ff;
    font-size: 1rem;
}

#room-header-info-details {
    font-size: 0.9rem;
    letter-spacing: 0.1rem
    white-space: nowrap;
    cursor: default;
    color: white;
    line-height: 3.9rem;
    text-shadow: 0 0 2px #00c4ff;
}
#room-header-info > span {
    display: inline-block;
    margin-left: 1.3rem;
    box-sizing: border-box;
    /* right: 25rem; */
    font-size: 0;
    text-align: center;
    cursor: pointer;
    /* width: 5rem; */
    -webkit-border-horizontal-spacing: inherit;

}
#room-header-avatar {
    position: relative;
    height: 100px;
    min-width: 100px;
    max-width: 100px;
    margin: 11px 0 0 36px;
    border-radius: 100%;
    overflow: hidden
    align-self:auto;;
}
		}
#room-header-avatar > img {
    position: relative;
    align-self: auto;
    height: 100%;
    left: -25%;
}

		.tes-headerCollapsed:hover #room-header-avatar:hover {
			z-index: 9;
		}
		#room-header-gifts {
			padding: 1% 1%;
		}
		#room-header-avatar:hover {
			border-radius: unset;
		}
		.tes-headerCollapsed #tes-settingsGear {
			font-size: 33px;
             left:-19px;
		}
		.tes-headerCollapsed #tes-settings > div {
		    height: fit-content;
		}
		.tes-headerCollapsed #tes-settingsBox {
			border-width: 1px;
			border-radius: 7px;
			border-top-right-radius: 0;
			padding-bottom: 7px;
		}
		.tes-headerCollapsed #tes-settings {
			top: -10px;
			right: 0;
		}


		/*** ---                                COLORSSSSSSS                                      --- ***/
		/*** ---                                PINKK                                      --- ***/

/*** --- TES BOX  --- ***/
		.tes-pinkmode #tes-settingsBox {
         background: #e76bb6;
         right: 0;
         width: 28em;
         transition: all .4s ease-in-out;
         animation: ease-to-bottom-21px .2s ease 0s 1;
         font-size: 0.9rem;
         flex: none;

		}
/*** --- END TES BOX --- ***/

#room-header.tes-pinkmode {
			background-color:#e76bb6;
border-bottom: 1px solid #e76bb6;
}


.tes-pinkmode #tes-header-grabber {
    border: #ffd1dc 1px solid;
    background-color: #fb2db0;
    box-shadow: 0 0 3px 0.9px white;
}

.tes-pinkmode #room-header-info > h1 {
    color: #ffffff;
    text-transform: uppercase;
    font-family: inherit;
    left: -1rem;
    align-self: auto;

}

.tes-pinkmode #room-header-info {
			padding: 0;
            color: #ffffff;
		}

.tes-pinkmode #room-header-gifts-buttons > a
{
    background-color: #ffd1dc;
    border-color: #ffd1dc;
    color: #ffadc1;
}
.tes-pinkmode #room-header-gifts-buttons > a:hover {
    background-color: #ffd1dc;
    border-color: #ffd1dc;
    color: #111111;
}

.tes-pinkmode #room-header-gifts-buttons > #get-coins {
    background-color: #ffd1dc;
    border-color: #ffd1dc;
    color: #ffadc1;
}
.tes-pinkmode #room-header-gifts-buttons > #get-coins:hover {
    background-color: #ffd1dc;
    border-color: #ffd1dc;
    color: #111111;
}

.tes-pinkmode #room-header-gifts-items > a > img {
    border: 4px solid #ffd1dc;
}

.tes-pinkmode #tes-header-grabber:before {border-color:#ffadc1;
    border-width: 4px 4px 4px 0;
    border-style: solid;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid transparent;}


		#tes-settings-pinkmode .pinkmode-colors {
			width: 0px;
			height: 0px;
		}
		#tes-settings-pinkmode .pinkmode-colors:after {
			content: " ";
			border-radius: 3px;
			height: 11px;
			width: 11px;
			margin-left: 3px;
			top: -9px;
			position: relative;
			display: block;
		}
		#tes-settings-pinkmode .pinkmode-colors:checked:after {
			border: #41a9c1 1px solid;
		}
		#pink .pinkmode-colors:after { background: #e76bb6; }
		#tes-settings-pinkmode .sublabel { margin-left: 15px; }



		/*** ---                                GREENNN                                      --- ***/
/*** --- TES BOX  --- ***/
		.tes-greenmode #tes-settingsBox {
         background: #00500d;
         border: #042500 1px solid;
         right: 0;
         width: 28em;
         transition: all .4s ease-in-out;
         animation: ease-to-bottom-21px .2s ease 0s 1;
         font-size: 0.9rem;
         flex: none;
		}
/*** --- END TES BOX --- ***/

#room-header.tes-greenmode {
			background-color:#00500d;
border-bottom: 1px solid #00500d;
}


.tes-greenmode #tes-header-grabber {
			border: #042500 1px solid;
			background-color:#042500;
}

.tes-greenmode #room-header-info > h1 {
    color:#ffffff;
    text-transform: uppercase;
}

.tes-greenmode #room-header-info {
			padding: 0;
color:#ffffff;
		}

.tes-greenmode #room-header-gifts-buttons > a
{
    background-color: #042500;
    border-color: #042500;
    color: #00570a;
}
.tes-greenmode #room-header-gifts-buttons > a:hover {
    background-color: #042500;
    border-color: #042500;
    color: #111111;
}

.tes-greenmode #room-header-gifts-buttons > #get-coins {
    background-color: #042500;
    border-color: #042500;
    color: #00570a;
}
.tes-greenmode #room-header-gifts-buttons > #get-coins:hover {
    background-color: #042500;
    border-color: #042500;
    color: #111111;
}

.tes-greenmode #room-header-gifts-items > a > img {
    border: 4px solid #042500;
}

.tes-greenmode #tes-header-grabber:before {border-color:#00570a;
    border-width: 4px 4px 4px 0;
    border-style: solid;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid transparent;}

		/*** ---                                BLUEEE                                      --- ***/

/*** --- TES BOX  --- ***/
		.tes-bluemode #tes-settingsBox {
           background: #2a388b;
           border: #fffbfc 1px solid;
           right: 0;
           width: 28em;
           transition: all .4s ease-in-out;
           font-size: 0.9rem;
           flex: none;
           z-index: 9;
           animation: ease-to-left .2s ease 0s 1;
		}
/*** --- END TES BOX --- ***/

#room-header.tes-bluemode {
			background-color:#2a388b;
border-bottom: 1px solid #2a388b;
}


.tes-bluemode #tes-header-grabber {
			border: #111949 1px solid;
			background-color:#111949;
}

.tes-bluemode #room-header-info > h1 {
    color:#ffffff;
    text-transform: uppercase;
}

.tes-bluemode #room-header-info {
			padding: 0;
color:#ffffff;
		}

.tes-bluemode #room-header-gifts-buttons > a
{
    background-color: #111949;
    border-color: #111949;
    color: #2a388b;
}
.tes-bluemode #room-header-gifts-buttons > a:hover {
    background-color: #111949;
    border-color: #111949;
    color: #111111;
}

.tes-bluemode #room-header-gifts-buttons > #get-coins {
    background-color: #111949;
    border-color: #111949;
    color: #2a388b;
}
.tes-bluemode #room-header-gifts-buttons > #get-coins:hover {
    background-color: #111949;
    border-color: #111949;
    color: #111111;
}

.tes-bluemode #room-header-gifts-items > a > img {
    border: 4px solid #111949;
}

.tes-bluemode #tes-header-grabber:before {border-color:#2a388b;
    border-width: 4px 4px 4px 0;
    border-style: solid;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid transparent;}

		/*** ---                                PURPLEEE                                      --- ***/

/*** --- TES BOX  --- ***/
		.tes-purplemode #tes-settingsBox {
          background: #BF8FE5;
          border: #ffadc1 1px solid;
          width: 28em;
          transition: all .4s ease-in-out;
          font-size: 0.9rem;
          flex: none;
          z-index: 9;
          animation: ease-to-left .2s ease 0s 1;
		}
/*** --- END TES BOX --- ***/

 #room-header.tes-purplemode {
			background-color:#BF8FE5;
 border-bottom: 1px solid #BF8FE5;
}


.tes-purplemode #tes-header-grabber {
			border: #9168b2 1px solid;
			background-color:#9168b2;
}

.tes-purplemode #room-header-info > h1 {
    color:#fff;
    text-transform: uppercase;
}

.tes-purplemode #room-header-info {
			padding: 0;
            color: #000;
		}

.tes-purplemode #room-header-gifts-buttons > a
{
    background-color: #9168b2;
    border-color: #9168b2;
    color: #BF8FE5;
}
.tes-purplemode #room-header-gifts-buttons > a:hover {
    background-color: #9168b2;
    border-color: #9168b2;
    color: #111111;
}

.tes-purplemode #room-header-gifts-buttons > #get-coins {
    background-color: #9168b2;
    border-color: #9168b2;
    color: #BF8FE5;
}
.tes-purplemode #room-header-gifts-buttons > #get-coins:hover {
    background-color: #9168b2;
    border-color: #9168b2;
    color: #111111;
}

.tes-purplemode #room-header-gifts-items > a > img {
    border: 4px solid #9168b2;
}

.tes-purplemode #tes-header-grabber:before {border-color:#BF8FE5;
    border-width: 4px 4px 4px 0;
    border-style: solid;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid transparent;}

	</style>
	`;
	titleCSS.insertAdjacentHTML(insertPosition, titleCSShtml);
	}

	if (cssName == "videolistCSS" || cssName == null) {
	videolistCSShtml = `
	<style id="videolistCSS" scope="tinychat-videolist">
#videolist.tes-sidemenuCollapsed { width: 100%; }
#videos-footer {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    height: 0px;
    min-height: 0px;
    width: 1px;
    position: fixed;
    bottom: 0;
    left: 10px !important;
    padding: 0 30px 0px;
    box-sizing: border-box;
    font-size: 0;
    z-index: 3;
    left: auto;
			background-color:#111111;
}

#videos-footer.tes-sidemenuCollapsed{    position: relative;
    bottom: 0;
    right: 50px;
}
.tes-sidemenuCollapsed#videos-footer{    position: relative;
    bottom: 0;
    right: 50px;
}

.video:after {
    content: '';
    position: absolute;
    display: block;
    height: 0%;
    width:  0%;
    top: 0;
    left: 0;
    border: 0px solid #111;
    border-radius: 10px;
    box-sizing: border-box;
    pointer-events: none;
}
#video::after
{

    border: 5px solid #111;

}
#video:after
{

    border: 5px solid #111;

}

#videos > .video {
    position: relative;
    width: 20%;
    padding: 5px;
    box-sizing: border-box;
    font-size: 0;
    overflow: hidden;
    background-color: #ffffff !important;

}
.video > div > iframe {
  width:100%;


}


		#videos-header {
			height: 0px;
			min-height: 0px;
			background-color:#111111;
		}
	#videos-content {
    background-color: #111111;
    position: relative;
    height: 100%;
    width: 114%;
    left: -10%;
    align-self: auto;
}
#videos {
    position: absolute;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    top: 6%;
    right: 5%;
    bottom: 6%;
    width: 90%;
    left: 25px;
    box-sizing: border-box;
    font-size: 0;
}
#videos-footer-youtube:hover {
    background-color: #e04e5e;
}
#videos-footer-youtube {
    background-color: #e04f5f;
    background-image: url(https://png.icons8.com/flat_round/40/000000/youtube-play.png);
    background-repeat: no-repeat;
    background-position: 6px;
    background-size: 70%;
    background-repeat: no-repeat;
    position: relative;
    left: -27px;
    top: 99px;
    transform: matrix3d(1,0,1,0,0,1,0,0,0,0,1,0,-4,0,0,1);
    }
#videos-footer-youtube > svg, #videos-footer-soundcloud > svg {
    vertical-align: ;
    display:none;
    }



#videos-footer-broadcast-wrapper.show-ptt > #videos-footer-push-to-talk {
    width: 60px;
    min-width: 60px;
    margin-left: 14px;
    opacity: 1;
    overflow: visible;
    background-color:#33393b;
   }


#videos-footer-push-to-talk > svg {
    vertical-align: left;
    pointer-events: none;
    display:none;




}
#videos-footer-youtube, #videos-footer-soundcloud {
    height: 40px;
    width: -92px !important;
    min-width: 40px !important;
    margin-right: -7px !important;
    margin-top: -250px;
    border-radius: 40px;
    text-align: center;
    line-height: 54px;
    cursor: pointer;
    overflow: hidden;
    transition: .2s;
    box-shadow: 0 0 10px 3px #df4e5e;
}



.tes-sidemenuCollapsed #videos-footer {
right:0px;



}


#videos-footer-push-to-talk {
    height: 60px;
    border-radius: 60px;
    width: 80px;
    min-width: 70px;
    margin-top: -145px;
    background-image: url(https://png.icons8.com/ios/100/000000/microphone-filled.png);
    background-position: 5px;
    background-size: 83%;
    background-repeat: no-repeat;
    display: block;
    background-color: #33393b;
    background-blend-mode: soft-light;
    text-shadow: 0 0 5px white;
    box-shadow: 0 0 3px 2px white;
    transition: .5s;
    transform: matrix3d(1,0,5.1,0,0,1,0,0,0,0,1,0,124,69,0,2);


}
#videos-footer-broadcast-wrapper.active-ptt > #videos-footer-push-to-talk {
    background-color: #2d373a;
    background-size: 94%;
    background-position: 2px;
    background-image: url(https://png.icons8.com/ios/100/000000/microphone-filled.png);
    box-shadow: 0 0px 10px 4px #eee;
    transform:matrix3d(1,0,1,0,0,1,0,0,0,0,1,0,60,39,0,1);
    overflow: hidden;
}


#videos-footer-push-to-talk.tes-sidemenuCollapsed {
    height: 100px;
    margin-top: -20px;


}
#videos-footer-broadcast-wrapper.tes-sidemenuCollapsed {
    position: relative;
    right: 0px;

}
#videos-footer-broadcast-wrapper {
    position: relative;
    right: 122px;
    margin-top: -104px;
    display: unset;
    flex-direction: row;
    align-items: flex;
    width: unset;
    padding-left: 0px !important;
}
#videos-footer-broadcast-wrapper > #videos-footer-submenu-button {
    height: 43px;
    padding-left: 0px;
    background-color: #13a832;
    position: relative;
    top: -75px;
    left: 24px;
    display: block;
    width: 40px;
    min-width: 20px;
    border-radius: 30px;
    box-sizing: border-round;
    cursor: pointer;
    transition: .2s;
    box-shadow: 0 0 13px 1px #ffff;
    transform: matrix3d(1,0,5.1,0,0,1,0,0,0,0,1,0,0,-3,0,1);

}
#videos-footer-submenu {
    position: absolute;
    width: 130px;
    bottom: 120px;
    left: 25x;
    right: -62px;
    padding: 2px;
    border-radius:0px;
    background-color: #fff;
    font-size: 150px;
    color: #000;
    box-shadow: 0 1px 4px 0 #00000017;
    opacity: 0;
    box-shadow: 0 0 4px 2px #eee;
    visibility: hidden;
    z-index: 1;
    transition: .2s;
}
#videos-footer-broadcast-wrapper.show-ptt > #videos-footer-submenu {
    right: -62px;
}

#videos-footer-submenu:before, #videos-footer-submenu:after {
    content: '';
    position: absolute;
    display: block;
    height: 300;
    width: 50;
    right: unset;
    bottom: unset;
    border-width: 17px 17px  17px;
    border-style: solid;
    border-color: #0000000f transparent;
}
#videos-footer-broadcast-wrapper > #videos-footer-submenu-button:before {
    content: '';
    position: absolute;
    display: block;
    height: 245;
    width: 90;
    top: 9px;
    right: 2px;
    border-width:0px 18px 26px;
    border-style: solid;
    border-color: #fff transparent;
    border-image:url(http://www.iconarchive.com/download/i45239/iconleak/stainless/preferences.ico);
    opacity: 1;
    /* border-image-width: auto; */
    border-image-repeat: inherit;
    visibility: visible;
    transition: .2s;
}
#videos-footer-broadcast {
    grid-auto-columns: auto;
    position: relative;
    display: block;
    padding-inline-start: 20px;
    padding-inline-end: 0px;
    right: -19px;
    top: 38px;
    height: 83px;
    min-width: 90px;
    max-width: 30%;
    padding-left: 0px;
    border-radius: 50px;
    box-sizing: unset;
    background-color: #13a832;
    color: #fff;
    background-image:url(https://png.icons8.com/ios/40/000000/camcorder-pro.png);
    background-repeat: no-repeat;
    background-blend-mode: color-burn;
    background-position: 16px;
    background-size: 70%;
    cursor: pointer;
    font-size:0px;
    transition: .2s;
    transform: matrix3d(1,0,1.1,0,0,1,0,0,1,0,1,0,-42,0,0,2);
    box-shadow: 0 0 7px 2px white;
}

#videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button {
z-index: 1;
box-shadow: 0 0 5px 1px white;
}
#videos-footer-broadcast-wrapper > .waiting {
    position: absolute;
    width: 90px;
    height: 30px;
    top: 70px;
    bottom: 0;
    left: 75px;
    right: 0;
    border-radius: 11px;
    background-color: #38cd57;
    opacity: 0;
    visibility: hidden;
    transition: .2s;
}
#videos-footer-youtube.hidden, #videos-footer-soundcloud.hidden {
    width: 0;
    min-width: 0;
    margin-right: 0;
    visibility: hidden;
}

}
		#Fvideolist * {
			width: 75%!important;
			display: contents;
			float: right;
			flex-direction: column;
		}
		#Fvideos {
			flex-direction: unset;
			flex-wrap: unset;
		}
		#videos-header > span {
        position: relative;
        align-self: auto;
        top: -9.4rem;
        right: -19.2rem;
        height: 0px;
        width: 2.1rem;
        color: #0000000f;
		}
		#videos-header > span > svg {
			height: 16px;
			padding: 0;
		}
.videos-header-volume {
    position: absolute;
    height: 128px;
    width: 24px;
    top: 2px;
    left: 50%;
    margin-left: -14px;
    margin-top: -7px;
    border-width: 50px 22px 22px;
    border-style: solid;
border-color: rgba(0, 0, 0, 0.55);
    border-radius: 5px;
    box-shadow: 10px 1px 4px 0 rgba(0, 0, 0, .09);
    opacity: 0;
    visibility: hidden;
    transition: .2s;
}
.videos-header-volume-level > div {
    position: absolute;
    display: block;
    height: 12px;
    width: 24px;
    top: 0px;
    left: 0px;
    border-radius: 0;
background-color:#5fc2f0b3;
}
.videos-header-volume:before {
    background-color: #111;
}



		/*** ---                                PINKKK                                      --- ***/



		.tes-pinkmode #videos-header {
			height: 0px;
			min-height: 0px;
			background-color: #e76bb6;

		}
		.tes-pinkmode #videos-content {
			background-color:#ef54b2;
		}


.tes-pinkmode #videos-footer-broadcast-wrapper.active > #videos-footer-broadcast, .tes-pinkmode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button, .tes-pinkmode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button:focus {			background-color:#ef54b2;}


		/*** ---                                GREENNN                                      --- ***/



		.tes-greenmode #videos-header {
			height: 10px;
			min-height: 10px;
			background-color:#042500;
		}
		.tes-greenmode #videos-content {
			background-color:#042500;
		}

.tes-greenmode #videos-footer-broadcast-wrapper.active > #videos-footer-broadcast {			background-color:#042500;border:1px solid #00570a;}

.tes-greenmode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button, .tes-greenmode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button:focus {			background-color:#042500;border:0px solid #042500;}

		/*** ---                                BLUEEE                                      --- ***/



		.tes-bluemode #videos-header {
			height: 10px;
			min-height: 10px;
			background-color:#111949;
		}
		.tes-bluemode #videos-content {
			background-color:#111949;
		}

.tes-bluemode #videos-footer-broadcast-wrapper.active > #videos-footer-broadcast {			background-color:#111949;border:1px solid #2a388b;}

.tes-bluemode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button, .tes-bluemode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button:focus {			background-color:#111949;border:0px solid #111949;}

		/*** ---                                PURPLEEE                                      --- ***/



		.tes-purplemode #videos-header {
			height: 10px;
			min-height: 10px;
			background-color:#9168b2;
		}
		.tes-purplemode #videos-content {
			background-color:#9168b2;
		}

.tes-purplemode #videos-footer-broadcast-wrapper.active > #videos-footer-broadcast {			background-color:#9168b2;border:1px solid #BF8FE5;}

.tes-purplemode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button, .tes-purplemode #videos-footer-broadcast-wrapper.active > #videos-footer-submenu-button:focus {			background-color:#9168b2;border:0px solid #9168b2;}
</style>
	`;
	videolistCSS.insertAdjacentHTML(insertPosition, videolistCSShtml);
	}

	if (cssName == "chatlistCSS" || cssName == null) {
	chatlistCSShtml = `
	<style id="chatlistCSS" scope="tinychat-chatlist">


		#chatlist > div > span {
			padding-left: 10px;
            color:#ffffff;
		}
		#chatlist > #header {
			top: 3px;
			height: auto;
		}

		/*** --- this block is in chatlistCSS & userlistCSS --- ***/
			.list-item > span > img {
				right: 32px;
				left: auto;
			}
.list-item > span > span > .send-gift {
    position: absolute;
    display: inline-block;
    height: 70%;
    width: 70%;
    top: 14%;
    right: 4%;
    padding: 0;
    background-image: url(…EzM1YxNEguOTMzeiIgZmlsbD0iIzA0Y2FmZiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9zdmc+);
    background-repeat: no-repeat;
    opacity: 0;
    visibility: hidden;
    cursor: pointer;
    transition: .2s;
}

			.list-item > span[data-status]:before {
				left: auto;
				right: 36px;
			}
			.list-item > span > span {
				background: none!important;
				box-shadow: none!important;
			}
		/*** ---                                        --- ***/

		.close-instant > path {
			fill: white;
		}
		.list-item > span > span { /* gift and close buttons */
			right: 16px;
		}
		.list-item > span:hover > span { /* gift and close buttons */
			right: 16px;
			background: none!important;
		}

	</style>
	`;
	chatlistCSS.insertAdjacentHTML(insertPosition, chatlistCSShtml);
	}

	if (cssName == "userlistCSS" || cssName == null) {
	userlistCSShtml = `
	<style id="userlistCSS" scope="tinychat-userlist">
#userlist > div > span {
    padding-left: 0%;
    padding-right: 40%;
    position: relative;
    display: inline-block;
    height: 72%;
    width: 100%;
    border-radius: 0 0 0 0;
    box-sizing: border-box;
    font-size: 0.7rem;
    color: #ffffff;
    line-height: 100%;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    transition: .2s;
    text-shadow: 0 0 2px white;
    font-family: sans-serif;
}
.tes-sidemenuCollapsed #button-banlist {
			left: -100px;
			width: 10px;
            right: 94px;
		}
#chatlist > div > span {
    position: relative;
    display: inline-block;
    height: 30px;
    width: 100%;
    padding-left: 36px;
    border-radius: 0 0px 0px 0;
    box-sizing: border-box;
    font-size: 14px;
    color: #ffffff;
    line-height: 30px;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    transition: .2s;
}

.list-item > span > span {
	right: auto;
	padding: 0 5px;
}
.list-item > span > .nickname {
	padding-right: 3px;
}

		/*** --- this block is in chatlistCSS & userlistCSS --- ***/
.list-item > span > img {
	right: 14px;
	left: auto;
}
.list-item > span > img {
    position: sticky;
    display: inline-block;
    height: 48%;
    top: 2%;
    opacity: 1;
    visibility: visible;
    transition: .2s;
}

.list-item > span[data-status]:before {
    top: 1%;
    border-radius: 60%;
    position: inherit;
}
.list-item > span > span {
	background: none;
	box-shadow: none;
}
		/*** ---                                        --- ***/

.list-item > span > span[data-moderator="1"]:before {
	filter: hue-rotate(226deg) saturate(4000%);
}
#userlist > #header {
	top: auto;
	height: auto;
}
#userlist > #header > span {
    display: block;
    border-color: transparent;
    background-color: #ffffff00;
    text-align: center;
    height: 4rem;
    width: 100%;
    top: 1em;
    text-shadow: 0 0 3px white;
    left:0rem;
}
#chatlist > #header {
    color: #111111;
}
#button-banlist {
    display: block;
    top: 1rem;
    width: 1em;
    align-self: auto;
    right:9.5rem;
    padding: 7px 22px;
    font-size: 1.2rem;
    font-weight: 150;
    color: #04caff;
    background-color: #3dff0000;
    background-size: 100%;
    text-shadow: 0 0 3px #04caff;
    text-transform: uppercase;
    cursor: pointer;
    overflow: visible;
    opacity: 1;
    transition: .2s;
}
#button-banlist:hover {
    color: #fff;
    background-color: #04caff00;
}

.list-item > span[data-status]:before {
    left: auto;
    right: 0;
border-radius:10px;
}

		/*** ---                                COLORSSSSSSS                                      --- ***/
		/*** ---                                PINKKK                                      --- ***/


#userlist.tes-pinkmode  > div > span:hover{
    display: block;
    border-color: black;
    background-color: #e76bb6;
    color:#ffffff;
    font-weight:bold;
}

.tes-pinkmode .list-item > span > span {
    background: none;
    box-shadow: none;
}

.tes-pinkmode .list-item > span:hover > span {
    background: none;
    box-shadow: none;
}


.list-item.tes-pinkmode > span > span > .send-gift:hover{
    background-color: #ffd1dc;
    font-weight:bold;}

#userlist.tes-pinkmode > #header > span {
    display: block;
    align-self: auto;
    border-color#ffffff: ;
    background-color:#ef54b2;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    top: 1.01rem;
}

#chatlist.tes-pinkmode > #header > span {
    color: #000 !important;
}

		/*** ---                                GREENNN                                      --- ***/


#userlist.tes-greenmode  > div > span{
    color:#ffffff;
}

#userlist.tes-greenmode  > div > span:hover{
    display: block;
    border-color: black;
    background-color: #042500;
    color:#ffffff;
    font-weight:bold;
}

.tes-greenmode .list-item > span > span {
    background: none;
    box-shadow: none;
}

.tes-greenmode .list-item > span:hover > span {
    background: none;
    box-shadow: none;
}


.list-item.tes-greenmode > span > span > .send-gift:hover{
    background-color: #042500;
    font-weight:bold;}

#userlist.tes-greenmode > #header > span {
    display: block;
    border-color: black;
    background-color:#00500d;
    color:#fff;
    font-weight:bold;
    text-align: center;
    top: 1.01rem;
    align-self: auto;
}

#chatlist.tes-greenmode > #header > span {
    color: #000 !important;
}

		/*** ---                                BLUEEE                                      --- ***/


#userlist.tes-bluemode  > div > span:hover{
    display: block;
    border-color: black;
    background-color: #111949;
    color:#ffffff;
    font-weight:bold;
}

.tes-bluemode .list-item > span > span {
    background: none;
    box-shadow: none;
}

.tes-bluemode .list-item > span:hover > span {
    background: none;
    box-shadow: none;
}


.list-item.tes-bluemode > span > span > .send-gift:hover{
    background-color: #111949;
    font-weight:bold;}

#userlist.tes-bluemode > #header > span {
    display: block;
    border-color: black;
    background-color: #2a388b;
    color: #fff;
    font-weight: bold;
    text-align: center;
    top: 1.01rem;
    align-self: auto;
}

#chatlist.tes-bluemode > #header > span {
    color: #000 !important;
}

		/*** ---                                PURPLEEE                                      --- ***/


#userlist.tes-purplemode  > div > span {
    color:#ffffff;
font-weight:bold;
}

.tes-purplemode #chatlist > div > span {
    color:#ffffff;
font-weight:bold;
}

#userlist.tes-purplemode  > div > span:hover{
    display: block;
    border-color: black;
    background-color: #9168b2;
    color:#ffffff;
    font-weight:bold;
}

.tes-purplemode .list-item > span > span {
    background: none;
    box-shadow: none;
}

.tes-purplemode .list-item > span:hover > span {
    background: none;
    box-shadow: none;
}


.list-item.tes-purplemode > span > span > .send-gift:hover{
    background-color: #9168b2;
    font-weight:bold;}

#userlist.tes-purplemode > #header > span {
    display: block;
    border-color: black;
    background-color: #bf8fe5;
    color: #fff;
    font-weight: bold;
    text-align: center;
    top: 1.01rem;
    align-self: auto;
}

#chatlist.tes-purplemode > #header > span {
    color: #000 !important;
}



	</style>
	`;
	userlistCSS.insertAdjacentHTML(insertPosition, userlistCSShtml);
	}

	if (cssName == "userContextmenuCSS" || cssName == null) {
	userContextmenuCSShtml = `
	<style id="userContextmenuCSS" scope="tinychat-user-contextmenu">
		#main {
			border: 1px solid rgba(0, 0, 0, .1);
		}
	</style>
	`;
	userContextmenuCSS.insertAdjacentHTML(insertPosition, userContextmenuCSShtml);
	}

	if (cssName == "bodyCSS" || cssName == null) {
	bodyCSShtml = `
	<style id="bodyCSS">

		/*** ---                                COLORSSSSSSS                                      --- ***/
		/*** ---                                PINKKK                                      --- ***/

body.tes-pinkmode{overflow: hidden;background-color:#ef54b2;}
		/*** ---                                GREENNN                                      --- ***/
body.tes-greenmode{overflow: hidden;background-color:#042500;}
		/*** ---                                BLUEEE                                      --- ***/
body.tes-bluemode{overflow: hidden;background-color:#111949;}
		/*** ---                                PURPLEEE                                      --- ***/
body.tes-purplemode{overflow: hidden;background-color:#9168b2;}



body{overflow: hidden;background-color:#111111;}
		#nav-static-wrapper {
			width: 2px;
			opacity: .7;
display:none;
visibility:hidden;
		}

		#nav-static-wrapper {
			width: 2px;
			opacity: .7;
display:none;
visibility:hidden;
		}

		#nav-static-wrapper.tes-sidemenuCollapsed{
display:none;
visibility:hidden;
		}
		@media screen and (max-width: 1000px) {
			#nav-static-wrapper {
				width: 82px;
				opacity: 1;
			}
		}

	    #menu-icon { transition: 1s; display:none;}
		.tes-sidemenuCollapsed #menu-icon {
			z-index: -1;
			opacity: 0;
display:none;
		}
		.tes-sidemenuCollapsed #header-user { display: none; }
		@media screen and (max-width: 1000px) {
			#header-user {
				left: 21px;
			}

#videos-footer-youtube.tes-sidemenuCollapsed{
		   padding: 0px;
left:100px;
background-color:#f07629;
	   }
		body.tes-changefont {
		  font-family: sans-serif;
		}
		#header-user {
			left: 62px;
		}
		@media screen and (max-width: 1000px) {
			#header-user {
				left: 20px;
			}
		}
		@media screen and (max-width: 700px) {
			#header-user {
				left: auto;
				right: 54px;
			}
		}
		@media screen and (min-width: 1000px) {
			#menu-icon:hover { opacity: 1; }
			#menu-icon {
				top: 4px;
				left: 19px;
				height: 12px;
				width: 109px;
				font-size: 10px;
				background: #04caff;
				border-radius: 6px;
				opacity: .8;
				visibility: hidden;
display:none;
			}
			#menu-icon:after {
				position: absolute;
				top: 3px;
				left: 51px;
				content: "";
				height: 7px;
				width: 7px;
				border-width: 2px 2px 0px 0px;
				border-style: solid;
				border-color: #fff;
				box-sizing: border-box;
				transform: rotate(45deg);
				transition: .2s;
				visibility: hidden;
			}
			#menu-icon:hover:after {
				border-width: 0px 0px 2px 2px;
				visibility: hidden;
			}
			#menu-icon > svg {
				opacity: 0;
				visibility: hidden;
			}
		}
#menu-icon {
				visibility: hidden;
display:none;}



	</style>
	`;
	bodyCSS.insertAdjacentHTML(insertPosition, bodyCSShtml);
	}

	messageCSS = `
body.tes-pinkmode{overflow: hidden;background-color:#F33AA6 !important;}
.message.system {
    font-size: 0.8rem;
    font-weight: 600;
    color: white;
    left: 0px;
    text-shadow:0 0 2px #00c4ff;
    align-self: auto;


}
.o
		.tes-mention-message { color: red; }
.on-black-scroll {
    padding-left: 16px;
    box-sizing: border-box;
    overflow-x: hidden;
    overflow-y: hidden;
}

.message {
    font-size: 15px;
    color: #eee;
    white-space: pre-line;
    word-wrap: break-word;
    position: relative;
    right: 0px;
    top:1px;

}
`;


	if (cssName == "chatlogCSS" || cssName == null) {
	chatlogCSShtml = `
	<style id="chatlogCSS" scope="tinychat-chatlog">

/* HERE IS THE OTHER GRABBER */
		#tes-chat-grabber {
		    position: absolute;
			top: 88px;
			right: 50%;tinychat-chatlog *
			background: white;
			width: 100px;
			height: 20px;
			border: #313131 1px solid;
			border-radius: 19px;
			text-align: center;
			color: #b4c1c5;
			cursor: pointer;
			transition: all .3s ease-in-out;
            background-color:a#3131317;
		}
		.tes-chatCollapsed #tes-chat-grabber {
			top: 0px;
			background: #111111;
			border-top: 0;
			z-index: 9;
			border-radius: 11px;
			line-height: 15px;
			border-top-left-radius: 0;
			border-top-right-radius: 0;
			height: 15px;
		}
		.tes-chatCollapsed:hover #tes-chat-grabber {
			height: 29px;
			line-height: 43px;
		}
		:host, #chat-wrapper.tes-chatCollapsed {

		}
/* END */
#chat-instant > a > .avatar, #chat-content > .message > a > .avatar {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-height: none;
    max-width: 100%;
    align-self: auto;
}
#chat-instant {
    position: relative;
    height: 0;
    min-height: 0;
    width: 100%;
    padding-left: 106px;
    box-sizing: border-box;
    background-color:#10101000;
    overflow: hidden;
}


#chat-instant > .nickname {
    white-space: nowrap;
    font-size: 1rem;
    font-weight: 700;
    color:#53b6ef;
    line-height: 44px;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: default;
    text-shadow: 0 0 1px white;
}

#chat-instant > a > .status-icon, #chat-content > .message > a > .status-icon {
    position: relative;
    height: 0;
    min-height: 0;
    width: 100%;
    font-size: 1rem;
    padding-left: 110px;
    box-sizing: border-box;
    background-color: #111111;
    overflow: hidden;
}

#chat-content > .message.system > .content {
    font-size: 12px;
    font-weight: 600;
    color: #00ff00;
margin:10px;

}

#chat-wrapper {

			border-left: 0px solid rgba(0, 0, 0, .1);
			box-sizing: border-box;
			background-color: #111111;
			transition: .2s;
}
#chat-content > .message {
			padding-bottom: 0;
			padding-top: 0!important;
    margin-bottom: 5px;
			min-height: 0px!important;
			color: #ff0000 !important;
		}
		/*
#chat-content > .message:hover {
			background: #00000008;
			color: #ffffff;
		}
		*/
#chat-content > .message.common {
    margin-bottom: 3px;
    margin-right: 20px;
    padding-bottom: 9px;
    color: #ffffff00 !important;
    background-color: #ffffff00;
    border: 0px solid;
    border-radius: 0px;
}
#chat-content > .message.system {
    box-sizing: border-box;
    background-color: #ffffff00;
    cursor: default;
    border: 1px solid #ffffff00;
    color: #ffffff00;
    border-radius:0px;
    padding: 0px 0px;
}
		}
#chat-content.tes-notif-off > .message.system {
			display: none;
		}
#chat-content.tes-notif-off > .message.system.dontHide {
			display: initial;
		}
		#chat-instant > a:first-child,
		#chat-content > .message > a:first-child {
			top: auto;
        background-color: #fff0;
		 }
		#chat-position #input:before {
			background: none;
		}
#input {
    position: relative;
    display: block;
    padding-top: 10px;
    margin-right: 35px;
    overflow-wrap: break-word;
}
#input > textarea{
overflow-y:auto;
background-color:#333333bd;
border:2px solid ##111111;
color:#ffffff;
}
#input #input-unread.show {
    right: 0;
    opacity: 0;
}
    #input-unread {
    position: absolute;
    display: inline-block;
    height: 3rem;
    top: -11%;
    width: 15rem;
    left: 7px;
    border-radius: 0px;
    font-size: 12px;
    line-height: 24px;
    white-space: nowrap;
    opacity: 0;
    cursor: pointer;
    transition: .2s;
}
#input:after {
    content: "";
    position: absolute;
    display: block;
    top: 10px;
    left: 0;
    right: 0;
    bottom: 0;
    border: 0px solid #cbcfcf;
    border-radius: 0px;
    box-sizing: border-box;
    pointer-events: none;
}
#input > .waiting {
    position: absolute;
    width: auto;
    top: 10px;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 0px;
    background-color: #e9eaea;
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    transition: .2s;
}
#chat-position {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    top: 50px;
    left: -47px;
    right: 50px;
    bottom: 30px;
    width: 90%;
    padding: 0 0 0 80px;

}


#chat-wider {
    font-size: 0;
    background-color: #313131;
    border: 1px solid #eee;
    border-radius: 0px;
    height:9px;
     top:42px;
    cursor: pointer;

wrapper    z-index: 1;
     padding-top: 20px;
width:20px;
color: #3b3b3b;
    position: absolute;
    top: 8%;
    left:10px;
}
#chat-wider.active + #chat-wrapper {
    min-width: 20px;
    width;16px
    height:14px;
    padding-top: 10px;;
}
#chat-wider.active {
    border-radius: 0px 0 0 0px;
       width: 16px;
    height: 10px;
    padding-top: 13px;
    top: 66px;
    left: 2px;

}

#chat-wider:before {
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
}

#chat-wider.active:before {
    transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
}
		#chat-wider:hover {
			background: #333;
			color: #5c5c5c;
			cursor: pointer;'
             border:0px;
		}

	#chat-instant > a > .avatar,
	#chat-content > .message > a > .avatar {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-height: none;
    max-width: 100%;
    align-self: auto;
    overflow: hidden;
		}
#abovefiller
{			border-radius: unset;}
#timestamp {
    font-size: 0.6rem;
    color: #ffffff;
    float: right;
    position: absolute;
    right: -20px;
    top: -8px;
    padding-right: 21px;
    font-weight: 1000;
    text-shadow: 0 0 1px #00c4ff;
}
#chat-content > .message > .nickname {
    overflow: initial;
    line-height: initial;
    position: relative;
    align-self: auto;
    right: 4px;
    top: -2px;
    font-size: 0.9rem;
    color:#00c4ff;
    text-shadow:0 0 2px #00c4ff;

}
		#chat-content div.message.common:last-of-type {
			margin-bottom: 10px;
			margin-right: 20px;
		}

		#chat-instant-button.tes-loading {
			border: 0;
			font-size: x-large;
			animation: spin .5s linear infinite;
		}
		@keyframes spin {
			0% { transform: rotate(0deg); }
			100% { transform: rotate(360deg); }
		}
		#tes-chatlogDisplay {
			display: none;
			position: fixed;
            top: 97px;
			left: 100px;
			width: 100%;
			height: 80%;
			z-index: 7;
			cursor: default;
		}
		#tes-chatlogDisplay.show { display: unset; }
		#tes-chatlogDisplay * {
			float: left;
			height: 100%;
		}
		#tes-chatlogDisplay textarea {
			transition: .2s;
			opacity: 0;
			border-radius: 0px;
			width: 90%;
		}
		#tes-chatlogDisplay textarea.show {
			opacity: .8;
		}
		#tes-chatlogDisplay textarea.show {
			background-color:#111111;
color:#fff;

		}
		#tes-chatlogDisplay #close {
			opacity: 0;
			transition: .2s;
			width: 40px;
			background: #41b7ef;
			height: 40px;
			border-top-right-radius:0px;
			border-bottom-right-radius: 0px;
			position: relative;
			color: white;
			top: 40%;
			vertical-align: middle;
			font-size: 22px;
			text-align: center;
			padding-top: 8px;
			cursor: pointer;
		}
		#tes-chatlogDisplay #close:hover {
			background: #72caf3;
		}
		#tes-chatlogDisplay #close.show {
			opacity: 1;
		}
		#tes-chatlogButtons {
			position: absolute;
			top: 2px;
			left: 6px;
			font: 0.9rem monospace;
		}
		.tes-chatlogBut {
			padding: 2px;
			border-radius: 4px;
			border: silver 1px solid;
			color: silver;
			transition: .3s;
            width: 2rem;
            height: 1.5rem;
            overflow: hidden;
            cursor: pointer;
            opacity: 1;
            float: left;
            box-shadow: 0 0 2.1px 1px white;
		}

		}
		.tes-chatlogBut ~ .tes-chatlogBut { margin-left: 2px; }
		.tes-chatlogBut .icon { width: auto; }
		.tes-chatlogBut .label {
			width: 0;
			opacity: 0;
			overflow: hidden;
			transition: .3s;
			display: block;
			position: relative;
			top: -2px;
			left: 28px;
			font: 11px sans-serif;
			color: white;
		}
		.tes-chatlogBut:hover .label {
			opacity: 1;
            width: 8rem;
            color:white;

		}
		.tes-chatboxPM #tes-chatlogSave {
			opacity: 0;
			z-index: -5;
		}
		#tes-chatlogSave .icon {
			/* transform: scaleY(.6); */
			position: absolute;
			top: -1px;
			left: 4px;
            font-size: 1.3rem;
		}
		#tes-chatlogSave .icon svg {
			width: 19px;
			height: 19px;
			position: relative;
			left: -3px;
		}
		#tes-chatlogSave .icon path {
			transform: scale(.08) scaleX(1.2) rotate(180deg);
			10%: 10px
			height:;
			fill: #ccc;
			transform-origin: 11px 12px;
		}
		#tes-chatlogSave:hover .icon path { fill: lightblue; }
		#tes-chatlogSave:hover { width: 6.3em; }
		#tes-chatlogSave:hover .label { width: 4.3em; }
		#tes-chatlogView .icon {
			font-size: 1.4em;
			top: 0px;
			position: absolute;
		}
		#tes-chatlogView:hover { width: 6.5rem; color:white;}


		/*** ---                                COLORSSSSSSS                                      --- ***/
		/*** ---                                PINKKK                                      --- ***/

.tes-pinkmode #input > textarea{
overflow-y:auto;
background-color:#ffadc1;
border:1px solid #ffadc1;
color:#ffffff;
}

.tes-pinkmode #chat-wider:before {
			background-color: #ffadc1;
			border-color: #ffadc1 !important;
color:#00ff00;
}


#chat-wrapper.tes-pinkmode  {
			background-color:#ef54b2;
}


.tes-pinkmode #chat-content > .message.common {
    border-color: #ef54b2;
    background-color: #ef54b2;
}

.tes-pinkmode.message {color:#000000;}

    #chat-wider.tes-pinkmode  {
    border: 1px solid #fdfdfd;
    background-color: #fb2db0;
    color: #ffffff;
    box-shadow: 0 0 2px 1px white;
}
		/*** ---                                GREENNN                                      --- ***/

.tes-greenmode #input > textarea{
overflow-y:auto;
background-color:#00570a;
border:1px solid #00570a;
color:#000000;
}

.tes-greenmode #chat-wider:before {
			background-color: #00570a;
			border-color: #00570a !important;
color:#00ff00;
}


#chat-wrapper.tes-greenmode  {
			background-color: #042500;
}


.tes-greenmode #chat-content > .message.common {
    border-color: #042500;
    background-color: #042500;
}

.tes-greenmode.message {color:#000000;}

#chat-wider.tes-greenmode  {
    border: 1px solid #00570a;
background-color:#042500;
color: #042500;
}

		/*** ---                                BLUEEE                                      --- ***/

.tes-bluemode #input > textarea{
overflow-y:auto;
background-color:#2a388b;
border:1px solid #2a388b;
color:#000000;
}

.tes-bluemode #chat-wider:before {
			background-color: #2a388b;
			border-color: #2a388b !important;
color:#00ff00;
}


#chat-wrapper.tes-bluemode  {
			background-color: #111949;
}


.tes-bluemode #chat-content > .message.common {

    border-color: #111949;
    background-color: #111949;
}

.tes-bluemode.message {color:#000000;}

#chat-wider.tes-bluemode  {
    border: 1px solid #2a388b;
background-color:#111949;
color: #111949;
}

		/*** ---                                PURPLEEE                                      --- ***/

.tes-purplemode #input > textarea{
overflow-y:auto;
background-color:#BF8FE5;
border:1px solid #BF8FE5;
color:#000000;
}

.tes-purplemode #chat-wider:before {
			background-color: #BF8FE5;
			border-color: #BF8FE5 !important;
color:#00ff00;
}


#chat-wrapper.tes-purplemode  {
			background-color: #9168b2;
}


.tes-purplemode #chat-content > .message.common {
    border-color: #9168b2;
    background-color: #9168b2;
}

.tes-purplemode.message {color:#000000;}

#chat-wider.tes-purplemode  {
    border: 1px solid #BF8FE5;
background-color:#9168b2;
color: #9168b2;
}



	</style>
	`;
	chatlogCSS.insertAdjacentHTML(insertPosition, chatlogCSShtml);
	}

	if (cssName == "sidemenuCSS" || cssName == null) {
	sidemenuCSShtml = `
	<style id="sidemenuCSS" scope="tinychat-sidemenu">
		#sidemenu {
        position: fixed;
        min-width: 188px;
        max-width: 170px;
        left: 0rem;
        background-color: #191919;
        background-position: right top;
        background-size: 0%;
        border-right: 1px solid #31313100;
        z-index: 3;
        align-self: auto;

			}



#sidemenu-content {
    		height: 86%;
    		padding-top: 3px;
    		box-sizing: border-box;
			padding-left: 0px;
			overflow-x: hidden;
			overflow-y: auto;
			background-color:#0000000f;
			border-right:0px solid;
            text-shadow: 0 0 2px #ffffff;
}


#user-info {
			position: absolute;
			height: 40px;
			width: 70%;
			bottom: 0;
			left: 0;
			padding: 20px 30px 20px 20px;
			border-top: 1px solid rgba(0, 0, 0, .1);
			box-sizing: border-box;
			background-color: #2a2a2a;
display: none; visibility:hidden;

			}
		@media screen and (max-width: 1000px) {
			#sidemenu {
				left: -158px;
			}
		}

#live-directory-wrapper {
			padding: 0;
		}
#top-buttons-wrapper {
			padding: 0;
		}
.logged-in #user-info {
			padding: 0;
			height: auto;
			text-align: center;
			visibility: hidden;
			display: none;
		}
#user-info button { opacity: .8; }
#user-info:hover button { opacity: 1; }
.logged-in #user-info > a { display: none; visibility:hidden;}
		@media screen and (min-width: 1000px) {
#live-directory {
    background-color:#111111;
    border-radius:0px;
    height: 25px;
    line-height: 25px;
    font-size: 13px;
    opacity: .8;
    margin-left: 4px;
    width: 155px;
    background-color: #111111;
    border: 0px solid #31313100;
    text-shadow: 0 0 2px white;
    box-shadow: 0 0 5px 2px white;
			}
			#upgrade {
				height: 0px;
				line-height: 0px;
				font-size: 13px;
				opacity: .8;
    #live-directory:active {
    background-color: #7ce5ecba;
    box-shadow: 0 0 3px 0px #61aeb3;

}
			}
			#live-directory:before {
				height: 8px;
				width: 8px;
				top: 0px;
			}
			#upgrade {
				margin-top: 0px;
				visibility: hidden;
				display: none;
			}
			#live-directory:hover, #upgrade:hover {
				opacity: 1;
			}
		}

		#sidemenu.tes-sidemenuCollapsed {
			min-width: 0px;
			max-width: 0px;
border:0px;
		}
		.tes-sidemenuCollapsed #user-info { display: none; }
		.tes-sidemenuCollapsed #user-info { display: none; }
		#tes-sidemenu-grabber {
        position: absolute;
        top: 7rem;
        left: 10.4rem;
        z-index: 3;
        height: 20px;
        padding-top: 19px;
        width: 20px;
        text-align: center;
        border: #ffffff 1px solid;
		}

#tes-sidemenu-grabber:before {
    content: '';
    position: absolute;
    display: block;
    height: 0;
    width: 0;
    top: 1.2rem;
    left: 0.7rem;
    margin: -4px 0 0 -2px;
    border-width: 4px 4px 4px 0;
    border-style: solid;
    border-color: transparent #bcc2c2;
    transition: .8s;
}
		#tes-sidemenu-grabber:hover {
			background: #333;
			color: #5c5c5c;
			cursor: pointer;
		}
		.tes-sidemenuCollapsed #tes-sidemenu-grabber{
			border-radius: 0 10px 10px 0;
			right: 10px;
    left: -4px;

		}

		#sidemenu.tes-nightmode,
		.tes-nightmode #sidemenu-content::-webkit-scrollbar-track {
			background: #191919;
		}
		.tes-nightmode #tes-sidemenu-grabber {
			background: #141414;
			color: #3b3b3b;
		}
		.tes-nightmode #tes-sidemenu-grabber:hover {
			background: #333;
			color: #5c5c5c;
		}

.tes-sidemenuCollapsed #tes-sidemenu-grabber:before {
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
}
		.tes-nightmode #user-info { background: black; }
		.tes-nightmode #user-info > button {
			background: #e76bb6;
			color: #e76bb6;
		}
		.tes-nightmode #user-info > button:hover {
			background: #0080a3;
			color: white;
		}
		.tes-nightmode #sidemenu-content::-webkit-scrollbar-thumb {
			border: 1px solid #191919;
width:50%;
			background-color: #111;
		}

		.tes-nightmode #sidemenu-content::-webkit-scrollbar {
    width: 5px;
}

		/*** ---                                COLORSSSSSSS                                      --- ***/
		/*** ---                                PINKKK                                      --- ***/

.tes-pinkmode #tes-sidemenu-grabber:before {
    top: 1.2rem;
    left: 0.7rem;

}

#sidemenu.tes-pinkmode > #tes-sidemenu-grabber {
    background-color: #fb2db0;
    color: #ffadc1;
    border-color: #ffffff;
    box-shadow: 0 0 3px 0.9px white;
}

#sidemenu.tes-pinkmode {
			background-color:#ef54b2;
            border-right:1px solid #ffd1dc;
}
#sidemenu.tes-pinkmode > #sidemenu-content {
			background-color:#ef54b2;
}


		@media screen and (min-width: 1000px) {
.tes-pinkmode #live-directory {
		height: 25px;
		line-height: 25px;
		font-size: 13px;
		opacity: .8;
		margin-left:10px;
		width:175px;
background-color:#fe24b0;
border:1px solid #ffadc1;
			}

#room-header.tes-pinkmode, .tes-pinkmode #tes-header-grabber {
background-color:#ffadc1;
box-shadow: 0 0 3px 1px white;
position: absolute;
top: 7.1rem;
right: 14.9rem;
}

.tes-pinkmode #tes-sidemenu-grabber{
			background-color:#ffd1dc;
}

#chat-wrapper.tes-pinkmode {			background-color:#ffd1dc;}

		/*** ---                                GREENNN                                      --- ***/

.tes-greenmode #tes-sidemenu-grabber:before {

    border-color: transparent #00570a;

}

#sidemenu.tes-greenmode > #tes-sidemenu-grabber {
			background-color: #042500;
			color: #00570a;
border-color:#00570a;
}

#sidemenu.tes-greenmode {
			background-color: #00500d;
            border-right:1px solid #042500;
}
#sidemenu.tes-greenmode > #sidemenu-content {
			background-color: #00500d;
}


		@media screen and (min-width: 1000px) {
.tes-greenmode #live-directory {
		height: 25px;
		line-height: 25px;
		font-size: 13px;
		opacity: .8;
		margin-left:10px;
		width:175px;
background-color:#042500;
border:1px solid #042500;
			}

#room-header.tes-greenmode, .tes-greenmode #tes-header-grabber {
background-color:#00570a;
}

.tes-greenmode #tes-sidemenu-grabber{
			background-color:#042500;
}

#chat-wrapper.tes-greenmode {			background-color:#042500;}

		/*** ---                                BLUEEE                                      --- ***/

.tes-bluemode #tes-sidemenu-grabber:before {

    border-color: transparent #2a388b;

}

#sidemenu.tes-bluemode > #tes-sidemenu-grabber {
			background-color: #111949;
			color: #2a388b;
border-color:#2a388b;
}

#sidemenu.tes-bluemode {
			background-color: #2a388b;
            border-right:1px solid #111949;
}
#sidemenu.tes-bluemode > #sidemenu-content {
			background-color: #2a388b;
}


		@media screen and (min-width: 1000px) {
.tes-bluemode #live-directory {
		height: 25px;
		line-height: 25px;
		font-size: 13px;
		opacity: .8;
		margin-left:10px;
		width:175px;
background-color:#111949;
border:1px solid #111949;
			}

#room-header.tes-bluemode, .tes-bluemode #tes-header-grabber {
background-color:#2a388b;
}

.tes-bluemode #tes-sidemenu-grabber{
			background-color:#111949;
}

#chat-wrapper.tes-bluemode {			background-color:#111949;}

		/*** ---                                PURPLEEE                                      --- ***/

.tes-purplemode #tes-sidemenu-grabber:before {

    border-color: transparent #BF8FE5;

}

#sidemenu.tes-purplemode > #tes-sidemenu-grabber {
			background-color: #9168b2;
			color: #BF8FE5;
border-color:#BF8FE5;
}

#sidemenu.tes-purplemode {
			background-color: #BF8FE5;
            border-right:1px solid #9168b2;
}
#sidemenu.tes-purplemode > #sidemenu-content {
			background-color: #BF8FE5;
}


		@media screen and (min-width: 1000px) {
.tes-purplemode #live-directory {
		height: 25px;
		line-height: 25px;
		font-size: 13px;
		opacity: .8;
		margin-left:10px;
		width:175px;
background-color:#9168b2;
border:1px solid #9168b2;
			}

#room-header.tes-purplemode, .tes-purplemode #tes-header-grabber {
    border: #ffffff 1px solid;
    background-color: #9168b2;
    box-shadow: 0 0 1px 1px white;

}

.tes-purplemode #tes-sidemenu-grabber{
			background-color:#9168b2;
}

#chat-wrapper.tes-purplemode {			background-color:#9168b2;}
	</style>
	`;
	sidemenuCSS.insertAdjacentHTML(insertPosition, sidemenuCSShtml);
	}

	if (cssName == "videomoderationCSS" || cssName == null) {
	videomoderationCSShtml = `
	<style id="videomoderationCSS" scope="tc-video-moderation">
#moderatorlist {
			padding-left: 0;
			z-index: 7;
max-height:22px;
}
#moderatorlist:hover {
		    position: absolute;
			background: white;
			z-index: 1000;
			width: 300px;
			min-height: 155px;
			flex-direction: column;
			position: absolute;
			background: #111;
			z-index: 1000;
			width: 350px;
			max-height: fit-content!important;
			left: 15px;
			border-radius: 13px;
			border: #fff 1px solid;
			top: 30px;
            left:0px;
}
#moderatorlist:after {
    top: 2px;
    right: 1px;
}
#moderatorlist:hover #header {
	height: unset;
	top: unset;
    padding-left:0 !important;
}
#moderatorlist > #header {
    top: 2px !important;
    width: 100%;
    height:20px;
}

#moderatorlist > #header > span > button {
    border-radius:10px;
    width: unset !important;
    height:unset !important;
    background-color: unset;
}
#moderatorlist.tes-nightmode > #header > span > button {
    background: var(--nightmodeBlack-bgcolor);
}
#moderatorlist.tes-nightmode:hover {
	border-color: #333;
}
.video:after{border:0px;}


	</style>
	`;
	videomoderationCSS.insertAdjacentHTML(insertPosition, videomoderationCSShtml);
	}

	if (cssName == "webappCSS" || cssName == null) {
	webappCSShtml = `
	<style id="webappCSS" scope="tinychat-webrtc-app">
.input-menu{display:none;}
		#room {
			padding: 0;
			padding-left: 80px;

		}
		#room.tes-sidemenuCollapsed {     margin-left: -21px;width: 100%;
}
		@media screen and (max-width: 1000px) {
			:host > #room {
				padding-left: 70px;

			}
		}
		@media screen and (max-width: 600px) {
			:host > #room {
				padding-left: 0;
			}
		}
       #room-content.tes-chatbelow {
			flex-direction: row !important;
			margin-left: 150px !important;
			margin-top: 10px !important;
			margin-bottom: 2px !important;
            background-color: rgba(0,0,0,.3);
		}

	</style>
	`;
	webappCSS.insertAdjacentHTML(insertPosition, webappCSShtml);
	}
}

function injectElements() {
	headerGrabberParElem = titleElem.querySelector("#room-header");
	headerGrabberParElem.insertAdjacentHTML("beforeend", `<div id="tes-header-grabber"></div>`);
	headerGrabberElem = headerGrabberParElem.querySelector("#tes-header-grabber");
	headerGrabberElem.addEventListener("click", headerGrabber);

	sidemenuOverlayElem = bodyElem.querySelector("#menu-icon");
	sidemenuOverlayElem.addEventListener("click", function(){sidemenuOverlayElem.classList.toggle("expanded");});

	chatlogButtonsHTML = `
		<div id="tes-chatlogButtons">
			<div id="tes-chatlogSave" class="tes-chatlogBut">
				<span class="icon">📁
					</svg>
				</span><!-- ? -->
				<span class="label">Save Logs</span>
			</div>
			<div id="tes-chatlogView" class="tes-chatlogBut">
				<span class="icon">📜</span>
				<span class="label">Chat Logs</span>
			</div>
			<div id="tes-chatlogDisplay">
				<textarea spellcheck="false"></textarea>
				<div id="close">X</div>
			</div>
		</div>`;

	selectAllButton = chatlogElem.querySelector("#chat-wrapper").insertAdjacentHTML("afterbegin", chatlogButtonsHTML);
	chatlogElem.querySelector("#tes-chatlogSave").addEventListener("click", function(){copyChatlog("download")} );
	chatlogElem.querySelector("#tes-chatlogView").addEventListener("click", function(){copyChatlog("view")} );
	chatlogElem.querySelector("#tes-chatlogDisplay #close").addEventListener("click", function(){copyChatlog("close")} );

	if (!isPaidAccount) {
		sidemenuGrabberParElem = sidemenuElem.querySelector("#sidemenu");
		sidemenuGrabberElem = document.createElement("div");
		sidemenuGrabberElem.setAttribute("id", "tes-sidemenu-grabber");
		sidemenuGrabberElem.innerHTML = "";
		sidemenuGrabberElem.addEventListener("click", sidemenuGrabber);
		sidemenuGrabberParElem.appendChild(sidemenuGrabberElem);
		sidemenuGrabberElem = sidemenuElem.querySelector("#tes-sidemenu-grabber");
	}
}



function sidemenuGrabber() {
	sidemenuGrabberParElem.classList.toggle("tes-sidemenuCollapsed");
	sidemenuGrabberParElem.classList.contains("tes-sidemenuCollapsed") ? sidemenuGrabberElem.innerHTML = "" : sidemenuGrabberElem.innerHTML = "";

	userlistElem.querySelector("#userlist").classList.toggle("tes-sidemenuCollapsed");
	videolistElem.querySelector("#videolist").classList.toggle("tes-sidemenuCollapsed");
	webappElem.querySelector("#room").classList.toggle("tes-sidemenuCollapsed");
	bodyElem.classList.toggle("tes-sidemenuCollapsed");
}

function chatlogGrabber() {
	chatlogGrabberParElem.classList.toggle("tes-chatCollapsed");
	chatlogGrabberParElem.classList.contains("tes-chatCollapsed") ? chatlogGrabberElem.innerHTML = "?" : chatlogGrabberElem.innerHTML = "?";

}

function headerGrabber() {
	headerGrabberParElem.classList.toggle("tes-headerCollapsed");
	headerGrabberParElem.classList.contains("tes-headerCollapsed") ? headerGrabberElem.innerHTML = "" : headerGrabberElem.innerHTML = "";

}



!browserFirefox ? injectElements() : void(0);

var scrollbox = chatlogElem.querySelector("#chat");
var unreadbubble = chatlogElem.querySelector("#input-unread");
var autoScrollStatus = true;


function updateScroll() {
	scrollbox.scrollTop = scrollbox.scrollHeight;
	scrollbox.scrollTop = scrollbox.scrollTop + 5;
}

function userHasScrolled(e) {
	var scrollwheelAmount = e.deltaY;

	if (scrollwheelAmount < 0) {
		autoScrollStatus = false;
	}
	if (autoScrollStatus === false && scrollbox.scrollHeight - scrollbox.scrollTop == scrollbox.offsetHeight) {
		autoScrollStatus = true;
	}
}

function newMessageAdded() {
	if (autoScrollStatus === true && settingsQuick["Autoscroll"]) { updateScroll(); }
	timestampAdd();
	messageParser();
}

function userContextmenuUpdated() {
	var elemBottom = 0;
	var topPos = userContextmenuCSS.getBoundingClientRect().top;
	var elemBottom = topPos + userContextmenuCSS.offsetHeight;
	if (elemBottom > (window.innerHeight - 82)) {
		// userContextmenuCSS.style.top = (userContextmenuCSS.style.top - userlistElem.querySelector("#userlist").scrollTop - 200) + "px";
		// userContextmenuCSS.style.top = (userlistElem.querySelector("#userlist").scrollTop - window.innerHeight) + "px";
		userContextmenuCSS.style.top = (window.innerHeight - 82 - userContextmenuCSS.offsetHeight - 15) + "px";
		// console.log("Change: " + userContextmenuCSS.style.top);
	}

	// console.log("elemBottom: " + elemBottom + ". Max: " + (window.innerHeight - 82) + ". offsetHeight: " + userContextmenuCSS.offsetHeight + ". New top: " + (window.innerHeight - 82 - userContextmenuCSS.offsetHeight));
}
function messageParserCheckCSS() {
	var messages = chatlogElem.querySelectorAll("#chat-content .message")
	for (i=0; i < messages.length; i++) {
		var tcMessageHtmlElem = messages[i].querySelector("tc-message-html").shadowRoot;
		if (!tcMessageHtmlElem.querySelector("#messageCSS")) tcMessageHtmlElem.appendChild(messageParserAddCSS());
		if (settingsQuick["NightMode"]) tcMessageHtmlElem.querySelector("#html").classList.add("tes-nightmode");
        if (settingsQuick["PinkMode"]) tcMessageHtmlElem.querySelector("#html").classList.add("tes-pinkmode");
	}
}
function messageParserAddCSS(elem=null) {
	var node = document.createElement("style");
	var textnode = document.createTextNode(messageCSS);
	node.appendChild(textnode);
	node.setAttribute("id", "messageCSS");

	if (elem) { elem.appendChild(node); }
	else { return node; }

}
messageCount = 0;
function messageParser() {

	latestMessageElem = chatlogElem.querySelector("#chat-content div.message:last-of-type");

	var typeSystem = false;

	if (latestMessageElem != null) {
		if (latestMessageElem.classList.contains("system")) typeSystem =  true;
		latestMessageElem.setAttribute("id", "msg-"+messageCount);
		messageCount++;

		tcMessageHtmlElem = latestMessageElem.querySelector("tc-message-html").shadowRoot;
		latestMessageContentElem = tcMessageHtmlElem.querySelector("#html");

		if (!browserFirefox) {
			if (!tcMessageHtmlElem.querySelector("#messageCSS")) {
				messageParserAddCSS(tcMessageHtmlElem);
			}
			if (settingsQuick["NightMode"]) latestMessageContentElem.classList.add("tes-nightmode");
            			if (settingsQuick["PinkMode"]) latestMessageContentElem.classList.add("tes-pinkmode");
		}


		latestMessageContent = latestMessageContentElem.innerHTML;

		latestMessageContent.includes(" banned ") || latestMessageContent.includes(" kicked ") ? latestMessageElem.classList.add("dontHide") : void(0);

		if (!browserFirefox && settingsQuick["MentionsMonitor"]) {
			for (i=0; i < settingMentions.length; i++) {
				if (latestMessageContent.toLowerCase().includes(settingMentions[i].toLowerCase())) {
					latestMessageContentElem.classList.add("tes-mention-message");
					audioPop.play();
					break;
				}
			}
		}
	}
}


var messagesMO = new MutationObserver(function (e) {
  if (e[0].addedNodes) newMessageAdded();
});
messagesMO.observe(chatlogElem.querySelector("#chat-content"), { childList: true });

var camsMO = new MutationObserver(function (e) {
  if (e[0].addedNodes) newCamAdded();
});
camsMO.observe(videolistElem.querySelector(".videos-items:last-child"), { childList: true });

var userContextmenuMO = new MutationObserver(function (e) {
  if (e[0].addedNodes) userContextmenuUpdated();
});
userContextmenuMO.observe(userContextmenuCSS, { attributes: true });

var chatTextboxMO = new MutationObserver(function (e) {
  if (e[0].addedNodes) chatboxSwitch();
});
chatTextboxMO.observe(chatlogElem.querySelector("#chat-instant"), { attributes: true, attributeFilter: ['class'], childList: false, characterData: false });

var userlistMO = new MutationObserver(function (e) {
  if (e[0].addedNodes) newUserAdded();
});
userlistMO.observe(userlistElem.querySelector("#userlist"), { childList: true });

var scrollboxEvent = scrollbox.addEventListener("wheel", userHasScrolled);
var unreadbubble = unreadbubble.addEventListener("click", function(){autoScrollStatus = true;} );


function chatboxSwitch() { messageParserCheckCSS(); }

function timestampAdd() {
	var queryString = messageQueryString + ".common:last-of-type .nickname";

	var SHOW_SECONDS = true;

	var date = new Date();
	var hours = date.getHours();
	var minutes = date.getMinutes().toString();
	var secs = date.getSeconds().toString();

	if (hours > 11) {
		hours = (hours % 12 || 12);
		var period = "pm";
	}
	else { var period = "am"; }

	if (hours == "0") { hours = "12"; }
	if (minutes == "0") { minutes = "00"; }
	if (minutes.length == 1) { minutes = "0" + minutes; }
	if (secs.length == 1) { secs = "0" + secs; }

	if (SHOW_SECONDS == true) {
		var timestamp = hours + ":" + minutes + ":" + secs + "" + period;
	}
	else {
		var timestamp = hours + ":" + minutes + period;
	}

	if (chatlogElem.querySelector(queryString) != null) {
		var recentMsgNickname = chatlogElem.querySelector(queryString);
		recentMsgNickname.insertAdjacentHTML("afterend", "<span id='timestamp'> " + timestamp + "</span>");
	}
}

var userCount = 0;
function newUserAdded() {
	if (!userlistElem.querySelector("#userlist .list-item:last-of-type")) return;

	var latestUserElem = userlistElem.querySelector("#userlist .list-item:last-of-type");
	var lastestUserNick = latestUserElem.querySelector(".nickname").innerHTML;

	var usersElems = userlistElem.querySelectorAll("#userlist .list-item");
	userCount = usersElems.length;
	users = [];

	for (i=0; i < usersElems.length; i++) {
		users += usersElems[i].querySelector(".nickname").innerHTML;
	}

	if (!userlistElem.querySelector("#tes-userCount")) {
		userCountParElem = userlistElem.querySelector("#header > span");
		userCountElem = document.createElement("span");
		userCountElem.setAttribute("id", "tes-userCount");
		userCountElem.innerHTML = "(" + userCount + ")";
		userCountParElem.appendChild(userCountElem);
		userCountElem = userlistElem.querySelector("#tes-userCount");
	}
	else {
		userCountElem.innerHTML = "(" + userCount + ")";
	}
}

camsMaxed = null;
function newCamAdded() {
	var queryString = ".videos-items:last-child > .js-video"
	if (videolistElem.querySelector(queryString)) var camElems = videolistElem.querySelectorAll(queryString);
	else return;

	camsCount = 0;

	for (i=0; i < camElems.length; i++) {
		camsCount = i + 1;
		var camItem = camElems[i].querySelector("tc-video-item").shadowRoot;
		var camItemCSS = camItem.querySelector(".video");
		if (settingsQuick["NightMode"]) camItemCSS.classList.add("tes-nightmode");
		else camItemCSS.classList.remove("tes-nightmode");

		camItemCSShtml = `
			<style id="camItemCSS">
.icon-tes-max {
    position: absolute;
    top: -40%;
    right: 0;
    z-index: 9;
    background: none;
    border: 0;
}
.icon-tes-max:hover {
    cursor: pointer;
}
.icon-tes-max path {
    fill: #f07629;
}
.video:hover .icon-tes-max {
    top: 50%;
    /*left: 48%;*/
    transition: top .2s ease .2s,
    left .2s ease .2s,
    right .2s ease .2s,
    opacity .2s;
}
.tes-nightmode.video:after {
    border:5px solid  rgba(0,0,0,.06);
}
.tes-pinkmode.video:after {
    border:5px solid # rgba(0,0,0,.06) !important;
}
.tes-greenmode.video:after {
    border:5px solid # rgba(0,0,0,.06) !important;
}
.tes-bluemode.video:after {
    border:5px solid  rgba(0,0,0,.06) !important;
}
.tes-purplemode.video:after {
    border:5px solid  rgba(0,0,0,.06) !important;
}
.icon-resize > svg {
    top: 3px;
    left: 3px;
    display: none;
}
			</style>
		`;
		if (!camItem.querySelector("#camItemCSS")) camItemCSS.insertAdjacentHTML("afterbegin", camItemCSShtml);

		var camName = camItem.querySelector(".nickname").getAttribute("title");
		camElems[i].setAttribute("id", "camUser-"+camName);

		// Cam maxing
		try {
		if (camItem.querySelector(".icon-tes-max")) {
			var maxbutton = camItem.querySelector(".icon-tes-max");
			maxbutton.parentNode.removeChild(maxbutton);
		}

		var camMaxButtonHtml = `
		<button class="icon-tes-max" id="maxbutton-` + camName + `">
		<svg width="18" height="18" viewBox="0 0 18 18" xmlns="http://www.w3.org/2000/svg">
		<path d="M14.37 12.95l3.335 3.336a1.003 1.003 0 1 1-1.42 1.42L12.95 14.37a8.028 8.028 0 1 1 1.42-1.42zm-6.342 1.1a6.02 6.02 0 1 0 0-12.042 6.02 6.02 0 0 0 0 12.042zM6.012 9.032a.996.996 0 0 1-.994-1.004c0-.554.452-1.003.994-1.003h4.033c.55 0 .994.445.994 1.003 0 .555-.454 1.004-.995 1.004H6.012z" fill-rule="evenodd"></path>
		<path d="M0 .99C0 .445.444 0 1 0a1 1 0 0 1 1 .99v4.02C2 5.555 1.556 6 1 6a1 1 0 0 1-1-.99V.99z" transform="translate(7 5)" fill-rule="evenodd"></path></svg>
		</button>`;
		camItem.querySelector(".icon-resize").insertAdjacentHTML("beforebegin", camMaxButtonHtml);

		var maxCamVar = function(maxCamVarArg){ maximizeCam(maxCamVarArg); };
		camItem.querySelector("#maxbutton-"+camName).addEventListener("click", maxCamVar.bind(this, camName));

		if (camsMaxed == camName) {
			camElems[i].classList.add("tes-maxedCam");
			camElems[i].parentElement.classList.add("tes-max");
		}
		if (!videolistElem.querySelector(".tes-maxedCam")) camElems[i].parentElement.classList.remove("tes-max");

		camMaxCSShtml = `
		<style id="camMaxCSS">
		.tes-max .js-video {
			width: 10%!important;
			z-index: 1;
		}
		.tes-leftcam .tes-max .js-video {
			float: right;
			order: 2;
		}
		.tes-leftcam .tes-max .tes-maxedCam {
			float: left;
			order: 1;
		}


		div[data-video-count="5"] .tes-max .js-video:not(.tes-maxedCam),
		div[data-video-count="6"] .tes-max .js-video:not(.tes-maxedCam),
		div[data-video-count="7"] .tes-max .js-video:not(.tes-maxedCam)
		{ width: 19%!important; }
		.tes-max.tes-camCount2 .js-video { width: 10%!important; }
		.tes-max.tes-camCount10-11 .js-video { width:8%!important; }
		.tes-max.tes-camCount12 .js-video { width: 8%!important; }

		:not(.hidden) + .tes-max.tes-camCount12 .js-video,
		:not(.hidden) + .tes-max.tes-camCount10-11 .js-video,
		:not(.hidden) + .tes-max .js-video
		{ width: 14%!important; }
		:not(.hidden) + .tes-max.tes-camCount2 .js-video { width: 10%!important; }

		.tes-max .js-video.tes-maxedCam,
		:not(.hidden) + .tes-max .js-video.tes-maxedCam { width: 65%!important; }

		@media screen and (max-width: 100px) {
			.tes-max .js-video { width: 10%!important; }

			.tes-max.tes-camCount2 .js-video { width: 10%!important; }
			.tes-max.tes-camCount10-11 .js-video { width: 0%!important; }
			.tes-max.tes-camCount12 .js-video { width: 0%!important; }

			.tes-max .js-video.tes-maxedCam,
			:not(.hidden) + .tes-max .js-video.tes-maxedCam { width: 0%!important; }
		</style>
		`;
		if (videolistCSS.querySelector("#camMaxCSS")) {
			var maxcss = videolistCSS.querySelector("#camMaxCSS");
			maxcss.parentNode.removeChild(maxcss);
		}
		videolistCSS.insertAdjacentHTML("beforeend", camMaxCSShtml);

		}
		catch(e) { console.log("TES ERROR newCamAdded: " + e.message); }

		if (settingsQuick["HideAllCams"] == "true" || urlPars.get("hideallcams") == "") {
			camItem.querySelector("button.checkbox-visibility").click();
			console.log("Cam hide: " + camName);

}


		camCounter(camElems[i]);
	}

	// console.log("camsCount: " + camsCount);
}

function maximizeCam(camName) {
	try {
	if (camName != camsMaxed && camsMaxed != null) {
		maximizeCam(camsMaxed);
		maximizeCam(camName);
		return;
	}

	var camElem = videolistElem.querySelector("#camUser-" + camName);
	if (camElem == null) {
		camsMaxed = null;
		return;
	}

	if (camElem.classList.contains("tes-maxedCam")) {
		camElem.classList.remove("tes-maxedCam");
		camElem.parentElement.classList.remove("tes-max");
		camsMaxed = null;
	}
	else {
		camElem.classList.add("tes-maxedCam");
		camElem.parentElement.classList.add("tes-max");
		camsMaxed = camName;
	}
	camCounter(camElem);
	}
	catch(e) { console.log("TES ERROR maximizeCam: " + e.message); }
}

function camCounter(camElem) {
	if (camsCount == 12) {
		camElem.parentElement.classList.remove("tes-camCount10-11");
		camElem.parentElement.classList.remove("tes-camCount2");

		camElem.parentElement.classList.add("tes-camCount12");
	}
	else if (camsCount > 9 && camsCount < 12) {
		camElem.parentElement.classList.remove("tes-camCount12");
		camElem.parentElement.classList.remove("tes-camCount2");

		camElem.parentElement.classList.add("tes-camCount10-11");
	}
	else if (camsCount == 2) {
		camElem.parentElement.classList.remove("tes-camCount12");
		camElem.parentElement.classList.remove("tes-camCount10-11");

		camElem.parentElement.classList.add("tes-camCount2");
	}
	else {
		camElem.parentElement.classList.remove("tes-camCount12");
		camElem.parentElement.classList.remove("tes-camCount10-11");
		camElem.parentElement.classList.remove("tes-camCount2");
	}
}


// Userscript ends here //
		})();
	}
	else { console.log("Waiting for init..."); }
}