UNPKG

@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
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}" @click="${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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAErF,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC5G,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAiDjD;;GAEG;IAEU,cAAc;4BAD1B,aAAa,CAAC,kBAAkB,CAAC;;;;sBACE,UAAU;;;;;;;;;;;;;;;;;;;8BAAlB,SAAQ,WAAU;;;;mCAwB3C,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;8CAC1B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;4CAC1B,KAAK,EAAE;0CACP,KAAK,EAAE;6CACP,KAAK,EAAE;4CACP,KAAK,EAAE;YALoB,0KAAS,OAAO,6BAAP,OAAO,yFAA6B;YAC7C,2MAAS,kBAAkB,6BAAlB,kBAAkB,+GAAK;YACnD,qMAAS,gBAAgB,6BAAhB,gBAAgB,2GAAS;YAClC,+LAAS,cAAc,6BAAd,cAAc,uGAAmE;YAC1F,wMAAS,iBAAiB,6BAAjB,iBAAiB,6GAAK;YAC/B,qMAAS,gBAAgB,6BAAhB,gBAAgB,2GAAK;YA7BzC,6KA0OC;;;;QAzOQ,MAAM,CAAC,MAAM,GAAgB;YAClC,YAAY;YACZ,WAAW;YACX,WAAW;YACX,YAAY;YACZ,eAAe;YACf,GAAG,CAAA;;;;;;;;;;;;;;KAcF;SACF,CAAC;QAE0B,2EAAwC,IAAI,EAAC;QAA7C,IAAS,OAAO,6CAA6B;QAA7C,IAAS,OAAO,mDAA6B;QAC7C,uJAA8B,CAAC,GAAC;QAAhC,IAAS,kBAAkB,wDAAK;QAAhC,IAAS,kBAAkB,8DAAK;QACnD,8JAA4B,KAAK,GAAC;QAAlC,IAAS,gBAAgB,sDAAS;QAAlC,IAAS,gBAAgB,4DAAS;QAClC,wJAAmF,MAAM,GAAC;QAA1F,IAAS,cAAc,oDAAmE;QAA1F,IAAS,cAAc,0DAAmE;QAC1F,4JAA6B,CAAC,GAAC;QAA/B,IAAS,iBAAiB,uDAAK;QAA/B,IAAS,iBAAiB,6DAAK;QAC/B,6JAA4B,CAAC,GAAC;QAA9B,IAAS,gBAAgB,sDAAK;QAA9B,IAAS,gBAAgB,4DAAK;QAEvC,yDAAyD;QACjD,MAAM,CAAU,gBAAgB,GAAG,IAAI,CAAC,CAAE,qBAAqB;QAC/D,gBAAgB,kEAAkB,IAAI,EAAC;QAEvC,KAAK,CAAC,YAAY;YACxB,IAAI,IAAI,CAAC,gBAAgB;gBAAE,OAAO;YAClC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;YAChC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;YAE1B,mFAAmF;YACnF,MAAM,gBAAgB,GAAG,KAAK,CAAC;YAC/B,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAE7B,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE;gBAC9C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC/C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC,GAAG,GAAG,CAAC,CAAC;gBAEzF,uCAAuC;gBACvC,IAAI,IAAI,CAAC,gBAAgB,GAAG,GAAG,EAAE,CAAC;oBAChC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;gBAClC,CAAC;qBAAM,IAAI,IAAI,CAAC,gBAAgB,GAAG,IAAI,EAAE,CAAC;oBACxC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;gBACnC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;gBACjC,CAAC;YACH,CAAC,EAAE,GAAG,CAAC,CAAC;YAER,IAAI,CAAC;gBACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,oBAAoB,CAAC,CAAC;gBACnD,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;gBAErC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;gBACjC,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;gBAE7B,6CAA6C;gBAC7C,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,oBAAoB,EAAE;oBACvD,MAAM,EAAE,MAAM;oBACd,OAAO,EAAE,IAAI;oBACb,QAAQ,EAAE,IAAI;iBACf,CAAC,CAAC,CAAC;YACN,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;gBACxC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC/B,CAAC;oBAAS,CAAC;gBACT,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBAC1B,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;oBAC5C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;gBAC/B,CAAC;gBACD,kDAAkD;gBAClD,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;oBAC9B,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;oBAC7B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;gBAC7B,CAAC,EAAE,IAAI,CAAC,CAAC;YACX,CAAC;QACH,CAAC;QAEO,aAAa;YACnB,QAAQ,IAAI,CAAC,cAAc,EAAE,CAAC;gBAC5B,KAAK,SAAS,CAAC,CAAC,OAAO,iBAAiB,CAAC;gBACzC,KAAK,UAAU,CAAC,CAAC,OAAO,eAAe,CAAC;gBACxC,KAAK,QAAQ,CAAC,CAAC,OAAO,aAAa,CAAC;gBACpC,KAAK,UAAU,CAAC,CAAC,OAAO,UAAU,CAAC;gBACnC,OAAO,CAAC,CAAC,OAAO,EAAE,CAAC;YACrB,CAAC;QACH,CAAC;QAEO,aAAa;YACnB,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;YACzD,OAAO,GAAG,OAAO,GAAG,CAAC;QACvB,CAAC;QAEM,MAAM;YACX,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBAClB,OAAO,IAAI,CAAA,8EAA8E,CAAC;YAC5F,CAAC;YAED,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;YACvB,MAAM,UAAU,GAAG,WAAW,CAAC,aAAa,CAAC;YAE7C,OAAO,IAAI,CAAA;;;;;;;;;4CAS6B,CAAC,CAAC,YAAY;;;yCAGjB,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC,YAAY;;;0FAGV,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;4FACpC,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;mFACjD,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;wFACzE,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC;qFACxD,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC;uFAC3C,CAAC,CAAC,aAAa;;;;;;;;;;;4CAW1D,CAAC,CAAC,kBAAkB;;;yCAGvB,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,CAAC,kBAAkB;;;4FAGpB,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;gGAC7C,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC;mFACnE,CAAC,CAAC,OAAO,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC;qFAChG,CAAC,CAAC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC;yFACpF,CAAC,CAAC,OAAO,CAAC,cAAc;yFACxB,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC;;;;;;;;0FAQvD,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC;gGACxC,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,CAAC;mFAChE,CAAC,CAAC,MAAM,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;2FACpF,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;qGACrC,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC;wFAC9D,WAAW,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC;;;;;;;;oGAQ5C,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,gBAAgB,CAAC;4FAC/D,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,uBAAuB,CAAC;gGAC1D,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,qBAAqB,CAAC;mFACzE,CAAC,CAAC,UAAU,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC;;2FAEtG,IAAI,CAAC,kBAAkB;uFAC3B,WAAW,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC;;;;;;;;;2CASpF,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;sBAEhE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;cAEnD,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAA;;;iDAGO,IAAI,CAAC,aAAa,EAAE;gDACrB,IAAI,CAAC,aAAa,EAAE;;;8CAGtB,IAAI,CAAC,cAAc,KAAK,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,mBAAmB,IAAI,CAAC,iBAAiB;;;aAG9H,CAAC,CAAC,CAAC,IAAI,CAAA;;;iDAG6B,CAAC,CAAC,SAAS,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,CAAC;;;;;iDAK5C,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;;;;;iDAK1C,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC;;;;;aAKxE;;6DAEgD,IAAI,CAAC,gBAAgB,aAAa,IAAI,CAAC,YAAY;kBAC9F,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU;;;;;;KAM9D,CAAC;QACJ,CAAC;;YAzOU,uDAAc;;;;;SAAd,cAAc"}