優化AI觀測台響應式資料表
All checks were successful
CD Pipeline / deploy (push) Successful in 59s

This commit is contained in:
OoO
2026-05-13 22:32:09 +08:00
parent 93dd1f12af
commit 9119e57a43
5 changed files with 237 additions and 1 deletions

View File

@@ -320,7 +320,7 @@ YOUTUBE_API_KEY = os.getenv('YOUTUBE_API_KEY', '')
# ==========================================
# 系統版本與路徑
# ==========================================
SYSTEM_VERSION = "V10.134"
SYSTEM_VERSION = "V10.135"
LOG_FILE_PATH = os.path.join(BASE_DIR, 'logs/system.log')
public_url = PUBLIC_URL # 用於模板顯示

View File

@@ -2545,6 +2545,95 @@
background-size: var(--obs-matrix-size) !important;
}
/* v3.12 responsive data surfaces: observability tables should read like
* operational records on phones, not desktop sheets squeezed into a viewport.
*/
.momo-observability-mode .table-responsive {
overflow-x: visible !important;
}
.momo-observability-mode .table-responsive .table {
min-width: 0 !important;
width: 100% !important;
table-layout: auto;
}
.momo-observability-mode .table :is(th, td) {
max-width: min(24rem, 38vw);
white-space: normal !important;
}
@media (max-width: 768px) {
.momo-observability-mode .table-responsive {
max-height: none !important;
overflow: visible !important;
}
.momo-observability-mode .table-responsive .obs-card-ready,
.momo-observability-mode .table-responsive .obs-card-ready thead,
.momo-observability-mode .table-responsive .obs-card-ready tbody,
.momo-observability-mode .table-responsive .obs-card-ready tr,
.momo-observability-mode .table-responsive .obs-card-ready td {
display: block;
width: 100% !important;
}
.momo-observability-mode .table-responsive .obs-card-ready thead {
position: absolute;
width: 1px !important;
height: 1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
}
.momo-observability-mode .table-responsive .obs-card-ready tbody {
display: grid;
gap: 0.7rem;
}
.momo-observability-mode .table-responsive .obs-card-ready tr {
display: grid;
gap: 0.44rem;
padding: 0.72rem;
border: 1px solid var(--obs-line);
border-radius: var(--momo-radius-lg, 8px);
background:
var(--obs-matrix-dot-soft),
var(--momo-bg-elevated, #fdfaf3);
background-size: var(--obs-matrix-size), auto;
box-shadow: var(--momo-shadow-sm, 0 1px 3px rgba(42, 37, 32, 0.05));
}
.momo-observability-mode .table-responsive .obs-card-ready td {
display: grid;
grid-template-columns: minmax(5.4rem, 35%) minmax(0, 1fr);
gap: 0.58rem;
align-items: start;
max-width: 100%;
padding: 0 !important;
border: 0 !important;
border-radius: 0 !important;
background: transparent !important;
box-shadow: none !important;
text-align: left !important;
}
.momo-observability-mode .table-responsive .obs-card-ready td::before {
content: attr(data-label);
color: var(--obs-muted);
font-family: var(--momo-font-mono, "JetBrains Mono", ui-monospace, monospace);
font-size: 0.72rem;
font-weight: 700;
line-height: 1.45;
overflow-wrap: anywhere;
}
.momo-observability-mode .table-responsive .obs-card-ready td:empty {
display: none;
}
}
.momo-observability-mode :is(
.obs-panel,
.agent-panel,

View File

@@ -528,6 +528,14 @@
})();
</script>
{% if active_page|default('') in [
'obs_overview', 'obs_agent_orchestration', 'obs_business_intel',
'obs_host_health', 'obs_ai_calls', 'obs_budget',
'obs_promotion_review', 'obs_rag_queries', 'obs_quality_trend',
'obs_ppt_audit'
] %}
<script src="{{ url_for('static', filename='js/observability-system.js') }}"></script>
{% endif %}
{% block extra_js %}{% endblock %}
{% block extra_scripts %}{% endblock %}
</body>

View File

@@ -2545,6 +2545,95 @@
background-size: var(--obs-matrix-size) !important;
}
/* v3.12 responsive data surfaces: observability tables should read like
* operational records on phones, not desktop sheets squeezed into a viewport.
*/
.momo-observability-mode .table-responsive {
overflow-x: visible !important;
}
.momo-observability-mode .table-responsive .table {
min-width: 0 !important;
width: 100% !important;
table-layout: auto;
}
.momo-observability-mode .table :is(th, td) {
max-width: min(24rem, 38vw);
white-space: normal !important;
}
@media (max-width: 768px) {
.momo-observability-mode .table-responsive {
max-height: none !important;
overflow: visible !important;
}
.momo-observability-mode .table-responsive .obs-card-ready,
.momo-observability-mode .table-responsive .obs-card-ready thead,
.momo-observability-mode .table-responsive .obs-card-ready tbody,
.momo-observability-mode .table-responsive .obs-card-ready tr,
.momo-observability-mode .table-responsive .obs-card-ready td {
display: block;
width: 100% !important;
}
.momo-observability-mode .table-responsive .obs-card-ready thead {
position: absolute;
width: 1px !important;
height: 1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
}
.momo-observability-mode .table-responsive .obs-card-ready tbody {
display: grid;
gap: 0.7rem;
}
.momo-observability-mode .table-responsive .obs-card-ready tr {
display: grid;
gap: 0.44rem;
padding: 0.72rem;
border: 1px solid var(--obs-line);
border-radius: var(--momo-radius-lg, 8px);
background:
var(--obs-matrix-dot-soft),
var(--momo-bg-elevated, #fdfaf3);
background-size: var(--obs-matrix-size), auto;
box-shadow: var(--momo-shadow-sm, 0 1px 3px rgba(42, 37, 32, 0.05));
}
.momo-observability-mode .table-responsive .obs-card-ready td {
display: grid;
grid-template-columns: minmax(5.4rem, 35%) minmax(0, 1fr);
gap: 0.58rem;
align-items: start;
max-width: 100%;
padding: 0 !important;
border: 0 !important;
border-radius: 0 !important;
background: transparent !important;
box-shadow: none !important;
text-align: left !important;
}
.momo-observability-mode .table-responsive .obs-card-ready td::before {
content: attr(data-label);
color: var(--obs-muted);
font-family: var(--momo-font-mono, "JetBrains Mono", ui-monospace, monospace);
font-size: 0.72rem;
font-weight: 700;
line-height: 1.45;
overflow-wrap: anywhere;
}
.momo-observability-mode .table-responsive .obs-card-ready td:empty {
display: none;
}
}
.momo-observability-mode :is(
.obs-panel,
.agent-panel,

View File

@@ -0,0 +1,50 @@
(function () {
'use strict';
function isObservabilityPage() {
return document.querySelector('.momo-observability-mode') !== null;
}
function normalizeLabel(text) {
return (text || '').replace(/\s+/g, ' ').trim();
}
function enhanceTable(table) {
if (!table || table.dataset.obsCardReady === '1') return;
const headers = Array.from(table.querySelectorAll('thead th')).map((th) => normalizeLabel(th.textContent));
if (!headers.length) return;
table.querySelectorAll('tbody tr').forEach((row) => {
Array.from(row.children).forEach((cell, index) => {
if (!cell.hasAttribute('data-label')) {
cell.setAttribute('data-label', headers[index] || '');
}
});
});
table.dataset.obsCardReady = '1';
table.classList.add('obs-card-ready');
}
function enhanceTables() {
if (!isObservabilityPage()) return;
document.querySelectorAll('.table-responsive table').forEach(enhanceTable);
}
document.addEventListener('DOMContentLoaded', enhanceTables);
let queued = false;
const observer = new MutationObserver(() => {
if (queued) return;
queued = true;
window.requestAnimationFrame(() => {
queued = false;
enhanceTables();
});
});
document.addEventListener('DOMContentLoaded', () => {
if (!isObservabilityPage()) return;
observer.observe(document.body, { childList: true, subtree: true });
});
})();