File size: 2,111 Bytes
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import { Button } from "@/components/ui/button";
import { Dialog, DialogContent, DialogTrigger } from "@/components/ui/dialog";
import { HighScoreBoard } from "@/components/HighScoreBoard";
import { useState } from "react";
import { useTranslation } from "@/hooks/useTranslation";

interface ActionButtonsProps {
  isCorrect: boolean;
  onNextRound: () => void;
  onPlayAgain: () => void;
  currentScore: number;
  avgWordsPerRound: number;
  sessionId: string;
  onScoreSubmitted: () => void;
}

export const ActionButtons = ({
  isCorrect,
  onNextRound,
  onPlayAgain,
  currentScore,
  avgWordsPerRound,
  sessionId,
  onScoreSubmitted,
}: ActionButtonsProps) => {
  const [isDialogOpen, setIsDialogOpen] = useState(false);
  const t = useTranslation();

  return (
    <div className="flex flex-col gap-4">
      {isCorrect ? (
        <Button
          onClick={onNextRound}
          className="w-full bg-primary text-lg hover:bg-primary/90"
        >
          {t.guess.nextRound} ⏎
        </Button>
      ) : (
        <>
          <Dialog open={isDialogOpen} onOpenChange={setIsDialogOpen}>
            <DialogTrigger asChild>
              <Button
                className="w-full bg-secondary text-lg hover:bg-secondary/90"
              >
                {t.guess.viewLeaderboard} 🏆
              </Button>
            </DialogTrigger>
            <DialogContent className="max-w-md bg-white">
              <HighScoreBoard
                currentScore={currentScore}
                avgWordsPerRound={avgWordsPerRound}
                onClose={() => setIsDialogOpen(false)}
                onPlayAgain={() => {
                  setIsDialogOpen(false);
                  onPlayAgain();
                }}
                sessionId={sessionId}
                onScoreSubmitted={onScoreSubmitted}
              />
            </DialogContent>
          </Dialog>
          <Button
            onClick={onPlayAgain}
            className="w-full bg-primary text-lg hover:bg-primary/90"
          >
            {t.guess.playAgain} ⏎
          </Button>
        </>
      )}
    </div>
  );
};