3.9 KiB
3.9 KiB
Fix Frontend Workbench Display
Goal
Make the authenticated workbench reflect real application data and simplify the navigation-heavy UI so it does not duplicate the sidebar.
What I Already Know
- The user reported that the frontend workbench data does not match actual data.
- The current
dashboard.jsphard-codes metric values, popular book ranking rows, borrowing rows, overdue rows, and book rows. - The workbench shortcut cards for 读者管理, 报表中心, 借阅流通, and 系统日志 duplicate links already present in the sidebar.
- The UI uses circular single-character markers beside text in metrics, shortcut cards, sidebar links, role chips, and topbar user summary.
- The sidebar is fixed on desktop, but responsive CSS changes
.app-sidebarand.app-topbarto static layout under 960px, effectively removing the persistent sidebar behavior. - Existing report infrastructure already exposes actual inventory summary, borrowing summary, overdue rows, and popular books through
ReportService.loadReportCenter(...).
Assumptions
- "UI text beside an unnecessary circle with one character" applies to decorative single-character icon circles in the authenticated shell and workbench, not to plain text labels or table status pills.
- The workbench should reuse existing server-rendered JSP/Servlet patterns rather than introducing client-side state.
- When a specific real data source does not yet exist, prefer showing an existing real metric over keeping a static fake metric.
Requirements
- Replace hard-coded workbench summary metrics with real data.
- Replace the hard-coded popular book ranking with real ranking data.
- Replace hard-coded borrowing/overdue/book table samples with real data or remove the fake sample rows in favor of empty states.
- Keep the workbench catalog search category selector populated from real categories.
- Remove the workbench shortcut entry block containing 读者管理, 报表中心, 借阅流通, and 系统日志.
- Remove the decorative circular single-character UI markers around text in the authenticated shell/workbench where they are not functionally necessary.
- Ensure the sidebar cannot be hidden or collapsed by responsive layout rules.
- Keep role-based visibility and permissions intact for administrator, librarian, and reader users.
Acceptance Criteria
- Workbench metrics are rendered from request attributes populated by backend services, not hard-coded numbers.
- Popular ranking and table content no longer contain static sample records such as 张晓明, 活着, 三体, or fixed 2024 dates unless those values come from the database.
- The workbench no longer shows shortcut cards for 读者管理, 报表中心, 借阅流通, or 系统日志.
- Decorative single-character circles next to UI text are removed or restyled as plain text/spacing without circular badges.
- Sidebar remains visible and occupies its sidebar column across responsive breakpoints.
- Existing navigation links still work and remain role-aware.
- Project lint/type-check or the closest available Java build/test command passes.
Out Of Scope
- Adding new major dashboard modules beyond the current workbench content.
- Redesigning unrelated pages outside the shared authenticated shell and workbench.
- Changing database schema unless necessary to replace static workbench data.
Technical Notes
- Likely files:
src/main/java/com/mzh/library/controller/DashboardServlet.java,src/main/webapp/WEB-INF/jsp/dashboard.jsp,src/main/webapp/WEB-INF/jsp/common/header.jspf, andsrc/main/webapp/static/css/app.css. - Existing actual report data:
ReportServiceImpl,JdbcReportDao,ReportCenter,InventorySummary,BorrowingSummary,OverdueReportRow, andPopularBookReportRow. - Existing category/book patterns:
BookServiceImpl,JdbcBookDao, andBookCatalogServlet. - Existing borrowing list pattern:
BorrowingServiceImpl.searchRecords(...)andBorrowingManagementServlet.