![]()
Some checks failed
CI / Rustfmt + Clippy (push) Has been cancelled
CI / Test (Linux) (push) Has been cancelled
CI / Test (macOS) (push) Has been cancelled
CI / Test (Windows) (push) Has been cancelled
CI / rpm/deb (push) Has been cancelled
CI / macOS dmg (push) Has been cancelled
CI / Windows Installer (push) Has been cancelled
CI / Upload Artifacts to Server (push) Has been cancelled
|
||
---|---|---|
.cargo | ||
.github/workflows | ||
assets | ||
crates | ||
scripts | ||
.envrc | ||
.gitignore | ||
.rustfmt.toml | ||
Cargo.lock | ||
Cargo.toml | ||
CHANGELOG.md | ||
check | ||
damus.keystore | ||
entitlements.plist | ||
example-android-config.json | ||
index.html | ||
LICENSE | ||
Makefile | ||
preview | ||
README.md | ||
SECURITY.md | ||
shell.nix | ||
TODO | ||
Trunk.toml |
Damus Notedeck
A multiplatform nostr client. Works on android and desktop
The desktop client is called notedeck:
Android
Look it actually runs on android!

Usage
$ ./target/release/notedeck
Developer Setup
Desktop (Linux/MacOS, Windows?)
If you're running debian-based machine like Ubuntu or ElementaryOS, all you need is to install rustup and run sudo apt install build-essential
.
$ cargo run --release
Android
The dev shell should also have all of the android-sdk dependencies needed for development, but you still need the aarch64-linux-android
rustup target installed:
$ rustup target add aarch64-linux-android
To run on a real device, just type:
$ cargo apk run --release -p notedeck_chrome
Android Emulator
- Install Android Studio
- Open 'Device Manager' in Android Studio
- Add a new device with API level
34
and ABIarm64-v8a
(even though the app uses 30, the 30 emulator can't find the vulkan adapter, but 34 works fine) - Start up the emulator
while the emulator is running, run:
cargo apk run --release -p notedeck_chrome
The app should appear on the emulator
Android Config
You can load custom views onto an android device for testing:
-
Copy
example-android-config.json
toandroid-config.json
-
Run
make push-android-config
to copy it to your device
Previews
You can preview individual widgets and views by running the preview script:
./preview RelayView
./preview ProfilePreview
# ... etc
When adding new previews you need to implement the Preview trait for your
view/widget and then add it to the src/ui_preview/main.rs
bin:
previews!(runner, name,
RelayView,
AccountLoginView,
ProfilePreview,
);
Contributing
Configure the developer environment:
./scripts/dev_setup.sh
This will add the pre-commit hook to your local repository to suggest proper formatting before commits.