Pulled ALL skills from 15 source repositories: - anthropics/skills: 16 (docs, design, MCP, testing) - obra/superpowers: 14 (TDD, debugging, agents, planning) - coreyhaines31/marketingskills: 25 (marketing, CRO, SEO, growth) - better-auth/skills: 5 (auth patterns) - vercel-labs/agent-skills: 5 (React, design, Vercel) - antfu/skills: 16 (Vue, Vite, Vitest, pnpm, Turborepo) - Plus 13 individual skills from various repos Mosaic Stack is not limited to coding — the Orchestrator and subagents serve coding, business, design, marketing, writing, logistics, analysis, and more. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
166 lines
4.9 KiB
Markdown
166 lines
4.9 KiB
Markdown
# React Native Guidelines
|
|
|
|
A structured repository for creating and maintaining React Native Best Practices
|
|
optimized for agents and LLMs.
|
|
|
|
## Structure
|
|
|
|
- `rules/` - Individual rule files (one per rule)
|
|
- `_sections.md` - Section metadata (titles, impacts, descriptions)
|
|
- `_template.md` - Template for creating new rules
|
|
- `area-description.md` - Individual rule files
|
|
- `metadata.json` - Document metadata (version, organization, abstract)
|
|
- **`AGENTS.md`** - Compiled output (generated)
|
|
|
|
## Rules
|
|
|
|
### Core Rendering (CRITICAL)
|
|
|
|
- `rendering-text-in-text-component.md` - Wrap strings in Text components
|
|
- `rendering-no-falsy-and.md` - Avoid falsy && operator in JSX
|
|
|
|
### List Performance (HIGH)
|
|
|
|
- `list-performance-virtualize.md` - Use virtualized lists (LegendList,
|
|
FlashList)
|
|
- `list-performance-function-references.md` - Keep stable object references
|
|
- `list-performance-callbacks.md` - Hoist callbacks to list root
|
|
- `list-performance-inline-objects.md` - Avoid inline objects in renderItem
|
|
- `list-performance-item-memo.md` - Pass primitives for memoization
|
|
- `list-performance-item-expensive.md` - Keep list items lightweight
|
|
- `list-performance-images.md` - Use compressed images in lists
|
|
- `list-performance-item-types.md` - Use item types for heterogeneous lists
|
|
|
|
### Animation (HIGH)
|
|
|
|
- `animation-gpu-properties.md` - Animate transform/opacity instead of layout
|
|
- `animation-gesture-detector-press.md` - Use GestureDetector for press
|
|
animations
|
|
- `animation-derived-value.md` - Prefer useDerivedValue over useAnimatedReaction
|
|
|
|
### Scroll Performance (HIGH)
|
|
|
|
- `scroll-position-no-state.md` - Never track scroll in useState
|
|
|
|
### Navigation (HIGH)
|
|
|
|
- `navigation-native-navigators.md` - Use native stack and native tabs
|
|
|
|
### React State (MEDIUM)
|
|
|
|
- `react-state-dispatcher.md` - Use functional setState updates
|
|
- `react-state-fallback.md` - State should represent user intent only
|
|
- `react-state-minimize.md` - Minimize state variables, derive values
|
|
|
|
### State Architecture (MEDIUM)
|
|
|
|
- `state-ground-truth.md` - State must represent ground truth
|
|
|
|
### React Compiler (MEDIUM)
|
|
|
|
- `react-compiler-destructure-functions.md` - Destructure functions early
|
|
- `react-compiler-reanimated-shared-values.md` - Use .get()/.set() for shared
|
|
values
|
|
|
|
### User Interface (MEDIUM)
|
|
|
|
- `ui-expo-image.md` - Use expo-image for optimized images
|
|
- `ui-image-gallery.md` - Use Galeria for lightbox/galleries
|
|
- `ui-menus.md` - Native dropdown and context menus with Zeego
|
|
- `ui-native-modals.md` - Use native Modal with formSheet
|
|
- `ui-pressable.md` - Use Pressable instead of TouchableOpacity
|
|
- `ui-measure-views.md` - Measuring view dimensions
|
|
- `ui-safe-area-scroll.md` - Use contentInsetAdjustmentBehavior
|
|
- `ui-scrollview-content-inset.md` - Use contentInset for dynamic spacing
|
|
- `ui-styling.md` - Modern styling patterns (gap, boxShadow, gradients)
|
|
|
|
### Design System (MEDIUM)
|
|
|
|
- `design-system-compound-components.md` - Use compound components
|
|
|
|
### Monorepo (LOW)
|
|
|
|
- `monorepo-native-deps-in-app.md` - Install native deps in app directory
|
|
- `monorepo-single-dependency-versions.md` - Single dependency versions
|
|
|
|
### Third-Party Dependencies (LOW)
|
|
|
|
- `imports-design-system-folder.md` - Import from design system folder
|
|
|
|
### JavaScript (LOW)
|
|
|
|
- `js-hoist-intl.md` - Hoist Intl formatter creation
|
|
|
|
### Fonts (LOW)
|
|
|
|
- `fonts-config-plugin.md` - Load fonts natively at build time
|
|
|
|
## Creating a New Rule
|
|
|
|
1. Copy `rules/_template.md` to `rules/area-description.md`
|
|
2. Choose the appropriate area prefix:
|
|
- `rendering-` for Core Rendering
|
|
- `list-performance-` for List Performance
|
|
- `animation-` for Animation
|
|
- `scroll-` for Scroll Performance
|
|
- `navigation-` for Navigation
|
|
- `react-state-` for React State
|
|
- `state-` for State Architecture
|
|
- `react-compiler-` for React Compiler
|
|
- `ui-` for User Interface
|
|
- `design-system-` for Design System
|
|
- `monorepo-` for Monorepo
|
|
- `imports-` for Third-Party Dependencies
|
|
- `js-` for JavaScript
|
|
- `fonts-` for Fonts
|
|
3. Fill in the frontmatter and content
|
|
4. Ensure you have clear examples with explanations
|
|
|
|
## Rule File Structure
|
|
|
|
Each rule file should follow this structure:
|
|
|
|
````markdown
|
|
---
|
|
title: Rule Title Here
|
|
impact: MEDIUM
|
|
impactDescription: Optional description
|
|
tags: tag1, tag2, tag3
|
|
---
|
|
|
|
## Rule Title Here
|
|
|
|
Brief explanation of the rule and why it matters.
|
|
|
|
**Incorrect (description of what's wrong):**
|
|
|
|
```tsx
|
|
// Bad code example
|
|
```
|
|
````
|
|
|
|
**Correct (description of what's right):**
|
|
|
|
```tsx
|
|
// Good code example
|
|
```
|
|
|
|
Reference: [Link](https://example.com)
|
|
|
|
```
|
|
|
|
## File Naming Convention
|
|
|
|
- Files starting with `_` are special (excluded from build)
|
|
- Rule files: `area-description.md` (e.g., `animation-gpu-properties.md`)
|
|
- Section is automatically inferred from filename prefix
|
|
- Rules are sorted alphabetically by title within each section
|
|
|
|
## Impact Levels
|
|
|
|
- `CRITICAL` - Highest priority, causes crashes or broken UI
|
|
- `HIGH` - Significant performance improvements
|
|
- `MEDIUM` - Moderate performance improvements
|
|
- `LOW` - Incremental improvements
|
|
```
|