clqms-fe1/docs/templates/master-data.html

326 lines
17 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 - Master Data - Locations</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;
}
}
</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">
<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">
<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 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 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="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">
<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="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 - Locations
</a>
</div>
<div class="flex-none gap-2">
<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>
<!-- Main Content Area -->
<main class="flex-1 overflow-auto p-6">
<!-- Toolbar -->
<div class="card bg-base-100 shadow-xl mb-6">
<div class="card-body">
<div class="flex flex-col lg:flex-row gap-4 justify-between">
<div class="join w-full lg:w-auto">
<input type="text" placeholder="Search locations..." class="input input-bordered join-item" />
<select class="select select-bordered join-item">
<option>All Types</option>
<option>Ward</option>
<option>Clinic</option>
<option>Laboratory</option>
<option>Pharmacy</option>
</select>
</div>
<button class="btn btn-primary" onclick="document.getElementById('location_modal').showModal()">Add New Location</button>
</div>
</div>
</div>
<!-- Data Table -->
<div class="card bg-base-100 shadow-xl">
<div class="overflow-x-auto">
<table class="table table-zebra">
<thead>
<tr>
<th>Location Code</th>
<th>Location Name</th>
<th>Location Type</th>
<th>Site</th>
<th class="text-right">Actions</th>
</tr>
</thead>
<tbody>
<tr>
<th>LOC-001</th>
<td>Main Ward</td>
<td><div class="badge badge-ghost">Ward</div></td>
<td>Site A</td>
<td class="text-right">
<div class="join justify-end">
<button class="btn btn-sm btn-ghost">Edit</button>
<button class="btn btn-sm btn-error btn-ghost">Delete</button>
</div>
</td>
</tr>
<tr>
<th>LOC-002</th>
<td>Clinic A</td>
<td><div class="badge badge-info">Clinic</div></td>
<td>Site A</td>
<td class="text-right">
<div class="join justify-end">
<button class="btn btn-sm btn-ghost">Edit</button>
<button class="btn btn-sm btn-error btn-ghost">Delete</button>
</div>
</td>
</tr>
<tr>
<th>LOC-003</th>
<td>Emergency Lab</td>
<td><div class="badge badge-success">Laboratory</div></td>
<td>Site B</td>
<td class="text-right">
<div class="join justify-end">
<button class="btn btn-sm btn-ghost">Edit</button>
<button class="btn btn-sm btn-error btn-ghost">Delete</button>
</div>
</td>
</tr>
<tr>
<th>LOC-004</th>
<td>Main Pharmacy</td>
<td><div class="badge badge-accent">Pharmacy</div></td>
<td>Site A</td>
<td class="text-right">
<div class="join justify-end">
<button class="btn btn-sm btn-ghost">Edit</button>
<button class="btn btn-sm btn-error btn-ghost">Delete</button>
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- Pagination -->
<div class="join justify-center mt-4">
<button class="join-item btn btn-sm" disabled>Previous</button>
<button class="join-item btn btn-sm btn-active">1</button>
<button class="join-item btn btn-sm">2</button>
<button class="join-item btn btn-sm">3</button>
<button class="join-item btn btn-sm">...</button>
<button class="join-item btn btn-sm">10</button>
<button class="join-item btn btn-sm">Next</button>
</div>
</div>
</main>
</div>
</div>
<!-- Add/Edit Modal -->
<dialog id="location_modal" class="modal">
<div class="modal-box">
<h3 class="font-bold text-lg text-primary mb-4">Add Location</h3>
<form>
<div class="form-control">
<label class="label"><span class="label-text">Location Code</span></label>
<input type="text" placeholder="e.g., LOC-001" class="input input-bordered" />
</div>
<div class="form-control">
<label class="label"><span class="label-text">Location Name</span></label>
<input type="text" placeholder="e.g., Main Ward" class="input input-bordered" />
</div>
<div class="form-control">
<label class="label"><span class="label-text">Location Type</span></label>
<select class="select select-bordered">
<option>Ward</option>
<option>Clinic</option>
<option>Laboratory</option>
<option>Pharmacy</option>
</select>
</div>
<div class="form-control">
<label class="label"><span class="label-text">Site</span></label>
<select class="select select-bordered">
<option>Site A</option>
<option>Site B</option>
<option>Site C</option>
</select>
</div>
</form>
<div class="modal-action">
<form method="dialog">
<button class="btn">Cancel</button>
</form>
<button class="btn btn-primary">Save</button>
</div>
</div>
<form method="dialog" class="modal-backdrop">
<button>close</button>
</form>
</dialog>
</body>
</html>