native: add LoginScreen
This commit is contained in:
parent
bcf6b64a7a
commit
b7243d67e5
1 changed files with 67 additions and 50 deletions
|
@ -1,63 +1,80 @@
|
||||||
import QtQuick
|
import QtQuick 2.15
|
||||||
import QtQuick.Window
|
import QtQuick.Controls 2.15
|
||||||
import Qt.labs.qmlmodels
|
import QtQuick.Controls.Basic
|
||||||
|
|
||||||
|
//import "Main.qml" as M
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Window {
|
Window {
|
||||||
|
|
||||||
|
SystemPalette { id: activeColors; colorGroup: SystemPalette.Active }
|
||||||
|
SystemPalette { id: inactiveColors; colorGroup: SystemPalette.Inactive }
|
||||||
|
SystemPalette { id: disabledColors; colorGroup: SystemPalette.Disabled }
|
||||||
|
|
||||||
|
function getColors() {
|
||||||
|
return root.active ? activeColors : inactiveColors;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
width: 400
|
width: 400
|
||||||
height: 400
|
height: 400
|
||||||
visible: true
|
visible: true
|
||||||
|
|
||||||
TableView {
|
color: getColors().window
|
||||||
anchors.fill: parent
|
|
||||||
columnSpacing: 1
|
|
||||||
rowSpacing: 1
|
|
||||||
boundsBehavior: Flickable.StopAtBounds
|
|
||||||
|
|
||||||
model: TableModel {
|
Label{
|
||||||
TableModelColumn { display: "checked" }
|
id: loginL
|
||||||
TableModelColumn { display: "amount" }
|
anchors{
|
||||||
TableModelColumn { display: "fruitType" }
|
verticalCenter: parent.verticalCenter
|
||||||
TableModelColumn { display: "fruitName" }
|
verticalCenterOffset: -70
|
||||||
TableModelColumn { display: "fruitPrice" }
|
horizontalCenter: parent.horizontalCenter
|
||||||
|
}
|
||||||
|
|
||||||
// Each row is one type of fruit that can be ordered
|
|
||||||
rows: [
|
|
||||||
{
|
|
||||||
// Each property is one cell/column.
|
|
||||||
checked: false,
|
|
||||||
amount: 1,
|
|
||||||
fruitType: "Apple",
|
|
||||||
fruitName: "Granny Smith",
|
|
||||||
fruitPrice: 1.50
|
|
||||||
},
|
|
||||||
{
|
|
||||||
checked: true,
|
|
||||||
amount: 4,
|
|
||||||
fruitType: "Orange",
|
|
||||||
fruitName: "Navel",
|
|
||||||
fruitPrice: 2.50
|
|
||||||
},
|
|
||||||
{
|
|
||||||
checked: false,
|
|
||||||
amount: 1,
|
|
||||||
fruitType: "Banana",
|
|
||||||
fruitName: "Cavendish",
|
|
||||||
fruitPrice: 3.50
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
delegate: TextInput {
|
|
||||||
text: model.display
|
|
||||||
padding: 12
|
|
||||||
selectByMouse: true
|
|
||||||
|
|
||||||
onAccepted: model.display = text
|
text: qsTr("Login")
|
||||||
|
font.pointSize: 20
|
||||||
|
font.bold: true
|
||||||
|
|
||||||
|
color: getColor().text
|
||||||
|
|
||||||
Rectangle {
|
|
||||||
anchors.fill: parent
|
|
||||||
color: "#efefef"
|
|
||||||
z: -1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TextField {
|
||||||
|
|
||||||
|
id: nameT
|
||||||
|
anchors{
|
||||||
|
horizontalCenter: parent.horizontalCenter
|
||||||
|
topMargin: 5
|
||||||
|
top: loginL.bottom
|
||||||
}
|
}
|
||||||
|
|
||||||
|
placeholderText: qsTr("Name")
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
TextField {
|
||||||
|
id: passwordT
|
||||||
|
anchors{
|
||||||
|
horizontalCenter: parent.horizontalCenter
|
||||||
|
topMargin: 5
|
||||||
|
top: nameT.bottom
|
||||||
|
}
|
||||||
|
|
||||||
|
placeholderText: qsTr("Password")
|
||||||
|
|
||||||
|
echoMode: TextInput.Password
|
||||||
|
}
|
||||||
|
|
||||||
|
Button {
|
||||||
|
id: submitB
|
||||||
|
anchors{
|
||||||
|
right: passwordT.right
|
||||||
|
topMargin: 5
|
||||||
|
top: passwordT.bottom
|
||||||
|
}
|
||||||
|
|
||||||
|
text: qsTr("Submit")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue