4.1 KiB
4.1 KiB
brainstorm: Redesign Frontend From Reference Image
Goal
Refactor the JSP/CSS frontend so the library-management application visually matches the provided dashboard reference as closely as practical while preserving existing Servlet/JSP behavior, routes, role-based navigation, forms, tables, and Simplified Chinese interface copy.
What I Already Know
- The user wants the frontend rebuilt to imitate the attached reference image as closely as possible.
- The reference image is a Chinese library management dashboard with a dark left sidebar, white top bar, dense white card panels, blue primary actions, rounded statistics cards, table sections, and operational shortcut tiles.
- The application is a JSP + Servlet + Maven WAR project, not a React/Vue SPA.
- Existing frontend files live under
src/main/webapp/WEB-INF/jsp/with shared CSS insrc/main/webapp/static/css/app.css. - Current shared header fragment is
src/main/webapp/WEB-INF/jsp/common/header.jspf. - Existing pages include dashboard, login, catalog, book management, reader management, borrowing, reports, system logs, and user management JSPs.
- Frontend spec requires image-first implementation and Simplified Chinese display copy.
Assumptions
- "Frontend" means the shared visual system across JSP pages, with the dashboard receiving the closest match because the reference image is a dashboard screenshot.
- The redesign should keep current endpoints, request parameter names, JSTL conditions, and server-rendered data contracts unchanged.
- New CSS classes and JSP structure are allowed when they improve visual fidelity, but no new frontend framework should be introduced.
- The reference image should be stored with the task for implementation/check agents.
Open Questions
- Confirm scope: apply the reference style across the whole JSP frontend, not only the dashboard page.
Requirements
- Build a left dark sidebar similar to the reference, including brand/title, role workbench buttons, module navigation, and compact footer/menu area.
- Build a top utility bar similar to the reference, including breadcrumb/location text, search field, notification/avatar/user controls where appropriate.
- Restyle the dashboard as a dense admin workspace with:
- Large white dashboard shell.
- Four metric cards with colored icon blocks and month-over-month text.
- Search/filter panel.
- Ranking/chart-like panel matching the screenshot's simple blue bar chart look.
- Recent borrowing table and overdue table.
- Book-management table.
- Shortcut cards for reader management, report center, borrowing circulation, and system logs.
- Restyle shared tables, forms, buttons, badges, panels, empty states, and navigation so secondary pages feel consistent with the reference.
- Preserve existing JSP/Servlet behavior and role-based visibility.
- Keep user-visible copy in Simplified Chinese.
- Keep responsive behavior usable on narrower screens.
Acceptance Criteria
- Dashboard layout visibly matches the reference image's structure, spacing, palette, and density.
- Shared navigation changes are reflected across existing JSP pages without breaking role-based links.
- Existing forms and tables remain functional and readable after the redesign.
- No React/Vue/SPA tooling is introduced.
- Maven build succeeds.
Definition Of Done
- Tests/build run where available.
- JSP/CSS changes reviewed against frontend specs and the reference image.
- Task context files are curated for implement/check agents.
- Any reusable convention learned during the work is considered for spec update.
Out Of Scope
- Backend behavior changes.
- Database schema changes.
- Replacing JSP with a JavaScript framework.
- Exact live charting libraries unless needed; a CSS/HTML approximation is acceptable for this visual refactor.
Technical Notes
- Reference image copied to
.trellis/tasks/04-28-frontend-reference-redesign/research/reference-dashboard.png. - Visual notes are recorded in
.trellis/tasks/04-28-frontend-reference-redesign/research/reference-dashboard-visual-notes.md. - Relevant spec index:
.trellis/spec/frontend/index.md.