-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.html
More file actions
96 lines (93 loc) · 4.07 KB
/
index.html
File metadata and controls
96 lines (93 loc) · 4.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>StreamDirector</title>
<link rel="stylesheet" href="styles.css" />
</head>
<body>
<div id="app" class="app">
<!-- Sidebar -->
<aside class="sidebar" id="sidebar">
<div class="sidebar-header">
<form class="add-channel" id="add-channel-form" autocomplete="off">
<input
type="text"
id="add-channel-input"
class="add-channel-input"
placeholder="Add channel…"
pattern="[a-zA-Z0-9_]+"
/>
<button type="submit" class="add-channel-btn" title="Add channel">+</button>
</form>
</div>
<ul class="channel-list" id="channel-list"></ul>
<div class="sidebar-footer">
<button class="start-all-btn" id="start-all" title="Start all live players">
▶ Start All
</button>
<button class="import-btn" id="import-btn" title="Import channel list">Import</button>
<span class="hotkey-hint"
>←→ cycle · F last · S sidebar · C chat</span
>
</div>
</aside>
<!-- Main content: single grid, all players as direct children -->
<main class="content" id="content">
<div class="focus-empty" id="focus-empty">
<div class="focus-empty-icon">▶</div>
<span>Select a channel to start</span>
</div>
<!-- Branding cell: bottom-left corner (logo + buttons + drag handle) -->
<div class="branding" id="branding">
<span class="branding-logo" title="Drag to move window"
>Stream<span class="logo-accent">Director</span></span
>
<a
class="github-link"
href="https://github.com/stefanpoensgen/stream-director"
target="_blank"
title="GitHub"
>
<svg viewBox="0 0 16 16" width="12" height="12" fill="currentColor">
<path
d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27s1.36.09 2 .27c1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.01 8.01 0 0 0 16 8c0-4.42-3.58-8-8-8z"
/>
</svg>
<span class="version"></span>
</a>
<button class="close-btn" id="close-btn" title="Close">✕</button>
<div class="branding-buttons">
<button class="sidebar-toggle" id="sidebar-toggle" title="Toggle sidebar (S)">
Menu
</button>
<button class="chat-btn" id="chat-btn" title="Open chat for focused channel (C)">
Chat
</button>
<button class="twitch-login-btn" id="twitch-login" title="Twitch Login">Login</button>
</div>
</div>
</main>
</div>
<!-- Import Modal -->
<div class="import-overlay hidden" id="import-overlay">
<div class="import-modal">
<div class="import-title">Import Channels</div>
<textarea
class="import-textarea"
id="import-textarea"
placeholder="One channel per line, e.g. shroud pokimane xqc"
rows="12"
></textarea>
<div class="import-actions">
<button class="import-cancel" id="import-cancel">Cancel</button>
<button class="import-confirm" id="import-confirm">Import</button>
</div>
</div>
</div>
<!-- Twitch Embed Player API (only external resource) -->
<script src="https://player.twitch.tv/js/embed/v1.js"></script>
<script type="module" src="app.js"></script>
</body>
</html>