File size: 2,325 Bytes
77ef733
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
// Fetch books from Open Library API
document.addEventListener('DOMContentLoaded', async function() {
    try {
        const response = await fetch('https://openlibrary.org/subjects/fiction.json?limit=8');
        const data = await response.json();
        displayBooks(data.works);
    } catch (error) {
        console.error('Error fetching books:', error);
        document.getElementById('featured-books').innerHTML = 
            '<div class="text-center text-parchment-700">Could not load books. Please try again later.</div>';
    }
});

function displayBooks(books) {
    const container = document.getElementById('featured-books');
    
    if (!books || books.length === 0) {
        container.innerHTML = '<div class="text-center text-parchment-700">No books found.</div>';
        return;
    }
    
    container.innerHTML = books.map(book => `
        <div class="book-card bg-white rounded-lg overflow-hidden shadow-sm hover:shadow-md">
            <div class="h-48 bg-parchment-100 flex items-center justify-center">
                ${book.cover_id ? 
                    `<img src="https://covers.openlibrary.org/b/id/${book.cover_id}-M.jpg" alt="${book.title}" class="h-full object-cover">` : 
                    `<div class="text-parchment-400 p-4 text-center"><i data-feather="book" class="w-12 h-12 mx-auto"></i><p>No cover available</p></div>`
                }
            </div>
            <div class="p-4">
                <h3 class="font-bold text-lg mb-1 line-clamp-1">${book.title}</h3>
                <p class="text-parchment-600 text-sm mb-2 line-clamp-1">${book.authors ? book.authors.map(a => a.name).join(', ') : 'Unknown Author'}</p>
                <div class="flex justify-between items-center">
                    <span class="text-xs bg-parchment-100 text-parchment-700 px-2 py-1 rounded">${book.subject ? book.subject[0] : 'Fiction'}</span>
                    <a href="https://openlibrary.org${book.key}" target="_blank" class="text-bookworm-500 hover:text-bookworm-700 text-sm font-medium flex items-center">
                        Details <i data-feather="arrow-right" class="w-4 h-4 ml-1"></i>
                    </a>
                </div>
            </div>
        </div>
    `).join('');
    
    feather.replace();
}

// Mobile menu toggle (handled in navbar component)