clqms-fe1/docs/templates/report-print.html

332 lines
18 KiB
HTML

<!DOCTYPE html>
<html lang="en" data-theme="forest">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>CLQMS - Results Report</title>
<link href="https://cdn.jsdelivr.net/npm/daisyui@5" rel="stylesheet" type="text/css" />
<script src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"></script>
<link rel="stylesheet" href="shared.css">
<style>
/* Mobile: drawer overlay behavior */
@media (max-width: 1023px) {
.sidebar-container {
position: fixed;
left: 0;
top: 0;
height: 100vh;
z-index: 40;
transform: translateX(-100%);
transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
#sidebar-toggle:checked ~ .sidebar-container {
transform: translateX(0);
}
#sidebar-toggle:checked ~ .main-content {
margin-left: 0;
}
.overlay {
display: block;
position: fixed;
inset: 0;
background-color: rgba(0, 0, 0, 0.5);
z-index: 30;
opacity: 0;
visibility: hidden;
transition: opacity 0.3s, visibility 0.3s;
}
#sidebar-toggle:checked ~ .overlay {
opacity: 1;
visibility: visible;
}
}
/* Desktop: slide and push behavior */
@media (min-width: 1024px) {
.page-wrapper {
display: flex;
}
.sidebar-container {
position: relative;
width: 0;
flex-shrink: 0;
overflow: hidden;
transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
#sidebar-toggle:checked ~ .page-wrapper .sidebar-container {
width: 320px;
}
.main-content {
flex: 1;
transition: margin-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.overlay {
display: none;
}
}
/* Print styles */
@media print {
.no-print { display: none !important; }
.sidebar-container { display: none !important; }
.navbar { display: none !important; }
body { background: white; }
}
</style>
</head>
<body class="bg-gradient-to-br from-base-200 via-base-100 to-emerald-50/20">
<input id="sidebar-toggle" type="checkbox" class="hidden" />
<label for="sidebar-toggle" class="overlay"></label>
<div class="page-wrapper min-h-screen">
<!-- Sidebar -->
<div class="sidebar-container no-print">
<div class="h-full w-80 bg-base-200 shadow-xl border-r border-base-300">
<div class="p-4">
<div class="flex items-center gap-3 px-2 mb-6">
<div class="w-10 h-10 rounded-lg bg-emerald-100 flex items-center justify-center">
<svg class="w-6 h-6 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19.428 15.428a2 2 0 00-1.022-.547l-2.387-.477a6 6 0 00-3.86.517l-.318.158a6 6 0 01-3.86.517L6.05 15.21a2 2 0 00-1.806.547M8 4h8l-1 1v5.172a2 2 0 00.586 1.414l5 5c1.26 1.26.367 3.414-1.415 3.414H4.828c-1.782 0-2.674-2.154-1.414-3.414l5-5A2 2 0 009 10.172V5L8 4z"/></svg>
</div>
<span class="text-xl font-bold text-gray-800">CLQMS</span>
</div>
<ul class="menu w-full">
<li class="menu-title uppercase font-bold text-xs text-emerald-600/70 mt-2">Main</li>
<li><a href="dashboard.html" class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700 active:bg-emerald-100">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 6a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2H6a2 2 0 01-2-2V6zM14 6a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2h-2a2 2 0 01-2-2V6zM4 16a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2H6a2 2 0 01-2-2v-2zM14 16a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2h-2a2 2 0 01-2-2v-2z"/></svg>
Dashboard
</a></li>
<li><a href="master-data.html" class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 7v10c0 2.21 3.582 4 8 4s8-1.79 8-4V7M4 7c0 2.21 3.582 4 8 4s8-1.79 8-4M4 7c0-2.21 3.582-4 8-4s8 1.79 8 4m0 5c0 2.21-3.582 4-8 4s-8-1.79-8-4"/></svg>
Master Data
</a></li>
<li><a href="result-entry.html" class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12h6m-6 4h6m2 5H7a2 2 0 01-2-2V5a2 2 0 012-2h5.586a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V19a2 2 0 01-2 2z"/></svg>
Result Entry
</a></li>
<li><a href="report-print.html" class="active text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M17 17h2a2 2 0 002-2v-4a2 2 0 00-2-2H5a2 2 0 00-2 2v4a2 2 0 002 2h2m2 4h6a2 2 0 002-2v-4a2 2 0 00-2-2H9a2 2 0 00-2 2v4a2 2 0 002 2zm8-12V5a2 2 0 00-2-2H9a2 2 0 00-2 2v4h10z"/></svg>
Reports
</a></li>
<li class="menu-title uppercase font-bold text-xs text-emerald-600/70 mt-4">Laboratory</li>
<li><a class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/></svg>
Patients
</a></li>
<li><a class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-3 7h3m-3 4h3m-6-4h.01M9 16h.01"/></svg>
Orders
</a></li>
<li><a class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19.428 15.428a2 2 0 00-1.022-.547l-2.387-.477a6 6 0 00-3.86.517l-.318.158a6 6 0 01-3.86.517L6.05 15.21a2 2 0 00-1.806.547M8 4h8l-1 1v5.172a2 2 0 00.586 1.414l5 5c1.26 1.26.367 3.414-1.415 3.414H4.828c-1.782 0-2.674-2.154-1.414-3.414l5-5A2 2 0 009 10.172V5L8 4z"/></svg>
Specimens
</a></li>
<li><a class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z"/></svg>
Results
</a></li>
<li class="menu-title uppercase font-bold text-xs text-emerald-600/70 mt-4">Administration</li>
<li><a class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 21V5a2 2 0 00-2-2H7a2 2 0 00-2 2v16m14 0h2m-2 0h-5m-9 0H3m2 0h5M9 7h1m-1 4h1m4-4h1m-1 4h1m-5 10v-5a1 1 0 011-1h2a1 1 0 011 1v5m-4 0h4"/></svg>
Organization
</a></li>
<li><a class="text-gray-700 hover:bg-emerald-50 hover:text-emerald-700">
<svg class="w-5 h-5 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 4.354a4 4 0 110 5.292M15 21H3v-1a6 6 0 0112 0v1zm0 0h6v-1a6 6 0 00-9-5.197M13 7a4 4 0 11-8 0 4 4 0 018 0z"/></svg>
Users
</a></li>
<li class="mt-4 pt-4 border-t border-gray-200"><a href="login.html" class="text-red-500 hover:bg-red-50">
<svg class="w-5 h-5" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M17 16l4-4m0 0l-4-4m4 4H7m6 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h4a3 3 0 013 3v1"/></svg>
Logout
</a></li>
</ul>
</div>
</div>
</div>
<!-- Main Content -->
<div class="main-content flex flex-col">
<!-- Header -->
<div class="navbar bg-base-100 shadow-sm border-b border-base-300 no-print">
<div class="flex-none">
<label for="sidebar-toggle" class="btn btn-square btn-ghost text-gray-600 hover:bg-emerald-50 hover:text-emerald-600 cursor-pointer">
<svg class="w-6 h-6" fill="none" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M4 6h16M4 12h16M4 18h16" /></svg>
</label>
</div>
<div class="flex-1">
<a class="btn btn-ghost text-xl font-bold text-gray-800 hover:bg-gray-100">
<svg class="w-6 h-6 mr-2 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M17 17h2a2 2 0 002-2v-4a2 2 0 00-2-2H5a2 2 0 00-2 2v4a2 2 0 002 2h2m2 4h6a2 2 0 002-2v-4a2 2 0 00-2-2H9a2 2 0 00-2 2v4a2 2 0 002 2zm8-12V5a2 2 0 00-2-2H9a2 2 0 00-2 2v4h10z"/></svg>
Results Report
</a>
</div>
<div class="flex-none gap-2 no-print">
<button onclick="window.print()" class="btn btn-primary">Print Report</button>
<button class="btn btn-ghost ml-2">Back to Entry</button>
</div>
<div class="flex-none gap-2 no-print">
<div class="dropdown dropdown-end">
<div tabindex="0" role="button" class="btn btn-ghost btn-circle avatar placeholder hover:bg-emerald-50">
<div class="bg-emerald-100 text-emerald-700 rounded-full w-10 border-2 border-emerald-200 flex items-center justify-center">
<span class="font-semibold">DL</span>
</div>
</div>
<ul tabindex="0" class="dropdown-content z-[1] menu p-2 shadow-xl bg-base-100 rounded-box w-52 border border-emerald-200">
<li><a class="hover:bg-emerald-50"><svg class="w-4 h-4 mr-2 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"/></svg>Profile</a></li>
<li><a class="hover:bg-emerald-50"><svg class="w-4 h-4 mr-2 text-emerald-600" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M10.325 4.317c.426-1.756 2.924-1.756 3.35 0a1.724 1.724 0 002.573 1.066c1.543-.94 3.31.826 2.37 2.37a1.724 1.724 0 001.065 2.572c1.756.426 1.756 2.924 0 3.35a1.724 1.724 0 00-1.066 2.573c.94 1.543-.826 3.31-2.37 2.37a1.724 1.724 0 00-2.572 1.065c-.426 1.756-2.924 1.756-3.35 0a1.724 1.724 0 00-2.573-1.066c-1.543.94-3.31-.826-2.37-2.37a1.724 1.724 0 00-1.065-2.572c-1.756-.426-1.756-2.924 0-3.35a1.724 1.724 0 001.066-2.573c-.94-1.543.826-3.31 2.37-2.37.996.608 2.296.07 2.572-1.065z"/><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"/></svg>Settings</a></li>
<div class="divider my-0"></div>
<li><a href="login.html" class="text-error hover:bg-red-50"><svg class="w-4 h-4 mr-2" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M17 16l4-4m0 0l-4-4m4 4H7m6 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h4a3 3 0 013 3v1"/></svg>Logout</a></li>
</ul>
</div>
</div>
</div>
<!-- Report Content -->
<main class="flex-1 overflow-auto p-6">
<div class="mockup-window bg-base-100 shadow-2xl max-w-4xl mx-auto">
<div class="p-8">
<!-- Report Header -->
<div class="text-center mb-8">
<h1 class="text-3xl font-bold text-primary mb-2">CLQMS</h1>
<p class="text-lg text-base-content/70">Clinical Laboratory Quality Management System</p>
<div class="divider"></div>
<h2 class="text-2xl font-bold">Laboratory Results Report</h2>
</div>
<!-- Patient Information -->
<div class="mb-6">
<h3 class="font-bold text-lg text-primary mb-3">Patient Information</h3>
<div class="grid grid-cols-2 gap-4">
<div>
<span class="text-sm text-base-content/50">Patient Name:</span>
<span class="ml-2 font-bold">John Doe</span>
</div>
<div>
<span class="text-sm text-base-content/50">Patient ID:</span>
<span class="ml-2 font-bold">P-1001</span>
</div>
<div>
<span class="text-sm text-base-content/50">Date of Birth:</span>
<span class="ml-2">1985-03-15</span>
</div>
<div>
<span class="text-sm text-base-content/50">Sex:</span>
<span class="ml-2">Male</span>
</div>
</div>
</div>
<div class="divider"></div>
<!-- Order Information -->
<div class="mb-6">
<h3 class="font-bold text-lg text-primary mb-3">Order Information</h3>
<div class="grid grid-cols-2 gap-4">
<div>
<span class="text-sm text-base-content/50">Order ID:</span>
<span class="ml-2 font-bold">ORD-2024001</span>
</div>
<div>
<span class="text-sm text-base-content/50">Order Date:</span>
<span class="ml-2">2024-02-08 10:30</span>
</div>
<div>
<span class="text-sm text-base-content/50">Priority:</span>
<div class="badge badge-success ml-2">Routine</div>
</div>
<div>
<span class="text-sm text-base-content/50">Requesting Physician:</span>
<span class="ml-2">Dr. Smith</span>
</div>
</div>
</div>
<div class="divider"></div>
<!-- Results Table -->
<div class="mb-6">
<h3 class="font-bold text-lg text-primary mb-3">Test Results</h3>
<table class="table">
<thead>
<tr>
<th>Test Code</th>
<th>Test Name</th>
<th>Result</th>
<th>Unit</th>
<th>Flag</th>
<th>Reference Range</th>
</tr>
</thead>
<tbody>
<tr>
<th class="font-normal">CBC-HGB</th>
<td>Hemoglobin</td>
<td class="font-bold">145</td>
<td>g/L</td>
<td><div class="badge badge-success">N</div></td>
<td>130-170</td>
</tr>
<tr class="bg-error/10">
<th class="font-normal">CBC-WBC</th>
<td>White Blood Cell Count</td>
<td class="font-bold text-error">12.5</td>
<td>10^9/L</td>
<td><div class="badge badge-error">H</div></td>
<td>4.0-11.0</td>
</tr>
<tr>
<th class="font-normal">CBC-RBC</th>
<td>Red Blood Cell Count</td>
<td class="font-bold">4.8</td>
<td>10^12/L</td>
<td><div class="badge badge-success">N</div></td>
<td>4.5-5.5</td>
</tr>
<tr>
<th class="font-normal">CBC-PLT</th>
<td>Platelet Count</td>
<td class="font-bold">250</td>
<td>10^9/L</td>
<td><div class="badge badge-success">N</div></td>
<td>150-400</td>
</tr>
<tr>
<th class="font-normal">CBC-HCT</th>
<td>Hematocrit</td>
<td class="font-bold">42</td>
<td>%</td>
<td><div class="badge badge-success">N</div></td>
<td>40-50</td>
</tr>
</tbody>
</table>
</div>
<div class="divider"></div>
<!-- Footer Info -->
<div class="text-sm text-base-content/70 mb-4">
<p><strong>Report Generated:</strong> 2024-02-08 14:30:00</p>
<p><strong>Verified By:</strong> Dr. Lab User</p>
</div>
<div class="alert alert-info">
<svg class="w-6 h-6 shrink-0 stroke-current" fill="none" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z" /></svg>
<span><strong>Interpretation:</strong> Results show elevated WBC count, may indicate infection. Follow-up recommended.</span>
</div>
</div>
</div>
</main>
</div>
</div>
</body>
</html>