2023-06-18 14:47:24 +02:00
|
|
|
import QtQuick 2.14
|
|
|
|
import QtQuick.Controls 2.14
|
|
|
|
import QtQuick.Layouts 1.14
|
|
|
|
|
|
|
|
import StatusQ.Controls 0.1
|
|
|
|
|
|
|
|
import Storybook 1.0
|
|
|
|
|
|
|
|
SplitView {
|
|
|
|
Logs { id: logs }
|
|
|
|
|
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
readonly property var sizesModel: [StatusBaseButton.Size.Tiny, StatusBaseButton.Size.Small, StatusBaseButton.Size.Large]
|
|
|
|
|
|
|
|
readonly property string effectiveEmoji: ctrlEmojiEnabled.checked ? ctrlEmoji.text : ""
|
|
|
|
readonly property int effectiveTextPosition: ctrlTextPosLeft.checked ? StatusBaseButton.TextPosition.Left
|
|
|
|
: StatusBaseButton.TextPosition.Right
|
|
|
|
}
|
|
|
|
|
|
|
|
SplitView {
|
|
|
|
orientation: Qt.Horizontal
|
|
|
|
SplitView.fillWidth: true
|
|
|
|
|
|
|
|
Pane {
|
|
|
|
SplitView.fillWidth: true
|
|
|
|
SplitView.fillHeight: true
|
|
|
|
|
|
|
|
GridLayout {
|
|
|
|
anchors.centerIn: parent
|
|
|
|
rowSpacing: 10
|
|
|
|
columnSpacing: 10
|
|
|
|
columns: 4
|
|
|
|
|
|
|
|
Label { text: "" }
|
|
|
|
Label { text: "Tiny" }
|
|
|
|
Label { text: "Small" }
|
|
|
|
Label { text: "Large" }
|
|
|
|
|
|
|
|
Label {
|
|
|
|
text: "StatusButton"
|
|
|
|
Layout.columnSpan: 4
|
|
|
|
font.bold: true
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Text only:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
size: modelData
|
|
|
|
text: ctrlText.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Icon only:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
size: modelData
|
|
|
|
icon.name: ctrlIconName.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Text + icon:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
size: modelData
|
|
|
|
text: ctrlText.text
|
|
|
|
icon.name: ctrlIconName.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Round icon:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
Layout.preferredHeight: width
|
|
|
|
size: modelData
|
|
|
|
icon.name: ctrlIconName.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
isRoundIcon: true
|
|
|
|
radius: height/2
|
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label {
|
2024-02-19 14:32:58 +01:00
|
|
|
text: "StatusFlatButton"
|
2023-06-18 14:47:24 +02:00
|
|
|
Layout.columnSpan: 4
|
|
|
|
font.bold: true
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Text only:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusFlatButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
size: modelData
|
|
|
|
text: ctrlText.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Icon only:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusFlatButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
size: modelData
|
|
|
|
icon.name: ctrlIconName.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Text + icon:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusFlatButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
size: modelData
|
|
|
|
text: ctrlText.text
|
|
|
|
icon.name: ctrlIconName.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Label { text: "Round icon:" }
|
|
|
|
Repeater {
|
|
|
|
model: d.sizesModel
|
|
|
|
delegate: StatusFlatButton {
|
|
|
|
Layout.preferredWidth: ctrlWidth.value || implicitWidth
|
|
|
|
Layout.preferredHeight: width
|
|
|
|
size: modelData
|
|
|
|
icon.name: ctrlIconName.text
|
|
|
|
asset.emoji: d.effectiveEmoji
|
2024-03-12 16:44:27 +01:00
|
|
|
tooltip.text: ctrlTooltip.text
|
2023-06-18 14:47:24 +02:00
|
|
|
textPosition: d.effectiveTextPosition
|
|
|
|
type: ctrlType.currentIndex
|
|
|
|
loading: ctrlLoading.checked
|
|
|
|
enabled: ctrlEnabled.checked
|
2024-03-12 16:44:27 +01:00
|
|
|
interactive: ctrlInteractive.checked
|
2023-06-18 14:47:24 +02:00
|
|
|
isRoundIcon: true
|
|
|
|
radius: height/2
|
|
|
|
textFillWidth: ctrlFillWidth.checked
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
LogsAndControlsPanel {
|
|
|
|
id: logsAndControlsPanel
|
|
|
|
|
|
|
|
SplitView.minimumWidth: 300
|
|
|
|
SplitView.preferredWidth: 400
|
|
|
|
|
|
|
|
logsView.logText: logs.logText
|
|
|
|
|
|
|
|
ColumnLayout {
|
|
|
|
width: parent.width
|
|
|
|
RowLayout {
|
|
|
|
Label { text: "Text:" }
|
|
|
|
TextField {
|
|
|
|
id: ctrlText
|
|
|
|
placeholderText: "Button text"
|
|
|
|
text: "Foobar"
|
|
|
|
}
|
|
|
|
// enum StatusBaseButton.TextPosition.xxx
|
|
|
|
RadioButton {
|
|
|
|
id: ctrlTextPosLeft
|
|
|
|
text: "left"
|
|
|
|
}
|
|
|
|
RadioButton {
|
|
|
|
id: ctrlTextPosRight
|
|
|
|
text: "right"
|
|
|
|
checked: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
Label { text: "Icon name:" }
|
|
|
|
TextField {
|
|
|
|
id: ctrlIconName
|
|
|
|
placeholderText: "Icon name"
|
|
|
|
text: "gif"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
Label { text: "Emoji:" }
|
|
|
|
TextField {
|
|
|
|
id: ctrlEmoji
|
|
|
|
text: "💩"
|
|
|
|
}
|
|
|
|
CheckBox {
|
|
|
|
id: ctrlEmojiEnabled
|
|
|
|
text: "enabled"
|
|
|
|
}
|
|
|
|
}
|
2024-03-12 16:44:27 +01:00
|
|
|
RowLayout {
|
|
|
|
Label { text: "Tooltip:" }
|
|
|
|
TextField {
|
|
|
|
id: ctrlTooltip
|
|
|
|
placeholderText: "Tooltip"
|
|
|
|
text: "Sample tooltip"
|
|
|
|
}
|
|
|
|
}
|
2023-06-18 14:47:24 +02:00
|
|
|
RowLayout {
|
|
|
|
Label { text: "Type:" }
|
|
|
|
ComboBox {
|
|
|
|
id: ctrlType
|
2024-02-19 14:32:58 +01:00
|
|
|
model: ["Normal", "Danger", "Primary", "Warning", "Success"] // enum StatusBaseButton.Type.xxx
|
2023-06-18 14:47:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
RowLayout {
|
|
|
|
Label { text: "Width:" }
|
|
|
|
SpinBox {
|
|
|
|
id: ctrlWidth
|
|
|
|
from: 0
|
|
|
|
to: 280
|
|
|
|
value: 0 // 0 == implicitWidth
|
|
|
|
stepSize: 10
|
|
|
|
textFromValue: function(value, locale) { return value === 0 ? "Implicit" : value }
|
|
|
|
}
|
|
|
|
CheckBox {
|
|
|
|
id: ctrlFillWidth
|
|
|
|
text: "Fill width"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Switch {
|
|
|
|
id: ctrlLoading
|
|
|
|
text: "Loading"
|
|
|
|
}
|
2024-03-12 16:44:27 +01:00
|
|
|
Switch {
|
|
|
|
id: ctrlInteractive
|
|
|
|
text: "Interactive"
|
|
|
|
checked: true
|
|
|
|
}
|
2023-06-18 14:47:24 +02:00
|
|
|
Switch {
|
|
|
|
id: ctrlEnabled
|
|
|
|
text: "Enabled"
|
|
|
|
checked: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-31 14:21:14 +02:00
|
|
|
// category: Controls
|
2023-10-03 13:56:30 +02:00
|
|
|
|
|
|
|
// https://www.figma.com/file/MtAO3a7HnEH5xjCDVNilS7/%F0%9F%8E%A8-Design-System-%E2%8E%9C-Desktop?type=design&node-id=1-12&t=UHegCbqAa5K7qUKd-0
|