UX: merge Distribution and Tables into a single Breakdown tab with clear option help\n\n- Replace separate Distribution/Tables tabs with one Breakdown tab\n- Breakdown shows categorical charts and data tables together\n- Add in-page help explaining Percent mode, Grouping, and Exclude '-'\n- Update filtering, containers, and tab logic to target new tab\n- Keep existing report JSON/HTML contracts; no server changes required
This commit is contained in:
		
					parent
					
						
							
								95e54359d7
							
						
					
				
			
			
				commit
				
					
						2bfd487106
					
				
			
		
					 1 changed files with 22 additions and 21 deletions
				
			
		|  | @ -14,8 +14,7 @@ | ||||||
|       <ul> |       <ul> | ||||||
|         <li class="is-active" data-tab="recent"><a>Recent</a></li> |         <li class="is-active" data-tab="recent"><a>Recent</a></li> | ||||||
|         <li data-tab="trends"><a>Trends</a></li> |         <li data-tab="trends"><a>Trends</a></li> | ||||||
|         <li data-tab="distribution"><a>Distribution</a></li> |         <li data-tab="breakdown"><a>Breakdown</a></li> | ||||||
|         <li data-tab="tables"><a>Tables</a></li> |  | ||||||
|         <li data-tab="analysis"><a>Analysis</a></li> |         <li data-tab="analysis"><a>Analysis</a></li> | ||||||
|       </ul> |       </ul> | ||||||
|     </div> |     </div> | ||||||
|  | @ -64,17 +63,17 @@ | ||||||
|         </label> |         </label> | ||||||
|       </div> |       </div> | ||||||
|       <div id="mode-percent-control" class="control is-hidden"> |       <div id="mode-percent-control" class="control is-hidden"> | ||||||
|         <label class="checkbox is-small"> |         <label class="checkbox is-small" title="Show values as a percentage of the total, instead of raw counts."> | ||||||
|           <input type="checkbox" id="percent-toggle"> Percent mode |           <input type="checkbox" id="percent-toggle"> Percent mode | ||||||
|         </label> |         </label> | ||||||
|       </div> |       </div> | ||||||
|       <div id="mode-group-control" class="control is-hidden"> |       <div id="mode-group-control" class="control is-hidden"> | ||||||
|         <label class="checkbox is-small"> |         <label class="checkbox is-small" title="Combine small categories into an 'Other' slice to declutter charts."> | ||||||
|           <input type="checkbox" id="group-toggle" checked> Group small into Other |           <input type="checkbox" id="group-toggle" checked> Group small into Other | ||||||
|         </label> |         </label> | ||||||
|       </div> |       </div> | ||||||
|       <div id="exclude-uncached-control" class="control is-hidden"> |       <div id="exclude-uncached-control" class="control is-hidden"> | ||||||
|         <label class="checkbox is-small"> |         <label class="checkbox is-small" title="Hide uncached entries (cache status '-') from cache status distributions."> | ||||||
|           <input type="checkbox" id="exclude-uncached-toggle" checked> Exclude “-” |           <input type="checkbox" id="exclude-uncached-toggle" checked> Exclude “-” | ||||||
|         </label> |         </label> | ||||||
|       </div> |       </div> | ||||||
|  | @ -99,12 +98,17 @@ | ||||||
|       <div id="reports-trends"></div> |       <div id="reports-trends"></div> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div id="distribution-section" class="is-hidden"> |     <div id="breakdown-section" class="is-hidden"> | ||||||
|       <div id="reports-distribution"></div> |       <div class="box mb-4"> | ||||||
|  |         <h2 class="subtitle">Breakdown</h2> | ||||||
|  |         <p class="mb-2">Explore categorical distributions and detailed lists side-by-side. Use the options below to adjust how categories are shown.</p> | ||||||
|  |         <ul style="margin-left: 1.2rem; list-style: disc;"> | ||||||
|  |           <li><strong>Percent mode</strong>: converts counts into percentages of the total for easier comparison.</li> | ||||||
|  |           <li><strong>Group small into Other</strong>: combines tiny slices under a single “Other” category to declutter charts.</li> | ||||||
|  |           <li><strong>Exclude “-”</strong>: hides uncached entries (cache status “-”) from cache status distributions.</li> | ||||||
|  |         </ul> | ||||||
|       </div> |       </div> | ||||||
| 
 |       <div id="reports-breakdown"></div> | ||||||
|     <div id="tables-section" class="is-hidden"> |  | ||||||
|       <div id="reports-tables"></div> |  | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|   <div id="analysis-section" class="is-hidden"> |   <div id="analysis-section" class="is-hidden"> | ||||||
|  | @ -145,15 +149,13 @@ | ||||||
|     const sections = { |     const sections = { | ||||||
|       recent: document.getElementById('recent-section'), |       recent: document.getElementById('recent-section'), | ||||||
|       trends: document.getElementById('trends-section'), |       trends: document.getElementById('trends-section'), | ||||||
|       distribution: document.getElementById('distribution-section'), |       breakdown: document.getElementById('breakdown-section'), | ||||||
|       tables: document.getElementById('tables-section'), |  | ||||||
|       analysis: document.getElementById('analysis-section') |       analysis: document.getElementById('analysis-section') | ||||||
|     }; |     }; | ||||||
|     const containers = { |     const containers = { | ||||||
|       recent: document.getElementById('overview-reports'), |       recent: document.getElementById('overview-reports'), | ||||||
|       trends: document.getElementById('reports-trends'), |       trends: document.getElementById('reports-trends'), | ||||||
|       distribution: document.getElementById('reports-distribution'), |       breakdown: document.getElementById('reports-breakdown') | ||||||
|       tables: document.getElementById('reports-tables') |  | ||||||
|     }; |     }; | ||||||
|     const analysisElems = { |     const analysisElems = { | ||||||
|       missing: document.getElementById('analysis-missing'), |       missing: document.getElementById('analysis-missing'), | ||||||
|  | @ -461,8 +463,7 @@ | ||||||
|           const filtered = reports.filter(rep => { |           const filtered = reports.filter(rep => { | ||||||
|             if (currentTab === 'recent') return true; |             if (currentTab === 'recent') return true; | ||||||
|             if (currentTab === 'trends') return rep.chart !== 'table' && !isDistributionType(rep.chart); |             if (currentTab === 'trends') return rep.chart !== 'table' && !isDistributionType(rep.chart); | ||||||
|             if (currentTab === 'distribution') return isDistributionType(rep.chart); |             if (currentTab === 'breakdown') return isDistributionType(rep.chart) || rep.chart === 'table'; | ||||||
|             if (currentTab === 'tables') return rep.chart === 'table'; |  | ||||||
|             return true; |             return true; | ||||||
|           }); |           }); | ||||||
|           // If no explicit window was given (URL or saved state), honor first report's default |           // If no explicit window was given (URL or saved state), honor first report's default | ||||||
|  | @ -582,11 +583,11 @@ | ||||||
|       intervalControl.classList.add('is-hidden'); |       intervalControl.classList.add('is-hidden'); | ||||||
|       domainControl.classList.toggle('is-hidden', !showDomain); |       domainControl.classList.toggle('is-hidden', !showDomain); | ||||||
|       timeControl.classList.toggle('is-hidden', !showTime); |       timeControl.classList.toggle('is-hidden', !showTime); | ||||||
|       // Only show percent/group/exclude toggles on Distribution tab, |       // Only show percent/group/exclude toggles on Breakdown tab, | ||||||
|       // and smoothing only on Trends tab |       // and smoothing only on Trends tab | ||||||
|       modePercentControl.classList.toggle('is-hidden', name !== 'distribution'); |       modePercentControl.classList.toggle('is-hidden', name !== 'breakdown'); | ||||||
|       modeGroupControl.classList.toggle('is-hidden', name !== 'distribution'); |       modeGroupControl.classList.toggle('is-hidden', name !== 'breakdown'); | ||||||
|       excludeUncachedControl.classList.toggle('is-hidden', name !== 'distribution'); |       excludeUncachedControl.classList.toggle('is-hidden', name !== 'breakdown'); | ||||||
|       smoothControl.classList.toggle('is-hidden', name !== 'trends'); |       smoothControl.classList.toggle('is-hidden', name !== 'trends'); | ||||||
|       updateURL(); |       updateURL(); | ||||||
|       if (name === 'recent') { |       if (name === 'recent') { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue