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, '&');
|
|
|
|
input = input.replace(/</g, '<');
|
|
|
|
input = input.replace(/>/g, '>');
|
|
|
|
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>
|