const { LitElement, html, css } = require('lit-element')
require('./github_link')
require('./components/button')
require('./components/buttonlink')
require('./components/textfield')
/* global fetch */
class PrismarineMenu extends LitElement {
constructor () {
super()
this.server = ''
this.serverport = 25565
this.proxy = ''
this.proxyport = ''
this.username = window.localStorage.getItem('username') ?? 'pviewer' + (Math.floor(Math.random() * 1000))
this.password = ''
fetch('config.json').then(res => res.json()).then(config => {
this.server = config.defaultHost
this.serverport = config.defaultHostPort ?? 25565
this.proxy = config.defaultProxy
this.proxyport = !config.defaultProxy && !config.defaultProxyPort ? '' : config.defaultProxyPort ?? 443
})
}
static get properties () {
return {
server: { type: String },
serverport: { type: Number },
proxy: { type: String },
proxyport: { type: Number },
username: { type: String },
password: { type: String }
}
}
static get styles () {
return css`
:host {
--guiScale: var(--guiScaleFactor, 3);
}
html {
height: 100%;
}
body {
margin:0;
padding:0;
font-family: sans-serif;
background: #000;
}
.login-box {
position: absolute;
top: 50%;
left: 50%;
width: calc(180px * var(--guiScale));
padding: calc(10px * var(--guiScale));
transform: translate(-50%, -50%);
box-sizing: border-box;
border-radius: 10px;
background: rgba(0, 0, 0, 0.5)
}
form {
display: flex;
margin-left: 0;
margin-right: 0;
padding-left: 0;
padding-right: 0;
flex-direction: column
}
.bottom-links {
margin-top: calc(6px * var(--guiScale));
display: flex;
flex-direction: column;
width: 100%;
}
.bottom-links span {
text-align: center;
color: rgb(175, 175, 175);
padding: calc(1px * var(--guiScale));
font-family: mojangles, minecraft, monospace;
font-size: calc(10px * var(--guiScale));
text-shadow: calc(1px * var(--guiScale)) calc(1px * var(--guiScale)) black;
}
.link-buttons {
display: flex;
justify-content: space-between;
gap: calc(4px * var(--guiScale));
}
.title, .subtitle {
text-align: center;
font-family: mojangles, minecraft, monospace;
font-size: calc(10px * var(--guiScale));
font-weight: normal;
color: white;
margin-top: 0;
text-shadow: calc(1px * var(--guiScale)) calc(1px * var(--guiScale)) black;
}
.subtitle {
font-size: calc(7.5px * var(--guiScale));
}
.wrapper {
display: flex;
justify-content: space-between;
gap: calc(6px * var(--guiScale));
}
.spacev {
height: calc(6px * var(--guiScale));
}
.field-spacev {
height: calc(14px * var(--guiScale));
}
`
}
dispatchConnect () {
window.localStorage.setItem('username', this.username)
this.dispatchEvent(new window.CustomEvent('connect', {
detail: {
server: `${this.server}:${this.serverport}`,
proxy: `${this.proxy}${this.proxy !== '' ? `:${this.proxyport}` : ''}`,
username: this.username,
password: this.password
}
}))
}
render () {
return html`