aboutsummaryrefslogtreecommitdiffstats
path: root/tests/manual/quickcontrols/material/material.qml
blob: 78efaf72e3738488b3b94b4988fc4262979c744e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
// Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtCore
import QtQuick
import QtQuick.Controls.Material
import QtQuick.Layouts

ApplicationWindow {
    id: window
    title: "Material"
    width: screen.desktopAvailableWidth * 0.8
    height: screen.desktopAvailableHeight * 0.8
    visible: true

    Material.theme: settings.theme

    Settings {
        id: settings

        property alias windowX: window.x
        property alias windowY: window.y
        property alias windowWidth: window.width
        property alias windowHeight: window.height

        property int theme: darkThemeSwitch.checked ? Material.Dark : Material.Light
        property string variant: denseSwitch.checked ? "Dense" : "Normal"

        property alias currentControlIndex: listView.currentIndex
    }

    Shortcut {
        sequences: ["Esc", "Back"]
        onActivated: openDrawerAction.trigger()
    }

    Shortcut {
        sequence: "Ctrl+Q"
        onActivated: Qt.quit()
    }

    Action {
        id: openDrawerAction
        text: "Controls"
        onTriggered: drawer.open()
    }

    header: ToolBar {
        RowLayout {
            spacing: 20
            anchors.fill: parent

            Material.theme: Material.Dark

            ToolButton {
                action: openDrawerAction
            }

            Label {
                id: titleLabel
                text: listView.currentItem ? listView.currentItem.text : "Material"
                font.pixelSize: 20
                elide: Label.ElideRight
                horizontalAlignment: Qt.AlignHCenter
                verticalAlignment: Qt.AlignVCenter
                Layout.fillWidth: true
            }

            Item {
                Layout.fillWidth: true
            }

            Switch {
                id: darkThemeSwitch
                text: "Dark"
                checked: settings.theme === Material.Dark
            }

            Switch {
                id: denseSwitch
                text: "Dense"
                checked: settings.variant === "Dense"

                ToolTip.text: "Requires restart"
                ToolTip.visible: hovered
            }
        }
    }

    Drawer {
        id: drawer
        width: window.width / 3
        height: window.height
        interactive: stackView.depth === 1

        ListView {
            id: listView
            focus: true
            currentIndex: settings.currentControlIndex
            anchors.fill: parent
            model: ["Button", "DelayButton", "RoundButton", "Switch"]
            delegate: ItemDelegate {
                width: listView.width
                text: modelData
                highlighted: ListView.isCurrentItem
                onClicked: listView.currentIndex = index
            }

            ScrollIndicator.vertical: ScrollIndicator { }

            // Need to wait until our count is non-zero before setting a default currentIndex.
            // This also allows us to use an alias for the settings property.
            Component.onCompleted: if (currentIndex === -1) currentIndex = 0

            onCurrentIndexChanged: {
                if (currentIndex >= 0 && currentIndex < count)
                    stackView.replace("qrc:/pages/" + model[currentIndex] + "Page.qml")
                drawer.close()
            }
        }
    }

    StackView {
        id: stackView
        anchors.fill: parent
    }
}