Deck törlés funkció implementálása modal-lal és consequence értékek finomítása
This commit is contained in:
@@ -7,7 +7,7 @@ import Navbar from "../../components/Navbar/Navbar.jsx"
|
||||
import DeckHeader from "../../components/DeckCreator/DeckHeader.jsx"
|
||||
import CardsList from "../../components/DeckCreator/CardsList.jsx"
|
||||
import CardEditor from "../../components/DeckCreator/CardEditor.jsx"
|
||||
import { createDeck, getDeckById, updateDeck } from '../../api/deckApi'
|
||||
import { createDeck, getDeckById, updateDeck, deleteDeck } from '../../api/deckApi'
|
||||
import { notifySuccess, notifyError, notifyWarning } from "../../components/Toastify/toastifyServices"
|
||||
|
||||
export default function DeckCreator() {
|
||||
@@ -29,6 +29,7 @@ export default function DeckCreator() {
|
||||
const [isCreatingCard, setIsCreatingCard] = useState(false)
|
||||
const [newCardType, setNewCardType] = useState(null)
|
||||
const [isLoading, setIsLoading] = useState(false)
|
||||
const [showDeleteModal, setShowDeleteModal] = useState(false)
|
||||
|
||||
// Betöltés API-ból
|
||||
useEffect(() => {
|
||||
@@ -239,6 +240,36 @@ export default function DeckCreator() {
|
||||
navigate("/decks")
|
||||
}
|
||||
|
||||
const handleDeleteDeck = () => {
|
||||
if (!deck.id) {
|
||||
notifyWarning('Nincs mit törölni - a pakli még nincs elmentve!')
|
||||
return
|
||||
}
|
||||
|
||||
setShowDeleteModal(true)
|
||||
}
|
||||
|
||||
const handleConfirmDelete = async () => {
|
||||
try {
|
||||
await deleteDeck(deck.id)
|
||||
setShowDeleteModal(false)
|
||||
notifySuccess('Pakli sikeresen törölve!')
|
||||
navigate('/decks')
|
||||
} catch (error) {
|
||||
console.error('Pakli törlési hiba:', error)
|
||||
const errorMessage = error?.response?.data?.error
|
||||
|| error?.response?.data?.message
|
||||
|| error?.message
|
||||
|| 'Ismeretlen hiba történt'
|
||||
notifyError('Hiba történt a törlés során: ' + errorMessage)
|
||||
setShowDeleteModal(false)
|
||||
}
|
||||
}
|
||||
|
||||
const handleCancelDelete = () => {
|
||||
setShowDeleteModal(false)
|
||||
}
|
||||
|
||||
const handleCreateCard = (cardType) => {
|
||||
setNewCardType(cardType)
|
||||
setIsCreatingCard(true)
|
||||
@@ -351,6 +382,7 @@ export default function DeckCreator() {
|
||||
onUpdate={handleDeckUpdate}
|
||||
onSave={handleSaveDeck}
|
||||
onBack={handleBack}
|
||||
onDelete={handleDeleteDeck}
|
||||
/>
|
||||
|
||||
{/* Main Content */}
|
||||
@@ -386,6 +418,35 @@ export default function DeckCreator() {
|
||||
</div>
|
||||
</main>
|
||||
)}
|
||||
|
||||
{/* Delete Confirmation Modal */}
|
||||
{showDeleteModal && (
|
||||
<div className="fixed inset-0 bg-black/40 flex items-center justify-center z-50">
|
||||
<div className="bg-[color:var(--color-surface)] rounded-xl shadow-xl p-6 w-96 text-center animate-fadeIn">
|
||||
<div className="text-4xl mb-4">🗑️</div>
|
||||
<h3 className="text-lg font-semibold mb-4 text-[color:var(--color-text)]">
|
||||
Biztosan törölni szeretnéd a(z) "{deck.name}" paklit?
|
||||
</h3>
|
||||
<p className="text-sm text-[color:var(--color-text-muted)] mb-6">
|
||||
Ez a művelet nem visszavonható!
|
||||
</p>
|
||||
<div className="flex justify-center gap-4">
|
||||
<button
|
||||
onClick={handleConfirmDelete}
|
||||
className="bg-red-600 text-white px-6 py-2 rounded-lg hover:bg-red-700 transition font-semibold"
|
||||
>
|
||||
Igen, törlöm
|
||||
</button>
|
||||
<button
|
||||
onClick={handleCancelDelete}
|
||||
className="bg-[color:var(--color-background)] text-[color:var(--color-text)] px-6 py-2 rounded-lg hover:bg-[color:var(--color-surface-selected)] transition"
|
||||
>
|
||||
Mégse
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user