mirror of
https://github.com/syssecfsu/witty.git
synced 2024-11-24 21:09:29 +01:00
114 lines
3.5 KiB
HTML
114 lines
3.5 KiB
HTML
<!doctype html>
|
|
<html>
|
|
|
|
<head>
|
|
<meta charset="UTF-8" />
|
|
<link rel="icon" type="image/x-icon" href="/assets/img/logo.svg">
|
|
|
|
<script src="/assets/external/xterm.js"></script>
|
|
<script src="/assets/external/xterm-addon-attach.js"></script>
|
|
<script src="/assets/external/xterm-addon-fit.js"></script>
|
|
<script src="/assets/external/xterm-addon-web-links.js"></script>
|
|
|
|
<script src="/assets/replay.js"></script>
|
|
|
|
<link rel="stylesheet" href="/assets/external/xterm.css" />
|
|
<link href="/assets/external/bootstrap.min.css" rel="stylesheet">
|
|
<link rel="stylesheet" href="/assets/main.css" />
|
|
|
|
<title>Replay</title>
|
|
</head>
|
|
|
|
<body>
|
|
<header>
|
|
<nav class="navbar navbar-light bg-light shadow-sm navbar-xs">
|
|
<div class="container-fluid">
|
|
<a class="navbar-brand mx-auto" href="https://github.com/syssecfsu/witty" target="_blank">
|
|
<img src="/assets/img/record.svg" style="margin-right: 0.5rem;" height="32"
|
|
class="d-inline-block align-text-top">
|
|
replay terminal
|
|
</a>
|
|
</div>
|
|
</nav>
|
|
</header>
|
|
|
|
|
|
<div class="d-flex flex-column align-items-center" style="margin-top: 2rem;">
|
|
<div id="terminal">
|
|
<div id="terminal_view"></div>
|
|
</div>
|
|
<div class="d-flex align-items-center">
|
|
<button type="button" class="btn btn-primary btn-sm" style="margin-right: 3px;" onclick="playbtn()">
|
|
<img src="/assets/img/play.svg" id="play-btn" height="18px">
|
|
</button>
|
|
<input type="range" class="form-range" min="0" max="100" id="replay-control" step="1"
|
|
oninput="seek(this.value)">
|
|
</div>
|
|
</div>
|
|
|
|
<script>
|
|
term = Init()
|
|
|
|
var rc = document.querySelector("#replay-control")
|
|
rc.value = 0
|
|
|
|
var icon = document.getElementById("play-btn")
|
|
var pause = false
|
|
|
|
var records
|
|
var total_dur
|
|
|
|
// return values are not reliable with async functions
|
|
fetchAndParse("/records/{{.fname}}",
|
|
function (v1, v2) {
|
|
records = v1
|
|
total_dur = v2
|
|
})
|
|
|
|
function playbtn() {
|
|
if (icon.src.includes("play")) {
|
|
icon.src = "/assets/img/pause.svg"
|
|
pause = false
|
|
replay_session(term, records, {{.max_wait}}, total_dur, rc.value,
|
|
function () {
|
|
return pause
|
|
},
|
|
function (percent) {
|
|
rc.value = percent
|
|
},
|
|
function () {
|
|
icon.src = "/assets/img/play.svg"
|
|
rc.value = 0
|
|
})
|
|
} else {
|
|
icon.src = "/assets/img/play.svg"
|
|
pause = true
|
|
}
|
|
}
|
|
|
|
// limit the rate of refresh to twice per second. Otherwise
|
|
// the screen flicks like crazy
|
|
var lastFired = new Date().getTime()
|
|
|
|
function seek(end) {
|
|
var now = new Date().getTime()
|
|
var elapsed = now - lastFired
|
|
|
|
if (elapsed <= 500) {
|
|
return
|
|
}
|
|
|
|
lastFired = now
|
|
|
|
// pause the play if it is currently playing
|
|
if (!icon.src.includes("play")) {
|
|
playbtn()
|
|
}
|
|
|
|
forwardScreen(term, records, end)
|
|
}
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html> |