Add initial implementation of P2P Poll app with HTML, CSS, and JavaScript

This commit is contained in:
2026-03-07 19:34:19 +01:00
parent 4275cbd795
commit 06afbc46f6
4 changed files with 373 additions and 1 deletions

55
index.html Normal file
View File

@@ -0,0 +1,55 @@
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
<title>P2P Poll</title>
<link rel="stylesheet" href="styles.css" />
<!-- Gun.js via CDN for quick start -->
<script src="https://unpkg.com/gun/gun.js"></script>
</head>
<body>
<div class="container">
<h1>P2P Poll</h1>
<section id="setup" class="card">
<h2>Start or Join Poll</h2>
<div class="field">
<label for="pollId">Poll ID (share with peer):</label>
<input id="pollId" type="text" placeholder="e.g. my-poll-123" />
</div>
<button id="loadPollBtn">Load Poll</button>
<button id="createPollBtn">Create New Poll</button>
<p class="note">Tip: You can run two instances and connect by using the same Poll ID.</p>
</section>
<section id="poll" class="card" style="display:none;">
<h2>Poll</h2>
<div class="field">
<label for="pollTitle">Poll Title</label>
<input id="pollTitle" type="text" placeholder="Poll Title" />
<button id="setTitleBtn">Set Title</button>
</div>
<div id="options" class="options">
<!-- dynamic options will render here -->
</div>
<div class="field">
<input id="newOption" type="text" placeholder="Add a new option" />
<button id="addOptionBtn">Add Option</button>
</div>
<div class="summary">
<p>Total votes: <span id="totalVotes">0</span></p>
</div>
<div class="share">
<p>Share Poll ID with peer: <code id="pollIdDisplay"></code></p>
</div>
</section>
</div>
<script src="app.js"></script>
</body>
</html>