Bootstrap 4 Card ChartJS

🏷️ Extraits de code HTML 📅 12/04/2026 👤 Mezgani said
Bootstrap Chartjs Dashboard Card Html

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>