Javascript не перенаправляет, а время в приложении Django остается прежним. Как решить эту проблему?

Привет всем, я пытаюсь создать веб-приложение с использованием django и js. Это своего рода чат приложение есть комнаты и каждая комната имеет время после того, как время закончилось. Я хочу удалить комнату. Пока я делаю тест, я понимаю, если один пользователь в комнате, другой пользователь на странице списка, комната не удаляется, когда 1 пользователь в комнате и другой странице списка. Время остается 1 секунда Как можно решить эту проблему. Можете ли вы помочь мне? Спасибо.

room_detail_page

  function updateRemainingTime() {
        // Sunucuya AJAX isteği gönder
        var xhr = new XMLHttpRequest();
        xhr.open('GET', '/remaining-time/' + roomName + '/', true);
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
                var remainingTime = JSON.parse(xhr.responseText);
                // Kalan süreyi güncelle
                document.getElementById('remaining-time').textContent = remainingTime.minutes + ':' + remainingTime.seconds;
                if (remainingTime.minutes <= 0 && remainingTime.seconds <= 0) {
                    deleteRoom(roomName);
                
            }
            }
        };
        xhr.send();
    }
    function deleteRoom(roomId) {
    var xhr = new XMLHttpRequest();
    xhr.open('POST', '/delete-room/' + roomId + '/', true);
    xhr.setRequestHeader('X-CSRFToken', '{{ csrf_token }}');
    xhr.onreadystatechange = function () {
        if (xhr.readyState === 4 && xhr.status === 200) {
            window.location.href = '/home';
            location.reload()
        }
    };
    xhr.send();
}
setInterval(updateRemainingTime, 1000); 

room_list_page

function updateRemainingTime(roomId) {
        // Sunucuya AJAX isteği gönder
        var xhr = new XMLHttpRequest();
        xhr.open('GET', '/remaining-time/' + roomId + '/', true);
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
                var remainingTime = JSON.parse(xhr.responseText);
                // Kalan süreyi güncelle
                var remainingTimeElement = document.getElementById('remaining-time-' + roomId);
            
                remainingTimeElement.textContent = remainingTime.minutes + ':' + remainingTime.seconds;
                if (remainingTime.minutes <= 0 && remainingTime.seconds <= 0 ) {
                    // If remaining time is 0 or negative, delete the room
                    deleteRoom(roomId);
                    
                }
                
            }
        };
        xhr.send();
    }
    // Belirli aralıklarla her oda için zamanı güncelle
    function deleteRoom(roomId) {
        // Sunucuya AJAX isteği gönder
        var xhr = new XMLHttpRequest();
        xhr.open('POST', '/delete-room/' + roomId + '/', true);
        xhr.setRequestHeader('X-CSRFToken', '{{ csrf_token }}');  // Add CSRF token if needed
        xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200) {
               location.reload()
            }
        };
        xhr.send();
    }
    room_ids.forEach(function(roomId) {
        setInterval(function() { updateRemainingTime(roomId); }, 1000); // Her saniyede bir güncelle
    });

api.py

def remaining_time_api(request, room_id):
    room = Room.objects.get(id=room_id)
    remaining_time = room.remaining_time()
    seconds = remaining_time.seconds % 60
    minutes = (remaining_time.seconds // 60) % 60
    return JsonResponse({'minutes': minutes, 'seconds': seconds})

def delete_room(request, room_id):
    room = get_object_or_404(Room, id=room_id)
    room.delete()
    return redirect('/home')  

Вернуться на верх