japanese-drum-game/public/src/js/about.js

179 lines
5.7 KiB
JavaScript
Raw Normal View History

2018-10-14 19:02:50 +08:00
class About{
2018-10-14 16:04:31 +08:00
constructor(touchEnabled){
this.touchEnabled = touchEnabled
loader.changePage("about", true)
2018-10-14 16:04:31 +08:00
cancelTouch = false
this.endButton = document.getElementById("tutorial-end-button")
this.diagTxt = document.getElementById("diag-txt")
this.version = document.getElementById("version-link").href
this.tutorialOuter = document.getElementById("tutorial-outer")
if(touchEnabled){
this.tutorialOuter.classList.add("touch-enabled")
}
2019-01-25 12:24:43 +08:00
this.linkIssues = document.getElementById("link-issues")
2018-10-14 16:04:31 +08:00
this.linkEmail = document.getElementById("link-email")
2019-01-23 02:47:09 +08:00
var tutorialTitle = document.getElementById("tutorial-title")
tutorialTitle.innerText = strings.aboutSimulator
tutorialTitle.setAttribute("alt", strings.aboutSimulator)
var tutorialContent = document.getElementById("tutorial-content")
strings.about.bugReporting.forEach(string => {
tutorialContent.appendChild(document.createTextNode(string))
tutorialContent.appendChild(document.createElement("br"))
})
var span = document.createElement("span")
span.classList.add("text-warn")
span.innerText = strings.about.diagnosticWarning
tutorialContent.appendChild(span)
this.endButton.innerText = strings.tutorial.ok
this.endButton.setAttribute("alt", strings.tutorial.ok)
2019-02-07 02:49:25 +08:00
var versionUrl = gameConfig._version.url
2019-01-25 12:24:43 +08:00
this.getLink(this.linkIssues).href = versionUrl + "issues"
pageEvents.add(this.linkIssues, ["click", "touchend"], this.linkButton.bind(this))
pageEvents.add(this.linkEmail, ["click", "touchend"], this.linkButton.bind(this))
2018-10-14 16:04:31 +08:00
pageEvents.once(this.endButton, ["mousedown", "touchstart"]).then(this.onEnd.bind(this))
pageEvents.keyOnce(this, 13, "down").then(this.onEnd.bind(this))
this.gamepad = new Gamepad({
"confirm": ["start", "b", "ls", "rs"]
}, this.onEnd.bind(this))
pageEvents.send("about", this.addDiag())
2018-10-14 16:04:31 +08:00
}
onEnd(event){
var touched = false
if(event && event.type === "touchstart"){
event.preventDefault()
touched = true
}
this.clean()
2019-02-04 17:14:42 +08:00
assets.sounds["se_don"].play()
2018-10-14 16:04:31 +08:00
localStorage.setItem("tutorial", "true")
setTimeout(() => {
new SongSelect("about", false, touched)
}, 500)
}
addDiag(){
var diag = []
diag.push("```")
diag.push("Taiko-Web version: " + this.version)
2018-11-21 17:02:53 +08:00
diag.push("URL: " + location.href)
2018-10-14 16:04:31 +08:00
diag.push("User agent: " + navigator.userAgent)
diag.push("Screen size: " + innerWidth + "x" + innerHeight + ", outer: " + outerWidth + "x" + outerHeight + ", ratio: " + (window.devicePixelRatio || 1).toFixed(2))
if(this.touchEnabled){
diag.push("Touch enabled: true")
}
if(!fullScreenSupported){
diag.push("Full screen supported: false")
}
diag.push("Blur performance: " + perf.blur + "ms, all images: " + perf.allImg + "ms")
diag.push("Page load: " + (perf.load / 1000).toFixed(1) + "s")
2018-10-14 16:04:31 +08:00
if("getGamepads" in navigator){
var gamepads = navigator.getGamepads()
for(var i = 0; i < gamepads.length; i++){
if(gamepads[i]){
var gamepadDiag = []
gamepadDiag.push(gamepads[i].id)
gamepadDiag.push("buttons: " + gamepads[i].buttons.length)
gamepadDiag.push("axes: " + gamepads[i].axes.length)
diag.push("Gamepad #" + (i + 1) + ": " + gamepadDiag.join(", "))
}
}
}
2019-01-23 02:47:09 +08:00
var userLangStr = " (none)"
if("languages" in navigator){
var userLang = navigator.languages.slice()
if(userLang[0] !== navigator.language){
userLang.unshift(navigator.language)
}
if(userLang.length !== 0){
userLangStr = " (" + userLang.join(", ") + ")"
}
}
diag.push("Language: " + strings.id + userLangStr)
2018-10-14 16:04:31 +08:00
var errorObj = {}
if(localStorage["lastError"]){
try{
errorObj = JSON.parse(localStorage["lastError"])
}catch(e){}
}
if(errorObj.timestamp && errorObj.stack){
2018-12-13 17:18:52 +08:00
if(errorObj.timestamp + 1000 * 60 * 60 * 24 > Date.now()){
2018-10-14 16:04:31 +08:00
diag.push("Last error: " + errorObj.stack)
diag.push("Error date: " + new Date(errorObj.timestamp).toGMTString())
}else{
localStorage.removeItem("lastError")
}
}
diag.push("```")
var diag = diag.join("\n")
2018-10-14 16:04:31 +08:00
if(navigator.userAgent.indexOf("Android") >= 0){
var iframe = document.createElement("iframe")
this.diagTxt.appendChild(iframe)
var body = iframe.contentWindow.document.body
body.innerText = diag
body.setAttribute("style", `
font-family: monospace;
margin: 2px 0 0 2px;
white-space: pre-wrap;
word-break: break-all;
cursor: text;
2018-10-14 16:04:31 +08:00
`)
body.setAttribute("onblur", `
getSelection().removeAllRanges()
`)
}else{
this.textarea = document.createElement("textarea")
this.textarea.readOnly = true
this.textarea.value = diag
this.diagTxt.appendChild(this.textarea)
if(!this.touchEnabled){
pageEvents.add(this.textarea, "focus", () => {
this.textarea.select()
})
pageEvents.add(this.textarea, "blur", () => {
getSelection().removeAllRanges()
})
}
2018-10-14 16:04:31 +08:00
}
2019-01-23 02:47:09 +08:00
var issueBody = strings.issueTemplate + "\n\n\n\n" + diag
this.getLink(this.linkEmail).href += "?body=" + encodeURIComponent(issueBody.replace(/\n/g, "<br>\r\n"))
return diag
}
getLink(target){
return target.getElementsByTagName("a")[0]
2018-10-14 16:04:31 +08:00
}
linkButton(event){
if(event.target === event.currentTarget){
this.getLink(event.currentTarget).click()
pageEvents.send("about-link", event)
}
2018-10-14 16:04:31 +08:00
}
clean(){
cancelTouch = true
this.gamepad.clean()
2019-01-25 12:24:43 +08:00
pageEvents.remove(this.linkIssues, ["click", "touchend"])
2018-10-14 16:04:31 +08:00
pageEvents.remove(this.linkEmail, ["click", "touchend"])
pageEvents.remove(this.endButton, ["mousedown", "touchstart"])
if(this.textarea){
pageEvents.remove(this.textarea, ["focus", "blur"])
}
2018-10-14 16:04:31 +08:00
pageEvents.keyRemove(this, 13)
delete this.endButton
delete this.diagTxt
delete this.version
delete this.tutorialOuter
2019-01-25 12:24:43 +08:00
delete this.linkIssues
2018-10-14 16:04:31 +08:00
delete this.linkEmail
delete this.textarea
2018-10-14 16:04:31 +08:00
}
}