@api.global/typedserver
Version:
A TypeScript-based project for easy serving of static files with support for live reloading, compression, and typed requests.
328 lines (322 loc) • 28.8 kB
JavaScript
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
var _, done = false;
for (var i = decorators.length - 1; i >= 0; i--) {
var context = {};
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
if (kind === "accessor") {
if (result === void 0) continue;
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
if (_ = accept(result.get)) descriptor.get = _;
if (_ = accept(result.set)) descriptor.set = _;
if (_ = accept(result.init)) initializers.unshift(_);
}
else if (_ = accept(result)) {
if (kind === "field") initializers.unshift(_);
else descriptor[key] = _;
}
}
if (target) Object.defineProperty(target, contextIn.name, descriptor);
done = true;
};
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
var useValue = arguments.length > 2;
for (var i = 0; i < initializers.length; i++) {
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
}
return useValue ? value : void 0;
};
import { LitElement, html, css, property, state, customElement } from './plugins.js';
import { sharedStyles, panelStyles, gaugeStyles, buttonStyles, speedtestStyles } from './sw-dash-styles.js';
import { SwDashTable } from './sw-dash-table.js';
/**
* Overview panel component with metrics gauges and stats
*/
let SwDashOverview = (() => {
let _classDecorators = [customElement('sw-dash-overview')];
let _classDescriptor;
let _classExtraInitializers = [];
let _classThis;
let _classSuper = LitElement;
let _metrics_decorators;
let _metrics_initializers = [];
let _metrics_extraInitializers = [];
let _eventCountLastHour_decorators;
let _eventCountLastHour_initializers = [];
let _eventCountLastHour_extraInitializers = [];
let _speedtestRunning_decorators;
let _speedtestRunning_initializers = [];
let _speedtestRunning_extraInitializers = [];
let _speedtestPhase_decorators;
let _speedtestPhase_initializers = [];
let _speedtestPhase_extraInitializers = [];
let _speedtestProgress_decorators;
let _speedtestProgress_initializers = [];
let _speedtestProgress_extraInitializers = [];
let _speedtestElapsed_decorators;
let _speedtestElapsed_initializers = [];
let _speedtestElapsed_extraInitializers = [];
var SwDashOverview = class extends _classSuper {
static { _classThis = this; }
static {
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
_metrics_decorators = [property({ type: Object })];
_eventCountLastHour_decorators = [property({ type: Number })];
_speedtestRunning_decorators = [state()];
_speedtestPhase_decorators = [state()];
_speedtestProgress_decorators = [state()];
_speedtestElapsed_decorators = [state()];
__esDecorate(this, null, _metrics_decorators, { kind: "accessor", name: "metrics", static: false, private: false, access: { has: obj => "metrics" in obj, get: obj => obj.metrics, set: (obj, value) => { obj.metrics = value; } }, metadata: _metadata }, _metrics_initializers, _metrics_extraInitializers);
__esDecorate(this, null, _eventCountLastHour_decorators, { kind: "accessor", name: "eventCountLastHour", static: false, private: false, access: { has: obj => "eventCountLastHour" in obj, get: obj => obj.eventCountLastHour, set: (obj, value) => { obj.eventCountLastHour = value; } }, metadata: _metadata }, _eventCountLastHour_initializers, _eventCountLastHour_extraInitializers);
__esDecorate(this, null, _speedtestRunning_decorators, { kind: "accessor", name: "speedtestRunning", static: false, private: false, access: { has: obj => "speedtestRunning" in obj, get: obj => obj.speedtestRunning, set: (obj, value) => { obj.speedtestRunning = value; } }, metadata: _metadata }, _speedtestRunning_initializers, _speedtestRunning_extraInitializers);
__esDecorate(this, null, _speedtestPhase_decorators, { kind: "accessor", name: "speedtestPhase", static: false, private: false, access: { has: obj => "speedtestPhase" in obj, get: obj => obj.speedtestPhase, set: (obj, value) => { obj.speedtestPhase = value; } }, metadata: _metadata }, _speedtestPhase_initializers, _speedtestPhase_extraInitializers);
__esDecorate(this, null, _speedtestProgress_decorators, { kind: "accessor", name: "speedtestProgress", static: false, private: false, access: { has: obj => "speedtestProgress" in obj, get: obj => obj.speedtestProgress, set: (obj, value) => { obj.speedtestProgress = value; } }, metadata: _metadata }, _speedtestProgress_initializers, _speedtestProgress_extraInitializers);
__esDecorate(this, null, _speedtestElapsed_decorators, { kind: "accessor", name: "speedtestElapsed", static: false, private: false, access: { has: obj => "speedtestElapsed" in obj, get: obj => obj.speedtestElapsed, set: (obj, value) => { obj.speedtestElapsed = value; } }, metadata: _metadata }, _speedtestElapsed_initializers, _speedtestElapsed_extraInitializers);
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
SwDashOverview = _classThis = _classDescriptor.value;
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
}
static styles = [
sharedStyles,
panelStyles,
gaugeStyles,
buttonStyles,
speedtestStyles,
css `
:host {
display: block;
}
.panel-content {
padding: var(--space-4);
}
.section-divider {
margin-top: var(--space-4);
padding-top: var(--space-4);
border-top: 1px solid var(--border-muted);
}
`
];
#metrics_accessor_storage = __runInitializers(this, _metrics_initializers, null);
get metrics() { return this.#metrics_accessor_storage; }
set metrics(value) { this.#metrics_accessor_storage = value; }
#eventCountLastHour_accessor_storage = (__runInitializers(this, _metrics_extraInitializers), __runInitializers(this, _eventCountLastHour_initializers, 0));
get eventCountLastHour() { return this.#eventCountLastHour_accessor_storage; }
set eventCountLastHour(value) { this.#eventCountLastHour_accessor_storage = value; }
#speedtestRunning_accessor_storage = (__runInitializers(this, _eventCountLastHour_extraInitializers), __runInitializers(this, _speedtestRunning_initializers, false));
get speedtestRunning() { return this.#speedtestRunning_accessor_storage; }
set speedtestRunning(value) { this.#speedtestRunning_accessor_storage = value; }
#speedtestPhase_accessor_storage = (__runInitializers(this, _speedtestRunning_extraInitializers), __runInitializers(this, _speedtestPhase_initializers, 'idle'));
get speedtestPhase() { return this.#speedtestPhase_accessor_storage; }
set speedtestPhase(value) { this.#speedtestPhase_accessor_storage = value; }
#speedtestProgress_accessor_storage = (__runInitializers(this, _speedtestPhase_extraInitializers), __runInitializers(this, _speedtestProgress_initializers, 0));
get speedtestProgress() { return this.#speedtestProgress_accessor_storage; }
set speedtestProgress(value) { this.#speedtestProgress_accessor_storage = value; }
#speedtestElapsed_accessor_storage = (__runInitializers(this, _speedtestProgress_extraInitializers), __runInitializers(this, _speedtestElapsed_initializers, 0));
get speedtestElapsed() { return this.#speedtestElapsed_accessor_storage; }
set speedtestElapsed(value) { this.#speedtestElapsed_accessor_storage = value; }
// Speedtest timing constants (must match service worker)
static TEST_DURATION_MS = 5000; // 5 seconds per test
progressInterval = (__runInitializers(this, _speedtestElapsed_extraInitializers), null);
async runSpeedtest() {
if (this.speedtestRunning)
return;
this.speedtestRunning = true;
this.speedtestPhase = 'latency';
this.speedtestProgress = 0;
this.speedtestElapsed = 0;
// Start progress animation (total ~10.5s: latency ~0.5s + 5s download + 5s upload)
const totalEstimatedMs = 10500;
const startTime = Date.now();
this.progressInterval = window.setInterval(() => {
this.speedtestElapsed = Date.now() - startTime;
this.speedtestProgress = Math.min(100, (this.speedtestElapsed / totalEstimatedMs) * 100);
// Estimate phase based on elapsed time
if (this.speedtestElapsed < 500) {
this.speedtestPhase = 'latency';
}
else if (this.speedtestElapsed < 5500) {
this.speedtestPhase = 'download';
}
else {
this.speedtestPhase = 'upload';
}
}, 100);
try {
const response = await fetch('/sw-dash/speedtest');
const result = await response.json();
this.speedtestPhase = 'complete';
this.speedtestProgress = 100;
// Dispatch event to parent to update metrics
this.dispatchEvent(new CustomEvent('speedtest-complete', {
detail: result,
bubbles: true,
composed: true
}));
}
catch (err) {
console.error('Speedtest failed:', err);
this.speedtestPhase = 'idle';
}
finally {
if (this.progressInterval) {
window.clearInterval(this.progressInterval);
this.progressInterval = null;
}
// Keep showing complete state briefly, then reset
setTimeout(() => {
this.speedtestRunning = false;
this.speedtestPhase = 'idle';
this.speedtestProgress = 0;
}, 1500);
}
}
getPhaseLabel() {
switch (this.speedtestPhase) {
case 'latency': return 'Testing latency';
case 'download': return 'Download test';
case 'upload': return 'Upload test';
case 'complete': return 'Complete';
default: return '';
}
}
formatElapsed() {
const seconds = Math.floor(this.speedtestElapsed / 1000);
return `${seconds}s`;
}
render() {
if (!this.metrics) {
return html `<div class="panel"><div class="panel-content">Loading metrics...</div></div>`;
}
const m = this.metrics;
const gaugeClass = SwDashTable.getGaugeClass;
return html `
<div class="grid">
<!-- Cache Panel -->
<div class="panel">
<div class="panel-title">Cache</div>
<div class="panel-content">
<div class="gauge">
<div class="gauge-header">
<span class="gauge-label">Hit Rate</span>
<span class="gauge-value">${m.cacheHitRate}%</span>
</div>
<div class="gauge-bar">
<div class="gauge-fill ${gaugeClass(m.cacheHitRate)}" style="width: ${m.cacheHitRate}%"></div>
</div>
</div>
<div class="row"><span class="label">Hits</span><span class="value success">${SwDashTable.formatNumber(m.cache.hits)}</span></div>
<div class="row"><span class="label">Misses</span><span class="value warning">${SwDashTable.formatNumber(m.cache.misses)}</span></div>
<div class="row"><span class="label">Errors</span><span class="value ${m.cache.errors > 0 ? 'error' : ''}">${SwDashTable.formatNumber(m.cache.errors)}</span></div>
<div class="row"><span class="label">From Cache</span><span class="value">${SwDashTable.formatBytes(m.cache.bytesServedFromCache)}</span></div>
<div class="row"><span class="label">Fetched</span><span class="value">${SwDashTable.formatBytes(m.cache.bytesFetched)}</span></div>
<div class="row"><span class="label">Resources</span><span class="value">${m.resourceCount}</span></div>
</div>
</div>
<!-- Network Panel -->
<div class="panel">
<div class="panel-title">Network</div>
<div class="panel-content">
<div class="gauge">
<div class="gauge-header">
<span class="gauge-label">Success Rate</span>
<span class="gauge-value">${m.networkSuccessRate}%</span>
</div>
<div class="gauge-bar">
<div class="gauge-fill ${gaugeClass(m.networkSuccessRate)}" style="width: ${m.networkSuccessRate}%"></div>
</div>
</div>
<div class="row"><span class="label">Total Requests</span><span class="value">${SwDashTable.formatNumber(m.network.totalRequests)}</span></div>
<div class="row"><span class="label">Successful</span><span class="value success">${SwDashTable.formatNumber(m.network.successfulRequests)}</span></div>
<div class="row"><span class="label">Failed</span><span class="value ${m.network.failedRequests > 0 ? 'error' : ''}">${SwDashTable.formatNumber(m.network.failedRequests)}</span></div>
<div class="row"><span class="label">Timeouts</span><span class="value ${m.network.timeouts > 0 ? 'warning' : ''}">${SwDashTable.formatNumber(m.network.timeouts)}</span></div>
<div class="row"><span class="label">Avg Latency</span><span class="value">${m.network.averageLatency}ms</span></div>
<div class="row"><span class="label">Transferred</span><span class="value">${SwDashTable.formatBytes(m.network.totalBytesTransferred)}</span></div>
</div>
</div>
<!-- Updates Panel -->
<div class="panel">
<div class="panel-title">Updates</div>
<div class="panel-content">
<div class="row"><span class="label">Total Checks</span><span class="value">${SwDashTable.formatNumber(m.update.totalChecks)}</span></div>
<div class="row"><span class="label">Successful</span><span class="value success">${SwDashTable.formatNumber(m.update.successfulChecks)}</span></div>
<div class="row"><span class="label">Failed</span><span class="value ${m.update.failedChecks > 0 ? 'error' : ''}">${SwDashTable.formatNumber(m.update.failedChecks)}</span></div>
<div class="row"><span class="label">Updates Found</span><span class="value">${SwDashTable.formatNumber(m.update.updatesFound)}</span></div>
<div class="row"><span class="label">Updates Applied</span><span class="value success">${SwDashTable.formatNumber(m.update.updatesApplied)}</span></div>
<div class="row"><span class="label">Last Check</span><span class="value">${SwDashTable.formatTimestamp(m.update.lastCheckTimestamp)}</span></div>
</div>
</div>
<!-- Connections Panel -->
<div class="panel">
<div class="panel-title">Connections</div>
<div class="panel-content">
<div class="row"><span class="label">Active Clients</span><span class="value success">${SwDashTable.formatNumber(m.connection.connectedClients)}</span></div>
<div class="row"><span class="label">Total Attempts</span><span class="value">${SwDashTable.formatNumber(m.connection.totalConnectionAttempts)}</span></div>
<div class="row"><span class="label">Successful</span><span class="value success">${SwDashTable.formatNumber(m.connection.successfulConnections)}</span></div>
<div class="row"><span class="label">Failed</span><span class="value ${m.connection.failedConnections > 0 ? 'error' : ''}">${SwDashTable.formatNumber(m.connection.failedConnections)}</span></div>
<div class="section-divider">
<div class="row"><span class="label">Events (1h)</span><span class="value">${this.eventCountLastHour}</span></div>
<div class="row"><span class="label">Started</span><span class="value">${SwDashTable.formatTimestamp(m.startTime)}</span></div>
</div>
</div>
</div>
<!-- Speedtest Panel -->
<div class="panel">
<div class="panel-title">Speedtest</div>
<div class="panel-content">
<div class="online-indicator ${m.speedtest.isOnline ? 'online' : 'offline'}">
<span class="online-dot"></span>
<span>${m.speedtest.isOnline ? 'Online' : 'Offline'}</span>
</div>
${this.speedtestRunning ? html `
<div class="speedtest-progress">
<div class="progress-header">
<span class="progress-phase">${this.getPhaseLabel()}</span>
<span class="progress-time">${this.formatElapsed()}</span>
</div>
<div class="progress-bar">
<div class="progress-fill ${this.speedtestPhase === 'complete' ? 'complete' : ''}" style="width: ${this.speedtestProgress}%"></div>
</div>
</div>
` : html `
<div class="speedtest-results">
<div class="speedtest-metric">
<div class="speedtest-value">${m.speedtest.lastDownloadSpeedMbps.toFixed(1)}</div>
<div class="speedtest-unit">Mbps</div>
<div class="speedtest-label">Download</div>
</div>
<div class="speedtest-metric">
<div class="speedtest-value">${m.speedtest.lastUploadSpeedMbps.toFixed(1)}</div>
<div class="speedtest-unit">Mbps</div>
<div class="speedtest-label">Upload</div>
</div>
<div class="speedtest-metric">
<div class="speedtest-value">${m.speedtest.lastLatencyMs.toFixed(0)}</div>
<div class="speedtest-unit">ms</div>
<div class="speedtest-label">Latency</div>
</div>
</div>
`}
<div class="btn-row">
<button class="btn btn-secondary" ?disabled="${this.speedtestRunning}" ="${this.runSpeedtest}">
${this.speedtestRunning ? 'Testing...' : 'Run Test'}
</button>
</div>
</div>
</div>
</div>
`;
}
static {
__runInitializers(_classThis, _classExtraInitializers);
}
};
return SwDashOverview = _classThis;
})();
export { SwDashOverview };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sw-dash-overview.js","sourceRoot":"","sources":["../ts_swdash/sw-dash-overview.ts"],"names":[],"mappings":"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"}