Button
Buttons allow for click based interaction with devices.
data:image/s3,"s3://crabby-images/83124/831248908393857918a9bb07c63cfc86b3349ca8" alt="Screenshot of component Button Button"
Usage
To determine what to write to the device, Button's have a writer
prop that takes a functional writer.
A writer that sets the bright
variable to 255
. The contents (children) between the <Button> </Button>
tags render inside the button.
import { Button } from '@electricui/components-desktop-blueprint' <Button writer ={state => { state .bright = 255 }}> Set brightness to 255</Button >
A writer that sets the rgb
messageID to a red colour.
<Button writer ={state => { state .rgb = { r : 255, g : 10, b : 10, } }}> Set RGB to red</Button >
A writer that sets the randfloat
messageID to a random float between 0 and 1 each click.
<Button writer ={state => { state .randfloat = Math .random () }}> Send random number</Button >
When calling a hardware callback function, use callback
with the messageID instead of a writer.
<Button callback ="estop" > Disable All</Button >
Add the noAck
boolean prop (or set it to true), to disable automatic acknowledgement when a click has occured.
Intent Colours
The intent of the button allows you to change the colour.
data:image/s3,"s3://crabby-images/043c8/043c8279911b561f34b95c2fcdf12df13890e5b2" alt="Screenshot of component Button with-default-intent"
data:image/s3,"s3://crabby-images/5d0c3/5d0c3fec69cb56c5953b6b4e69837b0952ddab84" alt="Screenshot of component Button with-primary-intent"
data:image/s3,"s3://crabby-images/5d8c7/5d8c7a1f6583086eeb2c9953c7f8042f91ef603d" alt="Screenshot of component Button with-success-intent"
data:image/s3,"s3://crabby-images/d3ddb/d3ddb3ae6131cf34b26a5c4157299d6450ec471b" alt="Screenshot of component Button with-warning-intent"
data:image/s3,"s3://crabby-images/98d57/98d571a277c041f61127cbc5f1520c7189e361c9" alt="Screenshot of component Button with-danger-intent"
<Button intent ="success">Button with success intent</Button >
Minimal Styling
Buttons can have minimal styling. Minimal buttons look like text with no frame or styling, on click they look like this:
data:image/s3,"s3://crabby-images/4eadf/4eadf262536cc76ca95e22a32c7ea11985033478" alt="Screenshot of component Button with-minimal-styling"
<Button minimal >Button with minimal styling</Button >
Outline Styling
Buttons also support an outlined
style.
<Button outlined >Button with outline styling</Button >
Large and Small, Fills
Control the size of the buttons with the large
and small
properties.
data:image/s3,"s3://crabby-images/b6aee/b6aee39bfe3d18b34523a63ba6355dce4726e47d" alt="Screenshot of component Button with-size-large"
data:image/s3,"s3://crabby-images/d3680/d36804e7fa7bf305a7d1f4440e939fc0931dfe50" alt="Screenshot of component Button with-size-default"
data:image/s3,"s3://crabby-images/096b0/096b0ce2cc11e37e93b0065cf4c03318fbb93c53" alt="Screenshot of component Button with-size-small"
<Button large >Button with large sizing</Button >
<Button >Button with default sizing</Button >
<Button small >Button with small sizing</Button >
A button will fill it's container with the fill
property.
data:image/s3,"s3://crabby-images/01afb/01afbee9c6fef3ddecbf912f9044c283184edc05" alt="Screenshot of component Button with-fill"
<Button >Default Button</Button >
<Button fill >Button with Fill</Button >
Grouping
Buttons can join to create command palletes or menu-like clusters. Buttons in groups accept the same set of properties applicable to standalone buttons.
data:image/s3,"s3://crabby-images/c36dd/c36ddb8621c742ea0ee1fab8c545151d68431b89" alt="Screenshot of component Button group-basic"
import { ButtonGroup } from '@blueprintjs/core'import { Button } from '@electricui/components-desktop-blueprint'
<ButtonGroup > <Button intent ="primary">Blue Pill</Button > <Button intent ="warning">Red Pill</Button ></ButtonGroup >
Groups can draw vertically with the vertical
prop.
data:image/s3,"s3://crabby-images/e037f/e037fdabf86fb644d4bd7d9209bbd8e62417494f" alt="Screenshot of component Button group-vertical"
<ButtonGroup vertical > <Button >Ascend</Button > <Button >Maintain Altitude</Button > <Button >Descend</Button ></ButtonGroup >
Icons
icon
and rightIcon
allow for an Icon
to be integrated inside the Button.
Use either IconNames or the string name.