import { API, setupCopyBtn, showError } from '../shared.js';
export const page = {
title: 'WHOIS Lookup',
template: () => `
`,
async init(search) {
const input = document.getElementById('whois-query-input');
const btn = document.getElementById('whois-lookup-button');
const errorEl = document.getElementById('whois-lookup-error');
const section = document.getElementById('whois-lookup-results-section');
const queryEl = document.getElementById('whois-lookup-query');
const loader = document.getElementById('whois-lookup-loader');
const output = document.getElementById('whois-lookup-output');
const copyBtn = document.getElementById('copy-whois-btn');
const syncBtn = () => { btn.disabled = !input.value.trim(); };
input.addEventListener('input', syncBtn);
setupCopyBtn(copyBtn, () => output.textContent);
async function doLookup() {
const query = input.value.trim();
if (!query) return;
const url = new URL(location.href);
url.searchParams.set('query', query);
history.replaceState({}, '', url);
showError(errorEl, null);
section.classList.remove('hidden');
loader.classList.remove('hidden');
output.textContent = '';
queryEl.textContent = query;
try {
const r = await fetch(`${API}/whois-lookup?query=${encodeURIComponent(query)}`);
const data = await r.json();
if (!r.ok || !data.success) throw new Error(data.error || `HTTP ${r.status}`);
output.textContent = typeof data.result === 'string'
? data.result
: JSON.stringify(data.result, null, 2);
} 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 q = params.get('query');
if (q) { input.value = q; syncBtn(); doLookup(); }
}
};