1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- import { Controller } from "@hotwired/stimulus"
- export default class extends Controller {
- connect() {
- // Écoute tous les clics sur .open-modal -> détournement vers #lastStep + MAJ des options du formulaire
- document.querySelectorAll('.planning-cell-free, .planning-cell-locked').forEach(element => {
- element.addEventListener('click', this.handleClick.bind(this))
- })
- }
- handleClick(event) {
- event.preventDefault()
- const slotId = event.currentTarget.dataset.id
- const cell = event.currentTarget;
- const path = cell.querySelector('.icon path');
- if (!slotId) return
- // A partir du slotId ->
- // 1. trouver l'état du slot cliqué et le basculer dans la BDD (LOCKED/UNLOCKED/GAME)
- // 2. mettre à jour le style de la case cliquée
- // Etape 1
- fetch(`/api/slot/${slotId}/toggleStatus`, {
- method: 'POST',
- headers: {
- 'Accept': 'application/json'
- }
- })
- .then(response => {
- if (!response.ok) {
- throw new Error(`Erreur API: ${response.status}`);
- }
- return response.json();
- })
- .then(data => {
-
- // Etape 2
- console.log('ID du slot cliqué :', slotId);
- console.log('ÉTAT DU SLOT :', data.status);
- if (data.status === "UNLOCKED") {
- cell.classList.add('planning-cell-free');
- cell.classList.remove('planning-cell-locked');
- path.setAttribute('d', 'M12 0a4 4 0 0 1 4 4v2.5h-1V4a3 3 0 1 0-6 0v2h.5A2.5 2.5 0 0 1 12 8.5v5A2.5 2.5 0 0 1 9.5 16h-7A2.5 2.5 0 0 1 0 13.5v-5A2.5 2.5 0 0 1 2.5 6H8V4a4 4 0 0 1 4-4');
- } else if (data.status === "LOCKED") {
- cell.classList.remove('planning-cell-free');
- cell.classList.add('planning-cell-locked');
- path.setAttribute('d', 'M8 0a4 4 0 0 1 4 4v2.05a2.5 2.5 0 0 1 2 2.45v5a2.5 2.5 0 0 1-2.5 2.5h-7A2.5 2.5 0 0 1 2 13.5v-5a2.5 2.5 0 0 1 2-2.45V4a4 4 0 0 1 4-4m0 1a3 3 0 0 0-3 3v2h6V4a3 3 0 0 0-3-3');
- } else {
- console.warn("Statut de réponse sans action :", data.status);
- }
- })
- .catch(error => {
- console.error('Erreur lors de la récupération des slots :', error);
- });
-
- }
- disconnect() {
- this.element.querySelectorAll('.planning-cell-free').forEach(element => {
- element.removeEventListener('click', this.handleClick)
- })
- }
- }
|