import { showToast } from '../components/toast.js'; import { t } from '../i18n.js'; const API = (url, opts = {}) => fetch('/api' + url, { headers: { 'Content-Type': 'application/json', Authorization: `Bearer ${localStorage.getItem('token')}`, ...opts.headers }, ...opts }).then(r => r.json()); export async function render(container) { const hash = window.location.hash; if (hash.startsWith('#/kiosk/')) { const id = hash.split('#/kiosk/')[1]; return renderEditor(container, id); } return renderList(container); } async function renderList(container) { container.innerHTML = `
${t('kiosk.empty_desc')}
${t('kiosk.no_buttons')}
`; list.querySelectorAll('[data-btn]').forEach(input => { input.oninput = () => { const idx = parseInt(input.dataset.btn); const field = input.dataset.field; if (field === 'url' && config.buttons[idx].action === 'page') config.buttons[idx].page = input.value; else config.buttons[idx][field] = input.tagName === 'SELECT' ? input.value : input.value; }; }); list.querySelectorAll('[data-remove-btn]').forEach(btn => { btn.onclick = () => { config.buttons.splice(parseInt(btn.dataset.removeBtn), 1); renderButtons(); }; }); } document.getElementById('addBtnBtn').onclick = () => { config.buttons.push({ label: t('kiosk.new_button'), sublabel: '', icon: '⭐', action: '', url: '' }); renderButtons(); }; document.getElementById('saveKioskBtn').onclick = async () => { config.title = document.getElementById('kTitle').value; config.subtitle = document.getElementById('kSubtitle').value; config.logoUrl = document.getElementById('kLogo').value; config.footer = document.getElementById('kFooter').value; config.idleTitle = document.getElementById('kIdleTitle').value; config.idleTimeout = parseInt(document.getElementById('kIdleTimeout').value) || 60; config.style = { ...config.style, background: document.getElementById('kBg').value, textColor: document.getElementById('kTextColor').value, columns: parseInt(document.getElementById('kColumns').value), buttonBg: document.getElementById('kBtnBg').value, buttonHover: document.getElementById('kBtnHover').value, }; try { await API(`/kiosk/${pageId}`, { method: 'PUT', body: JSON.stringify({ config }) }); showToast(t('kiosk.toast.saved'), 'success'); document.getElementById('kioskPreview').src = `/api/kiosk/${pageId}/render?t=${Date.now()}`; } catch (err) { showToast(err.message, 'error'); } }; renderButtons(); } export function cleanup() {}