Bootstrap Simple Admin Template Free Codepen -
function setActive(activeId) navLinks.forEach(link => link.classList.remove('active'); if (link.id === activeId) link.classList.add('active'); ); // Change story context based on section (just a playful narrative effect) if (activeId === 'nav-dashboard') if (mainTitle) mainTitle.innerHTML = '✨ Admin Dashboard — A Simple Bootstrap Story'; if (subtitleEl) subtitleEl.innerHTML = 'Welcome back, Olivia. Here\'s your latest performance & narrative.'; else if (activeId === 'nav-analytics') if (mainTitle) mainTitle.innerHTML = '📊 Analytics Story — Deep Data Insights'; if (subtitleEl) subtitleEl.innerHTML = 'Exploring growth metrics and conversion chapters.'; // scroll to chart for better experience document.querySelector('.story-card canvas')?.scrollIntoView( behavior: 'smooth', block: 'center' ); else if (activeId === 'nav-orders') if (mainTitle) mainTitle.innerHTML = '📦 Orders Chronicle — Transaction Stories'; if (subtitleEl) subtitleEl.innerHTML = 'Manage your latest orders and fulfillment narrative.'; document.querySelector('.table-responsive')?.scrollIntoView( behavior: 'smooth', block: 'start' ); else if (activeId === 'nav-customers') if (mainTitle) mainTitle.innerHTML = '👥 Customer Journey — People Behind the Story'; if (subtitleEl) subtitleEl.innerHTML = 'Discover your community: 1,429 new faces this month.'; // display small alert-like story const tempMsg = document.createElement('div'); tempMsg.className = 'alert alert-light story-card mt-2 d-flex align-items-center'; tempMsg.innerHTML = '<i class="bi bi-emoji-smile fs-4 me-2"></i> Customer story: Engagement rate +12% this week!'; const container = document.querySelector('.row.g-4.mb-5').parentNode; const existingAlert = document.querySelector('.temp-story-alert'); if(existingAlert) existingAlert.remove(); tempMsg.classList.add('temp-story-alert'); container.insertBefore(tempMsg, document.querySelector('.row.g-4.mb-5').nextSibling); setTimeout(() => if(tempMsg) tempMsg.style.opacity = '0'; setTimeout(() => tempMsg?.remove(), 800); , 3000); else if (activeId === 'nav-settings') if (mainTitle) mainTitle.innerHTML = '⚙️ Settings & Preferences — Tailor Your Story'; if (subtitleEl) subtitleEl.innerHTML = 'Customize your admin experience and theme narrative.';
<div class="container-fluid px-0"> <div class="row g-0"> <!-- SIDEBAR - The admin navigation story begins --> <div class="col-md-3 col-lg-2 admin-sidebar"> <div class="sidebar-brand d-flex align-items-center"> <i class="bi bi-stars"></i> <span>AdminStory</span> </div> <div class="mt-4"> <a href="#" class="nav-link-custom active d-block" id="nav-dashboard"> <i class="bi bi-speedometer2"></i> Dashboard </a> <a href="#" class="nav-link-custom d-block" id="nav-analytics"> <i class="bi bi-graph-up"></i> Analytics </a> <a href="#" class="nav-link-custom d-block" id="nav-orders"> <i class="bi bi-bag-check"></i> Orders </a> <a href="#" class="nav-link-custom d-block" id="nav-customers"> <i class="bi bi-people"></i> Customers </a> <a href="#" class="nav-link-custom d-block" id="nav-settings"> <i class="bi bi-gear"></i> Settings </a> </div> <div class="position-absolute bottom-0 start-0 p-3 d-none d-lg-block" style="opacity:0.6;"> <small class="text-white-50"><i class="bi bi-dot"></i> v2.0 · Bootstrap Admin</small> </div> </div> bootstrap simple admin template free codepen
// --- simple interactive "story" navigation: highlight active link & small dynamic content update (cosmetic) const navLinks = document.querySelectorAll('.nav-link-custom'); const mainTitle = document.querySelector('.greeting-highlight'); const subtitleEl = document.querySelector('.text-secondary-emphasis'); function setActive(activeId) navLinks
<!-- Story section: CHARTS + RECENT ACTIVITIES (narrative core) --> <div class="row g-4 mb-5"> <div class="col-lg-7"> <div class="story-card card h-100 p-3"> <div class="card-header bg-transparent border-0 pt-2 pb-0 d-flex justify-content-between align-items-center"> <h5 class="fw-semibold mb-0"><i class="bi bi-bar-chart-steps me-2"></i> Weekly Performance Story</h5> <span class="badge bg-light text-dark">Last 7 days</span> </div> <div class="card-body"> <canvas id="revenueChart" height="200" style="max-height: 240px; width: 100%"></canvas> </div> <div class="card-footer bg-transparent border-top-0 text-muted small"> 📈 Sales narrative: Strong mid-week growth driven by summer campaign. </div> </div> </div> <div class="col-lg-5"> <div class="story-card card h-100 p-3"> <div class="card-header bg-transparent border-0 pt-2 pb-0"> <h5 class="fw-semibold mb-0"><i class="bi bi-clock-history me-2"></i> Recent Story Events</h5> </div> <div class="card-body p-0 pt-2"> <ul class="list-group list-group-flush"> <li class="list-group-item d-flex align-items-center border-0 ps-0 pt-2 pb-2"> <i class="bi bi-check-circle-fill text-success me-3"></i> <div><strong>New user registration</strong> — +342 signups today</div> </li> <li class="list-group-item d-flex align-items-center border-0 ps-0 pt-2 pb-2"> <i class="bi bi-cart-check text-primary me-3"></i> <div><strong>Order #2369</strong> completed — High-value purchase</div> </li> <li class="list-group-item d-flex align-items-center border-0 ps-0 pt-2 pb-2"> <i class="bi bi-megaphone-fill text-warning me-3"></i> <div><strong>Marketing story</strong> — Email campaign launched</div> </li> <li class="list-group-item d-flex align-items-center border-0 ps-0 pt-2 pb-2"> <i class="bi bi-star-fill text-info me-3"></i> <div><strong>Product feedback</strong> — 4.8★ average rating</div> </li> <li class="list-group-item d-flex align-items-center border-0 ps-0 pt-2 pb-2"> <i class="bi bi-person-check-fill text-secondary me-3"></i> <div><strong>Support ticket resolved</strong> — 98% satisfaction</div> </li> </ul> </div> </div> </div> </div> function setActive(activeId) navLinks.forEach(link =>
navLinks.forEach(link => link.addEventListener('click', (e) => e.preventDefault(); const id = link.getAttribute('id'); if (id) setActive(id); ); );
<!-- Chart Initialization & Interactive Story elements --> <script> // --- CHART.JS: The story of revenue trends const ctx = document.getElementById('revenueChart').getContext('2d'); let revenueChart = new Chart(ctx, type: 'line', data: labels: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], datasets: [ label: 'Revenue ($)', data: [1850, 2100, 2670, 2980, 3120, 2750, 2375], borderColor: '#2c7da0', backgroundColor: 'rgba(44, 125, 160, 0.05)', borderWidth: 3, pointBackgroundColor: '#1f6e8c', pointBorderColor: '#fff', pointRadius: 5, pointHoverRadius: 7, tension: 0.3, fill: true, , label: 'Orders Count', data: [42, 48, 59, 71, 83, 68, 54], borderColor: '#f4a261', backgroundColor: 'rgba(244, 162, 97, 0.02)', borderWidth: 2, borderDash: [5, 5], pointRadius: 4, tension: 0.2, fill: false, ] , options: responsive: true, maintainAspectRatio: true, plugins: legend: position: 'top', labels: usePointStyle: true, boxWidth: 8 , tooltip: backgroundColor: '#0f2b3d', titleColor: '#f1f9ff' , scales: y: beginAtZero: true, grid: color: '#e9ecef' , title: display: true, text: 'Amount ($)' , x: grid: display: false );