2021-05-06 11:20:50 +02:00
import QtQuick 2.14
2021-05-06 13:10:17 +02:00
import QtQuick . Controls 2.14
2021-05-06 11:20:50 +02:00
import QtQuick . Layouts 1.14
import StatusQ . Core 0.1
import StatusQ . Core . Theme 0.1
import StatusQ . Controls 0.1
2021-06-28 16:36:51 +03:00
import Sandbox 0.1
2021-05-06 11:20:50 +02:00
GridLayout {
2021-07-23 11:44:38 +02:00
columns: 1
2021-05-06 11:20:50 +02:00
columnSpacing: 5
rowSpacing: 5
2021-09-29 21:22:23 +02:00
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
}
2021-05-06 11:20:50 +02:00
StatusIconTabButton {
icon.name: "chat"
}
StatusIconTabButton {
2022-07-22 16:42:05 +03:00
icon.source: "qrc:/demoapp/data/profile-image-1.jpeg"
2021-05-06 11:20:50 +02:00
}
2021-05-20 12:14:40 +02:00
StatusIconTabButton {
icon.color: Theme . palette . miscColor9
// This icon source is flawed and demonstrates the fallback case
// when the image source can't be loaded
2022-07-22 16:42:05 +03:00
icon.source: "https://httpstat.us/404"
2021-05-20 12:14:40 +02:00
name: "Pascal"
}
2021-05-06 11:20:50 +02:00
StatusIconTabButton {
name: "#status"
}
2021-05-06 13:10:17 +02:00
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
}
}
2021-05-06 14:47:57 +02:00
StatusNavBarTabButton {
icon.name: "chat"
tooltip.text: "Chat"
}
StatusNavBarTabButton {
name: "#status"
tooltip.text: "Some Channel"
}
StatusNavBarTabButton {
2022-07-22 16:42:05 +03:00
icon.source: "qrc:/demoapp/data/profile-image-1.jpeg"
2021-05-06 14:47:57 +02:00
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
}
2021-05-20 09:14:18 +03:00
StatusSwitch {
}
2022-09-02 17:59:28 +02:00
StatusSwitch {
text: "Switch with text"
}
2021-05-20 09:45:05 +03:00
StatusRadioButton {
2022-09-02 17:59:28 +02:00
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)"
2021-05-20 09:45:05 +03:00
}
2021-05-20 11:43:01 +03:00
StatusCheckBox { }
2022-08-09 08:07:52 +02:00
StatusCheckBox { checkState: Qt . Checked }
StatusCheckBox { text: "Check me on left side" }
StatusCheckBox { text: "Check me on right side" ; leftSide: false }
2021-05-27 14:41:14 +02:00
StatusChatInfoButton {
title: "Iuri Matias"
subTitle: "Contact"
2022-09-02 18:40:30 +03:00
asset.color: Theme . palette . miscColor7
asset.isImage: true
asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
2021-05-27 14:41:14 +02:00
type: StatusChatInfoButton . Type . OneToOneChat
muted: true
pinnedMessagesCount: 1
}
2021-08-25 16:14:37 +03:00
Item {
implicitWidth: 100
implicitHeight: 48
StatusChatInfoButton {
title: "Iuri Matias elided"
2022-09-13 15:08:06 +02:00
subTitle: "Very long subtitle should elide as well"
2022-09-02 18:40:30 +03:00
asset.color: Theme . palette . miscColor7
asset.isImage: true
asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
2021-08-25 16:14:37 +03:00
type: StatusChatInfoButton . Type . OneToOneChat
muted: true
2022-09-13 15:08:06 +02:00
pinnedMessagesCount: 10
2021-08-25 16:14:37 +03:00
width: 100
}
}
Item {
implicitWidth: 100
implicitHeight: 48
StatusChatInfoButton {
title: "Iuri Matias big not elided"
subTitle: "Contact"
2022-09-02 18:40:30 +03:00
asset.color: Theme . palette . miscColor7
asset.isImage: true
asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
2021-08-25 16:14:37 +03:00
type: StatusChatInfoButton . Type . OneToOneChat
muted: true
pinnedMessagesCount: 1
width: 400
}
}
2021-05-27 14:41:14 +02:00
StatusChatInfoButton {
title: "group"
subTitle: "Group Chat"
pinnedMessagesCount: 1
2022-09-02 18:40:30 +03:00
asset.color: Theme . palette . miscColor7
2021-05-27 14:41:14 +02:00
type: StatusChatInfoButton . Type . GroupChat
}
StatusChatInfoButton {
title: "public-chat"
subTitle: "Public Chat"
2022-09-02 18:40:30 +03:00
asset.color: Theme . palette . miscColor7
2021-05-27 14:41:14 +02:00
type: StatusChatInfoButton . Type . PublicChat
}
StatusChatInfoButton {
title: "community-channel"
subTitle: "Community Chat"
2022-09-02 18:40:30 +03:00
asset.color: Theme . palette . miscColor7
2021-05-27 14:41:14 +02:00
type: StatusChatInfoButton . Type . CommunityChat
}
2021-05-28 13:09:58 +03:00
2022-09-13 15:08:06 +02:00
StatusChatInfoButton {
title: "community-channel"
subTitle: "Some very long description text to see how the whole item wraps or elides"
asset.color: Theme . palette . miscColor7
type: StatusChatInfoButton . Type . CommunityChat
pinnedMessagesCount: 3
}
2021-05-28 13:09:58 +03:00
StatusSlider {
width: 360
from: 0
to: 100
value: 40
}
2022-01-14 20:18:57 +01:00
2022-05-25 11:12:50 +03:00
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%" ) ]
}
2022-01-14 20:18:57 +01:00
StatusBanner {
id: banner
width: 360
topPadding: 20
type: StatusBanner . Type . Danger
statusText: "Banner"
}
2022-01-18 19:06:00 +01:00
StatusProgressBar {
2022-05-25 11:12:50 +03:00
id: progressBar
2022-01-18 19:06:00 +01:00
text: "Weak"
value: 0.5
fillColor : Theme . palette . pinColor1
}
2021-05-06 13:10:17 +02:00
}