Feat: Filter and improved UI

This commit is contained in:
Sallu9007
2025-04-16 15:32:59 +05:30
parent 411cc7fe03
commit 355eee4892
7 changed files with 520 additions and 161 deletions

View File

@@ -1,37 +1,205 @@
<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="csrf-token" content="{{ csrf_token() }}">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="csrf-token" content="{{ csrf_token() }}">
<title>{{ config('app.name', 'Laravel') }}</title>
<title>{{ config('app.name', 'Faculty Portal') }}</title>
<!-- Fonts -->
<link rel="preconnect" href="https://fonts.bunny.net">
<link href="https://fonts.bunny.net/css?family=figtree:400,500,600&display=swap" rel="stylesheet" />
<!-- 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" />
<!-- 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">
<!-- Custom CSS -->
<style>
:root {
--primary-color: #3b82f6;
--secondary-color: #1e40af;
--accent-color: #93c5fd;
--success-color: #10b981;
--warning-color: #f59e0b;
--danger-color: #ef4444;
--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;
border-top-left-radius: 0.75rem !important;
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_filter {
margin-bottom: 1.5rem;
}
.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;
color: #374151 !important;
border-radius: 0.375rem !important;
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>
<!-- Scripts -->
@vite(['resources/css/app.css', 'resources/js/app.js'])
</head>
<body class="font-sans antialiased">
<div class="min-h-screen bg-gray-100">
@include('layouts.navigation')
<!-- Scripts -->
@vite(['resources/css/app.css', 'resources/js/app.js'])
</head>
<!-- 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
<body class="font-sans antialiased">
<div class="min-h-screen bg-gray-100">
@include('layouts.navigation')
<!-- Page Content -->
<main>
@yield('content')
</main>
</div>
</body>
<!-- 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
<!-- 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>
</div>
</footer>
</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>
<script src="https://cdn.datatables.net/buttons/2.2.3/js/dataTables.buttons.min.js"></script>
<script src="https://cdn.datatables.net/buttons/2.2.3/js/buttons.bootstrap5.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jszip/3.1.3/jszip.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.1.53/pdfmake.min.js"></script>
<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>
@yield('scripts')
</html>
</body>
</html>