File size: 1,349 Bytes
6864389
65676ec
 
 
 
 
 
6864389
 
65676ec
 
6864389
 
65676ec
6864389
 
 
 
65676ec
 
 
 
 
 
6864389
65676ec
 
 
 
 
 
 
 
 
 
 
 
 
6864389
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import { useTranslation } from "@/hooks/useTranslation";
import { getModelDisplayName } from "@/lib/modelNames";

interface SentenceWord {
  word: string;
  provider: 'player' | 'ai';
}

interface GuessDescriptionProps {
  sentence: SentenceWord[];
  model?: string;
}

export const GuessDescription = ({ sentence, model }: GuessDescriptionProps) => {
  const t = useTranslation();

  return (
    <div className="space-y-2">
      <p className="text-sm text-gray-600">
        <span className="inline-block border-b-2 border-blue-500">{t.guess.you}</span>
        {" "}{t.guess.and}{" "}
        <span className="inline-block border-b-2 border-green-500">{model ? getModelDisplayName(model) : t.guess.aiModel}</span>
        {" "}{t.guess.providedDescription}
      </p>
      <div className="rounded-lg bg-gray-50">
        <p className="p-4 text-2xl tracking-wider text-gray-800 flex flex-wrap gap-1">
          {sentence.map((wordObj, index) => (
            <span
              key={index}
              className={`inline-block ${
                wordObj.provider === 'player'
                  ? "border-b-2 border-blue-500" // Player words
                  : "border-b-2 border-green-500" // AI words
              }`}
            >
              {wordObj.word}
            </span>
          ))}
        </p>
      </div>
    </div>
  );
};