feat: implement sidebar

This commit is contained in:
Sallu9007
2025-04-27 22:21:43 +05:30
parent 75f40b7147
commit 2deb7dd254
5 changed files with 599 additions and 54 deletions

View File

@@ -1,5 +1,6 @@
<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
@@ -10,21 +11,21 @@
<!-- Fonts -->
<link rel="preconnect" href="https://fonts.bunny.net">
<link href="https://fonts.bunny.net/css?family=inter:300,400,500,600,700&display=swap" rel="stylesheet" />
<!-- Font Awesome -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css" integrity="sha512-DTOQO9RWCH3ppGqcWaEA1BIZOC6xxalwEsw9c2QQeAIftl+Vegovlnee1c9QX4TctnWMn13TZye+giMm8e2LwA==" crossorigin="anonymous" referrerpolicy="no-referrer" />
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/css/bootstrap.min.css" rel="stylesheet">
<!-- DataTables CSS -->
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.13.1/css/jquery.dataTables.min.css">
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.13.1/css/dataTables.bootstrap5.min.css">
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/buttons/2.2.3/css/buttons.bootstrap5.min.css">
<!-- Select2 CSS -->
<link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/css/select2.min.css" rel="stylesheet" />
<!-- Custom CSS -->
<style>
:root {
@@ -37,26 +38,26 @@
--light-bg: #f9fafb;
--dark-bg: #1f2937;
}
body {
font-family: 'Inter', sans-serif;
background-color: #f3f4f6;
}
.navbar {
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}
.card {
border-radius: 0.75rem;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
transition: all 0.3s ease;
}
.card:hover {
box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
}
.card-header {
background-color: white;
border-bottom: 1px solid #e5e7eb;
@@ -64,64 +65,64 @@
border-top-right-radius: 0.75rem !important;
padding: 1.25rem;
}
.table {
--bs-table-striped-bg: rgba(59, 130, 246, 0.05);
}
.table th {
font-weight: 600;
background-color: #f8fafc;
color: #334155;
}
.btn-primary {
background-color: var(--primary-color);
border-color: var(--primary-color);
}
.btn-primary:hover {
background-color: var(--secondary-color);
border-color: var(--secondary-color);
}
.dropdown-menu {
border-radius: 0.5rem;
box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
}
.page-title {
color: #1e293b;
font-weight: 600;
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter {
margin-bottom: 1.5rem;
}
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
border: 1px solid #d1d5db;
border-radius: 0.375rem;
padding: 0.375rem 0.75rem;
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
margin: 0 0.25rem;
border-radius: 0.375rem;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
background: var(--primary-color) !important;
border-color: var(--primary-color) !important;
color: white !important;
}
.dt-buttons {
margin-bottom: 1rem;
}
.dt-button {
background-color: #f3f4f6 !important;
border-color: #d1d5db !important;
@@ -130,34 +131,74 @@
padding: 0.375rem 0.75rem !important;
font-size: 0.875rem !important;
}
.dt-button:hover {
background-color: #e5e7eb !important;
border-color: #9ca3af !important;
}
.modal-content {
border-radius: 0.75rem;
border: none;
}
.modal-header {
border-top-left-radius: 0.75rem;
border-top-right-radius: 0.75rem;
background-color: #f8fafc;
}
.form-check-input:checked {
background-color: var(--primary-color);
border-color: var(--primary-color);
}
.wrap-text {
white-space: normal;
word-wrap: break-word;
max-width: 250px;
}
</style>
<style>
/* Sidebar collapse functionality */
#sidebar {
min-width: 250px;
max-width: 250px;
transition: all 0.3s;
z-index: 999;
}
#sidebar.active {
min-width: 80px;
max-width: 80px;
}
#sidebar.active .sidebar-text,
#sidebar.active h6.textWhite:not(.sidebar-icon) {
display: none;
}
#sidebar.active .col-2 {
width: 100% !important;
}
#sidebar.active .nav-link {
text-align: center;
padding: 10px 5px;
}
#main-content {
transition: all 0.3s;
margin-left: 250px;
width: calc(100% - 250px);
}
/* When sidebar is collapsed, adjust main content */
body.sidebar-collapsed #main-content {
margin-left: 80px;
width: calc(100% - 80px);
}
</style>
<!-- Scripts -->
@vite(['resources/css/app.css', 'resources/js/app.js'])
@@ -165,36 +206,35 @@
<body class="font-sans antialiased">
<div class="min-h-screen bg-gray-100">
@include('layouts.navigation')
@include('layouts.partials.navbar')
<!-- Page Heading -->
@hasSection('header')
<header class="bg-white shadow">
<div class="max-w-7xl mx-auto py-6 px-4 sm:px-6 lg:px-8">
@yield('header')
</div>
</header>
@endif
<div class="container-fluid">
<div class="row">
<!-- Sidebar -->
@include('layouts.partials.sidebar')
<!-- Page Content -->
<main class="py-6">
@yield('content')
</main>
<!-- Footer -->
<footer class="bg-white py-4 shadow-inner mt-auto">
<div class="container text-center text-gray-500">
<p class="text-sm">© {{ date('Y') }} {{ config('app.name', 'Faculty Portal') }}. All rights reserved.</p>
<!-- Main Content Area -->
<main role="main" class="col-md-10 col-lg-10 ms-auto px-4" id="main-content">
@yield('content')
<!-- Footer -->
<footer class="bg-white py-4 shadow-inner mt-auto">
<div class="container text-center text-gray-500">
<p class="text-sm">© {{ date('Y') }} {{ config('app.name', 'Faculty Portal') }}. All rights reserved.</p>
</div>
</footer>
</main>
</div>
</footer>
</div>
</div>
<!-- jQuery -->
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<!-- Bootstrap JS -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/js/bootstrap.bundle.min.js"></script>
<!-- DataTables JS -->
<script src="https://cdn.datatables.net/1.13.1/js/jquery.dataTables.min.js"></script>
<script src="https://cdn.datatables.net/1.13.1/js/dataTables.bootstrap5.min.js"></script>
@@ -205,15 +245,38 @@
<script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.1.53/vfs_fonts.js"></script>
<script src="https://cdn.datatables.net/buttons/2.2.3/js/buttons.html5.min.js"></script>
<script src="https://cdn.datatables.net/buttons/2.2.3/js/buttons.print.min.js"></script>
<!-- Select2 JS -->
<script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/js/select2.min.js"></script>
<!-- Chart JS -->
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
<script src="https://cdn.jsdelivr.net/npm/chartjs-plugin-datalabels@2.0.0"></script>
<script>
$(document).ready(function() {
$('#sidebarCollapse').on('click', function() {
$('#sidebar').toggleClass('active');
$('body').toggleClass('sidebar-collapsed');
// Save state to localStorage
if ($('#sidebar').hasClass('active')) {
localStorage.setItem('sidebarCollapsed', 'true');
} else {
localStorage.setItem('sidebarCollapsed', 'false');
}
});
// Check if sidebar was collapsed previously
if (localStorage.getItem('sidebarCollapsed') === 'true') {
$('#sidebar').addClass('active');
$('body').addClass('sidebar-collapsed');
}
});
</script>
@yield('scripts')
</body>
</html>