From 5a1ff5e7edbcf812cd96023c177a238f31bd5f22 Mon Sep 17 00:00:00 2001 From: Casper Rogild Storm Date: Thu, 7 Mar 2024 21:35:25 +0100 Subject: [PATCH] iced is now running master --- Cargo.lock | 1899 +++++++++++++-------------- Cargo.toml | 6 +- data/Cargo.toml | 2 +- data/src/client.rs | 2 +- data/src/time.rs | 5 +- src/buffer/channel.rs | 92 +- src/buffer/channel/topic.rs | 38 +- src/buffer/query.rs | 36 +- src/buffer/scroll_view.rs | 32 +- src/buffer/server.rs | 22 +- src/buffer/user_context.rs | 7 +- src/icon.rs | 2 +- src/main.rs | 2 +- src/screen/dashboard.rs | 4 +- src/screen/dashboard/command_bar.rs | 3 +- src/screen/dashboard/pane.rs | 34 +- src/screen/dashboard/side_menu.rs | 44 +- src/screen/help.rs | 14 +- src/screen/welcome.rs | 30 +- src/theme.rs | 648 +-------- src/theme/button.rs | 324 +++++ src/theme/container.rs | 109 ++ src/theme/menu.rs | 48 + src/theme/pane_grid.rs | 33 + src/theme/rule.rs | 18 + src/theme/scrollable.rs | 81 ++ src/theme/selectable_text.rs | 62 + src/theme/text.rs | 66 + src/theme/text_input.rs | 58 + src/widget.rs | 1 - src/widget/anchored_overlay.rs | 38 +- src/widget/combo_box.rs | 76 +- src/widget/context_menu.rs | 34 +- src/widget/double_click.rs | 5 +- src/widget/double_pass.rs | 5 +- src/widget/hover.rs | 12 +- src/widget/input.rs | 8 +- src/widget/input/completion.rs | 24 +- src/widget/key_press.rs | 7 +- src/widget/selectable_text.rs | 46 +- src/widget/shortcut.rs | 5 +- 41 files changed, 2072 insertions(+), 1910 deletions(-) create mode 100644 src/theme/button.rs create mode 100644 src/theme/container.rs create mode 100644 src/theme/menu.rs create mode 100644 src/theme/pane_grid.rs create mode 100644 src/theme/rule.rs create mode 100644 src/theme/scrollable.rs create mode 100644 src/theme/selectable_text.rs create mode 100644 src/theme/text.rs create mode 100644 src/theme/text_input.rs diff --git a/Cargo.lock b/Cargo.lock index edebdccb0..a340c52ce 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -4,9 +4,9 @@ version = 3 [[package]] name = "ab_glyph" -version = "0.2.21" +version = "0.2.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5110f1c78cf582855d895ecd0746b653db010cec6d9f5575293f27934d980a39" +checksum = "80179d7dd5d7e8c285d67c4a1e652972a92de7475beddfb92028c76463b13225" dependencies = [ "ab_glyph_rasterizer", "owned_ttf_parser", @@ -20,9 +20,9 @@ checksum = "c71b1793ee61086797f5c80b6efa2b8ffa6d5dd703f118545808a7f2e27f7046" [[package]] name = "addr2line" -version = "0.19.0" +version = "0.21.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a76fd60b23679b7d19bd066031410fb7e458ccc5e958eb5c325888ce4baedc97" +checksum = "8a30b2e23b9e17a9f90641c7ab1549cd9b44f296d3ccbf309d2863cfe398a0cb" dependencies = [ "gimli", ] @@ -35,20 +35,9 @@ checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" [[package]] name = "ahash" -version = "0.7.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fcb51a0695d8f838b1ee009b3fbf66bda078cd64590202a864a8f3e8c4315c47" -dependencies = [ - "getrandom", - "once_cell", - "version_check", -] - -[[package]] -name = "ahash" -version = "0.8.7" +version = "0.8.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "77c3a9648d43b9cd48db467b3f87fdd6e146bcc88ab0180006cef2179fe11d01" +checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011" dependencies = [ "cfg-if", "getrandom", @@ -59,9 +48,9 @@ dependencies = [ [[package]] name = "aho-corasick" -version = "1.0.1" +version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "67fc08ce920c31afb70f013dcce1bfc3a3195de6a228474e45e1f145b36f8d04" +checksum = "b2969dcb958b36655471fc61f7e416fa76033bdd4bfed0678d8fee1e2d07a1f0" dependencies = [ "memchr", ] @@ -80,9 +69,9 @@ checksum = "0942ffc6dcaadf03badf6e6a2d0228460359d5e34b57ccdc720b7382dfbd5ec5" [[package]] name = "android-activity" -version = "0.5.1" +version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39b801912a977c3fd52d80511fe1c0c8480c6f957f21ae2ce1b92ffe970cf4b9" +checksum = "ee91c0c2905bae44f84bfa4e044536541df26b7703fd0888deeb9060fcc44289" dependencies = [ "android-properties", "bitflags 2.4.2", @@ -137,9 +126,9 @@ checksum = "6b4930d2cb77ce62f89ee5d5289b4ac049559b1c45539271f5ed4fdc7db34545" [[package]] name = "arrayvec" -version = "0.7.2" +version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8da52d66c7071e2e3fa2a1e5c6d088fec47b593032b254f5e980de8ea54454d6" +checksum = "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" [[package]] name = "as-raw-xcb-connection" @@ -162,32 +151,34 @@ version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7c48ccdbf6ca6b121e0f586cbc0e73ae440e56c67c30fa0873b4e110d9c26d2b" dependencies = [ - "event-listener", + "event-listener 2.5.3", "futures-core", ] [[package]] name = "async-channel" -version = "1.9.0" +version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "81953c529336010edd6d8e358f886d9581267795c61b19475b71314bffa46d35" +checksum = "f28243a43d821d11341ab73c80bed182dc015c514b951616cf79bd4af39af0c3" dependencies = [ "concurrent-queue", - "event-listener", + "event-listener 5.2.0", + "event-listener-strategy 0.5.0", "futures-core", + "pin-project-lite", ] [[package]] name = "async-executor" -version = "1.5.1" +version = "1.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6fa3dc5f2a8564f07759c008b9109dc0d39de92a88d5588b8a5036d286383afb" +checksum = "17ae5ebefcc48e7452b4987947920dac9450be1110cadf34d1b8c116bdbaf97c" dependencies = [ - "async-lock", + "async-lock 3.3.0", "async-task", "concurrent-queue", - "fastrand 1.9.0", - "futures-lite", + "fastrand 2.0.1", + "futures-lite 2.2.0", "slab", ] @@ -197,10 +188,10 @@ version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "279cf904654eeebfa37ac9bb1598880884924aab82e290aa65c9e77a0e142e06" dependencies = [ - "async-lock", + "async-lock 2.8.0", "autocfg", "blocking", - "futures-lite", + "futures-lite 1.13.0", ] [[package]] @@ -209,80 +200,127 @@ version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fc5b45d93ef0529756f812ca52e44c221b35341892d3dcc34132ac02f3dd2af" dependencies = [ - "async-lock", + "async-lock 2.8.0", "autocfg", "cfg-if", "concurrent-queue", - "futures-lite", + "futures-lite 1.13.0", "log", "parking", "polling 2.8.0", - "rustix 0.37.19", + "rustix 0.37.27", "slab", - "socket2", + "socket2 0.4.10", "waker-fn", ] +[[package]] +name = "async-io" +version = "2.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dcccb0f599cfa2f8ace422d3555572f47424da5648a4382a9dd0310ff8210884" +dependencies = [ + "async-lock 3.3.0", + "cfg-if", + "concurrent-queue", + "futures-io", + "futures-lite 2.2.0", + "parking", + "polling 3.5.0", + "rustix 0.38.31", + "slab", + "tracing", + "windows-sys 0.52.0", +] + +[[package]] +name = "async-lock" +version = "2.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "287272293e9d8c41773cec55e365490fe034813a2f172f502d6ddcf75b2f582b" +dependencies = [ + "event-listener 2.5.3", +] + [[package]] name = "async-lock" -version = "2.7.0" +version = "3.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fa24f727524730b077666307f2734b4a1a1c57acb79193127dcc8914d5242dd7" +checksum = "d034b430882f8381900d3fe6f0aaa3ad94f2cb4ac519b429692a1bc2dda4ae7b" dependencies = [ - "event-listener", + "event-listener 4.0.3", + "event-listener-strategy 0.4.0", + "pin-project-lite", ] [[package]] name = "async-process" -version = "1.7.0" +version = "1.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7a9d28b1d97e08915212e2e45310d47854eafa69600756fc735fb788f75199c9" +checksum = "ea6438ba0a08d81529c69b36700fa2f95837bfe3e776ab39cde9c14d9149da88" dependencies = [ - "async-io", - "async-lock", - "autocfg", + "async-io 1.13.0", + "async-lock 2.8.0", + "async-signal", "blocking", "cfg-if", - "event-listener", - "futures-lite", - "rustix 0.37.19", - "signal-hook", + "event-listener 3.1.0", + "futures-lite 1.13.0", + "rustix 0.38.31", "windows-sys 0.48.0", ] [[package]] name = "async-recursion" -version = "1.0.4" +version = "1.0.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0e97ce7de6cf12de5d7226c73f5ba9811622f4db3a5b91b55c53e987e5f91cba" +checksum = "5fd55a5ba1179988837d24ab4c7cc8ed6efdeff578ede0416b4225a5fca35bd0" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", +] + +[[package]] +name = "async-signal" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e47d90f65a225c4527103a8d747001fc56e375203592b25ad103e1ca13124c5" +dependencies = [ + "async-io 2.3.2", + "async-lock 2.8.0", + "atomic-waker", + "cfg-if", + "futures-core", + "futures-io", + "rustix 0.38.31", + "signal-hook-registry", + "slab", + "windows-sys 0.48.0", ] [[package]] name = "async-task" -version = "4.4.0" +version = "4.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ecc7ab41815b3c653ccd2978ec3255c81349336702dfdf62ee6f7069b12a3aae" +checksum = "fbb36e985947064623dbd357f727af08ffd077f93d696782f3c56365fa2e2799" [[package]] name = "async-trait" -version = "0.1.69" +version = "0.1.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b2d0f03b3640e3a630367e40c468cb7f309529c708ed1d88597047b0e7c6ef7" +checksum = "c980ee35e870bd1a4d2c8294d4c04d0499e67bca1e4b5cefcc693c2fa00caea9" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "atomic-waker" -version = "1.1.1" +version = "1.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1181e1e0d1fce796a03db1ae795d67167da795f9cf4a39c37589e85ef57f26d3" +checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0" [[package]] name = "autocfg" @@ -292,24 +330,24 @@ checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" [[package]] name = "backtrace" -version = "0.3.67" +version = "0.3.69" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "233d376d6d185f2a3093e58f283f60f880315b6c60075b01f36b3b85154564ca" +checksum = "2089b7e3f35b9dd2d0ed921ead4f6d318c27680d4a5bd167b3ee120edb105837" dependencies = [ "addr2line", "cc", "cfg-if", "libc", - "miniz_oxide 0.6.2", + "miniz_oxide", "object", "rustc-demangle", ] [[package]] name = "base64" -version = "0.21.2" +version = "0.21.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "604178f6c5c21f02dc555784810edfb88d34ac2c73b2eae109655649ee73ce3d" +checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" [[package]] name = "bit-set" @@ -380,56 +418,57 @@ dependencies = [ [[package]] name = "blocking" -version = "1.3.1" +version = "1.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "77231a1c8f801696fc0123ec6150ce92cffb8e164a02afb9c8ddee0e9b65ad65" +checksum = "6a37913e8dc4ddcc604f0c6d3bf2887c995153af3611de9e23c352b44c1b9118" dependencies = [ "async-channel", - "async-lock", + "async-lock 3.3.0", "async-task", - "atomic-waker", - "fastrand 1.9.0", - "futures-lite", - "log", + "fastrand 2.0.1", + "futures-io", + "futures-lite 2.2.0", + "piper", + "tracing", ] [[package]] name = "bumpalo" -version = "3.13.0" +version = "3.15.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a3e2c3daef883ecc1b5d58c15adae93470a91d425f3532ba1695849656af3fc1" +checksum = "7ff69b9dd49fd426c69a0db9fc04dd934cdb6645ff000864d98f7e2af8830eaa" [[package]] name = "bytemuck" -version = "1.13.1" +version = "1.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "17febce684fd15d89027105661fec94afb475cb995fbc59d2865198446ba2eea" +checksum = "5d6d68c57235a3a081186990eca2867354726650f42f7516ca50c28d6281fd15" dependencies = [ "bytemuck_derive", ] [[package]] name = "bytemuck_derive" -version = "1.4.1" +version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fdde5c9cd29ebd706ce1b35600920a33550e402fc998a2e53ad3b42c3c47a192" +checksum = "4da9a32f3fed317401fa3c862968128267c3106685286e15d5aaa3d7389c2f60" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "byteorder" -version = "1.4.3" +version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "14c189c53d098945499cdfa7ecc63567cf3886b3332b312a5b4585d8d3a6a610" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" [[package]] name = "bytes" -version = "1.4.0" +version = "1.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89b2fd2a0dcf38d7971e2194b6b6eebab45ae01067456a7fd93d5547a61b70be" +checksum = "a2bd12c1caf447e69cd4528f47f94d203fd2582878ecb9e9465484c4148a8223" [[package]] name = "calloop" @@ -439,8 +478,8 @@ checksum = "fba7adb4dd5aa98e5553510223000e7148f621165ec5f9acd7113f6ca4995298" dependencies = [ "bitflags 2.4.2", "log", - "polling 3.3.2", - "rustix 0.38.30", + "polling 3.5.0", + "rustix 0.38.31", "slab", "thiserror", ] @@ -452,18 +491,19 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0f0ea9b9476c7fad82841a8dbb380e2eae480c21910feba80725b46931ed8f02" dependencies = [ "calloop", - "rustix 0.38.30", + "rustix 0.38.31", "wayland-backend", - "wayland-client 0.31.2", + "wayland-client", ] [[package]] name = "cc" -version = "1.0.79" +version = "1.0.90" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50d30906286121d95be3d479533b458f87493b30a4b5f79a607db8f5d11aa91f" +checksum = "8cd6604a82acf3039f1144f54b8eb34e91ffba622051189e71b781822d5ee1f5" dependencies = [ "jobserver", + "libc", ] [[package]] @@ -492,9 +532,9 @@ checksum = "77e53693616d3075149f4ead59bdeecd204ac6b8192d8969757601b74bddf00f" [[package]] name = "chrono" -version = "0.4.34" +version = "0.4.35" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5bc015644b92d5890fab7489e49d21f879d5c990186827d42ec511919404f38b" +checksum = "8eaf5903dcbc0a39312feb77df2ff4c76387d591b9fc7b04a238dcf8bb62639a" dependencies = [ "android-tzdata", "iana-time-zone", @@ -502,14 +542,14 @@ dependencies = [ "num-traits", "serde", "wasm-bindgen", - "windows-targets 0.52.0", + "windows-targets 0.52.4", ] [[package]] name = "clipboard-win" -version = "5.0.0" +version = "5.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c57002a5d9be777c1ef967e33674dac9ebd310d8893e4e3437b14d5f0f6372cc" +checksum = "12f9a0700e0127ba15d1d52dd742097f821cd9c65939303a44d970465040a297" dependencies = [ "error-code", ] @@ -527,21 +567,21 @@ dependencies = [ [[package]] name = "clipboard_wayland" -version = "0.2.0" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6f6364a9f7a66f2ac1a1a098aa1c7f6b686f2496c6ac5e5c0d773445df912747" +checksum = "003f886bc4e2987729d10c1db3424e7f80809f3fc22dbc16c685738887cb37b8" dependencies = [ "smithay-clipboard", ] [[package]] name = "clipboard_x11" -version = "0.4.0" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "983a7010836ecd04dde2c6d27a0cb56ec5d21572177e782bdcb24a600124e921" +checksum = "4274ea815e013e0f9f04a2633423e14194e408a0576c943ce3d14ca56c50031c" dependencies = [ "thiserror", - "x11rb 0.9.0", + "x11rb", ] [[package]] @@ -562,15 +602,14 @@ dependencies = [ [[package]] name = "cocoa-foundation" -version = "0.1.1" +version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "931d3837c286f56e3c58423ce4eba12d08db2374461a785c86f672b08b5650d6" +checksum = "8c6234cbb2e4c785b456c0644748b1ac416dd045799740356f8363dfe00c93f7" dependencies = [ "bitflags 1.3.2", "block", "core-foundation", "core-graphics-types", - "foreign-types 0.3.2", "libc", "objc", ] @@ -634,18 +673,18 @@ dependencies = [ [[package]] name = "concurrent-queue" -version = "2.2.0" +version = "2.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62ec6771ecfa0762d24683ee5a32ad78487a3d3afdc0fb8cae19d2c5deb50b7c" +checksum = "d16048cd947b08fa32c24458a22f5dc5e835264f689f4f5653210c69fd107363" dependencies = [ "crossbeam-utils", ] [[package]] name = "core-foundation" -version = "0.9.3" +version = "0.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "194a7a9e6de53fa55116934067c844d9d749312f75c6f6d0980e8c252f8c2146" +checksum = "91e195e091a93c46f7102ec7818a2aa394e1e1771c3ab4825963fa03e45afb8f" dependencies = [ "core-foundation-sys", "libc", @@ -653,9 +692,9 @@ dependencies = [ [[package]] name = "core-foundation-sys" -version = "0.8.4" +version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e496a50fda8aacccc86d7529e2c1e0892dbd0f898a6b5645b5561b89c3210efa" +checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" [[package]] name = "core-graphics" @@ -672,13 +711,12 @@ dependencies = [ [[package]] name = "core-graphics-types" -version = "0.1.1" +version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3a68b68b3446082644c91ac778bf50cd4104bfb002b5a6a7c44cca5a2c70788b" +checksum = "45390e6114f68f718cc7a830514a96f903cccd70d02a8f6d9f643ac4ba45afaf" dependencies = [ "bitflags 1.3.2", "core-foundation", - "foreign-types 0.3.2", "libc", ] @@ -705,64 +743,46 @@ dependencies = [ [[package]] name = "cpufeatures" -version = "0.2.9" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a17b76ff3a4162b0b27f354a0c87015ddad39d35f9c0c36607a3bdd175dde1f1" +checksum = "53fe5e26ff1b7aef8bca9c6080520cfb8d9333c7568e1829cef191a9723e5504" dependencies = [ "libc", ] [[package]] name = "crc32fast" -version = "1.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b540bd8bc810d3885c6ea91e2018302f68baba2129ab3e88f32389ee9370880d" -dependencies = [ - "cfg-if", -] - -[[package]] -name = "crossbeam-channel" -version = "0.5.8" +version = "1.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a33c2bf77f2df06183c3aa30d1e96c0695a313d4f9c453cc3762a6db39f99200" +checksum = "b3855a8a784b474f333699ef2bbca9db2c4a1f6d9088a90a2d25b1eb53111eaa" dependencies = [ "cfg-if", - "crossbeam-utils", ] [[package]] name = "crossbeam-deque" -version = "0.8.3" +version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ce6fd6f855243022dcecf8702fef0c297d4338e226845fe067f6341ad9fa0cef" +checksum = "613f8cc01fe9cf1a3eb3d7f488fd2fa8388403e97039e2f73692932e291a770d" dependencies = [ - "cfg-if", "crossbeam-epoch", "crossbeam-utils", ] [[package]] name = "crossbeam-epoch" -version = "0.9.15" +version = "0.9.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ae211234986c545741a7dc064309f67ee1e5ad243d0e48335adc0484d960bcc7" +checksum = "5b82ac4a3c2ca9c3460964f020e1402edd5753411d7737aa39c3714ad1b5420e" dependencies = [ - "autocfg", - "cfg-if", "crossbeam-utils", - "memoffset 0.9.0", - "scopeguard", ] [[package]] name = "crossbeam-utils" -version = "0.8.16" +version = "0.8.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a22b2d63d4d1dc0b7f1b6b2747dd0088008a9be28b6ddf0b1e7d335e3037294" -dependencies = [ - "cfg-if", -] +checksum = "248e3bacc7dc6baa3b21e405ee045c3047101a49145e7e9eca583ab4c2ca5345" [[package]] name = "crunchy" @@ -782,12 +802,12 @@ dependencies = [ [[package]] name = "ctor" -version = "0.2.6" +version = "0.2.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "30d2b3721e861707777e3195b0158f950ae6dc4a27e4d02ff9f67e3eb3de199e" +checksum = "ad291aa74992b9b7a7e88c38acbbf6ad7e107f1d90ee8775b7bc1fc3394f485c" dependencies = [ "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -803,7 +823,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3e3d747f100290a1ca24b752186f61f6637e1deffe3bf6320de6fcb29510a307" dependencies = [ "bitflags 2.4.2", - "libloading 0.8.0", + "libloading 0.8.3", "winapi", ] @@ -832,6 +852,15 @@ dependencies = [ "tokio-stream", ] +[[package]] +name = "deranged" +version = "0.3.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" +dependencies = [ + "powerfmt", +] + [[package]] name = "derivative" version = "2.2.0" @@ -886,7 +915,7 @@ version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "330c60081dcc4c72131f8eb70510f1ac07223e5d4163db481a04a0befcffa412" dependencies = [ - "libloading 0.8.0", + "libloading 0.8.3", ] [[package]] @@ -905,7 +934,7 @@ dependencies = [ "bytemuck", "drm-ffi", "drm-fourcc", - "rustix 0.38.30", + "rustix 0.38.31", ] [[package]] @@ -915,7 +944,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "41334f8405792483e32ad05fbb9c5680ff4e84491883d2947a4757dc54cb2ac6" dependencies = [ "drm-sys", - "rustix 0.38.30", + "rustix 0.38.31", ] [[package]] @@ -936,17 +965,18 @@ dependencies = [ [[package]] name = "either" -version = "1.8.1" +version = "1.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7fcaabb2fef8c910e7f4c7ce9f67a1283a1715879a7c230ca9d6d1ae31f16d91" +checksum = "11157ac094ffbdde99aa67b23417ebdd801842852b500e395a45a9c0aac03e4a" [[package]] name = "embed-resource" -version = "2.1.1" +version = "2.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "80663502655af01a2902dff3f06869330782267924bf1788410b74edcd93770a" +checksum = "c6985554d0688b687c5cb73898a34fbe3ad6c24c58c238a4d91d5e840670ee9d" dependencies = [ "cc", + "memchr", "rustc_version", "toml", "vswhom", @@ -955,9 +985,9 @@ dependencies = [ [[package]] name = "enumflags2" -version = "0.7.7" +version = "0.7.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c041f5090df68b32bcd905365fd51769c8b9d553fe87fde0b683534f10c01bd2" +checksum = "3278c9d5fb675e0a51dabcf4c0d355f692b064171535ba72361be1528a9d8e8d" dependencies = [ "enumflags2_derive", "serde", @@ -965,13 +995,13 @@ dependencies = [ [[package]] name = "enumflags2_derive" -version = "0.7.7" +version = "0.7.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e9a1f9f7d83e59740248a6e14ecf93929ade55027844dfcea78beafccc15745" +checksum = "5c785274071b1b420972453b306eeca06acf4633829db4223b58a2a8c5953bc4" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -992,9 +1022,9 @@ dependencies = [ [[package]] name = "error-code" -version = "3.0.0" +version = "3.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "281e452d3bad4005426416cdba5ccfd4f5c1280e10099e21db27f7c1c28347fc" +checksum = "a0474425d51df81997e2f90a21591180b38eccf27292d755f3e30750225c175b" [[package]] name = "etagere" @@ -1021,17 +1051,70 @@ version = "2.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0206175f82b8d6bf6652ff7d71a1e27fd2e4efde587fd368662814d6ec1d9ce0" +[[package]] +name = "event-listener" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d93877bcde0eb80ca09131a08d23f0a5c18a620b01db137dba666d18cd9b30c2" +dependencies = [ + "concurrent-queue", + "parking", + "pin-project-lite", +] + +[[package]] +name = "event-listener" +version = "4.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "67b215c49b2b248c855fb73579eb1f4f26c38ffdc12973e20e07b91d78d5646e" +dependencies = [ + "concurrent-queue", + "parking", + "pin-project-lite", +] + +[[package]] +name = "event-listener" +version = "5.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b5fb89194fa3cad959b833185b3063ba881dbfc7030680b314250779fb4cc91" +dependencies = [ + "concurrent-queue", + "parking", + "pin-project-lite", +] + +[[package]] +name = "event-listener-strategy" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "958e4d70b6d5e81971bebec42271ec641e7ff4e170a6fa605f2b8a8b65cb97d3" +dependencies = [ + "event-listener 4.0.3", + "pin-project-lite", +] + +[[package]] +name = "event-listener-strategy" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "feedafcaa9b749175d5ac357452a9d41ea2911da598fde46ce1fe02c37751291" +dependencies = [ + "event-listener 5.2.0", + "pin-project-lite", +] + [[package]] name = "exr" -version = "1.6.4" +version = "1.72.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "279d3efcc55e19917fff7ab3ddd6c14afb6a90881a0078465196fe2f99d08c56" +checksum = "887d93f60543e9a9362ef8a21beedd0a833c5d9610e18c67abe15a5963dcb1a4" dependencies = [ "bit_field", "flume", "half", "lebe", - "miniz_oxide 0.7.1", + "miniz_oxide", "rayon-core", "smallvec", "zune-inflate", @@ -1060,9 +1143,9 @@ checksum = "25cbce373ec4653f1a01a31e8a5e5ec0c622dc27ff9c4e6606eefef5cbbed4a5" [[package]] name = "fdeflate" -version = "0.3.0" +version = "0.3.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d329bdeac514ee06249dabc27877490f17f5d371ec693360768b838e19f3ae10" +checksum = "4f9bfee30e4dedf0ab8b422f03af778d9612b63f502710fc500a334ebe2de645" dependencies = [ "simd-adler32", ] @@ -1078,27 +1161,29 @@ dependencies = [ [[package]] name = "flate2" -version = "1.0.26" +version = "1.0.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3b9429470923de8e8cbd4d2dc513535400b4b3fef0319fb5c4e1f520a7bef743" +checksum = "46303f565772937ffe1d394a4fac6f411c6013172fadde9dcdb1e147a086940e" dependencies = [ "crc32fast", - "miniz_oxide 0.7.1", + "miniz_oxide", ] [[package]] name = "flume" -version = "0.10.14" +version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1657b4441c3403d9f7b3409e47575237dac27b1b5726df654a6ecbf92f0f7577" +checksum = "55ac459de2512911e4b674ce33cf20befaba382d05b62b008afc1c8b57cbf181" dependencies = [ - "futures-core", - "futures-sink", - "nanorand", - "pin-project", "spin", ] +[[package]] +name = "font-types" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5b7f6040d337bd44434ab21fc6509154edf2cece88b23758d9d64654c4e7730b" + [[package]] name = "fontconfig-parser" version = "0.5.6" @@ -1119,7 +1204,7 @@ dependencies = [ "memmap2 0.8.0", "slotmap", "tinyvec", - "ttf-parser 0.19.0", + "ttf-parser 0.19.2", ] [[package]] @@ -1149,7 +1234,7 @@ checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -1166,9 +1251,9 @@ checksum = "aa9a19cbb55df58761df49b23516a86d432839add4af60fc256da840f66ed35b" [[package]] name = "futures" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23342abe12aba583913b2e62f22225ff9c950774065e4bfb61a19cd9770fec40" +checksum = "645c6916888f6cb6350d2550b80fb63e734897a8498abe35cfb732b6487804b0" dependencies = [ "futures-channel", "futures-core", @@ -1181,9 +1266,9 @@ dependencies = [ [[package]] name = "futures-channel" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "955518d47e09b25bbebc7a18df10b81f0c766eaf4c4f1cccef2fca5f2a4fb5f2" +checksum = "eac8f7d7865dcb88bd4373ab671c8cf4508703796caa2b1985a9ca867b3fcb78" dependencies = [ "futures-core", "futures-sink", @@ -1191,15 +1276,15 @@ dependencies = [ [[package]] name = "futures-core" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4bca583b7e26f571124fe5b7561d49cb2868d79116cfa0eefce955557c6fee8c" +checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" [[package]] name = "futures-executor" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccecee823288125bd88b4d7f565c9e58e41858e47ab72e8ea2d64e93624386e0" +checksum = "a576fc72ae164fca6b9db127eaa9a9dda0d61316034f33a0a0d4eda41f02b01d" dependencies = [ "futures-core", "futures-task", @@ -1209,9 +1294,9 @@ dependencies = [ [[package]] name = "futures-io" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fff74096e71ed47f8e023204cfd0aa1289cd54ae5430a9523be060cdb849964" +checksum = "a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1" [[package]] name = "futures-lite" @@ -1228,34 +1313,47 @@ dependencies = [ "waker-fn", ] +[[package]] +name = "futures-lite" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "445ba825b27408685aaecefd65178908c36c6e96aaf6d8599419d46e624192ba" +dependencies = [ + "fastrand 2.0.1", + "futures-core", + "futures-io", + "parking", + "pin-project-lite", +] + [[package]] name = "futures-macro" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89ca545a94061b6365f2c7355b4b32bd20df3ff95f02da9329b34ccc3bd6ee72" +checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "futures-sink" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f43be4fe21a13b9781a69afa4985b0f6ee0e1afab2c6f454a8cf30e2b2237b6e" +checksum = "9fb8e00e87438d937621c1c6269e53f536c14d3fbd6a042bb24879e57d474fb5" [[package]] name = "futures-task" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "76d3d132be6c0e6aa1534069c705a74a5997a356c0dc2f86a47765e5617c5b65" +checksum = "38d84fa142264698cdce1a9f9172cf383a0c82de1bddcf3092901442c4097004" [[package]] name = "futures-util" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26b01e40b772d54cf6c6d721c1d1abd0647a0106a12ecaa1c186273392a69533" +checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" dependencies = [ "futures-channel", "futures-core", @@ -1279,16 +1377,6 @@ dependencies = [ "version_check", ] -[[package]] -name = "gethostname" -version = "0.2.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c1ebd34e35c46e00bb73e81363248d627782724609fe1b6396f553f68fe3862e" -dependencies = [ - "libc", - "winapi", -] - [[package]] name = "gethostname" version = "0.4.3" @@ -1296,27 +1384,25 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0176e0459c2e4a1fe232f984bca6890e681076abb9934f6cea7c326f3fc47818" dependencies = [ "libc", - "windows-targets 0.48.0", + "windows-targets 0.48.5", ] [[package]] name = "getrandom" -version = "0.2.10" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "be4136b2a15dd319360be1c07d9933517ccf0be8f16bf62a3bee4f0d618df427" +checksum = "190092ea657667030ac6a35e305e62fc4dd69fd98ac98631e5d3a2b1575a12b5" dependencies = [ "cfg-if", - "js-sys", "libc", "wasi", - "wasm-bindgen", ] [[package]] name = "gif" -version = "0.12.0" +version = "0.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "80792593675e051cf94a4b111980da2ba60d4a83e43e0048c5693baab3977045" +checksum = "3fb2d69b19215e18bb912fa30f7ce15846e301408695e44e0ef719f1da9e19f2" dependencies = [ "color_quant", "weezl", @@ -1324,9 +1410,9 @@ dependencies = [ [[package]] name = "gimli" -version = "0.27.2" +version = "0.28.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad0a93d233ebf96623465aad4046a8d3aa4da22d4f4beba5388838c8a434bbb4" +checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" [[package]] name = "gl_generator" @@ -1341,9 +1427,9 @@ dependencies = [ [[package]] name = "glam" -version = "0.24.0" +version = "0.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad83ab008a4fa3b31dfa713dd41b5a9bdea1e94e4cf1e2fc274ffbd49b0271d3" +checksum = "151665d9be52f9bb40fc7966565d39666f2d1e69233571b71b87791c7e0528b3" [[package]] name = "glow" @@ -1412,22 +1498,22 @@ dependencies = [ [[package]] name = "gpu-descriptor" -version = "0.2.3" +version = "0.2.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b0c02e1ba0bdb14e965058ca34e09c020f8e507a760df1121728e0aef68d57a" +checksum = "cc11df1ace8e7e564511f53af41f3e42ddc95b56fd07b3f4445d2a6048bc682c" dependencies = [ - "bitflags 1.3.2", + "bitflags 2.4.2", "gpu-descriptor-types", - "hashbrown 0.12.3", + "hashbrown", ] [[package]] name = "gpu-descriptor-types" -version = "0.1.1" +version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "363e3677e55ad168fef68cf9de3a4a310b53124c5e784c53a1d70e92d23f2126" +checksum = "6bf0b36e6f090b7e1d8a4b49c0cb81c1f8376f72198c65dd3ad9ff3556b8b78c" dependencies = [ - "bitflags 1.3.2", + "bitflags 2.4.2", ] [[package]] @@ -1442,9 +1528,9 @@ dependencies = [ [[package]] name = "half" -version = "2.3.1" +version = "2.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bc52e53916c08643f1b56ec082790d1e86a32e58dc5268f897f313fbae7b4872" +checksum = "b5eceaaeec696539ddaf7b333340f1af35a5aa87ae3e4f3ead0532f72affab2e" dependencies = [ "cfg-if", "crunchy", @@ -1471,22 +1557,13 @@ dependencies = [ "uuid", ] -[[package]] -name = "hashbrown" -version = "0.12.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" -dependencies = [ - "ahash 0.7.6", -] - [[package]] name = "hashbrown" version = "0.14.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "290f1a1d9242c78d09ce40a5e87e7554ee637af1351968159f4952f028f75604" dependencies = [ - "ahash 0.8.7", + "ahash", "allocator-api2", ] @@ -1499,7 +1576,7 @@ dependencies = [ "bitflags 2.4.2", "com", "libc", - "libloading 0.8.0", + "libloading 0.8.3", "thiserror", "widestring", "winapi", @@ -1513,18 +1590,9 @@ checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" [[package]] name = "hermit-abi" -version = "0.2.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ee512640fe35acbfb4bb779db6f0d80704c2cacfa2e39b601ef3e3f47d1ae4c7" -dependencies = [ - "libc", -] - -[[package]] -name = "hermit-abi" -version = "0.3.2" +version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "443144c8cdadd93ebf52ddb4056d257f5b52c04d3c804e657d19eb73fc33668b" +checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" [[package]] name = "hex" @@ -1540,16 +1608,16 @@ checksum = "dfa686283ad6dd069f105e5ab091b04c62850d3e4cf5d67debad1933f55023df" [[package]] name = "iana-time-zone" -version = "0.1.56" +version = "0.1.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0722cd7114b7de04316e7ea5456a0bbb20e4adb46fd27a3697adb812cff0f37c" +checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" dependencies = [ "android_system_properties", "core-foundation-sys", "iana-time-zone-haiku", "js-sys", "wasm-bindgen", - "windows 0.48.0", + "windows-core 0.52.0", ] [[package]] @@ -1563,10 +1631,9 @@ dependencies = [ [[package]] name = "iced" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ - "iced_core", "iced_futures", "iced_renderer", "iced_widget", @@ -1577,12 +1644,14 @@ dependencies = [ [[package]] name = "iced_core" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ - "bitflags 1.3.2", + "bitflags 2.4.2", + "glam", "log", "num-traits", + "once_cell", "palette", "raw-window-handle", "smol_str", @@ -1593,8 +1662,8 @@ dependencies = [ [[package]] name = "iced_futures" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ "futures", "iced_core", @@ -1606,13 +1675,12 @@ dependencies = [ [[package]] name = "iced_graphics" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ - "bitflags 1.3.2", + "bitflags 2.4.2", "bytemuck", "cosmic-text", - "glam", "half", "iced_core", "iced_futures", @@ -1629,8 +1697,8 @@ dependencies = [ [[package]] name = "iced_renderer" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ "iced_graphics", "iced_tiny_skia", @@ -1641,28 +1709,19 @@ dependencies = [ [[package]] name = "iced_runtime" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ "iced_core", "iced_futures", + "raw-window-handle", "thiserror", ] -[[package]] -name = "iced_style" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" -dependencies = [ - "iced_core", - "once_cell", - "palette", -] - [[package]] name = "iced_tiny_skia" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ "bytemuck", "cosmic-text", @@ -1677,10 +1736,10 @@ dependencies = [ [[package]] name = "iced_wgpu" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ - "bitflags 1.3.2", + "bitflags 2.4.2", "bytemuck", "futures", "glam", @@ -1694,12 +1753,11 @@ dependencies = [ [[package]] name = "iced_widget" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ "iced_renderer", "iced_runtime", - "iced_style", "num-traits", "ouroboros", "thiserror", @@ -1708,12 +1766,11 @@ dependencies = [ [[package]] name = "iced_winit" -version = "0.12.0" -source = "git+https://github.com/tarkah/iced?rev=f9db8d1efe68634b7b06ce07f12ea33a3e37d79c#f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" +version = "0.13.0-dev" +source = "git+https://github.com/iced-rs/iced?rev=3d915d3cb30e5d08829aa2928676a53c505a601e#3d915d3cb30e5d08829aa2928676a53c505a601e" dependencies = [ "iced_graphics", "iced_runtime", - "iced_style", "log", "thiserror", "tracing", @@ -1736,9 +1793,9 @@ dependencies = [ [[package]] name = "image" -version = "0.24.6" +version = "0.24.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "527909aa81e20ac3a44803521443a765550f09b5130c2c2fa1ea59c2f8f50a3a" +checksum = "5690139d2f55868e080017335e4b94cb7414274c74f1669c84fb5feba2c9f69d" dependencies = [ "bytemuck", "byteorder", @@ -1746,7 +1803,6 @@ dependencies = [ "exr", "gif", "jpeg-decoder", - "num-rational", "num-traits", "png", "qoi", @@ -1755,22 +1811,12 @@ dependencies = [ [[package]] name = "indexmap" -version = "1.9.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd070e393353796e801d209ad339e89596eb4c8d430d18ede6a1cced8fafbd99" -dependencies = [ - "autocfg", - "hashbrown 0.12.3", -] - -[[package]] -name = "indexmap" -version = "2.2.1" +version = "2.2.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "433de089bd45971eecf4668ee0ee8f4cec17db4f8bd8f7bc3197a6ce37aa7d9b" +checksum = "7b0b929d511467233429c45a44ac1dcaa21ba0f5ba11e4879e6ed28ddb4f9df4" dependencies = [ "equivalent", - "hashbrown 0.14.3", + "hashbrown", ] [[package]] @@ -1788,7 +1834,7 @@ version = "1.0.11" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "eae7b9aee968036d54dce06cebaefd919e4472e753296daccd6d344e3e2df0c2" dependencies = [ - "hermit-abi 0.3.2", + "hermit-abi", "libc", "windows-sys 0.48.0", ] @@ -1845,9 +1891,9 @@ dependencies = [ [[package]] name = "itoa" -version = "1.0.9" +version = "1.0.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" +checksum = "b1a46d1a171d865aa5f83f92695765caa047a9b4cbae2cbf37dbd613a793fd4c" [[package]] name = "jni" @@ -1873,27 +1919,27 @@ checksum = "8eaf4bc02d17cbdd7ff4c7438cafcdf7fb9a4613313ad11b4f8fefe7d3fa0130" [[package]] name = "jobserver" -version = "0.1.26" +version = "0.1.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "936cfd212a0155903bcbc060e316fb6cc7cbf2e1907329391ebadc1fe0ce77c2" +checksum = "ab46a6e9526ddef3ae7f787c06f0f2600639ba80ea3eade3d8e670a2230f51d6" dependencies = [ "libc", ] [[package]] name = "jpeg-decoder" -version = "0.3.0" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bc0000e42512c92e31c2252315bda326620a4e034105e900c98ec492fa077b3e" +checksum = "f5d4a7da358eff58addd2877a45865158f0d78c911d43a5784ceb7bbf52833b0" dependencies = [ "rayon", ] [[package]] name = "js-sys" -version = "0.3.67" +version = "0.3.69" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a1d36f1235bc969acba30b7f5990b864423a6068a10f7c90ae8f0112e3a59d1" +checksum = "29c15563dc2726973df627357ce0c9ddddbea194836909d655df6a75d2cf296d" dependencies = [ "wasm-bindgen", ] @@ -1914,7 +1960,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6aae1df220ece3c0ada96b8153459b67eebe9ae9212258bb0134ae60416fdf76" dependencies = [ "libc", - "libloading 0.8.0", + "libloading 0.8.3", "pkg-config", ] @@ -1926,11 +1972,12 @@ checksum = "e2db585e1d738fc771bf08a151420d3ed193d9d895a36df7f6f8a9456b911ddc" [[package]] name = "kurbo" -version = "0.9.5" +version = "0.10.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd85a5776cd9500c2e2059c8c76c3b01528566b7fcbaf8098b55a33fc298849b" +checksum = "1618d4ebd923e97d67e7cd363d80aef35fe961005cbbbb3d2dad8bdd1bc63440" dependencies = [ "arrayvec", + "smallvec", ] [[package]] @@ -1947,9 +1994,9 @@ checksum = "03087c2bad5e1034e8cace5926dec053fb3790248370865f5117a7d0213354c8" [[package]] name = "libc" -version = "0.2.152" +version = "0.2.153" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "13e3bf6590cbc649f4d1a3eefc9d5d6eb746f5200ffb04e5e142700b8faa56e7" +checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" [[package]] name = "libloading" @@ -1963,12 +2010,12 @@ dependencies = [ [[package]] name = "libloading" -version = "0.8.0" +version = "0.8.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d580318f95776505201b28cf98eb1fa5e4be3b689633ba6a3e6cd880ff22d8cb" +checksum = "0c2a198fb6b0eada2a8df47933734e6d35d350665a33a3593d7164fa52c75c19" dependencies = [ "cfg-if", - "windows-sys 0.48.0", + "windows-targets 0.52.4", ] [[package]] @@ -1978,8 +2025,30 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4ec2a862134d2a7d32d7983ddcdd1c4923530833c9f2ea1a44fc5fa473989058" [[package]] -name = "linux-raw-sys" -version = "0.3.8" +name = "libredox" +version = "0.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "85c833ca1e66078851dba29046874e38f08b2c883700aa29a03ddd3b23814ee8" +dependencies = [ + "bitflags 2.4.2", + "libc", + "redox_syscall 0.4.1", +] + +[[package]] +name = "libredox" +version = "0.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3af92c55d7d839293953fcd0fda5ecfe93297cfde6ffbdec13b41d99c0ba6607" +dependencies = [ + "bitflags 2.4.2", + "libc", + "redox_syscall 0.4.1", +] + +[[package]] +name = "linux-raw-sys" +version = "0.3.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ef53942eb7bf7ff43a617b3e2c1c4a5ecf5944a7c1bc12d7ee39bbb15e5c1519" @@ -1997,9 +2066,9 @@ checksum = "f0b5399f6804fbab912acbd8878ed3532d506b7c951b8f9f164ef90fef39e3f4" [[package]] name = "lock_api" -version = "0.4.9" +version = "0.4.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "435011366fe56583b16cf956f9df0095b405b82d76425bc8981c0e22e60ec4df" +checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" dependencies = [ "autocfg", "scopeguard", @@ -2007,24 +2076,24 @@ dependencies = [ [[package]] name = "log" -version = "0.4.20" +version = "0.4.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f" +checksum = "90ed8c1e510134f979dbc4f070f87d4313098b704861a105fe34231c70a3901c" [[package]] name = "lru" -version = "0.12.2" +version = "0.12.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "db2c024b41519440580066ba82aab04092b333e09066a5eb86c7c4890df31f22" +checksum = "d3262e75e648fce39813cb56ac41f3c3e3f65217ebf3844d818d1f9398cfb0dc" dependencies = [ - "hashbrown 0.14.3", + "hashbrown", ] [[package]] name = "mac-notification-sys" -version = "0.5.6" +version = "0.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3e72d50edb17756489e79d52eb146927bec8eba9dd48faadf9ef08bca3791ad5" +checksum = "51fca4d74ff9dbaac16a01b924bc3693fa2bba0862c2c633abc73f9a8ea21f64" dependencies = [ "cc", "dirs-next", @@ -2044,18 +2113,9 @@ dependencies = [ [[package]] name = "memchr" -version = "2.5.0" +version = "2.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2dffe52ecf27772e601905b7522cb4ef790d2cc203488bbd0e2fe85fcb74566d" - -[[package]] -name = "memmap2" -version = "0.5.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "83faa42c0a078c393f6b29d5db232d8be22776a891f8f56e5284faee4a20b327" -dependencies = [ - "libc", -] +checksum = "523dc4f511e55ab87b694dc30d0f820d60906ef06413f93d4d7a1385599cc149" [[package]] name = "memmap2" @@ -2075,15 +2135,6 @@ dependencies = [ "libc", ] -[[package]] -name = "memoffset" -version = "0.6.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5aa361d4faea93603064a027415f07bd8e1d5c88c9fbf68bf56a285428fd79ce" -dependencies = [ - "autocfg", -] - [[package]] name = "memoffset" version = "0.7.1" @@ -2125,18 +2176,9 @@ checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" [[package]] name = "miniz_oxide" -version = "0.6.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b275950c28b37e794e8c55d88aeb5e139d0ce23fdbbeda68f8d7174abdf9e8fa" -dependencies = [ - "adler", -] - -[[package]] -name = "miniz_oxide" -version = "0.7.1" +version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e7810e0be55b428ada41041c41f32c9f1a42817901b4ccf45fa3d4b6561e74c7" +checksum = "9d811f3e15f28568be3407c8e7fdb6514c1cda3cb30683f15b6a1a1dc4ea14a7" dependencies = [ "adler", "simd-adler32", @@ -2144,9 +2186,9 @@ dependencies = [ [[package]] name = "mio" -version = "0.8.8" +version = "0.8.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "927a765cd3fc26206e66b296465fa9d3e5ab003e651c1b3c060e7956d96b19d2" +checksum = "a4a650543ca06a924e8b371db273b2756685faae30f8487da1b56505a8f78b0c" dependencies = [ "libc", "wasi", @@ -2161,15 +2203,15 @@ checksum = "16cf681a23b4d0a43fc35024c176437f9dcd818db34e0f42ab456a0ee5ad497b" [[package]] name = "naga" -version = "0.19.0" +version = "0.19.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8878eb410fc90853da3908aebfe61d73d26d4437ef850b70050461f939509899" +checksum = "50e3524642f53d9af419ab5e8dd29d3ba155708267667c2f3f06c88c9e130843" dependencies = [ "bit-set", "bitflags 2.4.2", "codespan-reporting", "hexf-parse", - "indexmap 2.2.1", + "indexmap", "log", "num-traits", "rustc-hash", @@ -2179,15 +2221,6 @@ dependencies = [ "unicode-xid", ] -[[package]] -name = "nanorand" -version = "0.7.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6a51313c5820b0b02bd422f4b44776fbf47961755c74ce64afc73bfad10226c3" -dependencies = [ - "getrandom", -] - [[package]] name = "native-tls" version = "0.2.11" @@ -2238,40 +2271,14 @@ dependencies = [ [[package]] name = "nix" -version = "0.22.3" +version = "0.26.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e4916f159ed8e5de0082076562152a76b7a1f64a01fd9d1e0fea002c37624faf" -dependencies = [ - "bitflags 1.3.2", - "cc", - "cfg-if", - "libc", - "memoffset 0.6.5", -] - -[[package]] -name = "nix" -version = "0.24.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fa52e972a9a719cecb6864fb88568781eb706bac2cd1d4f04a648542dbf78069" -dependencies = [ - "bitflags 1.3.2", - "cfg-if", - "libc", - "memoffset 0.6.5", -] - -[[package]] -name = "nix" -version = "0.26.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfdda3d196821d6af13126e40375cdf7da646a96114af134d5f417a9a1dc8e1a" +checksum = "598beaf3cc6fdd9a5dfb1630c2800c7acd31df7aaf0f565796fba2b53ca1af1b" dependencies = [ "bitflags 1.3.2", "cfg-if", "libc", "memoffset 0.7.1", - "static_assertions", ] [[package]] @@ -2286,9 +2293,9 @@ dependencies = [ [[package]] name = "notify-rust" -version = "4.8.0" +version = "4.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2bfa211d18e360f08e36c364308f394b5eb23a6629150690e109a916dc6f610e" +checksum = "827c5edfa80235ded4ab3fe8e9dc619b4f866ef16fe9b1c6b8a7f8692c0f2226" dependencies = [ "log", "mac-notification-sys", @@ -2298,42 +2305,27 @@ dependencies = [ ] [[package]] -name = "num-integer" -version = "0.1.45" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9" -dependencies = [ - "autocfg", - "num-traits", -] - -[[package]] -name = "num-rational" -version = "0.4.1" +name = "num-conv" +version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0638a1c9d0a3c0914158145bc76cff373a75a627e6ecbfb71cbe6f453a5a19b0" -dependencies = [ - "autocfg", - "num-integer", - "num-traits", -] +checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" [[package]] name = "num-traits" -version = "0.2.15" +version = "0.2.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "578ede34cf02f8924ab9447f50c28075b4d3e5b269972345e7e0372b38c6cdcd" +checksum = "da0df0e5185db44f69b44f26786fe401b6c293d1907744beaa7fa62b2e5a517a" dependencies = [ "autocfg", ] [[package]] name = "num_cpus" -version = "1.15.0" +version = "1.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fac9e2da13b5eb447a6ce3d392f23a29d8694bff781bf03a16cd9ac8697593b" +checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" dependencies = [ - "hermit-abi 0.2.6", + "hermit-abi", "libc", ] @@ -2352,10 +2344,10 @@ version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "681030a937600a36906c185595136d26abfebb4aa9c65701cefcaf8578bb982b" dependencies = [ - "proc-macro-crate", + "proc-macro-crate 3.1.0", "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -2421,9 +2413,9 @@ dependencies = [ [[package]] name = "object" -version = "0.30.3" +version = "0.32.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ea86265d3d3dcb6a27fc51bd29a4bf387fae9d2986b823079d4986af253eb439" +checksum = "a6a622008b6e321afc04970976f62ee297fdbaa6f95318ca343e3eebb9648441" dependencies = [ "memchr", ] @@ -2436,9 +2428,9 @@ checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" [[package]] name = "open" -version = "5.0.1" +version = "5.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90878fb664448b54c4e592455ad02831e23a3f7e157374a8b95654731aac7349" +checksum = "449f0ff855d85ddbf1edd5b646d65249ead3f5e422aaa86b7d2d0b049b103e32" dependencies = [ "is-wsl", "libc", @@ -2447,11 +2439,11 @@ dependencies = [ [[package]] name = "openssl" -version = "0.10.55" +version = "0.10.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "345df152bc43501c5eb9e4654ff05f794effb78d4efe3d53abc158baddc0703d" +checksum = "95a0481286a310808298130d22dd1fef0fa571e05a8f44ec801801e84b216b1f" dependencies = [ - "bitflags 1.3.2", + "bitflags 2.4.2", "cfg-if", "foreign-types 0.3.2", "libc", @@ -2468,7 +2460,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -2479,9 +2471,9 @@ checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" [[package]] name = "openssl-sys" -version = "0.9.90" +version = "0.9.101" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "374533b0e45f3a7ced10fcaeccca020e66656bc03dac384f852e4e5a7a8104a6" +checksum = "dda2b0f344e78efc2facf7d195d098df0dd72151b26ab98da807afc26c198dff" dependencies = [ "cc", "libc", @@ -2491,11 +2483,11 @@ dependencies = [ [[package]] name = "orbclient" -version = "0.3.45" +version = "0.3.47" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "221d488cd70617f1bd599ed8ceb659df2147d9393717954d82a0f5e8032a6ab1" +checksum = "52f0d54bde9774d3a51dcf281a5def240c71996bc6ca05d2c847ec8b2b216166" dependencies = [ - "redox_syscall 0.3.5", + "libredox 0.0.2", ] [[package]] @@ -2510,9 +2502,9 @@ dependencies = [ [[package]] name = "ouroboros" -version = "0.17.0" +version = "0.18.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d813b7b31a82efae94bd30ffaac09aec85efc18db2d5ec3aead1a220ee954351" +checksum = "97b7be5a8a3462b752f4be3ff2b2bf2f7f1d00834902e46be2a4d68b87b0573c" dependencies = [ "aliasable", "ouroboros_macro", @@ -2521,31 +2513,32 @@ dependencies = [ [[package]] name = "ouroboros_macro" -version = "0.17.0" +version = "0.18.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a56f651b4dd45ae3ac3d260ced32eaf0620cddaae5f26c69b554a9016594726" +checksum = "b645dcde5f119c2c454a92d0dfa271a2a3b205da92e4292a68ead4bdbfde1f33" dependencies = [ "heck", - "proc-macro-error", + "itertools", "proc-macro2", + "proc-macro2-diagnostics", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "owned_ttf_parser" -version = "0.19.0" +version = "0.20.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "706de7e2214113d63a8238d1910463cfce781129a6f263d13fdb09ff64355ba4" +checksum = "d4586edfe4c648c71797a74c84bacb32b52b212eff5dfe2bb9f2c599844023e7" dependencies = [ - "ttf-parser 0.19.0", + "ttf-parser 0.20.0", ] [[package]] name = "palette" -version = "0.7.4" +version = "0.7.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d38e6e5ca1612e2081cc31188f08c3cba630ce4ba44709a153f1a0f38d678f2" +checksum = "ebfc23a4b76642983d57e4ad00bb4504eb30a8ce3c70f4aee1f725610e36d97a" dependencies = [ "approx", "fast-srgb8", @@ -2555,20 +2548,20 @@ dependencies = [ [[package]] name = "palette_derive" -version = "0.7.4" +version = "0.7.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e05d1c929301fee6830dafa764341118829b2535c216b0571e3821ecac5c885b" +checksum = "e8890702dbec0bad9116041ae586f84805b13eecd1d8b1df27c29998a9969d6d" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "parking" -version = "2.1.0" +version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "14f2252c834a40ed9bb5422029649578e63aa341ac401f74e719dd1afda8394e" +checksum = "bb813b8af86854136c6922af0598d719255ecb2179515e6e7730d468f05c9cae" [[package]] name = "parking_lot" @@ -2588,7 +2581,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" dependencies = [ "lock_api", - "parking_lot_core 0.9.7", + "parking_lot_core 0.9.9", ] [[package]] @@ -2607,15 +2600,15 @@ dependencies = [ [[package]] name = "parking_lot_core" -version = "0.9.7" +version = "0.9.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9069cbb9f99e3a5083476ccb29ceb1de18b9118cafa53e90c9551235de2b9521" +checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" dependencies = [ "cfg-if", "libc", - "redox_syscall 0.2.16", + "redox_syscall 0.4.1", "smallvec", - "windows-sys 0.45.0", + "windows-targets 0.48.5", ] [[package]] @@ -2632,15 +2625,15 @@ checksum = "8835116a5c179084a830efb3adc117ab007512b535bc1a21c991d3b32a6b44dd" [[package]] name = "percent-encoding" -version = "2.2.0" +version = "2.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "478c572c3d73181ff3c2539045f6eb99e5491218eae919370993b890cdbdd98e" +checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" [[package]] name = "phf" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "928c6535de93548188ef63bb7c4036bd415cd8f36ad25af44b9789b2ee72a48c" +checksum = "ade2d8b8f33c7333b51bcf0428d37e217e9f32192ae4772156f65063b8ce03dc" dependencies = [ "phf_macros", "phf_shared", @@ -2648,9 +2641,9 @@ dependencies = [ [[package]] name = "phf_generator" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1181c94580fa345f50f19d738aaa39c0ed30a600d95cb2d3e23f94266f14fbf" +checksum = "48e4cc64c2ad9ebe670cb8fd69dd50ae301650392e81c05f9bfcb2d5bdbc24b0" dependencies = [ "phf_shared", "rand", @@ -2658,51 +2651,31 @@ dependencies = [ [[package]] name = "phf_macros" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "92aacdc5f16768709a569e913f7451034034178b05bdc8acda226659a3dccc66" +checksum = "3444646e286606587e49f3bcf1679b8cef1dc2c5ecc29ddacaffc305180d464b" dependencies = [ "phf_generator", "phf_shared", "proc-macro2", "quote", - "syn 1.0.109", + "syn 2.0.52", ] [[package]] name = "phf_shared" -version = "0.11.1" +version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1fb5f6f826b772a8d4c0394209441e7d37cbbb967ae9c7e0e8134365c9ee676" +checksum = "90fcb95eef784c2ac79119d1dd819e162b5da872ce6f3c3abe1e8ca1c082f72b" dependencies = [ "siphasher", ] -[[package]] -name = "pin-project" -version = "1.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c95a7476719eab1e366eaf73d0260af3021184f18177925b07f54b30089ceead" -dependencies = [ - "pin-project-internal", -] - -[[package]] -name = "pin-project-internal" -version = "1.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39407670928234ebc5e6e580247dd567ad73a3578460c5990f9503df207e8f07" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.48", -] - [[package]] name = "pin-project-lite" -version = "0.2.9" +version = "0.2.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e0a7ae3ac2f1173085d398531c705756c94a4c56843785df85a60c1a0afac116" +checksum = "8afb450f006bf6385ca15ef45d71d2288452bc3683ce2e2cacc0d18e4be60b58" [[package]] name = "pin-utils" @@ -2710,23 +2683,34 @@ version = "0.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" +[[package]] +name = "piper" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "668d31b1c4eba19242f2088b2bf3316b82ca31082a8335764db4e083db7485d4" +dependencies = [ + "atomic-waker", + "fastrand 2.0.1", + "futures-io", +] + [[package]] name = "pkg-config" -version = "0.3.27" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26072860ba924cbfa98ea39c8c19b4dd6a4a25423dbdf219c1eca91aa0cf6964" +checksum = "d231b230927b5e4ad203db57bbcbee2802f6bce620b1e4a9024a07d94e2907ec" [[package]] name = "png" -version = "0.17.8" +version = "0.17.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "aaeebc51f9e7d2c150d3f3bfeb667f2aa985db5ef1e3d212847bdedb488beeaa" +checksum = "06e4b0d3d1312775e782c86c91a111aa1f910cbb65e1337f9975b5f9a554b5e1" dependencies = [ "bitflags 1.3.2", "crc32fast", "fdeflate", "flate2", - "miniz_oxide 0.7.1", + "miniz_oxide", ] [[package]] @@ -2747,18 +2731,24 @@ dependencies = [ [[package]] name = "polling" -version = "3.3.2" +version = "3.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "545c980a3880efd47b2e262f6a4bb6daad6555cf3367aa9c4e52895f69537a41" +checksum = "24f040dee2588b4963afb4e420540439d126f73fdacf4a9c486a96d840bac3c9" dependencies = [ "cfg-if", "concurrent-queue", "pin-project-lite", - "rustix 0.38.30", + "rustix 0.38.31", "tracing", "windows-sys 0.52.0", ] +[[package]] +name = "powerfmt" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" + [[package]] name = "ppv-lite86" version = "0.2.17" @@ -2778,47 +2768,45 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7f4c021e1093a56626774e81216a4ce732a735e5bad4868a03f3ed65ca0c3919" dependencies = [ "once_cell", - "toml_edit", + "toml_edit 0.19.15", ] [[package]] -name = "proc-macro-error" -version = "1.0.4" +name = "proc-macro-crate" +version = "3.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da25490ff9892aab3fcf7c36f08cfb902dd3e71ca0f9f9517bea02a73a5ce38c" +checksum = "6d37c51ca738a55da99dc0c4a34860fd675453b8b36209178c2249bb13651284" dependencies = [ - "proc-macro-error-attr", - "proc-macro2", - "quote", - "syn 1.0.109", - "version_check", + "toml_edit 0.21.1", ] [[package]] -name = "proc-macro-error-attr" -version = "1.0.4" +name = "proc-macro2" +version = "1.0.79" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a1be40180e52ecc98ad80b184934baf3d0d29f979574e439af5a55274b35f869" +checksum = "e835ff2298f5721608eb1a980ecaee1aef2c132bf95ecc026a11b7bf3c01c02e" dependencies = [ - "proc-macro2", - "quote", - "version_check", + "unicode-ident", ] [[package]] -name = "proc-macro2" -version = "1.0.78" +name = "proc-macro2-diagnostics" +version = "0.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e2422ad645d89c99f8f3e6b88a9fdeca7fabeac836b1002371c4367c8f984aae" +checksum = "af066a9c399a26e020ada66a034357a868728e72cd426f3adcd35f80d88d88c8" dependencies = [ - "unicode-ident", + "proc-macro2", + "quote", + "syn 2.0.52", + "version_check", + "yansi", ] [[package]] name = "profiling" -version = "1.0.8" +version = "1.0.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "332cd62e95873ea4f41f3dfd6bbbfc5b52aec892d7e8d534197c4720a0bbbab2" +checksum = "43d84d1d7a6ac92673717f9f6d1518374ef257669c24ebc5ac25d5033828be58" [[package]] name = "qoi" @@ -2831,9 +2819,9 @@ dependencies = [ [[package]] name = "quick-xml" -version = "0.23.1" +version = "0.30.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "11bafc859c6815fbaffbbbf4229ecb767ac913fecb27f9ad4343662e9ef099ea" +checksum = "eff6510e86862b57b210fd8cbe8ed3f0d7d600b9c2863cd4549a2e033c66e956" dependencies = [ "memchr", ] @@ -2894,9 +2882,9 @@ checksum = "9c8a99fddc9f0ba0a85884b8d14e3592853e787d581ca1816c91349b10e4eeab" [[package]] name = "rangemap" -version = "1.4.0" +version = "1.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "977b1e897f9d764566891689e642653e5ed90c6895106acd005eb4c1d0203991" +checksum = "f60fcc7d6849342eff22c4350c8b9a989ee8ceabc4b481253e8946b9fe83d684" [[package]] name = "raw-window-handle" @@ -2906,9 +2894,9 @@ checksum = "42a9830a0e1b9fb145ebb365b8bc4ccd75f290f98c0247deafbbe2c75cefb544" [[package]] name = "rayon" -version = "1.7.0" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1d2df5196e37bcc87abebc0053e20787d73847bb33134a69841207dd0a47f03b" +checksum = "e4963ed1bc86e4f3ee217022bd855b297cef07fb9eac5dfa1f788b220b49b3bd" dependencies = [ "either", "rayon-core", @@ -2916,14 +2904,21 @@ dependencies = [ [[package]] name = "rayon-core" -version = "1.11.0" +version = "1.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4b8f95bd6966f5c87776639160a66bd8ab9895d9d4ab01ddba9fc60661aebe8d" +checksum = "1465873a3dfdaa8ae7cb14b4383657caab0b3e8a0aa9ae8e04b044854c8dfce2" dependencies = [ - "crossbeam-channel", "crossbeam-deque", "crossbeam-utils", - "num_cpus", +] + +[[package]] +name = "read-fonts" +version = "0.15.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "17ea23eedb4d938031b6d4343222444608727a6aa68ec355e13588d9947ffe92" +dependencies = [ + "font-types", ] [[package]] @@ -2955,20 +2950,32 @@ dependencies = [ [[package]] name = "redox_users" -version = "0.4.3" +version = "0.4.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b033d837a7cf162d7993aded9304e30a83213c648b6e389db233191f891e5c2b" +checksum = "a18479200779601e498ada4e8c1e1f50e3ee19deb0259c25825a98b5603b2cb4" dependencies = [ "getrandom", - "redox_syscall 0.2.16", + "libredox 0.0.1", "thiserror", ] [[package]] name = "regex" -version = "1.8.3" +version = "1.10.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "81ca098a9821bd52d6b24fd8b10bd081f47d39c22778cafaa75a2857a62c6390" +checksum = "b62dbe01f0b06f9d8dc7d49e05a0785f153b00b2c227856282f671e0318c9b15" +dependencies = [ + "aho-corasick", + "memchr", + "regex-automata", + "regex-syntax", +] + +[[package]] +name = "regex-automata" +version = "0.4.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "86b83b8b9847f9bf95ef68afb0b8e6cdb80f498442f5179a29fad448fcc1eaea" dependencies = [ "aho-corasick", "memchr", @@ -2977,15 +2984,15 @@ dependencies = [ [[package]] name = "regex-syntax" -version = "0.7.2" +version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "436b050e76ed2903236f032a59761c1eb99e1b0aead2c257922771dab1fc8c78" +checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f" [[package]] name = "renderdoc-sys" -version = "1.0.0" +version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "216080ab382b992234dda86873c18d4c48358f5cfcb70fd693d7f6f2131b628b" +checksum = "19b30a45b0cd0bcca8037f3d0dc3421eaf95327a17cad11964fb8179b4fc4832" [[package]] name = "roxmltree" @@ -3016,9 +3023,9 @@ dependencies = [ [[package]] name = "rustix" -version = "0.37.19" +version = "0.37.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "acf8729d8542766f1b2cf77eb034d52f40d375bb8b615d0b147089946e16613d" +checksum = "fea8ca367a3a01fe35e6943c400addf443c0f57670e6ec51196f71a4b8762dd2" dependencies = [ "bitflags 1.3.2", "errno", @@ -3030,9 +3037,9 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.30" +version = "0.38.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "322394588aaf33c24007e8bb3238ee3e4c5c09c084ab32bc73890b99ff326bca" +checksum = "6ea3e1a662af26cd7a3ba09c0297a31af215563ecf42817c98df621387f4e949" dependencies = [ "bitflags 2.4.2", "errno", @@ -3060,9 +3067,9 @@ dependencies = [ [[package]] name = "ryu" -version = "1.0.13" +version = "1.0.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f91339c0467de62360649f8d3e185ca8de4224ff281f66000de5eb2a77a79041" +checksum = "e86697c916019a8588c99b5fac3cead74ec0b4b819707a682fd4d23fa0ce1ba1" [[package]] name = "same-file" @@ -3075,11 +3082,11 @@ dependencies = [ [[package]] name = "schannel" -version = "0.1.21" +version = "0.1.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "713cfb06c7059f3588fb8044c0fad1d09e3c01d225e25b9220dbfdcf16dbb1b3" +checksum = "fbc91545643bcf3a0bbb6569265615222618bdf33ce4ffbbd13c4bbd4c093534" dependencies = [ - "windows-sys 0.42.0", + "windows-sys 0.52.0", ] [[package]] @@ -3090,9 +3097,9 @@ checksum = "e1cf6437eb19a8f4a6cc0f7dca544973b0b78843adbfeb3683d1a94a0024a294" [[package]] name = "scopeguard" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d29ab0c6d3fc0ee92fe66e2d99f700eab17a8d57d1c1d3b748380fb20baa78cd" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" [[package]] name = "sctk-adwaita" @@ -3103,7 +3110,7 @@ dependencies = [ "ab_glyph", "log", "memmap2 0.9.4", - "smithay-client-toolkit 0.18.0", + "smithay-client-toolkit", "tiny-skia", ] @@ -3115,9 +3122,9 @@ checksum = "1c107b6f4780854c8b126e228ea8869f4d7b71260f962fefb57b996b8959ba6b" [[package]] name = "security-framework" -version = "2.9.1" +version = "2.9.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1fc758eb7bffce5b308734e9b0c1468893cae9ff70ebf13e7090be8dcbcc83a8" +checksum = "05b64fb303737d99b81884b2c63433e9ae28abebe5eb5045dcdd175dc2ecf4de" dependencies = [ "bitflags 1.3.2", "core-foundation", @@ -3128,9 +3135,9 @@ dependencies = [ [[package]] name = "security-framework-sys" -version = "2.9.0" +version = "2.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f51d0c0d83bec45f16480d0ce0058397a69e48fcdc52d1dc8855fb68acbd31a7" +checksum = "e932934257d3b408ed8f30db49d85ea163bfe74961f017f405b025af298f0c7a" dependencies = [ "core-foundation-sys", "libc", @@ -3144,35 +3151,35 @@ checksum = "58bf37232d3bb9a2c4e641ca2a11d83b5062066f88df7fed36c28772046d65ba" [[package]] name = "semver" -version = "1.0.17" +version = "1.0.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bebd363326d05ec3e2f532ab7660680f3b02130d780c299bca73469d521bc0ed" +checksum = "92d43fe69e652f3df9bdc2b85b2854a0825b86e4fb76bc44d945137d053639ca" [[package]] name = "serde" -version = "1.0.196" +version = "1.0.197" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "870026e60fa08c69f064aa766c10f10b1d62db9ccd4d0abb206472bee0ce3b32" +checksum = "3fb1c873e1b9b056a4dc4c0c198b24c3ffa059243875552b2bd0933b1aee4ce2" dependencies = [ "serde_derive", ] [[package]] name = "serde_derive" -version = "1.0.196" +version = "1.0.197" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "33c85360c95e7d137454dc81d9a4ed2b8efd8fbe19cee57357b32b9771fccb67" +checksum = "7eb0b34b42edc17f6b7cac84a52a1c5f0e1bb2227e997ca9011ea3dd34e8610b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "serde_json" -version = "1.0.99" +version = "1.0.114" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "46266871c240a00b8f503b877622fe33430b3c7d963bdc0f2adc511e54a1eae3" +checksum = "c5f09b1bd632ef549eaa9f60a1f8de742bdbc698e6cee2095fc84dde5f549ae0" dependencies = [ "itoa", "ryu", @@ -3181,31 +3188,31 @@ dependencies = [ [[package]] name = "serde_repr" -version = "0.1.13" +version = "0.1.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6f0a21fba416426ac927b1691996e82079f8b6156e920c85345f135b2e9ba2de" +checksum = "0b2e6b945e9d3df726b65d6ee24060aff8e3533d431f677a9695db04eff9dfdb" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "serde_spanned" -version = "0.6.2" +version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "93107647184f6027e3b7dcb2e11034cf95ffa1e3a682c67951963ac69c1c007d" +checksum = "eb3622f419d1296904700073ea6cc23ad690adbd66f13ea683df73298736f0c1" dependencies = [ "serde", ] [[package]] name = "serde_yaml" -version = "0.9.31" +version = "0.9.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "adf8a49373e98a4c5f0ceb5d05aa7c648d75f63774981ed95b7c7443bbd50c6e" +checksum = "8fd075d994154d4a774f95b51fb96bdc2832b0ea48425c92546073816cda1f2f" dependencies = [ - "indexmap 2.2.1", + "indexmap", "itoa", "ryu", "serde", @@ -3214,25 +3221,15 @@ dependencies = [ [[package]] name = "sha1" -version = "0.10.5" +version = "0.10.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f04293dc80c3993519f2d7f6f511707ee7094fe0c6d3406feb330cdb3540eba3" +checksum = "e3bf829a2d51ab4a5ddf1352d8470c140cadc8301b2ae1789db023f01cedd6ba" dependencies = [ "cfg-if", "cpufeatures", "digest", ] -[[package]] -name = "signal-hook" -version = "0.3.17" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8621587d4798caf8eb44879d42e56b9a93ea5dcd315a6487c357130095b62801" -dependencies = [ - "libc", - "signal-hook-registry", -] - [[package]] name = "signal-hook-registry" version = "1.4.1" @@ -3244,63 +3241,45 @@ dependencies = [ [[package]] name = "simd-adler32" -version = "0.3.5" +version = "0.3.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "238abfbb77c1915110ad968465608b68e869e0772622c9656714e73e5a1a522f" +checksum = "d66dc143e6b11c1eddc06d5c423cfc97062865baf299914ab64caa38182078fe" [[package]] name = "siphasher" -version = "0.3.10" +version = "0.3.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7bd3e3206899af3f8b12af284fafc038cc1dc2b41d1b89dd17297221c5d225de" +checksum = "38b58827f4464d87d377d175e90bf58eb00fd8716ff0a62f80356b5e61555d0d" [[package]] name = "slab" -version = "0.4.8" +version = "0.4.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6528351c9bc8ab22353f9d776db39a20288e8d6c37ef8cfe3317cf875eecfc2d" +checksum = "8f92a496fb766b417c996b9c5e57daf2f7ad3b0bebe1ccfca4856390e3d3bb67" dependencies = [ "autocfg", ] [[package]] name = "slotmap" -version = "1.0.6" +version = "1.0.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1e08e261d0e8f5c43123b7adf3e4ca1690d655377ac93a03b2c9d3e98de1342" +checksum = "dbff4acf519f630b3a3ddcfaea6c06b42174d9a44bc70c620e9ed1649d58b82a" dependencies = [ "version_check", ] [[package]] name = "smallvec" -version = "1.10.0" +version = "1.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a507befe795404456341dfab10cef66ead4c041f62b8b11bbb92bffe5d0953e0" +checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" [[package]] name = "smithay-client-toolkit" -version = "0.16.0" +version = "0.18.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f307c47d32d2715eb2e0ece5589057820e0e5e70d07c247d1063e844e107f454" -dependencies = [ - "bitflags 1.3.2", - "dlib", - "lazy_static", - "log", - "memmap2 0.5.10", - "nix 0.24.3", - "pkg-config", - "wayland-client 0.29.5", - "wayland-cursor 0.29.5", - "wayland-protocols 0.29.5", -] - -[[package]] -name = "smithay-client-toolkit" -version = "0.18.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "60e3d9941fa3bacf7c2bf4b065304faa14164151254cd16ce1b1bc8fc381600f" +checksum = "922fd3eeab3bd820d76537ce8f582b1cf951eceb5475c28500c7457d9d17f53a" dependencies = [ "bitflags 2.4.2", "calloop", @@ -3309,26 +3288,27 @@ dependencies = [ "libc", "log", "memmap2 0.9.4", - "rustix 0.38.30", + "rustix 0.38.31", "thiserror", "wayland-backend", - "wayland-client 0.31.2", + "wayland-client", "wayland-csd-frame", - "wayland-cursor 0.31.1", - "wayland-protocols 0.31.2", + "wayland-cursor", + "wayland-protocols", "wayland-protocols-wlr", - "wayland-scanner 0.31.1", + "wayland-scanner", "xkeysym", ] [[package]] name = "smithay-clipboard" -version = "0.6.6" +version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0a345c870a1fae0b1b779085e81b51e614767c239e93503588e54c5b17f4b0e8" +checksum = "c091e7354ea8059d6ad99eace06dd13ddeedbb0ac72d40a9a6e7ff790525882d" dependencies = [ - "smithay-client-toolkit 0.16.0", - "wayland-client 0.29.5", + "libc", + "smithay-client-toolkit", + "wayland-backend", ] [[package]] @@ -3342,14 +3322,24 @@ dependencies = [ [[package]] name = "socket2" -version = "0.4.9" +version = "0.4.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "64a4a911eed85daf18834cfaa86a79b7d266ff93ff5ba14005426219480ed662" +checksum = "9f7916fc008ca5542385b89a3d3ce689953c143e9304a9bf8beec1de48994c0d" dependencies = [ "libc", "winapi", ] +[[package]] +name = "socket2" +version = "0.5.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "05ffd9c0a93b7543e062e759284fcf5f5e3b098501104bfbdde4d404db792871" +dependencies = [ + "libc", + "windows-sys 0.52.0", +] + [[package]] name = "softbuffer" version = "0.4.1" @@ -3370,15 +3360,15 @@ dependencies = [ "objc", "raw-window-handle", "redox_syscall 0.4.1", - "rustix 0.38.30", + "rustix 0.38.31", "tiny-xlib", "wasm-bindgen", "wayland-backend", - "wayland-client 0.31.2", - "wayland-sys 0.31.1", + "wayland-client", + "wayland-sys", "web-sys", "windows-sys 0.52.0", - "x11rb 0.13.0", + "x11rb", ] [[package]] @@ -3413,16 +3403,17 @@ checksum = "6637bab7722d379c8b41ba849228d680cc12d0a45ba1fa2b48f2a30577a06731" [[package]] name = "svg_fmt" -version = "0.4.1" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8fb1df15f412ee2e9dfc1c504260fa695c1c3f10fe9f4a6ee2d2184d7d6450e2" +checksum = "f83ba502a3265efb76efb89b0a2f7782ad6f2675015d4ce37e4b547dda42b499" [[package]] name = "swash" -version = "0.1.8" +version = "0.1.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3b7c73c813353c347272919aa1af2885068b05e625e5532b43049e4f641ae77f" +checksum = "d06ff4664af8923625604261c645f5c4cc610cc83c84bec74b50d76237089de7" dependencies = [ + "read-fonts", "yazi", "zeno", ] @@ -3440,9 +3431,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.48" +version = "2.0.52" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0f3531638e407dfc0814761abb7c00a5b54992b849452a0646b7f65c9f770f3f" +checksum = "b699d15b36d1f02c3e7c69f8ffef53de37aefae075d8488d4ba1a7788d574a07" dependencies = [ "proc-macro2", "quote", @@ -3460,25 +3451,24 @@ dependencies = [ [[package]] name = "tauri-winrt-notification" -version = "0.1.2" +version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f5bff1d532fead7c43324a0fa33643b8621a47ce2944a633be4cb6c0240898f" +checksum = "006851c9ccefa3c38a7646b8cec804bb429def3da10497bfa977179869c3e8e2" dependencies = [ - "quick-xml 0.23.1", - "windows 0.39.0", + "quick-xml 0.30.0", + "windows 0.51.1", ] [[package]] name = "tempfile" -version = "3.5.0" +version = "3.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9fbec84f381d5795b08656e4912bec604d162bff9291d6189a78f4c8ab87998" +checksum = "85b77fafb263dd9d05cbeac119526425676db3784113aa9295c88498cbf8bff1" dependencies = [ "cfg-if", - "fastrand 1.9.0", - "redox_syscall 0.3.5", - "rustix 0.37.19", - "windows-sys 0.45.0", + "fastrand 2.0.1", + "rustix 0.38.31", + "windows-sys 0.52.0", ] [[package]] @@ -3492,29 +3482,29 @@ dependencies = [ [[package]] name = "thiserror" -version = "1.0.56" +version = "1.0.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d54378c645627613241d077a3a79db965db602882668f9136ac42af9ecb730ad" +checksum = "03468839009160513471e86a034bb2c5c0e4baae3b43f79ffc55c4a5427b3297" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.56" +version = "1.0.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fa0faa943b50f3db30a20aa7e265dbc66076993efed8463e8de414e5d06d3471" +checksum = "c61f3ba182994efc43764a46c018c347bc492c79f024e705f46567b418f6d4f7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "tiff" -version = "0.8.1" +version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7449334f9ff2baf290d55d73983a7d6fa15e01198faef72af07e2a8db851e471" +checksum = "ba1310fcea54c6a9a4fd1aad794ecc02c31682f6bfbecdf460bf19533eed1e3e" dependencies = [ "flate2", "jpeg-decoder", @@ -3523,25 +3513,28 @@ dependencies = [ [[package]] name = "time" -version = "0.3.23" +version = "0.3.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "59e399c068f43a5d116fedaf73b203fa4f9c519f17e2b34f63221d3792f81446" +checksum = "c8248b6521bb14bc45b4067159b9b6ad792e2d6d754d6c41fb50e29fefe38749" dependencies = [ + "deranged", + "num-conv", + "powerfmt", "serde", "time-core", ] [[package]] name = "time-core" -version = "0.1.1" +version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7300fbefb4dadc1af235a9cef3737cea692a9d97e1b9cbcd4ebdae6f8868e6fb" +checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" [[package]] name = "tiny-skia" -version = "0.11.3" +version = "0.11.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b6a067b809476893fce6a254cf285850ff69c847e6cfbade6a20b655b6c7e80d" +checksum = "83d13394d44dae3207b52a326c0c85a8bf87f1541f23b0d143811088497b09ab" dependencies = [ "arrayref", "arrayvec", @@ -3554,9 +3547,9 @@ dependencies = [ [[package]] name = "tiny-skia-path" -version = "0.11.3" +version = "0.11.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5de35e8a90052baaaf61f171680ac2f8e925a1e43ea9d2e3a00514772250e541" +checksum = "9c9e7fc0c2e86a30b117d0462aa261b72b7a99b7ebd7deb3a14ceda95c5bdc93" dependencies = [ "arrayref", "bytemuck", @@ -3571,7 +3564,7 @@ checksum = "d4098d49269baa034a8d1eae9bd63e9fa532148d772121dace3bcd6a6c98eb6d" dependencies = [ "as-raw-xcb-connection", "ctor", - "libloading 0.8.0", + "libloading 0.8.3", "tracing", ] @@ -3592,11 +3585,10 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokio" -version = "1.29.1" +version = "1.36.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "532826ff75199d5833b9d2c5fe410f29235e25704ee5f0ef599fb51c21f4a4da" +checksum = "61285f6515fa018fb2d1e46eb21223fff441ee8db5d0f1435e8ab4f5cdb80931" dependencies = [ - "autocfg", "backtrace", "bytes", "libc", @@ -3605,20 +3597,20 @@ dependencies = [ "parking_lot 0.12.1", "pin-project-lite", "signal-hook-registry", - "socket2", + "socket2 0.5.6", "tokio-macros", "windows-sys 0.48.0", ] [[package]] name = "tokio-macros" -version = "2.1.0" +version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "630bdcf245f78637c13ec01ffae6187cca34625e8c63150d424b59e55af2675e" +checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -3644,9 +3636,9 @@ dependencies = [ [[package]] name = "tokio-util" -version = "0.7.8" +version = "0.7.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "806fe8c2c87eccc8b3267cbae29ed3ab2d0bd37fca70ab622e46aaa9375ddb7d" +checksum = "5419f34732d9eb6ee4c3578b7989078579b7f039cbbb9ca2c4da015749371e15" dependencies = [ "bytes", "futures-core", @@ -3658,45 +3650,66 @@ dependencies = [ [[package]] name = "toml" -version = "0.7.4" +version = "0.8.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d6135d499e69981f9ff0ef2167955a5333c35e36f6937d382974566b3d5b94ec" +checksum = "af06656561d28735e9c1cd63dfd57132c8155426aa6af24f36a00a351f88c48e" dependencies = [ "serde", "serde_spanned", "toml_datetime", - "toml_edit", + "toml_edit 0.22.7", ] [[package]] name = "toml_datetime" -version = "0.6.2" +version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a76a9312f5ba4c2dec6b9161fdf25d87ad8a09256ccea5a556fef03c706a10f" +checksum = "3550f4e9685620ac18a50ed434eb3aec30db8ba93b0287467bca5826ea25baf1" dependencies = [ "serde", ] [[package]] name = "toml_edit" -version = "0.19.10" +version = "0.19.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1b5bb770da30e5cbfde35a2d7b9b8a2c4b8ef89548a7a6aeab5c9a576e3e7421" +dependencies = [ + "indexmap", + "toml_datetime", + "winnow 0.5.40", +] + +[[package]] +name = "toml_edit" +version = "0.21.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2380d56e8670370eee6566b0bfd4265f65b3f432e8c6d85623f728d4fa31f739" +checksum = "6a8534fd7f78b5405e860340ad6575217ce99f38d4d5c8f2442cb5ecb50090e1" dependencies = [ - "indexmap 1.9.3", + "indexmap", + "toml_datetime", + "winnow 0.5.40", +] + +[[package]] +name = "toml_edit" +version = "0.22.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "18769cd1cec395d70860ceb4d932812a0b4d06b1a4bb336745a4d21b9496e992" +dependencies = [ + "indexmap", "serde", "serde_spanned", "toml_datetime", - "winnow", + "winnow 0.6.5", ] [[package]] name = "tracing" -version = "0.1.37" +version = "0.1.40" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8ce8c33a8d48bd45d624a6e523445fd21ec13d3653cd51f681abf67418f54eb8" +checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef" dependencies = [ - "cfg-if", "pin-project-lite", "tracing-attributes", "tracing-core", @@ -3704,29 +3717,29 @@ dependencies = [ [[package]] name = "tracing-attributes" -version = "0.1.26" +version = "0.1.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f4f31f56159e98206da9efd823404b79b6ef3143b4a7ab76e67b1751b25a4ab" +checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] name = "tracing-core" -version = "0.1.31" +version = "0.1.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0955b8137a1df6f1a2e9a37d8a6656291ff0297c1a97c24e0d8425fe2312f79a" +checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" dependencies = [ "once_cell", ] [[package]] name = "ttf-parser" -version = "0.19.0" +version = "0.19.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "44dcf002ae3b32cd25400d6df128c5babec3927cd1eb7ce813cfff20eb6c3746" +checksum = "49d64318d8311fc2668e48b63969f4343e0a85c4a109aa8460d6672e364b8bd1" [[package]] name = "ttf-parser" @@ -3736,25 +3749,26 @@ checksum = "17f77d76d837a7830fe1d4f12b7b4ba4192c1888001c7164257e4bc6d21d96b4" [[package]] name = "typenum" -version = "1.16.0" +version = "1.17.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "497961ef93d974e23eb6f433eb5fe1b7930b659f06d12dec6fc44a8f554c0bba" +checksum = "42ff0bf0c66b8238c6f3b578df37d0b7848e55df8577b3f74f92a69acceeb825" [[package]] name = "uds_windows" -version = "1.0.2" +version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ce65604324d3cce9b966701489fbd0cf318cb1f7bd9dd07ac9a4ee6fb791930d" +checksum = "89daebc3e6fd160ac4aa9fc8b3bf71e1f74fbf92367ae71fb83a037e8bf164b9" dependencies = [ + "memoffset 0.9.0", "tempfile", "winapi", ] [[package]] name = "unicode-bidi" -version = "0.3.13" +version = "0.3.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "92888ba5573ff080736b3648696b70cafad7d250551175acbaa4e0385b3e1460" +checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75" [[package]] name = "unicode-bidi-mirroring" @@ -3770,9 +3784,9 @@ checksum = "cc2520efa644f8268dce4dcd3050eaa7fc044fca03961e9998ac7e2e92b77cf1" [[package]] name = "unicode-ident" -version = "1.0.9" +version = "1.0.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b15811caf2415fb889178633e7724bad2509101cde276048e013b9def5e51fa0" +checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" [[package]] name = "unicode-linebreak" @@ -3788,21 +3802,21 @@ checksum = "e4259d9d4425d9f0661581b804cb85fe66a4c631cadd8f490d1c13a35d5d9291" [[package]] name = "unicode-script" -version = "0.5.5" +version = "0.5.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7d817255e1bed6dfd4ca47258685d14d2bdcfbc64fdc9e3819bd5848057b8ecc" +checksum = "ad8d71f5726e5f285a935e9fe8edfd53f0491eb6e9a5774097fdabee7cd8c9cd" [[package]] name = "unicode-segmentation" -version = "1.10.1" +version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1dd624098567895118886609431a7c3b8f516e41d30e0643f03d94592a147e36" +checksum = "d4c87d22b6e3f4a18d4d40ef354e97c90fcb14dd91d7dc0aa9d8a1172ebf7202" [[package]] name = "unicode-width" -version = "0.1.10" +version = "0.1.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c0edd1e5b14653f783770bce4a4dabb4a5108a5370a5f5d8cfe8710c361f6c8b" +checksum = "e51733f11c9c4f72aa0c160008246859e340b00807569a0da0e7a1079b27ba85" [[package]] name = "unicode-xid" @@ -3818,9 +3832,9 @@ checksum = "ab4c90930b95a82d00dc9e9ac071b4991924390d46cbd0dfe566148667605e4b" [[package]] name = "uuid" -version = "1.3.3" +version = "1.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "345444e32442451b267fc254ae85a209c64be56d2890e601a0c37ff0c3c5ecd2" +checksum = "f00cc9702ca12d3c81455259621e676d0f7251cec66a21e98fe2e9a37db93b2a" dependencies = [ "getrandom", ] @@ -3859,15 +3873,15 @@ dependencies = [ [[package]] name = "waker-fn" -version = "1.1.0" +version = "1.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9d5b2c62b4012a3e1eca5a7e077d13b3bf498c4073e33ccd58626607748ceeca" +checksum = "f3c4517f54858c779bbcbf228f4fca63d121bf85fbecb2dc578cdf4a39395690" [[package]] name = "walkdir" -version = "2.4.0" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d71d857dc86794ca4c280d616f7da00d2dbfd8cd788846559a6813e6aa4b54ee" +checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b" dependencies = [ "same-file", "winapi-util", @@ -3881,9 +3895,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.90" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1223296a201415c7fad14792dbefaace9bd52b62d33453ade1c5b5f07555406" +checksum = "4be2531df63900aeb2bca0daaaddec08491ee64ceecbee5076636a3b026795a8" dependencies = [ "cfg-if", "wasm-bindgen-macro", @@ -3891,24 +3905,24 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.90" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fcdc935b63408d58a32f8cc9738a0bffd8f05cc7c002086c6ef20b7312ad9dcd" +checksum = "614d787b966d3989fa7bb98a654e369c762374fd3213d212cfc0251257e747da" dependencies = [ "bumpalo", "log", "once_cell", "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-futures" -version = "0.4.40" +version = "0.4.42" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bde2032aeb86bdfaecc8b261eef3cba735cc426c1f3a3416d1e0791be95fc461" +checksum = "76bc14366121efc8dbb487ab05bcc9d346b3b5ec0eaa76e46594cabbe51762c0" dependencies = [ "cfg-if", "js-sys", @@ -3918,9 +3932,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.90" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3e4c238561b2d428924c49815533a8b9121c664599558a5d9ec51f8a1740a999" +checksum = "a1f8823de937b71b9460c0c34e25f3da88250760bec0ebac694b49997550d726" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -3928,22 +3942,22 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.90" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bae1abb6806dc1ad9e560ed242107c0f6c84335f1749dd4e8ddb012ebd5e25a7" +checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.90" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4d91413b1c31d7539ba5ef2451af3f0b833a005eb27a631cec32bc0635a8602b" +checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96" [[package]] name = "wasm-timer" @@ -3968,26 +3982,10 @@ checksum = "9d50fa61ce90d76474c87f5fc002828d81b32677340112b4ef08079a9d459a40" dependencies = [ "cc", "downcast-rs", - "rustix 0.38.30", + "rustix 0.38.31", "scoped-tls", "smallvec", - "wayland-sys 0.31.1", -] - -[[package]] -name = "wayland-client" -version = "0.29.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f3b068c05a039c9f755f881dc50f01732214f5685e379829759088967c46715" -dependencies = [ - "bitflags 1.3.2", - "downcast-rs", - "libc", - "nix 0.24.3", - "scoped-tls", - "wayland-commons", - "wayland-scanner 0.29.5", - "wayland-sys 0.29.5", + "wayland-sys", ] [[package]] @@ -3997,21 +3995,9 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "82fb96ee935c2cea6668ccb470fb7771f6215d1691746c2d896b447a00ad3f1f" dependencies = [ "bitflags 2.4.2", - "rustix 0.38.30", + "rustix 0.38.31", "wayland-backend", - "wayland-scanner 0.31.1", -] - -[[package]] -name = "wayland-commons" -version = "0.29.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8691f134d584a33a6606d9d717b95c4fa20065605f798a3f350d78dced02a902" -dependencies = [ - "nix 0.24.3", - "once_cell", - "smallvec", - "wayland-sys 0.29.5", + "wayland-scanner", ] [[package]] @@ -4025,40 +4011,17 @@ dependencies = [ "wayland-backend", ] -[[package]] -name = "wayland-cursor" -version = "0.29.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6865c6b66f13d6257bef1cd40cbfe8ef2f150fb8ebbdb1e8e873455931377661" -dependencies = [ - "nix 0.24.3", - "wayland-client 0.29.5", - "xcursor", -] - [[package]] name = "wayland-cursor" version = "0.31.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "71ce5fa868dd13d11a0d04c5e2e65726d0897be8de247c0c5a65886e283231ba" dependencies = [ - "rustix 0.38.30", - "wayland-client 0.31.2", + "rustix 0.38.31", + "wayland-client", "xcursor", ] -[[package]] -name = "wayland-protocols" -version = "0.29.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b950621f9354b322ee817a23474e479b34be96c2e909c14f7bc0100e9a970bc6" -dependencies = [ - "bitflags 1.3.2", - "wayland-client 0.29.5", - "wayland-commons", - "wayland-scanner 0.29.5", -] - [[package]] name = "wayland-protocols" version = "0.31.2" @@ -4067,8 +4030,8 @@ checksum = "8f81f365b8b4a97f422ac0e8737c438024b5951734506b0e1d775c73030561f4" dependencies = [ "bitflags 2.4.2", "wayland-backend", - "wayland-client 0.31.2", - "wayland-scanner 0.31.1", + "wayland-client", + "wayland-scanner", ] [[package]] @@ -4079,9 +4042,9 @@ checksum = "23803551115ff9ea9bce586860c5c5a971e360825a0309264102a9495a5ff479" dependencies = [ "bitflags 2.4.2", "wayland-backend", - "wayland-client 0.31.2", - "wayland-protocols 0.31.2", - "wayland-scanner 0.31.1", + "wayland-client", + "wayland-protocols", + "wayland-scanner", ] [[package]] @@ -4092,20 +4055,9 @@ checksum = "ad1f61b76b6c2d8742e10f9ba5c3737f6530b4c243132c2a2ccc8aa96fe25cd6" dependencies = [ "bitflags 2.4.2", "wayland-backend", - "wayland-client 0.31.2", - "wayland-protocols 0.31.2", - "wayland-scanner 0.31.1", -] - -[[package]] -name = "wayland-scanner" -version = "0.29.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f4303d8fa22ab852f789e75a967f0a2cdc430a607751c0499bada3e451cbd53" -dependencies = [ - "proc-macro2", - "quote", - "xml-rs", + "wayland-client", + "wayland-protocols", + "wayland-scanner", ] [[package]] @@ -4119,17 +4071,6 @@ dependencies = [ "quote", ] -[[package]] -name = "wayland-sys" -version = "0.29.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "be12ce1a3c39ec7dba25594b97b42cb3195d54953ddb9d3d95a7c3902bc6e9d4" -dependencies = [ - "dlib", - "lazy_static", - "pkg-config", -] - [[package]] name = "wayland-sys" version = "0.31.1" @@ -4164,15 +4105,15 @@ dependencies = [ [[package]] name = "weezl" -version = "0.1.7" +version = "0.1.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9193164d4de03a926d909d3bc7c30543cecb35400c02114792c2cae20d5e2dbb" +checksum = "53a85b86a771b1c87058196170769dd264f66c0782acf1ae6cc51bfd64b39082" [[package]] name = "wgpu" -version = "0.19.1" +version = "0.19.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0bfe9a310dcf2e6b85f00c46059aaeaf4184caa8e29a1ecd4b7a704c3482332d" +checksum = "a4b1213b52478a7631d6e387543ed8f642bc02c578ef4e3b49aca2a29a7df0cb" dependencies = [ "arrayvec", "cfg-if", @@ -4195,16 +4136,16 @@ dependencies = [ [[package]] name = "wgpu-core" -version = "0.19.0" +version = "0.19.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6b15e451d4060ada0d99a64df44e4d590213496da7c4f245572d51071e8e30ed" +checksum = "f9f6b033c2f00ae0bc8ea872c5989777c60bc241aac4e58b24774faa8b391f78" dependencies = [ "arrayvec", "bit-vec", "bitflags 2.4.2", "cfg_aliases 0.1.1", "codespan-reporting", - "indexmap 2.2.1", + "indexmap", "log", "naga", "once_cell", @@ -4221,9 +4162,9 @@ dependencies = [ [[package]] name = "wgpu-hal" -version = "0.19.1" +version = "0.19.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e3bb47856236bfafc0bc591a925eb036ac19cd987624a447ff353e7a7e7e6f72" +checksum = "49f972c280505ab52ffe17e94a7413d9d54b58af0114ab226b9fc4999a47082e" dependencies = [ "android_system_properties", "arrayvec", @@ -4243,10 +4184,11 @@ dependencies = [ "js-sys", "khronos-egl", "libc", - "libloading 0.8.0", + "libloading 0.8.3", "log", "metal", "naga", + "ndk-sys", "objc", "once_cell", "parking_lot 0.12.1", @@ -4265,9 +4207,9 @@ dependencies = [ [[package]] name = "wgpu-types" -version = "0.19.0" +version = "0.19.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "895fcbeb772bfb049eb80b2d6e47f6c9af235284e9703c96fc0218a42ffd5af2" +checksum = "b671ff9fb03f78b46ff176494ee1ebe7d603393f42664be55b64dc8d53969805" dependencies = [ "bitflags 2.4.2", "js-sys", @@ -4298,18 +4240,9 @@ checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" [[package]] name = "winapi-util" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "70ec6ce85bb158151cae5e5c87f95a8e97d2c0c4b001223f33a334e3ce5de178" -dependencies = [ - "winapi", -] - -[[package]] -name = "winapi-wsapoll" -version = "0.1.1" +version = "0.1.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "44c17110f57155602a80dca10be03852116403c9ff3cd25b079d666f2aa3df6e" +checksum = "f29e6f9198ba0d26b4c9f07dbe6f9ed633e1f3d5b8b414090084349e46a52596" dependencies = [ "winapi", ] @@ -4322,9 +4255,9 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" [[package]] name = "window_clipboard" -version = "0.4.0" +version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c6a197337269a469b5b2583d65dd7dfe475fd79a525be0aa647ff6d37ac6612c" +checksum = "f6d692d46038c433f9daee7ad8757e002a4248c20b0a3fbc991d99521d3bcb6d" dependencies = [ "clipboard-win", "clipboard_macos", @@ -4336,24 +4269,12 @@ dependencies = [ [[package]] name = "windows" -version = "0.39.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1c4bd0a50ac6020f65184721f758dba47bb9fbc2133df715ec74a237b26794a" -dependencies = [ - "windows_aarch64_msvc 0.39.0", - "windows_i686_gnu 0.39.0", - "windows_i686_msvc 0.39.0", - "windows_x86_64_gnu 0.39.0", - "windows_x86_64_msvc 0.39.0", -] - -[[package]] -name = "windows" -version = "0.48.0" +version = "0.51.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e686886bc078bc1b0b600cac0147aadb815089b6e4da64016cbd754b6342700f" +checksum = "ca229916c5ee38c2f2bc1e9d8f04df975b4bd93f9955dc69fabb5d91270045c9" dependencies = [ - "windows-targets 0.48.0", + "windows-core 0.51.1", + "windows-targets 0.48.5", ] [[package]] @@ -4362,32 +4283,26 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e48a53791691ab099e5e2ad123536d0fff50652600abaf43bbf952894110d0be" dependencies = [ - "windows-core", - "windows-targets 0.52.0", + "windows-core 0.52.0", + "windows-targets 0.52.4", ] [[package]] name = "windows-core" -version = "0.52.0" +version = "0.51.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" +checksum = "f1f8cf84f35d2db49a46868f947758c7a1138116f7fac3bc844f43ade1292e64" dependencies = [ - "windows-targets 0.52.0", + "windows-targets 0.48.5", ] [[package]] -name = "windows-sys" -version = "0.42.0" +name = "windows-core" +version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a3e1820f08b8513f676f7ab6c1f99ff312fb97b553d30ff4dd86f9f15728aa7" +checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" dependencies = [ - "windows_aarch64_gnullvm 0.42.2", - "windows_aarch64_msvc 0.42.2", - "windows_i686_gnu 0.42.2", - "windows_i686_msvc 0.42.2", - "windows_x86_64_gnu 0.42.2", - "windows_x86_64_gnullvm 0.42.2", - "windows_x86_64_msvc 0.42.2", + "windows-targets 0.52.4", ] [[package]] @@ -4405,7 +4320,7 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets 0.48.0", + "windows-targets 0.48.5", ] [[package]] @@ -4414,7 +4329,7 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" dependencies = [ - "windows-targets 0.52.0", + "windows-targets 0.52.4", ] [[package]] @@ -4434,32 +4349,32 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b1eb6f0cd7c80c79759c929114ef071b87354ce476d9d94271031c0497adfd5" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" dependencies = [ - "windows_aarch64_gnullvm 0.48.0", - "windows_aarch64_msvc 0.48.0", - "windows_i686_gnu 0.48.0", - "windows_i686_msvc 0.48.0", - "windows_x86_64_gnu 0.48.0", - "windows_x86_64_gnullvm 0.48.0", - "windows_x86_64_msvc 0.48.0", + "windows_aarch64_gnullvm 0.48.5", + "windows_aarch64_msvc 0.48.5", + "windows_i686_gnu 0.48.5", + "windows_i686_msvc 0.48.5", + "windows_x86_64_gnu 0.48.5", + "windows_x86_64_gnullvm 0.48.5", + "windows_x86_64_msvc 0.48.5", ] [[package]] name = "windows-targets" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a18201040b24831fbb9e4eb208f8892e1f50a37feb53cc7ff887feb8f50e7cd" +checksum = "7dd37b7e5ab9018759f893a1952c9420d060016fc19a472b4bb20d1bdd694d1b" dependencies = [ - "windows_aarch64_gnullvm 0.52.0", - "windows_aarch64_msvc 0.52.0", - "windows_i686_gnu 0.52.0", - "windows_i686_msvc 0.52.0", - "windows_x86_64_gnu 0.52.0", - "windows_x86_64_gnullvm 0.52.0", - "windows_x86_64_msvc 0.52.0", + "windows_aarch64_gnullvm 0.52.4", + "windows_aarch64_msvc 0.52.4", + "windows_i686_gnu 0.52.4", + "windows_i686_msvc 0.52.4", + "windows_x86_64_gnu 0.52.4", + "windows_x86_64_gnullvm 0.52.4", + "windows_x86_64_msvc 0.52.4", ] [[package]] @@ -4470,21 +4385,15 @@ checksum = "597a5118570b68bc08d8d59125332c54f1ba9d9adeedeef5b99b02ba2b0698f8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea" - -[[package]] -name = "windows_aarch64_msvc" -version = "0.39.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ec7711666096bd4096ffa835238905bb33fb87267910e154b18b44eaabb340f2" +checksum = "bcf46cf4c365c6f2d1cc93ce535f2c8b244591df96ceee75d8e83deb70a9cac9" [[package]] name = "windows_aarch64_msvc" @@ -4494,21 +4403,15 @@ checksum = "e08e8864a60f06ef0d0ff4ba04124db8b0fb3be5776a5cd47641e942e58c4d43" [[package]] name = "windows_aarch64_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_aarch64_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef" - -[[package]] -name = "windows_i686_gnu" -version = "0.39.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "763fc57100a5f7042e3057e7e8d9bdd7860d330070251a73d003563a3bb49e1b" +checksum = "da9f259dd3bcf6990b55bffd094c4f7235817ba4ceebde8e6d11cd0c5633b675" [[package]] name = "windows_i686_gnu" @@ -4518,21 +4421,15 @@ checksum = "c61d927d8da41da96a81f029489353e68739737d3beca43145c8afec9a31a84f" [[package]] name = "windows_i686_gnu" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_gnu" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313" - -[[package]] -name = "windows_i686_msvc" -version = "0.39.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7bc7cbfe58828921e10a9f446fcaaf649204dcfe6c1ddd712c5eebae6bda1106" +checksum = "b474d8268f99e0995f25b9f095bc7434632601028cf86590aea5c8a5cb7801d3" [[package]] name = "windows_i686_msvc" @@ -4542,21 +4439,15 @@ checksum = "44d840b6ec649f480a41c8d80f9c65108b92d89345dd94027bfe06ac444d1060" [[package]] name = "windows_i686_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_i686_msvc" -version = "0.52.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a" - -[[package]] -name = "windows_x86_64_gnu" -version = "0.39.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6868c165637d653ae1e8dc4d82c25d4f97dd6605eaa8d784b5c6e0ab2a252b65" +checksum = "1515e9a29e5bed743cb4415a9ecf5dfca648ce85ee42e15873c3cd8610ff8e02" [[package]] name = "windows_x86_64_gnu" @@ -4566,15 +4457,15 @@ checksum = "8de912b8b8feb55c064867cf047dda097f92d51efad5b491dfb98f6bbb70cb36" [[package]] name = "windows_x86_64_gnu" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnu" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd" +checksum = "5eee091590e89cc02ad514ffe3ead9eb6b660aedca2183455434b93546371a03" [[package]] name = "windows_x86_64_gnullvm" @@ -4584,21 +4475,15 @@ checksum = "26d41b46a36d453748aedef1486d5c7a85db22e56aff34643984ea85514e94a3" [[package]] name = "windows_x86_64_gnullvm" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_gnullvm" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e" - -[[package]] -name = "windows_x86_64_msvc" -version = "0.39.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e4d40883ae9cae962787ca76ba76390ffa29214667a111db9e0a1ad8377e809" +checksum = "77ca79f2451b49fa9e2af39f0747fe999fcda4f5e241b2898624dca97a1f2177" [[package]] name = "windows_x86_64_msvc" @@ -4608,22 +4493,22 @@ checksum = "9aec5da331524158c6d1a4ac0ab1541149c0b9505fde06423b02f5ef0106b9f0" [[package]] name = "windows_x86_64_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "windows_x86_64_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dff9641d1cd4be8d1a070daf9e3773c5f67e78b4d9d42263020c057706765c04" +checksum = "32b752e52a2da0ddfbdbcc6fceadfeede4c939ed16d13e648833a61dfb611ed8" [[package]] name = "winit" version = "0.29.10" source = "git+https://github.com/iced-rs/winit.git?rev=b91e39ece2c0d378c3b80da7f3ab50e17bb798a5#b91e39ece2c0d378c3b80da7f3ab50e17bb798a5" dependencies = [ - "ahash 0.8.7", + "ahash", "android-activity", "atomic-waker", "bitflags 2.4.2", @@ -4646,42 +4531,51 @@ dependencies = [ "percent-encoding", "raw-window-handle", "redox_syscall 0.3.5", - "rustix 0.38.30", + "rustix 0.38.31", "sctk-adwaita", - "smithay-client-toolkit 0.18.0", + "smithay-client-toolkit", "smol_str", "unicode-segmentation", "wasm-bindgen", "wasm-bindgen-futures", "wayland-backend", - "wayland-client 0.31.2", - "wayland-protocols 0.31.2", + "wayland-client", + "wayland-protocols", "wayland-protocols-plasma", "web-sys", "web-time", "windows-sys 0.48.0", "x11-dl", - "x11rb 0.13.0", + "x11rb", "xkbcommon-dl", ] [[package]] name = "winnow" -version = "0.4.6" +version = "0.5.40" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f593a95398737aeed53e489c785df13f3618e41dbcd6718c6addbf1395aa6876" +dependencies = [ + "memchr", +] + +[[package]] +name = "winnow" +version = "0.6.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61de7bac303dc551fe038e2b3cef0f571087a47571ea6e79a87692ac99b99699" +checksum = "dffa400e67ed5a4dd237983829e66475f0a4a26938c4b04c21baede6262215b8" dependencies = [ "memchr", ] [[package]] name = "winreg" -version = "0.11.0" +version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "76a1a57ff50e9b408431e8f97d5456f2807f8eb2a2cd79b06068fc87f8ecf189" +checksum = "a277a57398d4bfa075df44f501a17cfdf8542d224f0d36095a2adc7aee4ef0a5" dependencies = [ "cfg-if", - "winapi", + "windows-sys 0.48.0", ] [[package]] @@ -4695,18 +4589,6 @@ dependencies = [ "pkg-config", ] -[[package]] -name = "x11rb" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6e99be55648b3ae2a52342f9a870c0e138709a3493261ce9b469afe6e4df6d8a" -dependencies = [ - "gethostname 0.2.3", - "nix 0.22.3", - "winapi", - "winapi-wsapoll", -] - [[package]] name = "x11rb" version = "0.13.0" @@ -4714,11 +4596,11 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f8f25ead8c7e4cba123243a6367da5d3990e0d3affa708ea19dce96356bd9f1a" dependencies = [ "as-raw-xcb-connection", - "gethostname 0.4.3", + "gethostname", "libc", - "libloading 0.8.0", + "libloading 0.8.3", "once_cell", - "rustix 0.38.30", + "rustix 0.38.31", "x11rb-protocol", ] @@ -4730,28 +4612,25 @@ checksum = "e63e71c4b8bd9ffec2c963173a4dc4cbde9ee96961d4fcb4429db9929b606c34" [[package]] name = "xcursor" -version = "0.3.4" +version = "0.3.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "463705a63313cd4301184381c5e8042f0a7e9b4bb63653f216311d4ae74690b7" -dependencies = [ - "nom", -] +checksum = "6a0ccd7b4a5345edfcd0c3535718a4e9ff7798ffc536bb5b5a0e26ff84732911" [[package]] name = "xdg-home" -version = "1.0.0" +version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2769203cd13a0c6015d515be729c526d041e9cf2c0cc478d57faee85f40c6dcd" +checksum = "21e5a325c3cb8398ad6cf859c1135b25dd29e186679cf2da7581d9679f63b38e" dependencies = [ - "nix 0.26.2", + "libc", "winapi", ] [[package]] name = "xkbcommon-dl" -version = "0.4.1" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6924668544c48c0133152e7eec86d644a056ca3d09275eb8d5cdb9855f9d8699" +checksum = "d039de8032a9a8856a6be89cea3e5d12fdd82306ab7c94d74e6deab2460651c5" dependencies = [ "bitflags 2.4.2", "dlib", @@ -4768,15 +4647,21 @@ checksum = "054a8e68b76250b253f671d1268cb7f1ae089ec35e195b2efb2a4e9a836d0621" [[package]] name = "xml-rs" -version = "0.8.13" +version = "0.8.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2d8f380ae16a37b30e6a2cf67040608071384b1450c189e61bea3ff57cde922d" +checksum = "0fcb9cbac069e033553e8bb871be2fbdffcab578eb25bd0f7c508cedc6dcd75a" [[package]] name = "xxhash-rust" -version = "0.8.8" +version = "0.8.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53be06678ed9e83edb1745eb72efc0bbcd7b5c3c35711a860906aed827a13d61" +checksum = "927da81e25be1e1a2901d59b81b37dd2efd1fc9c9345a55007f09bf5a2d3ee03" + +[[package]] +name = "yansi" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cfe53a6657fd280eaa890a3bc59152892ffa3e30101319d168b781ed6529b049" [[package]] name = "yazi" @@ -4786,15 +4671,15 @@ checksum = "c94451ac9513335b5e23d7a8a2b61a7102398b8cca5160829d313e84c9d98be1" [[package]] name = "zbus" -version = "3.14.1" +version = "3.15.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "31de390a2d872e4cd04edd71b425e29853f786dc99317ed72d73d6fcf5ebb948" +checksum = "675d170b632a6ad49804c8cf2105d7c31eddd3312555cffd4b740e08e97c25e6" dependencies = [ "async-broadcast", "async-executor", "async-fs", - "async-io", - "async-lock", + "async-io 1.13.0", + "async-lock 2.8.0", "async-process", "async-recursion", "async-task", @@ -4803,12 +4688,12 @@ dependencies = [ "byteorder", "derivative", "enumflags2", - "event-listener", + "event-listener 2.5.3", "futures-core", "futures-sink", "futures-util", "hex", - "nix 0.26.2", + "nix", "once_cell", "ordered-stream", "rand", @@ -4827,11 +4712,11 @@ dependencies = [ [[package]] name = "zbus_macros" -version = "3.14.1" +version = "3.15.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "41d1794a946878c0e807f55a397187c11fc7a038ba5d868e7db4f3bd7760bc9d" +checksum = "7131497b0f887e8061b430c530240063d33bf9455fa34438f388a245da69e0a5" dependencies = [ - "proc-macro-crate", + "proc-macro-crate 1.3.1", "proc-macro2", "quote", "regex", @@ -4841,9 +4726,9 @@ dependencies = [ [[package]] name = "zbus_names" -version = "2.6.0" +version = "2.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fb80bb776dbda6e23d705cf0123c3b95df99c4ebeaec6c2599d4a5419902b4a9" +checksum = "437d738d3750bed6ca9b8d423ccc7a8eb284f6b1d6d4e225a0e4e6258d864c8d" dependencies = [ "serde", "static_assertions", @@ -4852,9 +4737,9 @@ dependencies = [ [[package]] name = "zeno" -version = "0.2.2" +version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c110ba09c9b3a43edd4803d570df0da2414fed6e822e22b976a4e3ef50860701" +checksum = "dd15f8e0dbb966fd9245e7498c7e9e5055d9e5c8b676b95bd67091cd11a1e697" [[package]] name = "zerocopy" @@ -4873,7 +4758,7 @@ checksum = "9ce1b18ccd8e73a9321186f97e46f9f04b778851177567b1975109d26a08d2a6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.48", + "syn 2.0.52", ] [[package]] @@ -4887,9 +4772,9 @@ dependencies = [ [[package]] name = "zvariant" -version = "3.15.0" +version = "3.15.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "44b291bee0d960c53170780af148dca5fa260a63cdd24f1962fa82e03e53338c" +checksum = "4eef2be88ba09b358d3b58aca6e41cd853631d44787f319a1383ca83424fb2db" dependencies = [ "byteorder", "enumflags2", @@ -4901,11 +4786,11 @@ dependencies = [ [[package]] name = "zvariant_derive" -version = "3.15.0" +version = "3.15.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "934d7a7dfc310d6ee06c87ffe88ef4eca7d3e37bb251dece2ef93da8f17d8ecd" +checksum = "37c24dc0bed72f5f90d1f8bb5b07228cbf63b3c6e9f82d82559d4bae666e7ed9" dependencies = [ - "proc-macro-crate", + "proc-macro-crate 1.3.1", "proc-macro2", "quote", "syn 1.0.109", diff --git a/Cargo.toml b/Cargo.toml index 3ed8bfb9a..652f2bccf 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -14,7 +14,7 @@ data = { version = "0.1.0", path = "data" } notify-rust = "4" chrono = { version = "0.4", features = ['serde'] } fern = "0.6.1" -iced = { version = "0.12.0", features = ["tokio", "lazy", "advanced", "image"] } +iced = { version = "0.13.0-dev", features = ["tokio", "lazy", "advanced", "image"] } log = "0.4.16" once_cell = "1.18" palette = "0.7.4" @@ -37,5 +37,5 @@ embed-resource = "2.1.1" members = ["data", "irc", "irc/proto"] [patch.crates-io] -iced = { git = "https://github.com/tarkah/iced", rev = "f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" } -iced_core = { git = "https://github.com/tarkah/iced", rev = "f9db8d1efe68634b7b06ce07f12ea33a3e37d79c" } +iced = { git = "https://github.com/iced-rs/iced", rev = "3d915d3cb30e5d08829aa2928676a53c505a601e" } +iced_core = { git = "https://github.com/iced-rs/iced", rev = "3d915d3cb30e5d08829aa2928676a53c505a601e" } diff --git a/data/Cargo.toml b/data/Cargo.toml index a5d2c5343..1d8450a9d 100644 --- a/data/Cargo.toml +++ b/data/Cargo.toml @@ -12,7 +12,7 @@ chrono = { version = "0.4", features = ['serde'] } dirs-next = "2.0.0" flate2 = "1.0" futures = "0.3.21" -iced_core = "0.12.0" +iced_core = "0.13.0-dev" log = "0.4.16" palette = "0.7.4" rand = "0.8.4" diff --git a/data/src/client.rs b/data/src/client.rs index 9c271d3ec..43c9eb9a9 100644 --- a/data/src/client.rs +++ b/data/src/client.rs @@ -825,7 +825,7 @@ impl Map { } } - pub fn nickname(&self, server: &Server) -> Option { + pub fn nickname<'a>(&'a self, server: &Server) -> Option> { self.client(server).map(Client::nickname) } diff --git a/data/src/time.rs b/data/src/time.rs index d7ac704b6..c86e5c573 100644 --- a/data/src/time.rs +++ b/data/src/time.rs @@ -1,6 +1,6 @@ use std::time::SystemTime; -use chrono::{DateTime, NaiveDateTime, TimeZone, Utc}; +use chrono::{DateTime, Utc}; use serde::{Deserialize, Serialize}; #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Serialize, Deserialize)] @@ -28,7 +28,6 @@ impl Posix { let seconds = (self.0 / 1_000_000_000) as i64; let nanos = (self.0 % 1_000_000_000) as u32; - NaiveDateTime::from_timestamp_opt(seconds, nanos) - .map(|datetime| Utc.from_utc_datetime(&datetime)) + DateTime::from_timestamp(seconds, nanos) } } diff --git a/src/buffer/channel.rs b/src/buffer/channel.rs index d759c16f1..7b73350da 100644 --- a/src/buffer/channel.rs +++ b/src/buffer/channel.rs @@ -6,7 +6,7 @@ use iced::{Command, Length}; use super::{input_view, scroll_view, user_context}; use crate::theme; -use crate::widget::{selectable_text, Collection, Element}; +use crate::widget::{selectable_text, Element}; mod topic; @@ -42,38 +42,32 @@ pub fn view<'a>( history, config, move |message| { - let timestamp = config - .buffer - .format_timestamp(&message.server_time) - .map(|timestamp| selectable_text(timestamp).style(theme::Text::Transparent)); + let timestamp = + config + .buffer + .format_timestamp(&message.server_time) + .map(|timestamp| { + selectable_text(timestamp).style(theme::selectable_text::transparent) + }); match message.target.source() { message::Source::User(user) => { let nick = user_context::view( selectable_text(config.buffer.nickname.brackets.format(user)).style( - theme::Text::Nickname( - user.color_seed(&config.buffer.nickname.color), - false, - ), + |theme| { + theme::selectable_text::nickname( + theme, + user.color_seed(&config.buffer.nickname.color), + false, + ) + }, ), user.clone(), ) .map(scroll_view::Message::UserContext); - let row_style = match our_nick { - Some(nick) - if message::reference_user( - user.nickname(), - nick, - &message.text, - ) => - { - theme::Container::Highlight - } - _ => theme::Container::Default, - }; let space = selectable_text(" "); - let message = selectable_text(&message.text); + let text = selectable_text(&message.text); Some( container( @@ -81,25 +75,38 @@ pub fn view<'a>( .push_maybe(timestamp) .push(nick) .push(space) - .push(message), + .push(text), ) - .style(row_style) + .style(move |theme, status| match our_nick { + Some(nick) + if message::reference_user( + user.nickname(), + nick, + &message.text, + ) => + { + theme::container::highlight(theme, status) + } + _ => Default::default(), + }) .into(), ) } message::Source::Server(_) => { - let message = selectable_text(&message.text).style(theme::Text::Server); + let message = + selectable_text(&message.text).style(theme::selectable_text::info); Some(container(row![].push_maybe(timestamp).push(message)).into()) } message::Source::Action => { - let message = selectable_text(&message.text).style(theme::Text::Accent); + let message = + selectable_text(&message.text).style(theme::selectable_text::accent); Some(container(row![].push_maybe(timestamp).push(message)).into()) } message::Source::Internal(message::source::Internal::Status(status)) => { - let message = - selectable_text(&message.text).style(theme::Text::Status(*status)); + let message = selectable_text(&message.text) + .style(|theme| theme::selectable_text::status(theme, *status)); Some(container(row![].push_maybe(timestamp).push(message)).into()) } @@ -260,7 +267,7 @@ fn topic<'a>( mod nick_list { use data::{Config, User}; - use iced::widget::{column, container, scrollable, text}; + use iced::widget::{column, container, scrollable, text, Scrollable}; use iced::Length; use user_context::Message; @@ -268,30 +275,33 @@ mod nick_list { use crate::theme; use crate::widget::Element; - pub fn view<'a>(users: &[User], config: &'a Config) -> Element<'a, Message> { + pub fn view<'a>(users: &'a [User], config: &'a Config) -> Element<'a, Message> { let column = column(users.iter().map(|user| { let content = text(format!( "{}{}", user.highest_access_level(), user.nickname() )) - .style(theme::Text::Nickname( - user.color_seed(&config.buffer.channel.users.color), - user.is_away(), - )); + .style(|theme| { + theme::text::nickname( + theme, + user.color_seed(&config.buffer.channel.users.color), + user.is_away(), + ) + }); user_context::view(content, user.clone()) })) .padding(4) .spacing(1); - container( - scrollable(column) - .direction(scrollable::Direction::Vertical( - scrollable::Properties::new().width(1).scroller_width(1), - )) - .style(theme::Scrollable::Hidden), - ) + container(Scrollable::with_direction_and_style( + column, + scrollable::Direction::Vertical( + scrollable::Properties::new().width(1).scroller_width(1), + ), + theme::scrollable::hidden, + )) .width(Length::Shrink) .max_width(120) .height(Length::Fill) diff --git a/src/buffer/channel/topic.rs b/src/buffer/channel/topic.rs index f42fa0c15..1e804c95e 100644 --- a/src/buffer/channel/topic.rs +++ b/src/buffer/channel/topic.rs @@ -1,19 +1,19 @@ use chrono::{DateTime, Utc}; use data::user::Nick; use data::{Config, User}; -use iced::widget::{column, container, horizontal_rule, row, scrollable}; +use iced::widget::{column, container, horizontal_rule, row, scrollable, Scrollable}; use iced::Length; use super::user_context; use crate::theme; -use crate::widget::{double_pass, selectable_text, Collection, Element}; +use crate::widget::{double_pass, selectable_text, Element}; pub fn view<'a>( text: &'a str, who: Option<&'a str>, time: Option<&'a DateTime>, max_lines: u16, - users: &[User], + users: &'a [User], config: &'a Config, ) -> Element<'a, user_context::Message> { let set_by = who.and_then(|who| { @@ -21,33 +21,33 @@ pub fn view<'a>( let user = if let Some(user) = users.iter().find(|user| user.nickname() == nick) { user_context::view( - selectable_text(who).style(theme::Text::Nickname( - user.color_seed(&config.buffer.nickname.color), - false, - )), + selectable_text(who).style(|theme| { + theme::selectable_text::nickname( + theme, + user.color_seed(&config.buffer.nickname.color), + false, + ) + }), user.clone(), ) } else { - selectable_text(who).style(theme::Text::Server).into() + selectable_text(who).style(theme::selectable_text::info).into() }; Some(row![ - selectable_text("set by ").style(theme::Text::Transparent), + selectable_text("set by ").style(theme::selectable_text::transparent), user, - selectable_text(format!(" at {}", time?.to_rfc2822())).style(theme::Text::Transparent), + selectable_text(format!(" at {}", time?.to_rfc2822())).style(theme::selectable_text::transparent), ]) }); - let content = column![selectable_text(text).style(theme::Text::Transparent)].push_maybe(set_by); + let content = column![selectable_text(text).style(theme::selectable_text::transparent)].push_maybe(set_by); - let scrollable = scrollable(container(content).width(Length::Fill).padding(padding())) - .style(theme::Scrollable::Hidden) - .direction(scrollable::Direction::Vertical( - scrollable::Properties::default() - .alignment(scrollable::Alignment::Start) - .width(5) - .scroller_width(5), - )); + let scrollable = Scrollable::with_direction_and_style( + container(content).width(Length::Fill).padding(padding()), + scrollable::Direction::Vertical(scrollable::Properties::new().width(1).scroller_width(1)), + theme::scrollable::hidden, + ); // Use double pass to limit layout to `max_lines` of text column![ diff --git a/src/buffer/query.rs b/src/buffer/query.rs index 6323a2b8d..ad824fefb 100644 --- a/src/buffer/query.rs +++ b/src/buffer/query.rs @@ -5,7 +5,7 @@ use iced::{Command, Length}; use super::{input_view, scroll_view, user_context}; use crate::theme; -use crate::widget::{selectable_text, Collection, Element}; +use crate::widget::{selectable_text, Element}; #[derive(Debug, Clone)] pub enum Message { @@ -36,19 +36,25 @@ pub fn view<'a>( history, config, |message| { - let timestamp = config - .buffer - .format_timestamp(&message.server_time) - .map(|timestamp| selectable_text(timestamp).style(theme::Text::Transparent)); + let timestamp = + config + .buffer + .format_timestamp(&message.server_time) + .map(|timestamp| { + selectable_text(timestamp).style(theme::selectable_text::transparent) + }); match message.target.source() { message::Source::User(user) => { let nick = user_context::view( selectable_text(config.buffer.nickname.brackets.format(user)).style( - theme::Text::Nickname( - user.color_seed(&config.buffer.nickname.color), - false, - ), + |theme| { + theme::selectable_text::nickname( + theme, + user.color_seed(&config.buffer.nickname.color), + false, + ) + }, ), user.clone(), ) @@ -69,18 +75,20 @@ pub fn view<'a>( ) } message::Source::Server(_) => { - let message = selectable_text(&message.text).style(theme::Text::Server); + let message = + selectable_text(&message.text).style(theme::selectable_text::info); Some(container(row![].push_maybe(timestamp).push(message)).into()) } message::Source::Action => { - let message = selectable_text(&message.text).style(theme::Text::Accent); + let message = + selectable_text(&message.text).style(theme::selectable_text::accent); Some(container(row![].push_maybe(timestamp).push(message)).into()) } message::Source::Internal(message::source::Internal::Status(status)) => { - let message = - selectable_text(&message.text).style(theme::Text::Status(*status)); + let message = selectable_text(&message.text) + .style(|theme| theme::selectable_text::status(theme, *status)); Some(container(row![].push_maybe(timestamp).push(message)).into()) } @@ -100,7 +108,7 @@ pub fn view<'a>( let text_input = show_text_input.then(|| { column![ - vertical_space(4), + vertical_space().height(4), input_view::view(&state.input_view, buffer, input, &[], channels, is_focused) .map(Message::InputView) ] diff --git a/src/buffer/scroll_view.rs b/src/buffer/scroll_view.rs index eff9a6819..5e5f664d4 100644 --- a/src/buffer/scroll_view.rs +++ b/src/buffer/scroll_view.rs @@ -2,7 +2,7 @@ use data::message::Limit; use data::server::Server; use data::user::Nick; use data::{history, time, Config}; -use iced::widget::{column, container, horizontal_rule, row, scrollable, text}; +use iced::widget::{column, container, horizontal_rule, row, text, scrollable, Scrollable}; use iced::{Command, Length}; use super::user_context; @@ -89,7 +89,7 @@ pub fn view<'a>( .padding([0, 6, 0, 0]), text("backlog") .size(font_size) - .style(theme::Text::Transparent), + .style(theme::text::transparent), container(horizontal_rule(1)) .width(Length::Fill) .padding([0, 0, 0, 6]) @@ -97,27 +97,29 @@ pub fn view<'a>( .padding(2) .align_items(iced::Alignment::Center); - column![column(old), container(divider), column(new)] + column![column(old), divider, column(new)] } else { column![column(old), column(new)] }; - scrollable(container(content).width(Length::Fill).padding([0, 8])) - .direction(scrollable::Direction::Vertical( + Scrollable::with_direction( + container(content).width(Length::Fill).padding([0, 8]), + scrollable::Direction::Vertical( scrollable::Properties::default() .alignment(status.alignment()) .width(5) .scroller_width(5), - )) - .on_scroll(move |viewport| Message::Scrolled { - count, - remaining, - oldest, - status, - viewport, - }) - .id(state.scrollable.clone()) - .into() + ), + ) + .on_scroll(move |viewport| Message::Scrolled { + count, + remaining, + oldest, + status, + viewport, + }) + .id(state.scrollable.clone()) + .into() } #[derive(Debug, Clone)] diff --git a/src/buffer/server.rs b/src/buffer/server.rs index cbe3b2cc1..645cda4fc 100644 --- a/src/buffer/server.rs +++ b/src/buffer/server.rs @@ -4,7 +4,7 @@ use iced::{Command, Length}; use super::{input_view, scroll_view}; use crate::theme; -use crate::widget::{selectable_text, Collection, Element}; +use crate::widget::{selectable_text, Element}; #[derive(Debug, Clone)] pub enum Message { @@ -30,20 +30,24 @@ pub fn view<'a>( history, config, |message| { - let timestamp = config - .buffer - .format_timestamp(&message.server_time) - .map(|timestamp| selectable_text(timestamp).style(theme::Text::Transparent)); + let timestamp = + config + .buffer + .format_timestamp(&message.server_time) + .map(|timestamp| { + selectable_text(timestamp).style(theme::selectable_text::transparent) + }); match message.target.source() { message::Source::Server(_) => { - let message = selectable_text(&message.text).style(theme::Text::Server); + let message = + selectable_text(&message.text).style(theme::selectable_text::info); Some(container(row![].push_maybe(timestamp).push(message)).into()) } message::Source::Internal(message::source::Internal::Status(status)) => { - let message = - selectable_text(&message.text).style(theme::Text::Status(*status)); + let message = selectable_text(&message.text) + .style(|theme| theme::selectable_text::status(theme, *status)); Some(container(row![].push_maybe(timestamp).push(message)).into()) } @@ -64,7 +68,7 @@ pub fn view<'a>( let text_input = show_text_input.then(|| { column![ - vertical_space(4), + vertical_space().height(4), input_view::view(&state.input_view, buffer, input, &[], channels, is_focused) .map(Message::InputView) ] diff --git a/src/buffer/user_context.rs b/src/buffer/user_context.rs index 144cc90bd..46185be56 100644 --- a/src/buffer/user_context.rs +++ b/src/buffer/user_context.rs @@ -43,7 +43,7 @@ pub fn view<'a>(content: impl Into>, user: User) -> Element let content = button(content) .padding(0) - .style(theme::Button::Bare) + .style(theme::button::bare) .on_press(Message::SingleClick(user.clone())); context_menu(content, entries, move |entry, length| { @@ -52,9 +52,10 @@ pub fn view<'a>(content: impl Into>, user: User) -> Element Entry::Query => ("Message", Message::Query(user.clone())), }; - button(text(content).style(theme::Text::Primary)) + button(text(content).style(theme::text::primary)) + .padding(5) .width(length) - .style(theme::Button::Context) + .style(theme::button::context) .on_press(message) .into() }) diff --git a/src/icon.rs b/src/icon.rs index 2b95988bd..c588b997f 100644 --- a/src/icon.rs +++ b/src/icon.rs @@ -44,7 +44,7 @@ pub fn topic<'a>() -> Text<'a> { fn to_text<'a>(unicode: char) -> Text<'a> { text(unicode.to_string()) - .style(theme::Text::Primary) + .style(theme::text::primary) .line_height(LineHeight::Relative(1.0)) .size(theme::ICON_SIZE) .font(font::ICON) diff --git a/src/main.rs b/src/main.rs index 45e5887f7..4f465f386 100644 --- a/src/main.rs +++ b/src/main.rs @@ -456,7 +456,7 @@ impl Application for Halloy { container(content) .width(Length::Fill) .height(Length::Fill) - .style(theme::Container::Primary) + .style(theme::container::primary) .into() } diff --git a/src/screen/dashboard.rs b/src/screen/dashboard.rs index 3b95cf625..761bce7d7 100644 --- a/src/screen/dashboard.rs +++ b/src/screen/dashboard.rs @@ -15,7 +15,7 @@ use self::command_bar::CommandBar; use self::pane::Pane; use self::side_menu::SideMenu; use crate::buffer::{self, Buffer}; -use crate::widget::{anchored_overlay, selectable_text, shortcut, Collection, Element}; +use crate::widget::{anchored_overlay, selectable_text, shortcut, Element}; use crate::{event, theme, Theme}; const SAVE_AFTER: Duration = Duration::from_secs(3); @@ -538,7 +538,7 @@ impl Dashboard { container(Space::new(Length::Fill, Length::Fill)) .width(Length::Fill) .height(Length::Fill) - .style(theme::Container::SemiTransparent), + .style(theme::container::semi_transparent), anchored_overlay::Anchor::BelowTopCentered, 0.0, ); diff --git a/src/screen/dashboard/command_bar.rs b/src/screen/dashboard/command_bar.rs index eb3cf0a0a..b8f30bb63 100644 --- a/src/screen/dashboard/command_bar.rs +++ b/src/screen/dashboard/command_bar.rs @@ -61,7 +61,6 @@ impl CommandBar { let combo_box = combo_box(&self.state, "Type a command...", None, Message::Command) .on_close(Message::Unfocused) .on_option_hovered(Message::Hovered) - .style(theme::ComboBox::Default) .size(font_size) .padding([8, 8]); @@ -89,7 +88,7 @@ impl CommandBar { .padding([0, 20]), container(combo_box) .padding(1) - .style(theme::Container::Context) + .style(theme::container::context) .width(Length::Fill), ) } diff --git a/src/screen/dashboard/pane.rs b/src/screen/dashboard/pane.rs index 5264ce99e..1ebd2d6fa 100644 --- a/src/screen/dashboard/pane.rs +++ b/src/screen/dashboard/pane.rs @@ -91,10 +91,12 @@ impl Pane { .map(move |msg| Message::Buffer(id, msg)); widget::Content::new(content) - .style(theme::Container::PaneBody { - selected: is_focused, + .style(if is_focused { + theme::container::pane_body_selected + } else { + theme::container::pane_body }) - .title_bar(title_bar.style(theme::Container::PaneHeader)) + .title_bar(title_bar.style(theme::container::pane_header)) } pub fn resource(&self) -> Option { @@ -146,11 +148,14 @@ impl TitleBar { .center_x() .center_y(), ) + .padding(5) .width(22) .height(22) .on_press(Message::ToggleShowTopic) - .style(theme::Button::Pane { - selected: settings.channel.topic.visible, + .style(if settings.channel.topic.visible { + theme::button::pane_selected + } else { + theme::button::pane }); controls = controls.push(topic); @@ -164,11 +169,14 @@ impl TitleBar { .center_x() .center_y(), ) + .padding(5) .width(22) .height(22) .on_press(Message::ToggleShowUserList) - .style(theme::Button::Pane { - selected: settings.channel.users.visible, + .style(if settings.channel.users.visible { + theme::button::pane_selected + } else { + theme::button::pane }); controls = controls.push(users); @@ -187,11 +195,14 @@ impl TitleBar { .center_x() .center_y(), ) + .padding(5) .width(22) .height(22) .on_press(Message::MaximizePane) - .style(theme::Button::Pane { - selected: maximized, + .style(if maximized { + theme::button::pane_selected + } else { + theme::button::pane }); controls = controls.push(maximize); @@ -206,15 +217,16 @@ impl TitleBar { .center_x() .center_y(), ) + .padding(5) .width(22) .height(22) .on_press(Message::ClosePane) - .style(theme::Button::Pane { selected: false }); + .style(theme::button::pane); controls = controls.push(delete); } - let title = container(text(value).style(theme::Text::Transparent)) + let title = container(text(value).style(theme::text::transparent)) .height(22) .padding([0, 4]) .align_y(iced::alignment::Vertical::Center); diff --git a/src/screen/dashboard/side_menu.rs b/src/screen/dashboard/side_menu.rs index dcb6f3eb9..40e5646a2 100644 --- a/src/screen/dashboard/side_menu.rs +++ b/src/screen/dashboard/side_menu.rs @@ -2,11 +2,12 @@ use data::dashboard::DefaultAction; use data::{history, Buffer}; use iced::widget::{ button, column, container, horizontal_space, pane_grid, row, scrollable, text, vertical_space, + Scrollable, }; use iced::Length; use super::pane::Pane; -use crate::widget::{context_menu, Collection, Element}; +use crate::widget::{context_menu, Element}; use crate::{icon, theme}; #[derive(Debug, Clone)] @@ -110,19 +111,20 @@ impl SideMenu { )); } - column = column.push(vertical_space(12)); + column = column.push(vertical_space().height(12)); } } } Some( - container( - scrollable(column).direction(scrollable::Direction::Vertical( + container(Scrollable::with_direction( + column, + scrollable::Direction::Vertical( iced::widget::scrollable::Properties::default() .width(0) .scroller_width(0), - )), - ) + ), + )) .padding([8, 0, 6, 6]) .center_x() .max_width(config.width) @@ -183,28 +185,31 @@ fn buffer_button<'a>( } else { icon::wifi_off() }, - text(server.to_string()).style(theme::Text::Primary) + text(server.to_string()).style(theme::text::primary) ] .spacing(8) .align_items(iced::Alignment::Center), Buffer::Channel(_, channel) => row![] - .push(horizontal_space(3)) - .push_maybe(has_unread.then_some(icon::dot().size(6).style(theme::Text::Info))) - .push(horizontal_space(if has_unread { 10 } else { 16 })) - .push(text(channel).style(theme::Text::Primary)) + .push(horizontal_space().width(3)) + .push_maybe(has_unread.then_some(icon::dot().size(6).style(theme::text::info))) + .push(horizontal_space().width(if has_unread { 10 } else { 16 })) + .push(text(channel).style(theme::text::primary)) .align_items(iced::Alignment::Center), Buffer::Query(_, nick) => row![] - .push(horizontal_space(3)) - .push_maybe(has_unread.then_some(icon::dot().size(6).style(theme::Text::Info))) - .push(horizontal_space(if has_unread { 10 } else { 16 })) - .push(text(nick).style(theme::Text::Primary)) + .push(horizontal_space().width(3)) + .push_maybe(has_unread.then_some(icon::dot().size(6).style(theme::text::info))) + .push(horizontal_space().width(if has_unread { 10 } else { 16 })) + .push(text(nick).style(theme::text::primary)) .align_items(iced::Alignment::Center), }; let base = button(row) + .padding(5) .width(Length::Fill) - .style(theme::Button::SideMenu { - selected: open.is_some(), + .style(if open.is_some() { + theme::button::side_menu_selected + } else { + theme::button::side_menu }) .on_press(match default_action { DefaultAction::NewPane => Message::Open(buffer.clone()), @@ -238,9 +243,10 @@ fn buffer_button<'a>( ), }; - button(text(content).style(theme::Text::Primary)) + button(text(content).style(theme::text::primary)) .width(length) - .style(theme::Button::Context) + .padding(5) + .style(theme::button::context) .on_press(message) .into() }) diff --git a/src/screen/help.rs b/src/screen/help.rs index 6ef467911..28ff14b04 100644 --- a/src/screen/help.rs +++ b/src/screen/help.rs @@ -43,8 +43,9 @@ impl Help { .align_x(alignment::Horizontal::Center) .width(Length::Fill), ) + .padding(5) .width(Length::Fixed(250.0)) - .style(theme::Button::Secondary) + .style(theme::button::secondary) .on_press(Message::OpenConfigurationDirectory); let refresh_button = button( @@ -52,18 +53,19 @@ impl Help { .align_x(alignment::Horizontal::Center) .width(Length::Fill), ) + .padding(5) .width(Length::Fixed(250.0)) - .style(theme::Button::Secondary) + .style(theme::button::secondary) .on_press(Message::RefreshConfiguration); let content = column![] .spacing(1) .push(icon::error().size(45)) - .push(vertical_space(10)) + .push(vertical_space().height(10)) .push(text("Error reading configuration file").font(font::MONO_BOLD.clone())) - .push(vertical_space(3)) - .push(text(self.error.to_string()).style(theme::Text::Error)) - .push(vertical_space(10)) + .push(vertical_space().height(3)) + .push(text(self.error.to_string()).style(theme::text::error)) + .push(vertical_space().height(10)) .push( column![] .width(250) diff --git a/src/screen/welcome.rs b/src/screen/welcome.rs index 74cfe6579..b878f2490 100644 --- a/src/screen/welcome.rs +++ b/src/screen/welcome.rs @@ -47,8 +47,9 @@ impl Welcome { .align_x(alignment::Horizontal::Center) .width(Length::Fill), ) + .padding(5) .width(Length::Fill) - .style(theme::Button::Secondary) + .style(theme::button::secondary) .on_press(Message::OpenConfigurationDirectory); let refresh_button = button( @@ -56,8 +57,9 @@ impl Welcome { .align_x(alignment::Horizontal::Center) .width(Length::Fill), ) + .padding(5) .width(Length::Fill) - .style(theme::Button::Secondary) + .style(theme::button::secondary) .on_press(Message::RefreshConfiguration); let content = column![] @@ -68,42 +70,42 @@ impl Welcome { ))) .width(150), ) - .push(vertical_space(10)) + .push(vertical_space().height(10)) .push(text("Welcome to Halloy!").font(font::MONO_BOLD.clone())) - .push(vertical_space(4)) + .push(vertical_space().height(4)) .push(text( "No configuration file found. Please follow the steps below to proceed", )) - .push(vertical_space(8)) + .push(vertical_space().height(8)) .push( column![] .push(row![ - text("1. ").style(theme::Text::Accent), + text("1. ").style(theme::text::accent), text("Go to "), - text(config_dir).style(theme::Text::Info) + text(config_dir).style(theme::text::info) ]) .push(row![ - text("2. ").style(theme::Text::Accent), + text("2. ").style(theme::text::accent), text("Create "), - text("config.yaml").style(theme::Text::Info), + text("config.yaml").style(theme::text::info), text(" - you can use "), - text("config.template.yaml").style(theme::Text::Info), + text("config.template.yaml").style(theme::text::info), text(" as a starting point"), ]) .push(row![ - text("3. ").style(theme::Text::Accent), + text("3. ").style(theme::text::accent), text("Customize the file with your preferred servers, settings, and theme") ]) .push(row![ - text("4. ").style(theme::Text::Accent), + text("4. ").style(theme::text::accent), text("Join "), - text("#halloy").style(theme::Text::Info), + text("#halloy").style(theme::text::info), text(" on libera.chat if you have questions or looking for help"), ]) .spacing(2) .align_items(iced::Alignment::Start), ) - .push(vertical_space(10)) + .push(vertical_space().height(10)) .push( row![] .width(250) diff --git a/src/theme.rs b/src/theme.rs index 795a5cc68..d03dfdcf9 100644 --- a/src/theme.rs +++ b/src/theme.rs @@ -1,9 +1,17 @@ -use data::message; -use data::theme::{alpha, randomize_color, Colors}; -use iced::widget::{button, container, pane_grid, rule, scrollable, text, text_input}; -use iced::{application, overlay, Background, Border, Color}; +use data::theme::Colors; +use iced::application; -use crate::widget::selectable_text; +use crate::widget::combo_box; + +pub mod button; +pub mod container; +pub mod menu; +pub mod pane_grid; +pub mod rule; +pub mod scrollable; +pub mod selectable_text; +pub mod text; +pub mod text_input; // TODO: If we use non-standard font sizes, we should consider // Config.font.size since it's user configurable @@ -57,10 +65,8 @@ impl Default for Theme { } } -impl application::StyleSheet for Theme { - type Style = (); - - fn appearance(&self, _style: &Self::Style) -> application::Appearance { +impl application::DefaultStyle for Theme { + fn default_style(&self) -> application::Appearance { application::Appearance { background_color: self.colors().background.base, text_color: self.colors().text.base, @@ -68,624 +74,14 @@ impl application::StyleSheet for Theme { } } -#[derive(Debug, Clone, Default)] -pub enum Rule { - #[default] - Default -} - -impl rule::StyleSheet for Theme { - type Style = Rule; - - fn appearance(&self, style: &Self::Style) -> rule::Appearance { - match style { - Rule::Default => rule::Appearance { - color: self.colors().background.light, - width: 1, - radius: 0.0.into(), - fill_mode: rule::FillMode::Full, - } - } - } -} - -#[derive(Debug, Clone, Default)] -pub enum Text { - #[default] - Default, - Primary, - Action, - Accent, - Info, - Server, - Error, - Transparent, - Status(message::source::Status), - Nickname(Option, bool), -} - -impl text::StyleSheet for Theme { - type Style = Text; - - fn appearance(&self, style: Self::Style) -> text::Appearance { - match style { - Text::Default => text::Appearance { color: None }, - Text::Primary => text::Appearance { - color: Some(self.colors().text.base), - }, - Text::Action => text::Appearance { - color: Some(self.colors().action.base), - }, - Text::Accent => text::Appearance { - color: Some(self.colors().accent.base), - }, - Text::Info => text::Appearance { - color: Some(self.colors().info.base), - }, - Text::Error => text::Appearance { - color: Some(self.colors().error.base), - }, - Text::Nickname(seed, transparent) => { - let original_color = self.colors().action.base; - let randomized_color = seed - .map(|seed| randomize_color(original_color, seed.as_str())) - .unwrap_or_else(|| original_color); - - let color = if transparent { - let dark_theme = self.colors().is_dark_theme(); - alpha(randomized_color, if dark_theme { 0.2 } else { 0.4 }) - } else { - randomized_color - }; - - text::Appearance { color: Some(color) } - } - Text::Server => text::Appearance { - color: Some(self.colors().info.base), - }, - Text::Status(status) => text::Appearance { - color: Some(match status { - message::source::Status::Success => self.colors().success.base, - message::source::Status::Error => self.colors().error.base, - }), - }, - Text::Transparent => text::Appearance { - color: Some(self.colors().text.low_alpha), - }, - } - } -} - -#[derive(Debug, Clone, Default)] -pub enum Container { - #[default] - Default, - Primary, - PaneBody { - selected: bool, - }, - PaneHeader, - Command { - selected: bool, - }, - Context, - Highlight, - SemiTransparent, -} - -impl container::StyleSheet for Theme { - type Style = Container; - - fn appearance(&self, style: &Self::Style) -> container::Appearance { - match style { - Container::Default => container::Appearance { - ..Default::default() - }, - Container::Primary => container::Appearance { - background: Some(Background::Color(self.colors().background.base)), - text_color: Some(self.colors().text.base), - ..Default::default() - }, - Container::PaneBody { selected } => container::Appearance { - background: Some(Background::Color(self.colors().background.dark)), - border: Border { - radius: 4.0.into(), - width: 1.0, - color: if *selected { - self.colors().action.base - } else { - Color::TRANSPARENT - }, - }, - ..Default::default() - }, - Container::PaneHeader => container::Appearance { - background: Some(Background::Color(self.colors().background.darker)), - border: Border { - radius: [4.0, 4.0, 0.0, 0.0].into(), - width: 1.0, - color: Color::TRANSPARENT, - }, - ..Default::default() - }, - Container::Command { selected } if *selected => container::Appearance { - background: Some(Background::Color(self.colors().background.darker)), - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Container::Command { .. } => container::Appearance { - background: None, - ..Default::default() - }, - Container::Context => container::Appearance { - //TODO: Blur background when possible? - background: Some(Background::Color(self.colors().background.base)), - border: Border { - radius: 4.0.into(), - width: 1.0, - color: if self.colors().is_dark_theme() { - self.colors().background.lighter - } else { - self.colors().background.darker - }, - }, - ..Default::default() - }, - Container::Highlight => container::Appearance { - background: Some(Background::Color(self.colors().info.high_alpha)), - border: Border { - radius: 0.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Container::SemiTransparent => container::Appearance { - background: Some( - Color { - a: 0.80, - ..self.colors().background.base - } - .into(), - ), - ..Default::default() - }, - } - } -} - -#[derive(Debug, Clone, Default)] -pub enum Button { - #[default] - Default, - Secondary, - SideMenu { - selected: bool, - }, - Pane { - selected: bool, - }, - Context, - Bare, -} - -impl button::StyleSheet for Theme { - type Style = Button; - - fn active(&self, style: &Self::Style) -> button::Appearance { - match style { - Button::Default => button::Appearance { - background: Some(Background::Color(self.colors().action.high_alpha)), - text_color: self.colors().action.base, - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::Secondary => button::Appearance { - background: Some(Background::Color(self.colors().text.high_alpha)), - text_color: self.colors().text.base, - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::SideMenu { selected } if *selected => button::Appearance { - background: Some(Background::Color(self.colors().background.darker)), - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::SideMenu { .. } => button::Appearance { - background: None, - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::Pane { selected } if *selected => button::Appearance { - background: Some(Background::Color(self.colors().action.med_alpha)), - border: Border { - color: self.colors().action.low_alpha, - width: 1.0, - radius: 3.0.into(), - }, - ..Default::default() - }, - Button::Pane { .. } => button::Appearance { - background: Some(Background::Color(self.colors().background.dark)), - border: Border { - color: if self.colors().is_dark_theme() { - self.colors().background.lightest - } else { - self.colors().background.darkest - }, - width: 1.0, - radius: 3.0.into(), - }, - ..Default::default() - }, - Button::Context => button::Appearance { - background: Some(Background::Color(Color::TRANSPARENT)), - border: Border { - radius: 4.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::Bare => button::Appearance { - background: Some(Background::Color(Color::TRANSPARENT)), - ..Default::default() - }, - } - } - - fn pressed(&self, style: &Self::Style) -> button::Appearance { - let active = self.active(style); - match style { - Button::Default => button::Appearance { ..active }, - Button::Secondary => button::Appearance { ..active }, - Button::SideMenu { selected: _ } => button::Appearance { ..active }, - Button::Pane { selected: _ } => button::Appearance { ..active }, - Button::Context => button::Appearance { ..active }, - Button::Bare => button::Appearance { ..active }, - } - } - - fn hovered(&self, style: &Self::Style) -> button::Appearance { - let active = self.active(style); - - match style { - Button::Default => button::Appearance { - background: Some(Background::Color(self.colors().action.med_alpha)), - text_color: self.colors().action.base, - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::Secondary => button::Appearance { - background: Some(Background::Color(self.colors().text.med_alpha)), - text_color: self.colors().text.base, - border: Border { - radius: 3.0.into(), - ..Default::default() - }, - ..Default::default() - }, - Button::SideMenu { selected } if *selected => button::Appearance { - background: Some(Background::Color(self.colors().background.darkest)), - ..active - }, - Button::SideMenu { .. } => button::Appearance { - background: Some(Background::Color(self.colors().background.dark)), - ..active - }, - Button::Pane { selected } if *selected => button::Appearance { - background: Some(Background::Color(self.colors().action.high_alpha)), - ..active - }, - Button::Pane { .. } => button::Appearance { - background: Some(Background::Color(if self.colors().is_dark_theme() { - self.colors().background.light - } else { - self.colors().background.darker - })), - ..active - }, - Button::Context => button::Appearance { - background: Some(Background::Color(self.colors().background.darker)), - ..active - }, - Button::Bare => button::Appearance { ..active }, - } - } - - fn disabled(&self, style: &Self::Style) -> button::Appearance { - let active = self.active(style); - - button::Appearance { - text_color: Color { - a: 0.2, - ..active.text_color - }, - border: Border { - color: Color { - a: 0.2, - ..active.border.color - }, - ..Default::default() +impl combo_box::DefaultStyle for Theme { + fn default_style() -> combo_box::Style<'static, Self> { + combo_box::Style { + text_input: Box::new(text_input::primary), + menu: menu::Style { + list: Box::new(menu::combo_box), + scrollable: Box::new(scrollable::primary), }, - ..active - } - } -} - -#[derive(Default)] -pub enum Scrollable { - #[default] - Default, - Hidden, -} - -impl scrollable::StyleSheet for Theme { - type Style = Scrollable; - - fn active(&self, style: &Self::Style) -> scrollable::Scrollbar { - match style { - Scrollable::Default => scrollable::Scrollbar { - background: Some(Background::Color(self.colors().background.darker)), - border: Border { - radius: 8.0.into(), - width: 1.0, - color: Color::TRANSPARENT, - }, - scroller: scrollable::Scroller { - color: self.colors().background.darkest, - border: Border { - radius: 8.0.into(), - width: 0.0, - color: Color::TRANSPARENT, - }, - }, - }, - Scrollable::Hidden => scrollable::Scrollbar { - background: Some(Background::Color(Color::TRANSPARENT)), - border: Border { - radius: 8.0.into(), - width: 1.0, - color: Color::TRANSPARENT, - }, - scroller: scrollable::Scroller { - color: Color::TRANSPARENT, - border: Border { - radius: 8.0.into(), - width: 0.0, - color: Color::TRANSPARENT, - }, - }, - }, - } - } - - fn hovered( - &self, - style: &Self::Style, - _is_mouse_over_scrollbar: bool, - ) -> scrollable::Scrollbar { - let active = self.active(style); - match style { - Scrollable::Default => scrollable::Scrollbar { ..active }, - Scrollable::Hidden => scrollable::Scrollbar { ..active }, - } - } -} - -#[derive(Default)] -pub enum PaneGrid { - #[default] - Default, -} - -impl pane_grid::StyleSheet for Theme { - type Style = PaneGrid; - - fn hovered_region(&self, style: &Self::Style) -> pane_grid::Appearance { - match style { - PaneGrid::Default => pane_grid::Appearance { - background: Background::Color(self.colors().action.high_alpha), - border: Border { - width: 1.0, - color: self.colors().action.base, - radius: 4.0.into(), - }, - }, - } - } - - fn picked_split(&self, style: &Self::Style) -> Option { - match style { - PaneGrid::Default => Some(pane_grid::Line { - color: self.colors().action.base, - width: 4.0, - }), - } - } - - fn hovered_split(&self, style: &Self::Style) -> Option { - match style { - PaneGrid::Default => Some(pane_grid::Line { - color: self.colors().action.base, - width: 4.0, - }), - } - } -} - -#[derive(Default)] -pub enum TextInput { - #[default] - Default, - Error, -} - -impl text_input::StyleSheet for Theme { - type Style = TextInput; - - fn active(&self, style: &Self::Style) -> text_input::Appearance { - match style { - TextInput::Default => text_input::Appearance { - background: Background::Color(self.colors().background.darker), - border: Border { - radius: 4.0.into(), - width: 0.0, - color: Color::TRANSPARENT, - // XXX Not currently displayed in application. - }, - icon_color: self.colors().info.base, - }, - TextInput::Error => text_input::Appearance { - border: Border { - width: 1.0, - color: self.colors().error.base, - ..Default::default() - }, - ..self.active(&TextInput::Default) - }, - } - } - - fn focused(&self, style: &Self::Style) -> text_input::Appearance { - self.active(style) - } - - fn hovered(&self, style: &Self::Style) -> text_input::Appearance { - self.active(style) - } - - fn selection_color(&self, style: &Self::Style) -> Color { - match style { - TextInput::Default | TextInput::Error => self.colors().accent.high_alpha, - } - } - - fn placeholder_color(&self, style: &Self::Style) -> Color { - match style { - TextInput::Default | TextInput::Error => self.colors().text.low_alpha, - } - } - - fn value_color(&self, style: &Self::Style) -> Color { - match style { - TextInput::Default | TextInput::Error => self.colors().text.base, - } - } - - fn disabled_color(&self, style: &Self::Style) -> Color { - match style { - TextInput::Default | TextInput::Error => self.colors().text.base, - } - } - - fn disabled(&self, style: &Self::Style) -> text_input::Appearance { - match style { - TextInput::Default | TextInput::Error => text_input::Appearance { - background: Background::Color(self.colors().background.light), - border: Border { - radius: 0.0.into(), - width: 0.0, - color: Color::TRANSPARENT, - // XXX Not currently displayed in application. - }, - icon_color: self.colors().info.base, - }, - } - } -} - -impl selectable_text::StyleSheet for Theme { - type Style = Text; - - fn appearance(&self, style: &Self::Style) -> selectable_text::Appearance { - let color = ::appearance(self, style.clone()).color; - - let selection_color = self.colors().accent.high_alpha; - - selectable_text::Appearance { - color, - selection_color, - } - } -} - -#[derive(Debug, Clone, Default)] -pub enum Menu { - #[default] - Default, - ComboBox, -} - -impl overlay::menu::StyleSheet for Theme { - type Style = Menu; - - fn appearance(&self, style: &Self::Style) -> overlay::menu::Appearance { - match style { - Menu::Default => overlay::menu::Appearance { - text_color: self.colors().text.base, - background: Background::Color(self.colors().background.base), - border: Border { - width: 1.0, - radius: 4.0.into(), - color: self.colors().action.base, - }, - selected_text_color: self.colors().text.high_alpha, - selected_background: Background::Color(self.colors().background.high_alpha), - }, - Menu::ComboBox => overlay::menu::Appearance { - text_color: self.colors().text.base, - background: Background::Color(self.colors().background.base), - border: Border { - width: 1.0, - radius: 4.0.into(), - color: if self.colors().is_dark_theme() { - self.colors().background.lighter - } else { - self.colors().background.darker - }, - }, - selected_text_color: self.colors().text.base, - selected_background: Background::Color(self.colors().background.dark), - }, - } - } -} - -#[derive(Debug, Clone, Default)] -pub enum ComboBox { - #[default] - Default, -} - -impl From for TextInput { - fn from(combo_box: ComboBox) -> Self { - match combo_box { - ComboBox::Default => TextInput::Default, - } - } -} - -impl From for Menu { - fn from(combo_box: ComboBox) -> Self { - match combo_box { - ComboBox::Default => Menu::ComboBox, } } } diff --git a/src/theme/button.rs b/src/theme/button.rs new file mode 100644 index 000000000..30ac1d690 --- /dev/null +++ b/src/theme/button.rs @@ -0,0 +1,324 @@ +use iced::widget::button::{Appearance, DefaultStyle, Status}; +use iced::{Background, Border, Color}; + +use super::Theme; + +impl DefaultStyle for Theme { + fn default_style(&self, status: Status) -> Appearance { + primary(self, status) + } +} + +pub fn primary(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: Some(Background::Color(theme.colors().action.high_alpha)), + text_color: theme.colors().action.base, + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Hovered => Appearance { + background: Some(Background::Color(theme.colors().action.med_alpha)), + text_color: theme.colors().action.base, + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Disabled => { + let active = primary(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn secondary(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: Some(Background::Color(theme.colors().text.high_alpha)), + text_color: theme.colors().text.base, + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Hovered => Appearance { + background: Some(Background::Color(theme.colors().text.med_alpha)), + text_color: theme.colors().text.base, + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Disabled => { + let active = secondary(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn context(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: Some(Background::Color(Color::TRANSPARENT)), + border: Border { + radius: 4.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Hovered => { + let active = context(theme, Status::Active); + + Appearance { + background: Some(Background::Color(theme.colors().background.darker)), + ..active + } + } + Status::Disabled => { + let active = context(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn bare(_theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed | Status::Hovered => Appearance { + background: Some(Background::Color(Color::TRANSPARENT)), + ..Default::default() + }, + Status::Disabled => { + let active = bare(_theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn side_menu(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: None, + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Hovered => { + let active = side_menu(theme, Status::Active); + + Appearance { + background: Some(Background::Color(theme.colors().background.dark)), + ..active + } + } + Status::Disabled => { + let active = side_menu(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn side_menu_selected(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: Some(Background::Color(theme.colors().background.darker)), + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + }, + Status::Hovered => { + let active = side_menu_selected(theme, Status::Active); + + Appearance { + background: Some(Background::Color(theme.colors().background.darkest)), + ..active + } + } + Status::Disabled => { + let active = side_menu_selected(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn pane(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: Some(Background::Color(theme.colors().background.dark)), + border: Border { + color: if theme.colors().is_dark_theme() { + theme.colors().background.lightest + } else { + theme.colors().background.darkest + }, + width: 1.0, + radius: 3.0.into(), + }, + ..Default::default() + }, + Status::Hovered => { + let active = pane(theme, Status::Active); + + Appearance { + background: Some(Background::Color(if theme.colors().is_dark_theme() { + theme.colors().background.light + } else { + theme.colors().background.darker + })), + ..active + } + } + Status::Disabled => { + let active = pane(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} + +pub fn pane_selected(theme: &Theme, status: Status) -> Appearance { + match status { + Status::Active | Status::Pressed => Appearance { + background: Some(Background::Color(theme.colors().action.med_alpha)), + border: Border { + color: theme.colors().action.low_alpha, + width: 1.0, + radius: 3.0.into(), + }, + ..Default::default() + }, + Status::Hovered => { + let active = pane_selected(theme, Status::Active); + + Appearance { + background: Some(Background::Color(theme.colors().action.high_alpha)), + ..active + } + } + Status::Disabled => { + let active = pane_selected(theme, Status::Active); + + Appearance { + text_color: Color { + a: 0.2, + ..active.text_color + }, + border: Border { + color: Color { + a: 0.2, + ..active.text_color + }, + ..Default::default() + }, + ..active + } + } + } +} diff --git a/src/theme/container.rs b/src/theme/container.rs new file mode 100644 index 000000000..868c87648 --- /dev/null +++ b/src/theme/container.rs @@ -0,0 +1,109 @@ +use iced::widget::container::{Appearance, DefaultStyle, Status}; +use iced::{Background, Border, Color}; + +use super::Theme; + +impl DefaultStyle for Theme { + fn default_style(&self, _status: Status) -> Appearance { + Appearance::default() + } +} + +pub fn primary(theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: Some(Background::Color(theme.colors().background.base)), + text_color: Some(theme.colors().text.base), + ..Default::default() + } +} + +pub fn pane_body(theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: Some(Background::Color(theme.colors().background.dark)), + border: Border { + radius: 4.0.into(), + width: 1.0, + color: Color::TRANSPARENT, + }, + ..Default::default() + } +} + +pub fn pane_body_selected(theme: &Theme, status: Status) -> Appearance { + let pane_body = pane_body(theme, status); + + Appearance { + border: Border { + color: theme.colors().action.base, + ..pane_body.border + }, + ..pane_body + } +} + +pub fn pane_header(theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: Some(Background::Color(theme.colors().background.darker)), + border: Border { + radius: [4.0, 4.0, 0.0, 0.0].into(), + width: 1.0, + color: Color::TRANSPARENT, + }, + ..Default::default() + } +} + +pub fn command(_theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: None, + ..Default::default() + } +} + +pub fn command_selected(theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: Some(Background::Color(theme.colors().background.darker)), + border: Border { + radius: 3.0.into(), + ..Default::default() + }, + ..Default::default() + } +} + +pub fn context(theme: &Theme, _status: Status) -> Appearance { + Appearance { + //TODO: Blur background when possible? + background: Some(Background::Color(theme.colors().background.base)), + border: Border { + radius: 4.0.into(), + width: 1.0, + color: theme.colors().background.darker, + }, + ..Default::default() + } +} + +pub fn highlight(theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: Some(Background::Color(theme.colors().info.high_alpha)), + border: Border { + radius: 0.0.into(), + ..Default::default() + }, + ..Default::default() + } +} + +pub fn semi_transparent(theme: &Theme, _status: Status) -> Appearance { + Appearance { + background: Some( + Color { + a: 0.80, + ..theme.colors().background.base + } + .into(), + ), + ..Default::default() + } +} diff --git a/src/theme/menu.rs b/src/theme/menu.rs new file mode 100644 index 000000000..b7e9baa48 --- /dev/null +++ b/src/theme/menu.rs @@ -0,0 +1,48 @@ +pub use iced::widget::overlay::menu::Style; +use iced::{ + widget::overlay::menu::{Appearance, DefaultStyle}, + Background, Border, +}; + +use super::{scrollable, Theme}; + +impl DefaultStyle for Theme { + fn default_style() -> Style<'static, Self> { + Style { + list: Box::new(primary), + scrollable: Box::new(scrollable::primary), + } + } +} + +pub fn primary(theme: &Theme) -> Appearance { + Appearance { + text_color: theme.colors().text.base, + background: Background::Color(theme.colors().background.base), + border: Border { + width: 1.0, + radius: 4.0.into(), + color: theme.colors().action.base, + }, + selected_text_color: theme.colors().text.high_alpha, + selected_background: Background::Color(theme.colors().background.high_alpha), + } +} + +pub fn combo_box(theme: &Theme) -> Appearance { + Appearance { + text_color: theme.colors().text.base, + background: Background::Color(theme.colors().background.base), + border: Border { + width: 1.0, + radius: 4.0.into(), + color: if theme.colors().is_dark_theme() { + theme.colors().background.lighter + } else { + theme.colors().background.darker + }, + }, + selected_text_color: theme.colors().text.base, + selected_background: Background::Color(theme.colors().background.dark), + } +} diff --git a/src/theme/pane_grid.rs b/src/theme/pane_grid.rs new file mode 100644 index 000000000..b3dae92d1 --- /dev/null +++ b/src/theme/pane_grid.rs @@ -0,0 +1,33 @@ +use iced::{ + widget::pane_grid::{Appearance, DefaultStyle, Highlight, Line}, + Background, Border, +}; + +use super::Theme; + +impl DefaultStyle for Theme { + fn default_style(&self) -> Appearance { + primary(self) + } +} + +pub fn primary(theme: &Theme) -> Appearance { + Appearance { + hovered_region: Highlight { + background: Background::Color(theme.colors().action.high_alpha), + border: Border { + width: 1.0, + color: theme.colors().action.base, + radius: 4.0.into(), + }, + }, + picked_split: Line { + color: theme.colors().action.base, + width: 4.0, + }, + hovered_split: Line { + color: theme.colors().action.base, + width: 4.0, + }, + } +} diff --git a/src/theme/rule.rs b/src/theme/rule.rs new file mode 100644 index 000000000..6d0030497 --- /dev/null +++ b/src/theme/rule.rs @@ -0,0 +1,18 @@ +use iced::widget::rule::{Appearance, DefaultStyle, FillMode}; + +use super::Theme; + +impl DefaultStyle for Theme { + fn default_style(&self) -> Appearance { + primary(self) + } +} + +pub fn primary(theme: &Theme) -> Appearance { + Appearance { + color: theme.colors().background.light, + width: 1, + radius: 0.0.into(), + fill_mode: FillMode::Full, + } +} \ No newline at end of file diff --git a/src/theme/scrollable.rs b/src/theme/scrollable.rs new file mode 100644 index 000000000..104c27bc2 --- /dev/null +++ b/src/theme/scrollable.rs @@ -0,0 +1,81 @@ +use iced::{ + widget::{ + container, + scrollable::{Appearance, DefaultStyle, Scrollbar, Scroller, Status}, + }, + Background, Border, Color, Shadow, +}; + +use super::Theme; + +impl DefaultStyle for Theme { + fn default_style(&self, status: Status) -> Appearance { + primary(self, status) + } +} + +pub fn primary(theme: &Theme, status: Status) -> Appearance { + let scrollbar = Scrollbar { + background: None, + border: Border::default(), + scroller: Scroller { + color: theme.colors().background.darker, + border: Border { + radius: 8.0.into(), + width: 0.0, + color: Color::TRANSPARENT, + }, + }, + }; + + match status { + Status::Active | Status::Hovered { .. } | Status::Dragged { .. } => Appearance { + container: container::Appearance { + text_color: None, + background: None, + border: Border { + radius: 8.0.into(), + width: 1.0, + color: Color::TRANSPARENT, + }, + shadow: Shadow::default(), + }, + vertical_scrollbar: scrollbar, + horizontal_scrollbar: scrollbar, + gap: None, + }, + } +} + +pub fn hidden(_theme: &Theme, status: Status) -> Appearance { + let scrollbar = Scrollbar { + background: None, + border: Border::default(), + scroller: Scroller { + color: Color::TRANSPARENT, + border: Border { + radius: 0.0.into(), + width: 0.0, + color: Color::TRANSPARENT, + }, + }, + }; + + match status { + Status::Active | Status::Hovered { .. } | Status::Dragged { .. } => Appearance { + container: container::Appearance { + text_color: None, + background: Some(Background::Color(Color::TRANSPARENT)), + border: Border { + radius: 8.0.into(), + width: 1.0, + color: Color::TRANSPARENT, + }, + shadow: Shadow::default(), + }, + vertical_scrollbar: scrollbar, + horizontal_scrollbar: scrollbar, + gap: None, + }, + } +} diff --git a/src/theme/selectable_text.rs b/src/theme/selectable_text.rs new file mode 100644 index 000000000..f36577d39 --- /dev/null +++ b/src/theme/selectable_text.rs @@ -0,0 +1,62 @@ +use data::message; + +use crate::widget::selectable_text::{Appearance, DefaultStyle}; + +use super::{text, Theme}; + +impl DefaultStyle for Theme { + fn default_style(&self) -> Appearance { + Appearance { + color: None, + selection_color: self.colors().accent.high_alpha, + } + } +} + +pub fn transparent(theme: &Theme) -> Appearance { + let color = text::transparent(theme).color; + + Appearance { + color, + selection_color: theme.colors().accent.high_alpha, + } +} + +pub fn info(theme: &Theme) -> Appearance { + let color = text::info(theme).color; + + Appearance { + color, + selection_color: theme.colors().accent.high_alpha, + } +} + +pub fn accent(theme: &Theme) -> Appearance { + let color = text::accent(theme).color; + + Appearance { + color, + selection_color: theme.colors().accent.high_alpha, + } +} + +pub fn nickname(theme: &Theme, seed: Option, transparent: bool) -> Appearance { + let color = text::nickname(theme, seed, transparent).color; + + Appearance { + color, + selection_color: theme.colors().accent.high_alpha, + } +} + +pub fn status(theme: &Theme, status: message::source::Status) -> Appearance { + let color = match status { + message::source::Status::Success => text::success(theme).color, + message::source::Status::Error => text::error(theme).color, + }; + + Appearance { + color, + selection_color: theme.colors().accent.high_alpha, + } +} diff --git a/src/theme/text.rs b/src/theme/text.rs new file mode 100644 index 000000000..28d15c1ee --- /dev/null +++ b/src/theme/text.rs @@ -0,0 +1,66 @@ +use super::Theme; +use data::theme::{alpha, randomize_color}; +use iced::widget::text::{Appearance, DefaultStyle}; + +impl DefaultStyle for Theme { + fn default_style(&self) -> Appearance { + none(self) + } +} + +pub fn none(_theme: &Theme) -> Appearance { + Appearance { color: None } +} + +pub fn primary(theme: &Theme) -> Appearance { + Appearance { + color: Some(theme.colors().text.base), + } +} + +pub fn accent(theme: &Theme) -> Appearance { + Appearance { + color: Some(theme.colors().accent.base), + } +} + +pub fn info(theme: &Theme) -> Appearance { + Appearance { + color: Some(theme.colors().info.base), + } +} + +pub fn error(theme: &Theme) -> Appearance { + Appearance { + color: Some(theme.colors().error.base), + } +} + +pub fn success(theme: &Theme) -> Appearance { + Appearance { + color: Some(theme.colors().success.base), + } +} + +pub fn transparent(theme: &Theme) -> Appearance { + Appearance { + color: Some(theme.colors().text.low_alpha), + } +} + +pub fn nickname(theme: &Theme, seed: Option, transparent: bool) -> Appearance { + let original_color = theme.colors().action.base; + let randomized_color = seed + .as_deref() + .map(|seed| randomize_color(original_color, seed)) + .unwrap_or_else(|| original_color); + + let color = if transparent { + let dark_theme = theme.colors().is_dark_theme(); + alpha(randomized_color, if dark_theme { 0.2 } else { 0.4 }) + } else { + randomized_color + }; + + Appearance { color: Some(color) } +} diff --git a/src/theme/text_input.rs b/src/theme/text_input.rs new file mode 100644 index 000000000..72639db70 --- /dev/null +++ b/src/theme/text_input.rs @@ -0,0 +1,58 @@ +use iced::{ + widget::text_input::{Appearance, DefaultStyle, Status}, + Background, Border, Color, +}; + +use super::Theme; + +impl DefaultStyle for Theme { + fn default_style(&self, status: Status) -> Appearance { + primary(self, status) + } +} + +pub fn primary(theme: &Theme, status: Status) -> Appearance { + let active = Appearance { + background: Background::Color(theme.colors().background.darker), + border: Border { + radius: 4.0.into(), + width: 0.0, + color: Color::TRANSPARENT, + // XXX Not currently displayed in application. + }, + icon: theme.colors().info.base, + placeholder: theme.colors().text.low_alpha, + value: theme.colors().text.base, + selection: theme.colors().accent.high_alpha, + }; + + match status { + Status::Active | Status::Hovered | Status::Focused => active, + Status::Disabled => Appearance { + background: Background::Color(theme.colors().background.light), + border: Border { + radius: 0.0.into(), + width: 0.0, + color: Color::TRANSPARENT, + // XXX Not currently displayed in application. + }, + ..active + }, + } +} + +pub fn error(theme: &Theme, status: Status) -> Appearance { + let primary = primary(theme, status); + + match status { + Status::Active | Status::Hovered | Status::Focused => Appearance { + border: Border { + width: 1.0, + color: theme.colors().error.base, + ..Default::default() + }, + ..primary + }, + Status::Disabled => primary, + } +} diff --git a/src/widget.rs b/src/widget.rs index 29692f466..f84c2664d 100644 --- a/src/widget.rs +++ b/src/widget.rs @@ -1,6 +1,5 @@ #![allow(dead_code)] pub use self::anchored_overlay::anchored_overlay; -pub use self::collection::Collection; pub use self::combo_box::combo_box; pub use self::context_menu::context_menu; pub use self::double_pass::double_pass; diff --git a/src/widget/anchored_overlay.rs b/src/widget/anchored_overlay.rs index 1e301b6ff..b001adb6b 100644 --- a/src/widget/anchored_overlay.rs +++ b/src/widget/anchored_overlay.rs @@ -141,24 +141,23 @@ impl<'a, Message> Widget for AnchoredOverlay<'a, Messa tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { let (first, second) = tree.children.split_at_mut(1); let base = self .base .as_widget_mut() - .overlay(&mut first[0], layout, renderer); + .overlay(&mut first[0], layout, renderer, translation); - let overlay = overlay::Element::new( - layout.position(), - Box::new(Overlay { - content: &mut self.overlay, - tree: &mut second[0], - anchor: self.anchor, - offset: self.offset, - base_layout: layout.bounds(), - }), - ); + let overlay = overlay::Element::new(Box::new(Overlay { + content: &mut self.overlay, + tree: &mut second[0], + anchor: self.anchor, + offset: self.offset, + base_layout: layout.bounds(), + position: layout.position(), + })); Some( overlay::Group::with_children(base.into_iter().chain(Some(overlay)).collect()) @@ -182,21 +181,16 @@ struct Overlay<'a, 'b, Message> { anchor: Anchor, offset: f32, base_layout: Rectangle, + position: Point, } impl<'a, 'b, Message> overlay::Overlay for Overlay<'a, 'b, Message> { - fn layout( - &mut self, - renderer: &Renderer, - bounds: Size, - position: Point, - _translation: Vector, - ) -> layout::Node { + fn layout(&mut self, renderer: &Renderer, bounds: Size) -> layout::Node { let height = match self.anchor { // From top of base to top of viewport - Anchor::AboveTop => position.y, + Anchor::AboveTop => self.position.y, // From top of base to bottom of viewport - Anchor::BelowTopCentered => bounds.height - position.y, + Anchor::BelowTopCentered => bounds.height - self.position.y, }; let limits = layout::Limits::new( @@ -224,7 +218,7 @@ impl<'a, 'b, Message> overlay::Overlay for Overlay<'a, ), }; - node.move_to(position + translation) + node.move_to(self.position + translation) } fn draw( @@ -301,6 +295,6 @@ impl<'a, 'b, Message> overlay::Overlay for Overlay<'a, ) -> Option> { self.content .as_widget_mut() - .overlay(self.tree, layout, renderer) + .overlay(self.tree, layout, renderer, Vector::default()) } } diff --git a/src/widget/combo_box.rs b/src/widget/combo_box.rs index 72fff0742..8199f56de 100644 --- a/src/widget/combo_box.rs +++ b/src/widget/combo_box.rs @@ -4,8 +4,8 @@ use iced::advanced::{ }; use iced::overlay::menu; use iced::widget::text::LineHeight; -use iced::widget::{container, scrollable, text_input, TextInput}; -use iced::{event, keyboard, Event, Length, Padding, Rectangle}; +use iced::widget::{text_input, TextInput}; +use iced::{event, keyboard, Event, Length, Padding, Rectangle, Vector}; use std::cell::RefCell; use std::fmt::Display; @@ -22,7 +22,6 @@ use crate::Theme; pub struct ComboBox<'a, T, Message, Theme = crate::Theme, Renderer = super::Renderer> where Renderer: text::Renderer, - Theme: text_input::StyleSheet + menu::StyleSheet, { state: &'a State, text_input: TextInput<'a, TextInputEvent, Theme, Renderer>, @@ -32,7 +31,7 @@ where on_option_hovered: Option Message>>, on_close: Option, on_input: Option Message>>, - menu_style: ::Style, + menu_style: menu::Style<'a, Theme>, padding: Padding, size: Option, } @@ -41,7 +40,6 @@ impl<'a, T, Message, Theme, Renderer> ComboBox<'a, T, Message, Theme, Renderer> where T: std::fmt::Display + Clone, Renderer: text::Renderer, - Theme: text_input::StyleSheet + menu::StyleSheet, { /// Creates a new [`ComboBox`] with the given list of options, a placeholder, /// the current selected value, and the message to produce when an option is @@ -51,9 +49,14 @@ where placeholder: &str, selection: Option<&T>, on_selected: impl Fn(T) -> Message + 'static, - ) -> Self { - let text_input = - TextInput::new(placeholder, &state.value()).on_input(TextInputEvent::TextChanged); + ) -> Self + where + Theme: DefaultStyle + 'a, + { + let style = Theme::default_style(); + + let text_input = TextInput::with_style(placeholder, &state.value(), style.text_input) + .on_input(TextInputEvent::TextChanged); let selection = selection.map(T::to_string).unwrap_or_default(); @@ -66,7 +69,7 @@ where on_option_hovered: None, on_input: None, on_close: None, - menu_style: Default::default(), + menu_style: style.menu, padding: text_input::DEFAULT_PADDING, size: None, } @@ -101,24 +104,14 @@ where } /// Sets the style of the [`ComboBox`]. - // TODO: Define its own `StyleSheet` trait - pub fn style(mut self, style: S) -> Self + pub fn style(mut self, style: impl Into>) -> Self where - S: Into<::Style> - + Into<::Style> - + Clone, + Theme: 'a, { - self.menu_style = style.clone().into(); - self.text_input = self.text_input.style(style); - self - } + let style = style.into(); - /// Sets the style of the [`TextInput`] of the [`ComboBox`]. - pub fn text_input_style(mut self, style: S) -> Self - where - S: Into<::Style> + Clone, - { - self.text_input = self.text_input.style(style); + self.text_input = self.text_input.style(style.text_input); + self.menu_style = style.menu; self } @@ -344,8 +337,7 @@ where T: Display + Clone + 'static, Message: Clone, Renderer: text::Renderer, - Theme: - container::StyleSheet + text_input::StyleSheet + scrollable::StyleSheet + menu::StyleSheet, + Theme: 'a, { fn size(&self) -> iced::Size { Widget::::size(&self.text_input) @@ -612,6 +604,7 @@ where tree: &'b mut widget::Tree, layout: Layout<'_>, _renderer: &Renderer, + _translation: Vector, ) -> Option> { let Menu { menu, @@ -631,10 +624,10 @@ where hovered_option, |x| (self.on_selected)(x), self.on_option_hovered.as_deref(), + &self.menu_style, ) .width(bounds.width) - .padding(self.padding) - .style(self.menu_style.clone()); + .padding(self.padding); if let Some(font) = self.font { menu = menu.font(font); @@ -718,3 +711,30 @@ where { ComboBox::new(state, placeholder, selection, on_selected) } + +/// The style of a [`ComboBox`]. +#[allow(missing_debug_implementations)] +pub struct Style<'a, Theme> { + /// The style of the [`TextInput`] of the [`ComboBox`]. + pub text_input: text_input::Style<'a, Theme>, + + /// The style of the [`Menu`] of the [`ComboBox`]. + /// + /// [`Menu`]: menu::Menu + pub menu: menu::Style<'a, Theme>, +} + +/// The default style of a [`ComboBox`]. +pub trait DefaultStyle: Sized { + /// Returns the default style of a [`ComboBox`]. + fn default_style() -> Style<'static, Self>; +} + +impl DefaultStyle for iced::Theme { + fn default_style() -> Style<'static, Self> { + Style { + text_input: Box::new(text_input::default), + menu: menu::DefaultStyle::default_style(), + } + } +} diff --git a/src/widget/context_menu.rs b/src/widget/context_menu.rs index 709e1e79c..12803b74e 100644 --- a/src/widget/context_menu.rs +++ b/src/widget/context_menu.rs @@ -20,7 +20,7 @@ where entries.iter().copied().map(|entry| view(entry, length)), )) .padding(4) - .style(theme::Container::Context) + .style(theme::container::context) }; let menu = double_pass( @@ -174,6 +174,7 @@ impl<'a, Message> Widget for ContextMenu<'a, Message> tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { let state = tree.state.downcast_mut::(); @@ -182,17 +183,15 @@ impl<'a, Message> Widget for ContextMenu<'a, Message> let base = self .base .as_widget_mut() - .overlay(&mut first[0], layout, renderer); + .overlay(&mut first[0], layout, renderer, translation); let overlay = state.open().map(|position| { - overlay::Element::new( - position, - Box::new(Overlay { - content: &mut self.menu, - tree: &mut second[0], - state, - }), - ) + overlay::Element::new(Box::new(Overlay { + content: &mut self.menu, + tree: &mut second[0], + state, + position: position + translation, + })) }); Some(overlay::Group::with_children(base.into_iter().chain(overlay).collect()).overlay()) @@ -212,17 +211,12 @@ struct Overlay<'a, 'b, Message> { content: &'b mut Element<'a, Message>, tree: &'b mut widget::Tree, state: &'b mut State, + position: Point, } impl<'a, 'b, Message> overlay::Overlay for Overlay<'a, 'b, Message> { - fn layout( - &mut self, - renderer: &Renderer, - viewport: Size, - position: Point, - _translation: Vector, - ) -> layout::Node { - let limits = layout::Limits::new(Size::ZERO, viewport) + fn layout(&mut self, renderer: &Renderer, bounds: Size) -> layout::Node { + let limits = layout::Limits::new(Size::ZERO, bounds) .width(Length::Fill) .height(Length::Fill); @@ -231,8 +225,8 @@ impl<'a, 'b, Message> overlay::Overlay for Overlay<'a, .as_widget() .layout(self.tree, renderer, &limits); - let viewport = Rectangle::new(Point::ORIGIN, viewport); - let mut bounds = Rectangle::new(position, node.size()); + let viewport = Rectangle::new(Point::ORIGIN, bounds); + let mut bounds = Rectangle::new(self.position, node.size()); if bounds.x < viewport.x { bounds.x = viewport.x; diff --git a/src/widget/double_click.rs b/src/widget/double_click.rs index fda66cdfd..c7df3e664 100644 --- a/src/widget/double_click.rs +++ b/src/widget/double_click.rs @@ -2,7 +2,7 @@ use std::time; use iced::advanced::widget::{self, tree, Tree}; use iced::advanced::{mouse, overlay, renderer, Clipboard, Layout, Shell, Widget}; -use iced::{advanced, event, Length, Rectangle, Size}; +use iced::{advanced, event, Length, Rectangle, Size, Vector}; const TIMEOUT_MILLIS: u64 = 250; @@ -169,10 +169,11 @@ where tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { self.content .as_widget_mut() - .overlay(&mut tree.children[0], layout, renderer) + .overlay(&mut tree.children[0], layout, renderer, translation) } } diff --git a/src/widget/double_pass.rs b/src/widget/double_pass.rs index b7342347f..1b7e4f9ee 100644 --- a/src/widget/double_pass.rs +++ b/src/widget/double_pass.rs @@ -4,7 +4,7 @@ use iced::advanced::widget::tree; use iced::advanced::{layout, overlay, renderer, widget, Clipboard, Layout, Shell, Widget}; -use iced::{event, mouse, Event, Length, Rectangle, Size}; +use iced::{event, mouse, Event, Length, Rectangle, Size, Vector}; use super::{Element, Renderer}; use crate::Theme; @@ -141,10 +141,11 @@ impl<'a, Message> Widget for DoublePass<'a, Message> { tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { self.second_pass .as_widget_mut() - .overlay(tree, layout, renderer) + .overlay(tree, layout, renderer, translation) } } diff --git a/src/widget/hover.rs b/src/widget/hover.rs index 171ced025..145161040 100644 --- a/src/widget/hover.rs +++ b/src/widget/hover.rs @@ -67,7 +67,7 @@ mod component { mod widget { use iced::advanced::widget::{self, tree}; use iced::advanced::{layout, mouse, overlay, renderer, Clipboard, Layout, Shell, Widget}; - use iced::{Length, Size}; + use iced::{Length, Size, Vector}; use crate::widget::{Element, Renderer}; use crate::Theme; @@ -223,10 +223,14 @@ mod widget { tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { - self.content - .as_widget_mut() - .overlay(&mut tree.children[0], layout, renderer) + self.content.as_widget_mut().overlay( + &mut tree.children[0], + layout, + renderer, + translation, + ) } } diff --git a/src/widget/input.rs b/src/widget/input.rs index d5d7e3a85..e37d1a255 100644 --- a/src/widget/input.rs +++ b/src/widget/input.rs @@ -198,9 +198,9 @@ where fn view(&self, state: &Self::State) -> Element<'_, Self::Event> { let style = if state.error.is_some() { - theme::TextInput::Error + theme::text_input::error } else { - theme::TextInput::Default + theme::text_input::primary }; let text_input = text_input("Send message...", self.input) @@ -249,10 +249,10 @@ where } fn error<'a, Message: 'a>(error: impl ToString) -> Element<'a, Message> { - container(text(error).style(theme::Text::Error)) + container(text(error).style(theme::text::error)) .center_y() .padding(8) - .style(theme::Container::Primary) + .style(theme::container::primary) .into() } diff --git a/src/widget/input/completion.rs b/src/widget/input/completion.rs index 3bd4a2c58..79cbebb78 100644 --- a/src/widget/input/completion.rs +++ b/src/widget/input/completion.rs @@ -219,7 +219,11 @@ impl Commands { Element::from( container(content) .width(width) - .style(theme::Container::Command { selected }) + .style(if selected { + theme::container::command_selected + } else { + theme::container::command + }) .padding(6) .center_y(), ) @@ -232,7 +236,7 @@ impl Commands { container(double_pass(first_pass, second_pass)) .padding(4) - .style(theme::Container::Context) + .style(theme::container::context) .width(Length::Shrink) .into() }) @@ -260,17 +264,17 @@ impl Command { let title = Some(Element::from(text(self.title))); let args = self.args.iter().enumerate().map(|(index, arg)| { - let style = if index == active_arg { - theme::Text::Accent - } else { - theme::Text::Default - }; - - Element::from(text(format!(" {arg}")).style(style)) + Element::from(text(format!(" {arg}")).style(move |theme| { + if index == active_arg { + theme::text::accent(theme) + } else { + theme::text::none(theme) + } + })) }); container(row(title.into_iter().chain(args))) - .style(theme::Container::Context) + .style(theme::container::context) .padding(8) .center_y() .into() diff --git a/src/widget/key_press.rs b/src/widget/key_press.rs index 114e59f08..ac07bcb5f 100644 --- a/src/widget/key_press.rs +++ b/src/widget/key_press.rs @@ -1,7 +1,7 @@ use iced::advanced::widget::tree; use iced::advanced::{layout, overlay, renderer, widget, Clipboard, Layout, Shell, Widget}; pub use iced::keyboard::{key::Named, Key, Modifiers}; -use iced::{event, keyboard, mouse, Event, Length, Rectangle, Size}; +use iced::{event, keyboard, mouse, Event, Length, Rectangle, Size, Vector}; use super::{Element, Renderer}; use crate::Theme; @@ -136,8 +136,11 @@ where tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { - self.content.as_widget_mut().overlay(tree, layout, renderer) + self.content + .as_widget_mut() + .overlay(tree, layout, renderer, translation) } } diff --git a/src/widget/selectable_text.rs b/src/widget/selectable_text.rs index b9fed5275..e8f816f50 100644 --- a/src/widget/selectable_text.rs +++ b/src/widget/selectable_text.rs @@ -18,7 +18,7 @@ mod selection; pub fn selectable_text<'a, Theme, Renderer>(content: impl ToString) -> Text<'a, Theme, Renderer> where Renderer: text::Renderer, - Theme: StyleSheet, + Theme: DefaultStyle + 'a, { Text::new(content.to_string()) } @@ -26,7 +26,7 @@ where pub struct Text<'a, Theme, Renderer> where Renderer: text::Renderer, - Theme: StyleSheet, + Theme: DefaultStyle + 'a, { content: Cow<'a, str>, size: Option, @@ -37,13 +37,13 @@ where vertical_alignment: alignment::Vertical, font: Option, shaping: Shaping, - style: ::Style, + style: Style<'a, Theme>, } impl<'a, Theme, Renderer> Text<'a, Theme, Renderer> where Renderer: text::Renderer, - Theme: StyleSheet, + Theme: DefaultStyle + 'a, { pub fn new(content: impl Into>) -> Self { Text { @@ -59,7 +59,7 @@ where shaping: Shaping::Basic, #[cfg(not(debug_assertions))] shaping: Shaping::Advanced, - style: Default::default(), + style: Box::new(Theme::default_style), } } @@ -78,8 +78,8 @@ where self } - pub fn style(mut self, style: impl Into<::Style>) -> Self { - self.style = style.into(); + pub fn style(mut self, style: impl Fn(&Theme) -> Appearance + 'a) -> Self { + self.style = Box::new(style); self } @@ -112,7 +112,7 @@ where impl<'a, Message, Theme, Renderer> Widget for Text<'a, Theme, Renderer> where Renderer: text::Renderer, - Theme: StyleSheet, + Theme: DefaultStyle + 'a, { fn size(&self) -> Size { Size { @@ -225,7 +225,7 @@ where return; } - let appearance = theme.appearance(&self.style); + let appearance = (self.style)(theme); let state = tree.state.downcast_ref::>(); @@ -425,7 +425,7 @@ impl<'a, Message, Theme, Renderer> From> for Element<'a, Message, Theme, Renderer> where Renderer: text::Renderer + 'a, - Theme: StyleSheet + 'a, + Theme: DefaultStyle + 'a, { fn from(text: Text<'a, Theme, Renderer>) -> Element<'a, Message, Theme, Renderer> { Element::new(text) @@ -503,13 +503,29 @@ pub fn selected(f: fn(Vec<(f32, String)>) -> Message) -> Comma }) } -pub trait StyleSheet { - type Style: Default; - - fn appearance(&self, style: &Self::Style) -> Appearance; -} +pub type Style<'a, Theme> = Box Appearance + 'a>; +#[derive(Debug, Clone, Copy)] pub struct Appearance { pub color: Option, pub selection_color: Color, } + +impl Default for Appearance { + fn default() -> Self { + Appearance { + color: None, + selection_color: Color::WHITE, + } + } +} + +pub trait DefaultStyle { + fn default_style(&self) -> Appearance; +} + +impl DefaultStyle for Appearance { + fn default_style(&self) -> Appearance { + *self + } +} diff --git a/src/widget/shortcut.rs b/src/widget/shortcut.rs index c73926e6d..a30bfc599 100644 --- a/src/widget/shortcut.rs +++ b/src/widget/shortcut.rs @@ -2,7 +2,7 @@ use data::shortcut; pub use data::shortcut::Command; use iced::advanced::widget::tree; use iced::advanced::{layout, overlay, renderer, widget, Clipboard, Layout, Shell, Widget}; -use iced::{event, keyboard, mouse, Event, Length, Rectangle, Size}; +use iced::{event, keyboard, mouse, Event, Length, Rectangle, Size, Vector}; use super::{Element, Renderer}; use crate::Theme; @@ -165,10 +165,11 @@ impl<'a, Message> Widget for Shortcut<'a, Message> { tree: &'b mut widget::Tree, layout: Layout<'_>, renderer: &Renderer, + translation: Vector, ) -> Option> { self.content .as_widget_mut() - .overlay(&mut tree.children[0], layout, renderer) + .overlay(&mut tree.children[0], layout, renderer, translation) } }