Go to file
William Casarin af8d7d222c Add note wide mode for reposts
This adds a 'wide' note design for note previews. This is a mode
where the note contents does not have padding at the start. This makes
notes previews a bit nicer.

Screenshot: https://cdn.jb55.com/s/84271f386d564c34.png
Signed-off-by: William Casarin <jb55@jb55.com>
2024-07-10 10:56:15 -07:00
.github/workflows github: remove pages workflow 2024-04-27 01:53:08 -07:00
assets Account switcher 2024-05-27 10:48:28 -07:00
enostr Merge 'impl linux credential storage' #115 2024-07-01 10:49:15 -07:00
queries add my pubkey to the timeline query for testing 2024-07-01 07:31:12 -07:00
scripts Add precommit hook to suggest proper formatting 2024-04-19 14:13:11 -07:00
src Add note wide mode for reposts 2024-07-10 10:56:15 -07:00
.envrc env: allow private things like secret keys 2024-07-01 06:33:22 -07:00
.gitignore env: allow private things like secret keys 2024-07-01 06:33:22 -07:00
Cargo.lock Switch to egui master to fix wgpu issues 2024-07-02 17:48:18 -07:00
Cargo.toml Switch to egui master to fix wgpu issues 2024-07-02 17:48:18 -07:00
LICENSE add license 2023-07-05 14:56:14 -07:00
Makefile profile picture image cache 2024-02-27 14:26:02 -08:00
README.md docs: make note about not needing nix on ubunutu 2024-07-10 09:54:07 -07:00
SECURITY.md Create SECURITY.md 2024-04-09 23:05:31 -05:00
Trunk.toml trunk: notedeck 2023-07-06 08:40:50 -07:00
check check: remove duplicate and disable wasm checks 2024-04-19 17:37:41 -07:00
damus.keystore add temporary release keystore 2023-07-09 12:29:39 -07:00
index.html codename is domus for now 2023-07-01 11:25:55 -07:00
preview add --light lightmode flag to previews and notedeck 2024-06-14 11:12:16 -07:00
rust-toolchain progress 2022-11-06 19:32:13 -08:00
shell.nix Merge commit 'refs/pull/github/53' 2024-05-15 09:40:12 -07:00

README.md

Damus

A multiplatform nostr client. Works on android and desktop

Alpha! WIP!

Desktop

The desktop client is called notedeck:

notedeck

Android

Look it actually runs on android!

Usage

You can customize the columns by passing them as command-line arguments. This is only for testing and will likely change.

$ ./target/release/notedeck "$(cat queries/timeline.json)" "$(cat queries/notifications.json)"

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.

First, install nix if you don't have it.

The shell.nix provides a reproducible build environment, mainly for android but it also includes rust tools if you don't have those installed. It will likely work without nix if you are just looking to do non-android dev and have the rust toolchain already installed. If you decide to use nix, I recommend using direnv to load the nix shell environment when you cd into the directory.

If you don't have direnv, enter the dev shell via:

$ nix-shell

Once you have your dev shell setup, you can build with this command:

$ 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

Android Emulator

  • Install Android Studio
  • Open 'Device Manager' in Android Studio
  • Add a new device with API level 34 and ABI arm64-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

The app should appear on the emulator

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.