chore: restruture

This commit is contained in:
Ren Amamiya
2026-04-07 11:46:08 +07:00
parent 6fef2ae1c6
commit 9ff18aae35
45 changed files with 201 additions and 129 deletions

111
Cargo.lock generated
View File

@@ -280,7 +280,7 @@ dependencies = [
[[package]]
name = "assets"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"gpui 0.2.2 (git+https://github.com/zed-industries/zed)",
@@ -343,7 +343,7 @@ checksum = "c96bf972d85afc50bf5ab8fe2d54d1586b4e0b46c97c50a0c9e71e2f7bcd812a"
dependencies = [
"async-task",
"concurrent-queue",
"fastrand 2.3.0",
"fastrand 2.4.1",
"futures-lite 2.6.1",
"pin-project-lite",
"slab",
@@ -577,7 +577,7 @@ checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0"
[[package]]
name = "auto_update"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -1037,7 +1037,7 @@ dependencies = [
[[package]]
name = "chat"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -1060,7 +1060,7 @@ dependencies = [
[[package]]
name = "chat_ui"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"chat",
@@ -1254,7 +1254,7 @@ dependencies = [
[[package]]
name = "collections"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"indexmap",
"rustc-hash 2.1.2",
@@ -1294,7 +1294,7 @@ dependencies = [
[[package]]
name = "common"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"bech32",
@@ -1390,7 +1390,7 @@ dependencies = [
[[package]]
name = "coop"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"assets",
@@ -1431,8 +1431,10 @@ dependencies = [
[[package]]
name = "coop_mobile"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"android-activity",
"android_logger",
"anyhow",
"assets",
"chat",
@@ -1443,10 +1445,10 @@ dependencies = [
"gpui-mobile",
"gpui_platform",
"gpui_tokio",
"itertools 0.13.0",
"log",
"nostr-connect",
"nostr-sdk",
"objc2",
"oneshot",
"person",
"relay_auth",
@@ -1463,7 +1465,7 @@ dependencies = [
[[package]]
name = "coop_web"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"assets",
@@ -1788,6 +1790,7 @@ dependencies = [
"quote",
"rustc_version",
"syn",
"unicode-xid",
]
[[package]]
@@ -1803,7 +1806,7 @@ dependencies = [
[[package]]
name = "derive_refineable"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"proc-macro2",
"quote",
@@ -1812,7 +1815,7 @@ dependencies = [
[[package]]
name = "device"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -2188,11 +2191,11 @@ dependencies = [
[[package]]
name = "fastrand"
version = "2.3.0"
version = "2.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "37909eebbb50d72f9059c3b6d82c0463f2ff062c9e95845c43a6c9c0355411be"
checksum = "9f1f227452a390804cdb637b74a86990f2a7d7ba4b7d5693aac9b4dd6defd8d6"
dependencies = [
"getrandom 0.2.17",
"getrandom 0.3.4",
]
[[package]]
@@ -2332,7 +2335,7 @@ version = "0.12.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5e139bc46ca777eb5efaf62df0ab8cc5fd400866427e56c68b22e414e53bd3be"
dependencies = [
"fastrand 2.3.0",
"fastrand 2.4.1",
"futures-core",
"futures-sink",
"spin 0.9.8",
@@ -2552,7 +2555,7 @@ version = "2.6.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "f78e10609fe0e0b3f4157ffab1876319b5b0db102a2c60dc4626306dc46b44ad"
dependencies = [
"fastrand 2.3.0",
"fastrand 2.4.1",
"futures-core",
"futures-io",
"parking",
@@ -2879,7 +2882,7 @@ dependencies = [
[[package]]
name = "gpui"
version = "0.2.2"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"async-channel 2.5.0",
@@ -2959,12 +2962,12 @@ dependencies = [
[[package]]
name = "gpui-mobile"
version = "0.1.0"
source = "git+https://github.com/itsbalamurali/gpui-mobile#f75068f0e036c82fb10436549537d8daea83ef06"
source = "git+https://github.com/itsbalamurali/gpui-mobile#24c8ef2f987d7c0ad891ad15599d7f3ecd193282"
dependencies = [
"android-activity",
"android_logger",
"anyhow",
"block",
"block2",
"core-foundation 0.10.0",
"core-foundation-sys",
"core-graphics 0.24.0",
@@ -2977,7 +2980,7 @@ dependencies = [
"ndk",
"ndk-context",
"ndk-sys",
"objc",
"objc2",
"parking_lot",
"pathfinder_geometry",
"raw-window-handle",
@@ -2991,7 +2994,7 @@ dependencies = [
[[package]]
name = "gpui_linux"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"as-raw-xcb-connection",
@@ -3039,7 +3042,7 @@ dependencies = [
[[package]]
name = "gpui_macos"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"async-task",
@@ -3093,7 +3096,7 @@ dependencies = [
[[package]]
name = "gpui_macros"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"heck 0.5.0",
"proc-macro2",
@@ -3104,7 +3107,7 @@ dependencies = [
[[package]]
name = "gpui_platform"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"console_error_panic_hook",
"gpui 0.2.2 (git+https://github.com/zed-industries/zed)",
@@ -3117,7 +3120,7 @@ dependencies = [
[[package]]
name = "gpui_tokio"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"gpui 0.2.2 (git+https://github.com/zed-industries/zed)",
@@ -3137,7 +3140,7 @@ dependencies = [
[[package]]
name = "gpui_util"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"log",
@@ -3146,7 +3149,7 @@ dependencies = [
[[package]]
name = "gpui_web"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"console_error_panic_hook",
@@ -3198,7 +3201,7 @@ dependencies = [
[[package]]
name = "gpui_wgpu"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"bytemuck",
@@ -3226,7 +3229,7 @@ dependencies = [
[[package]]
name = "gpui_windows"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"collections 0.1.0 (git+https://github.com/zed-industries/zed)",
@@ -3523,7 +3526,7 @@ dependencies = [
[[package]]
name = "http_client"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"async-compression",
@@ -3548,7 +3551,7 @@ dependencies = [
[[package]]
name = "http_client_tls"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"rustls",
"rustls-platform-verifier",
@@ -4403,7 +4406,7 @@ dependencies = [
[[package]]
name = "media"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"bindgen",
@@ -5277,7 +5280,7 @@ dependencies = [
[[package]]
name = "perf"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"collections 0.1.0 (git+https://github.com/zed-industries/zed)",
"serde",
@@ -5286,7 +5289,7 @@ dependencies = [
[[package]]
name = "person"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -5401,7 +5404,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c835479a4443ded371d6c535cbfd8d31ad92c5d23ae9770a61bc155e4992a3c1"
dependencies = [
"atomic-waker",
"fastrand 2.3.0",
"fastrand 2.4.1",
"futures-io",
]
@@ -5997,7 +6000,7 @@ dependencies = [
[[package]]
name = "refineable"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"derive_refineable 0.1.0 (git+https://github.com/zed-industries/zed)",
]
@@ -6033,7 +6036,7 @@ checksum = "dc897dd8d9e8bd1ed8cdad82b5966c3e0ecae09fb1907d58efaa013543185d0a"
[[package]]
name = "relay_auth"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -6096,7 +6099,7 @@ dependencies = [
[[package]]
name = "reqwest_client"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"bytes",
@@ -6154,7 +6157,7 @@ dependencies = [
[[package]]
name = "rope"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"heapless 0.9.2",
"log",
@@ -6431,7 +6434,7 @@ dependencies = [
[[package]]
name = "scheduler"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"async-task",
"backtrace",
@@ -6710,7 +6713,7 @@ dependencies = [
[[package]]
name = "settings"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -6957,7 +6960,7 @@ dependencies = [
[[package]]
name = "state"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -7044,7 +7047,7 @@ dependencies = [
[[package]]
name = "sum_tree"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"heapless 0.9.2",
"log",
@@ -7278,7 +7281,7 @@ version = "3.27.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "32497e9a4c7b38532efcdebeef879707aa9f794296a4f0244f6f69e9bc8574bd"
dependencies = [
"fastrand 2.3.0",
"fastrand 2.4.1",
"getrandom 0.4.2",
"once_cell",
"rustix 1.1.4",
@@ -7307,7 +7310,7 @@ dependencies = [
[[package]]
name = "theme"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"gpui 0.2.2 (git+https://github.com/zed-industries/zed)",
@@ -7444,7 +7447,7 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20"
[[package]]
name = "title_bar"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -7826,7 +7829,7 @@ dependencies = [
[[package]]
name = "ui"
version = "1.0.0-beta2"
version = "1.0.0-beta3"
dependencies = [
"anyhow",
"common",
@@ -8056,7 +8059,7 @@ dependencies = [
[[package]]
name = "util"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"async-fs",
@@ -8105,7 +8108,7 @@ dependencies = [
[[package]]
name = "util_macros"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"perf 0.1.0 (git+https://github.com/zed-industries/zed)",
"quote",
@@ -9933,7 +9936,7 @@ dependencies = [
[[package]]
name = "zlog"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"anyhow",
"chrono",
@@ -9961,7 +9964,7 @@ dependencies = [
[[package]]
name = "ztracing"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
dependencies = [
"tracing",
"tracing-subscriber",
@@ -9977,7 +9980,7 @@ source = "git+https://github.com/zed-industries/zed?rev=56104fb17e6c5849900a4c28
[[package]]
name = "ztracing_macro"
version = "0.1.0"
source = "git+https://github.com/zed-industries/zed#68452a3daea53843b9b388ec53a2cfd7673baac0"
source = "git+https://github.com/zed-industries/zed#3a5dc8ef6aaed33f7c57f9eeab36bbc71a19bc59"
[[package]]
name = "zune-core"

View File

@@ -1,7 +1,7 @@
[workspace]
resolver = "2"
members = ["crates/*"]
default-members = ["crates/coop"]
members = ["crates/*", "desktop", "web", "mobile"]
default-members = ["desktop"]
[workspace.package]
version = "1.0.0-beta3"

54
GEMINI.md Normal file
View File

@@ -0,0 +1,54 @@
# Coop - Gemini Context
## Project Overview
Coop is a simple, fast, and reliable Nostr client for secure messaging across all platforms. It is written in Rust and structured as a Cargo workspace. The project utilizes:
- **GPUI**: The GPU-accelerated UI framework developed by Zed Industries for cross-platform, high-performance user interfaces.
- **Rust Nostr SDK**: For handling the Nostr protocol (including NIPs like 44, 49, 59, 96).
The workspace is divided into several sub-crates under `crates/`, including the main application (`coop`), UI components (`ui`, `chat_ui`, `title_bar`, `theme`), and domain logic (`chat`, `person`, `relay_auth`, `state`, `device`).
## Building and Running
### Prerequisites
- **Rust Toolchain**: Use `rustup` to install the Rust toolchain.
- **System Dependencies**: Depending on your OS, you must run the provided setup scripts to install necessary libraries before compiling.
### Commands
- **Install Linux Dependencies**:
```bash
./script/linux
```
- **Install FreeBSD Dependencies**:
```bash
./script/freebsd
```
- **Install macOS Dependencies**:
```bash
./script/macos
```
- **Build the project** (debug mode):
```bash
cargo build
```
- **Run the application**:
```bash
cargo run
```
- **Build for Production** (optimized release binary):
```bash
cargo build --release
```
### Packaging
- Packaging scripts and manifests are available in the `script/` directory (e.g., `bundle-linux`, `bundle-snap`, `prepare-flathub`) and the `flathub/` directory.
## Development Conventions
- **Code Formatting**: The project enforces a strict Rust code formatting style via `rustfmt.toml`.
- **Edition**: 2024
- **Indentation**: Block style with 4 tab spaces.
- **Imports**: Grouped by `StdExternalCrate`, with module granularity and automatic reordering of imports, modules, and impl items.
- **Modularity**: Code is split into focused crates (e.g., separating UI code in `chat_ui` from core messaging logic in `chat`). When contributing, ensure your code respects these boundaries.
- **Contributing**: Contributions are made via Pull Requests on the `lumehq/coop` GitHub repository. Ensure all tests pass before submitting.
- **UI Architecture**: Because Coop uses GPUI, UI components are built using GPUI's element tree structure, event handling, and view contexts.

View File

@@ -1,36 +0,0 @@
[package]
name = "coop_mobile"
version.workspace = true
edition.workspace = true
publish.workspace = true
[dependencies]
assets = { path = "../assets" }
ui = { path = "../ui" }
theme = { path = "../theme" }
common = { path = "../common" }
state = { path = "../state" }
device = { path = "../device" }
chat = { path = "../chat" }
settings = { path = "../settings" }
person = { path = "../person" }
relay_auth = { path = "../relay_auth" }
gpui.workspace = true
gpui_platform.workspace = true
gpui_tokio.workspace = true
gpui-mobile = { git = "https://github.com/itsbalamurali/gpui-mobile" }
nostr-connect.workspace = true
nostr-sdk.workspace = true
anyhow.workspace = true
serde.workspace = true
serde_json.workspace = true
itertools.workspace = true
log.workspace = true
smallvec.workspace = true
smol.workspace = true
futures.workspace = true
oneshot.workspace = true
tracing-subscriber.workspace = true

View File

@@ -15,7 +15,7 @@ description = "Chat Freely, Stay Private on Nostr"
identifier = "su.reya.coop"
category = "SocialNetworking"
version = "1.0.0-beta3"
out-dir = "../../dist"
out-dir = "../dist"
before-packaging-command = "cargo build --release"
resources = ["Cargo.toml", "src"]
icons = [
@@ -27,19 +27,19 @@ icons = [
]
[dependencies]
assets = { path = "../assets" }
ui = { path = "../ui" }
title_bar = { path = "../title_bar" }
theme = { path = "../theme" }
common = { path = "../common" }
state = { path = "../state" }
device = { path = "../device" }
chat = { path = "../chat" }
chat_ui = { path = "../chat_ui" }
settings = { path = "../settings" }
auto_update = { path = "../auto_update" }
person = { path = "../person" }
relay_auth = { path = "../relay_auth" }
assets = { path = "../crates/assets" }
ui = { path = "../crates/ui" }
title_bar = { path = "../crates/title_bar" }
theme = { path = "../crates/theme" }
common = { path = "../crates/common" }
state = { path = "../crates/state" }
device = { path = "../crates/device" }
chat = { path = "../crates/chat" }
chat_ui = { path = "../crates/chat_ui" }
settings = { path = "../crates/settings" }
auto_update = { path = "../crates/auto_update" }
person = { path = "../crates/person" }
relay_auth = { path = "../crates/relay_auth" }
gpui.workspace = true
gpui_platform.workspace = true

View File

Before

Width:  |  Height:  |  Size: 8.4 KiB

After

Width:  |  Height:  |  Size: 8.4 KiB

View File

Before

Width:  |  Height:  |  Size: 22 KiB

After

Width:  |  Height:  |  Size: 22 KiB

View File

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.6 KiB

View File

@@ -50,7 +50,7 @@
},
{
"type": "dir",
"path": "./crates/coop/resources"
"path": "./desktop/resources"
}
]
}

View File

Before

Width:  |  Height:  |  Size: 30 KiB

After

Width:  |  Height:  |  Size: 30 KiB

View File

Before

Width:  |  Height:  |  Size: 70 KiB

After

Width:  |  Height:  |  Size: 70 KiB

View File

Before

Width:  |  Height:  |  Size: 120 KiB

After

Width:  |  Height:  |  Size: 120 KiB

51
mobile/Cargo.toml Normal file
View File

@@ -0,0 +1,51 @@
[package]
name = "coop_mobile"
version.workspace = true
edition.workspace = true
publish.workspace = true
[lib]
name = "coop_mobile"
crate-type = ["cdylib", "staticlib", "lib"]
path = "src/lib.rs"
[[bin]]
name = "coop_mobile"
path = "src/main.rs"
[dependencies]
assets = { path = "../crates/assets" }
ui = { path = "../crates/ui" }
theme = { path = "../crates/theme" }
common = { path = "../crates/common" }
state = { path = "../crates/state" }
device = { path = "../crates/device" }
chat = { path = "../crates/chat" }
settings = { path = "../crates/settings" }
person = { path = "../crates/person" }
relay_auth = { path = "../crates/relay_auth" }
gpui.workspace = true
gpui_platform.workspace = true
gpui_tokio.workspace = true
gpui-mobile = { git = "https://github.com/itsbalamurali/gpui-mobile" }
nostr-connect.workspace = true
nostr-sdk.workspace = true
anyhow.workspace = true
serde.workspace = true
serde_json.workspace = true
log.workspace = true
smallvec.workspace = true
smol.workspace = true
futures.workspace = true
oneshot.workspace = true
tracing-subscriber.workspace = true
[target.'cfg(target_os = "ios")'.dependencies]
objc2 = "0.6"
[target.'cfg(target_os = "android")'.dependencies]
android_logger = "0.15"
android-activity = { version = "0.6", features = ["native-activity"] }

View File

@@ -98,9 +98,9 @@ cp $(find_libs) "${coop_dir}/lib"
# Icons
mkdir -p "${coop_dir}/share/icons/hicolor/512x512/apps"
cp "crates/coop/resources/icon.png" "${coop_dir}/share/icons/hicolor/512x512/apps/coop.png"
cp "desktop/resources/icon.png" "${coop_dir}/share/icons/hicolor/512x512/apps/coop.png"
mkdir -p "${coop_dir}/share/icons/hicolor/1024x1024/apps"
cp "crates/coop/resources/icon@2x.png" "${coop_dir}/share/icons/hicolor/1024x1024/apps/coop.png"
cp "desktop/resources/icon@2x.png" "${coop_dir}/share/icons/hicolor/1024x1024/apps/coop.png"
# .desktop
export DO_STARTUP_NOTIFY="true"
@@ -110,7 +110,7 @@ export APP_ARGS="%U"
export APP_NAME="Coop"
mkdir -p "${coop_dir}/share/applications"
envsubst < "crates/coop/resources/coop.desktop.in" > "${coop_dir}/share/applications/coop.desktop"
envsubst < "desktop/resources/coop.desktop.in" > "${coop_dir}/share/applications/coop.desktop"
# Create archive out of everything that's in the temp directory
arch=$(uname -m)

View File

@@ -21,11 +21,11 @@ export DO_STARTUP_NOTIFY="true"
export APP_NAME="Coop"
export APP_ICON="\${SNAP}/meta/gui/coop.png"
export APP_ARGS="%U"
envsubst < "crates/coop/resources/coop.desktop.in" > "snap/gui/coop.desktop"
cp "crates/coop/resources/icon.png" "snap/gui/coop.png"
envsubst < "desktop/resources/coop.desktop.in" > "snap/gui/coop.desktop"
cp "desktop/resources/icon.png" "snap/gui/coop.png"
# Generate snapcraft.yaml with version and architecture
RELEASE_VERSION="$1" ARCH_SUFFIX="$ARCH_SUFFIX" envsubst < crates/coop/resources/snap/snapcraft.yaml.in > snap/snapcraft.yaml
RELEASE_VERSION="$1" ARCH_SUFFIX="$ARCH_SUFFIX" envsubst < desktop/resources/snap/snapcraft.yaml.in > snap/snapcraft.yaml
# Clean previous builds
snapcraft clean

View File

@@ -24,7 +24,7 @@ export ICON_FILE="icon"
export CHANNEL="stable"
# Generate manifest
envsubst < "crates/coop/resources/flatpak/manifest-template.json" > "$APP_ID.json"
envsubst < "desktop/resources/flatpak/manifest-template.json" > "$APP_ID.json"
# Build Flatpak
flatpak-builder --user --install --force-clean build "$APP_ID.json"

View File

@@ -93,7 +93,7 @@ echo " Created flathub/release-info.xml"
# Step 4: Generate the metainfo file with release info
echo "[4/5] Generating metainfo.xml..."
export APP_ID APP_NAME BRANDING_LIGHT BRANDING_DARK
cat crates/coop/resources/flatpak/coop.metainfo.xml.in | \
cat desktop/resources/flatpak/coop.metainfo.xml.in | \
sed -e "/@release_info@/r flathub/release-info.xml" -e '/@release_info@/d' \
> flathub/${APP_ID}.metainfo.xml
echo " Created flathub/${APP_ID}.metainfo.xml"
@@ -153,8 +153,8 @@ modules:
- install -Dm755 target/release/coop /app/bin/coop
# Install icons
- install -Dm644 crates/coop/resources/icon.png /app/share/icons/hicolor/512x512/apps/su.reya.coop.png
- install -Dm644 crates/coop/resources/icon@2x.png /app/share/icons/hicolor/1024x1024/apps/su.reya.coop.png
- install -Dm644 desktop/resources/icon.png /app/share/icons/hicolor/512x512/apps/su.reya.coop.png
- install -Dm644 desktop/resources/icon@2x.png /app/share/icons/hicolor/1024x1024/apps/su.reya.coop.png
# Install desktop file
- |
@@ -164,7 +164,7 @@ modules:
export APP_CLI="coop"
export APP_ARGS="%U"
export DO_STARTUP_NOTIFY="true"
envsubst < crates/coop/resources/coop.desktop.in > coop.desktop
envsubst < desktop/resources/coop.desktop.in > coop.desktop
install -Dm644 coop.desktop /app/share/applications/su.reya.coop.desktop
# Install metainfo (use pre-generated one with release info)

View File

@@ -13,7 +13,7 @@ fi
NEW_VERSION="$1"
WORKSPACE_CARGO="Cargo.toml"
CRATE_CARGO="crates/coop/Cargo.toml"
CRATE_CARGO="desktop/Cargo.toml"
# Check if both Cargo.toml files exist
if [ ! -f "$WORKSPACE_CARGO" ]; then

View File

@@ -5,16 +5,16 @@ edition.workspace = true
publish.workspace = true
[dependencies]
assets = { path = "../assets" }
ui = { path = "../ui" }
theme = { path = "../theme" }
common = { path = "../common" }
state = { path = "../state" }
device = { path = "../device" }
chat = { path = "../chat" }
settings = { path = "../settings" }
person = { path = "../person" }
relay_auth = { path = "../relay_auth" }
assets = { path = "../crates/assets" }
ui = { path = "../crates/ui" }
theme = { path = "../crates/theme" }
common = { path = "../crates/common" }
state = { path = "../crates/state" }
device = { path = "../crates/device" }
chat = { path = "../crates/chat" }
settings = { path = "../crates/settings" }
person = { path = "../crates/person" }
relay_auth = { path = "../crates/relay_auth" }
gpui.workspace = true
gpui_platform.workspace = true