prismarine-web-client/lib/menus/play_screen.js

143 lines
3.9 KiB
JavaScript
Raw Normal View History

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)