Skip to content

Commit

Permalink
fix loading contents on dashboard
Browse files Browse the repository at this point in the history
  • Loading branch information
zshipko committed Nov 21, 2022
1 parent 8abfbe3 commit b034337
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 33 deletions.
30 changes: 19 additions & 11 deletions src/irmin-server/unix/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -65,9 +65,9 @@
#path, #branch {
padding: 5px;
margin: 5px;
font-size: 110%%;
font-size: 110%;
border: 1px solid #ddd;
width: 75%%;
width: 75%;
background: #222;
color: #ddd;
}
Expand All @@ -76,7 +76,7 @@
padding: 5px;
margin: 5px;
font-family: monospace;
font-size: 130%%;
font-size: 130%;
}

h1, h2 {
Expand Down Expand Up @@ -118,7 +118,7 @@
}

.content-hash {
font-size: 115%%;
font-size: 115%;
border: 1px solid #ddd;
padding: 10px;
margin-bottom: 20px;
Expand All @@ -133,7 +133,7 @@
vertical-align: middle;
width: 30px;
padding-bottom: 5px;
filter: invert(100%%);
filter: invert(100%);
}
</style>
</head>
Expand All @@ -143,11 +143,11 @@
</a>
<h2 class="branch-area">
<img src="">
<input id="branch" value="%s" />
<input id="branch" value="" />
</div>
<h2 class="path-area">
<img alt="svgImg" src=""/>
<input id="path" value="%s"/>
<input id="path" value=""/>
<span class="no-select" id="up">&uarr;</span>
<span class="no-select" id="refresh">&#8635;</span>
</h2>
Expand Down Expand Up @@ -201,9 +201,9 @@ <h2 class="path-area">
}
return lines.join("<br>");
}

+ "</pre>"
function getContents(data) {
if (typeof data.contents === "string") return data.contents;
if (typeof data.contents === "string") return "<pre>" + data.contents + "</pre>";

if (data.contents.base64){
let b = atob(data.contents.base64);
Expand All @@ -219,13 +219,15 @@ <h2 class="path-area">
if (state.path !== path || state.branch !== branch){
history.pushState({path: path, branch: branch}, '');
}

pathInput.value = path;

fetch(path + "?branch=" + branch, {method: 'POST'})
.then(r => r.json())
.then(data => {
list.innerHTML = "";
document.getElementById("contents").innerHTML = "";
if (data.contents !== undefined){
if (data.contents){
let html = "<div class='content-hash'>" + data.hash + "</div>";
html += getContents(data);
document.getElementById("contents").innerHTML = html;
Expand All @@ -237,7 +239,6 @@ <h2 class="path-area">
});
}

update(pathInput.value, branchInput.value);

pathInput.onkeydown = function(e){
if (e.keyCode == 13){
Expand Down Expand Up @@ -265,6 +266,13 @@ <h2 class="path-area">
update(event.state.path, event.state.branch);
}
}

window.onload = function() {
let params = new URLSearchParams(window.location.search);
pathInput.value = window.location.pathname;
branchInput.value = params.get("branch") || "main";
update(pathInput.value, branchInput.value);
}
</script>
</body>
</html>
35 changes: 13 additions & 22 deletions src/irmin-server/unix/server.ml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ open Lwt.Infix
open Irmin_server
include Server_intf

let html = [%blob "index.html"]

module Make (Codec : Conn.Codec.S) (Store : Irmin.Generic_key.S) = struct
module Command = Command.Make (IO) (Codec) (Store)
module Store = Store
Expand Down Expand Up @@ -283,28 +285,20 @@ module Make (Codec : Conn.Codec.S) (Store : Irmin.Generic_key.S) = struct
| `Branch branch -> Store.of_branch t.repo branch
in
let* is_contents =
Store.kind store prefix >|= fun x -> x = Some `Contents
Store.kind store prefix >|= function
| Some `Contents -> true
| _ -> false
in
let res = Cohttp_lwt_unix.Response.make () in
let res = Cohttp_lwt_unix.Response.make ~status:`OK () in
if is_contents then
let* contents = Store.get store prefix in
let contents' = Irmin.Type.to_json_string Store.contents_t contents in
let* last_mod = Store.last_modified store prefix in
let last_mod =
String.concat ", "
(List.map
(fun c ->
Store.Commit.hash c |> Irmin.Type.to_json_string Store.hash_t)
last_mod)
in
let body =
Cohttp_lwt.Body.of_string
(Printf.sprintf
{|{"contents": %s, "hash": %s, "last_modified": [%s]}|} contents'
(Irmin.Type.to_json_string Store.hash_t
(Store.Contents.hash contents))
last_mod)
Printf.sprintf {|{"contents": %s, "hash": %s }|} contents'
(Irmin.Type.to_json_string Store.hash_t
(Store.Contents.hash contents))
in
let body = Cohttp_lwt.Body.of_string body in
Lwt.return (res, body)
else
let* keys = list store prefix in
Expand All @@ -319,6 +313,7 @@ module Make (Codec : Conn.Codec.S) (Store : Irmin.Generic_key.S) = struct
keys
in
let keys = String.concat "," keys in

let body = Cohttp_lwt.Body.of_string (Printf.sprintf "[%s]" keys) in
Lwt.return (res, body)
in
Expand All @@ -342,14 +337,10 @@ module Make (Codec : Conn.Codec.S) (Store : Irmin.Generic_key.S) = struct
| `POST -> data_callback prefix branch
| `GET ->
let res = Cohttp_lwt_unix.Response.make () in
let body =
Cohttp_lwt.Body.of_string
@@ Printf.sprintf [%blob "index.html"] branch_name path
in
let body = Cohttp_lwt.Body.of_string html in
Lwt.return (res, body)
| _ ->
let status = `Not_found in
let res = Cohttp_lwt_unix.Response.make ~status () in
let res = Cohttp_lwt_unix.Response.make ~status:`Not_found () in
let body = Cohttp_lwt.Body.of_string "Not found" in
Lwt.return (res, body)
in
Expand Down

0 comments on commit b034337

Please sign in to comment.