Add HTML shell, CSS layout, and dev server
This commit is contained in:
parent
fcf8de7f75
commit
933b6fc452
3 changed files with 115 additions and 0 deletions
41
index.html
Normal file
41
index.html
Normal file
|
|
@ -0,0 +1,41 @@
|
||||||
|
<!doctype html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<title>slay with friends</title>
|
||||||
|
<link rel="stylesheet" href="style.css">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div id="game">
|
||||||
|
<section id="enemy-zone">
|
||||||
|
<div id="enemy-info">
|
||||||
|
<span id="enemy-name"></span>
|
||||||
|
<div id="enemy-hp-bar"><span id="enemy-hp"></span></div>
|
||||||
|
<span id="enemy-block"></span>
|
||||||
|
<div id="enemy-status"></div>
|
||||||
|
<div id="enemy-intent"></div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section id="info-bar">
|
||||||
|
<div id="energy"></div>
|
||||||
|
<div id="player-hp-bar"><span id="player-hp"></span></div>
|
||||||
|
<div id="player-block"></div>
|
||||||
|
<div id="player-strength"></div>
|
||||||
|
<div id="player-status"></div>
|
||||||
|
<div id="pile-counts">
|
||||||
|
<button id="draw-pile-btn">draw: <span id="draw-count">0</span></button>
|
||||||
|
<button id="discard-pile-btn">discard: <span id="discard-count">0</span></button>
|
||||||
|
</div>
|
||||||
|
<button id="end-turn-btn">end turn</button>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section id="hand"></section>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="overlay" hidden></div>
|
||||||
|
|
||||||
|
<script type="module" src="src/main.js"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
13
src/serve.js
Normal file
13
src/serve.js
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
const server = Bun.serve({
|
||||||
|
port: 3000,
|
||||||
|
async fetch(req) {
|
||||||
|
const url = new URL(req.url);
|
||||||
|
let path = url.pathname === "/" ? "/index.html" : url.pathname;
|
||||||
|
const file = Bun.file(`.${path}`);
|
||||||
|
if (await file.exists()) {
|
||||||
|
return new Response(file);
|
||||||
|
}
|
||||||
|
return new Response("not found", { status: 404 });
|
||||||
|
},
|
||||||
|
});
|
||||||
|
console.debug(`dev server: http://localhost:${server.port}`);
|
||||||
61
style.css
Normal file
61
style.css
Normal file
|
|
@ -0,0 +1,61 @@
|
||||||
|
* { margin: 0; padding: 0; box-sizing: border-box; }
|
||||||
|
|
||||||
|
#game {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
height: 100dvh;
|
||||||
|
max-width: 500px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
#enemy-zone {
|
||||||
|
flex: 4;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
#info-bar {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: 8px;
|
||||||
|
padding: 4px 8px;
|
||||||
|
border-top: 1px solid #ccc;
|
||||||
|
border-bottom: 1px solid #ccc;
|
||||||
|
}
|
||||||
|
|
||||||
|
#hand {
|
||||||
|
flex: 3;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
padding: 8px;
|
||||||
|
overflow-x: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
#hand .card {
|
||||||
|
width: 80px;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: transform 0.15s;
|
||||||
|
}
|
||||||
|
|
||||||
|
#hand .card.selected {
|
||||||
|
transform: translateY(-20px);
|
||||||
|
}
|
||||||
|
|
||||||
|
#hand .card.no-energy {
|
||||||
|
opacity: 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
#overlay {
|
||||||
|
position: fixed;
|
||||||
|
inset: 0;
|
||||||
|
background: rgba(0,0,0,0.7);
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
color: white;
|
||||||
|
font-size: 2rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
#overlay[hidden] { display: none; }
|
||||||
Loading…
Reference in a new issue