Compare commits
3 Commits
feature/mo
...
0a633258a8
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0a633258a8 | ||
| 36202e1a3a | |||
|
|
38bbd13c7f |
54
src/main.js
54
src/main.js
@@ -551,9 +551,9 @@ function hostRowHTML(host, index, showPin = true) {
|
||||
: `<div class="flex-shrink-0 w-4 h-4"></div>`;
|
||||
return `
|
||||
<div class="host-row bg-gray-800/50 rounded-lg p-2 border border-gray-700/50" data-index="${index}">
|
||||
<div class="flex items-center gap-4 min-w-0">
|
||||
<div class="host-row-inner flex items-center gap-4 min-w-0">
|
||||
${pinBtn}
|
||||
<div class="w-[420px] flex-shrink-0 grid grid-cols-[minmax(0,1fr)_auto] items-center">
|
||||
<div class="host-info-panel w-[420px] flex-shrink-0 grid grid-cols-[minmax(0,1fr)_auto] items-center">
|
||||
<div class="flex items-center gap-2 min-w-[200px]">
|
||||
<div class="w-3 h-3 rounded-full flex-shrink-0" style="background-color: ${latencyHex(null)}"></div>
|
||||
<span class="font-medium text-white truncate">${host.name}</span>
|
||||
@@ -589,9 +589,9 @@ function buildUI(state) {
|
||||
app.innerHTML = `
|
||||
<div class="mx-auto px-[5%] py-8">
|
||||
<header class="mb-8">
|
||||
<div class="flex items-center justify-between mb-4">
|
||||
<div class="header-top flex items-center justify-between mb-4">
|
||||
<h1 class="text-3xl font-bold text-white"><a href="https://git.eeqj.de/sneak/netwatch" target="_blank" rel="noopener" class="underline decoration-dashed decoration-gray-500 underline-offset-4">NetWatch</a> by <a href="https://sneak.berlin" target="_blank" rel="noopener" class="text-blue-400 underline hover:text-blue-300">@sneak</a></h1>
|
||||
<div class="flex flex-col items-end gap-2">
|
||||
<div class="header-controls flex flex-col items-end gap-2">
|
||||
<button id="pause-btn"
|
||||
class="flex items-center gap-3 px-6 py-3 bg-gray-800 hover:bg-gray-700 border border-gray-600 rounded-lg transition-colors focus:outline-none focus:ring-2 focus:ring-blue-500">
|
||||
<svg id="pause-icon" class="w-8 h-8 text-yellow-400" fill="currentColor" viewBox="0 0 24 24">
|
||||
@@ -1128,25 +1128,39 @@ function handleResize(state) {
|
||||
|
||||
// --- Bootstrap ---------------------------------------------------------------
|
||||
|
||||
// --- Mobile Detection --------------------------------------------------------
|
||||
|
||||
function isMobile() {
|
||||
// Check both user agent and viewport width for robust detection
|
||||
const uaMatch =
|
||||
/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
|
||||
navigator.userAgent,
|
||||
);
|
||||
const narrowViewport = window.innerWidth <= 768;
|
||||
return uaMatch || narrowViewport;
|
||||
}
|
||||
|
||||
function buildMobileUI() {
|
||||
const app = document.getElementById("app");
|
||||
app.innerHTML = `
|
||||
<div class="mx-auto px-[5%] py-8">
|
||||
<header class="mb-8">
|
||||
<h1 class="text-3xl font-bold text-white"><a href="https://git.eeqj.de/sneak/netwatch" target="_blank" rel="noopener" class="underline decoration-dashed decoration-gray-500 underline-offset-4">NetWatch</a> by <a href="https://sneak.berlin" target="_blank" rel="noopener" class="text-blue-400 underline hover:text-blue-300">@sneak</a></h1>
|
||||
<p class="text-gray-400 text-sm mt-2">Real-time network latency monitor</p>
|
||||
</header>
|
||||
<div style="margin: 2rem auto; max-width: 500px; padding: 3rem 2rem; background: rgba(31, 41, 55, 0.7); border: 1px solid rgba(75, 85, 99, 0.5); border-radius: 1rem; text-align: center;">
|
||||
<p style="font-size: 1.5rem; font-weight: 600; color: #d1d5db;">Not yet available on mobile.</p>
|
||||
<p style="font-size: 0.875rem; color: #6b7280; margin-top: 1rem;">Please visit on a desktop browser for the full experience.</p>
|
||||
</div>
|
||||
</div>`;
|
||||
}
|
||||
|
||||
async function init() {
|
||||
log.info("NetWatch starting");
|
||||
|
||||
// Mobile detection — show a friendly message and bail out early
|
||||
if (window.innerWidth < 768) {
|
||||
const app = document.getElementById("app");
|
||||
app.innerHTML = `
|
||||
<div class="mx-auto px-[5%] py-8">
|
||||
<header class="mb-8">
|
||||
<h1 class="text-3xl font-bold text-white"><a href="https://git.eeqj.de/sneak/netwatch" target="_blank" rel="noopener" class="underline decoration-dashed decoration-gray-500 underline-offset-4">NetWatch</a> by <a href="https://sneak.berlin" target="_blank" rel="noopener" class="text-blue-400 underline hover:text-blue-300">@sneak</a></h1>
|
||||
<p class="text-gray-400 mt-2">Real-time network connectivity monitor</p>
|
||||
</header>
|
||||
<div style="display:flex;align-items:center;justify-content:center;min-height:50vh;">
|
||||
<div style="background:#1f2937;border:1px solid #374151;border-radius:12px;padding:2rem 1.5rem;text-align:center;max-width:90vw;">
|
||||
<p style="font-size:1.25rem;color:#e5e7eb;margin:0;">Not yet available on mobile.</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>`;
|
||||
log.info("Mobile viewport detected — skipping monitor startup");
|
||||
if (isMobile()) {
|
||||
log.info("Mobile device detected — showing placeholder");
|
||||
buildMobileUI();
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
@@ -21,3 +21,54 @@ body {
|
||||
rgba(255, 255, 255, 0) 100%
|
||||
);
|
||||
}
|
||||
|
||||
/* Mobile-responsive host rows */
|
||||
@media (max-width: 768px) {
|
||||
.host-row-inner {
|
||||
flex-direction: column !important;
|
||||
align-items: stretch !important;
|
||||
gap: 0.5rem !important;
|
||||
}
|
||||
|
||||
.host-row-inner .pin-btn {
|
||||
align-self: flex-end;
|
||||
}
|
||||
|
||||
.host-info-panel {
|
||||
width: 100% !important;
|
||||
}
|
||||
|
||||
.host-row .sparkline-container {
|
||||
width: 100% !important;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
/* Summary line: allow wrapping */
|
||||
#summary {
|
||||
display: flex !important;
|
||||
flex-wrap: wrap !important;
|
||||
gap: 0.25rem 0.5rem !important;
|
||||
justify-content: center !important;
|
||||
}
|
||||
|
||||
#summary .text-gray-600.mx-3 {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* Header: stack controls below title */
|
||||
.header-top {
|
||||
flex-direction: column !important;
|
||||
align-items: flex-start !important;
|
||||
gap: 1rem !important;
|
||||
}
|
||||
|
||||
.header-controls {
|
||||
align-items: flex-start !important;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#pause-btn {
|
||||
width: 100%;
|
||||
justify-content: center;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user