mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-12 23:40:45 +00:00
114 lines
3.6 KiB
Markdown
114 lines
3.6 KiB
Markdown
# OpenClaw Android UI Style Guide
|
|
|
|
Scope: all native Android UI in `apps/android` (Jetpack Compose).
|
|
Goal: one coherent visual system across onboarding, settings, and future screens.
|
|
|
|
## 1. Design Direction
|
|
|
|
- Clean, quiet surfaces.
|
|
- Strong readability first.
|
|
- One clear primary action per screen state.
|
|
- Progressive disclosure for advanced controls.
|
|
- Deterministic flows: validate early, fail clearly.
|
|
|
|
## 2. Style Baseline
|
|
|
|
The onboarding flow defines the current visual baseline.
|
|
New screens should match that language unless there is a strong product reason not to.
|
|
|
|
Baseline traits:
|
|
|
|
- Light neutral background with subtle depth.
|
|
- Clear blue accent for active/primary states.
|
|
- Strong border hierarchy for structure.
|
|
- Medium/semibold typography (no thin text).
|
|
- Divider-and-spacing layout over heavy card nesting.
|
|
|
|
## 3. Core Tokens
|
|
|
|
Use these as shared design tokens for new Compose UI.
|
|
|
|
- Background gradient: `#FFFFFF`, `#F7F8FA`, `#EFF1F5`
|
|
- Surface: `#F6F7FA`
|
|
- Border: `#E5E7EC`
|
|
- Border strong: `#D6DAE2`
|
|
- Text primary: `#17181C`
|
|
- Text secondary: `#4D5563`
|
|
- Text tertiary: `#8A92A2`
|
|
- Accent primary: `#1D5DD8`
|
|
- Accent soft: `#ECF3FF`
|
|
- Success: `#2F8C5A`
|
|
- Warning: `#C8841A`
|
|
|
|
Rule: do not introduce random per-screen colors when an existing token fits.
|
|
|
|
## 4. Typography
|
|
|
|
Primary type family: Manrope (`400/500/600/700`).
|
|
|
|
Recommended scale:
|
|
|
|
- Display: `34sp / 40sp`, bold
|
|
- Section title: `24sp / 30sp`, semibold
|
|
- Headline/action: `16sp / 22sp`, semibold
|
|
- Body: `15sp / 22sp`, medium
|
|
- Callout/helper: `14sp / 20sp`, medium
|
|
- Caption 1: `12sp / 16sp`, medium
|
|
- Caption 2: `11sp / 14sp`, medium
|
|
|
|
Use monospace only for commands, setup codes, endpoint-like values.
|
|
Hard rule: avoid ultra-thin weights on light backgrounds.
|
|
|
|
## 5. Layout And Spacing
|
|
|
|
- Respect safe drawing insets.
|
|
- Keep content hierarchy mostly via spacing + dividers.
|
|
- Prefer vertical rhythm from `8/10/12/14/20dp`.
|
|
- Use pinned bottom actions for multi-step or high-importance flows.
|
|
- Avoid unnecessary container nesting.
|
|
|
|
## 6. Buttons And Actions
|
|
|
|
- Primary action: filled accent button, visually dominant.
|
|
- Secondary action: lower emphasis (outlined/text/surface button).
|
|
- Icon-only buttons must remain legible and >=44dp target.
|
|
- Back buttons in action rows use rounded-square shape, not circular by default.
|
|
|
|
## 7. Inputs And Forms
|
|
|
|
- Always show explicit label or clear context title.
|
|
- Keep helper copy short and actionable.
|
|
- Validate before advancing steps.
|
|
- Prefer immediate inline errors over hidden failure states.
|
|
- Keep optional advanced fields explicit (`Manual`, `Advanced`, etc.).
|
|
|
|
## 8. Progress And Multi-Step Flows
|
|
|
|
- Use clear step count (`Step X of N`).
|
|
- Use labeled progress rail/indicator when steps are discrete.
|
|
- Keep navigation predictable: back/next behavior should never surprise.
|
|
|
|
## 9. Accessibility
|
|
|
|
- Minimum practical touch target: `44dp`.
|
|
- Do not rely on color alone for status.
|
|
- Preserve high contrast for all text tiers.
|
|
- Add meaningful `contentDescription` for icon-only controls.
|
|
|
|
## 10. Architecture Rules
|
|
|
|
- Durable UI state in `MainViewModel`.
|
|
- Composables: state in, callbacks out.
|
|
- No business/network logic in composables.
|
|
- Keep side effects explicit (`LaunchedEffect`, activity result APIs).
|
|
|
|
## 11. Source Of Truth
|
|
|
|
- `app/src/main/java/ai/openclaw/android/ui/OpenClawTheme.kt`
|
|
- `app/src/main/java/ai/openclaw/android/ui/OnboardingFlow.kt`
|
|
- `app/src/main/java/ai/openclaw/android/ui/RootScreen.kt`
|
|
- `app/src/main/java/ai/openclaw/android/ui/SettingsSheet.kt`
|
|
- `app/src/main/java/ai/openclaw/android/MainViewModel.kt`
|
|
|
|
If style and implementation diverge, update both in the same change.
|