Fork de travail pop-os/libcosmic pour contribs COSMIC
Find a file
Ashley Wulber 7cc791a3f5
feat: add support for dark / light mode switching (#178)
* feat: add support for dark / light mode switching and simultaneouscustom light / dark mode themes

* refactor(color-picker): optional initial color and fallback color

* refactor: used FixedPortion for layout of the settings item

This makes sure that the control always has at least the specified portion of the available space

* refactor: make all members of the ThemeBuilder public

* refactor: add and update palette colors

* fix(theme): typo and derive PartialEq for ThemeBuilder

* fix: update color picker usage

* feat: add more variables to the theme

* fix: radius on headerbar

* fix: Theme CosmicConfigEntry impl

* chore: specify rev of taffy

* fix: theme CosmicConfigEntry missing variables

* fix: apply theme type when theme mode changes

* wip: add plus icon to empty color picker button

* chore: fix rev and imports

* refactor(color-picker): allow custom size for the icon

* refactor(color_picker): make color_button public

* update iced
2023-10-16 16:19:04 -04:00
.github/workflows chore: Update calloop (#173) 2023-10-02 17:51:33 +02:00
.vscode feat!: implement Application API 2023-08-02 11:54:07 +02:00
cosmic-config feat: add support for dark / light mode switching (#178) 2023-10-16 16:19:04 -04:00
cosmic-config-derive feat: add support for dark / light mode switching (#178) 2023-10-16 16:19:04 -04:00
cosmic-theme feat: add support for dark / light mode switching (#178) 2023-10-16 16:19:04 -04:00
examples feat: add support for dark / light mode switching (#178) 2023-10-16 16:19:04 -04:00
iced@1e45d23ac8 feat: add support for dark / light mode switching (#178) 2023-10-16 16:19:04 -04:00
res refactor(widget): improvements to button and icon widgets 2023-09-14 01:38:56 +02:00
src feat: add support for dark / light mode switching (#178) 2023-10-16 16:19:04 -04:00
.gitignore chore: remove debian directory 2023-09-15 17:37:35 +02:00
.gitmodules chore(examples): migrated cosmic-design-demo 2023-09-15 20:48:25 +02:00
Cargo.toml chore(iced): enable advanced feature 2023-10-12 16:37:38 +02:00
config.toml refactor launcher removing templates 2021-12-31 14:58:26 -05:00
justfile fix: names for examples in justfiles 2023-09-15 17:21:46 +02:00
LICENSE Initial commit 2021-11-12 20:22:30 -07:00
README.md chore(readme): instructions for running examples 2023-09-14 01:38:56 +02:00

LIBCOSMIC

A platform toolkit based on iced which provides the building blocks for developing the future COSMIC desktop environment. Applications and applets alike are equally supported targets of Libcosmic. Applets integrate directly with COSMIC's interface as shell components, which was made possible by the Layer Shell protocol of Wayland.

Building

Libcosmic is written entirely in Rust, with minimal dependence on system libraries. On Pop!_OS, the following dependencies are all that's necessary compile the cosmic library:

sudo apt install cargo cmake just libexpat1-dev libfontconfig-dev libfreetype-dev pkg-config

Some examples are included in the examples directory to to kickstart your COSMIC adventure. To run them, you need to clone the repository with the following commands:

git clone https://github.com/pop-os/libcosmic
cd libcosmic
git submodule update --init --recursive

If you have already cloned the repository, run these to sync with the latest updates:

git fetch origin
git checkout master
git reset --hard origin/master
git submodule update --init --recursive

The examples may then be run by their cargo project names, such as just run cosmic-design-demo.

To create a new COSMIC project, use cargo new {{name_of_project}} to create a new project workspace, edit the Cargo.toml contained within, and add this to begin.

[workspace.dependencies.libcosmic]
git = "https://github.com/pop-os/libcosmic"
default-features = false
features = ["wayland", "tokio"]

Cargo Features

Available cargo features to choose from:

  • a11y: Experimental accessibility support.
  • animated-image: Enables animated images from the image crate.
  • debug: Enables addtional debugging features.
  • smol: Uses smol as the preferred async runtime.
    • Conflicts with tokio
  • tokio: Uses tokio as the preferred async runtime.
    • If unset, the default executor defined by iced will be used.
    • Conflicts with smol
  • wayland: Wayland-compatible client windows.
    • Conflicts with winit
  • winit: Cross-platform and X11 client window support
    • Conflicts with wayland
  • wgpu: GPU accelerated rendering with WGPU.
    • By default, softbuffer is used for software rendering.
  • xdg-portal: Enables XDG portal dialog integrations.

Project Showcase

Documentation

Documentation can be found here.

Licence

Licensed under the Mozilla Public License 2.0.

Contact