mirror of
https://github.com/openclaw/openclaw.git
synced 2026-02-09 05:19:32 +08:00
79 lines
2.9 KiB
Markdown
79 lines
2.9 KiB
Markdown
# Contributing to OpenClaw
|
|
|
|
Welcome to the lobster tank! 🦞
|
|
|
|
## Quick Links
|
|
|
|
- **GitHub:** https://github.com/openclaw/openclaw
|
|
- **Discord:** https://discord.gg/qkhbAGHRBT
|
|
- **X/Twitter:** [@steipete](https://x.com/steipete) / [@openclaw](https://x.com/openclaw)
|
|
|
|
## Maintainers
|
|
|
|
- **Peter Steinberger** - Benevolent Dictator
|
|
- GitHub: [@steipete](https://github.com/steipete) · X: [@steipete](https://x.com/steipete)
|
|
|
|
- **Shadow** - Discord + Slack subsystem
|
|
- GitHub: [@thewilloftheshadow](https://github.com/thewilloftheshadow) · X: [@4shad0wed](https://x.com/4shad0wed)
|
|
|
|
- **Jos** - Telegram, API, Nix mode
|
|
- GitHub: [@joshp123](https://github.com/joshp123) · X: [@jjpcodes](https://x.com/jjpcodes)
|
|
|
|
- **Christoph Nakazawa** - JS Infra
|
|
- GitHub: [@cpojer](https://github.com/cpojer) · X: [@cnakazawa](https://x.com/cnakazawa)
|
|
|
|
- **Gustavo Madeira Santana** - Multi-agents, CLI, web UI
|
|
- GitHub: [@gumadeiras](https://github.com/gumadeiras) · X: [@gumadeiras](https://x.com/gumadeiras)
|
|
|
|
## How to Contribute
|
|
|
|
1. **Bugs & small fixes** → Open a PR!
|
|
2. **New features / architecture** → Start a [GitHub Discussion](https://github.com/openclaw/openclaw/discussions) or ask in Discord first
|
|
3. **Questions** → Discord #setup-help
|
|
|
|
## Before You PR
|
|
|
|
- Test locally with your OpenClaw instance
|
|
- Run tests: `pnpm build && pnpm check && pnpm test`
|
|
- Keep PRs focused (one thing per PR)
|
|
- Describe what & why
|
|
|
|
## Control UI Decorators
|
|
|
|
The Control UI uses Lit with **legacy** decorators (current Rollup parsing does not support
|
|
`accessor` fields required for standard decorators). When adding reactive fields, keep the
|
|
legacy style:
|
|
|
|
```ts
|
|
@state() foo = "bar";
|
|
@property({ type: Number }) count = 0;
|
|
```
|
|
|
|
The root `tsconfig.json` is configured for legacy decorators (`experimentalDecorators: true`)
|
|
with `useDefineForClassFields: false`. Avoid flipping these unless you are also updating the UI
|
|
build tooling to support standard decorators.
|
|
|
|
## AI/Vibe-Coded PRs Welcome! 🤖
|
|
|
|
Built with Codex, Claude, or other AI tools? **Awesome - just mark it!**
|
|
|
|
Please include in your PR:
|
|
|
|
- [ ] Mark as AI-assisted in the PR title or description
|
|
- [ ] Note the degree of testing (untested / lightly tested / fully tested)
|
|
- [ ] Include prompts or session logs if possible (super helpful!)
|
|
- [ ] Confirm you understand what the code does
|
|
|
|
AI PRs are first-class citizens here. We just want transparency so reviewers know what to look for.
|
|
|
|
## Current Focus & Roadmap 🗺
|
|
|
|
We are currently prioritizing:
|
|
|
|
- **Stability**: Fixing edge cases in channel connections (WhatsApp/Telegram).
|
|
- **UX**: Improving the onboarding wizard and error messages.
|
|
- **Skills**: Expanding the library of bundled skills and improving the Skill Creation developer experience.
|
|
- **Performance**: Optimizing token usage and compaction logic.
|
|
|
|
Check the [GitHub Issues](https://github.com/openclaw/openclaw/issues) for "good first issue" labels!
|