Dashboard Bootstrap 4 avec cartes et graphiques ChartJS pour visualiser les données en temps réel.
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="UTF-8" />
<meta name="copyright" content="MEZGANI Said" />
<meta name="author" content="AngularForAll" />
<meta name="robots" content="noindex, nofollow" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Dashboard avec Charts | AngularForAll</title>
<!-- Bootstrap 4 CSS -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.2/dist/css/bootstrap.min.css">
<!-- Font Awesome -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css">
<style>
:root {
--primary-color: #007bff;
--secondary-color: #6c757d;
--success-color: #28a745;
--danger-color: #dc3545;
--warning-color: #ffc107;
--info-color: #17a2b8;
}
body {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
min-height: 100vh;
padding: 30px 0;
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}
.dashboard-container {
max-width: 1400px;
margin: 0 auto;
}
.dashboard-header {
text-align: center;
color: white;
margin-bottom: 50px;
}
.dashboard-header h1 {
font-weight: 700;
font-size: 2.5rem;
margin-bottom: 10px;
text-shadow: 2px 2px 4px rgba(0,0,0,0.2);
}
.dashboard-header p {
font-size: 1.2rem;
opacity: 0.9;
}
/* Cards */
.chart-card {
background: white;
border-radius: 15px;
box-shadow: 0 10px 30px rgba(0,0,0,0.2);
padding: 25px;
margin-bottom: 30px;
transition: all 0.3s;
}
.chart-card:hover {
transform: translateY(-5px);
box-shadow: 0 15px 40px rgba(0,0,0,0.3);
}
.card-header-custom {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 20px;
padding-bottom: 15px;
border-bottom: 2px solid #f0f0f0;
}
.card-title-custom {
font-size: 1.3rem;
font-weight: 600;
color: #2c3e50;
}
.card-icon {
font-size: 1.5rem;
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 50%;
}
.card-icon.primary {
background-color: rgba(0, 123, 255, 0.1);
color: var(--primary-color);
}
.card-icon.success {
background-color: rgba(40, 167, 69, 0.1);
color: var(--success-color);
}
.card-icon.danger {
background-color: rgba(220, 53, 69, 0.1);
color: var(--danger-color);
}
.card-icon.warning {
background-color: rgba(255, 193, 7, 0.1);
color: var(--warning-color);
}
.card-icon.info {
background-color: rgba(23, 162, 184, 0.1);
color: var(--info-color);
}
.chart-container {
position: relative;
height: 300px;
margin-bottom: 15px;
}
.chart-info {
display: flex;
justify-content: space-around;
padding-top: 15px;
border-top: 1px solid #f0f0f0;
}
.info-item {
text-align: center;
}
.info-label {
font-size: 0.85rem;
color: #7f8c8d;
margin-bottom: 5px;
}
.info-value {
font-size: 1.3rem;
font-weight: 700;
color: #2c3e50;
}
@media (max-width: 768px) {
.dashboard-header h1 {
font-size: 1.8rem;
}
.chart-card {
padding: 15px;
}
.chart-container {
height: 250px;
}
}
</style>
</head>
<body>
<!-- Header -->
<div class="dashboard-header">
<h1><i class="fas fa-chart-line mr-3"></i>Dashboard Analytique</h1>
<p>Visualisez vos données en temps réel</p>
</div>
<!-- Container -->
<div class="container-fluid dashboard-container">
<!-- Row 1 -->
<div class="row">
<!-- Card 1 - Line Chart -->
<div class="col-md-6">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Chiffre d'Affaires</h3>
<div class="card-icon primary">
<i class="fas fa-chart-line"></i>
</div>
</div>
<div class="chart-container">
<canvas id="lineChart"></canvas>
</div>
<div class="chart-info">
<div class="info-item">
<div class="info-label">Total</div>
<div class="info-value">45,000€</div>
</div>
<div class="info-item">
<div class="info-label">Moyenne</div>
<div class="info-value">7,500€</div>
</div>
<div class="info-item">
<div class="info-label">Croissance</div>
<div class="info-value text-success">+25%</div>
</div>
</div>
</div>
</div>
<!-- Card 2 - Bar Chart -->
<div class="col-md-6">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Ventes par Catégorie</h3>
<div class="card-icon success">
<i class="fas fa-bar-chart"></i>
</div>
</div>
<div class="chart-container">
<canvas id="barChart"></canvas>
</div>
<div class="chart-info">
<div class="info-item">
<div class="info-label">Catégorie Top</div>
<div class="info-value">Électronique</div>
</div>
<div class="info-item">
<div class="info-label">Ventes</div>
<div class="info-value">12,500€</div>
</div>
</div>
</div>
</div>
</div>
<!-- Row 2 -->
<div class="row">
<!-- Card 3 - Doughnut Chart -->
<div class="col-md-6">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Distribution des Ventes</h3>
<div class="card-icon danger">
<i class="fas fa-ring"></i>
</div>
</div>
<div class="chart-container" style="height: 250px;">
<canvas id="doughnutChart"></canvas>
</div>
</div>
</div>
<!-- Card 4 - Pie Chart -->
<div class="col-md-6">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Parts de Marché</h3>
<div class="card-icon warning">
<i class="fas fa-pie-chart"></i>
</div>
</div>
<div class="chart-container" style="height: 250px;">
<canvas id="pieChart"></canvas>
</div>
</div>
</div>
</div>
<!-- Row 3 -->
<div class="row">
<!-- Card 5 - Area Chart -->
<div class="col-md-6">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Utilisateurs Actifs</h3>
<div class="card-icon info">
<i class="fas fa-users"></i>
</div>
</div>
<div class="chart-container">
<canvas id="areaChart"></canvas>
</div>
<div class="chart-info">
<div class="info-item">
<div class="info-label">Total Utilisateurs</div>
<div class="info-value">1,250</div>
</div>
<div class="info-item">
<div class="info-label">Actifs Aujourd'hui</div>
<div class="info-value">856</div>
</div>
<div class="info-item">
<div class="info-label">Taux d'Activité</div>
<div class="info-value text-success">68.5%</div>
</div>
</div>
</div>
</div>
<!-- Card 6 - Radar Chart -->
<div class="col-md-6">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Évaluation Produits</h3>
<div class="card-icon primary">
<i class="fas fa-star"></i>
</div>
</div>
<div class="chart-container">
<canvas id="radarChart"></canvas>
</div>
</div>
</div>
</div>
<!-- Row 4 -->
<div class="row">
<!-- Card 7 - Mixed Chart -->
<div class="col-lg-12">
<div class="chart-card">
<div class="card-header-custom">
<h3 class="card-title-custom">Analyse Combinée (Ventes & Profit)</h3>
<div class="card-icon success">
<i class="fas fa-coins"></i>
</div>
</div>
<div class="chart-container" style="height: 350px;">
<canvas id="mixedChart"></canvas>
</div>
</div>
</div>
</div>
</div>
<!-- Scripts -->
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.2/dist/js/bootstrap.bundle.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/chart.js@3.9.1/dist/chart.min.js"></script>
<script>
// Configuration globale de Chart.js
Chart.defaults.font.family = "'Segoe UI', Tahoma, Geneva, Verdana, sans-serif";
Chart.defaults.color = '#7f8c8d';
// 1. Line Chart - Chiffre d'Affaires
const lineCtx = document.getElementById('lineChart').getContext('2d');
new Chart(lineCtx, {
type: 'line',
data: {
labels: ['Jan', 'Fév', 'Mar', 'Avr', 'Mai', 'Juin'],
datasets: [{
label: 'Chiffre d\'Affaires',
data: [5000, 7500, 6800, 9200, 8500, 10000],
borderColor: '#007bff',
backgroundColor: 'rgba(0, 123, 255, 0.1)',
borderWidth: 3,
fill: true,
tension: 0.4,
pointRadius: 6,
pointBackgroundColor: '#007bff',
pointBorderColor: '#fff',
pointBorderWidth: 2,
pointHoverRadius: 8
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
plugins: {
legend: {
display: true,
position: 'top'
}
},
scales: {
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.05)'
}
}
}
}
});
// 2. Bar Chart - Ventes par Catégorie
const barCtx = document.getElementById('barChart').getContext('2d');
new Chart(barCtx, {
type: 'bar',
data: {
labels: ['Électronique', 'Vêtements', 'Livres', 'Maison', 'Sports'],
datasets: [{
label: 'Ventes (€)',
data: [12500, 8900, 6700, 9300, 5600],
backgroundColor: [
'#007bff',
'#28a745',
'#ffc107',
'#dc3545',
'#17a2b8'
],
borderRadius: 5,
borderSkipped: false
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
indexAxis: 'y',
plugins: {
legend: {
display: true
}
},
scales: {
x: {
grid: {
color: 'rgba(0, 0, 0, 0.05)'
}
}
}
}
});
// 3. Doughnut Chart - Distribution des Ventes
const doughnutCtx = document.getElementById('doughnutChart').getContext('2d');
new Chart(doughnutCtx, {
type: 'doughnut',
data: {
labels: ['Produit A', 'Produit B', 'Produit C', 'Produit D'],
datasets: [{
data: [30, 25, 25, 20],
backgroundColor: [
'#007bff',
'#28a745',
'#ffc107',
'#dc3545'
],
borderColor: '#fff',
borderWidth: 2
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
plugins: {
legend: {
position: 'bottom'
}
}
}
});
// 4. Pie Chart - Parts de Marché
const pieCtx = document.getElementById('pieChart').getContext('2d');
new Chart(pieCtx, {
type: 'pie',
data: {
labels: ['Marché A', 'Marché B', 'Marché C', 'Marché D', 'Autres'],
datasets: [{
data: [35, 25, 20, 12, 8],
backgroundColor: [
'rgba(0, 123, 255, 0.8)',
'rgba(40, 167, 69, 0.8)',
'rgba(255, 193, 7, 0.8)',
'rgba(220, 53, 69, 0.8)',
'rgba(23, 162, 184, 0.8)'
],
borderColor: '#fff',
borderWidth: 2
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
plugins: {
legend: {
position: 'right'
}
}
}
});
// 5. Area Chart - Utilisateurs Actifs
const areaCtx = document.getElementById('areaChart').getContext('2d');
new Chart(areaCtx, {
type: 'line',
data: {
labels: ['Lun', 'Mar', 'Mer', 'Jeu', 'Ven', 'Sam', 'Dim'],
datasets: [{
label: 'Utilisateurs Actifs',
data: [650, 720, 680, 750, 820, 890, 920],
borderColor: '#17a2b8',
backgroundColor: 'rgba(23, 162, 184, 0.2)',
borderWidth: 3,
fill: true,
tension: 0.4,
pointRadius: 5,
pointBackgroundColor: '#17a2b8'
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
plugins: {
legend: {
display: true
}
},
scales: {
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.05)'
}
}
}
}
});
// 6. Radar Chart - Évaluation Produits
const radarCtx = document.getElementById('radarChart').getContext('2d');
new Chart(radarCtx, {
type: 'radar',
data: {
labels: ['Qualité', 'Prix', 'Livraison', 'Service', 'Durabilité', 'Design'],
datasets: [{
label: 'Évaluation',
data: [85, 78, 90, 88, 82, 80],
borderColor: '#007bff',
backgroundColor: 'rgba(0, 123, 255, 0.2)',
borderWidth: 2,
pointRadius: 4,
pointBackgroundColor: '#007bff'
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
plugins: {
legend: {
display: true
}
}
}
});
// 7. Mixed Chart - Ventes & Profit
const mixedCtx = document.getElementById('mixedChart').getContext('2d');
new Chart(mixedCtx, {
type: 'bar',
data: {
labels: ['Jan', 'Fév', 'Mar', 'Avr', 'Mai', 'Juin', 'Juil'],
datasets: [
{
type: 'bar',
label: 'Ventes',
data: [15000, 18000, 16000, 22000, 25000, 28000, 30000],
backgroundColor: 'rgba(0, 123, 255, 0.7)',
borderRadius: 5
},
{
type: 'line',
label: 'Profit',
data: [3000, 3600, 3200, 4400, 5000, 5600, 6000],
borderColor: '#28a745',
backgroundColor: 'rgba(40, 167, 69, 0.1)',
borderWidth: 3,
tension: 0.4,
pointRadius: 5,
pointBackgroundColor: '#28a745'
}
]
},
options: {
responsive: true,
maintainAspectRatio: false,
plugins: {
legend: {
display: true,
position: 'top'
}
},
scales: {
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.05)'
}
}
}
}
});
</script>
</body>
</html>