radiance-plasma
for build instructions of the latest stable release.
In your Java app, this is how you would configure a toggle command, add it to a command group, and project the group to create a command button strip:
Command styleBold = Command.builder()
.setIconFactory(Format_text_bold.factory())
.setAction((CommandActionEvent e) -> System.out.println("Bold toggled"))
.setToggleSelected(true)
.setActionRichTooltip(RichTooltip.builder()
.setTitle(resourceBundle.getString("FontBold.tooltip.textActionTitle"))
.addDescriptionSection(resourceBundle.getString("FontBold.tooltip.textActionParagraph1"))
.build())
.build();
Map<Command, CommandButtonPresentationModel.Overlay> styleOverlays = new HashMap<>();
styleOverlays.put(styleBold, CommandButtonPresentationModel.overlay().setActionKeyTip("1"));
CommandStripProjection styleStripProjection = new CommandStripProjection(
new CommandGroup(styleBold),
CommandStripPresentationModel.withDefaults());
styleStripProjection.setCommandOverlays(styleOverlays);
JCommandButtonStrip buttonStrip = styleStripProjection.buildComponent();
And here is how the same code would look like in Kotlin using the Plasma-provided DSL:
commandButtonStrip {
command {
iconFactory = Format_text_bold.factory()
action = { println("Bold toggled") }
isToggleSelected = true
actionRichTooltip {
title = resourceBundle.getString("FontBold.tooltip.textActionTitle")
description = resourceBundle.getString("FontBold.tooltip.textActionParagraph1")
}
actionKeyTip = "1"
}
}
Plasma provides DSL constructs for the following Flamingo components:
JCommandButton
JCommandButtonPanel
JCommandButtonStrip
JCommandPopupMenu
JRibbon
and all its parts
For example, here is a function that constructs and returns a ribbon band:
fun getFindBand(): KRibbonBand {
return ribbonBand {
title = resourceBundle.getString("Find.textBandTitle")
iconFactory = Edit_find.factory()
collapsedStateKeyTip = "ZY"
command(RibbonElementPriority.TOP, actionKeyTip = "FD") {
title = resourceBundle.getString("Search.text")
iconFactory = System_search.factory()
action = { println("Search activated") }
}
command(RibbonElementPriority.MEDIUM) {
title = resourceBundle.getString("Find.text")
iconFactory = Edit_find.factory()
action = { println("Find activated") }
}
command(RibbonElementPriority.MEDIUM) {
title = resourceBundle.getString("FindReplace.text")
iconFactory = Edit_find_replace.factory()
action = { println("Find Replace activated") }
isActionEnabled = false
}
command(RibbonElementPriority.MEDIUM) {
title = resourceBundle.getString("SelectAll.text")
iconFactory = Edit_select_all.factory()
action = { println("Select All activated") }
}
resizePolicies = { ribbonBand ->
listOf(CoreRibbonResizePolicies.Mirror(ribbonBand),
CoreRibbonResizePolicies.IconRibbonBandResizePolicy(ribbonBand))
}
}
}
You can then construct a ribbon task out of one or more bands:
fun getPageLayoutTask(): KRibbonTask {
return ribbonTask {
title = resourceBundle.getString("PageLayout.textTaskTitle")
keyTip = "P"
bands {
+getClipboardBand()
+getQuickStylesBand()
+getFontBand()
+getDocumentBand()
+getFindBand()
}
}
}
And a ribbon frame out of one or more ribbon tasks and other elements:
val ribbonFrame = ribbonFrame {
title = builder.resourceBundle.getString("Frame.title")
applicationIcon = Applications_internet.factory()
tasks {
+builder.getPageLayoutTask()
+builder.getWriteTask()
+builder.getAnimationsTask()
+builder.getWrappedTask()
}
contextualTaskGroups {
// ...
}
anchored {
// ...
}
taskbar {
// ...
}
applicationMenu {
// ...
}
// This returns a JRibbonFrame object
val javaRibbonFrame = ribbonFrame.asRibbonFrame()
// Which we can then configure and display
javaRibbonFrame.preferredSize = Dimension(...)
javaRibbonFrame.minimumSize = Dimension(...)
javaRibbonFrame.pack()
javaRibbonFrame.setLocation(...)
javaRibbonFrame.defaultCloseOperation = WindowConstants.DISPOSE_ON_CLOSE
javaRibbonFrame.setVisible(true)