Commit Graph

177 Commits

Author SHA1 Message Date
c6dc2c3050 chore: merge executor worktree (worktree-agent-a2b5acd5) 2026-04-20 17:17:19 +02:00
c3b50c70a8 docs(05-03): complete page rounding sweep and spacing upgrade plan 2026-04-20 17:17:05 +02:00
00670afe4e feat(05-03): remove rounded-* and upgrade spacing on all 9 pages
- DashboardPage: space-y-6->space-y-8, gap-6->gap-8 in chart grid
- BudgetListPage: remove rounded-md from template toggle row
- BudgetDetailPage: remove rounded-sm/md from skeleton and group headings, rounded-md from summary box, rounded-full from category dot
- TemplatePage: remove rounded-sm/full/md from skeleton and group headings and category dot; gap-6->gap-8, space-y-6->space-y-8
- CategoriesPage: remove rounded-sm/full/md from skeleton and group headings; space-y-6->space-y-8
- QuickAddPage: remove rounded-full/md from skeleton items
- SettingsPage: space-y-4->space-y-6 in CardContent (skeleton and live)
2026-04-20 17:16:29 +02:00
12ed62e430 docs(phase-05): update tracking after wave 1 2026-04-20 17:13:14 +02:00
441d201837 chore: merge executor worktree (worktree-agent-a29c13e1) 2026-04-20 17:12:56 +02:00
6e892374b8 chore: merge executor worktree (worktree-agent-a0017a3e) 2026-04-20 17:12:52 +02:00
1547fe350c docs(05-02): complete shared component rounding and spacing cleanup plan 2026-04-20 17:12:39 +02:00
4eb866cad1 docs(05-01): complete design token foundation plan summary 2026-04-20 17:12:22 +02:00
e7282fa3d6 feat(05-02): remove hardcoded rounded-* from CategorySection, ChartEmptyState, QuickAddPicker
- CategorySection: remove rounded-md from collapsible trigger button
- ChartEmptyState: remove rounded-lg from empty state border container
- QuickAddPicker: remove rounded-sm from picker item buttons
- QuickAddPicker: remove rounded-full from category dot indicator
2026-04-20 17:12:03 +02:00
4c74deced7 feat(05-01): update chart Bar radius to 0 and remove rounded-full legend dot
- SpendBarChart: set radius={0} on both Bar elements (was radius={4})
- IncomeBarChart: set radius={0} on both Bar elements (was radius={[4,4,0,0]})
- ExpenseDonutChart: remove rounded-full from legend color dot className
2026-04-20 17:11:48 +02:00
e8f13c91c6 feat(05-02): upgrade PageShell spacing to gap-8 and remove rounded-* from DashboardSkeleton
- PageShell: gap-6 → gap-8 for header-to-content spacing on all pages
- DashboardSkeleton: gap-6 → gap-8 (outer flex), gap-4 → gap-6 (summary cards), gap-6 → gap-8 (chart grid)
- DashboardSkeleton: remove rounded-md from 3 chart skeleton placeholders
- DashboardSkeleton: remove rounded-md from collapsible section row divs
- DashboardSkeleton: remove rounded-full from 2 badge skeleton placeholders
2026-04-20 17:11:20 +02:00
99b5b5f8e4 feat(05-01): edit design tokens and add CSS overrides in index.css
- Set --radius: 0 for sharp-cornered design system cascade
- Warm background chroma from 0.005 to 0.01
- Delete --color-chart-1 through --color-chart-5 (redundant with fill vars)
- Raise fill chroma to 0.22+ for vibrant pastel category colors
- Add .recharts-rectangle and [data-sonner-toast] radius overrides
2026-04-20 17:11:12 +02:00
e5637511d7 docs(05): create phase 5 design system token rework plans
3 plans across 2 waves covering DS-01, DS-02, DS-03:
- Plan 01: Token edits (radius, colors, chart vars) + chart components
- Plan 02: Shared component rounded-* removal + spacing upgrades
- Plan 03: Per-page sweep (9 pages) + visual verification checkpoint

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-20 16:53:20 +02:00
df2c6af8bf docs(phase-5): add validation strategy
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-20 16:45:06 +02:00
0a598e53d8 docs(05): research phase 5 design system token rework
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-20 16:44:11 +02:00
1258368522 docs(phase-5): UI design contract for Design System Token Rework
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-20 16:37:13 +02:00
a67a802bc2 docs(05): smart discuss context for Design System Token Rework
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-20 16:34:35 +02:00
1ea119d2a4 docs: create milestone v2.0 roadmap (5 phases) 2026-04-02 16:09:19 +02:00
0b02d7d328 docs: define milestone v2.0 requirements 2026-04-02 15:59:43 +02:00
0b72f1c305 docs: complete project research 2026-04-02 15:30:56 +02:00
8fdab4b796 docs: start milestone v2.0 UX Simplification & Design Rework 2026-04-02 15:16:10 +02:00
4b0f18a216 Merge branch 'Develop' of https://gitea.jeanlucmakiola.de/makiolaj/SimpleFinanceDash into Develop
# Conflicts:
#	.planning/milestones/v1.0-phases/02-dashboard-charts-and-layout/02-01-SUMMARY.md
#	.planning/milestones/v1.0-phases/03-collapsible-dashboard-sections/03-CONTEXT.md
2026-04-02 14:33:13 +02:00
039fa0bc80 sum 2026-04-02 14:29:36 +02:00
439d0e950d chore: archive v1.0 phase directories 2026-03-24 09:46:00 +01:00
3a771ba7cd chore: complete v1.0 UI/UX Overhaul milestone 2026-03-24 09:44:12 +01:00
1d5e019839 docs: sync roadmap and state — mark phases 02-04 complete 2026-03-24 09:39:50 +01:00
0410d90e02 docs(02-01): add missing summary for month navigation plan 2026-03-24 09:39:26 +01:00
a270deb2db docs(phase-04): complete phase execution 2026-03-17 16:29:35 +01:00
51516cd73d docs(04-03): add final commit hash and self-check to SUMMARY.md 2026-03-17 16:24:18 +01:00
1e61b88628 docs(04-03): complete budget pages design consistency plan
- BudgetListPage: PageShell, locale-aware months via Intl.DateTimeFormat, skeleton, i18n month/year/total labels
- BudgetDetailPage: semantic tokens, direction-aware diff, group headers, skeleton, PageShell, locale heading
- STATE.md: advance plan, record metrics, add decisions, update session
- ROADMAP.md: phase 04 marked 3/3 plans complete
2026-03-17 16:23:50 +01:00
24d071c1f3 feat(04-03): upgrade BudgetDetailPage with semantic tokens, direction-aware diff, PageShell, group headers, and skeleton
- Replace TierBadge and tier column with cleaner per-category grouping display
- Rewrite DifferenceCell with direction-aware diff logic (spending types: over when actual > budgeted; income/saving/investment: over when actual < budgeted)
- Replace text-green-600/text-red-600 with text-on-budget/text-over-budget semantic tokens
- Replace dot+h2 group headers with left-border accent headers matching dashboard style
- Fix headingLabel to use i18n.language via Intl.DateTimeFormat instead of hardcoded 'en'
- Wrap page in PageShell with locale-aware title and Add Item action button
- Add back-link as first child of PageShell with -mt-4 compensation
- Replace null loading state with PageShell + Skeleton groups
- Update group footer total label to use budgets.total i18n interpolation key
2026-03-17 16:21:37 +01:00
89dd3ded74 feat(04-03): upgrade BudgetListPage with PageShell, locale-aware months, skeleton, and i18n labels
- Replace hardcoded MONTHS array with Intl.DateTimeFormat locale-aware monthItems useMemo
- Update budgetLabel helper to accept locale parameter and use Intl.DateTimeFormat
- Replace null loading state with PageShell + Skeleton rows
- Replace manual header with PageShell title and action prop
- Replace hardcoded 'Month'/'Year' Labels with t('budgets.month')/t('budgets.year')
- Add month/year/total keys to en.json and de.json budgets namespace
2026-03-17 16:20:02 +01:00
f166f1ac5e docs(04-02): complete CRUD pages design consistency plan
- 04-02-SUMMARY.md: documents PageShell adoption, skeleton loading, group headers
- STATE.md: position advanced to 04-02 complete, decisions recorded
- ROADMAP.md: phase 4 progress updated (2 of 3 plans complete)
2026-03-17 16:18:11 +01:00
ba19c30f07 feat(04-02): upgrade QuickAddPage and SettingsPage with PageShell and skeletons
- QuickAddPage: adopt PageShell for header with title and Add button
- QuickAddPage: replace return null with skeleton loading state (5-row table skeleton)
- SettingsPage: adopt PageShell for header with title
- SettingsPage: remove duplicate h1 heading (was shown alongside CardTitle)
- SettingsPage: remove CardHeader and CardTitle (PageShell provides page-level title)
- SettingsPage: replace return null with skeleton loading state
- SettingsPage: clean up imports — remove CardHeader/CardTitle
2026-03-17 16:16:23 +01:00
e9497e42a7 feat(04-02): upgrade CategoriesPage and TemplatePage with PageShell, skeletons, and group headers
- CategoriesPage: adopt PageShell for header with title and Add Category button
- CategoriesPage: replace return null with skeleton loading state
- CategoriesPage: upgrade dot group headers to left-border accent style
- TemplatePage: mirror PageShell layout (flex-col gap-6) for inline-editable header
- TemplatePage: replace return null with skeleton loading state
- TemplatePage: upgrade dot group headers to left-border accent style
- TemplateName h1: add tracking-tight to match PageShell h1 style
2026-03-17 16:15:04 +01:00
b15a14dea0 docs(04-01): complete auth page redesign plan
- LoginPage and RegisterPage redesigned with muted bg, card accent, logo, subtitle
- Google and GitHub SVG provider icons added to OAuth buttons
- auth.loginSubtitle and auth.registerSubtitle keys in en.json and de.json
- STATE.md updated with position, decisions, metrics
- ROADMAP.md updated with Phase 4 progress (1/3 plans complete)
2026-03-17 16:12:33 +01:00
0ff9939789 feat(04-01): redesign RegisterPage to match LoginPage visual treatment
- Change background from bg-background to bg-muted/60
- Add border-t-4 border-t-primary shadow-lg card accent
- Add favicon.svg logo above CardTitle
- Add auth.registerSubtitle below title
- Add pb-4 to CardHeader for consistent spacing with LoginPage
2026-03-17 16:10:19 +01:00
36d068e0ba feat(04-01): redesign LoginPage with brand presence and OAuth icons
- Change background from bg-background to bg-muted/60
- Add border-t-4 border-t-primary shadow-lg card accent
- Add favicon.svg logo above CardTitle
- Add auth.loginSubtitle below title
- Add Google SVG icon and GitHub SVG icon to OAuth buttons
- Add gap-2 to OAuth button className for icon/text spacing
- Add auth.loginSubtitle and auth.registerSubtitle to en.json and de.json
2026-03-17 16:09:23 +01:00
fbe01b7372 docs(04): create phase plan — 3 plans for full-app design consistency 2026-03-17 16:04:04 +01:00
c16f3302c8 docs(phase-4): add validation strategy 2026-03-17 15:57:41 +01:00
b6a4d3e83d docs(04): research phase domain 2026-03-17 15:56:22 +01:00
c960d80af0 docs(state): record phase 4 context session 2026-03-17 15:50:39 +01:00
b6e34d991e docs(04): capture phase context 2026-03-17 15:50:20 +01:00
748c7edc65 docs(phase-03): complete phase execution
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-17 15:20:03 +01:00
80929e1865 docs(03-02): complete collapsible sections integration plan
- 03-02-SUMMARY.md: documents CollapsibleSections wired into dashboard
- STATE.md: records key-prop reset decision, phase 3 completion, updated session
- ROADMAP.md: phase 3 plans (2/2) marked complete

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-17 15:15:17 +01:00
9a8d13fcfb feat(03-02): wire collapsible sections into DashboardContent
- Add CATEGORY_TYPES_ALL constant and isOverBudget direction-aware helper
- Derive groupedSections via useMemo (filters empty groups, computes totals)
- Initialize openSections state with smart defaults (over-budget expanded)
- State resets on month navigation via key={budgetId} on DashboardContent
- Insert CollapsibleSections between chart grid and QuickAdd
- Add skeleton placeholders for collapsible sections area in DashboardSkeleton

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-17 15:13:41 +01:00
7d08da20ce docs(03-01): complete collapsible sections foundations plan 2026-03-17 15:10:12 +01:00
f30b846f04 feat(03-01): build CategorySection and CollapsibleSections components
- CategorySection: presentational collapsible with left border accent, chevron, badges, 4-column table
- Direction-aware difference logic: spending types (actual > budget = over), income/saving/investment (actual < budget = over)
- Per-item and footer totals with color-coded difference column
- CollapsibleSections: thin container rendering ordered CategorySection list with controlled open state
- Both components accept t() as prop (presentational pattern)
2026-03-17 15:07:56 +01:00
21ce6d8230 feat(03-01): add CSS animation tokens, i18n keys, and carryover display
- Add collapsible-open/close keyframes and CSS animation tokens to index.css
- Add dashboard.sections and dashboard.carryoverIncludes keys to en.json and de.json
- Add optional subtitle/subtitleClassName props to StatCard
- Extend SummaryStrip balance prop with carryoverSubtitle/carryoverIsNegative
- Compute and pass carryover subtitle from DashboardContent to SummaryStrip
2026-03-17 15:07:08 +01:00
1a4035bea1 docs(03): create phase plan 2026-03-17 15:01:41 +01:00