// SearchEngine Frontend JavaScript
// API endpoint
const API_BASE_URL = 'http://120.76.41.98:6002';
// Update API URL display
document.getElementById('apiUrl').textContent = API_BASE_URL;
// Handle Enter key in search input
function handleKeyPress(event) {
if (event.key === 'Enter') {
performSearch();
}
}
// Set query from example buttons
function setQuery(query) {
document.getElementById('searchInput').value = query;
performSearch();
}
// Perform search
async function performSearch() {
const query = document.getElementById('searchInput').value.trim();
if (!query) {
alert('请输入搜索关键词');
return;
}
// Get options (temporarily disable translation and embedding due to GPU issues)
const size = parseInt(document.getElementById('resultSize').value);
const enableTranslation = false; // Disabled temporarily
const enableEmbedding = false; // Disabled temporarily
const enableRerank = document.getElementById('enableRerank').checked;
// Show loading
document.getElementById('loading').style.display = 'block';
document.getElementById('results').innerHTML = '';
document.getElementById('queryInfo').innerHTML = '';
try {
const response = await fetch(`${API_BASE_URL}/search/`, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
query: query,
size: size,
enable_translation: enableTranslation,
enable_embedding: enableEmbedding,
enable_rerank: enableRerank
})
});
if (!response.ok) {
throw new Error(`HTTP ${response.status}: ${response.statusText}`);
}
const data = await response.json();
displayResults(data);
displayQueryInfo(data.query_info);
} catch (error) {
console.error('Search error:', error);
document.getElementById('results').innerHTML = `
搜索出错: ${error.message}
请确保后端服务正在运行 (${API_BASE_URL})
`;
} finally {
document.getElementById('loading').style.display = 'none';
}
}
// Display search results
function displayResults(data) {
const resultsDiv = document.getElementById('results');
if (!data.hits || data.hits.length === 0) {
resultsDiv.innerHTML = `
`;
return;
}
let html = `
`;
data.hits.forEach((hit, index) => {
const source = hit._source;
const score = hit._custom_score || hit._score;
html += `
${source.categoryName ? `📁 ${escapeHtml(source.categoryName)}` : ''}
${source.brandName ? `🏷️ ${escapeHtml(source.brandName)}` : ''}
${source.supplierName ? `🏭 ${escapeHtml(source.supplierName)}` : ''}
${source.create_time ? `📅 ${formatDate(source.create_time)}` : ''}
${source.imageUrl ? `
})
` : ''}
ID: ${source.skuId || 'N/A'}
`;
});
resultsDiv.innerHTML = html;
}
// Display query processing information
function displayQueryInfo(queryInfo) {
if (!queryInfo) return;
const queryInfoDiv = document.getElementById('queryInfo');
let html = `
查询处理信息
原始查询
${escapeHtml(queryInfo.original_query || 'N/A')}
重写后查询
${escapeHtml(queryInfo.rewritten_query || 'N/A')}
检测语言
${getLanguageName(queryInfo.detected_language)}
查询域
${escapeHtml(queryInfo.domain || 'default')}
`;
// Show translations if any
if (queryInfo.translations && Object.keys(queryInfo.translations).length > 0) {
html += '翻译结果
';
for (const [lang, translation] of Object.entries(queryInfo.translations)) {
if (translation) {
html += `
${getLanguageName(lang)}
${escapeHtml(translation)}
`;
}
}
html += '
';
}
// Show embedding info
if (queryInfo.has_vector) {
html += `
✓ 使用了语义向量搜索
`;
}
queryInfoDiv.innerHTML = html;
}
// Helper functions
function escapeHtml(text) {
if (!text) return '';
const div = document.createElement('div');
div.textContent = text;
return div.innerHTML;
}
function formatDate(dateStr) {
try {
const date = new Date(dateStr);
return date.toLocaleDateString('zh-CN');
} catch {
return dateStr;
}
}
function getLanguageName(code) {
const names = {
'zh': '中文',
'en': 'English',
'ru': 'Русский',
'ar': 'العربية',
'ja': '日本語',
'unknown': '未知'
};
return names[code] || code;
}
// Initialize page
document.addEventListener('DOMContentLoaded', function() {
console.log('SearchEngine Frontend loaded');
console.log('API Base URL:', API_BASE_URL);
// Focus on search input
document.getElementById('searchInput').focus();
});