mirror of
https://github.com/CherryHQ/cherry-studio.git
synced 2025-12-25 11:20:07 +08:00
- Expanded the migration status document to outline the comprehensive plan for transitioning from antd + styled-components to shadcn/ui + Tailwind CSS. - Introduced detailed migration strategies, principles, and component classification guidelines. - Added extraction criteria and migration steps to ensure a structured approach to component migration and optimization. - Emphasized collaboration with UI designers for maintaining design consistency throughout the migration process.
6.7 KiB
6.7 KiB
Cherry Studio UI Migration Plan
Overview
This document outlines the detailed plan for migrating Cherry Studio from antd + styled-components to shadcn/ui + Tailwind CSS. We will adopt a progressive migration strategy to ensure system stability and development efficiency, while gradually implementing UI refactoring in collaboration with UI designers.
Migration Strategy
Target Tech Stack
- UI Component Library: shadcn/ui (replacing antd and previously migrated HeroUI)
- Styling Solution: Tailwind CSS (replacing styled-components)
- Design System: Custom CSS variable system (see DESIGN_SYSTEM.md)
- Theme System: CSS variables + shadcn/ui theme
Migration Principles
- Backward Compatibility: Old components continue working until new components are fully available
- Progressive Migration: Migrate components one by one to avoid large-scale rewrites
- Feature Parity: Ensure new components have all the functionality of old components
- Design Consistency: Follow new design system specifications (see DESIGN_SYSTEM.md)
- Performance Priority: Optimize bundle size and rendering performance
- Designer Collaboration: Work with UI designers for gradual component encapsulation and UI optimization
Usage Example
// Import components from @cherrystudio/ui
import { Spinner, DividerWithText, InfoTooltip } from '@cherrystudio/ui'
// Use in components
function MyComponent() {
return (
<div>
<Spinner size={24} />
<DividerWithText text="Divider Text" />
<InfoTooltip content="Tooltip message" />
</div>
)
}
Directory Structure
@packages/ui/
├── src/
│ ├── components/ # Main components directory
│ │ ├── primitives/ # Basic/primitive components (Avatar, ErrorBoundary, Selector, etc.)
│ │ │ └── shadcn-io/ # shadcn/ui components (dropzone, etc.)
│ │ ├── icons/ # Icon components (Icon, FileIcons, etc.)
│ │ └── composites/ # Composite components (CodeEditor, ListItem, etc.)
│ ├── hooks/ # Custom React Hooks
│ ├── styles/ # Global styles and CSS variables
│ ├── types/ # TypeScript type definitions
│ ├── utils/ # Utility functions
│ └── index.ts # Main export file
Component Classification Guide
When submitting PRs, please place components in the correct directory based on their function:
- primitives: Basic and primitive UI elements, shadcn/ui components
Avatar: Avatar componentsErrorBoundary: Error boundary componentsSelector: Selection componentsshadcn-io/: Direct shadcn/ui components or adaptations
- icons: All icon-related components
Icon: Icon factory and basic iconsFileIcons: File-specific icons- Loading/spinner icons (SvgSpinners180Ring, ToolsCallingIcon, etc.)
- composites: Complex components made from multiple primitives
CodeEditor: Code editing componentsListItem: List item componentsThinkingEffect: Animation components- Form and interaction components (DraggableList, EditableNumber, etc.)
Component Extraction Criteria
Extraction Standards
- Usage Frequency: Component is used in ≥ 3 places in the codebase
- Future Reusability: Expected to be used in multiple scenarios in the future
- Business Complexity: Component contains complex interaction logic or state management
- Maintenance Cost: Centralized management can reduce maintenance overhead
- Design Consistency: Components that require unified visual and interaction experience
- Test Coverage: As common components, they facilitate unit test writing and maintenance
Extraction Principles
- Single Responsibility: Each component should only handle one clear function
- Highly Configurable: Provide flexible configuration options through props
- Backward Compatible: New versions maintain API backward compatibility
- Complete Documentation: Provide clear API documentation and usage examples
- Type Safety: Use TypeScript to ensure type safety
Cases Not Recommended for Extraction
- Simple display components used only on a single page
- Overly customized business logic components
- Components tightly coupled to specific data sources
Migration Steps
| Phase | Status | Main Tasks | Description |
|---|---|---|---|
| Phase 1 | 🚧 In Progress | Design System Integration | • Integrate design system CSS variables (todocss.css → design-tokens.css → globals.css) • Configure Tailwind CSS to use custom design tokens • Establish basic style guidelines and theme system |
| Phase 2 | ⏳ To Start | Component Migration and Optimization | • Filter components for migration based on extraction criteria • Remove antd dependencies, replace with shadcn/ui • Remove HeroUI dependencies, replace with shadcn/ui • Remove styled-components, replace with Tailwind CSS + design system variables • Optimize component APIs and type definitions |
| Phase 3 | ⏳ To Start | UI Refactoring and Optimization | • Gradually implement UI refactoring with UI designers • Ensure visual consistency and user experience • Performance optimization and code quality improvement |
Notes
-
Do NOT migrate components with these dependencies (can be migrated after decoupling):
- window.api calls
- Redux (useSelector, useDispatch, etc.)
- Other external data sources
-
Can migrate but need decoupling later:
- Components using i18n (change i18n to props)
- Components using antd (replace with shadcn/ui later)
- Components using HeroUI (replace with shadcn/ui later)
-
Submission Guidelines:
- Each PR should focus on one category of components
- Ensure all migrated components are exported
- Follow component extraction criteria, only migrate qualified components
Design System Integration
CSS Variable System
- Refer to DESIGN_SYSTEM.md for complete design system planning
- Design variables will be managed through CSS variable system, naming conventions TBD
- Support theme switching and responsive design
Migration Priority Adjustment
- High Priority: Basic components (buttons, inputs, tags, etc.)
- Medium Priority: Display components (cards, lists, tables, etc.)
- Low Priority: Composite components and business-coupled components
UI Designer Collaboration
- All component designs need confirmation from UI designers
- Gradually implement UI refactoring to maintain visual consistency
- New components must comply with design system specifications