3.7 KiB
CLAUDE.md
This document serves as a shared guideline for all team members when using Claude Code in this repository.
Tech Stack
read @.cursor/rules/project-introduce.mdc
Directory Structure
read @.cursor/rules/project-structure.mdc
Development
Git Workflow
- The current release branch is
nextinstead ofmainuntil v2.0.0 is officially released - use rebase for git pull
- git commit message should prefix with gitmoji
- git branch name format example: tj/feat/feature-name
- use .github/PULL_REQUEST_TEMPLATE.md to generate pull request description
Package Management
This repository adopts a monorepo structure.
- Use
pnpmas the primary package manager for dependency management - Use
bunto run npm scripts - Use
bunxto run executable npm packages
TypeScript Code Style Guide
see @.cursor/rules/typescript.mdc
Testing
- Required Rule: read
@.cursor/rules/testing-guide/testing-guide.mdcbefore writing tests - Command:
- web:
bunx vitest run --silent='passed-only' '[file-path-pattern]' - packages(eg: database):
cd packages/database && bunx vitest run --silent='passed-only' '[file-path-pattern]'
- web:
Important:
- wrap the file path in single quotes to avoid shell expansion
- Never run
bun run testetc to run tests, this will run all tests and cost about 10mins - If trying to fix the same test twice, but still failed, stop and ask for help.
Typecheck
- use
bun run typecheckto check type errors.
i18n
- Keys: Add to
src/locales/default/namespace.ts - Dev: Translate
locales/zh-CN/namespace.jsonandlocales/en-US/namespace.jsonlocales file only for dev preview - DON'T run
pnpm i18n, let CI auto handle it
Linear Issue Management
When working with Linear issues:
- Retrieve issue details before starting work using
mcp__linear-server__get_issue - Check for sub-issues: If the issue has sub-issues, retrieve and review ALL sub-issues using
mcp__linear-server__list_issueswithparentIdfilter before starting work - Update issue status when completing tasks using
mcp__linear-server__update_issue - MUST add completion comment using
mcp__linear-server__create_comment
Completion Comment (REQUIRED)
Every time you complete an issue, you MUST add a comment summarizing the work done. This is critical for:
- Team visibility and knowledge sharing
- Code review context
- Future reference and debugging
IMPORTANT: Per-Issue Completion Rule
When working on multiple issues (e.g., parent issue with sub-issues), you MUST update status and add comment for EACH issue IMMEDIATELY after completing it. Do NOT wait until all issues are done to update them in batch.
Workflow for EACH individual issue:
- Complete the implementation for this specific issue
- Run type check:
bun run typecheck - Run related tests if applicable
- Create PR if needed
- IMMEDIATELY update issue status to "In Review" (NOT "Done"):
mcp__linear-server__update_issue - IMMEDIATELY add completion comment:
mcp__linear-server__create_comment - Only then move on to the next issue
Note: Issue status should be set to "In Review" when PR is created. The status will be updated to "Done" only after the PR is merged (usually handled by Linear-GitHub integration or manually).
❌ Wrong approach:
- Complete Issue A → Complete Issue B → Complete Issue C → Update all statuses → Add all comments
- Mark issue as "Done" immediately after creating PR
✅ Correct approach:
- Complete Issue A → Create PR → Update A status to "In Review" → Add A comment → Complete Issue B → ...
Rules Index
Some useful project rules are listed in @.cursor/rules/rules-index.mdc