86 lines
No EOL
2.2 KiB
HTML
86 lines
No EOL
2.2 KiB
HTML
<!DOCTYPE html>
|
|
<html lang='en'>
|
|
<head>
|
|
<title>{title}</title>
|
|
<link href="../images/favicon/favicon-16x16.png" rel="icon" type="image/png"/>
|
|
<link href="../../images/favicon/favicon-16x16.png" rel="icon" type="image/png"/>
|
|
|
|
<!-- for code formatting -->
|
|
<link rel="stylesheet" href="../templates/hybrid.min.css">
|
|
<link rel="stylesheet" href="../../templates/hybrid.min.css">
|
|
<script src="../templates/highlight.min.js"></script>
|
|
<script src="../../templates/highlight.min.js"></script>
|
|
<script>hljs.highlightAll()</script>
|
|
</head>
|
|
<body>
|
|
{body}
|
|
</body>
|
|
<style>
|
|
section.slide {
|
|
position: absolute;
|
|
top: 50%;
|
|
left: 50%;
|
|
transform: translate(-50%, -50%) scale(2);
|
|
}
|
|
ol, ul {
|
|
margin-top: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
img{
|
|
display: block;
|
|
margin-left: auto;
|
|
margin-right: auto;
|
|
max-width: 40%;
|
|
max-height: 40%;
|
|
}
|
|
</style>
|
|
<script>
|
|
let slide_number = 0;
|
|
let slide_max = 0;
|
|
|
|
for (let section of document.querySelectorAll("section.slide")) {
|
|
let number = parseInt(section.id, 10);
|
|
if (number > slide_max) {
|
|
slide_max = number;
|
|
}
|
|
}
|
|
|
|
slide_next = (change) => {
|
|
// make old hidden
|
|
document.getElementById(`${slide_number}`).style.display = "none";
|
|
|
|
// make the change
|
|
let slide_number_new = slide_number + change;
|
|
if (slide_number_new >= 0 && slide_number_new <= slide_max) {
|
|
slide_number += change;
|
|
}
|
|
|
|
// make current visible
|
|
document.getElementById(`${slide_number}`).style.display = "block";
|
|
}
|
|
|
|
// add event listner
|
|
onkeydown = (event) => {
|
|
if (event.key === "ArrowRight" || event.key === "ArrowDown") {
|
|
slide_next(1);
|
|
}
|
|
if (event.key === "ArrowLeft" || event.key === "ArrowUp") {
|
|
slide_next(-1);
|
|
}
|
|
};
|
|
|
|
on_events = (clickTargetWidth, xCoordInClickTarget) => {
|
|
if (clickTargetWidth / 2 > xCoordInClickTarget) {
|
|
slide_next(-1);
|
|
} else {
|
|
slide_next(1);
|
|
}
|
|
}
|
|
|
|
ontouchstart = (event) => {
|
|
on_events(event.target.offsetWidth, event.touches[0].clientX - event.target.getBoundingClientRect().left);
|
|
};
|
|
// show the first slide
|
|
slide_next(0)
|
|
</script>
|
|
</html> |