32db0bb023
- fix the control's width (don't have to be explicit, the QQC2 Control takes care of calculating the implicitWidth/Height automatically based on contents) - while at it, fix the metrics to be able to support RTL languages too (it was off for Arabic) - some smaller cleanups too
234 lines
6.0 KiB
QML
234 lines
6.0 KiB
QML
import QtQuick 2.14
|
|
import QtQuick.Controls 2.14
|
|
import QtQuick.Layouts 1.14
|
|
import StatusQ.Core 0.1
|
|
import StatusQ.Core.Theme 0.1
|
|
import StatusQ.Controls 0.1
|
|
|
|
import Sandbox 0.1
|
|
|
|
GridLayout {
|
|
columns: 1
|
|
columnSpacing: 5
|
|
rowSpacing: 5
|
|
|
|
StatusSelectableText {
|
|
color: Theme.palette.baseColor1
|
|
text: "This is a multiline paragraph that can be selected and copied. A paragraph is a group of words put together to form a group that is usually longer than a sentence. Paragraphs are often made up of several sentences. There are usually between three and eight sentences. Paragraphs can begin with an indentation (about five spaces), or by missing a line out, and then starting again."
|
|
font.pixelSize: 15
|
|
width: 300
|
|
multiline: true
|
|
}
|
|
|
|
StatusSelectableText {
|
|
color: Theme.palette.baseColor1
|
|
text: "<p>This is a selectable link in rich text format to test <a href='www.google.com'>www.google.com</a></p>"
|
|
font.pixelSize: 15
|
|
width: 200
|
|
}
|
|
|
|
StatusIconTabButton {
|
|
icon.name: "chat"
|
|
}
|
|
|
|
StatusIconTabButton {
|
|
icon.source: "qrc:/demoapp/data/profile-image-1.jpeg"
|
|
}
|
|
|
|
StatusIconTabButton {
|
|
icon.color: Theme.palette.miscColor9
|
|
// This icon source is flawed and demonstrates the fallback case
|
|
// when the image source can't be loaded
|
|
icon.source: "https://httpstat.us/404"
|
|
name: "Pascal"
|
|
}
|
|
|
|
StatusIconTabButton {
|
|
name: "#status"
|
|
}
|
|
|
|
Button {
|
|
text: "Hover me!"
|
|
StatusToolTip {
|
|
visible: parent.hovered
|
|
text: "Top"
|
|
}
|
|
StatusToolTip {
|
|
visible: parent.hovered
|
|
text: "Right"
|
|
orientation: StatusToolTip.Orientation.Right
|
|
x: parent.width + 16
|
|
y: parent.height / 2 - height / 2 + 4
|
|
}
|
|
StatusToolTip {
|
|
visible: parent.hovered
|
|
text: "Bottom"
|
|
orientation: StatusToolTip.Orientation.Bottom
|
|
y: parent.height + 12
|
|
}
|
|
StatusToolTip {
|
|
visible: parent.hovered
|
|
text: "Left"
|
|
orientation: StatusToolTip.Orientation.Left
|
|
x: -parent.width /2 -8
|
|
y: parent.height / 2 - height / 2 + 4
|
|
}
|
|
}
|
|
|
|
StatusNavBarTabButton {
|
|
icon.name: "chat"
|
|
tooltip.text: "Chat"
|
|
}
|
|
|
|
StatusNavBarTabButton {
|
|
name: "#status"
|
|
tooltip.text: "Some Channel"
|
|
}
|
|
|
|
StatusNavBarTabButton {
|
|
icon.source: "qrc:/demoapp/data/profile-image-1.jpeg"
|
|
tooltip.text: "Some Community"
|
|
}
|
|
|
|
StatusNavBarTabButton {
|
|
icon.name: "profile"
|
|
tooltip.text: "Profile"
|
|
badge.value: 0
|
|
badge.visible: true
|
|
badge.anchors.leftMargin:-16
|
|
}
|
|
|
|
StatusNavBarTabButton {
|
|
icon.name: "chat"
|
|
tooltip.text: "Chat"
|
|
badge.value: 35
|
|
}
|
|
|
|
StatusNavBarTabButton {
|
|
icon.name: "chat"
|
|
tooltip.text: "Chat"
|
|
badge.value: 100
|
|
}
|
|
|
|
StatusSwitch {
|
|
|
|
}
|
|
StatusSwitch {
|
|
text: "Switch with text"
|
|
}
|
|
|
|
StatusRadioButton {
|
|
text: "Radio button 1"
|
|
checked: true
|
|
}
|
|
StatusRadioButton {
|
|
text: "Radio button 2 (clicking on this text will uncheck the above)"
|
|
}
|
|
StatusRadioButton {
|
|
LayoutMirroring.enabled : true
|
|
text: "Radio button 3 (forced right-to-left)"
|
|
}
|
|
|
|
StatusCheckBox {}
|
|
StatusCheckBox { checkState: Qt.Checked}
|
|
StatusCheckBox { text: "Check me on left side"}
|
|
StatusCheckBox { text: "Check me on right side"; leftSide: false}
|
|
|
|
StatusChatInfoButton {
|
|
title: "Iuri Matias"
|
|
subTitle: "Contact"
|
|
asset.color: Theme.palette.miscColor7
|
|
asset.isImage: true
|
|
asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
|
|
type: StatusChatInfoButton.Type.OneToOneChat
|
|
muted: true
|
|
pinnedMessagesCount: 1
|
|
}
|
|
|
|
Item {
|
|
implicitWidth: 100
|
|
implicitHeight: 48
|
|
StatusChatInfoButton {
|
|
title: "Iuri Matias elided"
|
|
subTitle: "Contact"
|
|
asset.color: Theme.palette.miscColor7
|
|
asset.isImage: true
|
|
asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
|
|
type: StatusChatInfoButton.Type.OneToOneChat
|
|
muted: true
|
|
pinnedMessagesCount: 1
|
|
width: 100
|
|
}
|
|
}
|
|
|
|
Item {
|
|
implicitWidth: 100
|
|
implicitHeight: 48
|
|
StatusChatInfoButton {
|
|
title: "Iuri Matias big not elided"
|
|
subTitle: "Contact"
|
|
asset.color: Theme.palette.miscColor7
|
|
asset.isImage: true
|
|
asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
|
|
type: StatusChatInfoButton.Type.OneToOneChat
|
|
muted: true
|
|
pinnedMessagesCount: 1
|
|
width: 400
|
|
}
|
|
}
|
|
|
|
StatusChatInfoButton {
|
|
title: "group"
|
|
subTitle: "Group Chat"
|
|
pinnedMessagesCount: 1
|
|
asset.color: Theme.palette.miscColor7
|
|
type: StatusChatInfoButton.Type.GroupChat
|
|
}
|
|
|
|
StatusChatInfoButton {
|
|
title: "public-chat"
|
|
subTitle: "Public Chat"
|
|
asset.color: Theme.palette.miscColor7
|
|
type: StatusChatInfoButton.Type.PublicChat
|
|
}
|
|
|
|
StatusChatInfoButton {
|
|
title: "community-channel"
|
|
subTitle: "Community Chat"
|
|
asset.color: Theme.palette.miscColor7
|
|
type: StatusChatInfoButton.Type.CommunityChat
|
|
}
|
|
|
|
StatusSlider {
|
|
width: 360
|
|
from: 0
|
|
to: 100
|
|
value: 40
|
|
}
|
|
|
|
StatusLabeledSlider {
|
|
width: 360
|
|
model: [ qsTr("XS"), qsTr("S"), qsTr("M"), qsTr("L"), qsTr("XL"), qsTr("XXL")]
|
|
}
|
|
|
|
StatusLabeledSlider {
|
|
width: 360
|
|
model: [ qsTr("50%"), qsTr("100%"), qsTr("150%"), qsTr("200%")]
|
|
}
|
|
|
|
StatusBanner {
|
|
id: banner
|
|
width: 360
|
|
topPadding: 20
|
|
type: StatusBanner.Type.Danger
|
|
statusText: "Banner"
|
|
}
|
|
|
|
StatusProgressBar {
|
|
id: progressBar
|
|
text: "Weak"
|
|
value: 0.5
|
|
fillColor : Theme.palette.pinColor1
|
|
}
|
|
}
|