summaryrefslogtreecommitdiffstats
path: root/experimental/Wifi/main.qml
blob: 5c7bed9643a26e3053ed78f6976ba6c161a1488d (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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
import QtQuick 2.0
import Qt.labs.wifi 0.1

Rectangle
{
    id: root

    color: Qt.rgba(Math.random(), Math.random(), Math.random(), 1);

    QWifiManager {
        id: wifiManager;

        Component.onCompleted: start();

        onReadyChanged: {
            print("QML: QWifiManager is now connected...");
        }

        onOnlineChanged: print(online ? "QML: WifiManager is online" : "QML: WifiManager is not online...");

        //scanning: ready && connectedSSID == "";
        scanning: ready
    }

    Component {
        id: listDelegate

        Rectangle {
            id: delegateBackground
            property bool expanded: false
            height: expanded ? 300 : 70
            clip: true // ### fixme

            Behavior on height { NumberAnimation { duration: 500; easing.type: Easing.InOutCubic } }

            width: parent.width

            gradient: Gradient {
                GradientStop { position: 0; color: "white" }
                GradientStop { position: 67 / delegateBackground.height; color: "lightgray" }
                GradientStop { position: 1; color: "gray" }
            }

            Text {
                id: ssidLabel
                anchors.top: parent.top
                anchors.left: parent.left
                anchors.margins: 10
                font.pixelSize: 24
                font.bold: true
                text: network.ssid + (wifiManager.connectedSSID == network.ssid ? " (connected)" : "");
            }

            Text {
                id: bssidLabel
                anchors.top: ssidLabel.bottom
                anchors.left: parent.left
                anchors.margins: 5
                anchors.leftMargin: 40
                text: network.bssid
                color: "gray"
                font.pixelSize: ssidLabel.font.pixelSize * 0.5
            }

            Text {
                id: flagsLabel
                x: 200
                anchors.top: bssidLabel.top
                text: (network.supportsWPA2 ? "WPA2 " : "")
                      + (network.supportsWPA ? "WPA " : "")
                      + (network.supportsWEP ? "WEP " : "")
                      + (network.supportsWPS ? "WPS " : "");
                color: "gray"
                font.pixelSize: ssidLabel.font.pixelSize * 0.5
                font.italic: true
            }

            Rectangle {
                width: Math.max(100 + network.signalStrength, 0) / 100 * parent.width;
                height: 20
                radius: 10
                antialiasing: true
                anchors.margins: 20
                anchors.right: parent.right
                anchors.top: parent.top
                color: "lightblue"
                border.color: "lightgray"
            }

            MouseArea {
                anchors.fill: parent
                onClicked: {
                    parent.expanded = !expanded
                }
            }

            Rectangle {
                id: passwordInputBackground
                anchors.fill: passwordInput
                anchors.margins: -5
                color: "white"
                radius: 5
                border.color: "gray"
            }

            TextInput {
                id: passwordInput
                //echoMode: TextInput.PasswordEchoOnEdit
                y: 100
                width: 300
                height: 50
                anchors.horizontalCenter: parent.horizontalCenter
                font.pixelSize: 18
            }

            Rectangle {
                id: connectButton
                anchors.top: passwordInput.bottom
                anchors.margins: 20
                anchors.horizontalCenter: parent.horizontalCenter
                width: passwordInput.width
                height: passwordInputBackground.height

                gradient: Gradient {
                    GradientStop { position: 0; color: "white" }
                    GradientStop { position: 1; color: buttonMouse.pressed ? "steelblue" : "lightsteelblue" }
                }

                border.color: "gray"

                Text {
                    anchors.centerIn: parent
                    font.pixelSize: 24
                    text: "Connect"
                }
                MouseArea {
                    id: buttonMouse
                    anchors.fill: parent
                    onClicked: wifiManager.connect(network, passwordInput.text);
                }
            }

        }
    }

    ListView {
        anchors.fill: root
        model: wifiManager.networks
        delegate: listDelegate;
    }

    Image {
        source: wifiManager.online ? "http://img3.imageshack.us/img3/9870/magepicture.jpg" : ""
        anchors.bottom: parent.bottom

        width: parent.width
        height: sourceSize.height * (width / sourceSize.width);
    }
}