feat: add new "out for cal" status for units currently being calibrated.
-retire unit button changed to be more dramatic... lol
This commit is contained in:
@@ -92,7 +92,7 @@
|
||||
<p id="deployedStatus" class="font-medium text-gray-900 dark:text-white">--</p>
|
||||
</div>
|
||||
<div>
|
||||
<span class="text-sm text-gray-500 dark:text-gray-400">Retired</span>
|
||||
<span class="text-sm text-gray-500 dark:text-gray-400">Unit Status</span>
|
||||
<p id="retiredStatus" class="font-medium text-gray-900 dark:text-white">--</p>
|
||||
</div>
|
||||
</div>
|
||||
@@ -497,18 +497,28 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Checkboxes -->
|
||||
<div class="flex items-center gap-6 border-t border-gray-200 dark:border-gray-700 pt-4">
|
||||
<label class="flex items-center gap-2 cursor-pointer">
|
||||
<input type="checkbox" name="deployed" id="deployed" value="true"
|
||||
class="w-4 h-4 text-seismo-orange focus:ring-seismo-orange rounded">
|
||||
<span class="text-sm text-gray-700 dark:text-gray-300">Deployed</span>
|
||||
</label>
|
||||
<label class="flex items-center gap-2 cursor-pointer">
|
||||
<input type="checkbox" name="retired" id="retired" value="true"
|
||||
class="w-4 h-4 text-seismo-orange focus:ring-seismo-orange rounded">
|
||||
<span class="text-sm text-gray-700 dark:text-gray-300">Retired</span>
|
||||
</label>
|
||||
<!-- Status Checkboxes -->
|
||||
<div class="border-t border-gray-200 dark:border-gray-700 pt-4 space-y-3">
|
||||
<div class="flex items-center gap-6">
|
||||
<label class="flex items-center gap-2 cursor-pointer">
|
||||
<input type="checkbox" name="deployed" id="deployed" value="true"
|
||||
class="w-4 h-4 text-seismo-orange focus:ring-seismo-orange rounded">
|
||||
<span class="text-sm text-gray-700 dark:text-gray-300">Deployed</span>
|
||||
</label>
|
||||
<label class="flex items-center gap-2 cursor-pointer">
|
||||
<input type="checkbox" name="out_for_calibration" id="outForCalibration" value="true"
|
||||
class="w-4 h-4 text-purple-600 focus:ring-purple-500 rounded">
|
||||
<span class="text-sm text-gray-700 dark:text-gray-300">Out for Calibration</span>
|
||||
</label>
|
||||
</div>
|
||||
<!-- Hidden field for retired — controlled by the Retire button below -->
|
||||
<input type="hidden" name="retired" id="retired" value="">
|
||||
<div id="retireButtonSection">
|
||||
<button type="button" id="retireBtn"
|
||||
class="px-4 py-2 text-sm font-medium rounded-lg border transition-colors"
|
||||
onclick="toggleRetired()">
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Notes -->
|
||||
@@ -817,7 +827,16 @@ function populateViewMode() {
|
||||
}
|
||||
|
||||
document.getElementById('deployedStatus').textContent = currentUnit.deployed ? 'Yes' : 'No';
|
||||
document.getElementById('retiredStatus').textContent = currentUnit.retired ? 'Yes' : 'No';
|
||||
if (currentUnit.retired) {
|
||||
document.getElementById('retiredStatus').textContent = 'Retired';
|
||||
document.getElementById('retiredStatus').className = 'font-medium text-red-600 dark:text-red-400';
|
||||
} else if (currentUnit.out_for_calibration) {
|
||||
document.getElementById('retiredStatus').textContent = 'Out for Calibration';
|
||||
document.getElementById('retiredStatus').className = 'font-medium text-purple-600 dark:text-purple-400';
|
||||
} else {
|
||||
document.getElementById('retiredStatus').textContent = 'Active';
|
||||
document.getElementById('retiredStatus').className = 'font-medium text-gray-900 dark:text-white';
|
||||
}
|
||||
|
||||
// Basic info
|
||||
document.getElementById('viewDeviceType').textContent = currentUnit.device_type || '--';
|
||||
@@ -1009,7 +1028,9 @@ function populateEditForm() {
|
||||
document.getElementById('address').value = currentUnit.address || '';
|
||||
document.getElementById('coordinates').value = currentUnit.coordinates || '';
|
||||
document.getElementById('deployed').checked = currentUnit.deployed;
|
||||
document.getElementById('retired').checked = currentUnit.retired;
|
||||
document.getElementById('outForCalibration').checked = currentUnit.out_for_calibration || false;
|
||||
document.getElementById('retired').value = currentUnit.retired ? 'true' : '';
|
||||
updateRetireButton(currentUnit.retired);
|
||||
document.getElementById('note').value = currentUnit.note || '';
|
||||
|
||||
// Seismograph fields
|
||||
@@ -1153,6 +1174,25 @@ function cancelEdit() {
|
||||
populateEditForm();
|
||||
}
|
||||
|
||||
function updateRetireButton(isRetired) {
|
||||
const btn = document.getElementById('retireBtn');
|
||||
if (!btn) return;
|
||||
if (isRetired) {
|
||||
btn.textContent = 'Un-Retire Unit';
|
||||
btn.className = 'px-4 py-2 text-sm font-medium rounded-lg border transition-colors bg-gray-100 dark:bg-gray-700 text-gray-700 dark:text-gray-300 border-gray-300 dark:border-gray-600 hover:bg-gray-200 dark:hover:bg-gray-600';
|
||||
} else {
|
||||
btn.textContent = 'Retire Unit';
|
||||
btn.className = 'px-4 py-2 text-sm font-medium rounded-lg border transition-colors bg-red-50 dark:bg-red-900/20 text-red-700 dark:text-red-400 border-red-300 dark:border-red-700 hover:bg-red-100 dark:hover:bg-red-900/40';
|
||||
}
|
||||
}
|
||||
|
||||
function toggleRetired() {
|
||||
const hiddenInput = document.getElementById('retired');
|
||||
const isCurrentlyRetired = hiddenInput.value === 'true';
|
||||
hiddenInput.value = isCurrentlyRetired ? '' : 'true';
|
||||
updateRetireButton(!isCurrentlyRetired);
|
||||
}
|
||||
|
||||
// Handle form submission
|
||||
document.getElementById('editForm').addEventListener('submit', async function(e) {
|
||||
e.preventDefault();
|
||||
|
||||
Reference in New Issue
Block a user