2023-01-26 10:41:07 +02:00
import QtQuick 2.14
import QtQuick . Controls 2.14
import QtQuick . Layouts 1.14
2023-05-31 23:58:23 +03:00
2023-01-26 10:41:07 +02:00
import StatusQ . Core 0.1
2023-05-31 23:58:23 +03:00
import StatusQ . Controls 0.1
import StatusQ . Popups 0.1
import StatusQ . Popups . Dialog 0.1
2023-01-26 10:41:07 +02:00
import Storybook 1.0
import Models 1.0
import utils 1.0
SplitView {
id: root
Logs { id: logs }
2023-05-31 23:58:23 +03:00
QtObject {
id: d
2023-07-28 13:51:41 +03:00
property string longText: ModelsData . descriptions . longLoremIpsum . repeat ( 5 )
2023-05-31 23:58:23 +03:00
readonly property bool isRectangle: contentComboBox . currentValue === "rectangle"
2023-07-28 13:51:41 +03:00
readonly property bool isImage: contentComboBox . currentValue === "image"
2023-05-31 23:58:23 +03:00
readonly property bool isText: contentComboBox . currentValue === "text"
}
2023-01-26 10:41:07 +02:00
SplitView {
orientation: Qt . Vertical
SplitView.fillWidth: true
2023-07-28 13:51:41 +03:00
Item {
2023-01-26 10:41:07 +02:00
SplitView.fillWidth: true
SplitView.fillHeight: true
2023-05-31 23:58:23 +03:00
Rectangle {
2023-07-28 13:51:41 +03:00
anchors.centerIn: parent
width: 600
height: 600
2023-05-31 23:58:23 +03:00
2023-07-28 13:51:41 +03:00
border.color: "black"
border.width: 1
StatusScrollView {
id: scrolView1
anchors.fill: parent
anchors.margins: 1
contentWidth: widthFillCheckBox . checked ? availableWidth : widthSpinBox . value
visible: d . isRectangle
Rectangle {
gradient: Gradient . NightFade
implicitWidth: widthFillCheckBox . checked ? scrolView1.availableWidth : widthSpinBox . value
implicitHeight: heightFillCheckBox . checked ? scrolView1.availableHeight : heightSpinBox . value
}
}
StatusScrollView {
id: scrollView3
anchors.fill: parent
anchors.margins: 1
contentWidth: widthFillCheckBox . checked ? availableWidth : widthSpinBox . value
visible: d . isImage
Image {
width: widthFillCheckBox . checked ? scrollView3.availableWidth : widthSpinBox . value
source: "https://placekitten.com/900/900"
}
}
StatusScrollView {
id: scrollView2
anchors.fill: parent
anchors.margins: 1
contentWidth: widthFillCheckBox . checked ? availableWidth : widthSpinBox . value
2023-05-31 23:58:23 +03:00
2023-07-28 13:51:41 +03:00
visible: d . isText
2023-05-31 23:58:23 +03:00
2023-07-28 13:51:41 +03:00
Text {
width: widthFillCheckBox . checked ? scrollView2.availableWidth : widthSpinBox . value
wrapMode: Text . WrapAnywhere
text: d . longText
}
}
2023-05-31 23:58:23 +03:00
}
}
StatusModal {
id: modal
2023-07-28 13:51:41 +03:00
anchors.centerIn: parent
2023-05-31 23:58:23 +03:00
padding: 0
2023-07-28 13:51:41 +03:00
destroyOnClose: false
headerSettings.title: "StatusScrollView"
showFooter: false
2023-05-31 23:58:23 +03:00
StatusScrollView {
id: modalScrollView
2023-01-26 10:41:07 +02:00
anchors.fill: parent
2023-05-31 23:58:23 +03:00
contentWidth: availableWidth
Text {
width: modalScrollView . availableWidth
wrapMode: Text . WrapAnywhere
text: d . longText
}
}
}
StatusModal {
id: modal2
anchors.centerIn: parent
padding: 16
2023-07-28 13:51:41 +03:00
destroyOnClose: false
headerSettings.title: "StatusScrollView (detached scrollbars)"
showFooter: false
2023-05-31 23:58:23 +03:00
ColumnLayout {
anchors.fill: parent
spacing: 20
Text {
id: textItem
Layout.fillWidth: true
text: "This header is fixed and not scrollable"
font.pixelSize: 18
}
Item {
id: modal2scrollViewWrapper
Layout.fillWidth: true
Layout.fillHeight: true
implicitWidth: modal2scrollView . implicitWidth
implicitHeight: modal2scrollView . implicitHeight
StatusScrollView {
id: modal2scrollView
anchors.fill: parent
contentWidth: availableWidth
padding: 0
ScrollBar.vertical: StatusScrollBar {
parent: modal2scrollViewWrapper
anchors.top: modal2scrollView . top
anchors.bottom: modal2scrollView . bottom
anchors.left: modal2scrollView . right
anchors.leftMargin: 1
}
Text {
width: modal2scrollView . availableWidth
wrapMode: Text . WordWrap
text: d . longText
}
}
2023-01-26 10:41:07 +02:00
}
}
}
LogsAndControlsPanel {
id: logsAndControlsPanel
SplitView.minimumHeight: 100
SplitView.preferredHeight: 200
logsView.logText: logs . logText
2023-05-31 23:58:23 +03:00
2023-07-28 13:51:41 +03:00
ColumnLayout {
Layout.fillHeight: true
Layout.fillWidth: true
2023-05-31 23:58:23 +03:00
2023-07-28 13:51:41 +03:00
RowLayout {
Layout.fillWidth: true
Button {
Layout.fillHeight: true
text: "StatusModal"
onClicked: {
modal . open ( )
}
}
Button {
Layout.fillHeight: true
text: "StatusModal\n(detached bar)"
onClicked: {
modal2 . open ( )
}
2023-05-31 23:58:23 +03:00
}
}
2023-07-28 13:51:41 +03:00
Label {
id: slidesLabel
Layout.fillWidth: true
wrapMode: Text . WordWrap
textFormat: Text . MarkdownText
text: "Please, read our [contributing guide](https://github.com/status-im/status-desktop/blob/master/ui/StatusQ/src/contributing.md#StatusScrollView) (or checkout a [presenation](https://docs.google.com/presentation/d/1ZZeg9j2fZMV-iHreu_Wsl1u6D9POH7SlUO78ZXNj-AI)) about using `StatusScrollView`"
onLinkActivated: ( link ) = > {
Qt . openUrlExternally ( link )
}
MouseArea {
anchors.fill: parent
cursorShape: Qt . PointingHandCursor
visible: ! ! slidesLabel . hoveredLink
acceptedButtons: Qt . NoButton
2023-05-31 23:58:23 +03:00
}
}
2023-07-28 13:51:41 +03:00
2023-05-31 23:58:23 +03:00
}
2023-01-26 10:41:07 +02:00
}
}
Pane {
2023-05-31 23:58:23 +03:00
SplitView.minimumWidth: 300
SplitView.preferredWidth: 300
ScrollView {
GridLayout {
Layout.fillWidth: true
columns: 2
columnSpacing: 10
ComboBox {
id: contentComboBox
Layout.columnSpan: 2
Layout.fillWidth: true
Layout.bottomMargin: 20
2023-07-28 13:51:41 +03:00
model: [ "image" , "rectangle" , "text" ]
2023-05-31 23:58:23 +03:00
}
Label {
text: "fill width"
}
CheckBox {
id: widthFillCheckBox
}
Label {
text: "rectangle width"
}
SpinBox {
id: widthSpinBox
enabled: ! widthFillCheckBox . checked
editable: true
height: 30
2023-07-28 13:51:41 +03:00
value: 900
2023-05-31 23:58:23 +03:00
stepSize: 100
from: 0
to: 1000
}
Label {
text: "fill height"
}
CheckBox {
id: heightFillCheckBox
checked: false
}
Label {
text: "rectangle height"
}
SpinBox {
id: heightSpinBox
editable: true
height: 30
value: 800
stepSize: 100
from: 0
to: 1000
}
}
}
}
2023-01-26 10:41:07 +02:00
}
2023-07-31 14:21:14 +02:00
// category: Components