<log-root style='position:absolute;bottom:0;left:10px;right:10px;'>
<template shadowrootmode=open>
<style>
#log-root {position:absolute;left:10px;bottom:3px;right:10px;z-index:99999}
#log {display:flex;background:white;border:2px solid transparent;padding:10px;border-radius:5px;cursor:pointer;
margin-bottom:10px}
#log-text {flex:1;white-space:pre-wrap}
#log-close {width:15px;height:15px}
</style>
<div id=log-root style='display:none'>
<div id=log>
<div id=log-text></div>
<img id=log-close src=''>
</div>
</div>
</template>
<script>
//console.clear();
class Log extends HTMLElement {
constructor() {
super();
var $ = (root,sel)=>(!sel && (sel=root,root=document),root.querySelector(sel));
$.rem = (root,sel)=>{
var node = $(root,sel);
node && node.remove();
return node;
}//rem
var root = this;
var shadow = root.shadowRoot;
window.log = log;
var def = {};
def.time = 4000;
def.console = true;
log.config = def;
log.initdom=function(rootnode){ //c
log.root = $(shadow,'#log-root');
log.item = $.rem(log.root,'#log');
log.root.style.display = '';
}//initdom
function log(){
var str = [...arguments].join(' ');
var nlog = log.item.cloneNode(true);
nlog.onclick = rem;
$(nlog,'#log-text').textContent = str;
log.root.append(nlog);
if(log.config.console){
console.log.apply(console,arguments);
}
if(log.config.time){
setTimeout(rem,log.config.time);
}
log.config = def;
return nlog;
function rem(){
nlog.remove();
}//rem
}//log
log.red=function(){
var nlog = log.apply(null,arguments);
nlog.style.borderColor = 'red';
nlog.style.color = 'red';
}//red
log.green=function(){
var nlog = log.apply(null,arguments);
nlog.style.borderColor = 'green';
nlog.style.color = 'green';
}//green
log.orange=function(){
var nlog = log.apply(null,arguments);
nlog.style.borderColor = 'orange';
nlog.style.color = 'orange';
}//orange
log.error=function(err){
log.red(err.message);
}//error
log.initdom();
}//constructor
}//class
customElements.define('log-root',Log);
</script>
</log-root>
<log>
<script src='https://script-tag-q0dit4tshpll.runkit.sh/libs/html/libs-html-loader.js'></script>
</log>
<button onclick='button_click()'>test</button>
<script>
function button_click(){
log.green('test');
}//button_click
</script>