fixed time left display

This commit is contained in:
Enki 2025-01-10 09:04:26 +00:00
parent 63ccbd4bb4
commit 291771d033
2 changed files with 40 additions and 44 deletions

View File

@ -41,16 +41,11 @@ def dashboard():
subscription_data = []
for sub in subscriptions:
remaining_time = None
if sub.expiry_time > datetime.utcnow():
remaining_time = sub.expiry_time - datetime.utcnow()
subscription_data.append({
'id': sub.id,
'status': sub.status.value,
'start_time': sub.start_time,
'expiry_time': sub.expiry_time,
'remaining_time': str(remaining_time) if remaining_time else None,
'assigned_ip': sub.assigned_ip
})

View File

@ -27,24 +27,15 @@
</div>
<div>
<p class="text-gray-400">Expires</p>
<p class="font-medium">{{ active_subscription.expiry_time.strftime('%Y-%m-%d %H:%M UTC') }}</p>
<p class="font-medium" id="expiry-time">
{{ active_subscription.expiry_time.strftime('%Y-%m-%d %H:%M UTC') }}
</p>
</div>
<div>
<p class="text-gray-400">Time Remaining</p>
<p class="font-medium">{{ active_subscription.remaining_time }}</p>
<p class="font-medium" id="time-remaining">Calculating...</p>
</div>
</div>
<div class="mt-6 flex space-x-4">
<button onclick="downloadConfig('{{ active_subscription.id }}')"
class="px-4 py-2 bg-blue-600 hover:bg-blue-700 rounded text-white">
Download Config
</button>
<button onclick="showQRCode('{{ active_subscription.id }}')"
class="px-4 py-2 bg-green-600 hover:bg-green-700 rounded text-white">
Show QR Code
</button>
</div>
</div>
{% else %}
<div class="bg-dark-lighter rounded-lg p-6 mb-8 text-center">
@ -72,8 +63,12 @@
{% for sub in subscriptions %}
<tr class="border-t border-gray-700">
<td class="p-2">{{ sub.status }}</td>
<td class="p-2">{{ sub.start_time.strftime('%Y-%m-%d %H:%M UTC') }}</td>
<td class="p-2">{{ sub.expiry_time.strftime('%Y-%m-%d %H:%M UTC') }}</td>
<td class="p-2">
{{ sub.start_time.strftime('%Y-%m-%d %H:%M UTC') }}
</td>
<td class="p-2">
{{ sub.expiry_time.strftime('%Y-%m-%d %H:%M UTC') }}
</td>
<td class="p-2 font-mono">{{ sub.assigned_ip }}</td>
</tr>
{% endfor %}
@ -85,30 +80,36 @@
</div>
<script>
async function downloadConfig(subscriptionId) {
try {
const response = await fetch(`/api/subscription/config/${subscriptionId}`);
if (!response.ok) throw new Error('Failed to fetch config');
const data = await response.json();
const blob = new Blob([data.config], { type: 'text/plain' });
const url = URL.createObjectURL(blob);
const a = document.createElement('a');
a.href = url;
a.download = 'wireguard.conf';
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
URL.revokeObjectURL(url);
} catch (error) {
console.error('Error downloading config:', error);
alert('Failed to download configuration');
}
}
document.addEventListener('DOMContentLoaded', function() {
const expiryTimeElement = document.getElementById('expiry-time');
const timeRemainingElement = document.getElementById('time-remaining');
function showQRCode(subscriptionId) {
// TODO: Implement QR code display
alert('QR Code feature coming soon');
}
if (expiryTimeElement && timeRemainingElement) {
const expiryTime = new Date(expiryTimeElement.innerText);
const calculateTimeRemaining = () => {
const now = new Date();
const diff = expiryTime - now;
if (diff <= 0) {
timeRemainingElement.innerText = 'Expired';
return;
}
const days = Math.floor(diff / (1000 * 60 * 60 * 24));
const hours = Math.floor((diff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
const minutes = Math.floor((diff % (1000 * 60 * 60)) / (1000 * 60));
let timeString = '';
if (days > 0) timeString += `${days}d `;
if (hours > 0) timeString += `${hours}h `;
timeString += `${minutes}m`;
timeRemainingElement.innerText = timeString;
};
calculateTimeRemaining();
setInterval(calculateTimeRemaining, 60000);
}
});
</script>
{% endblock %}