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(); }
}
};