SearchResultsPanel.tsx 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import React from 'react';
  2. import { RagSearchResult } from '../services/ragService';
  3. import { FileText, Star } from 'lucide-react';
  4. import { useLanguage } from '../contexts/LanguageContext';
  5. interface SearchResultsPanelProps {
  6. results: RagSearchResult[];
  7. isVisible: boolean;
  8. onClose: () => void;
  9. }
  10. const SearchResultsPanel: React.FC<SearchResultsPanelProps> = ({ results, isVisible, onClose }) => {
  11. const { t } = useLanguage();
  12. if (!isVisible || results.length === 0) return null;
  13. return (
  14. <div className="fixed inset-0 z-50 bg-black/50 flex items-center justify-center p-4">
  15. <div className="bg-white rounded-xl shadow-2xl w-full max-w-2xl max-h-[80vh] overflow-hidden">
  16. <div className="p-4 border-b border-slate-200 flex justify-between items-center">
  17. <h3 className="text-lg font-semibold text-slate-800">{t('searchResults')}</h3>
  18. <button
  19. onClick={onClose}
  20. className="text-slate-400 hover:text-slate-600 text-xl"
  21. >
  22. ×
  23. </button>
  24. </div>
  25. <div className="overflow-y-auto max-h-[60vh] p-4 space-y-4">
  26. {results.map((result, index) => (
  27. <div key={index} className="border border-slate-200 rounded-lg p-4 hover:bg-slate-50">
  28. <div className="flex items-center gap-2 mb-2">
  29. <FileText className="w-4 h-4 text-blue-600" />
  30. <span className="font-medium text-slate-700">{result.fileName}</span>
  31. <div className="flex items-center gap-1 ml-auto">
  32. <Star className="w-3 h-3 text-yellow-500" />
  33. <span className="text-xs text-slate-500">{result.score.toFixed(3)}</span>
  34. </div>
  35. </div>
  36. <p className="text-sm text-slate-600 line-clamp-4">{result.content}</p>
  37. <div className="mt-2 text-xs text-slate-400">
  38. {t('chunkNumber')} #{result.chunkIndex + 1}
  39. </div>
  40. </div>
  41. ))}
  42. </div>
  43. </div>
  44. </div>
  45. );
  46. };
  47. export default SearchResultsPanel;