op/datapack: add painting_variant JSON zip export button

데이터팩 수정 페이지에 "이미지.zip 출력" 버튼과 크기 입력(기본 4, 1~16)
을 추가. 누르면 GET /op/datapack/:key/images-zip?size=N 으로 음악 개수만큼
cover_NN.json (asset_id, width=size, height=size, title, author) 을 zip 으로
스트리밍해서 내려준다. 사용자가 맵 데이터팩의 data/musicquiz/painting_variant/
에 그대로 풀어 넣을 수 있다.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
2026-05-14 23:22:23 +09:00
parent 212e70cd56
commit 848fac500e
3 changed files with 66 additions and 1 deletions

View File

@@ -27,6 +27,9 @@
<p class="muted" id="countLabel"></p>
<section class="dpActions" hidden id="dpActions">
<button type="button" class="secondaryButton" id="imagesZipBtn"><%= t('datapack.imagesZip') %></button>
<label class="muted" for="imagesZipSize" style="margin-left:4px;"><%= t('datapack.imagesZipSizeLabel') %></label>
<input type="number" id="imagesZipSize" value="4" min="1" max="16" style="width:60px;" />
<button type="button" class="secondaryButton" id="exportBtn"><%= t('datapack.export') %></button>
<button type="button" class="secondaryButton" id="copyBtn"><%= t('datapack.copy') %></button>
<span class="statusText" id="dp-status"></span>
@@ -119,6 +122,21 @@
})
.catch(function (err) { s.textContent = I18N.failed.replace('{{message}}', err.message); s.classList.add('error') })
})
document.getElementById('imagesZipBtn').addEventListener('click', function () {
if (!pickedKey) return
var sizeInput = document.getElementById('imagesZipSize')
var size = parseInt(sizeInput.value, 10)
if (!isFinite(size) || size < 1) size = 4
if (size > 16) size = 16
sizeInput.value = String(size)
var s = document.getElementById('dp-status')
s.textContent = I18N.imagesZipDownloading; s.classList.remove('error')
// 브라우저 기본 다운로드로 위임. 인증 쿠키는 자동으로 따라간다.
var url = '/op/datapack/' + encodeURIComponent(pickedKey) + '/images-zip?size=' + size
window.location.href = url
// 다운로드 시작은 비동기지만, 사용자에게 즉시 피드백.
setTimeout(function () { s.textContent = I18N.imagesZipDone }, 500)
})
document.getElementById('copyBtn').addEventListener('click', function () {
var out = document.getElementById('codeOut')
if (out.hidden) return