UI Bundle UI
Identify the Task
Determine which category the request falls into:
| Category | Examples | Implementation Guide |
|---|
| Page | New routed page (contacts, dashboard, settings) | |
| Header / Footer | Site-wide nav bar, footer, branding | implementation/header-footer.md
|
| Component | Widget, card, table, form, dialog | implementation/component.md
|
Layout and Navigation
is the source of truth for navigation and layout. Every page shares this shell.
When making any change that affects navigation, header, footer, sidebar, theme, or layout:
- Edit — the layout used by
- Replace all default/template nav items and labels with app-specific links and names
- Replace placeholder app name everywhere: header, nav brand, footer, in
Before finishing, confirm: Did I update
with real nav items and branding?
| What | Where |
|---|
| Layout, nav, branding | |
| Document title | |
| Root page content | Component at root route in |
React and TypeScript Standards
Routing
Use a single router package. With
/
, all imports must come from
(not
).
If the app uses a client-side router (React Router, Remix Router, Vue Router, etc.), always derive basename / basepath / base from the document's
tag at runtime. Never hardcode the basename:
js
const basename = document.querySelector('base')
? new URL(document.querySelector('base').href).pathname.replace(/\/$/, '')
: '/';
const router = createBrowserRouter(routes, { basename });
Component Library and Styling
- shadcn/ui for components:
import { Button } from '@/components/ui/button';
- Tailwind CSS utility classes
URL and Path Handling
Apps run behind dynamic base paths. Router navigation (
,
) uses absolute paths (
). Non-router attributes (
) use dot-relative (
). Prefer Vite
for static assets.
TypeScript
- Never use — use proper types, generics, or with type guards
- Event handlers:
(event: React.FormEvent<HTMLFormElement>): void
- State:
useState<User | null>(null)
— always provide the type parameter
- No unsafe assertions () — use type guards instead
Module Restrictions
React UI bundles must not import Salesforce platform modules like
or
(LWC-only). For data access, use the
using-ui-bundle-salesforce-data
skill.
Design Thinking
Before coding, commit to a bold aesthetic direction:
- Purpose: What problem does this interface solve? Who uses it?
- Tone: Pick a clear direction — brutally minimal, maximalist, retro-futuristic, organic, luxury, playful, editorial, brutalist, art deco, soft/pastel, industrial. Use these as inspiration but design one true to the context.
- Differentiation: What makes this unforgettable? What's the one thing someone will remember?
Choose a clear conceptual direction and execute it with precision. Bold maximalism and refined minimalism both work — the key is intentionality, not intensity.
Frontend Aesthetics
-
Typography: Choose distinctive, characterful fonts. Pair a display font with a refined body font. Never default to Inter, Roboto, Arial, Space Grotesk, or system fonts.
-
Color: Commit to a cohesive palette using CSS variables. Dominant colors with sharp accents outperform timid, evenly-distributed palettes. Avoid cliched purple gradients on white.
-
Motion: Focus on high-impact moments — one well-orchestrated page load with staggered reveals (
) creates more delight than scattered micro-interactions. Use scroll-triggering and hover states that surprise. Prefer CSS-only solutions; use Motion library for React when available.
-
Spatial Composition: Unexpected layouts — asymmetry, overlap, diagonal flow, grid-breaking elements. Generous negative space OR controlled density.
-
Backgrounds & Depth: Create atmosphere rather than defaulting to solid colors. Gradient meshes, noise textures, geometric patterns, layered transparencies, dramatic shadows, decorative borders, grain overlays.
-
Mobile Responsiveness: All generated UI MUST be mobile-responsive. Use Tailwind responsive prefixes (
,
,
) to adapt layouts across breakpoints. Stack columns on small screens, use flexible grids, and ensure touch targets are at least 44px. Test that navigation, typography, and spacing work on mobile viewports.
Match implementation complexity to the aesthetic vision. Maximalist designs need elaborate animations and effects. Minimalist designs need restraint, precision, and careful spacing/typography. No two designs should look the same — vary themes, fonts, and aesthetics across generations.
Clarifying Questions
Ask one question at a time and stop when you have enough context.
For a Page
- Name and purpose?
- URL path?
- Should it appear in navigation?
- Access control? (public, authenticated via , or unauthenticated via )
- Content sections? (list, form, table, detail view)
- Data fetching needs?
For a Header / Footer
- Header, footer, or both?
- Contents? (logo, nav links, user avatar, copyright, social icons)
- Sticky header?
- Color scheme or style direction?
For a Component
- What should it do?
- Which page does it belong to?
- Shared/reusable or specific to one feature?
- Data or props needed?
- Internal state? (loading, toggle, form state)
- Specific shadcn components to use?
Verification
Before completing, run lint and build from the UI bundle directory. Lint must result in 0 errors and build must succeed.