mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-24 07:03:56 -06:00
Add a Cura-themed, re-usable TableView component
CURA-7868
This commit is contained in:
parent
5f6b3b52c1
commit
dc02038513
1 changed files with 72 additions and 0 deletions
72
resources/qml/TableView.qml
Normal file
72
resources/qml/TableView.qml
Normal file
|
@ -0,0 +1,72 @@
|
|||
// Copyright (C) 2021 Ultimaker B.V.
|
||||
// Cura is released under the terms of the LGPLv3 or higher.
|
||||
|
||||
import QtQuick 2.10
|
||||
import QtQuick.Window 2.2
|
||||
import QtQuick.Controls 1.4 as OldControls // TableView doesn't exist in the QtQuick Controls 2.x in 5.10, so use the old one
|
||||
import QtQuick.Controls 2.3
|
||||
import QtQuick.Controls.Styles 1.4
|
||||
|
||||
import UM 1.2 as UM
|
||||
import Cura 1.6 as Cura
|
||||
|
||||
|
||||
OldControls.TableView
|
||||
{
|
||||
id: tableView
|
||||
|
||||
itemDelegate: Item
|
||||
{
|
||||
height: tableCellLabel.implicitHeight + UM.Theme.getSize("thin_margin").height
|
||||
|
||||
Label
|
||||
{
|
||||
id: tableCellLabel
|
||||
color: UM.Theme.getColor("text")
|
||||
elide: Text.ElideRight
|
||||
text: styleData.value
|
||||
anchors.fill: parent
|
||||
anchors.leftMargin: 10 * screenScaleFactor
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
}
|
||||
}
|
||||
|
||||
rowDelegate: Rectangle
|
||||
{
|
||||
color: styleData.selected ? UM.Theme.getColor("toolbar_button_hover") : UM.Theme.getColor("main_background")
|
||||
}
|
||||
|
||||
// Use the old styling technique since it's the only way to make the scrollbars themed in the TableView
|
||||
style: TableViewStyle
|
||||
{
|
||||
backgroundColor: UM.Theme.getColor("main_background")
|
||||
|
||||
handle: Rectangle
|
||||
{
|
||||
// both implicit width and height have to be set, since the handle is used by both the horizontal and the vertical scrollbars
|
||||
implicitWidth: UM.Theme.getSize("scrollbar").width
|
||||
implicitHeight: UM.Theme.getSize("scrollbar").width //
|
||||
radius: width / 2
|
||||
color: UM.Theme.getColor(styleData.pressed ? "scrollbar_handle_down" : styleData.hovered ? "scrollbar_handle_hover" : "scrollbar_handle")
|
||||
}
|
||||
|
||||
scrollBarBackground: Rectangle
|
||||
{
|
||||
// both implicit width and height have to be set, since the handle is used by both the horizontal and the vertical scrollbars
|
||||
implicitWidth: UM.Theme.getSize("scrollbar").width
|
||||
implicitHeight: UM.Theme.getSize("scrollbar").width
|
||||
color: UM.Theme.getColor("main_background")
|
||||
}
|
||||
|
||||
corner: Rectangle // The little rectangle between the vertical and horizontal scrollbars
|
||||
{
|
||||
color: UM.Theme.getColor("main_background")
|
||||
}
|
||||
|
||||
// Override the control arrows
|
||||
incrementControl: Item { }
|
||||
decrementControl: Item { }
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue