// Build table rows function buildTable() const tbody = document.getElementById('table-body'); if (!tbody) return; tbody.innerHTML = ''; fileItems.forEach(item => const icon, display, link = getIconAndLink(item); const row = tbody.insertRow(); if (item.isParent) row.classList.add('parent-row'); // filename column const cellName = row.insertCell(0); const nameSpan = document.createElement('span'); nameSpan.className = 'filename'; const anchor = document.createElement('a'); anchor.href = link; // special styling for parent directory if (item.isParent) anchor.style.fontWeight = '600'; anchor.style.background = '#f1f5f9'; anchor.style.padding = '0.2rem 0.6rem'; anchor.style.borderRadius = '20px'; anchor.style.display = 'inline-flex'; anchor.style.alignItems = 'center'; const iconSpan = document.createElement('span'); iconSpan.className = item.isDir ? 'dir-icon' : 'file-icon'; iconSpan.textContent = icon; iconSpan.style.marginRight = '8px'; anchor.appendChild(iconSpan); anchor.appendChild(document.createTextNode(display)); nameSpan.appendChild(anchor); cellName.appendChild(nameSpan); // last modified column const cellDate = row.insertCell(1); cellDate.className = 'date'; cellDate.textContent = formatDate(item.lastModified); // size column const cellSize = row.insertCell(2); cellSize.className = 'size'; if (item.isDir && !item.isParent) cellSize.textContent = '—'; else cellSize.textContent = item.size; );
// Toggle view between table and grid let currentView = 'table'; // 'table' or 'grid' const tableViewDiv = document.getElementById('table-view'); const gridViewDiv = document.getElementById('grid-view'); const viewBtns = document.querySelectorAll('.view-btn'); index of ebooks epub parent directory
h1 font-size: 2.2rem; font-weight: 600; letter-spacing: -0.3px; margin: 0.25rem 0 0.2rem; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; // Build table rows function buildTable() const tbody