forked from lbovet/docson
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
115 lines (108 loc) · 3.92 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
<!DOCTYPE html>
<!--
~ Copyright 2013 Laurent Bovet <[email protected]>
~
~ Licensed under the Apache License, Version 2.0 (the "License");
~ you may not use this file except in compliance with the License.
~ You may obtain a copy of the License at
~
~ http://www.apache.org/licenses/LICENSE-2.0
~
~ Unless required by applicable law or agreed to in writing, software
~ distributed under the License is distributed on an "AS IS" BASIS,
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
~ See the License for the specific language governing permissions and
~ limitations under the License.
-->
<html>
<head>
<meta charset="utf-8">
<link rel="stylesheet" href="css/docson.css">
<script src="lib/require.js"></script>
<script>
require(["docson", "lib/jquery"], function(docson) {
$(function () {
var embedded = window.parent !== window;
if (embedded) {
$("body").addClass("embedded");
$("doc").addClass("embedded");
}
$("#url").keypress(function (event) {
if (event.keyCode == 13) {
window.location.hash = $(this).val();
}
});
$(window).on('hashchange', function () {
update();
});
update();
var url;
function update() {
if (window.location.hash) {
$("#form").hide();
url = decodeURIComponent(window.location.hash.substring(1));
var segments = url.split("$");
function render(schema) {
try {
docson.doc("doc", schema, segments[1]);
} catch (e) {
error("Could not parse schema: " + e.message + "<pre>" + $('<pre/>').text(schema).html() + "</pre>");
}
}
if(/\.ts$/.test(segments[0])) {
require.config( { baseUrl: "../typson" } );
require(["typson-schema"], function(typson) {
typson.definitions(segments[0]).done(render);
});
} else {
$.get(segments[0])
.done(render)
.fail(function (xhr, status, err) {
error("Could not load " + segments[0] + ": " + status + " " + err);
});
}
} else {
$("#doc").empty();
$("#form").show();
}
}
function error(message) {
$("#form").show();
$("#doc").html($("<div/>").addClass("error")
.html(message));
}
var doc = $('#doc').get(0);
if(embedded) {
doc.onresize = function(height) {
parent.postMessage( { id: "docson", url: url, height: height}, "*");
}
}
});
});
</script>
<style>
body {
font-family: verdana, helvetica;
}
#form {
display: none;
}
#form input[type=text] {
border-radius: 6px;
-moz-border-radius: 6px;
-webkit-border-radius: 6px;
}
.embedded {
margin: 0px;
padding: 0px;
}
</style>
</head>
<body>
<div id="form">
Please enter a schema URL:
<input type="text" id="url" size="60">
</div>
<div id="doc"></div>
</body>
</html>