Exposing Theme Metadata
All available UI Customization Keys that can be used in Custom Themes must be defined in a dedicated *.themeMetadata.json file which is registered via com.intellij.themeMetadataProvider
extension point.
The following minimal sample demonstrates all details required when exposing UI customization keys of your plugin's UI.
/resources/META-INF/plugin.xml:
/resources/META-INF/MyPlugin.themeMetadata.json:
Attributes
name
- Human-readable name, e.g., plugin namefixed
- Specifies whether metadata describes external elements, e.g., an UI library. Default:false
.ui
- Root element listing all customization keys:key
- Customization key name (see Key Naming Scheme)description
- Description to be shown to Theme authors editing *.theme.json filesdeprecated
-true
when the key is deprecated. It is highly recommended to provide explanation and/or replacement indescription
if available.source
- Fully qualified name of the underlying UI component implementation, e.g.,javax.swing.JPasswordField
since
- The release number when this UI customization key was exposed, e.g.,2021.1
Note: The
since
attribute is supported starting with the 2019.2 release and it is not displayed in versions prior to 2019.2.
Color keys can be used via JBColor.namedColor()
providing defaults for Light and Dark theme:
Other keys can be obtained via javax.swing.UIManager#getXXX()
methods.
Key Naming Scheme
All keys must follow this Naming Pattern:
Object[.SubObject].[state][Part]Property
Property
Word | Use for | Example |
---|---|---|
| Text color. |
|
| Background color for objects with text. |
|
| Objects with a single color (do not have foreground/background). Do not use the word "Color" separately, always use with the "part" word. The word "Color" shows that this is a color property. Otherwise, it can be confused with a property of another type. |
|
State
Word | Use for | Example |
---|---|---|
| Enabled components, default state. Omit this word. The default state does not need explicit naming. |
|
| Enabled components that might be perceived as interactive but are actually not. Example: a tree with visible selection but not in focus. Goes after other state words. |
|
| The current focused component. |
|
| A selected tab or any other control that has equally meaningful selected and inactive states. |
|
| An action as indicated in states. |
|
| Validation states. See example in the guide article. |
|
| Unavailable components. |
|
Part
A part is an internal element of a component, e.g., an arrow button in a combo box. Create a separate key for a part if its properties differ from the parent object.
If a part is common among several components, use the same name for it. Notable examples of common parts:
Common parts | Use for | Example |
---|---|---|
| Shortcut foreground. |
|
| A line around a component. |
|
| The vertical line that denotes typing place. |
|
| An object that has been modified but not yet saved. Example: change anything in the Settings dialog, the setting group name in the tree becomes blue. |
|
| Wide focus border around a component. |
"Component" is a special key that sets common properties for several basic input components. |
| Secondary labels with additional useful information. Usually appear in gray color to the right or below a regular label. |
|
| An icon that is created with a source code (not an image file). |
|
| The focus place in a component with selectable text. Can be in a typed text or in a list or tree. Goes before other state words (for historical reasons). |
|
| A horizontal or vertical line inside a component. Can be with a label. |
|
| A shadow below a component. |
|
SubObject
Use a subobject when creating keys for one of the following:
An implementation variation. Usually has a similar set of UI property keys as the parent object. Examples:
Default button:
Button.Default.background
Tool window notification:
Notification.ToolWindow.errorBackground
An internal smaller component of a complex component with its own UI and behavior. Examples:
Tool window tab:
ToolWindow.HeaderTab.inactiveBackground
The hint text at the bottom of a popup:
Popup.Advertiser.background
Gradient Color
If a component has a gradient color, add the words "start" and "end" for the beginning and ending of a gradient. Examples:
Button.startBorderColor
/Button.endBorderColor
SearchMatch.startBackground
/SearchMatch.endBackground
Capitalization
Capitalize Object and SubObject. Use lowerCamelCase for property.
Do Not Use
Do not use | Use instead |
---|---|
|
|
|
|
|
|
| Omit |
Swing Legacy
Some color keys are not named according to the rules above. Such keys are inherited from Java Swing and cannot be renamed for compatibility reasons. Do not use naming patterns from the legacy keys.
Examples of Swing keys:
activeCaption
Correct:WindowsDialogHeader.background
Button.disabledText
Correct:Button.disabledForeground
TableHeader.background
Correct:Table.Header.background
IntelliJ Platform Metadata
Metadata is split up as follows:
IntelliJPlatform.themeMetadata.json
- all keys from IntelliJ Platform and custom UI componentsJDK.themeMetadata.json
- all keys from Swing components
New keys should be added to IntelliJPlatform.themeMetadata.json only (or corresponding "local" *.themeMetadata.json file of the plugin if applicable).
Please make sure to add a description
and use since
and deprecated
attributes explained in Attributes. Respect Key Naming Scheme and keep alphabetical ordering of keys.