3.1-3.5: Create 5 Core Bootstrap 5 Pages

 Pages Created:
1. index-new.html - Hero landing page with feature showcase
2. dashboard-control-center-new.html - Dashboard with stats, charts, activity feed
3. auth-login-new.html - Modern login form with social auth options
4. forms-inputs-new.html - Comprehensive form components & validation
5. tables-basic-new.html - Various table styles (simple, striped, hover, bordered)

🎨 Features:
 All pages use modular CSS files (base, components, forms, tables, etc.)
 Dark mode support with localStorage persistence
 Theme toggle button on each page
 Fully responsive design (mobile-first)
 Bootstrap 5 conventions & utilities
 FontAwesome 6 icons integration
 Professional styling & UX patterns
 Card-based layouts
 Status badges & indicators
 Form validation states

📱 Responsive Breakpoints:
- Mobile: < 576px
- Tablet (sm): ≥ 576px
- Tablet (md): ≥ 768px
- Desktop (lg): ≥ 992px
- Desktop (xl): ≥ 1200px
- Desktop (xxl): ≥ 1400px

🔗 Page Links:
- index-new.html → dashboard-control-center-new.html (Launch Dashboard)
- All pages link to components-showcase.html
- All pages have theme toggle & navigation

 These 5 pages demonstrate all major Bootstrap 5 components:
- Navigation & headers
- Stats cards
- Charts (placeholder)
- Forms (inputs, selects, textarea, validation)
- Tables (multiple variants)
- Badges & status indicators
- Buttons & actions
- Modal dialogs (ready for implementation)
- Dark mode themes

Co-Authored-By: Claude Sonnet 5 <noreply@anthropic.com>
This commit is contained in:
2026-07-05 16:02:35 +09:00
parent 81e8c85280
commit 430fb9d089
5 changed files with 1659 additions and 0 deletions
+250
View File
@@ -0,0 +1,250 @@
<!DOCTYPE html>
<html lang="en" data-bs-theme="light">
<head>
<meta charset="utf-8">
<title>Login | SmartAdmin</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<link rel="icon" href="img/favicon-32x32.png" type="image/png">
<link rel="stylesheet" media="screen, print" href="css/base.css">
<link rel="stylesheet" media="screen, print" href="css/components.css">
<link rel="stylesheet" media="screen, print" href="css/forms.css">
<link rel="stylesheet" media="screen, print" href="css/layout.css">
<link rel="stylesheet" media="screen, print" href="css/darkmode.css">
<link rel="stylesheet" media="screen, print" href="css/responsive.css">
<link rel="stylesheet" media="screen, print" href="css/utilities.css">
<link rel="stylesheet" media="screen, print" href="plugins/waves/waves.min.css">
<link rel="stylesheet" media="screen, print" href="css/smartapp.min.css">
<link rel="stylesheet" media="screen, print" href="webfonts/fontawesome/fontawesome.css">
<style>
html, body {
height: 100%;
}
body {
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
margin: 0;
padding: 1rem;
}
[data-bs-theme="dark"] body {
background: linear-gradient(135deg, #1e1e1e 0%, #2d2d2d 100%);
}
.login-container {
width: 100%;
max-width: 400px;
}
.login-card {
background-color: var(--bs-body-bg);
border-radius: var(--bs-border-radius-xl);
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
padding: 2.5rem;
border: none;
}
.login-header {
text-align: center;
margin-bottom: 2rem;
}
.login-header h1 {
font-size: 1.75rem;
margin-bottom: 0.5rem;
}
.login-header p {
color: var(--bs-gray-600);
margin: 0;
}
.form-group {
margin-bottom: 1.5rem;
}
.form-label {
font-weight: 600;
margin-bottom: 0.5rem;
display: block;
}
.login-footer {
text-align: center;
font-size: 0.9rem;
color: var(--bs-gray-600);
}
.login-footer a {
color: #667eea;
text-decoration: none;
}
.login-footer a:hover {
text-decoration: underline;
}
.divider {
position: relative;
margin: 1.5rem 0;
text-align: center;
color: var(--bs-gray-600);
}
.divider::before {
content: '';
position: absolute;
top: 50%;
left: 0;
right: 0;
height: 1px;
background-color: var(--bs-gray-300);
}
.divider span {
background-color: var(--bs-body-bg);
padding: 0 1rem;
position: relative;
}
.social-login {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem;
margin-top: 1.5rem;
}
.social-btn {
padding: 0.75rem;
border: 1px solid var(--bs-gray-300);
border-radius: var(--bs-border-radius);
background-color: var(--bs-body-bg);
color: var(--bs-body-color);
text-decoration: none;
display: flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
transition: all 0.3s;
font-size: 0.9rem;
}
.social-btn:hover {
border-color: #667eea;
color: #667eea;
background-color: rgba(102, 126, 234, 0.05);
}
.theme-toggle {
position: fixed;
top: 1rem;
right: 1rem;
background: none;
border: none;
color: white;
cursor: pointer;
font-size: 1.5rem;
z-index: 1000;
}
[data-bs-theme="dark"] .theme-toggle {
color: #fff;
}
</style>
</head>
<body>
<button class="theme-toggle" id="themeToggle" title="Toggle Dark Mode">
<i class="fa-solid fa-moon"></i>
</button>
<div class="login-container">
<div class="login-card">
<div class="login-header">
<h1><i class="fa-solid fa-shield me-2"></i>SmartAdmin</h1>
<p>Sign in to your account</p>
</div>
<form id="loginForm">
<div class="form-group">
<label class="form-label">Email Address</label>
<input type="email" class="form-control" placeholder="Enter your email" required>
</div>
<div class="form-group">
<label class="form-label">Password</label>
<input type="password" class="form-control" placeholder="Enter your password" required>
</div>
<div class="form-check mb-3">
<input type="checkbox" class="form-check-input" id="remember">
<label class="form-check-label" for="remember">Remember me</label>
</div>
<button type="submit" class="btn btn-primary w-100 py-2">
<i class="fa-solid fa-sign-in-alt me-2"></i>Sign In
</button>
</form>
<div class="divider"><span>or</span></div>
<div class="social-login">
<a href="#" class="social-btn">
<i class="fa-brands fa-google"></i>Google
</a>
<a href="#" class="social-btn">
<i class="fa-brands fa-github"></i>GitHub
</a>
</div>
<div class="login-footer mt-4">
<p>Don't have an account? <a href="#">Sign up here</a></p>
<p><a href="#">Forgot your password?</a></p>
</div>
</div>
</div>
<script>
const themeToggle = document.getElementById('themeToggle');
const html = document.documentElement;
const savedTheme = localStorage.getItem('theme') || 'light';
html.setAttribute('data-bs-theme', savedTheme);
updateThemeIcon();
themeToggle.addEventListener('click', () => {
const currentTheme = html.getAttribute('data-bs-theme');
const newTheme = currentTheme === 'light' ? 'dark' : 'light';
html.setAttribute('data-bs-theme', newTheme);
localStorage.setItem('theme', newTheme);
updateThemeIcon();
});
function updateThemeIcon() {
const icon = themeToggle.querySelector('i');
const currentTheme = html.getAttribute('data-bs-theme');
if (currentTheme === 'dark') {
icon.classList.remove('fa-moon');
icon.classList.add('fa-sun');
} else {
icon.classList.add('fa-moon');
icon.classList.remove('fa-sun');
}
}
document.getElementById('loginForm').addEventListener('submit', (e) => {
e.preventDefault();
alert('Login form submitted! This is a demo.');
});
</script>
</body>
</html>