diff --git a/docs/.vitepress/config.js b/docs/.vitepress/config.js
index 08b446962..46a590f2e 100644
--- a/docs/.vitepress/config.js
+++ b/docs/.vitepress/config.js
@@ -94,6 +94,7 @@ export default ({ mode }) => {
collapsed: false,
items: [
{ text: 'ui-button', link: '/nodes/widgets/ui-button' },
+ { text: 'ui-button-group', link: '/nodes/widgets/ui-button-group' },
{ text: 'ui-control', link: '/nodes/widgets/ui-control' },
{ text: 'ui-chart', link: '/nodes/widgets/ui-chart' },
{ text: 'ui-dropdown', link: '/nodes/widgets/ui-dropdown' },
diff --git a/docs/nodes/widgets/ui-button-group.md b/docs/nodes/widgets/ui-button-group.md
new file mode 100644
index 000000000..264af2dd1
--- /dev/null
+++ b/docs/nodes/widgets/ui-button-group.md
@@ -0,0 +1,37 @@
+---
+props:
+ Group: Defines which group of the UI Dashboard this widget will render in.
+ Size: Controls the width of the button with respect to the parent group. Maximum value is the width of the group.
+ Label: The text shown within the button.
+ Appearance: Specify whether the shape of the widget should be rectangular or have rounded corners.
+ Use theme colors: Specify whether the theme colors should be used. If not active, custom colors can be specified for each option separately.
+ Options: Specify which options need to be displayed. Each option can specify a label, icon, value and color.
+ Topic: The text that needs to be send in the msg.topic field.
+ Passthrough: Specify whether input messages should be passed through as output messages.
+controls:
+ enabled:
+ example: true | false
+ description: Allow control over whether or not the button is clickable.
+dynamic:
+ Class:
+ payload: msg.class
+ structure: ["String"]
+---
+
+
+
+# Button `ui-button-grup`
+
+Adds a set of buttons that act as a multi-state switch to your dashboard. When an individual button is clicked, it will become active and all other buttons in the group will become inactive, with the newly selected value being emitted from the node in Node-RED.
+
+The selected option can be set by sending a `msg.payload` with the value of the button to be selected.
+
+## Properties
+
+