chat-echo 0.2.2

Web chat interface for the Echo ecosystem
Documentation
# Contributing

Contributions are welcome. This document explains the workflow.

## Reporting bugs or requesting features

Open an [issue](https://github.com/dnacenta/chat-echo/issues). Use a clear title and include enough context to reproduce the problem or understand the request.

## Making changes

1. Fork the repo
2. Create a branch from `development` (see naming below)
3. Make your changes
4. Open a PR targeting `development`

`main` is protected. All changes go through `development` first.

## Branch naming

Branches follow this pattern:

```
<type>/<issue-number>-<short-description>
```

| Type       | When to use                          | Example                              |
|------------|--------------------------------------|--------------------------------------|
| `feat`     | New functionality                    | `feat/3-markdown-rendering`          |
| `fix`      | Bug fix                              | `fix/5-websocket-reconnect`          |
| `refactor` | Code restructure, no behavior change | `refactor/8-extract-bridge-client`   |
| `docs`     | Documentation only                   | `docs/2-config-reference`            |
| `chore`    | Maintenance, deps, CI                | `chore/10-update-dependencies`       |

If there's no issue yet, create one first so there's a number to reference.

## Commit messages

This project uses [Conventional Commits](https://www.conventionalcommits.org/) (lowercase):

```
<type>(<scope>): <description>
```

Examples:

```
fix(ws): handle reconnect on server restart
feat(ui): add markdown rendering support
docs: add configuration examples
refactor(bridge): split client into separate module
```

Rules:
- Lowercase everything
- Imperative, present tense ("add" not "added")
- No period at the end
- Reference the issue in the body or footer: `Closes #7`

## Pull request titles

PR titles follow the same convention, referencing the issue number as scope:

```
fix(#5): handle websocket reconnect on server restart
feat(#3): add markdown rendering support
docs(#2): expand configuration reference
```

## Code style

- Run `cargo clippy` before submitting -- no warnings
- Run `cargo fmt` for formatting
- Run `cargo test` to make sure nothing breaks
- Keep changes focused -- one issue per PR