238 lines
6.4 KiB
HTML
Raw Normal View History

2021-02-18 10:48:58 +01:00
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style type="text/css">
html, body {
height: 100%;
}
body {
font-family: sans-serif;
font-size: 1rem;
margin: 0;
display: grid;
grid-template-areas: "nav nav" "items details";
grid-template-columns: 1fr 400px;
grid-template-rows: auto 1fr;
min-height: 0;
}
main {
grid-area: items;
min-width: 0;
min-height: 0;
overflow-y: auto;
2021-02-18 12:02:26 +01:00
padding: 8px;
2021-02-18 10:48:58 +01:00
}
main section h2 {
margin: 2px 14px;
font-size: 1rem;
}
2021-02-18 10:48:58 +01:00
aside {
grid-area: details;
2021-02-18 11:08:43 +01:00
padding: 8px;
2021-02-18 10:48:58 +01:00
}
aside h3 {
word-wrap: anywhere;
}
2021-02-18 11:08:43 +01:00
aside p {
margin: 2px 0;
}
2021-02-18 10:48:58 +01:00
aside .values li span {
word-wrap: ;
word-wrap: anywhere;
padding: 4px;
2021-02-18 10:48:58 +01:00
}
aside .values {
list-style: none;
padding: 0;
2021-02-18 11:08:43 +01:00
border: 1px solid lightgray;
2021-02-18 10:48:58 +01:00
}
2021-02-18 11:08:43 +01:00
aside .values span.key {
width: 30%;
2021-02-18 10:48:58 +01:00
display: block;
}
2021-02-18 11:08:43 +01:00
aside .values span.value {
width: 70%;
display: block;
white-space: pre-wrap;
2021-02-18 11:08:43 +01:00
}
2021-02-18 10:48:58 +01:00
aside .values li {
display: flex;
2021-02-18 11:08:43 +01:00
}
aside .values li:not(:first-child) {
border-top: 1px solid lightgray;
2021-02-18 10:48:58 +01:00
}
nav {
grid-area: nav;
}
2021-02-18 11:26:27 +01:00
.timeline li:not(.expanded) > ol {
display: none;
}
.timeline li > div {
display: flex;
}
.timeline .toggleExpanded {
border: none;
background: none;
width: 24px;
height: 24px;
margin-right: 4px;
cursor: pointer;
}
.timeline .toggleExpanded:before {
content: "▶";
}
.timeline li.expanded > div > .toggleExpanded:before {
content: "▼";
}
2021-02-18 10:48:58 +01:00
.timeline ol {
list-style: none;
padding: 0 0 0 20px;
margin: 0;
2021-02-18 10:48:58 +01:00
}
2021-02-23 22:11:01 +01:00
.timeline .item {
2021-02-18 10:48:58 +01:00
--hue: 100deg;
--brightness: 80%;
background-color: hsl(var(--hue), 60%, var(--brightness));
border: 1px solid hsl(var(--hue), 60%, calc(var(--brightness) - 40%));
border-radius: 4px;
padding: 2px;
display: flex;
margin: 1px;
2021-02-18 11:26:27 +01:00
flex: 1;
min-width: 0;
2021-02-23 22:11:01 +01:00
color: inherit;
text-decoration: none;
2021-02-18 11:26:27 +01:00
}
2021-02-23 22:11:01 +01:00
.timeline .item:not(.has-children) {
2021-02-18 11:26:27 +01:00
margin-left: calc(24px + 4px + 1px);
2021-02-18 10:48:58 +01:00
}
2021-02-23 22:11:01 +01:00
.timeline .item .caption {
2021-02-18 10:48:58 +01:00
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
flex: 1;
}
2021-02-19 11:57:57 +01:00
.timeline .item.level-3 {
2021-02-18 10:48:58 +01:00
--brightness: 90%;
}
2021-02-19 11:57:57 +01:00
.timeline .item.level-2 {
--brightness: 95%;
}
.timeline .item.level-5 {
--brightness: 80%;
}
2021-02-18 10:48:58 +01:00
2021-02-19 11:57:57 +01:00
.timeline .item.level-6, .timeline .item.level-7 {
2021-02-18 10:48:58 +01:00
--hue: 0deg !important;
}
2021-02-19 11:57:57 +01:00
.timeline .item.level-7 {
--brightness: 50%;
color: white;
}
2021-02-23 22:11:01 +01:00
.timeline .item.type-network {
2021-02-18 10:48:58 +01:00
--hue: 30deg;
}
2022-05-04 18:44:11 +02:00
.timeline .item.type-call {
--hue: 50deg;
}
2021-02-23 22:11:01 +01:00
.timeline .item.type-navigation {
2021-02-19 11:57:57 +01:00
--hue: 200deg;
}
2021-02-23 22:11:01 +01:00
.timeline .item.selected {
2021-02-18 10:48:58 +01:00
background-color: Highlight;
border-color: Highlight;
color: HighlightText;
}
.timeline .item.highlighted {
background-color: fuchsia;
color: white;
}
2021-02-18 10:48:58 +01:00
.hidden {
display: none;
}
#highlight {
width: 300px;
}
nav form {
display: inline;
}
2022-05-04 18:44:11 +02:00
#filename {
margin: 0;
font-size: 1rem;
padding: 4px 0;
}
2021-02-18 10:48:58 +01:00
</style>
</head>
<body>
<nav>
2022-05-04 18:44:11 +02:00
<div>
<button id="openFile">Open log file</button>
<button id="collapseAll">Collapse all</button>
<button id="hideCollapsed">Hide collapsed root items</button>
<button id="hideHighlightedSiblings" title="Hide collapsed siblings of highlighted">Hide non-highlighted</button>
<button id="showAll">Show all</button>
<form id="highlightForm">
<input type="text" id="highlight" name="highlight" placeholder="Highlight a search term" autocomplete="on">
<output id="highlightMatches"></output>
</form>
</div>
<h2 id="filename"></h2>
</nav>
2021-02-18 10:48:58 +01:00
<main></main>
<aside></aside>
<script type="module" src="main.js"></script>
<script type="module">
import {loadBlob} from "./main.js";
window.addEventListener("message", event => {
console.log("message", event);
if (event.data.type === "open") {
document.getElementById("filename").innerText = "Loading logs from other tab...";
loadBlob(event.data.logs).then(() => {
document.getElementById("filename").innerText = "Logs from other tab at " + new Date();
});
} else if (event.data.type === "ping") {
document.getElementById("filename").innerText = "Waiting for logs from other tab...";
event.source.postMessage({type: "pong"});
}
});
</script>
2021-02-18 10:48:58 +01:00
</body>
</html>