143 lines
3.9 KiB
JavaScript
143 lines
3.9 KiB
JavaScript
|
const { LitElement, html, css } = require('lit')
|
||
|
const { commonCss, displayScreen } = require('./components/common')
|
||
|
|
||
|
class PlayScreen extends LitElement {
|
||
|
static get styles () {
|
||
|
return css`
|
||
|
${commonCss}
|
||
|
.title {
|
||
|
top: 12px;
|
||
|
}
|
||
|
|
||
|
.edit-boxes {
|
||
|
position: absolute;
|
||
|
top: 59px;
|
||
|
left: 50%;
|
||
|
display: flex;
|
||
|
flex-direction: column;
|
||
|
gap: 14px 0;
|
||
|
transform: translate(-50%);
|
||
|
width: 310px;
|
||
|
}
|
||
|
|
||
|
.wrapper {
|
||
|
width: 100%;
|
||
|
display: flex;
|
||
|
flex-direction: row;
|
||
|
gap: 0 4px;
|
||
|
}
|
||
|
|
||
|
.button-wrapper {
|
||
|
display: flex;
|
||
|
flex-direction: row;
|
||
|
gap: 0 4px;
|
||
|
position: absolute;
|
||
|
bottom: 9px;
|
||
|
left: 50%;
|
||
|
transform: translate(-50%);
|
||
|
width: 310px;
|
||
|
}
|
||
|
`
|
||
|
}
|
||
|
|
||
|
static get properties () {
|
||
|
return {
|
||
|
server: { type: String },
|
||
|
serverport: { type: Number },
|
||
|
proxy: { type: String },
|
||
|
proxyport: { type: Number },
|
||
|
username: { type: String },
|
||
|
password: { type: String }
|
||
|
}
|
||
|
}
|
||
|
|
||
|
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 = ''
|
||
|
|
||
|
window.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
|
||
|
})
|
||
|
}
|
||
|
|
||
|
render () {
|
||
|
return html`
|
||
|
<div class="dirt-bg"></div>
|
||
|
|
||
|
<p class="title">Join a Server</p>
|
||
|
|
||
|
<main class="edit-boxes">
|
||
|
<div class="wrapper">
|
||
|
<pmui-editbox
|
||
|
pmui-width="150px"
|
||
|
pmui-label="Server IP"
|
||
|
pmui-id="serverip"
|
||
|
pmui-value="${this.server}"
|
||
|
@input=${e => { this.server = e.target.value }}
|
||
|
></pmui-editbox>
|
||
|
<pmui-editbox
|
||
|
pmui-width="150px"
|
||
|
pmui-label="Server Port"
|
||
|
pmui-id="port"
|
||
|
pmui-value="${this.serverport}"
|
||
|
@input=${e => { this.serverport = e.target.value }}
|
||
|
></pmui-editbox>
|
||
|
</div>
|
||
|
<div class="wrapper">
|
||
|
<pmui-editbox
|
||
|
pmui-width="150px"
|
||
|
pmui-label="Proxy"
|
||
|
pmui-id="proxy"
|
||
|
pmui-value="${this.proxy}"
|
||
|
@input=${e => { this.proxy = e.target.value }}
|
||
|
></pmui-editbox>
|
||
|
<pmui-editbox
|
||
|
pmui-width="150px"
|
||
|
pmui-label="Port"
|
||
|
pmui-id="port"
|
||
|
pmui-value="${this.proxyport}"
|
||
|
@input=${e => { this.proxyport = e.target.value }}
|
||
|
></pmui-editbox>
|
||
|
</div>
|
||
|
<div class="wrapper">
|
||
|
<pmui-editbox
|
||
|
pmui-width="150px"
|
||
|
pmui-label="Username"
|
||
|
pmui-id="username"
|
||
|
pmui-value="${this.username}"
|
||
|
@input=${e => { this.username = e.target.value }}
|
||
|
></pmui-editbox>
|
||
|
</div>
|
||
|
</main>
|
||
|
|
||
|
<div class="button-wrapper">
|
||
|
<pmui-button pmui-width="150px" pmui-label="Connect" @pmui-click=${this.onConnectPress}></pmui-button>
|
||
|
<pmui-button pmui-width="150px" pmui-label="Cancel" @pmui-click=${() => displayScreen(this, document.getElementById('title-screen'))}></pmui-button>
|
||
|
</div>
|
||
|
`
|
||
|
}
|
||
|
|
||
|
onConnectPress () {
|
||
|
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
|
||
|
}
|
||
|
}))
|
||
|
}
|
||
|
}
|
||
|
|
||
|
window.customElements.define('pmui-playscreen', PlayScreen)
|