207 lines
5.3 KiB
QML
207 lines
5.3 KiB
QML
import QtQuick
|
|
import QtQuick.Layouts
|
|
import QtQuick.Controls
|
|
import Qt.labs.qmlmodels
|
|
|
|
Item {
|
|
anchors.fill: parent
|
|
//color: "lightslategrey"
|
|
property var availableFilters: ["Name", "Adresse", "PLZ", "Ort"]
|
|
id: test
|
|
|
|
SearchBar
|
|
{
|
|
id:searchBar
|
|
anchors.margins: 9
|
|
}
|
|
|
|
Button
|
|
{
|
|
id: addBusinessBtn
|
|
icon.source: "../images/addbusiness.svg"
|
|
icon.color: "olive"
|
|
anchors.right: parent.right
|
|
flat: true
|
|
onClicked: appLoader.source = "AddCustomer.qml"
|
|
}
|
|
|
|
|
|
ColumnLayout
|
|
{
|
|
id: tableColumn
|
|
anchors
|
|
{
|
|
|
|
top: searchBar.bottom
|
|
bottom: parent.bottom
|
|
left: parent.left
|
|
right: parent.right
|
|
}
|
|
|
|
RowLayout
|
|
{
|
|
// Layout.fillHeight: true
|
|
// Layout.fillWidth: true
|
|
|
|
|
|
RadioButton
|
|
{
|
|
|
|
checked: true
|
|
text: qsTr("Alle")
|
|
}
|
|
RadioButton
|
|
{
|
|
|
|
text: qsTr("Interessent")
|
|
}
|
|
RadioButton
|
|
{
|
|
|
|
text: qsTr("Kunden")
|
|
}
|
|
RadioButton
|
|
{
|
|
|
|
text: qsTr("Erledigt")
|
|
}
|
|
|
|
}
|
|
|
|
HorizontalHeaderView
|
|
{
|
|
id: horizontalHeader
|
|
Layout.fillWidth: true
|
|
implicitHeight: 40
|
|
movableColumns: true
|
|
syncView: testTable
|
|
|
|
delegate: Rectangle {
|
|
color: addBusinessBtn.palette.alternateBase
|
|
border.color: addBusinessBtn.palette.base
|
|
implicitHeight: 40
|
|
Layout.fillWidth: true
|
|
implicitWidth: 1
|
|
Text
|
|
{
|
|
text: model.display
|
|
elide: Text.ElideRight
|
|
width: parent.width
|
|
height: parent.height
|
|
horizontalAlignment: Text.AlignHCenter
|
|
verticalAlignment: Text.AlignVCenter
|
|
color: addBusinessBtn.palette.text
|
|
}
|
|
}
|
|
}
|
|
|
|
TableView
|
|
{
|
|
property var customWidths: [0.2, 0.5, 0.3]
|
|
property real newWidth: 0
|
|
|
|
id: testTable
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
columnSpacing: 1
|
|
rowSpacing: 2
|
|
model: dbm
|
|
alternatingRows: true
|
|
resizableColumns: true
|
|
selectionBehavior: TableView.SelectRows
|
|
selectionModel: ItemSelectionModel
|
|
{
|
|
id: selModel
|
|
model: testTable.model
|
|
}
|
|
|
|
// columnWidthProvider: function(column)
|
|
// {
|
|
// switch (column)
|
|
// {
|
|
// case 0: return width * 0.2;
|
|
// case 1: return width * 0.5;
|
|
// case 2: return width * 0.3;
|
|
// default: return width / model.columnCount();
|
|
// }
|
|
//return customWidths[column] * width;
|
|
//return tableColumn.content.implicitWidth // model.columnCount()
|
|
// newWidth = columnWidth(column)
|
|
// return newWidth
|
|
// }
|
|
|
|
Timer
|
|
{
|
|
running: true
|
|
interval: 3000
|
|
repeat: true
|
|
onTriggered:
|
|
{
|
|
//testTable.columnWidths[2] = 150
|
|
console.log("Timing..")
|
|
testTable.forceLayout();
|
|
}
|
|
}
|
|
|
|
|
|
|
|
delegate:Rectangle
|
|
{
|
|
required property bool selected
|
|
required property bool current
|
|
implicitWidth: tableColumn.width / testTable.columns
|
|
Layout.fillWidth: true
|
|
implicitHeight: 25
|
|
//color: selected? "lightblue": palette.base
|
|
color: selected
|
|
? addBusinessBtn.palette.highlight //palette.highlight
|
|
: (testTable.alternatingRows && row % 2 !== 0
|
|
? addBusinessBtn.palette.base // palette.base
|
|
: addBusinessBtn.palette.alternateBase) //palette.alternateBase)
|
|
|
|
Text
|
|
{
|
|
//Layout.fillWidth: true
|
|
text: model.display
|
|
elide: Text.ElideRight
|
|
width: parent.width
|
|
color: addBusinessBtn.palette.text
|
|
}
|
|
|
|
MouseArea
|
|
{
|
|
id: mouseArea
|
|
property bool hovered:false
|
|
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
|
|
|
|
onClicked:
|
|
{
|
|
dbm.onRowClicked(row)
|
|
|
|
|
|
|
|
}
|
|
onEntered:
|
|
{
|
|
testTable.selectionModel.select(testTable.model.index(row, 0), ItemSelectionModel.SelectCurrent | ItemSelectionModel.Rows)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
Item
|
|
{
|
|
Layout.fillHeight: true
|
|
Layout.fillWidth: true
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|