WebAdventure/web/index.html

292 lines
102 KiB
HTML
Raw Normal View History

2019-06-05 22:18:59 +02:00
<!DOCTYPE html>
<html>
2019-07-23 08:27:24 +02:00
<head>
<meta charset="utf-8"/>
<title>KIDNAPPD JSON</title>
<link rel="stylesheet" type="text/css" href="deps/opt/bootstrap.css"/>
</head>
<body>
2019-08-05 21:26:57 +02:00
<img style="margin: auto; width: 350px; display: block" width="350" src="
<div style="float: left; position: absolute; top: 5px"><h1 style="display: block">Level Editor</h1>
2019-07-23 08:27:24 +02:00
<button onclick="resetServer()">Reset</button>
2019-08-05 21:26:57 +02:00
<button onclick="generateForm()">LOS</button>
<input type="text" id="oldJSON">
<a href="https://developer.amazon.com/de/docs/custom-skills/ask-soundlibrary.html" target="_blank"><button type="button">Sound Library</button></a>
</div>
<button id="addBreakBtn" onclick="insertAtCursor(1)">Pause einfügen</button>
<button id="addEmphBtn" onclick="insertAtCursor(2)">Betonung einfügen</button>
<button id="addSoundBtn" onclick="insertAtCursor(3)">Ton einfügen</button>
2019-07-23 08:27:24 +02:00
<form></form>
<div id="res" class="alert"></div>
<script type="text/javascript" src="deps/jquery.min.js"></script>
<script type="text/javascript" src="deps/underscore.js"></script>
<script type="text/javascript" src="deps/opt/jsv.js"></script>
<script type="text/javascript" src="lib/jsonform.js"></script>
<script type="text/javascript">
2019-08-05 21:26:57 +02:00
var oldJSON = {};
function generateForm() {
if ($("#oldJSON").val() != "") {
oldJSON = JSON.parse($("#oldJSON").val());
}
console.log(oldJSON);
$('form').jsonForm({
schema: {
"room": {
"type": "tabarray",
"items": {
"type": "object",
"title": "Room",
"properties": {
"id": {
2019-07-23 08:27:24 +02:00
"type": "integer",
2019-08-05 21:26:57 +02:00
"title": "ID",
"required": true
},
"name": {
"type": "string",
"title": "Name",
"required": true
},
"description": {
"type": "string",
"title": "Description",
"required": true
},
"gameoverFlag": {
"type": "boolean",
"title": "GameoverFlag"
},
2019-07-23 08:27:24 +02:00
"items": {
2019-08-05 21:26:57 +02:00
"type": "tabarray",
"items": {
"type": "integer",
"title": "Item"
}
},
"puzzles": {
"type": "tabarray",
"items": {
"type": "integer",
"title": "Puzzle"
}
2019-07-23 08:27:24 +02:00
}
2019-08-05 21:26:57 +02:00
}
2019-07-23 08:27:24 +02:00
}
2019-08-05 21:26:57 +02:00
},
"puzzle": {
"type": "tabarray",
"items": {
"type": "object",
"title": "Puzzle",
"properties": {
"id": {
"type": "integer",
"title": "ID",
"required": true
},
"name": {
"type": "string",
"title": "Name",
"required": true
},
2019-07-23 08:27:24 +02:00
"items": {
2019-08-05 21:26:57 +02:00
"type": "tabarray",
"items": {
"type": "integer",
"title": "Item"
}
},
"description": {
"type": "string",
"title": "Description",
"required": true
},
"solved": {
"type": "boolean",
"title": "solved"
},
"solvedText": {
"type": "string",
"title": "SolvedText",
"required": true
},
"gameOverFlag": {
"type": "boolean",
"title": "GameOverFlag"
},
"dependencyText": {
"type": "string",
"title": "DependencyText"
}, "dependency": {
"type": "integer",
"title": "Dependency",
}, "nextRoom": {
2019-07-23 08:27:24 +02:00
"type": "integer",
2019-08-05 21:26:57 +02:00
"title": "NextRoom",
2019-07-23 08:27:24 +02:00
}
}
}
2019-08-05 21:26:57 +02:00
},
"item": {
"type": "tabarray",
"items": {
"type": "object",
"title": "Item",
"properties": {
"id": {
"type": "integer",
"title": "ID",
"required": true
},
"name": {
"type": "string",
"title": "Name",
"required": true
},
"portableFlag": {
"type": "boolean",
"title": "PortableFlag"
},
"hiddenFlag": {
"type": "boolean",
"title": "HiddenFlag"
},
"description": {
"type": "string",
"title": "Description",
"required": true
}
2019-07-23 08:27:24 +02:00
}
2019-06-05 22:18:59 +02:00
}
2019-08-05 21:26:57 +02:00
},
"story": {
"type": "tabarray",
"items": {
"type": "string",
"title": "Story"
}
2019-07-23 08:27:24 +02:00
}
2019-08-05 21:26:57 +02:00
2019-07-23 08:27:24 +02:00
},
2019-08-05 21:26:57 +02:00
"value": oldJSON
,
onSubmit: function (errors, values) {
if (errors) {
$('#res').html('<p>Something went wrong, please try again.</p>');
} else {
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
var divToPrint = magic(JSON.stringify(values, null, 4));
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
var newWin = window.open('', 'Print-Window');
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
newWin.document.open();
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
newWin.document.write('<html><body><pre>' + divToPrint + '</pre></body><style>html{word-break: break-all;background-color: #0b0e07; color: white; width: 100%; height: 100%}</style></html>');
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
newWin.document.close();
console.log("hier: " + JSON.stringify(values));
$.post("https://medinf.efi.th-nuernberg.de/tomcat/WebAdventure/IO?levelsubmit", values);
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
$.post("https://medinf.efi.th-nuernberg.de/tomcat/WebAdventure/IO?levelsubmit="+JSON.stringify(values));
}
2019-06-05 22:18:59 +02:00
}
2019-08-05 21:26:57 +02:00
});
}
function magic(input) {
input = input.replace(/&/g, '&amp;');
input = input.replace(/</g, '&lt;');
input = input.replace(/>/g, '&gt;');
return input;
}
2019-07-23 08:27:24 +02:00
function resetServer() {
2019-08-05 21:26:57 +02:00
$.post("https://medinf.efi.th-nuernberg.de/tomcat/WebAdventure/IO?levelreset=true", {"reset": true});
}
$('button').on('mousedown',
/** @param {!jQuery.Event} event */
function (event) {
event.preventDefault();
}
);
function insertAtCursor(n) {
var textToInsert;
//get text to insert
switch (n) {
case 1:
textToInsert = "<break time=\"1s\"/> "
break;
case 2:
textToInsert = "<emphasis level=\"strong\">X</emphasis>"
break;
case 3:
textToInsert = "<audio src=\"URL\"/>"
break;
default:
// code block
}
// get current text of the input
var input = document.activeElement;
var value = input.value;
// save selection start and end position
var start = input.selectionStart;
var end = input.selectionEnd;
// update the value with our text inserted
input.value = value.slice(0, start) + textToInsert + value.slice(end);
// update cursor to be at the end of insertion
input.selectionStart = input.selectionEnd = start + textToInsert.length;
2019-07-23 08:27:24 +02:00
}
2019-08-05 21:26:57 +02:00
2019-07-23 08:27:24 +02:00
</script>
2019-08-05 21:26:57 +02:00
<style>html {
padding: 10px
}
#addBreakBtn {
position: fixed;
top: 10px;
right: 10px
}
#addEmphBtn {
position: fixed;
top: 10px;
right: 125px
}
2019-07-23 08:27:24 +02:00
2019-08-05 21:26:57 +02:00
#addSoundBtn {
position: fixed;
top: 10px;
right: 261px
}
</style>
2019-07-23 08:27:24 +02:00
</body>
2019-06-05 22:18:59 +02:00
</html>