import { API, showError } from '../shared.js'; export const page = { title: 'MAC Vendor Lookup', template: () => `

MAC Address Vendor Lookup

`, async init(search) { const input = document.getElementById('mac-input'); const btn = document.getElementById('mac-lookup-button'); const errorEl = document.getElementById('mac-lookup-error'); const section = document.getElementById('mac-lookup-results-section'); const queryEl = document.getElementById('mac-lookup-query'); const loader = document.getElementById('mac-lookup-loader'); const output = document.getElementById('mac-lookup-output'); const syncBtn = () => { btn.disabled = !input.value.trim(); }; input.addEventListener('input', syncBtn); async function doLookup() { const mac = input.value.trim(); if (!mac) return; showError(errorEl, null); section.classList.remove('hidden'); loader.classList.remove('hidden'); output.textContent = ''; queryEl.textContent = mac; try { const r = await fetch(`${API}/mac-lookup?mac=${encodeURIComponent(mac)}`); const data = await r.json(); if (!r.ok || !data.success) throw new Error(data.error || `HTTP ${r.status}`); output.textContent = data.vendor || 'No vendor found.'; } catch (err) { showError(errorEl, err.message); output.textContent = ''; } finally { loader.classList.add('hidden'); } } btn.addEventListener('click', doLookup); input.addEventListener('keypress', e => { if (e.key === 'Enter' && !btn.disabled) doLookup(); }); const params = new URLSearchParams(search); const m = params.get('mac'); if (m) { input.value = m; syncBtn(); doLookup(); } } };