mirror of
https://github.com/StuffAnThings/qbit_manage.git
synced 2025-10-09 13:29:15 +08:00
Add a new method to convert URLs in log messages to clickable links, with corresponding CSS styles for hover, visited, and focus states. [FR]: WebUI make hyperlinks clickable Fixes #938
292 lines
7 KiB
CSS
292 lines
7 KiB
CSS
/* Log Viewer Styles */
|
|
.log-viewer {
|
|
display: flex;
|
|
flex-direction: column;
|
|
height: 70vh !important; /* 70% of viewport height */
|
|
max-height: 70vh !important; /* Maximum height constraint */
|
|
width: 100%;
|
|
background-color: var(--bg-primary);
|
|
border-radius: var(--border-radius);
|
|
overflow: hidden;
|
|
box-shadow: var(--shadow-md);
|
|
}
|
|
|
|
.log-viewer-header {
|
|
display: flex;
|
|
flex-wrap: wrap; /* Allow wrapping on smaller screens */
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
padding: var(--spacing-md) var(--spacing-lg);
|
|
border-bottom: 1px solid var(--border-color);
|
|
background-color: var(--bg-secondary);
|
|
gap: var(--spacing-md); /* Spacing between main header elements */
|
|
}
|
|
|
|
.log-viewer-title {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--spacing-sm);
|
|
}
|
|
|
|
.log-viewer-title h4 {
|
|
margin: 0;
|
|
font-size: var(--font-size-lg);
|
|
font-weight: 600;
|
|
color: var(--text-primary);
|
|
}
|
|
|
|
.log-status {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--spacing-xs);
|
|
font-size: var(--font-size-sm);
|
|
color: var(--text-secondary);
|
|
}
|
|
|
|
.log-viewer-controls {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
align-items: center;
|
|
gap: var(--spacing-md); /* Spacing between filter and action groups */
|
|
}
|
|
|
|
.log-filters,
|
|
.log-actions {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--spacing-sm); /* Spacing between individual controls */
|
|
}
|
|
|
|
.log-floating-scroll-top-btn {
|
|
position: fixed;
|
|
opacity: 0;
|
|
pointer-events: none;
|
|
transition: opacity 0.2s ease-in-out;
|
|
z-index: 1000; /* High z-index to float above everything */
|
|
}
|
|
|
|
.log-floating-scroll-top-btn.visible {
|
|
opacity: 1;
|
|
pointer-events: auto;
|
|
}
|
|
|
|
.log-floating-scroll-bottom-btn {
|
|
position: fixed;
|
|
opacity: 0;
|
|
pointer-events: none;
|
|
transition: opacity 0.2s ease-in-out;
|
|
z-index: 1000; /* High z-index to float above everything */
|
|
}
|
|
|
|
.log-floating-scroll-bottom-btn.visible {
|
|
opacity: 1;
|
|
pointer-events: auto;
|
|
}
|
|
|
|
.log-viewer-content {
|
|
position: relative; /* Enable absolute positioning for child elements */
|
|
flex: 1; /* Takes up remaining vertical space */
|
|
overflow: auto; /* Add scrollbars when content overflows */
|
|
overflow-x: auto; /* Enable horizontal scrolling */
|
|
overflow-y: auto; /* Enable vertical scrolling */
|
|
max-height: calc(70vh - 100px) !important; /* Account for header/footer height */
|
|
height: calc(70vh - 100px) !important; /* Height accounting for header/footer */
|
|
min-height: 0; /* Allow content to shrink within flex container */
|
|
padding: var(--spacing-md) var(--spacing-lg);
|
|
background-color: var(--bg-primary); /* Slightly different background for log area */
|
|
font-family: var(--font-mono); /* Monospace font for logs */
|
|
font-size: var(--font-size-sm);
|
|
line-height: 1.4;
|
|
color: var(--text-primary);
|
|
}
|
|
|
|
.log-container {
|
|
/* No specific styles needed here, it's just a wrapper for log entries */
|
|
}
|
|
|
|
.log-entry {
|
|
display: flex;
|
|
align-items: baseline; /* Align text baselines */
|
|
padding: var(--spacing-xs) 0;
|
|
border-bottom: 1px dotted var(--border-color); /* Subtle separator */
|
|
white-space: pre; /* Preserve whitespace and don't wrap */
|
|
word-break: normal; /* Don't break words */
|
|
}
|
|
|
|
.log-entry:last-child {
|
|
border-bottom: none; /* No border for the last entry */
|
|
}
|
|
|
|
.log-entry.word-wrap {
|
|
white-space: normal; /* Override pre-wrap if word wrap is enabled */
|
|
}
|
|
|
|
.log-timestamp {
|
|
flex-shrink: 0; /* Prevent timestamp from shrinking */
|
|
margin-right: var(--spacing-sm);
|
|
color: var(--text-muted);
|
|
font-size: var(--font-size-xs);
|
|
}
|
|
|
|
.log-level {
|
|
flex-shrink: 0;
|
|
margin-right: var(--spacing-sm);
|
|
font-weight: 600;
|
|
text-transform: uppercase;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--spacing-xs);
|
|
}
|
|
|
|
.log-icon {
|
|
font-size: var(--font-size-xs); /* Adjust icon size */
|
|
}
|
|
|
|
.log-level-text {
|
|
font-size: var(--font-size-xs);
|
|
}
|
|
|
|
.log-message {
|
|
flex-grow: 1; /* Allow message to take up remaining space */
|
|
min-width: 0; /* Allow content to shrink */
|
|
overflow: visible; /* Allow content to overflow */
|
|
}
|
|
|
|
/* Clickable links in log messages */
|
|
.log-link {
|
|
color: var(--link-color, #007bff);
|
|
text-decoration: underline;
|
|
text-decoration-color: var(--link-color, #007bff);
|
|
text-decoration-thickness: 1px;
|
|
text-underline-offset: 2px;
|
|
transition: color 0.2s ease, text-decoration-color 0.2s ease;
|
|
}
|
|
|
|
.log-link:hover {
|
|
color: var(--link-hover-color, #0056b3);
|
|
text-decoration-color: var(--link-hover-color, #0056b3);
|
|
}
|
|
|
|
.log-link:visited {
|
|
color: var(--link-visited-color, #6c757d);
|
|
text-decoration-color: var(--link-visited-color, #6c757d);
|
|
}
|
|
|
|
.log-link:focus {
|
|
outline: 2px solid var(--focus-color, #007bff);
|
|
outline-offset: 2px;
|
|
}
|
|
|
|
.log-source {
|
|
flex-shrink: 0;
|
|
margin-left: var(--spacing-sm);
|
|
color: var(--text-secondary);
|
|
font-size: var(--font-size-xs);
|
|
}
|
|
|
|
/* Log Level Colors (from LogViewer JS) - ensure these match the JS for consistency */
|
|
.log-entry.log-debug .log-level { color: #6c757d; }
|
|
.log-entry.log-info .log-level { color: #17a2b8; }
|
|
.log-entry.log-warning .log-level { color: #ffc107; }
|
|
.log-entry.log-error .log-level { color: #dc3545; }
|
|
.log-entry.log-critical .log-level { color: #721c24; }
|
|
|
|
/* Log Placeholder */
|
|
.log-placeholder {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
height: 100%;
|
|
padding: var(--spacing-2xl);
|
|
color: var(--text-muted);
|
|
text-align: center;
|
|
}
|
|
|
|
.placeholder-icon {
|
|
font-size: 3rem; /* Larger icon */
|
|
margin-bottom: var(--spacing-md);
|
|
}
|
|
|
|
.placeholder-text {
|
|
font-size: var(--font-size-lg);
|
|
font-weight: 500;
|
|
margin-bottom: var(--spacing-sm);
|
|
}
|
|
|
|
.placeholder-subtext {
|
|
font-size: var(--font-size-sm);
|
|
}
|
|
|
|
/* Log Viewer Footer (Stats and Settings) */
|
|
.log-viewer-footer {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
padding: var(--spacing-sm) var(--spacing-lg);
|
|
border-top: 1px solid var(--border-color);
|
|
background-color: var(--bg-secondary);
|
|
font-size: var(--font-size-sm);
|
|
color: var(--text-secondary);
|
|
gap: var(--spacing-md);
|
|
}
|
|
|
|
.log-stats {
|
|
display: flex;
|
|
gap: var(--spacing-md);
|
|
}
|
|
|
|
.stat-item {
|
|
display: flex;
|
|
gap: var(--spacing-xs);
|
|
}
|
|
|
|
.stat-label {
|
|
font-weight: 500;
|
|
}
|
|
|
|
.stat-value {
|
|
font-weight: 600;
|
|
}
|
|
|
|
.error-count {
|
|
color: var(--error-color);
|
|
}
|
|
|
|
.warning-count {
|
|
color: var(--warning-color);
|
|
}
|
|
|
|
.log-settings {
|
|
display: flex;
|
|
gap: var(--spacing-md);
|
|
}
|
|
|
|
/* Log Viewer Refresh Interval Control */
|
|
.refresh-interval-control {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--spacing-sm);
|
|
}
|
|
|
|
.refresh-interval-control .form-label {
|
|
margin-bottom: 0; /* Remove default margin-bottom from label */
|
|
white-space: nowrap; /* Prevent text from wrapping */
|
|
}
|
|
|
|
/* Log Viewer Header and Status */
|
|
.log-viewer-title {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
|
|
gap: var(--spacing-md);
|
|
}
|
|
|
|
.log-status {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--spacing-md);
|
|
|
|
}
|