aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/client/components/CreateDeckModal.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/components/CreateDeckModal.tsx')
-rw-r--r--src/client/components/CreateDeckModal.tsx6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/client/components/CreateDeckModal.tsx b/src/client/components/CreateDeckModal.tsx
index 4541a68..34d46e7 100644
--- a/src/client/components/CreateDeckModal.tsx
+++ b/src/client/components/CreateDeckModal.tsx
@@ -1,5 +1,7 @@
+import { useAtomValue } from "jotai";
import { type FormEvent, useState } from "react";
import { ApiClientError, apiClient } from "../api";
+import { isOnlineAtom } from "../atoms";
interface CreateDeckModalProps {
isOpen: boolean;
@@ -16,6 +18,7 @@ export function CreateDeckModal({
const [description, setDescription] = useState("");
const [error, setError] = useState<string | null>(null);
const [isSubmitting, setIsSubmitting] = useState(false);
+ const isOnline = useAtomValue(isOnlineAtom);
const resetForm = () => {
setName("");
@@ -160,7 +163,8 @@ export function CreateDeckModal({
</button>
<button
type="submit"
- disabled={isSubmitting || !name.trim()}
+ disabled={isSubmitting || !name.trim() || !isOnline}
+ title={!isOnline ? "Reconnect to create a deck" : undefined}
className="px-4 py-2 bg-primary hover:bg-primary-dark text-white font-medium rounded-lg transition-all duration-200 disabled:opacity-50 disabled:cursor-not-allowed"
>
{isSubmitting ? "Creating..." : "Create Deck"}