feat: add support for multi-themes (#210)
* chore: update deps * wip * add themes * add matrix theme * add flexoki and spaceduck themes * . * simple theme change function * . * respect shadow and radius settings * add rose pine themes * toggle theme
This commit is contained in:
167
Cargo.lock
generated
167
Cargo.lock
generated
@@ -206,7 +206,7 @@ dependencies = [
|
|||||||
"url",
|
"url",
|
||||||
"wayland-backend",
|
"wayland-backend",
|
||||||
"wayland-client",
|
"wayland-client",
|
||||||
"wayland-protocols 0.32.9",
|
"wayland-protocols",
|
||||||
"zbus",
|
"zbus",
|
||||||
]
|
]
|
||||||
|
|
||||||
@@ -346,9 +346,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "async-lock"
|
name = "async-lock"
|
||||||
version = "3.4.1"
|
version = "3.4.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5fd03604047cee9b6ce9de9f70c6cd540a0520c813cbd49bae61f33ab80ed1dc"
|
checksum = "290f7f2596bd5b78a9fec8088ccd89180d7f9f55b94b0576823bbbdc72ee8311"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"event-listener 5.4.1",
|
"event-listener 5.4.1",
|
||||||
"event-listener-strategy",
|
"event-listener-strategy",
|
||||||
@@ -963,9 +963,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cc"
|
name = "cc"
|
||||||
version = "1.2.49"
|
version = "1.2.50"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "90583009037521a116abf44494efecd645ba48b6622457080f080b85544e2215"
|
checksum = "9f50d563227a1c37cc0a263f64eca3334388c01c5e4c4861a9def205c614383c"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"find-msvc-tools",
|
"find-msvc-tools",
|
||||||
"jobserver",
|
"jobserver",
|
||||||
@@ -1130,9 +1130,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cmake"
|
name = "cmake"
|
||||||
version = "0.1.56"
|
version = "0.1.57"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b042e5d8a74ae91bb0961acd039822472ec99f8ab0948cbf6d1369588f8be586"
|
checksum = "75443c44cd6b379beb8c5b45d85d0773baf31cce901fe7bb252f4eff3008ef7d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cc",
|
"cc",
|
||||||
]
|
]
|
||||||
@@ -1211,7 +1211,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collections"
|
name = "collections"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"rustc-hash 2.1.1",
|
"rustc-hash 2.1.1",
|
||||||
@@ -1643,7 +1643,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "derive_refineable"
|
name = "derive_refineable"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
@@ -1816,7 +1816,7 @@ dependencies = [
|
|||||||
"cc",
|
"cc",
|
||||||
"memchr",
|
"memchr",
|
||||||
"rustc_version",
|
"rustc_version",
|
||||||
"toml 0.9.8",
|
"toml 0.9.10+spec-1.1.0",
|
||||||
"vswhom",
|
"vswhom",
|
||||||
"winreg",
|
"winreg",
|
||||||
]
|
]
|
||||||
@@ -2101,9 +2101,9 @@ checksum = "3a3076410a55c90011c298b04d0cfa770b00fa04e1e3c97d3f6c9de105a03844"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "flatbuffers"
|
name = "flatbuffers"
|
||||||
version = "25.9.23"
|
version = "25.12.19"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "09b6620799e7340ebd9968d2e0708eb82cf1971e9a16821e2091b6d6e475eed5"
|
checksum = "35f6839d7b3b98adde531effaf34f0c2badc6f4735d26fe74709d8e513a96ef3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 2.10.0",
|
"bitflags 2.10.0",
|
||||||
"rustc_version",
|
"rustc_version",
|
||||||
@@ -2583,7 +2583,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gpui"
|
name = "gpui"
|
||||||
version = "0.2.2"
|
version = "0.2.2"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"as-raw-xcb-connection",
|
"as-raw-xcb-connection",
|
||||||
@@ -2665,7 +2665,7 @@ dependencies = [
|
|||||||
"wayland-backend",
|
"wayland-backend",
|
||||||
"wayland-client",
|
"wayland-client",
|
||||||
"wayland-cursor",
|
"wayland-cursor",
|
||||||
"wayland-protocols 0.31.2",
|
"wayland-protocols",
|
||||||
"wayland-protocols-plasma",
|
"wayland-protocols-plasma",
|
||||||
"wayland-protocols-wlr",
|
"wayland-protocols-wlr",
|
||||||
"windows 0.61.3",
|
"windows 0.61.3",
|
||||||
@@ -2683,7 +2683,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gpui_macros"
|
name = "gpui_macros"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"heck 0.5.0",
|
"heck 0.5.0",
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
@@ -2694,7 +2694,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gpui_tokio"
|
name = "gpui_tokio"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"gpui",
|
"gpui",
|
||||||
@@ -2916,7 +2916,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "http_client"
|
name = "http_client"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-compression",
|
"async-compression",
|
||||||
@@ -2941,7 +2941,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "http_client_tls"
|
name = "http_client_tls"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"rustls",
|
"rustls",
|
||||||
"rustls-platform-verifier",
|
"rustls-platform-verifier",
|
||||||
@@ -3365,9 +3365,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "itoa"
|
name = "itoa"
|
||||||
version = "1.0.15"
|
version = "1.0.16"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "4a5f13b858c8d314ee3e8f639011f7ccefe71f97f96e50151fb991f267928e2c"
|
checksum = "7ee5b5339afb4c41626dde77b7a611bd4f2c202b897852b4bcf5d03eddc61010"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "jni"
|
name = "jni"
|
||||||
@@ -3734,7 +3734,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "media"
|
name = "media"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bindgen",
|
"bindgen",
|
||||||
@@ -3984,7 +3984,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr"
|
name = "nostr"
|
||||||
version = "0.44.1"
|
version = "0.44.1"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"aes",
|
"aes",
|
||||||
"base64",
|
"base64",
|
||||||
@@ -3997,7 +3997,7 @@ dependencies = [
|
|||||||
"hex",
|
"hex",
|
||||||
"instant",
|
"instant",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"rand 0.8.5",
|
"rand 0.9.2",
|
||||||
"scrypt",
|
"scrypt",
|
||||||
"secp256k1",
|
"secp256k1",
|
||||||
"serde",
|
"serde",
|
||||||
@@ -4009,7 +4009,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr-connect"
|
name = "nostr-connect"
|
||||||
version = "0.44.0"
|
version = "0.44.0"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-utility",
|
"async-utility",
|
||||||
"nostr",
|
"nostr",
|
||||||
@@ -4021,7 +4021,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr-database"
|
name = "nostr-database"
|
||||||
version = "0.44.0"
|
version = "0.44.0"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"btreecap",
|
"btreecap",
|
||||||
"flatbuffers",
|
"flatbuffers",
|
||||||
@@ -4033,7 +4033,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr-gossip"
|
name = "nostr-gossip"
|
||||||
version = "0.44.0"
|
version = "0.44.0"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"nostr",
|
"nostr",
|
||||||
]
|
]
|
||||||
@@ -4041,7 +4041,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr-lmdb"
|
name = "nostr-lmdb"
|
||||||
version = "0.44.0"
|
version = "0.44.0"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-utility",
|
"async-utility",
|
||||||
"flume",
|
"flume",
|
||||||
@@ -4055,7 +4055,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr-relay-pool"
|
name = "nostr-relay-pool"
|
||||||
version = "0.44.0"
|
version = "0.44.0"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-utility",
|
"async-utility",
|
||||||
"async-wsocket",
|
"async-wsocket",
|
||||||
@@ -4072,7 +4072,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "nostr-sdk"
|
name = "nostr-sdk"
|
||||||
version = "0.44.1"
|
version = "0.44.1"
|
||||||
source = "git+https://github.com/rust-nostr/nostr#577390dd1ffd7bc1fc577a96b9334b7894212dea"
|
source = "git+https://github.com/rust-nostr/nostr#e09c9d82a1778683d2a6b968d09eb2c619883bf3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-utility",
|
"async-utility",
|
||||||
"nostr",
|
"nostr",
|
||||||
@@ -4085,9 +4085,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ntapi"
|
name = "ntapi"
|
||||||
version = "0.4.1"
|
version = "0.4.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "e8a3895c6391c39d7fe7ebc444a87eb2991b2a0bc718fdabd071eec617fc68e4"
|
checksum = "c70f219e21142367c70c0b30c6a9e3a14d55b4d12a204d897fbec83a0363f081"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"winapi",
|
"winapi",
|
||||||
]
|
]
|
||||||
@@ -4589,7 +4589,7 @@ checksum = "9b4f627cb1b25917193a259e49bdad08f671f8d9708acfd5fe0a8c1455d87220"
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "perf"
|
name = "perf"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"collections",
|
"collections",
|
||||||
"serde",
|
"serde",
|
||||||
@@ -4816,7 +4816,7 @@ version = "3.4.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "219cb19e96be00ab2e37d6e299658a0cfa83e52429179969b0f0121b4ac46983"
|
checksum = "219cb19e96be00ab2e37d6e299658a0cfa83e52429179969b0f0121b4ac46983"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"toml_edit 0.23.9",
|
"toml_edit 0.23.10+spec-1.0.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@@ -5061,9 +5061,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rangemap"
|
name = "rangemap"
|
||||||
version = "1.7.0"
|
version = "1.7.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "acbbbbea733ec66275512d0b9694f34102e7d5406fdbe2ad8d21b28dce92887c"
|
checksum = "973443cf09a9c8656b574a866ab68dfa19f0867d0340648c7d2f6a71b8a8ea68"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rav1e"
|
name = "rav1e"
|
||||||
@@ -5224,7 +5224,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "refineable"
|
name = "refineable"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"derive_refineable",
|
"derive_refineable",
|
||||||
]
|
]
|
||||||
@@ -5277,9 +5277,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "reqwest"
|
name = "reqwest"
|
||||||
version = "0.12.26"
|
version = "0.12.28"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3b4c14b2d9afca6a60277086b0cc6a6ae0b568f6f7916c943a8cdc79f8be240f"
|
checksum = "eddd3ca559203180a307f12d114c268abf583f59b03cb906fd0b3ff8646c1147"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"base64",
|
"base64",
|
||||||
"bytes",
|
"bytes",
|
||||||
@@ -5322,7 +5322,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "reqwest_client"
|
name = "reqwest_client"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bytes",
|
"bytes",
|
||||||
@@ -5376,7 +5376,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "rope"
|
name = "rope"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"arrayvec",
|
"arrayvec",
|
||||||
"log",
|
"log",
|
||||||
@@ -5579,9 +5579,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustls-pki-types"
|
name = "rustls-pki-types"
|
||||||
version = "1.13.1"
|
version = "1.13.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "708c0f9d5f54ba0272468c1d306a52c495b31fa155e91bc25371e6df7996908c"
|
checksum = "21e6f2ab2928ca4291b86736a8bd920a277a399bba1589409d72154ff87c1282"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"web-time",
|
"web-time",
|
||||||
"zeroize",
|
"zeroize",
|
||||||
@@ -5669,9 +5669,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ryu"
|
name = "ryu"
|
||||||
version = "1.0.20"
|
version = "1.0.21"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "28d3b2b1366ec20994f1fd18c3c594f05c5dd4bc44d8bb0c1c632c8d6829481f"
|
checksum = "62049b2877bf12821e8f9ad256ee38fdc31db7387ec2d3b3f403024de2034aea"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "salsa20"
|
name = "salsa20"
|
||||||
@@ -5902,9 +5902,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "serde_json"
|
name = "serde_json"
|
||||||
version = "1.0.145"
|
version = "1.0.146"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "402a6f66d8c709116cf22f558eab210f5a50187f702eb4d7e5ef38d9a7f1c79c"
|
checksum = "217ca874ae0207aac254aa02c957ded05585a90892cc8d87f9e5fa49669dadd8"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"itoa",
|
"itoa",
|
||||||
@@ -5949,9 +5949,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "serde_spanned"
|
name = "serde_spanned"
|
||||||
version = "1.0.3"
|
version = "1.0.4"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "e24345aa0fe688594e73770a5f6d1b216508b4f93484c0026d521acd30134392"
|
checksum = "f8bbf91e5a4d6315eee45e704372590b30e260ee83af6639d64557f51b067776"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"serde_core",
|
"serde_core",
|
||||||
]
|
]
|
||||||
@@ -6293,7 +6293,7 @@ checksum = "13c2bddecc57b384dee18652358fb23172facb8a2c51ccc10d74c157bdea3292"
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "sum_tree"
|
name = "sum_tree"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"arrayvec",
|
"arrayvec",
|
||||||
"log",
|
"log",
|
||||||
@@ -6572,6 +6572,11 @@ dependencies = [
|
|||||||
"anyhow",
|
"anyhow",
|
||||||
"gpui",
|
"gpui",
|
||||||
"log",
|
"log",
|
||||||
|
"schemars",
|
||||||
|
"serde",
|
||||||
|
"serde_json",
|
||||||
|
"smallvec",
|
||||||
|
"tempfile",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@@ -6817,14 +6822,14 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml"
|
name = "toml"
|
||||||
version = "0.9.8"
|
version = "0.9.10+spec-1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f0dc8b1fb61449e27716ec0e1bdf0f6b8f3e8f6b05391e8497b8b6d7804ea6d8"
|
checksum = "0825052159284a1a8b4d6c0c86cbc801f2da5afd2b225fa548c72f2e74002f48"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"serde_core",
|
"serde_core",
|
||||||
"serde_spanned 1.0.3",
|
"serde_spanned 1.0.4",
|
||||||
"toml_datetime 0.7.3",
|
"toml_datetime 0.7.5+spec-1.1.0",
|
||||||
"toml_parser",
|
"toml_parser",
|
||||||
"toml_writer",
|
"toml_writer",
|
||||||
"winnow",
|
"winnow",
|
||||||
@@ -6841,9 +6846,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml_datetime"
|
name = "toml_datetime"
|
||||||
version = "0.7.3"
|
version = "0.7.5+spec-1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f2cdb639ebbc97961c51720f858597f7f24c4fc295327923af55b74c3c724533"
|
checksum = "92e1cfed4a3038bc5a127e35a2d360f145e1f4b971b551a2ba5fd7aedf7e1347"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"serde_core",
|
"serde_core",
|
||||||
]
|
]
|
||||||
@@ -6864,21 +6869,21 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml_edit"
|
name = "toml_edit"
|
||||||
version = "0.23.9"
|
version = "0.23.10+spec-1.0.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5d7cbc3b4b49633d57a0509303158ca50de80ae32c265093b24c414705807832"
|
checksum = "84c8b9f757e028cee9fa244aea147aab2a9ec09d5325a9b01e0a49730c2b5269"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"toml_datetime 0.7.3",
|
"toml_datetime 0.7.5+spec-1.1.0",
|
||||||
"toml_parser",
|
"toml_parser",
|
||||||
"winnow",
|
"winnow",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml_parser"
|
name = "toml_parser"
|
||||||
version = "1.0.4"
|
version = "1.0.6+spec-1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "c0cbe268d35bdb4bb5a56a2de88d0ad0eb70af5384a99d648cd4b3d04039800e"
|
checksum = "a3198b4b0a8e11f09dd03e133c0280504d0801269e9afa46362ffde1cbeebf44"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"winnow",
|
"winnow",
|
||||||
]
|
]
|
||||||
@@ -6891,9 +6896,9 @@ checksum = "5d99f8c9a7727884afe522e9bd5edbfc91a3312b36a77b5fb8926e4c31a41801"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml_writer"
|
name = "toml_writer"
|
||||||
version = "1.0.4"
|
version = "1.0.6+spec-1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "df8b2b54733674ad286d16267dcfc7a71ed5c776e4ac7aa3c3e2561f7c637bf2"
|
checksum = "ab16f14aed21ee8bfd8ec22513f7287cd4a91aa92e44edfe2c17ddd004e92607"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tower"
|
name = "tower"
|
||||||
@@ -6942,9 +6947,9 @@ checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tracing"
|
name = "tracing"
|
||||||
version = "0.1.43"
|
version = "0.1.44"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "2d15d90a0b5c19378952d479dc858407149d7bb45a14de0142f6c534b16fc647"
|
checksum = "63e71662fa4b2a2c3a26f570f037eb95bb1f85397f3cd8076caed2f026a6d100"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"log",
|
"log",
|
||||||
"pin-project-lite",
|
"pin-project-lite",
|
||||||
@@ -6965,9 +6970,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tracing-core"
|
name = "tracing-core"
|
||||||
version = "0.1.35"
|
version = "0.1.36"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7a04e24fab5c89c6a36eb8558c9656f30d81de51dfa4d3b45f26b21d61fa0a6c"
|
checksum = "db97caf9d906fbde555dd62fa95ddba9eecfd14cb388e4f491a66d74cd5fb79a"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"valuable",
|
"valuable",
|
||||||
@@ -7264,7 +7269,7 @@ checksum = "b6c140620e7ffbb22c2dee59cafe6084a59b5ffc27a8859a5f0d494b5d52b6be"
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "util"
|
name = "util"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-fs",
|
"async-fs",
|
||||||
@@ -7300,7 +7305,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "util_macros"
|
name = "util_macros"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"perf",
|
"perf",
|
||||||
"quote",
|
"quote",
|
||||||
@@ -7559,18 +7564,6 @@ dependencies = [
|
|||||||
"xcursor",
|
"xcursor",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "wayland-protocols"
|
|
||||||
version = "0.31.2"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "8f81f365b8b4a97f422ac0e8737c438024b5951734506b0e1d775c73030561f4"
|
|
||||||
dependencies = [
|
|
||||||
"bitflags 2.10.0",
|
|
||||||
"wayland-backend",
|
|
||||||
"wayland-client",
|
|
||||||
"wayland-scanner",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wayland-protocols"
|
name = "wayland-protocols"
|
||||||
version = "0.32.9"
|
version = "0.32.9"
|
||||||
@@ -7585,14 +7578,14 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wayland-protocols-plasma"
|
name = "wayland-protocols-plasma"
|
||||||
version = "0.2.0"
|
version = "0.3.9"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "23803551115ff9ea9bce586860c5c5a971e360825a0309264102a9495a5ff479"
|
checksum = "a07a14257c077ab3279987c4f8bb987851bf57081b93710381daea94f2c2c032"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 2.10.0",
|
"bitflags 2.10.0",
|
||||||
"wayland-backend",
|
"wayland-backend",
|
||||||
"wayland-client",
|
"wayland-client",
|
||||||
"wayland-protocols 0.31.2",
|
"wayland-protocols",
|
||||||
"wayland-scanner",
|
"wayland-scanner",
|
||||||
]
|
]
|
||||||
|
|
||||||
@@ -7605,7 +7598,7 @@ dependencies = [
|
|||||||
"bitflags 2.10.0",
|
"bitflags 2.10.0",
|
||||||
"wayland-backend",
|
"wayland-backend",
|
||||||
"wayland-client",
|
"wayland-client",
|
||||||
"wayland-protocols 0.32.9",
|
"wayland-protocols",
|
||||||
"wayland-scanner",
|
"wayland-scanner",
|
||||||
]
|
]
|
||||||
|
|
||||||
@@ -8787,7 +8780,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "zlog"
|
name = "zlog"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"chrono",
|
"chrono",
|
||||||
@@ -8798,7 +8791,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "ztracing"
|
name = "ztracing"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"tracing",
|
"tracing",
|
||||||
"tracing-subscriber",
|
"tracing-subscriber",
|
||||||
@@ -8809,7 +8802,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "ztracing_macro"
|
name = "ztracing_macro"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/zed-industries/zed#975a76bbf09e2b3b0207c2d02947851591500c2f"
|
source = "git+https://github.com/zed-industries/zed#acee48bfda7b71e1347129bddccfcca85d40b4c7"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "zune-core"
|
name = "zune-core"
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ rust-embed = "8.5.0"
|
|||||||
rust-i18n = "3"
|
rust-i18n = "3"
|
||||||
serde = { version = "1.0", features = ["derive"] }
|
serde = { version = "1.0", features = ["derive"] }
|
||||||
serde_json = "1.0"
|
serde_json = "1.0"
|
||||||
|
schemars = "1"
|
||||||
smallvec = "1.14.0"
|
smallvec = "1.14.0"
|
||||||
smol = "2"
|
smol = "2"
|
||||||
tracing = "0.1.40"
|
tracing = "0.1.40"
|
||||||
|
|||||||
136
assets/themes/catppuccin-frappe.json
Normal file
136
assets/themes/catppuccin-frappe.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "catppuccin-frappe",
|
||||||
|
"name": "Catppuccin Frappé",
|
||||||
|
"author": "Catppuccin",
|
||||||
|
"url": "https://github.com/catppuccin/catppuccin",
|
||||||
|
"light": {
|
||||||
|
"background": "#303446",
|
||||||
|
"surface_background": "#292c3c",
|
||||||
|
"elevated_surface_background": "#232634",
|
||||||
|
"panel_background": "#303446",
|
||||||
|
"overlay": "#c6d0f51a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#303446",
|
||||||
|
"window_border": "#626880",
|
||||||
|
"border": "#626880",
|
||||||
|
"border_variant": "#51576d",
|
||||||
|
"border_focused": "#8caaee",
|
||||||
|
"border_selected": "#8caaee",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#414559",
|
||||||
|
"ring": "#8caaee",
|
||||||
|
"text": "#c6d0f5",
|
||||||
|
"text_muted": "#b5bfe2",
|
||||||
|
"text_placeholder": "#a5adce",
|
||||||
|
"text_accent": "#8caaee",
|
||||||
|
"icon": "#c6d0f5",
|
||||||
|
"icon_muted": "#b5bfe2",
|
||||||
|
"icon_accent": "#8caaee",
|
||||||
|
"element_foreground": "#303446",
|
||||||
|
"element_background": "#8caaee",
|
||||||
|
"element_hover": "#8caaeee6",
|
||||||
|
"element_active": "#7e99d6",
|
||||||
|
"element_selected": "#7088be",
|
||||||
|
"element_disabled": "#8caaee4d",
|
||||||
|
"secondary_foreground": "#8caaee",
|
||||||
|
"secondary_background": "#414559",
|
||||||
|
"secondary_hover": "#8caaee1a",
|
||||||
|
"secondary_active": "#51576d",
|
||||||
|
"secondary_selected": "#51576d",
|
||||||
|
"secondary_disabled": "#8caaee4d",
|
||||||
|
"danger_foreground": "#303446",
|
||||||
|
"danger_background": "#e78284",
|
||||||
|
"danger_hover": "#e78284e6",
|
||||||
|
"danger_active": "#d07576",
|
||||||
|
"danger_selected": "#b96869",
|
||||||
|
"danger_disabled": "#e782844d",
|
||||||
|
"warning_foreground": "#303446",
|
||||||
|
"warning_background": "#e5c890",
|
||||||
|
"warning_hover": "#e5c890e6",
|
||||||
|
"warning_active": "#ceb481",
|
||||||
|
"warning_selected": "#b7a072",
|
||||||
|
"warning_disabled": "#e5c8904d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#414559",
|
||||||
|
"ghost_element_hover": "#c6d0f51a",
|
||||||
|
"ghost_element_active": "#51576d",
|
||||||
|
"ghost_element_selected": "#51576d",
|
||||||
|
"ghost_element_disabled": "#c6d0f50d",
|
||||||
|
"tab_inactive_background": "#414559",
|
||||||
|
"tab_hover_background": "#51576d",
|
||||||
|
"tab_active_background": "#626880",
|
||||||
|
"scrollbar_thumb_background": "#c6d0f533",
|
||||||
|
"scrollbar_thumb_hover_background": "#c6d0f54d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#51576d",
|
||||||
|
"drop_target_background": "#8caaee1a",
|
||||||
|
"cursor": "#99d1db",
|
||||||
|
"selection": "#99d1db40"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#303446",
|
||||||
|
"surface_background": "#292c3c",
|
||||||
|
"elevated_surface_background": "#232634",
|
||||||
|
"panel_background": "#303446",
|
||||||
|
"overlay": "#c6d0f51a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#303446",
|
||||||
|
"window_border": "#626880",
|
||||||
|
"border": "#626880",
|
||||||
|
"border_variant": "#51576d",
|
||||||
|
"border_focused": "#8caaee",
|
||||||
|
"border_selected": "#8caaee",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#414559",
|
||||||
|
"ring": "#8caaee",
|
||||||
|
"text": "#c6d0f5",
|
||||||
|
"text_muted": "#b5bfe2",
|
||||||
|
"text_placeholder": "#a5adce",
|
||||||
|
"text_accent": "#8caaee",
|
||||||
|
"icon": "#c6d0f5",
|
||||||
|
"icon_muted": "#b5bfe2",
|
||||||
|
"icon_accent": "#8caaee",
|
||||||
|
"element_foreground": "#303446",
|
||||||
|
"element_background": "#8caaee",
|
||||||
|
"element_hover": "#8caaeee6",
|
||||||
|
"element_active": "#7e99d6",
|
||||||
|
"element_selected": "#7088be",
|
||||||
|
"element_disabled": "#8caaee4d",
|
||||||
|
"secondary_foreground": "#8caaee",
|
||||||
|
"secondary_background": "#414559",
|
||||||
|
"secondary_hover": "#8caaee1a",
|
||||||
|
"secondary_active": "#51576d",
|
||||||
|
"secondary_selected": "#51576d",
|
||||||
|
"secondary_disabled": "#8caaee4d",
|
||||||
|
"danger_foreground": "#303446",
|
||||||
|
"danger_background": "#e78284",
|
||||||
|
"danger_hover": "#e78284e6",
|
||||||
|
"danger_active": "#d07576",
|
||||||
|
"danger_selected": "#b96869",
|
||||||
|
"danger_disabled": "#e782844d",
|
||||||
|
"warning_foreground": "#303446",
|
||||||
|
"warning_background": "#e5c890",
|
||||||
|
"warning_hover": "#e5c890e6",
|
||||||
|
"warning_active": "#ceb481",
|
||||||
|
"warning_selected": "#b7a072",
|
||||||
|
"warning_disabled": "#e5c8904d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#414559",
|
||||||
|
"ghost_element_hover": "#c6d0f51a",
|
||||||
|
"ghost_element_active": "#51576d",
|
||||||
|
"ghost_element_selected": "#51576d",
|
||||||
|
"ghost_element_disabled": "#c6d0f50d",
|
||||||
|
"tab_inactive_background": "#414559",
|
||||||
|
"tab_hover_background": "#51576d",
|
||||||
|
"tab_active_background": "#626880",
|
||||||
|
"scrollbar_thumb_background": "#c6d0f533",
|
||||||
|
"scrollbar_thumb_hover_background": "#c6d0f54d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#51576d",
|
||||||
|
"drop_target_background": "#8caaee1a",
|
||||||
|
"cursor": "#99d1db",
|
||||||
|
"selection": "#99d1db40"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/catppuccin-latte.json
Normal file
136
assets/themes/catppuccin-latte.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "catppuccin-latte",
|
||||||
|
"name": "Catppuccin Latte",
|
||||||
|
"author": "Catppuccin",
|
||||||
|
"url": "https://github.com/catppuccin/catppuccin",
|
||||||
|
"light": {
|
||||||
|
"background": "#eff1f5",
|
||||||
|
"surface_background": "#e6e9ef",
|
||||||
|
"elevated_surface_background": "#dce0e8",
|
||||||
|
"panel_background": "#eff1f5",
|
||||||
|
"overlay": "#4c4f691a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#eff1f5",
|
||||||
|
"window_border": "#acb0be",
|
||||||
|
"border": "#acb0be",
|
||||||
|
"border_variant": "#bcc0cc",
|
||||||
|
"border_focused": "#1e66f5",
|
||||||
|
"border_selected": "#1e66f5",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#ccd0da",
|
||||||
|
"ring": "#1e66f5",
|
||||||
|
"text": "#4c4f69",
|
||||||
|
"text_muted": "#5c5f77",
|
||||||
|
"text_placeholder": "#6c6f85",
|
||||||
|
"text_accent": "#1e66f5",
|
||||||
|
"icon": "#4c4f69",
|
||||||
|
"icon_muted": "#5c5f77",
|
||||||
|
"icon_accent": "#1e66f5",
|
||||||
|
"element_foreground": "#eff1f5",
|
||||||
|
"element_background": "#1e66f5",
|
||||||
|
"element_hover": "#1e66f5e6",
|
||||||
|
"element_active": "#1b5cdc",
|
||||||
|
"element_selected": "#1852c3",
|
||||||
|
"element_disabled": "#1e66f54d",
|
||||||
|
"secondary_foreground": "#1e66f5",
|
||||||
|
"secondary_background": "#e6e9ef",
|
||||||
|
"secondary_hover": "#1e66f51a",
|
||||||
|
"secondary_active": "#dce0e8",
|
||||||
|
"secondary_selected": "#dce0e8",
|
||||||
|
"secondary_disabled": "#1e66f54d",
|
||||||
|
"danger_foreground": "#eff1f5",
|
||||||
|
"danger_background": "#d20f39",
|
||||||
|
"danger_hover": "#d20f39e6",
|
||||||
|
"danger_active": "#bc0e33",
|
||||||
|
"danger_selected": "#a60c2d",
|
||||||
|
"danger_disabled": "#d20f394d",
|
||||||
|
"warning_foreground": "#4c4f69",
|
||||||
|
"warning_background": "#df8e1d",
|
||||||
|
"warning_hover": "#df8e1de6",
|
||||||
|
"warning_active": "#c9801a",
|
||||||
|
"warning_selected": "#b47217",
|
||||||
|
"warning_disabled": "#df8e1d4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#e6e9ef",
|
||||||
|
"ghost_element_hover": "#4c4f691a",
|
||||||
|
"ghost_element_active": "#dce0e8",
|
||||||
|
"ghost_element_selected": "#dce0e8",
|
||||||
|
"ghost_element_disabled": "#4c4f690d",
|
||||||
|
"tab_inactive_background": "#e6e9ef",
|
||||||
|
"tab_hover_background": "#dce0e8",
|
||||||
|
"tab_active_background": "#ccd0da",
|
||||||
|
"scrollbar_thumb_background": "#4c4f6933",
|
||||||
|
"scrollbar_thumb_hover_background": "#4c4f694d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#dce0e8",
|
||||||
|
"drop_target_background": "#1e66f51a",
|
||||||
|
"cursor": "#04a5e5",
|
||||||
|
"selection": "#04a5e540"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#eff1f5",
|
||||||
|
"surface_background": "#e6e9ef",
|
||||||
|
"elevated_surface_background": "#dce0e8",
|
||||||
|
"panel_background": "#eff1f5",
|
||||||
|
"overlay": "#4c4f691a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#eff1f5",
|
||||||
|
"window_border": "#acb0be",
|
||||||
|
"border": "#acb0be",
|
||||||
|
"border_variant": "#bcc0cc",
|
||||||
|
"border_focused": "#1e66f5",
|
||||||
|
"border_selected": "#1e66f5",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#ccd0da",
|
||||||
|
"ring": "#1e66f5",
|
||||||
|
"text": "#4c4f69",
|
||||||
|
"text_muted": "#5c5f77",
|
||||||
|
"text_placeholder": "#6c6f85",
|
||||||
|
"text_accent": "#1e66f5",
|
||||||
|
"icon": "#4c4f69",
|
||||||
|
"icon_muted": "#5c5f77",
|
||||||
|
"icon_accent": "#1e66f5",
|
||||||
|
"element_foreground": "#eff1f5",
|
||||||
|
"element_background": "#1e66f5",
|
||||||
|
"element_hover": "#1e66f5e6",
|
||||||
|
"element_active": "#1b5cdc",
|
||||||
|
"element_selected": "#1852c3",
|
||||||
|
"element_disabled": "#1e66f54d",
|
||||||
|
"secondary_foreground": "#1e66f5",
|
||||||
|
"secondary_background": "#e6e9ef",
|
||||||
|
"secondary_hover": "#1e66f51a",
|
||||||
|
"secondary_active": "#dce0e8",
|
||||||
|
"secondary_selected": "#dce0e8",
|
||||||
|
"secondary_disabled": "#1e66f54d",
|
||||||
|
"danger_foreground": "#eff1f5",
|
||||||
|
"danger_background": "#d20f39",
|
||||||
|
"danger_hover": "#d20f39e6",
|
||||||
|
"danger_active": "#bc0e33",
|
||||||
|
"danger_selected": "#a60c2d",
|
||||||
|
"danger_disabled": "#d20f394d",
|
||||||
|
"warning_foreground": "#4c4f69",
|
||||||
|
"warning_background": "#df8e1d",
|
||||||
|
"warning_hover": "#df8e1de6",
|
||||||
|
"warning_active": "#c9801a",
|
||||||
|
"warning_selected": "#b47217",
|
||||||
|
"warning_disabled": "#df8e1d4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#e6e9ef",
|
||||||
|
"ghost_element_hover": "#4c4f691a",
|
||||||
|
"ghost_element_active": "#dce0e8",
|
||||||
|
"ghost_element_selected": "#dce0e8",
|
||||||
|
"ghost_element_disabled": "#4c4f690d",
|
||||||
|
"tab_inactive_background": "#e6e9ef",
|
||||||
|
"tab_hover_background": "#dce0e8",
|
||||||
|
"tab_active_background": "#ccd0da",
|
||||||
|
"scrollbar_thumb_background": "#4c4f6933",
|
||||||
|
"scrollbar_thumb_hover_background": "#4c4f694d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#dce0e8",
|
||||||
|
"drop_target_background": "#1e66f51a",
|
||||||
|
"cursor": "#04a5e5",
|
||||||
|
"selection": "#04a5e540"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/catppuccin-macchiato.json
Normal file
136
assets/themes/catppuccin-macchiato.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "catppuccin-macchiato",
|
||||||
|
"name": "Catppuccin Macchiato",
|
||||||
|
"author": "Catppuccin",
|
||||||
|
"url": "https://github.com/catppuccin/catppuccin",
|
||||||
|
"light": {
|
||||||
|
"background": "#24273a",
|
||||||
|
"surface_background": "#1e2030",
|
||||||
|
"elevated_surface_background": "#181926",
|
||||||
|
"panel_background": "#24273a",
|
||||||
|
"overlay": "#cad3f51a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#24273a",
|
||||||
|
"window_border": "#5b6078",
|
||||||
|
"border": "#5b6078",
|
||||||
|
"border_variant": "#494d64",
|
||||||
|
"border_focused": "#8aadf4",
|
||||||
|
"border_selected": "#8aadf4",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#363a4f",
|
||||||
|
"ring": "#8aadf4",
|
||||||
|
"text": "#cad3f5",
|
||||||
|
"text_muted": "#b8c0e0",
|
||||||
|
"text_placeholder": "#a5adcb",
|
||||||
|
"text_accent": "#8aadf4",
|
||||||
|
"icon": "#cad3f5",
|
||||||
|
"icon_muted": "#b8c0e0",
|
||||||
|
"icon_accent": "#8aadf4",
|
||||||
|
"element_foreground": "#24273a",
|
||||||
|
"element_background": "#8aadf4",
|
||||||
|
"element_hover": "#8aadf4e6",
|
||||||
|
"element_active": "#7c9cdc",
|
||||||
|
"element_selected": "#6e8bc4",
|
||||||
|
"element_disabled": "#8aadf44d",
|
||||||
|
"secondary_foreground": "#8aadf4",
|
||||||
|
"secondary_background": "#363a4f",
|
||||||
|
"secondary_hover": "#8aadf41a",
|
||||||
|
"secondary_active": "#494d64",
|
||||||
|
"secondary_selected": "#494d64",
|
||||||
|
"secondary_disabled": "#8aadf44d",
|
||||||
|
"danger_foreground": "#24273a",
|
||||||
|
"danger_background": "#ed8796",
|
||||||
|
"danger_hover": "#ed8796e6",
|
||||||
|
"danger_active": "#d57a87",
|
||||||
|
"danger_selected": "#bd6d78",
|
||||||
|
"danger_disabled": "#ed87964d",
|
||||||
|
"warning_foreground": "#24273a",
|
||||||
|
"warning_background": "#eed49f",
|
||||||
|
"warning_hover": "#eed49fe6",
|
||||||
|
"warning_active": "#d6bf8f",
|
||||||
|
"warning_selected": "#beaa7f",
|
||||||
|
"warning_disabled": "#eed49f4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#363a4f",
|
||||||
|
"ghost_element_hover": "#cad3f51a",
|
||||||
|
"ghost_element_active": "#494d64",
|
||||||
|
"ghost_element_selected": "#494d64",
|
||||||
|
"ghost_element_disabled": "#cad3f50d",
|
||||||
|
"tab_inactive_background": "#363a4f",
|
||||||
|
"tab_hover_background": "#494d64",
|
||||||
|
"tab_active_background": "#5b6078",
|
||||||
|
"scrollbar_thumb_background": "#cad3f533",
|
||||||
|
"scrollbar_thumb_hover_background": "#cad3f54d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#494d64",
|
||||||
|
"drop_target_background": "#8aadf41a",
|
||||||
|
"cursor": "#91d7e3",
|
||||||
|
"selection": "#91d7e340"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#24273a",
|
||||||
|
"surface_background": "#1e2030",
|
||||||
|
"elevated_surface_background": "#181926",
|
||||||
|
"panel_background": "#24273a",
|
||||||
|
"overlay": "#cad3f51a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#24273a",
|
||||||
|
"window_border": "#5b6078",
|
||||||
|
"border": "#5b6078",
|
||||||
|
"border_variant": "#494d64",
|
||||||
|
"border_focused": "#8aadf4",
|
||||||
|
"border_selected": "#8aadf4",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#363a4f",
|
||||||
|
"ring": "#8aadf4",
|
||||||
|
"text": "#cad3f5",
|
||||||
|
"text_muted": "#b8c0e0",
|
||||||
|
"text_placeholder": "#a5adcb",
|
||||||
|
"text_accent": "#8aadf4",
|
||||||
|
"icon": "#cad3f5",
|
||||||
|
"icon_muted": "#b8c0e0",
|
||||||
|
"icon_accent": "#8aadf4",
|
||||||
|
"element_foreground": "#24273a",
|
||||||
|
"element_background": "#8aadf4",
|
||||||
|
"element_hover": "#8aadf4e6",
|
||||||
|
"element_active": "#7c9cdc",
|
||||||
|
"element_selected": "#6e8bc4",
|
||||||
|
"element_disabled": "#8aadf44d",
|
||||||
|
"secondary_foreground": "#8aadf4",
|
||||||
|
"secondary_background": "#363a4f",
|
||||||
|
"secondary_hover": "#8aadf41a",
|
||||||
|
"secondary_active": "#494d64",
|
||||||
|
"secondary_selected": "#494d64",
|
||||||
|
"secondary_disabled": "#8aadf44d",
|
||||||
|
"danger_foreground": "#24273a",
|
||||||
|
"danger_background": "#ed8796",
|
||||||
|
"danger_hover": "#ed8796e6",
|
||||||
|
"danger_active": "#d57a87",
|
||||||
|
"danger_selected": "#bd6d78",
|
||||||
|
"danger_disabled": "#ed87964d",
|
||||||
|
"warning_foreground": "#24273a",
|
||||||
|
"warning_background": "#eed49f",
|
||||||
|
"warning_hover": "#eed49fe6",
|
||||||
|
"warning_active": "#d6bf8f",
|
||||||
|
"warning_selected": "#beaa7f",
|
||||||
|
"warning_disabled": "#eed49f4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#363a4f",
|
||||||
|
"ghost_element_hover": "#cad3f51a",
|
||||||
|
"ghost_element_active": "#494d64",
|
||||||
|
"ghost_element_selected": "#494d64",
|
||||||
|
"ghost_element_disabled": "#cad3f50d",
|
||||||
|
"tab_inactive_background": "#363a4f",
|
||||||
|
"tab_hover_background": "#494d64",
|
||||||
|
"tab_active_background": "#5b6078",
|
||||||
|
"scrollbar_thumb_background": "#cad3f533",
|
||||||
|
"scrollbar_thumb_hover_background": "#cad3f54d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#494d64",
|
||||||
|
"drop_target_background": "#8aadf41a",
|
||||||
|
"cursor": "#91d7e3",
|
||||||
|
"selection": "#91d7e340"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/catppuccin-mocha.json
Normal file
136
assets/themes/catppuccin-mocha.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "catppuccin-mocha",
|
||||||
|
"name": "Catppuccin Mocha",
|
||||||
|
"author": "Catppuccin",
|
||||||
|
"url": "https://github.com/catppuccin/catppuccin",
|
||||||
|
"light": {
|
||||||
|
"background": "#1e1e2e",
|
||||||
|
"surface_background": "#181825",
|
||||||
|
"elevated_surface_background": "#11111b",
|
||||||
|
"panel_background": "#1e1e2e",
|
||||||
|
"overlay": "#cdd6f41a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#1e1e2e",
|
||||||
|
"window_border": "#585b70",
|
||||||
|
"border": "#585b70",
|
||||||
|
"border_variant": "#45475a",
|
||||||
|
"border_focused": "#89b4fa",
|
||||||
|
"border_selected": "#89b4fa",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#313244",
|
||||||
|
"ring": "#89b4fa",
|
||||||
|
"text": "#cdd6f4",
|
||||||
|
"text_muted": "#bac2de",
|
||||||
|
"text_placeholder": "#a6adc8",
|
||||||
|
"text_accent": "#89b4fa",
|
||||||
|
"icon": "#cdd6f4",
|
||||||
|
"icon_muted": "#bac2de",
|
||||||
|
"icon_accent": "#89b4fa",
|
||||||
|
"element_foreground": "#1e1e2e",
|
||||||
|
"element_background": "#89b4fa",
|
||||||
|
"element_hover": "#89b4fae6",
|
||||||
|
"element_active": "#7ba2e1",
|
||||||
|
"element_selected": "#6d90c8",
|
||||||
|
"element_disabled": "#89b4fa4d",
|
||||||
|
"secondary_foreground": "#89b4fa",
|
||||||
|
"secondary_background": "#313244",
|
||||||
|
"secondary_hover": "#89b4fa1a",
|
||||||
|
"secondary_active": "#45475a",
|
||||||
|
"secondary_selected": "#45475a",
|
||||||
|
"secondary_disabled": "#89b4fa4d",
|
||||||
|
"danger_foreground": "#1e1e2e",
|
||||||
|
"danger_background": "#f38ba8",
|
||||||
|
"danger_hover": "#f38ba8e6",
|
||||||
|
"danger_active": "#db7d97",
|
||||||
|
"danger_selected": "#c36f86",
|
||||||
|
"danger_disabled": "#f38ba84d",
|
||||||
|
"warning_foreground": "#1e1e2e",
|
||||||
|
"warning_background": "#f9e2af",
|
||||||
|
"warning_hover": "#f9e2afe6",
|
||||||
|
"warning_active": "#e0cb9e",
|
||||||
|
"warning_selected": "#c7b48d",
|
||||||
|
"warning_disabled": "#f9e2af4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#313244",
|
||||||
|
"ghost_element_hover": "#cdd6f41a",
|
||||||
|
"ghost_element_active": "#45475a",
|
||||||
|
"ghost_element_selected": "#45475a",
|
||||||
|
"ghost_element_disabled": "#cdd6f50d",
|
||||||
|
"tab_inactive_background": "#313244",
|
||||||
|
"tab_hover_background": "#45475a",
|
||||||
|
"tab_active_background": "#585b70",
|
||||||
|
"scrollbar_thumb_background": "#cdd6f533",
|
||||||
|
"scrollbar_thumb_hover_background": "#cdd6f54d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#45475a",
|
||||||
|
"drop_target_background": "#89b4fa1a",
|
||||||
|
"cursor": "#89dceb",
|
||||||
|
"selection": "#89dceb40"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#1e1e2e",
|
||||||
|
"surface_background": "#181825",
|
||||||
|
"elevated_surface_background": "#11111b",
|
||||||
|
"panel_background": "#1e1e2e",
|
||||||
|
"overlay": "#cdd6f41a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#1e1e2e",
|
||||||
|
"window_border": "#585b70",
|
||||||
|
"border": "#585b70",
|
||||||
|
"border_variant": "#45475a",
|
||||||
|
"border_focused": "#89b4fa",
|
||||||
|
"border_selected": "#89b4fa",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#313244",
|
||||||
|
"ring": "#89b4fa",
|
||||||
|
"text": "#cdd6f4",
|
||||||
|
"text_muted": "#bac2de",
|
||||||
|
"text_placeholder": "#a6adc8",
|
||||||
|
"text_accent": "#89b4fa",
|
||||||
|
"icon": "#cdd6f4",
|
||||||
|
"icon_muted": "#bac2de",
|
||||||
|
"icon_accent": "#89b4fa",
|
||||||
|
"element_foreground": "#1e1e2e",
|
||||||
|
"element_background": "#89b4fa",
|
||||||
|
"element_hover": "#89b4fae6",
|
||||||
|
"element_active": "#7ba2e1",
|
||||||
|
"element_selected": "#6d90c8",
|
||||||
|
"element_disabled": "#89b4fa4d",
|
||||||
|
"secondary_foreground": "#89b4fa",
|
||||||
|
"secondary_background": "#313244",
|
||||||
|
"secondary_hover": "#89b4fa1a",
|
||||||
|
"secondary_active": "#45475a",
|
||||||
|
"secondary_selected": "#45475a",
|
||||||
|
"secondary_disabled": "#89b4fa4d",
|
||||||
|
"danger_foreground": "#1e1e2e",
|
||||||
|
"danger_background": "#f38ba8",
|
||||||
|
"danger_hover": "#f38ba8e6",
|
||||||
|
"danger_active": "#db7d97",
|
||||||
|
"danger_selected": "#c36f86",
|
||||||
|
"danger_disabled": "#f38ba84d",
|
||||||
|
"warning_foreground": "#1e1e2e",
|
||||||
|
"warning_background": "#f9e2af",
|
||||||
|
"warning_hover": "#f9e2afe6",
|
||||||
|
"warning_active": "#e0cb9e",
|
||||||
|
"warning_selected": "#c7b48d",
|
||||||
|
"warning_disabled": "#f9e2af4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#313244",
|
||||||
|
"ghost_element_hover": "#cdd6f41a",
|
||||||
|
"ghost_element_active": "#45475a",
|
||||||
|
"ghost_element_selected": "#45475a",
|
||||||
|
"ghost_element_disabled": "#cdd6f50d",
|
||||||
|
"tab_inactive_background": "#313244",
|
||||||
|
"tab_hover_background": "#45475a",
|
||||||
|
"tab_active_background": "#585b70",
|
||||||
|
"scrollbar_thumb_background": "#cdd6f533",
|
||||||
|
"scrollbar_thumb_hover_background": "#cdd6f54d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#45475a",
|
||||||
|
"drop_target_background": "#89b4fa1a",
|
||||||
|
"cursor": "#89dceb",
|
||||||
|
"selection": "#89dceb40"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/flexoki.json
Normal file
136
assets/themes/flexoki.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "flexoki",
|
||||||
|
"name": "Flexoki",
|
||||||
|
"author": "Steph Ango",
|
||||||
|
"url": "https://stephango.com/flexoki",
|
||||||
|
"light": {
|
||||||
|
"background": "#FFFCF0",
|
||||||
|
"surface_background": "#F2F0E5",
|
||||||
|
"elevated_surface_background": "#E6E4D9",
|
||||||
|
"panel_background": "#FFFCF0",
|
||||||
|
"overlay": "#100F0F1a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#FFFCF0",
|
||||||
|
"window_border": "#CECDC3",
|
||||||
|
"border": "#CECDC3",
|
||||||
|
"border_variant": "#DAD8CE",
|
||||||
|
"border_focused": "#24837B",
|
||||||
|
"border_selected": "#24837B",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#E6E4D9",
|
||||||
|
"ring": "#24837B",
|
||||||
|
"text": "#100F0F",
|
||||||
|
"text_muted": "#6F6E69",
|
||||||
|
"text_placeholder": "#878580",
|
||||||
|
"text_accent": "#24837B",
|
||||||
|
"icon": "#100F0F",
|
||||||
|
"icon_muted": "#6F6E69",
|
||||||
|
"icon_accent": "#24837B",
|
||||||
|
"element_foreground": "#DDF1E4",
|
||||||
|
"element_background": "#24837B",
|
||||||
|
"element_hover": "#24837Be5",
|
||||||
|
"element_active": "#20756E",
|
||||||
|
"element_selected": "#1C6861",
|
||||||
|
"element_disabled": "#24837B4c",
|
||||||
|
"secondary_foreground": "#24837B",
|
||||||
|
"secondary_background": "#E6E4D9",
|
||||||
|
"secondary_hover": "#24837B1a",
|
||||||
|
"secondary_active": "#DAD8CE",
|
||||||
|
"secondary_selected": "#DAD8CE",
|
||||||
|
"secondary_disabled": "#24837B4c",
|
||||||
|
"danger_foreground": "#FFE1D5",
|
||||||
|
"danger_background": "#AF3029",
|
||||||
|
"danger_hover": "#AF3029e5",
|
||||||
|
"danger_active": "#9E2B25",
|
||||||
|
"danger_selected": "#8D2620",
|
||||||
|
"danger_disabled": "#AF30294c",
|
||||||
|
"warning_foreground": "#FFE7CE",
|
||||||
|
"warning_background": "#BC5215",
|
||||||
|
"warning_hover": "#BC5215e5",
|
||||||
|
"warning_active": "#A94913",
|
||||||
|
"warning_selected": "#964011",
|
||||||
|
"warning_disabled": "#BC52154c",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#E6E4D9",
|
||||||
|
"ghost_element_hover": "#100F0F1a",
|
||||||
|
"ghost_element_active": "#DAD8CE",
|
||||||
|
"ghost_element_selected": "#DAD8CE",
|
||||||
|
"ghost_element_disabled": "#100F0F0d",
|
||||||
|
"tab_inactive_background": "#E6E4D9",
|
||||||
|
"tab_hover_background": "#DAD8CE",
|
||||||
|
"tab_active_background": "#CECDC3",
|
||||||
|
"scrollbar_thumb_background": "#100F0F33",
|
||||||
|
"scrollbar_thumb_hover_background": "#100F0F4d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#DAD8CE",
|
||||||
|
"drop_target_background": "#24837B1a",
|
||||||
|
"cursor": "#205EA6",
|
||||||
|
"selection": "#24837B40"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#100F0F",
|
||||||
|
"surface_background": "#1C1B1A",
|
||||||
|
"elevated_surface_background": "#282726",
|
||||||
|
"panel_background": "#100F0F",
|
||||||
|
"overlay": "#FFFCF01a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#100F0F",
|
||||||
|
"window_border": "#403E3C",
|
||||||
|
"border": "#403E3C",
|
||||||
|
"border_variant": "#343331",
|
||||||
|
"border_focused": "#3AA99F",
|
||||||
|
"border_selected": "#3AA99F",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#282726",
|
||||||
|
"ring": "#3AA99F",
|
||||||
|
"text": "#FFFCF0",
|
||||||
|
"text_muted": "#878580",
|
||||||
|
"text_placeholder": "#575653",
|
||||||
|
"text_accent": "#3AA99F",
|
||||||
|
"icon": "#FFFCF0",
|
||||||
|
"icon_muted": "#878580",
|
||||||
|
"icon_accent": "#3AA99F",
|
||||||
|
"element_foreground": "#101F1D",
|
||||||
|
"element_background": "#3AA99F",
|
||||||
|
"element_hover": "#3AA99Fe5",
|
||||||
|
"element_active": "#34988F",
|
||||||
|
"element_selected": "#2F877F",
|
||||||
|
"element_disabled": "#3AA99F4c",
|
||||||
|
"secondary_foreground": "#3AA99F",
|
||||||
|
"secondary_background": "#282726",
|
||||||
|
"secondary_hover": "#3AA99F1a",
|
||||||
|
"secondary_active": "#343331",
|
||||||
|
"secondary_selected": "#343331",
|
||||||
|
"secondary_disabled": "#3AA99F4c",
|
||||||
|
"danger_foreground": "#261312",
|
||||||
|
"danger_background": "#D14D41",
|
||||||
|
"danger_hover": "#D14D41e5",
|
||||||
|
"danger_active": "#BC453A",
|
||||||
|
"danger_selected": "#A73D33",
|
||||||
|
"danger_disabled": "#D14D414c",
|
||||||
|
"warning_foreground": "#27180E",
|
||||||
|
"warning_background": "#DA702C",
|
||||||
|
"warning_hover": "#DA702Ce5",
|
||||||
|
"warning_active": "#C46527",
|
||||||
|
"warning_selected": "#AF5A22",
|
||||||
|
"warning_disabled": "#DA702C4c",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#282726",
|
||||||
|
"ghost_element_hover": "#FFFCF01a",
|
||||||
|
"ghost_element_active": "#343331",
|
||||||
|
"ghost_element_selected": "#343331",
|
||||||
|
"ghost_element_disabled": "#FFFCF00d",
|
||||||
|
"tab_inactive_background": "#282726",
|
||||||
|
"tab_hover_background": "#343331",
|
||||||
|
"tab_active_background": "#403E3C",
|
||||||
|
"scrollbar_thumb_background": "#FFFCF033",
|
||||||
|
"scrollbar_thumb_hover_background": "#FFFCF04d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#343331",
|
||||||
|
"drop_target_background": "#3AA99F1a",
|
||||||
|
"cursor": "#4385BE",
|
||||||
|
"selection": "#3AA99F40"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/rose-pine-dawn.json
Normal file
136
assets/themes/rose-pine-dawn.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "rose-pine-dawn",
|
||||||
|
"name": "Rosé Pine Dawn",
|
||||||
|
"author": "Rosé Pine",
|
||||||
|
"url": "https://rosepinetheme.com/",
|
||||||
|
"light": {
|
||||||
|
"background": "#faf4ed",
|
||||||
|
"surface_background": "#fffaf3",
|
||||||
|
"elevated_surface_background": "#f2e9e1",
|
||||||
|
"panel_background": "#fffaf3",
|
||||||
|
"overlay": "#5752791a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#faf4ed",
|
||||||
|
"window_border": "#cecacd",
|
||||||
|
"border": "#cecacd",
|
||||||
|
"border_variant": "#dfdad9",
|
||||||
|
"border_focused": "#286983",
|
||||||
|
"border_selected": "#286983",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#f4ede8",
|
||||||
|
"ring": "#286983",
|
||||||
|
"text": "#575279",
|
||||||
|
"text_muted": "#797593",
|
||||||
|
"text_placeholder": "#9893a5",
|
||||||
|
"text_accent": "#907aa9",
|
||||||
|
"icon": "#575279",
|
||||||
|
"icon_muted": "#797593",
|
||||||
|
"icon_accent": "#907aa9",
|
||||||
|
"element_foreground": "#faf4ed",
|
||||||
|
"element_background": "#286983",
|
||||||
|
"element_hover": "#286983e6",
|
||||||
|
"element_active": "#245f76",
|
||||||
|
"element_selected": "#205569",
|
||||||
|
"element_disabled": "#2869834d",
|
||||||
|
"secondary_foreground": "#286983",
|
||||||
|
"secondary_background": "#f4ede8",
|
||||||
|
"secondary_hover": "#2869831a",
|
||||||
|
"secondary_active": "#dfdad9",
|
||||||
|
"secondary_selected": "#dfdad9",
|
||||||
|
"secondary_disabled": "#2869834d",
|
||||||
|
"danger_foreground": "#faf4ed",
|
||||||
|
"danger_background": "#b4637a",
|
||||||
|
"danger_hover": "#b4637ae6",
|
||||||
|
"danger_active": "#a2596e",
|
||||||
|
"danger_selected": "#904f62",
|
||||||
|
"danger_disabled": "#b4637a4d",
|
||||||
|
"warning_foreground": "#faf4ed",
|
||||||
|
"warning_background": "#ea9d34",
|
||||||
|
"warning_hover": "#ea9d34e6",
|
||||||
|
"warning_active": "#d38d2f",
|
||||||
|
"warning_selected": "#bc7d2a",
|
||||||
|
"warning_disabled": "#ea9d344d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#f4ede8",
|
||||||
|
"ghost_element_hover": "#5752791a",
|
||||||
|
"ghost_element_active": "#dfdad9",
|
||||||
|
"ghost_element_selected": "#dfdad9",
|
||||||
|
"ghost_element_disabled": "#5752790d",
|
||||||
|
"tab_inactive_background": "#f4ede8",
|
||||||
|
"tab_hover_background": "#dfdad9",
|
||||||
|
"tab_active_background": "#cecacd",
|
||||||
|
"scrollbar_thumb_background": "#57527933",
|
||||||
|
"scrollbar_thumb_hover_background": "#5752794d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#dfdad9",
|
||||||
|
"drop_target_background": "#2869831a",
|
||||||
|
"cursor": "#56949f",
|
||||||
|
"selection": "#56949f40"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#faf4ed",
|
||||||
|
"surface_background": "#fffaf3",
|
||||||
|
"elevated_surface_background": "#f2e9e1",
|
||||||
|
"panel_background": "#fffaf3",
|
||||||
|
"overlay": "#5752791a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#faf4ed",
|
||||||
|
"window_border": "#cecacd",
|
||||||
|
"border": "#cecacd",
|
||||||
|
"border_variant": "#dfdad9",
|
||||||
|
"border_focused": "#286983",
|
||||||
|
"border_selected": "#286983",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#f4ede8",
|
||||||
|
"ring": "#286983",
|
||||||
|
"text": "#575279",
|
||||||
|
"text_muted": "#797593",
|
||||||
|
"text_placeholder": "#9893a5",
|
||||||
|
"text_accent": "#907aa9",
|
||||||
|
"icon": "#575279",
|
||||||
|
"icon_muted": "#797593",
|
||||||
|
"icon_accent": "#907aa9",
|
||||||
|
"element_foreground": "#faf4ed",
|
||||||
|
"element_background": "#286983",
|
||||||
|
"element_hover": "#286983e6",
|
||||||
|
"element_active": "#245f76",
|
||||||
|
"element_selected": "#205569",
|
||||||
|
"element_disabled": "#2869834d",
|
||||||
|
"secondary_foreground": "#286983",
|
||||||
|
"secondary_background": "#f4ede8",
|
||||||
|
"secondary_hover": "#2869831a",
|
||||||
|
"secondary_active": "#dfdad9",
|
||||||
|
"secondary_selected": "#dfdad9",
|
||||||
|
"secondary_disabled": "#2869834d",
|
||||||
|
"danger_foreground": "#faf4ed",
|
||||||
|
"danger_background": "#b4637a",
|
||||||
|
"danger_hover": "#b4637ae6",
|
||||||
|
"danger_active": "#a2596e",
|
||||||
|
"danger_selected": "#904f62",
|
||||||
|
"danger_disabled": "#b4637a4d",
|
||||||
|
"warning_foreground": "#faf4ed",
|
||||||
|
"warning_background": "#ea9d34",
|
||||||
|
"warning_hover": "#ea9d34e6",
|
||||||
|
"warning_active": "#d38d2f",
|
||||||
|
"warning_selected": "#bc7d2a",
|
||||||
|
"warning_disabled": "#ea9d344d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#f4ede8",
|
||||||
|
"ghost_element_hover": "#5752791a",
|
||||||
|
"ghost_element_active": "#dfdad9",
|
||||||
|
"ghost_element_selected": "#dfdad9",
|
||||||
|
"ghost_element_disabled": "#5752790d",
|
||||||
|
"tab_inactive_background": "#f4ede8",
|
||||||
|
"tab_hover_background": "#dfdad9",
|
||||||
|
"tab_active_background": "#cecacd",
|
||||||
|
"scrollbar_thumb_background": "#57527933",
|
||||||
|
"scrollbar_thumb_hover_background": "#5752794d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#dfdad9",
|
||||||
|
"drop_target_background": "#2869831a",
|
||||||
|
"cursor": "#56949f",
|
||||||
|
"selection": "#56949f40"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/rose-pine-moon.json
Normal file
136
assets/themes/rose-pine-moon.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "rose-pine-moon",
|
||||||
|
"name": "Rosé Pine Moon",
|
||||||
|
"author": "Rosé Pine",
|
||||||
|
"url": "https://rosepinetheme.com/",
|
||||||
|
"light": {
|
||||||
|
"background": "#232136",
|
||||||
|
"surface_background": "#2a273f",
|
||||||
|
"elevated_surface_background": "#393552",
|
||||||
|
"panel_background": "#2a273f",
|
||||||
|
"overlay": "#e0def41a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#232136",
|
||||||
|
"window_border": "#56526e",
|
||||||
|
"border": "#56526e",
|
||||||
|
"border_variant": "#44415a",
|
||||||
|
"border_focused": "#3e8fb0",
|
||||||
|
"border_selected": "#3e8fb0",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#2a283e",
|
||||||
|
"ring": "#3e8fb0",
|
||||||
|
"text": "#e0def4",
|
||||||
|
"text_muted": "#908caa",
|
||||||
|
"text_placeholder": "#6e6a86",
|
||||||
|
"text_accent": "#c4a7e7",
|
||||||
|
"icon": "#e0def4",
|
||||||
|
"icon_muted": "#908caa",
|
||||||
|
"icon_accent": "#c4a7e7",
|
||||||
|
"element_foreground": "#232136",
|
||||||
|
"element_background": "#3e8fb0",
|
||||||
|
"element_hover": "#3e8fb0e6",
|
||||||
|
"element_active": "#38809d",
|
||||||
|
"element_selected": "#32718a",
|
||||||
|
"element_disabled": "#3e8fb04d",
|
||||||
|
"secondary_foreground": "#3e8fb0",
|
||||||
|
"secondary_background": "#2a283e",
|
||||||
|
"secondary_hover": "#3e8fb01a",
|
||||||
|
"secondary_active": "#44415a",
|
||||||
|
"secondary_selected": "#44415a",
|
||||||
|
"secondary_disabled": "#3e8fb04d",
|
||||||
|
"danger_foreground": "#232136",
|
||||||
|
"danger_background": "#eb6f92",
|
||||||
|
"danger_hover": "#eb6f92e6",
|
||||||
|
"danger_active": "#d46483",
|
||||||
|
"danger_selected": "#bd5974",
|
||||||
|
"danger_disabled": "#eb6f924d",
|
||||||
|
"warning_foreground": "#232136",
|
||||||
|
"warning_background": "#f6c177",
|
||||||
|
"warning_hover": "#f6c177e6",
|
||||||
|
"warning_active": "#ddae6b",
|
||||||
|
"warning_selected": "#c49b5f",
|
||||||
|
"warning_disabled": "#f6c1774d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#2a283e",
|
||||||
|
"ghost_element_hover": "#e0def41a",
|
||||||
|
"ghost_element_active": "#44415a",
|
||||||
|
"ghost_element_selected": "#44415a",
|
||||||
|
"ghost_element_disabled": "#e0def40d",
|
||||||
|
"tab_inactive_background": "#2a283e",
|
||||||
|
"tab_hover_background": "#44415a",
|
||||||
|
"tab_active_background": "#56526e",
|
||||||
|
"scrollbar_thumb_background": "#e0def433",
|
||||||
|
"scrollbar_thumb_hover_background": "#e0def44d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#44415a",
|
||||||
|
"drop_target_background": "#3e8fb01a",
|
||||||
|
"cursor": "#9ccfd8",
|
||||||
|
"selection": "#9ccfd840"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#232136",
|
||||||
|
"surface_background": "#2a273f",
|
||||||
|
"elevated_surface_background": "#393552",
|
||||||
|
"panel_background": "#2a273f",
|
||||||
|
"overlay": "#e0def41a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#232136",
|
||||||
|
"window_border": "#56526e",
|
||||||
|
"border": "#56526e",
|
||||||
|
"border_variant": "#44415a",
|
||||||
|
"border_focused": "#3e8fb0",
|
||||||
|
"border_selected": "#3e8fb0",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#2a283e",
|
||||||
|
"ring": "#3e8fb0",
|
||||||
|
"text": "#e0def4",
|
||||||
|
"text_muted": "#908caa",
|
||||||
|
"text_placeholder": "#6e6a86",
|
||||||
|
"text_accent": "#c4a7e7",
|
||||||
|
"icon": "#e0def4",
|
||||||
|
"icon_muted": "#908caa",
|
||||||
|
"icon_accent": "#c4a7e7",
|
||||||
|
"element_foreground": "#232136",
|
||||||
|
"element_background": "#3e8fb0",
|
||||||
|
"element_hover": "#3e8fb0e6",
|
||||||
|
"element_active": "#38809d",
|
||||||
|
"element_selected": "#32718a",
|
||||||
|
"element_disabled": "#3e8fb04d",
|
||||||
|
"secondary_foreground": "#3e8fb0",
|
||||||
|
"secondary_background": "#2a283e",
|
||||||
|
"secondary_hover": "#3e8fb01a",
|
||||||
|
"secondary_active": "#44415a",
|
||||||
|
"secondary_selected": "#44415a",
|
||||||
|
"secondary_disabled": "#3e8fb04d",
|
||||||
|
"danger_foreground": "#232136",
|
||||||
|
"danger_background": "#eb6f92",
|
||||||
|
"danger_hover": "#eb6f92e6",
|
||||||
|
"danger_active": "#d46483",
|
||||||
|
"danger_selected": "#bd5974",
|
||||||
|
"danger_disabled": "#eb6f924d",
|
||||||
|
"warning_foreground": "#232136",
|
||||||
|
"warning_background": "#f6c177",
|
||||||
|
"warning_hover": "#f6c177e6",
|
||||||
|
"warning_active": "#ddae6b",
|
||||||
|
"warning_selected": "#c49b5f",
|
||||||
|
"warning_disabled": "#f6c1774d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#2a283e",
|
||||||
|
"ghost_element_hover": "#e0def41a",
|
||||||
|
"ghost_element_active": "#44415a",
|
||||||
|
"ghost_element_selected": "#44415a",
|
||||||
|
"ghost_element_disabled": "#e0def40d",
|
||||||
|
"tab_inactive_background": "#2a283e",
|
||||||
|
"tab_hover_background": "#44415a",
|
||||||
|
"tab_active_background": "#56526e",
|
||||||
|
"scrollbar_thumb_background": "#e0def433",
|
||||||
|
"scrollbar_thumb_hover_background": "#e0def44d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#44415a",
|
||||||
|
"drop_target_background": "#3e8fb01a",
|
||||||
|
"cursor": "#9ccfd8",
|
||||||
|
"selection": "#9ccfd840"
|
||||||
|
}
|
||||||
|
}
|
||||||
136
assets/themes/rose-pine.json
Normal file
136
assets/themes/rose-pine.json
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
{
|
||||||
|
"id": "rose-pine",
|
||||||
|
"name": "Rosé Pine",
|
||||||
|
"author": "Rosé Pine",
|
||||||
|
"url": "https://rosepinetheme.com/",
|
||||||
|
"light": {
|
||||||
|
"background": "#191724",
|
||||||
|
"surface_background": "#1f1d2e",
|
||||||
|
"elevated_surface_background": "#26233a",
|
||||||
|
"panel_background": "#1f1d2e",
|
||||||
|
"overlay": "#e0def41a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#191724",
|
||||||
|
"window_border": "#524f67",
|
||||||
|
"border": "#524f67",
|
||||||
|
"border_variant": "#403d52",
|
||||||
|
"border_focused": "#31748f",
|
||||||
|
"border_selected": "#31748f",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#21202e",
|
||||||
|
"ring": "#31748f",
|
||||||
|
"text": "#e0def4",
|
||||||
|
"text_muted": "#908caa",
|
||||||
|
"text_placeholder": "#6e6a86",
|
||||||
|
"text_accent": "#c4a7e7",
|
||||||
|
"icon": "#e0def4",
|
||||||
|
"icon_muted": "#908caa",
|
||||||
|
"icon_accent": "#c4a7e7",
|
||||||
|
"element_foreground": "#191724",
|
||||||
|
"element_background": "#31748f",
|
||||||
|
"element_hover": "#31748fe6",
|
||||||
|
"element_active": "#2c6980",
|
||||||
|
"element_selected": "#275e71",
|
||||||
|
"element_disabled": "#31748f4d",
|
||||||
|
"secondary_foreground": "#31748f",
|
||||||
|
"secondary_background": "#21202e",
|
||||||
|
"secondary_hover": "#31748f1a",
|
||||||
|
"secondary_active": "#403d52",
|
||||||
|
"secondary_selected": "#403d52",
|
||||||
|
"secondary_disabled": "#31748f4d",
|
||||||
|
"danger_foreground": "#191724",
|
||||||
|
"danger_background": "#eb6f92",
|
||||||
|
"danger_hover": "#eb6f92e6",
|
||||||
|
"danger_active": "#d46483",
|
||||||
|
"danger_selected": "#bd5974",
|
||||||
|
"danger_disabled": "#eb6f924d",
|
||||||
|
"warning_foreground": "#191724",
|
||||||
|
"warning_background": "#f6c177",
|
||||||
|
"warning_hover": "#f6c177e6",
|
||||||
|
"warning_active": "#ddae6b",
|
||||||
|
"warning_selected": "#c49b5f",
|
||||||
|
"warning_disabled": "#f6c1774d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#21202e",
|
||||||
|
"ghost_element_hover": "#e0def41a",
|
||||||
|
"ghost_element_active": "#403d52",
|
||||||
|
"ghost_element_selected": "#403d52",
|
||||||
|
"ghost_element_disabled": "#e0def40d",
|
||||||
|
"tab_inactive_background": "#21202e",
|
||||||
|
"tab_hover_background": "#403d52",
|
||||||
|
"tab_active_background": "#524f67",
|
||||||
|
"scrollbar_thumb_background": "#e0def433",
|
||||||
|
"scrollbar_thumb_hover_background": "#e0def44d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#403d52",
|
||||||
|
"drop_target_background": "#31748f1a",
|
||||||
|
"cursor": "#9ccfd8",
|
||||||
|
"selection": "#9ccfd840"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#191724",
|
||||||
|
"surface_background": "#1f1d2e",
|
||||||
|
"elevated_surface_background": "#26233a",
|
||||||
|
"panel_background": "#1f1d2e",
|
||||||
|
"overlay": "#e0def41a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#191724",
|
||||||
|
"window_border": "#524f67",
|
||||||
|
"border": "#524f67",
|
||||||
|
"border_variant": "#403d52",
|
||||||
|
"border_focused": "#31748f",
|
||||||
|
"border_selected": "#31748f",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#21202e",
|
||||||
|
"ring": "#31748f",
|
||||||
|
"text": "#e0def4",
|
||||||
|
"text_muted": "#908caa",
|
||||||
|
"text_placeholder": "#6e6a86",
|
||||||
|
"text_accent": "#c4a7e7",
|
||||||
|
"icon": "#e0def4",
|
||||||
|
"icon_muted": "#908caa",
|
||||||
|
"icon_accent": "#c4a7e7",
|
||||||
|
"element_foreground": "#191724",
|
||||||
|
"element_background": "#31748f",
|
||||||
|
"element_hover": "#31748fe6",
|
||||||
|
"element_active": "#2c6980",
|
||||||
|
"element_selected": "#275e71",
|
||||||
|
"element_disabled": "#31748f4d",
|
||||||
|
"secondary_foreground": "#31748f",
|
||||||
|
"secondary_background": "#21202e",
|
||||||
|
"secondary_hover": "#31748f1a",
|
||||||
|
"secondary_active": "#403d52",
|
||||||
|
"secondary_selected": "#403d52",
|
||||||
|
"secondary_disabled": "#31748f4d",
|
||||||
|
"danger_foreground": "#191724",
|
||||||
|
"danger_background": "#eb6f92",
|
||||||
|
"danger_hover": "#eb6f92e6",
|
||||||
|
"danger_active": "#d46483",
|
||||||
|
"danger_selected": "#bd5974",
|
||||||
|
"danger_disabled": "#eb6f924d",
|
||||||
|
"warning_foreground": "#191724",
|
||||||
|
"warning_background": "#f6c177",
|
||||||
|
"warning_hover": "#f6c177e6",
|
||||||
|
"warning_active": "#ddae6b",
|
||||||
|
"warning_selected": "#c49b5f",
|
||||||
|
"warning_disabled": "#f6c1774d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#21202e",
|
||||||
|
"ghost_element_hover": "#e0def41a",
|
||||||
|
"ghost_element_active": "#403d52",
|
||||||
|
"ghost_element_selected": "#403d52",
|
||||||
|
"ghost_element_disabled": "#e0def40d",
|
||||||
|
"tab_inactive_background": "#21202e",
|
||||||
|
"tab_hover_background": "#403d52",
|
||||||
|
"tab_active_background": "#524f67",
|
||||||
|
"scrollbar_thumb_background": "#e0def433",
|
||||||
|
"scrollbar_thumb_hover_background": "#e0def44d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#403d52",
|
||||||
|
"drop_target_background": "#31748f1a",
|
||||||
|
"cursor": "#9ccfd8",
|
||||||
|
"selection": "#9ccfd840"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -7,6 +7,7 @@ use rust_embed::RustEmbed;
|
|||||||
#[include = "fonts/**/*"]
|
#[include = "fonts/**/*"]
|
||||||
#[include = "brand/**/*"]
|
#[include = "brand/**/*"]
|
||||||
#[include = "icons/**/*"]
|
#[include = "icons/**/*"]
|
||||||
|
#[include = "themes/**/*"]
|
||||||
#[exclude = "*.DS_Store"]
|
#[exclude = "*.DS_Store"]
|
||||||
pub struct Assets;
|
pub struct Assets;
|
||||||
|
|
||||||
@@ -47,13 +48,4 @@ impl Assets {
|
|||||||
|
|
||||||
cx.text_system().add_fonts(embedded_fonts)
|
cx.text_system().add_fonts(embedded_fonts)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn load_test_fonts(&self, cx: &App) {
|
|
||||||
cx.text_system()
|
|
||||||
.add_fonts(vec![self
|
|
||||||
.load("fonts/plex-mono/ZedPlexMono-Regular.ttf")
|
|
||||||
.unwrap()
|
|
||||||
.unwrap()])
|
|
||||||
.unwrap()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1021,8 +1021,8 @@ impl ChatPanel {
|
|||||||
.absolute()
|
.absolute()
|
||||||
.right_4()
|
.right_4()
|
||||||
.top_neg_2()
|
.top_neg_2()
|
||||||
.shadow_sm()
|
.when(cx.theme().shadow, |this| this.shadow_sm())
|
||||||
.rounded_md()
|
.rounded(cx.theme().radius)
|
||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border)
|
.border_color(cx.theme().border)
|
||||||
.bg(cx.theme().background)
|
.bg(cx.theme().background)
|
||||||
@@ -1074,7 +1074,7 @@ impl ChatPanel {
|
|||||||
.child(
|
.child(
|
||||||
img(url.as_str())
|
img(url.as_str())
|
||||||
.size_16()
|
.size_16()
|
||||||
.shadow_lg()
|
.when(cx.theme().shadow, |this| this.shadow_lg())
|
||||||
.rounded(cx.theme().radius)
|
.rounded(cx.theme().radius)
|
||||||
.object_fit(ObjectFit::ScaleDown),
|
.object_fit(ObjectFit::ScaleDown),
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -11,11 +11,7 @@ pub const BOOTSTRAP_RELAYS: [&str; 5] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
/// Search Relays.
|
/// Search Relays.
|
||||||
pub const SEARCH_RELAYS: [&str; 3] = [
|
pub const SEARCH_RELAYS: [&str; 2] = ["wss://search.nos.today", "wss://relay.noswhere.com"];
|
||||||
"wss://relay.nostr.band",
|
|
||||||
"wss://search.nos.today",
|
|
||||||
"wss://relay.noswhere.com",
|
|
||||||
];
|
|
||||||
|
|
||||||
/// Default relay for Nostr Connect
|
/// Default relay for Nostr Connect
|
||||||
pub const NOSTR_CONNECT_RELAY: &str = "wss://relay.nsec.app";
|
pub const NOSTR_CONNECT_RELAY: &str = "wss://relay.nsec.app";
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ actions!(
|
|||||||
DarkMode,
|
DarkMode,
|
||||||
ViewProfile,
|
ViewProfile,
|
||||||
ViewRelays,
|
ViewRelays,
|
||||||
|
Themes,
|
||||||
Settings,
|
Settings,
|
||||||
Logout,
|
Logout,
|
||||||
Quit
|
Quit
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ use encryption::Encryption;
|
|||||||
use encryption_ui::EncryptionPanel;
|
use encryption_ui::EncryptionPanel;
|
||||||
use gpui::prelude::FluentBuilder;
|
use gpui::prelude::FluentBuilder;
|
||||||
use gpui::{
|
use gpui::{
|
||||||
deferred, div, px, rems, App, AppContext, Axis, ClipboardItem, Context, Entity,
|
deferred, div, px, relative, rems, App, AppContext, Axis, ClipboardItem, Context, Entity,
|
||||||
InteractiveElement, IntoElement, ParentElement, Render, SharedString,
|
InteractiveElement, IntoElement, ParentElement, Render, SharedString,
|
||||||
StatefulInteractiveElement, Styled, Subscription, Window,
|
StatefulInteractiveElement, Styled, Subscription, Window,
|
||||||
};
|
};
|
||||||
@@ -20,7 +20,7 @@ use person::PersonRegistry;
|
|||||||
use relay_auth::RelayAuth;
|
use relay_auth::RelayAuth;
|
||||||
use settings::AppSettings;
|
use settings::AppSettings;
|
||||||
use smallvec::{smallvec, SmallVec};
|
use smallvec::{smallvec, SmallVec};
|
||||||
use theme::{ActiveTheme, Theme, ThemeMode};
|
use theme::{ActiveTheme, Theme, ThemeMode, ThemeRegistry};
|
||||||
use title_bar::TitleBar;
|
use title_bar::TitleBar;
|
||||||
use ui::avatar::Avatar;
|
use ui::avatar::Avatar;
|
||||||
use ui::button::{Button, ButtonVariants};
|
use ui::button::{Button, ButtonVariants};
|
||||||
@@ -32,7 +32,9 @@ use ui::popover::{Popover, PopoverContent};
|
|||||||
use ui::popup_menu::PopupMenuExt;
|
use ui::popup_menu::PopupMenuExt;
|
||||||
use ui::{h_flex, v_flex, ContextModal, IconName, Root, Sizable, StyledExt};
|
use ui::{h_flex, v_flex, ContextModal, IconName, Root, Sizable, StyledExt};
|
||||||
|
|
||||||
use crate::actions::{reset, DarkMode, KeyringPopup, Logout, Settings, ViewProfile, ViewRelays};
|
use crate::actions::{
|
||||||
|
reset, DarkMode, KeyringPopup, Logout, Settings, Themes, ViewProfile, ViewRelays,
|
||||||
|
};
|
||||||
use crate::user::viewer;
|
use crate::user::viewer;
|
||||||
use crate::views::compose::compose_button;
|
use crate::views::compose::compose_button;
|
||||||
use crate::views::{onboarding, preferences, setup_relay, startup, welcome};
|
use crate::views::{onboarding, preferences, setup_relay, startup, welcome};
|
||||||
@@ -313,6 +315,58 @@ impl ChatSpace {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn on_themes(&mut self, _ev: &Themes, window: &mut Window, cx: &mut Context<Self>) {
|
||||||
|
window.open_modal(cx, move |this, _window, cx| {
|
||||||
|
let registry = ThemeRegistry::global(cx);
|
||||||
|
let themes = registry.read(cx).themes();
|
||||||
|
|
||||||
|
this.title("Select theme")
|
||||||
|
.show_close(true)
|
||||||
|
.overlay_closable(true)
|
||||||
|
.child(v_flex().gap_2().pb_4().children({
|
||||||
|
let mut items = Vec::with_capacity(themes.len());
|
||||||
|
|
||||||
|
for (name, theme) in themes.iter() {
|
||||||
|
items.push(
|
||||||
|
h_flex()
|
||||||
|
.h_10()
|
||||||
|
.justify_between()
|
||||||
|
.child(
|
||||||
|
v_flex()
|
||||||
|
.child(
|
||||||
|
div()
|
||||||
|
.text_sm()
|
||||||
|
.text_color(cx.theme().text)
|
||||||
|
.line_height(relative(1.3))
|
||||||
|
.child(theme.name.clone()),
|
||||||
|
)
|
||||||
|
.child(
|
||||||
|
div()
|
||||||
|
.text_xs()
|
||||||
|
.text_color(cx.theme().text_muted)
|
||||||
|
.child(theme.author.clone()),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
.child(
|
||||||
|
Button::new(format!("change-{name}"))
|
||||||
|
.label("Set")
|
||||||
|
.small()
|
||||||
|
.ghost()
|
||||||
|
.on_click({
|
||||||
|
let theme = theme.clone();
|
||||||
|
move |_ev, window, cx| {
|
||||||
|
Theme::apply_theme(theme.clone(), Some(window), cx);
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
items
|
||||||
|
}))
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
fn on_sign_out(&mut self, _e: &Logout, _window: &mut Window, cx: &mut Context<Self>) {
|
fn on_sign_out(&mut self, _e: &Logout, _window: &mut Window, cx: &mut Context<Self>) {
|
||||||
reset(cx);
|
reset(cx);
|
||||||
}
|
}
|
||||||
@@ -567,6 +621,7 @@ impl ChatSpace {
|
|||||||
IconName::Sun,
|
IconName::Sun,
|
||||||
Box::new(DarkMode),
|
Box::new(DarkMode),
|
||||||
)
|
)
|
||||||
|
.menu_with_icon("Themes", IconName::Moon, Box::new(Themes))
|
||||||
.menu_with_icon(
|
.menu_with_icon(
|
||||||
"Settings",
|
"Settings",
|
||||||
IconName::Settings,
|
IconName::Settings,
|
||||||
@@ -646,6 +701,7 @@ impl Render for ChatSpace {
|
|||||||
.on_action(cx.listener(Self::on_profile))
|
.on_action(cx.listener(Self::on_profile))
|
||||||
.on_action(cx.listener(Self::on_relays))
|
.on_action(cx.listener(Self::on_relays))
|
||||||
.on_action(cx.listener(Self::on_dark_mode))
|
.on_action(cx.listener(Self::on_dark_mode))
|
||||||
|
.on_action(cx.listener(Self::on_themes))
|
||||||
.on_action(cx.listener(Self::on_sign_out))
|
.on_action(cx.listener(Self::on_sign_out))
|
||||||
.on_action(cx.listener(Self::on_open_pubkey))
|
.on_action(cx.listener(Self::on_open_pubkey))
|
||||||
.on_action(cx.listener(Self::on_copy_pubkey))
|
.on_action(cx.listener(Self::on_copy_pubkey))
|
||||||
|
|||||||
@@ -83,6 +83,9 @@ fn main() {
|
|||||||
// Initialize components
|
// Initialize components
|
||||||
ui::init(cx);
|
ui::init(cx);
|
||||||
|
|
||||||
|
// Initialize theme registry
|
||||||
|
theme::init(cx);
|
||||||
|
|
||||||
// Initialize backend for keys storage
|
// Initialize backend for keys storage
|
||||||
key_store::init(cx);
|
key_store::init(cx);
|
||||||
|
|
||||||
|
|||||||
@@ -120,8 +120,8 @@ impl RenderOnce for RoomListItem {
|
|||||||
.flex_1()
|
.flex_1()
|
||||||
.flex()
|
.flex()
|
||||||
.justify_between()
|
.justify_between()
|
||||||
.child(Skeleton::new().w_32().h_2p5().rounded_sm())
|
.child(Skeleton::new().w_32().h_2p5().rounded(cx.theme().radius))
|
||||||
.child(Skeleton::new().w_6().h_2p5().rounded_sm()),
|
.child(Skeleton::new().w_6().h_2p5().rounded(cx.theme().radius)),
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -151,18 +151,20 @@ impl Sidebar {
|
|||||||
|
|
||||||
let mut results: Vec<Event> = Vec::with_capacity(FIND_LIMIT);
|
let mut results: Vec<Event> = Vec::with_capacity(FIND_LIMIT);
|
||||||
|
|
||||||
while let Some(event) = stream.next().await {
|
while let Some((_url, event)) = stream.next().await {
|
||||||
// Skip if author is match current user
|
if let Ok(event) = event {
|
||||||
if event.pubkey == public_key {
|
// Skip if author is match current user
|
||||||
continue;
|
if event.pubkey == public_key {
|
||||||
}
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
// Skip if the event has already been added
|
// Skip if the event has already been added
|
||||||
if results.iter().any(|this| this.pubkey == event.pubkey) {
|
if results.iter().any(|this| this.pubkey == event.pubkey) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
results.push(event);
|
results.push(event);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if results.is_empty() {
|
if results.is_empty() {
|
||||||
|
|||||||
@@ -191,7 +191,7 @@ impl Onboarding {
|
|||||||
div()
|
div()
|
||||||
.id(ix)
|
.id(ix)
|
||||||
.flex_1()
|
.flex_1()
|
||||||
.rounded_md()
|
.rounded(cx.theme().radius)
|
||||||
.py_0p5()
|
.py_0p5()
|
||||||
.px_2()
|
.px_2()
|
||||||
.bg(cx.theme().ghost_element_background_alt)
|
.bg(cx.theme().ghost_element_background_alt)
|
||||||
@@ -308,13 +308,13 @@ impl Render for Onboarding {
|
|||||||
.p_2()
|
.p_2()
|
||||||
.flex_1()
|
.flex_1()
|
||||||
.h_full()
|
.h_full()
|
||||||
.rounded_2xl()
|
.rounded(cx.theme().radius_lg)
|
||||||
.child(
|
.child(
|
||||||
v_flex()
|
v_flex()
|
||||||
.size_full()
|
.size_full()
|
||||||
.justify_center()
|
.justify_center()
|
||||||
.bg(cx.theme().surface_background)
|
.bg(cx.theme().surface_background)
|
||||||
.rounded_2xl()
|
.rounded(cx.theme().radius_lg)
|
||||||
.child(
|
.child(
|
||||||
v_flex()
|
v_flex()
|
||||||
.gap_5()
|
.gap_5()
|
||||||
@@ -324,8 +324,8 @@ impl Render for Onboarding {
|
|||||||
this.child(
|
this.child(
|
||||||
img(qr.clone())
|
img(qr.clone())
|
||||||
.size(px(256.))
|
.size(px(256.))
|
||||||
.rounded_xl()
|
.rounded(cx.theme().radius_lg)
|
||||||
.shadow_lg()
|
.when(cx.theme().shadow, |this| this.shadow_lg())
|
||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().element_active),
|
.border_color(cx.theme().element_active),
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -77,8 +77,10 @@ impl Screening {
|
|||||||
.stream_events_from(BOOTSTRAP_RELAYS, filter, Duration::from_secs(2))
|
.stream_events_from(BOOTSTRAP_RELAYS, filter, Duration::from_secs(2))
|
||||||
.await
|
.await
|
||||||
{
|
{
|
||||||
while let Some(event) = stream.next().await {
|
while let Some((_url, event)) = stream.next().await {
|
||||||
activity = Some(event.created_at);
|
if let Ok(event) = event {
|
||||||
|
activity = Some(event.created_at);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -249,7 +249,7 @@ impl Render for Startup {
|
|||||||
.h_10()
|
.h_10()
|
||||||
.w_72()
|
.w_72()
|
||||||
.bg(cx.theme().elevated_surface_background)
|
.bg(cx.theme().elevated_surface_background)
|
||||||
.rounded_lg()
|
.rounded(cx.theme().radius_lg)
|
||||||
.text_sm()
|
.text_sm()
|
||||||
.when(self.loading, |this| {
|
.when(self.loading, |this| {
|
||||||
this.child(
|
this.child(
|
||||||
|
|||||||
@@ -8,3 +8,10 @@ publish.workspace = true
|
|||||||
gpui.workspace = true
|
gpui.workspace = true
|
||||||
anyhow.workspace = true
|
anyhow.workspace = true
|
||||||
log.workspace = true
|
log.workspace = true
|
||||||
|
serde.workspace = true
|
||||||
|
serde_json.workspace = true
|
||||||
|
schemars.workspace = true
|
||||||
|
smallvec.workspace = true
|
||||||
|
|
||||||
|
[dev-dependencies]
|
||||||
|
tempfile = "3.10"
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -1,284 +1,31 @@
|
|||||||
use std::ops::{Deref, DerefMut};
|
use std::ops::{Deref, DerefMut};
|
||||||
|
use std::rc::Rc;
|
||||||
|
|
||||||
use colors::{brand, hsl, neutral};
|
use gpui::{px, App, Global, Pixels, SharedString, Window};
|
||||||
use gpui::{px, App, Global, Hsla, Pixels, SharedString, Window, WindowAppearance};
|
|
||||||
|
|
||||||
use crate::colors::{danger, warning};
|
|
||||||
use crate::platform_kind::PlatformKind;
|
|
||||||
use crate::scrollbar_mode::ScrollBarMode;
|
|
||||||
|
|
||||||
mod colors;
|
mod colors;
|
||||||
|
mod registry;
|
||||||
mod scale;
|
mod scale;
|
||||||
|
mod scrollbar_mode;
|
||||||
|
mod theme;
|
||||||
|
|
||||||
pub mod platform_kind;
|
pub use colors::*;
|
||||||
pub mod scrollbar_mode;
|
pub use registry::*;
|
||||||
|
pub use scale::*;
|
||||||
|
pub use scrollbar_mode::*;
|
||||||
|
pub use theme::*;
|
||||||
|
|
||||||
/// Defines window border radius for platforms that use client side decorations.
|
/// Defines window border radius for platforms that use client side decorations.
|
||||||
pub const CLIENT_SIDE_DECORATION_ROUNDING: Pixels = px(10.0);
|
pub const CLIENT_SIDE_DECORATION_ROUNDING: Pixels = px(10.0);
|
||||||
|
|
||||||
/// Defines window shadow size for platforms that use client side decorations.
|
/// Defines window shadow size for platforms that use client side decorations.
|
||||||
pub const CLIENT_SIDE_DECORATION_SHADOW: Pixels = px(10.0);
|
pub const CLIENT_SIDE_DECORATION_SHADOW: Pixels = px(10.0);
|
||||||
|
|
||||||
pub fn init(cx: &mut App) {
|
pub fn init(cx: &mut App) {
|
||||||
|
registry::init(cx);
|
||||||
|
|
||||||
Theme::sync_system_appearance(None, cx);
|
Theme::sync_system_appearance(None, cx);
|
||||||
}
|
Theme::sync_scrollbar_appearance(cx);
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Default)]
|
|
||||||
pub struct ThemeColor {
|
|
||||||
// Surface colors
|
|
||||||
pub background: Hsla,
|
|
||||||
pub surface_background: Hsla,
|
|
||||||
pub elevated_surface_background: Hsla,
|
|
||||||
pub panel_background: Hsla,
|
|
||||||
pub overlay: Hsla,
|
|
||||||
pub title_bar: Hsla,
|
|
||||||
pub title_bar_inactive: Hsla,
|
|
||||||
pub window_border: Hsla,
|
|
||||||
|
|
||||||
// Border colors
|
|
||||||
pub border: Hsla,
|
|
||||||
pub border_variant: Hsla,
|
|
||||||
pub border_focused: Hsla,
|
|
||||||
pub border_selected: Hsla,
|
|
||||||
pub border_transparent: Hsla,
|
|
||||||
pub border_disabled: Hsla,
|
|
||||||
pub ring: Hsla,
|
|
||||||
|
|
||||||
// Text colors
|
|
||||||
pub text: Hsla,
|
|
||||||
pub text_muted: Hsla,
|
|
||||||
pub text_placeholder: Hsla,
|
|
||||||
pub text_accent: Hsla,
|
|
||||||
|
|
||||||
// Icon colors
|
|
||||||
pub icon: Hsla,
|
|
||||||
pub icon_muted: Hsla,
|
|
||||||
pub icon_accent: Hsla,
|
|
||||||
|
|
||||||
// Element colors
|
|
||||||
pub element_foreground: Hsla,
|
|
||||||
pub element_background: Hsla,
|
|
||||||
pub element_hover: Hsla,
|
|
||||||
pub element_active: Hsla,
|
|
||||||
pub element_selected: Hsla,
|
|
||||||
pub element_disabled: Hsla,
|
|
||||||
|
|
||||||
// Secondary element colors
|
|
||||||
pub secondary_foreground: Hsla,
|
|
||||||
pub secondary_background: Hsla,
|
|
||||||
pub secondary_hover: Hsla,
|
|
||||||
pub secondary_active: Hsla,
|
|
||||||
pub secondary_selected: Hsla,
|
|
||||||
pub secondary_disabled: Hsla,
|
|
||||||
|
|
||||||
// Danger element colors
|
|
||||||
pub danger_foreground: Hsla,
|
|
||||||
pub danger_background: Hsla,
|
|
||||||
pub danger_hover: Hsla,
|
|
||||||
pub danger_active: Hsla,
|
|
||||||
pub danger_selected: Hsla,
|
|
||||||
pub danger_disabled: Hsla,
|
|
||||||
|
|
||||||
// Warning element colors
|
|
||||||
pub warning_foreground: Hsla,
|
|
||||||
pub warning_background: Hsla,
|
|
||||||
pub warning_hover: Hsla,
|
|
||||||
pub warning_active: Hsla,
|
|
||||||
pub warning_selected: Hsla,
|
|
||||||
pub warning_disabled: Hsla,
|
|
||||||
|
|
||||||
// Ghost element colors
|
|
||||||
pub ghost_element_background: Hsla,
|
|
||||||
pub ghost_element_background_alt: Hsla,
|
|
||||||
pub ghost_element_hover: Hsla,
|
|
||||||
pub ghost_element_active: Hsla,
|
|
||||||
pub ghost_element_selected: Hsla,
|
|
||||||
pub ghost_element_disabled: Hsla,
|
|
||||||
|
|
||||||
// Tab colors
|
|
||||||
pub tab_inactive_background: Hsla,
|
|
||||||
pub tab_hover_background: Hsla,
|
|
||||||
pub tab_active_background: Hsla,
|
|
||||||
|
|
||||||
// Scrollbar colors
|
|
||||||
pub scrollbar_thumb_background: Hsla,
|
|
||||||
pub scrollbar_thumb_hover_background: Hsla,
|
|
||||||
pub scrollbar_thumb_border: Hsla,
|
|
||||||
pub scrollbar_track_background: Hsla,
|
|
||||||
pub scrollbar_track_border: Hsla,
|
|
||||||
|
|
||||||
// Interactive colors
|
|
||||||
pub drop_target_background: Hsla,
|
|
||||||
pub cursor: Hsla,
|
|
||||||
pub selection: Hsla,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The default colors for the theme.
|
|
||||||
///
|
|
||||||
/// Themes that do not specify all colors are refined off of these defaults.
|
|
||||||
impl ThemeColor {
|
|
||||||
/// Returns the default colors for light themes.
|
|
||||||
///
|
|
||||||
/// Themes that do not specify all colors are refined off of these defaults.
|
|
||||||
pub fn light() -> Self {
|
|
||||||
Self {
|
|
||||||
background: neutral().light().step_1(),
|
|
||||||
surface_background: neutral().light().step_2(),
|
|
||||||
elevated_surface_background: neutral().light().step_3(),
|
|
||||||
panel_background: gpui::white(),
|
|
||||||
overlay: neutral().light_alpha().step_3(),
|
|
||||||
title_bar: gpui::transparent_black(),
|
|
||||||
title_bar_inactive: neutral().light().step_1(),
|
|
||||||
window_border: hsl(240.0, 5.9, 78.0),
|
|
||||||
|
|
||||||
border: neutral().light().step_6(),
|
|
||||||
border_variant: neutral().light().step_5(),
|
|
||||||
border_focused: brand().light().step_7(),
|
|
||||||
border_selected: brand().light().step_7(),
|
|
||||||
border_transparent: gpui::transparent_black(),
|
|
||||||
border_disabled: neutral().light().step_3(),
|
|
||||||
ring: brand().light().step_8(),
|
|
||||||
|
|
||||||
text: neutral().light().step_12(),
|
|
||||||
text_muted: neutral().light().step_11(),
|
|
||||||
text_placeholder: neutral().light().step_10(),
|
|
||||||
text_accent: brand().light().step_11(),
|
|
||||||
|
|
||||||
icon: neutral().light().step_11(),
|
|
||||||
icon_muted: neutral().light().step_10(),
|
|
||||||
icon_accent: brand().light().step_11(),
|
|
||||||
|
|
||||||
element_foreground: brand().light().step_12(),
|
|
||||||
element_background: brand().light().step_9(),
|
|
||||||
element_hover: brand().light_alpha().step_10(),
|
|
||||||
element_active: brand().light().step_10(),
|
|
||||||
element_selected: brand().light().step_11(),
|
|
||||||
element_disabled: brand().light_alpha().step_3(),
|
|
||||||
|
|
||||||
secondary_foreground: brand().light().step_11(),
|
|
||||||
secondary_background: brand().light().step_3(),
|
|
||||||
secondary_hover: brand().light_alpha().step_4(),
|
|
||||||
secondary_active: brand().light().step_5(),
|
|
||||||
secondary_selected: brand().light().step_5(),
|
|
||||||
secondary_disabled: brand().light_alpha().step_3(),
|
|
||||||
|
|
||||||
danger_foreground: danger().light().step_12(),
|
|
||||||
danger_background: danger().light().step_3(),
|
|
||||||
danger_hover: danger().light_alpha().step_4(),
|
|
||||||
danger_active: danger().light().step_5(),
|
|
||||||
danger_selected: danger().light().step_5(),
|
|
||||||
danger_disabled: danger().light_alpha().step_3(),
|
|
||||||
|
|
||||||
warning_foreground: warning().light().step_12(),
|
|
||||||
warning_background: warning().light().step_3(),
|
|
||||||
warning_hover: warning().light_alpha().step_4(),
|
|
||||||
warning_active: warning().light().step_5(),
|
|
||||||
warning_selected: warning().light().step_5(),
|
|
||||||
warning_disabled: warning().light_alpha().step_3(),
|
|
||||||
|
|
||||||
ghost_element_background: gpui::transparent_black(),
|
|
||||||
ghost_element_background_alt: neutral().light().step_3(),
|
|
||||||
ghost_element_hover: neutral().light_alpha().step_4(),
|
|
||||||
ghost_element_active: neutral().light().step_5(),
|
|
||||||
ghost_element_selected: neutral().light().step_5(),
|
|
||||||
ghost_element_disabled: neutral().light_alpha().step_2(),
|
|
||||||
|
|
||||||
tab_inactive_background: neutral().light().step_3(),
|
|
||||||
tab_hover_background: neutral().light().step_4(),
|
|
||||||
tab_active_background: neutral().light().step_5(),
|
|
||||||
|
|
||||||
scrollbar_thumb_background: neutral().light_alpha().step_3(),
|
|
||||||
scrollbar_thumb_hover_background: neutral().light_alpha().step_4(),
|
|
||||||
scrollbar_thumb_border: gpui::transparent_black(),
|
|
||||||
scrollbar_track_background: gpui::transparent_black(),
|
|
||||||
scrollbar_track_border: neutral().light().step_5(),
|
|
||||||
|
|
||||||
drop_target_background: brand().light_alpha().step_2(),
|
|
||||||
cursor: hsl(200., 100., 50.),
|
|
||||||
selection: hsl(200., 100., 50.).alpha(0.25),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the default colors for dark themes.
|
|
||||||
///
|
|
||||||
/// Themes that do not specify all colors are refined off of these defaults.
|
|
||||||
pub fn dark() -> Self {
|
|
||||||
Self {
|
|
||||||
background: neutral().dark().step_1(),
|
|
||||||
surface_background: neutral().dark().step_2(),
|
|
||||||
elevated_surface_background: neutral().dark().step_3(),
|
|
||||||
panel_background: gpui::black(),
|
|
||||||
overlay: neutral().dark_alpha().step_3(),
|
|
||||||
title_bar: gpui::transparent_black(),
|
|
||||||
title_bar_inactive: neutral().dark().step_1(),
|
|
||||||
window_border: hsl(240.0, 3.7, 28.0),
|
|
||||||
|
|
||||||
border: neutral().dark().step_6(),
|
|
||||||
border_variant: neutral().dark().step_5(),
|
|
||||||
border_focused: brand().dark().step_7(),
|
|
||||||
border_selected: brand().dark().step_7(),
|
|
||||||
border_transparent: gpui::transparent_black(),
|
|
||||||
border_disabled: neutral().dark().step_3(),
|
|
||||||
ring: brand().dark().step_8(),
|
|
||||||
|
|
||||||
text: neutral().dark().step_12(),
|
|
||||||
text_muted: neutral().dark().step_11(),
|
|
||||||
text_placeholder: neutral().dark().step_10(),
|
|
||||||
text_accent: brand().dark().step_11(),
|
|
||||||
|
|
||||||
icon: neutral().dark().step_11(),
|
|
||||||
icon_muted: neutral().dark().step_10(),
|
|
||||||
icon_accent: brand().dark().step_11(),
|
|
||||||
|
|
||||||
element_foreground: brand().dark().step_1(),
|
|
||||||
element_background: brand().dark().step_9(),
|
|
||||||
element_hover: brand().dark_alpha().step_10(),
|
|
||||||
element_active: brand().dark().step_10(),
|
|
||||||
element_selected: brand().dark().step_11(),
|
|
||||||
element_disabled: brand().dark_alpha().step_3(),
|
|
||||||
|
|
||||||
secondary_foreground: brand().dark().step_12(),
|
|
||||||
secondary_background: brand().dark().step_3(),
|
|
||||||
secondary_hover: brand().dark_alpha().step_4(),
|
|
||||||
secondary_active: brand().dark().step_5(),
|
|
||||||
secondary_selected: brand().dark().step_5(),
|
|
||||||
secondary_disabled: brand().dark_alpha().step_3(),
|
|
||||||
|
|
||||||
danger_foreground: danger().dark().step_12(),
|
|
||||||
danger_background: danger().dark().step_3(),
|
|
||||||
danger_hover: danger().dark_alpha().step_4(),
|
|
||||||
danger_active: danger().dark().step_5(),
|
|
||||||
danger_selected: danger().dark().step_5(),
|
|
||||||
danger_disabled: danger().dark_alpha().step_3(),
|
|
||||||
|
|
||||||
warning_foreground: warning().dark().step_12(),
|
|
||||||
warning_background: warning().dark().step_3(),
|
|
||||||
warning_hover: warning().dark_alpha().step_4(),
|
|
||||||
warning_active: warning().dark().step_5(),
|
|
||||||
warning_selected: warning().dark().step_5(),
|
|
||||||
warning_disabled: warning().dark_alpha().step_3(),
|
|
||||||
|
|
||||||
ghost_element_background: gpui::transparent_black(),
|
|
||||||
ghost_element_background_alt: neutral().dark().step_3(),
|
|
||||||
ghost_element_hover: neutral().dark_alpha().step_4(),
|
|
||||||
ghost_element_active: neutral().dark().step_5(),
|
|
||||||
ghost_element_selected: neutral().dark().step_5(),
|
|
||||||
ghost_element_disabled: neutral().dark_alpha().step_2(),
|
|
||||||
|
|
||||||
tab_inactive_background: neutral().dark().step_3(),
|
|
||||||
tab_hover_background: neutral().dark().step_4(),
|
|
||||||
tab_active_background: neutral().dark().step_5(),
|
|
||||||
|
|
||||||
scrollbar_thumb_background: neutral().dark_alpha().step_3(),
|
|
||||||
scrollbar_thumb_hover_background: neutral().dark_alpha().step_4(),
|
|
||||||
scrollbar_thumb_border: gpui::transparent_black(),
|
|
||||||
scrollbar_track_background: gpui::transparent_black(),
|
|
||||||
scrollbar_track_border: neutral().dark().step_5(),
|
|
||||||
|
|
||||||
drop_target_background: brand().dark_alpha().step_2(),
|
|
||||||
cursor: hsl(200., 100., 50.),
|
|
||||||
selection: hsl(200., 100., 50.).alpha(0.25),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait ActiveTheme {
|
pub trait ActiveTheme {
|
||||||
@@ -292,49 +39,38 @@ impl ActiveTheme for App {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Default, PartialEq, PartialOrd, Eq, Hash)]
|
|
||||||
pub enum ThemeMode {
|
|
||||||
Light,
|
|
||||||
#[default]
|
|
||||||
Dark,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ThemeMode {
|
|
||||||
pub fn is_dark(&self) -> bool {
|
|
||||||
matches!(self, Self::Dark)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Return lower_case theme name: `light`, `dark`.
|
|
||||||
pub fn name(&self) -> &'static str {
|
|
||||||
match self {
|
|
||||||
ThemeMode::Light => "light",
|
|
||||||
ThemeMode::Dark => "dark",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<WindowAppearance> for ThemeMode {
|
|
||||||
fn from(appearance: WindowAppearance) -> Self {
|
|
||||||
match appearance {
|
|
||||||
WindowAppearance::Dark | WindowAppearance::VibrantDark => Self::Dark,
|
|
||||||
WindowAppearance::Light | WindowAppearance::VibrantLight => Self::Light,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Theme {
|
pub struct Theme {
|
||||||
pub colors: ThemeColor,
|
/// Theme colors
|
||||||
|
pub colors: ThemeColors,
|
||||||
|
|
||||||
|
/// Theme family
|
||||||
|
pub theme: Rc<ThemeFamily>,
|
||||||
|
|
||||||
|
/// The appearance of the theme (light or dark).
|
||||||
pub mode: ThemeMode,
|
pub mode: ThemeMode,
|
||||||
|
|
||||||
|
/// The font family for the application.
|
||||||
pub font_family: SharedString,
|
pub font_family: SharedString,
|
||||||
|
|
||||||
|
/// The root font size for the application, default is 15px.
|
||||||
pub font_size: Pixels,
|
pub font_size: Pixels,
|
||||||
|
|
||||||
|
/// Radius for the general elements.
|
||||||
pub radius: Pixels,
|
pub radius: Pixels,
|
||||||
pub scrollbar_mode: ScrollBarMode,
|
|
||||||
pub platform_kind: PlatformKind,
|
/// Radius for the large elements, e.g.: modal, notification.
|
||||||
|
pub radius_lg: Pixels,
|
||||||
|
|
||||||
|
/// Enable shadow for the general elements. default is true
|
||||||
|
pub shadow: bool,
|
||||||
|
|
||||||
|
/// Show the scrollbar mode, default: scrolling
|
||||||
|
pub scrollbar_mode: ScrollbarMode,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Deref for Theme {
|
impl Deref for Theme {
|
||||||
type Target = ThemeColor;
|
type Target = ThemeColors;
|
||||||
|
|
||||||
fn deref(&self) -> &Self::Target {
|
fn deref(&self) -> &Self::Target {
|
||||||
&self.colors
|
&self.colors
|
||||||
@@ -375,42 +111,76 @@ impl Theme {
|
|||||||
Self::change(appearance, window, cx);
|
Self::change(appearance, window, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Change the app's appearance
|
/// Sync the Scrollbar showing behavior with the system
|
||||||
pub fn change(mode: impl Into<ThemeMode>, window: Option<&mut Window>, cx: &mut App) {
|
pub fn sync_scrollbar_appearance(cx: &mut App) {
|
||||||
let mode = mode.into();
|
Theme::global_mut(cx).scrollbar_mode = if cx.should_auto_hide_scrollbars() {
|
||||||
let colors = match mode {
|
ScrollbarMode::Scrolling
|
||||||
ThemeMode::Light => ThemeColor::light(),
|
} else {
|
||||||
ThemeMode::Dark => ThemeColor::dark(),
|
ScrollbarMode::Hover
|
||||||
};
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Apply a new theme to the application.
|
||||||
|
pub fn apply_theme(new_theme: Rc<ThemeFamily>, window: Option<&mut Window>, cx: &mut App) {
|
||||||
|
let theme = cx.global_mut::<Theme>();
|
||||||
|
let mode = theme.mode;
|
||||||
|
// Update the theme
|
||||||
|
theme.theme = new_theme;
|
||||||
|
// Emit a theme change event
|
||||||
|
Self::change(mode, window, cx);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Change the app's appearance
|
||||||
|
pub fn change<M>(mode: M, window: Option<&mut Window>, cx: &mut App)
|
||||||
|
where
|
||||||
|
M: Into<ThemeMode>,
|
||||||
|
{
|
||||||
if !cx.has_global::<Theme>() {
|
if !cx.has_global::<Theme>() {
|
||||||
let theme = Theme::from(colors);
|
let default_theme = ThemeFamily::default();
|
||||||
|
let theme = Theme::from(default_theme);
|
||||||
|
|
||||||
cx.set_global(theme);
|
cx.set_global(theme);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let mode = mode.into();
|
||||||
let theme = cx.global_mut::<Theme>();
|
let theme = cx.global_mut::<Theme>();
|
||||||
|
|
||||||
|
// Set the theme mode
|
||||||
theme.mode = mode;
|
theme.mode = mode;
|
||||||
theme.colors = colors;
|
|
||||||
|
|
||||||
|
// Set the theme colors
|
||||||
|
if mode.is_dark() {
|
||||||
|
theme.colors = *theme.theme.dark();
|
||||||
|
} else {
|
||||||
|
theme.colors = *theme.theme.light();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Refresh the window if available
|
||||||
if let Some(window) = window {
|
if let Some(window) = window {
|
||||||
window.refresh();
|
window.refresh();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<ThemeColor> for Theme {
|
impl From<ThemeFamily> for Theme {
|
||||||
fn from(colors: ThemeColor) -> Self {
|
fn from(family: ThemeFamily) -> Self {
|
||||||
let mode = ThemeMode::default();
|
let mode = ThemeMode::default();
|
||||||
|
// Define the theme colors based on the appearance
|
||||||
|
let colors = match mode {
|
||||||
|
ThemeMode::Light => family.light(),
|
||||||
|
ThemeMode::Dark => family.dark(),
|
||||||
|
};
|
||||||
|
|
||||||
Theme {
|
Theme {
|
||||||
font_size: px(15.),
|
font_size: px(15.),
|
||||||
font_family: ".SystemUIFont".into(),
|
font_family: ".SystemUIFont".into(),
|
||||||
radius: px(5.),
|
radius: px(5.),
|
||||||
scrollbar_mode: ScrollBarMode::default(),
|
radius_lg: px(10.),
|
||||||
platform_kind: PlatformKind::platform(),
|
shadow: true,
|
||||||
|
scrollbar_mode: ScrollbarMode::default(),
|
||||||
mode,
|
mode,
|
||||||
colors,
|
colors: *colors,
|
||||||
|
theme: Rc::new(family),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
70
crates/theme/src/registry.rs
Normal file
70
crates/theme/src/registry.rs
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
use std::collections::HashMap;
|
||||||
|
use std::rc::Rc;
|
||||||
|
use std::sync::Arc;
|
||||||
|
|
||||||
|
use anyhow::{Context as AnyhowContext, Error};
|
||||||
|
use gpui::{App, AppContext, AssetSource, Context, Entity, Global, SharedString};
|
||||||
|
|
||||||
|
use crate::ThemeFamily;
|
||||||
|
|
||||||
|
pub fn init(cx: &mut App) {
|
||||||
|
ThemeRegistry::set_global(cx.new(ThemeRegistry::new), cx);
|
||||||
|
}
|
||||||
|
|
||||||
|
struct GlobalThemeRegistry(Entity<ThemeRegistry>);
|
||||||
|
|
||||||
|
impl Global for GlobalThemeRegistry {}
|
||||||
|
|
||||||
|
pub struct ThemeRegistry {
|
||||||
|
/// Map of theme names to theme families
|
||||||
|
themes: HashMap<SharedString, Rc<ThemeFamily>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ThemeRegistry {
|
||||||
|
/// Retrieve the global theme registry state
|
||||||
|
pub fn global(cx: &App) -> Entity<Self> {
|
||||||
|
cx.global::<GlobalThemeRegistry>().0.clone()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Set the global theme registry instance
|
||||||
|
pub(crate) fn set_global(state: Entity<Self>, cx: &mut App) {
|
||||||
|
cx.set_global(GlobalThemeRegistry(state));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Create a new theme registry instance
|
||||||
|
pub(crate) fn new(cx: &mut Context<Self>) -> Self {
|
||||||
|
let mut themes = HashMap::new();
|
||||||
|
let asset = cx.asset_source();
|
||||||
|
|
||||||
|
if let Ok(paths) = asset.list("themes") {
|
||||||
|
for path in paths.into_iter() {
|
||||||
|
match Self::load(&path, asset) {
|
||||||
|
Ok(theme) => {
|
||||||
|
themes.insert(path, Rc::new(theme));
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
log::error!("Failed to load theme: {path}. Error: {e}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Self { themes }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Load a theme from the asset source.
|
||||||
|
fn load(path: &str, asset: &Arc<dyn AssetSource>) -> Result<ThemeFamily, Error> {
|
||||||
|
// Load the theme file from the assets
|
||||||
|
let content = asset.load(path)?.context("Theme not found")?;
|
||||||
|
|
||||||
|
// Parse the JSON content into a Theme Family struct
|
||||||
|
let theme: ThemeFamily = serde_json::from_slice(&content)?;
|
||||||
|
|
||||||
|
Ok(theme)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns a reference to the map of themes.
|
||||||
|
pub fn themes(&self) -> &HashMap<SharedString, Rc<ThemeFamily>> {
|
||||||
|
&self.themes
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,12 +1,15 @@
|
|||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, Default)]
|
use schemars::JsonSchema;
|
||||||
pub enum ScrollBarMode {
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, Default, Serialize, Deserialize, JsonSchema)]
|
||||||
|
pub enum ScrollbarMode {
|
||||||
#[default]
|
#[default]
|
||||||
Scrolling,
|
Scrolling,
|
||||||
Hover,
|
Hover,
|
||||||
Always,
|
Always,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ScrollBarMode {
|
impl ScrollbarMode {
|
||||||
pub fn is_scrolling(&self) -> bool {
|
pub fn is_scrolling(&self) -> bool {
|
||||||
matches!(self, Self::Scrolling)
|
matches!(self, Self::Scrolling)
|
||||||
}
|
}
|
||||||
|
|||||||
359
crates/theme/src/theme.rs
Normal file
359
crates/theme/src/theme.rs
Normal file
@@ -0,0 +1,359 @@
|
|||||||
|
use std::path::Path;
|
||||||
|
|
||||||
|
use gpui::{SharedString, WindowAppearance};
|
||||||
|
use schemars::JsonSchema;
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
use crate::ThemeColors;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Copy, Default, PartialEq, PartialOrd, Eq, Hash)]
|
||||||
|
pub enum ThemeMode {
|
||||||
|
#[default]
|
||||||
|
Light,
|
||||||
|
Dark,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ThemeMode {
|
||||||
|
pub fn is_dark(&self) -> bool {
|
||||||
|
matches!(self, Self::Dark)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Return lower_case theme name: `light`, `dark`.
|
||||||
|
pub fn name(&self) -> &'static str {
|
||||||
|
match self {
|
||||||
|
ThemeMode::Light => "light",
|
||||||
|
ThemeMode::Dark => "dark",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<WindowAppearance> for ThemeMode {
|
||||||
|
fn from(appearance: WindowAppearance) -> Self {
|
||||||
|
match appearance {
|
||||||
|
WindowAppearance::Dark | WindowAppearance::VibrantDark => Self::Dark,
|
||||||
|
WindowAppearance::Light | WindowAppearance::VibrantLight => Self::Light,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Theme family
|
||||||
|
#[derive(Clone, Debug, PartialEq, Deserialize, Serialize, JsonSchema)]
|
||||||
|
pub struct ThemeFamily {
|
||||||
|
/// The unique identifier for the theme.
|
||||||
|
pub id: String,
|
||||||
|
|
||||||
|
/// The name of the theme.
|
||||||
|
pub name: SharedString,
|
||||||
|
|
||||||
|
/// The author of the theme.
|
||||||
|
pub author: SharedString,
|
||||||
|
|
||||||
|
/// The URL of the theme.
|
||||||
|
pub url: String,
|
||||||
|
|
||||||
|
/// The light colors for the theme.
|
||||||
|
pub light: ThemeColors,
|
||||||
|
|
||||||
|
/// The dark colors for the theme.
|
||||||
|
pub dark: ThemeColors,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for ThemeFamily {
|
||||||
|
fn default() -> Self {
|
||||||
|
ThemeFamily {
|
||||||
|
id: "coop".into(),
|
||||||
|
name: "Coop Default Theme".into(),
|
||||||
|
author: "Coop".into(),
|
||||||
|
url: "https://github.com/lumehq/coop".into(),
|
||||||
|
light: ThemeColors::light(),
|
||||||
|
dark: ThemeColors::dark(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ThemeFamily {
|
||||||
|
/// Returns the light colors for the theme.
|
||||||
|
#[inline(always)]
|
||||||
|
pub fn light(&self) -> &ThemeColors {
|
||||||
|
&self.light
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the dark colors for the theme.
|
||||||
|
#[inline(always)]
|
||||||
|
pub fn dark(&self) -> &ThemeColors {
|
||||||
|
&self.dark
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Load a theme family from a JSON file.
|
||||||
|
///
|
||||||
|
/// # Arguments
|
||||||
|
///
|
||||||
|
/// * `path` - Path to the JSON file containing the theme family. This can be
|
||||||
|
/// an absolute path or a path relative to the current working directory.
|
||||||
|
///
|
||||||
|
/// # Returns
|
||||||
|
///
|
||||||
|
/// Returns `Ok(ThemeFamily)` if the file was successfully loaded and parsed,
|
||||||
|
/// or `Err(anyhow::Error)` if there was an error reading or parsing the file.
|
||||||
|
///
|
||||||
|
/// # Errors
|
||||||
|
///
|
||||||
|
/// This function will return an error if:
|
||||||
|
/// - The file cannot be read (permission issues, file doesn't exist, etc.)
|
||||||
|
/// - The file contains invalid JSON
|
||||||
|
/// - The JSON structure doesn't match the `ThemeFamily` schema
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```no_run
|
||||||
|
/// use theme::ThemeFamily;
|
||||||
|
///
|
||||||
|
/// # fn main() -> anyhow::Result<()> {
|
||||||
|
/// // Load from a relative path
|
||||||
|
/// let theme = ThemeFamily::from_file("assets/themes/my-theme.json")?;
|
||||||
|
///
|
||||||
|
/// // Load from an absolute path
|
||||||
|
/// let theme = ThemeFamily::from_file("/path/to/themes/my-theme.json")?;
|
||||||
|
/// # Ok(())
|
||||||
|
/// # }
|
||||||
|
/// ```
|
||||||
|
pub fn from_file<P: AsRef<Path>>(path: P) -> anyhow::Result<Self> {
|
||||||
|
let json_data = std::fs::read(path)?;
|
||||||
|
let theme_family = serde_json::from_slice(&json_data)?;
|
||||||
|
|
||||||
|
Ok(theme_family)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Load a theme family from a JSON file in the assets/themes directory.
|
||||||
|
///
|
||||||
|
/// This function looks for the file at `assets/themes/{name}.json` relative
|
||||||
|
/// to the current working directory. This is useful for loading themes
|
||||||
|
/// from the standard theme directory in the project structure.
|
||||||
|
///
|
||||||
|
/// # Arguments
|
||||||
|
///
|
||||||
|
/// * `name` - Name of the theme file (without the .json extension)
|
||||||
|
///
|
||||||
|
/// # Returns
|
||||||
|
///
|
||||||
|
/// Returns `Ok(ThemeFamily)` if the file was successfully loaded and parsed,
|
||||||
|
/// or `Err(anyhow::Error)` if there was an error reading or parsing the file.
|
||||||
|
///
|
||||||
|
/// # Errors
|
||||||
|
///
|
||||||
|
/// This function will return an error if:
|
||||||
|
/// - The file cannot be read (permission issues, file doesn't exist, etc.)
|
||||||
|
/// - The file contains invalid JSON
|
||||||
|
/// - The JSON structure doesn't match the `ThemeFamily` schema
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```no_run
|
||||||
|
/// use theme::ThemeFamily;
|
||||||
|
///
|
||||||
|
/// # fn main() -> anyhow::Result<()> {
|
||||||
|
/// // Assuming the file exists at `assets/themes/my-theme.json`
|
||||||
|
/// let theme = ThemeFamily::from_assets("my-theme")?;
|
||||||
|
///
|
||||||
|
/// println!("Loaded theme: {}", theme.name);
|
||||||
|
/// # Ok(())
|
||||||
|
/// # }
|
||||||
|
/// ```
|
||||||
|
pub fn from_assets(name: &str) -> anyhow::Result<Self> {
|
||||||
|
let path = format!("assets/themes/{}.json", name);
|
||||||
|
Self::from_file(path)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use std::fs;
|
||||||
|
|
||||||
|
use tempfile::tempdir;
|
||||||
|
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_from_file() {
|
||||||
|
// Create a temporary directory for our test
|
||||||
|
let dir = tempdir().unwrap();
|
||||||
|
let file_path = dir.path().join("test-theme.json");
|
||||||
|
|
||||||
|
// Create a minimal valid theme JSON with hex colors
|
||||||
|
// Using simple hex colors that Hsla can parse
|
||||||
|
// Note: We need to escape the # characters in the raw string
|
||||||
|
let json_data = r##"{
|
||||||
|
"id": "test-theme",
|
||||||
|
"name": "Test Theme",
|
||||||
|
"author": "Coop",
|
||||||
|
"url": "https://github.com/lumehq/coop",
|
||||||
|
"light": {
|
||||||
|
"background": "#ffffff",
|
||||||
|
"surface_background": "#fafafa",
|
||||||
|
"elevated_surface_background": "#f5f5f5",
|
||||||
|
"panel_background": "#ffffff",
|
||||||
|
"overlay": "#0000001a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#ffffff",
|
||||||
|
"window_border": "#c7c7cf",
|
||||||
|
"border": "#dbdbdb",
|
||||||
|
"border_variant": "#d1d1d1",
|
||||||
|
"border_focused": "#3366cc",
|
||||||
|
"border_selected": "#3366cc",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#e6e6e6",
|
||||||
|
"ring": "#4d79d6",
|
||||||
|
"text": "#1a1a1a",
|
||||||
|
"text_muted": "#4d4d4d",
|
||||||
|
"text_placeholder": "#808080",
|
||||||
|
"text_accent": "#3366cc",
|
||||||
|
"icon": "#4d4d4d",
|
||||||
|
"icon_muted": "#808080",
|
||||||
|
"icon_accent": "#3366cc",
|
||||||
|
"element_foreground": "#ffffff",
|
||||||
|
"element_background": "#3366cc",
|
||||||
|
"element_hover": "#3366cce6",
|
||||||
|
"element_active": "#2e5cb8",
|
||||||
|
"element_selected": "#2952a3",
|
||||||
|
"element_disabled": "#3366cc4d",
|
||||||
|
"secondary_foreground": "#2952a3",
|
||||||
|
"secondary_background": "#e6ecf5",
|
||||||
|
"secondary_hover": "#3366cc1a",
|
||||||
|
"secondary_active": "#d9e2f0",
|
||||||
|
"secondary_selected": "#d9e2f0",
|
||||||
|
"secondary_disabled": "#3366cc4d",
|
||||||
|
"danger_foreground": "#ffffff",
|
||||||
|
"danger_background": "#f5e6e6",
|
||||||
|
"danger_hover": "#cc33331a",
|
||||||
|
"danger_active": "#f0d9d9",
|
||||||
|
"danger_selected": "#f0d9d9",
|
||||||
|
"danger_disabled": "#cc33334d",
|
||||||
|
"warning_foreground": "#1a1a1a",
|
||||||
|
"warning_background": "#f5f0e6",
|
||||||
|
"warning_hover": "#cc99331a",
|
||||||
|
"warning_active": "#f0ead9",
|
||||||
|
"warning_selected": "#f0ead9",
|
||||||
|
"warning_disabled": "#cc99334d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#e6e6e6",
|
||||||
|
"ghost_element_hover": "#0000001a",
|
||||||
|
"ghost_element_active": "#d9d9d9",
|
||||||
|
"ghost_element_selected": "#d9d9d9",
|
||||||
|
"ghost_element_disabled": "#0000000d",
|
||||||
|
"tab_inactive_background": "#e6e6e6",
|
||||||
|
"tab_hover_background": "#e0e0e0",
|
||||||
|
"tab_active_background": "#d9d9d9",
|
||||||
|
"scrollbar_thumb_background": "#00000033",
|
||||||
|
"scrollbar_thumb_hover_background": "#0000004d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#d9d9d9",
|
||||||
|
"drop_target_background": "#3366cc1a",
|
||||||
|
"cursor": "#3399ff",
|
||||||
|
"selection": "#3399ff40"
|
||||||
|
},
|
||||||
|
"dark": {
|
||||||
|
"background": "#1a1a1a",
|
||||||
|
"surface_background": "#1f1f1f",
|
||||||
|
"elevated_surface_background": "#242424",
|
||||||
|
"panel_background": "#262626",
|
||||||
|
"overlay": "#ffffff1a",
|
||||||
|
"title_bar": "#00000000",
|
||||||
|
"title_bar_inactive": "#1a1a1a",
|
||||||
|
"window_border": "#404046",
|
||||||
|
"border": "#404040",
|
||||||
|
"border_variant": "#383838",
|
||||||
|
"border_focused": "#4d79d6",
|
||||||
|
"border_selected": "#4d79d6",
|
||||||
|
"border_transparent": "#00000000",
|
||||||
|
"border_disabled": "#2e2e2e",
|
||||||
|
"ring": "#668cdf",
|
||||||
|
"text": "#f2f2f2",
|
||||||
|
"text_muted": "#b3b3b3",
|
||||||
|
"text_placeholder": "#808080",
|
||||||
|
"text_accent": "#668cdf",
|
||||||
|
"icon": "#b3b3b3",
|
||||||
|
"icon_muted": "#808080",
|
||||||
|
"icon_accent": "#668cdf",
|
||||||
|
"element_foreground": "#ffffff",
|
||||||
|
"element_background": "#4d79d6",
|
||||||
|
"element_hover": "#4d79d6e6",
|
||||||
|
"element_active": "#456dc1",
|
||||||
|
"element_selected": "#3e62ac",
|
||||||
|
"element_disabled": "#4d79d64d",
|
||||||
|
"secondary_foreground": "#3e62ac",
|
||||||
|
"secondary_background": "#2a3652",
|
||||||
|
"secondary_hover": "#4d79d61a",
|
||||||
|
"secondary_active": "#303d5c",
|
||||||
|
"secondary_selected": "#303d5c",
|
||||||
|
"secondary_disabled": "#4d79d64d",
|
||||||
|
"danger_foreground": "#ffffff",
|
||||||
|
"danger_background": "#522a2a",
|
||||||
|
"danger_hover": "#d64d4d1a",
|
||||||
|
"danger_active": "#5c3030",
|
||||||
|
"danger_selected": "#5c3030",
|
||||||
|
"danger_disabled": "#d64d4d4d",
|
||||||
|
"warning_foreground": "#f2f2f2",
|
||||||
|
"warning_background": "#52482a",
|
||||||
|
"warning_hover": "#d6b34d1a",
|
||||||
|
"warning_active": "#5c5430",
|
||||||
|
"warning_selected": "#5c5430",
|
||||||
|
"warning_disabled": "#d6b34d4d",
|
||||||
|
"ghost_element_background": "#00000000",
|
||||||
|
"ghost_element_background_alt": "#2e2e2e",
|
||||||
|
"ghost_element_hover": "#ffffff1a",
|
||||||
|
"ghost_element_active": "#383838",
|
||||||
|
"ghost_element_selected": "#383838",
|
||||||
|
"ghost_element_disabled": "#ffffff0d",
|
||||||
|
"tab_inactive_background": "#2e2e2e",
|
||||||
|
"tab_hover_background": "#333333",
|
||||||
|
"tab_active_background": "#383838",
|
||||||
|
"scrollbar_thumb_background": "#ffffff33",
|
||||||
|
"scrollbar_thumb_hover_background": "#ffffff4d",
|
||||||
|
"scrollbar_thumb_border": "#00000000",
|
||||||
|
"scrollbar_track_background": "#00000000",
|
||||||
|
"scrollbar_track_border": "#383838",
|
||||||
|
"drop_target_background": "#4d79d61a",
|
||||||
|
"cursor": "#4db3ff",
|
||||||
|
"selection": "#4db3ff40"
|
||||||
|
}
|
||||||
|
}"##;
|
||||||
|
|
||||||
|
// Write the JSON to the file
|
||||||
|
fs::write(&file_path, json_data).unwrap();
|
||||||
|
|
||||||
|
// Test loading the theme from file
|
||||||
|
let theme = ThemeFamily::from_file(&file_path).unwrap();
|
||||||
|
|
||||||
|
// Verify the loaded theme
|
||||||
|
assert_eq!(theme.id, "test-theme");
|
||||||
|
assert_eq!(theme.name, "Test Theme");
|
||||||
|
|
||||||
|
// Clean up
|
||||||
|
dir.close().unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_from_file_nonexistent() {
|
||||||
|
// Test that loading a non-existent file returns an error
|
||||||
|
let result = ThemeFamily::from_file("non-existent-file.json");
|
||||||
|
assert!(result.is_err());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_from_file_invalid_json() {
|
||||||
|
// Create a temporary directory for our test
|
||||||
|
let dir = tempdir().unwrap();
|
||||||
|
let file_path = dir.path().join("invalid-theme.json");
|
||||||
|
|
||||||
|
// Write invalid JSON
|
||||||
|
fs::write(&file_path, "invalid json").unwrap();
|
||||||
|
|
||||||
|
// Test that loading invalid JSON returns an error
|
||||||
|
let result = ThemeFamily::from_file(&file_path);
|
||||||
|
assert!(result.is_err());
|
||||||
|
|
||||||
|
// Clean up
|
||||||
|
dir.close().unwrap();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -9,18 +9,20 @@ use gpui::{
|
|||||||
WindowControlArea,
|
WindowControlArea,
|
||||||
};
|
};
|
||||||
use smallvec::{smallvec, SmallVec};
|
use smallvec::{smallvec, SmallVec};
|
||||||
use theme::platform_kind::PlatformKind;
|
|
||||||
use theme::{ActiveTheme, CLIENT_SIDE_DECORATION_ROUNDING};
|
use theme::{ActiveTheme, CLIENT_SIDE_DECORATION_ROUNDING};
|
||||||
use ui::h_flex;
|
use ui::h_flex;
|
||||||
|
|
||||||
|
use crate::platform_kind::PlatformKind;
|
||||||
#[cfg(target_os = "linux")]
|
#[cfg(target_os = "linux")]
|
||||||
use crate::platforms::linux::LinuxWindowControls;
|
use crate::platforms::linux::LinuxWindowControls;
|
||||||
use crate::platforms::windows::WindowsWindowControls;
|
use crate::platforms::windows::WindowsWindowControls;
|
||||||
|
|
||||||
|
mod platform_kind;
|
||||||
mod platforms;
|
mod platforms;
|
||||||
|
|
||||||
pub struct TitleBar {
|
pub struct TitleBar {
|
||||||
children: SmallVec<[AnyElement; 2]>,
|
children: SmallVec<[AnyElement; 2]>,
|
||||||
|
platform_kind: PlatformKind,
|
||||||
should_move: bool,
|
should_move: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -34,6 +36,7 @@ impl TitleBar {
|
|||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
Self {
|
Self {
|
||||||
children: smallvec![],
|
children: smallvec![],
|
||||||
|
platform_kind: PlatformKind::platform(),
|
||||||
should_move: false,
|
should_move: false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -90,7 +93,7 @@ impl Render for TitleBar {
|
|||||||
.map(|this| {
|
.map(|this| {
|
||||||
if window.is_fullscreen() {
|
if window.is_fullscreen() {
|
||||||
this.px_2()
|
this.px_2()
|
||||||
} else if cx.theme().platform_kind.is_mac() {
|
} else if self.platform_kind.is_mac() {
|
||||||
this.pl(px(platforms::mac::TRAFFIC_LIGHT_PADDING))
|
this.pl(px(platforms::mac::TRAFFIC_LIGHT_PADDING))
|
||||||
.pr_2()
|
.pr_2()
|
||||||
.when(children.len() <= 1, |this| {
|
.when(children.len() <= 1, |this| {
|
||||||
@@ -120,14 +123,14 @@ impl Render for TitleBar {
|
|||||||
.items_center()
|
.items_center()
|
||||||
.justify_between()
|
.justify_between()
|
||||||
.w_full()
|
.w_full()
|
||||||
.when(cx.theme().platform_kind.is_mac(), |this| {
|
.when(self.platform_kind.is_mac(), |this| {
|
||||||
this.on_click(|event, window, _| {
|
this.on_click(|event, window, _| {
|
||||||
if event.click_count() == 2 {
|
if event.click_count() == 2 {
|
||||||
window.titlebar_double_click();
|
window.titlebar_double_click();
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.when(cx.theme().platform_kind.is_linux(), |this| {
|
.when(self.platform_kind.is_linux(), |this| {
|
||||||
this.on_click(|event, window, _| {
|
this.on_click(|event, window, _| {
|
||||||
if event.click_count() == 2 {
|
if event.click_count() == 2 {
|
||||||
window.zoom_window();
|
window.zoom_window();
|
||||||
@@ -136,47 +139,45 @@ impl Render for TitleBar {
|
|||||||
})
|
})
|
||||||
.children(children),
|
.children(children),
|
||||||
)
|
)
|
||||||
.when(!window.is_fullscreen(), |this| {
|
.when(!window.is_fullscreen(), |this| match self.platform_kind {
|
||||||
match cx.theme().platform_kind {
|
PlatformKind::Linux => {
|
||||||
PlatformKind::Linux => {
|
#[cfg(target_os = "linux")]
|
||||||
#[cfg(target_os = "linux")]
|
if matches!(decorations, Decorations::Client { .. }) {
|
||||||
if matches!(decorations, Decorations::Client { .. }) {
|
this.child(LinuxWindowControls::new(None))
|
||||||
this.child(LinuxWindowControls::new(None))
|
.when(supported_controls.window_menu, |this| {
|
||||||
.when(supported_controls.window_menu, |this| {
|
this.on_mouse_down(MouseButton::Right, move |ev, window, _| {
|
||||||
this.on_mouse_down(MouseButton::Right, move |ev, window, _| {
|
window.show_window_menu(ev.position)
|
||||||
window.show_window_menu(ev.position)
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
.on_mouse_move(cx.listener(move |this, _ev, window, _| {
|
})
|
||||||
if this.should_move {
|
.on_mouse_move(cx.listener(move |this, _ev, window, _| {
|
||||||
this.should_move = false;
|
if this.should_move {
|
||||||
window.start_window_move();
|
|
||||||
}
|
|
||||||
}))
|
|
||||||
.on_mouse_down_out(cx.listener(move |this, _ev, _window, _cx| {
|
|
||||||
this.should_move = false;
|
this.should_move = false;
|
||||||
}))
|
window.start_window_move();
|
||||||
.on_mouse_up(
|
}
|
||||||
MouseButton::Left,
|
}))
|
||||||
cx.listener(move |this, _ev, _window, _cx| {
|
.on_mouse_down_out(cx.listener(move |this, _ev, _window, _cx| {
|
||||||
this.should_move = false;
|
this.should_move = false;
|
||||||
}),
|
}))
|
||||||
)
|
.on_mouse_up(
|
||||||
.on_mouse_down(
|
MouseButton::Left,
|
||||||
MouseButton::Left,
|
cx.listener(move |this, _ev, _window, _cx| {
|
||||||
cx.listener(move |this, _ev, _window, _cx| {
|
this.should_move = false;
|
||||||
this.should_move = true;
|
}),
|
||||||
}),
|
)
|
||||||
)
|
.on_mouse_down(
|
||||||
} else {
|
MouseButton::Left,
|
||||||
this
|
cx.listener(move |this, _ev, _window, _cx| {
|
||||||
}
|
this.should_move = true;
|
||||||
#[cfg(not(target_os = "linux"))]
|
}),
|
||||||
|
)
|
||||||
|
} else {
|
||||||
this
|
this
|
||||||
}
|
}
|
||||||
PlatformKind::Windows => this.child(WindowsWindowControls::new(height)),
|
#[cfg(not(target_os = "linux"))]
|
||||||
PlatformKind::Mac => this,
|
this
|
||||||
}
|
}
|
||||||
|
PlatformKind::Windows => this.child(WindowsWindowControls::new(height)),
|
||||||
|
PlatformKind::Mac => this,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,14 +16,17 @@ impl PlatformKind {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub fn is_linux(&self) -> bool {
|
pub fn is_linux(&self) -> bool {
|
||||||
matches!(self, Self::Linux)
|
matches!(self, Self::Linux)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub fn is_windows(&self) -> bool {
|
pub fn is_windows(&self) -> bool {
|
||||||
matches!(self, Self::Windows)
|
matches!(self, Self::Windows)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
pub fn is_mac(&self) -> bool {
|
pub fn is_mac(&self) -> bool {
|
||||||
matches!(self, Self::Mac)
|
matches!(self, Self::Mac)
|
||||||
}
|
}
|
||||||
@@ -309,7 +309,7 @@ impl DockItem {
|
|||||||
|
|
||||||
pub(crate) fn focus_tab_panel(&self, window: &mut Window, cx: &mut App) {
|
pub(crate) fn focus_tab_panel(&self, window: &mut Window, cx: &mut App) {
|
||||||
if let DockItem::Tabs { view, .. } = self {
|
if let DockItem::Tabs { view, .. } = self {
|
||||||
window.focus(&view.read(cx).focus_handle(cx));
|
window.focus(&view.read(cx).focus_handle(cx), cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -53,9 +53,9 @@ impl Render for DragPanel {
|
|||||||
.justify_center()
|
.justify_center()
|
||||||
.overflow_hidden()
|
.overflow_hidden()
|
||||||
.whitespace_nowrap()
|
.whitespace_nowrap()
|
||||||
.rounded(cx.theme().radius)
|
.rounded(cx.theme().radius_lg)
|
||||||
.text_xs()
|
.text_xs()
|
||||||
.shadow_lg()
|
.when(cx.theme().shadow, |this| this.shadow_lg())
|
||||||
.bg(cx.theme().background)
|
.bg(cx.theme().background)
|
||||||
.text_color(cx.theme().text_accent)
|
.text_color(cx.theme().text_accent)
|
||||||
.child(self.panel.title(cx))
|
.child(self.panel.title(cx))
|
||||||
@@ -651,8 +651,8 @@ impl TabPanel {
|
|||||||
.child(
|
.child(
|
||||||
div()
|
div()
|
||||||
.size_full()
|
.size_full()
|
||||||
.rounded_xl()
|
.rounded(cx.theme().radius_lg)
|
||||||
.shadow_sm()
|
.when(cx.theme().shadow, |this| this.shadow_sm())
|
||||||
.when(cx.theme().mode.is_dark(), |this| this.shadow_lg())
|
.when(cx.theme().mode.is_dark(), |this| this.shadow_lg())
|
||||||
.bg(cx.theme().panel_background)
|
.bg(cx.theme().panel_background)
|
||||||
.overflow_hidden()
|
.overflow_hidden()
|
||||||
@@ -671,7 +671,7 @@ impl TabPanel {
|
|||||||
.p_1()
|
.p_1()
|
||||||
.child(
|
.child(
|
||||||
div()
|
div()
|
||||||
.rounded_xl()
|
.rounded(cx.theme().radius_lg)
|
||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().element_disabled)
|
.border_color(cx.theme().element_disabled)
|
||||||
.bg(cx.theme().drop_target_background)
|
.bg(cx.theme().drop_target_background)
|
||||||
@@ -898,7 +898,7 @@ impl TabPanel {
|
|||||||
|
|
||||||
fn focus_active_panel(&self, window: &mut Window, cx: &mut Context<Self>) {
|
fn focus_active_panel(&self, window: &mut Window, cx: &mut Context<Self>) {
|
||||||
if let Some(active_panel) = self.active_panel(cx) {
|
if let Some(active_panel) = self.active_panel(cx) {
|
||||||
window.focus(&active_panel.focus_handle(cx));
|
window.focus(&active_panel.focus_handle(cx), cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -426,8 +426,8 @@ where
|
|||||||
self.selected_value.as_ref()
|
self.selected_value.as_ref()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn focus(&self, window: &mut Window, _: &mut App) {
|
pub fn focus(&self, window: &mut Window, cx: &mut App) {
|
||||||
self.focus_handle.focus(window);
|
self.focus_handle.focus(window, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn on_blur(&mut self, window: &mut Window, cx: &mut Context<Self>) {
|
fn on_blur(&mut self, window: &mut Window, cx: &mut Context<Self>) {
|
||||||
@@ -445,7 +445,7 @@ where
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
self.list.focus_handle(cx).focus(window);
|
self.list.focus_handle(cx).focus(window, cx);
|
||||||
cx.propagate();
|
cx.propagate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -454,7 +454,7 @@ where
|
|||||||
self.open = true;
|
self.open = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
self.list.focus_handle(cx).focus(window);
|
self.list.focus_handle(cx).focus(window, cx);
|
||||||
cx.propagate();
|
cx.propagate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -466,7 +466,7 @@ where
|
|||||||
self.open = true;
|
self.open = true;
|
||||||
cx.notify();
|
cx.notify();
|
||||||
} else {
|
} else {
|
||||||
self.list.focus_handle(cx).focus(window);
|
self.list.focus_handle(cx).focus(window, cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -475,7 +475,7 @@ where
|
|||||||
|
|
||||||
self.open = !self.open;
|
self.open = !self.open;
|
||||||
if self.open {
|
if self.open {
|
||||||
self.list.focus_handle(cx).focus(window);
|
self.list.focus_handle(cx).focus(window, cx);
|
||||||
}
|
}
|
||||||
cx.notify();
|
cx.notify();
|
||||||
}
|
}
|
||||||
@@ -708,7 +708,7 @@ where
|
|||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border)
|
.border_color(cx.theme().border)
|
||||||
.rounded(cx.theme().radius)
|
.rounded(cx.theme().radius)
|
||||||
.shadow_sm()
|
.when(cx.theme().shadow, |this| this.shadow_sm())
|
||||||
.overflow_hidden()
|
.overflow_hidden()
|
||||||
.input_font_size(self.size)
|
.input_font_size(self.size)
|
||||||
.map(|this| match self.width {
|
.map(|this| match self.width {
|
||||||
@@ -793,7 +793,7 @@ where
|
|||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border)
|
.border_color(cx.theme().border)
|
||||||
.rounded(popup_radius)
|
.rounded(popup_radius)
|
||||||
.shadow_md()
|
.when(cx.theme().shadow, |this| this.shadow_md())
|
||||||
.child(state.list.clone()),
|
.child(state.list.clone()),
|
||||||
)
|
)
|
||||||
.on_mouse_down_out(window.listener_for(
|
.on_mouse_down_out(window.listener_for(
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ pub trait FocusableCycle {
|
|||||||
.nth(1)
|
.nth(1)
|
||||||
.unwrap_or(fallback_handle);
|
.unwrap_or(fallback_handle);
|
||||||
|
|
||||||
target_focus_handle.focus(window);
|
target_focus_handle.focus(window, cx);
|
||||||
cx.stop_propagation();
|
cx.stop_propagation();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -859,7 +859,7 @@ impl Element for TextElement {
|
|||||||
let p = point(input_bounds.origin.x, origin.y + offset_y);
|
let p = point(input_bounds.origin.x, origin.y + offset_y);
|
||||||
|
|
||||||
for line in lines {
|
for line in lines {
|
||||||
_ = line.paint(p, line_height, window, cx);
|
_ = line.paint(p, line_height, TextAlign::Left, None, window, cx);
|
||||||
offset_y += line_height;
|
offset_y += line_height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -766,7 +766,7 @@ impl InputState {
|
|||||||
|
|
||||||
/// Focus the input field.
|
/// Focus the input field.
|
||||||
pub fn focus(&self, window: &mut Window, cx: &mut Context<Self>) {
|
pub fn focus(&self, window: &mut Window, cx: &mut Context<Self>) {
|
||||||
self.focus_handle.focus(window);
|
self.focus_handle.focus(window, cx);
|
||||||
self.blink_cursor.update(cx, |cursor, cx| {
|
self.blink_cursor.update(cx, |cursor, cx| {
|
||||||
cursor.start(cx);
|
cursor.start(cx);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -45,7 +45,6 @@ mod window_border;
|
|||||||
/// This must be called before using any of the UI components.
|
/// This must be called before using any of the UI components.
|
||||||
/// You can initialize the UI module at your application's entry point.
|
/// You can initialize the UI module at your application's entry point.
|
||||||
pub fn init(cx: &mut gpui::App) {
|
pub fn init(cx: &mut gpui::App) {
|
||||||
theme::init(cx);
|
|
||||||
dropdown::init(cx);
|
dropdown::init(cx);
|
||||||
input::init(cx);
|
input::init(cx);
|
||||||
list::init(cx);
|
list::init(cx);
|
||||||
|
|||||||
@@ -244,7 +244,7 @@ where
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn focus(&mut self, window: &mut Window, cx: &mut App) {
|
pub fn focus(&mut self, window: &mut Window, cx: &mut App) {
|
||||||
self.focus_handle(cx).focus(window);
|
self.focus_handle(cx).focus(window, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Set the selected index of the list, this will also scroll to the selected item.
|
/// Set the selected index of the list, this will also scroll to the selected item.
|
||||||
|
|||||||
@@ -145,7 +145,7 @@ impl AppMenu {
|
|||||||
})
|
})
|
||||||
.with_menu_items(items, window, cx)
|
.with_menu_items(items, window, cx)
|
||||||
});
|
});
|
||||||
popup_menu.read(cx).focus_handle(cx).focus(window);
|
popup_menu.read(cx).focus_handle(cx).focus(window, cx);
|
||||||
self._subscription =
|
self._subscription =
|
||||||
Some(cx.subscribe_in(&popup_menu, window, Self::handle_dismiss));
|
Some(cx.subscribe_in(&popup_menu, window, Self::handle_dismiss));
|
||||||
self.popup_menu = Some(popup_menu.clone());
|
self.popup_menu = Some(popup_menu.clone());
|
||||||
@@ -157,7 +157,7 @@ impl AppMenu {
|
|||||||
|
|
||||||
let focus_handle = popup_menu.read(cx).focus_handle(cx);
|
let focus_handle = popup_menu.read(cx).focus_handle(cx);
|
||||||
if !focus_handle.contains_focused(window, cx) {
|
if !focus_handle.contains_focused(window, cx) {
|
||||||
focus_handle.focus(window);
|
focus_handle.focus(window, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
popup_menu
|
popup_menu
|
||||||
|
|||||||
@@ -156,7 +156,7 @@ impl Element for ContextMenu {
|
|||||||
.when_some(menu_view, |this, menu| {
|
.when_some(menu_view, |this, menu| {
|
||||||
// Focus the menu, so that can be handle the action.
|
// Focus the menu, so that can be handle the action.
|
||||||
if !menu.focus_handle(cx).contains_focused(window, cx) {
|
if !menu.focus_handle(cx).contains_focused(window, cx) {
|
||||||
menu.focus_handle(cx).focus(window);
|
menu.focus_handle(cx).focus(window, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.child(div().occlude().child(menu.clone()))
|
this.child(div().occlude().child(menu.clone()))
|
||||||
|
|||||||
@@ -659,7 +659,7 @@ impl PopupMenu {
|
|||||||
cx: &mut Context<Self>,
|
cx: &mut Context<Self>,
|
||||||
) {
|
) {
|
||||||
if let Some(context) = self.action_context.as_ref() {
|
if let Some(context) = self.action_context.as_ref() {
|
||||||
context.focus(window);
|
context.focus(window, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
window.dispatch_action(action.boxed_clone(), cx);
|
window.dispatch_action(action.boxed_clone(), cx);
|
||||||
@@ -759,7 +759,7 @@ impl PopupMenu {
|
|||||||
// Focus the submenu, so that can be handle the action.
|
// Focus the submenu, so that can be handle the action.
|
||||||
active_submenu.update(cx, |view, cx| {
|
active_submenu.update(cx, |view, cx| {
|
||||||
view.set_selected_index(0, cx);
|
view.set_selected_index(0, cx);
|
||||||
view.focus_handle.focus(window);
|
view.focus_handle.focus(window, cx);
|
||||||
});
|
});
|
||||||
cx.notify();
|
cx.notify();
|
||||||
return true;
|
return true;
|
||||||
@@ -790,7 +790,7 @@ impl PopupMenu {
|
|||||||
|
|
||||||
self.selected_index = None;
|
self.selected_index = None;
|
||||||
parent.update(cx, |view, cx| {
|
parent.update(cx, |view, cx| {
|
||||||
view.focus_handle.focus(window);
|
view.focus_handle.focus(window, cx);
|
||||||
cx.notify();
|
cx.notify();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -819,7 +819,7 @@ impl PopupMenu {
|
|||||||
|
|
||||||
// Focus back to the previous focused handle.
|
// Focus back to the previous focused handle.
|
||||||
if let Some(action_context) = self.action_context.as_ref() {
|
if let Some(action_context) = self.action_context.as_ref() {
|
||||||
window.focus(action_context);
|
window.focus(action_context, cx);
|
||||||
}
|
}
|
||||||
|
|
||||||
let Some(parent_menu) = self.parent_menu.clone() else {
|
let Some(parent_menu) = self.parent_menu.clone() else {
|
||||||
|
|||||||
@@ -342,7 +342,7 @@ impl RenderOnce for Modal {
|
|||||||
});
|
});
|
||||||
|
|
||||||
let window_paddings = crate::window_border::window_paddings(window, cx);
|
let window_paddings = crate::window_border::window_paddings(window, cx);
|
||||||
let radius = (cx.theme().radius * 2.).min(px(20.));
|
let radius = (cx.theme().radius_lg * 2.).min(px(20.));
|
||||||
|
|
||||||
let view_size = window.viewport_size()
|
let view_size = window.viewport_size()
|
||||||
- gpui::size(
|
- gpui::size(
|
||||||
@@ -407,7 +407,7 @@ impl RenderOnce for Modal {
|
|||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border.alpha(0.4))
|
.border_color(cx.theme().border.alpha(0.4))
|
||||||
.rounded(radius)
|
.rounded(radius)
|
||||||
.shadow_xl()
|
.when(cx.theme().shadow, |this| this.shadow_xl())
|
||||||
.min_h_24()
|
.min_h_24()
|
||||||
.key_context(CONTEXT)
|
.key_context(CONTEXT)
|
||||||
.track_focus(&self.focus_handle)
|
.track_focus(&self.focus_handle)
|
||||||
|
|||||||
@@ -295,8 +295,8 @@ impl Render for Notification {
|
|||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border)
|
.border_color(cx.theme().border)
|
||||||
.bg(cx.theme().surface_background)
|
.bg(cx.theme().surface_background)
|
||||||
.rounded(cx.theme().radius * 1.6)
|
.rounded(cx.theme().radius_lg)
|
||||||
.shadow_md()
|
.when(cx.theme().shadow, |this| this.shadow_md())
|
||||||
.p_2()
|
.p_2()
|
||||||
.gap_3()
|
.gap_3()
|
||||||
.justify_start()
|
.justify_start()
|
||||||
|
|||||||
@@ -445,7 +445,7 @@ impl<M: ManagedView> Element for Popover<M> {
|
|||||||
if let Some(previous_focus_handle) =
|
if let Some(previous_focus_handle) =
|
||||||
previous_focus_handle.as_ref()
|
previous_focus_handle.as_ref()
|
||||||
{
|
{
|
||||||
window.focus(previous_focus_handle);
|
window.focus(previous_focus_handle, cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*old_content_view1.borrow_mut() = None;
|
*old_content_view1.borrow_mut() = None;
|
||||||
@@ -455,7 +455,7 @@ impl<M: ManagedView> Element for Popover<M> {
|
|||||||
)
|
)
|
||||||
.detach();
|
.detach();
|
||||||
|
|
||||||
window.focus(&new_content_view.focus_handle(cx));
|
window.focus(&new_content_view.focus_handle(cx), cx);
|
||||||
*old_content_view.borrow_mut() = Some(new_content_view);
|
*old_content_view.borrow_mut() = Some(new_content_view);
|
||||||
window.refresh();
|
window.refresh();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -60,7 +60,7 @@ impl ContextModal for Window {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let focus_handle = cx.focus_handle();
|
let focus_handle = cx.focus_handle();
|
||||||
focus_handle.focus(window);
|
focus_handle.focus(window, cx);
|
||||||
|
|
||||||
root.active_modals.push(ActiveModal {
|
root.active_modals.push(ActiveModal {
|
||||||
focus_handle,
|
focus_handle,
|
||||||
@@ -81,7 +81,7 @@ impl ContextModal for Window {
|
|||||||
|
|
||||||
if let Some(top_modal) = root.active_modals.last() {
|
if let Some(top_modal) = root.active_modals.last() {
|
||||||
// Focus the next modal.
|
// Focus the next modal.
|
||||||
top_modal.focus_handle.focus(window);
|
top_modal.focus_handle.focus(window, cx);
|
||||||
} else {
|
} else {
|
||||||
// Restore focus if there are no more modals.
|
// Restore focus if there are no more modals.
|
||||||
root.focus_back(window, cx);
|
root.focus_back(window, cx);
|
||||||
@@ -188,9 +188,9 @@ impl Root {
|
|||||||
.read(cx)
|
.read(cx)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn focus_back(&mut self, window: &mut Window, _: &mut App) {
|
fn focus_back(&mut self, window: &mut Window, cx: &mut App) {
|
||||||
if let Some(handle) = self.previous_focus_handle.clone() {
|
if let Some(handle) = self.previous_focus_handle.clone() {
|
||||||
window.focus(&handle);
|
window.focus(&handle, cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,7 +9,6 @@ use gpui::{
|
|||||||
IntoElement, LayoutId, MouseDownEvent, MouseMoveEvent, MouseUpEvent, PaintQuad, Pixels, Point,
|
IntoElement, LayoutId, MouseDownEvent, MouseMoveEvent, MouseUpEvent, PaintQuad, Pixels, Point,
|
||||||
Position, ScrollHandle, ScrollWheelEvent, Size, UniformListScrollHandle, Window,
|
Position, ScrollHandle, ScrollWheelEvent, Size, UniformListScrollHandle, Window,
|
||||||
};
|
};
|
||||||
use theme::scrollbar_mode::ScrollBarMode;
|
|
||||||
use theme::ActiveTheme;
|
use theme::ActiveTheme;
|
||||||
|
|
||||||
use crate::AxisExt;
|
use crate::AxisExt;
|
||||||
@@ -355,9 +354,10 @@ impl Scrollbar {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn style_for_idle(cx: &App) -> (Hsla, Hsla, Hsla, Pixels, Pixels, Pixels) {
|
fn style_for_idle(cx: &App) -> (Hsla, Hsla, Hsla, Pixels, Pixels, Pixels) {
|
||||||
let (width, inset, radius) = match cx.theme().scrollbar_mode {
|
let (width, inset, radius) = if cx.theme().scrollbar_mode.is_scrolling() {
|
||||||
ScrollBarMode::Scrolling => (THUMB_WIDTH, THUMB_INSET, THUMB_RADIUS),
|
(THUMB_WIDTH, THUMB_INSET, THUMB_RADIUS)
|
||||||
_ => (THUMB_ACTIVE_WIDTH, THUMB_ACTIVE_INSET, THUMB_ACTIVE_RADIUS),
|
} else {
|
||||||
|
(THUMB_ACTIVE_WIDTH, THUMB_ACTIVE_INSET, THUMB_ACTIVE_RADIUS)
|
||||||
};
|
};
|
||||||
|
|
||||||
(
|
(
|
||||||
|
|||||||
@@ -78,7 +78,7 @@ pub trait StyledExt: Styled + Sized {
|
|||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border)
|
.border_color(cx.theme().border)
|
||||||
.shadow_lg()
|
.shadow_lg()
|
||||||
.rounded_lg()
|
.rounded(cx.theme().radius_lg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -181,7 +181,7 @@ impl Element for Switch {
|
|||||||
// Switch Toggle
|
// Switch Toggle
|
||||||
div()
|
div()
|
||||||
.rounded_full()
|
.rounded_full()
|
||||||
.shadow_sm()
|
.when(cx.theme().shadow, |this| this.shadow_sm())
|
||||||
.bg(toggle_bg)
|
.bg(toggle_bg)
|
||||||
.size(bar_width)
|
.size(bar_width)
|
||||||
.map(|this| {
|
.map(|this| {
|
||||||
|
|||||||
@@ -115,7 +115,7 @@ impl RenderOnce for Tab {
|
|||||||
.text_ellipsis()
|
.text_ellipsis()
|
||||||
.text_color(text_color)
|
.text_color(text_color)
|
||||||
.bg(bg_color)
|
.bg(bg_color)
|
||||||
.rounded(cx.theme().radius)
|
.rounded(cx.theme().radius_lg)
|
||||||
.hover(|this| this.bg(hover_bg_color))
|
.hover(|this| this.bg(hover_bg_color))
|
||||||
.when_some(self.prefix, |this, prefix| {
|
.when_some(self.prefix, |this, prefix| {
|
||||||
this.child(prefix).text_color(text_color)
|
this.child(prefix).text_color(text_color)
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
use gpui::prelude::FluentBuilder;
|
||||||
use gpui::{
|
use gpui::{
|
||||||
div, relative, App, AppContext, Context, Entity, IntoElement, ParentElement, Render,
|
div, relative, App, AppContext, Context, Entity, IntoElement, ParentElement, Render,
|
||||||
SharedString, Styled, Window,
|
SharedString, Styled, Window,
|
||||||
@@ -24,8 +25,8 @@ impl Render for Tooltip {
|
|||||||
.border_1()
|
.border_1()
|
||||||
.border_color(cx.theme().border)
|
.border_color(cx.theme().border)
|
||||||
.bg(cx.theme().surface_background)
|
.bg(cx.theme().surface_background)
|
||||||
.shadow_md()
|
.when(cx.theme().shadow, |this| this.shadow_md())
|
||||||
.rounded_lg()
|
.rounded(cx.theme().radius_lg)
|
||||||
.text_sm()
|
.text_sm()
|
||||||
.text_color(cx.theme().text_muted)
|
.text_color(cx.theme().text_muted)
|
||||||
.line_height(relative(1.25))
|
.line_height(relative(1.25))
|
||||||
|
|||||||
Reference in New Issue
Block a user