- Express + EJS + express-session stack (auth/navbar ported from minecraft_launcher)
- Public: main folder list, folder video grid, internal popup player (/player/:videoId)
- Admin (/op): login, folder CRUD with right-click context menu + add-folder modal
- Admin folder: video grid with right-click edit/rename/delete, "영상 추가" -> editor
- Video editor: drag-drop upload, file picker, YouTube URL probe (ETA + 5분 경고),
background yt-dlp download with progress polling, navbar title edit, trim controls,
save runs ffmpeg trim (original preserved)
- Filesystem storage under data/folders/<name>/<videoId>/{meta.json, original.<ext>, edited.<ext>}
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
31 lines
1.0 KiB
Plaintext
31 lines
1.0 KiB
Plaintext
<header class="topNav">
|
|
<a class="navBrand" href="/op/dashboard">
|
|
<span class="navLogo">🎬</span>
|
|
<span class="navTitle">비디오 사이트 관리</span>
|
|
</a>
|
|
<div class="navUser">
|
|
<button type="button" class="navUserButton" id="userMenuToggle"><%= userId %></button>
|
|
<div class="navUserMenu" id="userMenu" hidden>
|
|
<form method="post" action="/op/logout">
|
|
<button type="submit" class="dangerLink">로그아웃</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</header>
|
|
<script>
|
|
(function () {
|
|
var toggle = document.getElementById('userMenuToggle')
|
|
var menu = document.getElementById('userMenu')
|
|
if (!toggle || !menu) return
|
|
toggle.addEventListener('click', function () {
|
|
var hidden = menu.hasAttribute('hidden')
|
|
if (hidden) menu.removeAttribute('hidden')
|
|
else menu.setAttribute('hidden', '')
|
|
})
|
|
document.addEventListener('click', function (event) {
|
|
if (event.target === toggle || menu.contains(event.target)) return
|
|
menu.setAttribute('hidden', '')
|
|
})
|
|
})()
|
|
</script>
|