eb076410a62ea6a94b71358424080af261ba2c25 jcasper Thu Mar 26 03:20:14 2026 -0700 Moved hgFetch into hgTrackUi; added etags, Cache-Control directives, and GET use instead of POST when udcTimeout isn't set, all to support browser caching of remote files; bumped the DataTables version for facetedComposite to facilitate making all the checkboxes have a consistent look; refs #36320 diff --git src/hg/htdocs/style/facetedComposite.css src/hg/htdocs/style/facetedComposite.css index b9a6e685cec..8bfac71e18c 100644 --- src/hg/htdocs/style/facetedComposite.css +++ src/hg/htdocs/style/facetedComposite.css @@ -1,190 +1,197 @@ /* SPDX-License-Identifier: MIT; (c) 2025 Andrew D Smith (author) */ #container { display: flex; width: 100%; gap: 1em; align-items: flex-start; box-sizing: border-box; } #filters { display: flex; flex-direction: column; gap: 1em; width: 300px; flex-shrink: 0; /* ADS: the lines below are for vertical scrolling if needed */ /* max-height: 80vh; */ /* overflow-y: auto; */ align-self: stretch; box-sizing: border-box; padding-right: 0.5em; } #filters > div { display: flex; flex-direction: column; gap: 0.3em; } #filters label { display: flex; align-items: center; gap: 0.3em; cursor: pointer; user-select: none; } #theMetaDataTable_wrapper { flex: 1 1 auto; min-width: 0; box-sizing: border-box; } #theMetaDataTable { width: 100% !important; box-sizing: border-box; } #theMetaDataTable td:nth-child(n+2), #theMetaDataTable th:nth-child(n+2) { vertical-align: top; /* white-space: nowrap; */ /* overflow: hidden; /* hide overflow */ min-width: 100px; /* Adjust width as needed */ } -#theMetaDataTable .select-checkbox { - width: 1em !important; /* force narrow width */ +/* Override Select 3.0's custom checkbox styling to use native appearance */ +table.dataTable input.dt-select-checkbox { + appearance: auto; + width: auto; + height: auto; +} +table.dataTable input.dt-select-checkbox:checked::after, +table.dataTable input.dt-select-checkbox:indeterminate::after { + display: none; } #theMetaDataTable input.row-select { /* additional checkbox styling */ } table.dataTable { width: 100%; border-collapse: collapse; table-layout: auto; } table.dataTable tbody tr:nth-child(odd) { background-color: #f0f0f0; } table.dataTable tbody tr:nth-child(even) { background-color: #ffffff; } table.dataTable tbody tr:hover { background-color: #d3eaff; /* Light blue on hover */ } .color-box { display: inline-block; width: 1em; height: 1em; vertical-align: middle; /* background-color set dynamically in JS */ } .facet-heading { cursor: pointer; user-select: none; } .facet-heading::after { content: " ❯"; margin-left: 0.3em; display: inline-block; transition: transform 0.2s; transform: rotate(90deg); /* points down = expanded */ } .facet-heading.collapsed::after { transform: rotate(0deg); /* points right = collapsed */ } .facet-body { display: flex; flex-direction: column; gap: 0.3em; } .facet-body.collapsed { display: none; } /* "Show only selected" toggle in the toolbar */ #selected-filter { display: inline-flex; align-items: center; gap: 0.5em; margin-left: 1.5em; } -.dataTables_length { +.dt-length { display: inline-flex !important; align-items: center; } /* Toggle switch for "show only selected" filter */ .toggle-switch { position: relative; display: inline-block; width: 28px; height: 16px; } .toggle-switch input { opacity: 0; width: 0; height: 0; } .toggle-slider { position: absolute; inset: 0; background-color: #ccc; border-radius: 16px; cursor: pointer; transition: background-color 0.2s; } .toggle-slider::before { content: ""; position: absolute; height: 12px; width: 12px; left: 2px; bottom: 2px; background-color: white; border-radius: 50%; transition: transform 0.2s; } .toggle-switch input:checked + .toggle-slider { background-color: #4a90d9; } .toggle-switch input:checked + .toggle-slider::before { transform: translateX(12px); } /* Active filter chips bar */ #active-filters { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-start; text-align: left; gap: 0.4em; padding: 0.5em 0; border-top: 1px solid #ddd; margin-top: 0.75em; width: 100%; } .filter-chip-group-label { font-weight: bold; font-size: 0.85em; margin-left: 0.3em; } .filter-chip { display: inline-flex; align-items: center; background-color: #e8f0fe; border: 1px solid #c2d6f2; border-radius: 12px; padding: 0.15em 0.5em; font-size: 0.85em; white-space: nowrap; } .filter-chip .remove-chip { background: none; border: none; cursor: pointer; font-size: 1em; line-height: 1; padding: 0 0 0 0.25em; color: #666; } .filter-chip .remove-chip:hover { color: #c00; }