export charts
This commit is contained in:
@@ -7,12 +7,14 @@
|
||||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||
<script src="https://cdn.jsdelivr.net/npm/chart.js@3.9.1"></script>
|
||||
<script src="https://cdn.jsdelivr.net/npm/chartjs-plugin-datalabels@2.2.0"></script>
|
||||
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/2.5.1/jspdf.umd.min.js"></script>
|
||||
<script src="https://html2canvas.hertzen.com/dist/html2canvas.min.js"></script>
|
||||
<link rel="stylesheet" href="https://unpkg.com/leaflet/dist/leaflet.css" />
|
||||
<script src="https://unpkg.com/leaflet/dist/leaflet.js"></script>
|
||||
|
||||
<script src="/js/dashboard/filter.js"></script>
|
||||
<script src="/js/dashboard/charts.js"></script>
|
||||
<script src="/js/dashboard/export.js"></script>
|
||||
|
||||
|
||||
<style>
|
||||
@@ -20,7 +22,6 @@
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
/* HEADER */
|
||||
.top-navbar {
|
||||
height: 60px;
|
||||
background: #0B8F3C;
|
||||
@@ -35,7 +36,6 @@
|
||||
font-size: 18px;
|
||||
}
|
||||
|
||||
/* NAV BAR */
|
||||
.nav-bar {
|
||||
display: flex;
|
||||
background: white;
|
||||
@@ -48,7 +48,6 @@
|
||||
border-bottom: 1px solid #dcdcdc;
|
||||
}
|
||||
|
||||
/* NAV ITEMS */
|
||||
.btn-theme-outline {
|
||||
background-color: #fff;
|
||||
color: #0B8F3C;
|
||||
@@ -110,12 +109,65 @@
|
||||
.card h3 {
|
||||
color: #0B8F3C;
|
||||
}
|
||||
|
||||
.export-control {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
#exportItems {
|
||||
display: flex;
|
||||
gap: 8px;
|
||||
opacity: 0;
|
||||
transform: translateX(-10px);
|
||||
pointer-events: none;
|
||||
width: 0;
|
||||
overflow: hidden;
|
||||
transition: all 0.2s ease;
|
||||
}
|
||||
|
||||
#exportItems.show {
|
||||
opacity: 1;
|
||||
transform: translateX(0);
|
||||
pointer-events: auto;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
|
||||
.export-modal {
|
||||
display: none;
|
||||
position: fixed;
|
||||
inset: 0;
|
||||
background: rgba(0, 0, 0, 0.4);
|
||||
z-index: 10000;
|
||||
}
|
||||
|
||||
.export-content {
|
||||
background: white;
|
||||
padding: 20px;
|
||||
width: 400px;
|
||||
margin: 10% auto;
|
||||
border-radius: 10px;
|
||||
}
|
||||
|
||||
@media print {
|
||||
#floatingExport {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
.nav-bar,
|
||||
.top-navbar {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
.card {
|
||||
page-break-inside: avoid;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<!-- TOP HEADER -->
|
||||
<div class="top-navbar">
|
||||
|
||||
<div class="brand-title">
|
||||
@@ -128,7 +180,6 @@
|
||||
|
||||
</div>
|
||||
|
||||
<!-- NAVIGATION BAR -->
|
||||
<div class="nav-bar">
|
||||
|
||||
<a href="/dashboard" class="nav-item {{ request()->is('dashboard') ? 'active-tab' : '' }}">
|
||||
@@ -141,12 +192,11 @@
|
||||
{{ $program->code }}
|
||||
</a>
|
||||
@endforeach -->
|
||||
@foreach($programs->where('code', '!=', 'NDS') as $program)
|
||||
@foreach($programs as $program)
|
||||
|
||||
@if($program->code === 'SEQ')
|
||||
|
||||
<a href="/dashboard/seq"
|
||||
class="nav-item {{ request()->is('dashboard/seq') ? 'active-tab' : '' }}">
|
||||
|
||||
<a href="/dashboard/seq" class="nav-item {{ request()->is('dashboard/seq') ? 'active-tab' : '' }}">
|
||||
SEQ
|
||||
</a>
|
||||
@else
|
||||
@@ -158,33 +208,69 @@
|
||||
|
||||
@endforeach
|
||||
|
||||
<div class="ms-auto d-flex align-items-center gap-4 pe-3">
|
||||
<div class="ms-auto d-flex align-items-center gap-2 pe-3">
|
||||
|
||||
<button type="button" onclick="reloadDataSource()" class="btn btn-sm btn-theme-outline">
|
||||
Refresh Data
|
||||
</button>
|
||||
|
||||
<div id="exportControl" class="d-flex align-items-center gap-2">
|
||||
|
||||
<button id="exportToggle" class="btn btn-sm btn-theme-outline">
|
||||
Export ▸
|
||||
</button>
|
||||
|
||||
<div id="exportItems" class="align-items-center gap-2">
|
||||
|
||||
<button class="btn btn-sm btn-light" onclick="openChartSelector()">Charts</button>
|
||||
<button class="btn btn-sm btn-light" onclick="exportFullDashboard()">Screen</button>
|
||||
<button class="btn btn-sm btn-light" onclick="window.print()">Print</button>
|
||||
|
||||
<button class="btn btn-sm btn-outline-secondary" id="exportClose">✕</button>
|
||||
|
||||
</div>
|
||||
<div id="chartModal" class="export-modal">
|
||||
<div class="export-content">
|
||||
<h5>Select Charts</h5>
|
||||
<div id="chartList"></div>
|
||||
|
||||
<div class="mt-3 d-flex justify-content-end gap-2">
|
||||
<button onclick="closeChartSelector()">Cancel</button>
|
||||
<button onclick="exportSelectedCharts()">Download PDF</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- Main Wrapper -->
|
||||
<div class="main-wrapper">
|
||||
|
||||
<!-- Page Content -->
|
||||
<div class="content-area">
|
||||
@yield('content')
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
@yield('scripts')
|
||||
|
||||
<script>
|
||||
window.addEventListener("click", (e) => {
|
||||
const modal = document.getElementById("chartModal");
|
||||
|
||||
if (e.target === modal) {
|
||||
modal.style.display = "none";
|
||||
}
|
||||
});
|
||||
function reloadDataSource() {
|
||||
fetch(`/api/dashboard/reload`)
|
||||
.then(res => res.json())
|
||||
.then(data => {
|
||||
location.reload()
|
||||
});
|
||||
.then(() => location.reload());
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user