Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/buttercam/compose-jetbrains-theme
JetBrains style UI kit for Compose Desktop.
https://github.com/buttercam/compose-jetbrains-theme
compose-desktop jetbrains ui
Last synced: 4 days ago
JSON representation
JetBrains style UI kit for Compose Desktop.
- Host: GitHub
- URL: https://github.com/buttercam/compose-jetbrains-theme
- Owner: ButterCam
- License: mit
- Created: 2021-10-08T06:18:41.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-10-27T06:36:33.000Z (over 1 year ago)
- Last Synced: 2025-01-15T23:10:45.456Z (11 days ago)
- Topics: compose-desktop, jetbrains, ui
- Language: Kotlin
- Homepage:
- Size: 2.63 MB
- Stars: 233
- Watchers: 10
- Forks: 10
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# We are planning to migrate to [JetBrains/jewel](https://github.com/JetBrains/jewel)!
We are discussing with JetBrains officials about migrating this project to [JetBrains/jewel](https://github.com/JetBrains/jewel). This will be the focus of our next work.
Track progress in this issue: JetBrains/jewel#28
# JetBrains UI Kit for Compose Desktop
New JetBrains style controls and UI kits for [Compose Desktop](https://www.jetbrains.com/lp/compose/).
Classic JetBrains UI kit have been moved to [here](classic).
![screenshot](docs/screenshot-expui.png)
## Quick Start
## Requirements
### JetBrains Runtime
To get the best presentation across platforms, this library requires the application to run
on [JetBrains Runtime](https://github.com/JetBrains/JetBrainsRuntime) (JBR).[JetBrains Runtime](https://github.com/JetBrains/JetBrainsRuntime) is a modified version of the JetBrains JDK
distribution, which is widely used across the JetBrains' IDEs such as IntelliJ, GoLand and others.In this library we use the additional API provided by JetBrains Runtime to customise the title bar in Windows and macOS.
If the `JBWindow` component is not used, it can also be used without the JetBrains Runtime.
When using `JBWindow` in a non-JetBrains Runtime environment, a native title bar may additionally be displayed.
JBR-17 (corresponding to JDK 17) can be downloaded from [the SDK page](https://www.jetbrains.com/help/idea/sdk.html) of
IntelliJ.Make sure that the [project SDK](https://www.jetbrains.com/help/idea/project-settings-and-structure.html#project-sdk)
and [Gradle JVM](https://www.jetbrains.com/help/idea/gradle-jvm-selection.html) are both JBR-17.#### Project SDK settings
![](docs/project-sdk.png)
#### Gradle JVM settings
![](docs/gradle-jvm.png)
### `jdk.unsupported` module
Most of the JetBrains Runtime APIs are private to JetBrains, and the class `sun.misc.Unsafe` is used to get access to
these APIs.You need to add the `jdk.unsupported` module to the compose dependency as in the following code to make it work.
You can also skip this step if you don't need to use the `JBWindow` component.
```kotlin
compose.desktop {
application {
nativeDistributions {
modules("jdk.unsupported")
}
}
}
```## 1. Add dependency
```kotlin
dependencies {
implementation(compose.desktop.currentOs) {
exclude("org.jetbrains.compose.material")
}
implementation("com.bybutter.compose:compose-jetbrains-expui-theme:2.0.0")
}
```## 2. Use JBWindow DSL
The optimal display of JBWindow requires JetBrains Runtime, refer to the previous [requirements](#Requirements).
```kotlin
fun main() = application {
JBWindow(
title = "JetBrains ExpUI Gallery",
showTitle = true, // If you want to render your own component in the center of the title bar like Intellij do, disable this to hide the title of the MainToolBar (TitleBar).
theme = LightTheme, // Change the theme here, LightTheme and DarkTheme are provided.
state = rememberWindowState(size = DpSize(900.dp, 700.dp)),
onCloseRequest = {
exitApplication()
},
mainToolBar = {
// Render your own component in the MainToolBar (TitleBar).
Row(
Modifier.mainToolBarItem(
Alignment.End,
true
)
) { // Use the mainToolBarItem modifier to change alignment of components and enable/disable window drag area on this component.
}
}) {
// Window content
}
}
```## 3. Use LightTheme and DarkTheme DSL
Since `JBWindow` requires JetBrains Runtime, if you don't want to use the `JBWindow` component, you can also use a
normal `Window` with `LightTheme`/`DarkTheme` DSL.```kotlin
fun main() = application {
Window({}) {
LightTheme {
// Your components here
}
}
}
```# Screenshot
## MacOS
## Windows
![image](https://user-images.githubusercontent.com/9367842/203374673-be0e25ab-de0c-4682-a511-bbadf0949446.png)
![image](https://user-images.githubusercontent.com/9367842/203374902-0b384bdd-fff4-4cbc-a8eb-93d6b58229a2.png)## Linux(Ubuntu with Gnome)
![image](https://user-images.githubusercontent.com/9367842/203574847-6b6a3d4a-0da2-41f8-ac3f-9a8402f26b16.png)
![image](https://user-images.githubusercontent.com/9367842/203574918-953092bc-b00f-455b-a43a-237c63093095.png)