Bring changes from TableView to Digital Library version

The classes should be approximately the same. There's 2 differences now though:
* The ScrollBar is re-implemented in the Digital Library because the re-useable component is not available in all Cura editions that the Digital Library needs to support.
* The sections are not working. It was removing big parts of the table for some reason and I don't think it's worth debugging since this version of the table doesn't use it at all. It's also a bit faster this way.

Contributes to issue CURA-8686.
This commit is contained in:
Ghostkeeper 2022-01-26 17:24:24 +01:00
parent 7a1c3e1bd5
commit 43d4075309
No known key found for this signature in database
GPG key ID: D2A8871EE34EC59A

View file

@ -35,7 +35,7 @@ Item
model: columnHeaders model: columnHeaders
Rectangle Rectangle
{ {
width: Math.round(tableBase.width / headerRepeater.count) width: Math.max(1, Math.round(tableBase.width / headerRepeater.count))
height: UM.Theme.getSize("section").height height: UM.Theme.getSize("section").height
color: UM.Theme.getColor("secondary") color: UM.Theme.getColor("secondary")
@ -53,7 +53,7 @@ Item
color: UM.Theme.getColor("text") color: UM.Theme.getColor("text")
elide: Text.ElideRight elide: Text.ElideRight
} }
Rectangle Rectangle //Resize handle.
{ {
anchors anchors
{ {
@ -79,24 +79,31 @@ Item
{ {
if(drag.active) if(drag.active)
{ {
parent.parent.width = Math.max(10, parent.parent.width + mouseX); //Don't go smaller than 10 pixels, to make sure you can still scale it back. let new_width = parent.parent.width + mouseX; //Don't go smaller than 10 pixels, to make sure you can still scale it back.
let sum_widths = 0; let sum_widths = mouseX;
for(let i = 0; i < headerBar.children.length; ++i) for(let i = 0; i < headerBar.children.length; ++i)
{ {
sum_widths += headerBar.children[i].width; sum_widths += headerBar.children[i].width;
} }
if(sum_widths > tableBase.width) if(sum_widths > tableBase.width)
{ {
parent.parent.width -= sum_widths - tableBase.width; //Limit the total width to not exceed the view. new_width -= sum_widths - tableBase.width; //Limit the total width to not exceed the view.
} }
let width_fraction = new_width / tableBase.width; //Scale with the same fraction along with the total width, if the table is resized.
parent.parent.width = Qt.binding(function() { return tableBase.width * width_fraction });
} }
tableView.forceLayout();
} }
} }
} }
onWidthChanged:
{
tableView.forceLayout(); //Rescale table cells underneath as well.
}
} }
} }
} }
TableView TableView
{ {
id: tableView id: tableView
@ -154,14 +161,25 @@ Item
font: UM.Theme.getFont("default") font: UM.Theme.getFont("default")
color: UM.Theme.getColor("text") color: UM.Theme.getColor("text")
} }
MouseArea TextMetrics
{
id: cellTextMetrics
text: cellContent.text
font: cellContent.font
elide: cellContent.elide
elideWidth: cellContent.width
}
UM.TooltipArea
{ {
anchors.fill: parent anchors.fill: parent
enabled: tableBase.allowSelection text: (cellTextMetrics.elidedText == cellContent.text) ? "" : cellContent.text //Show full text in tooltip if it was elided.
onClicked: onClicked:
{ {
tableBase.currentRow = row; //Select this row. if(tableBase.allowSelection)
{
tableBase.currentRow = row; //Select this row.
}
} }
onDoubleClicked: onDoubleClicked:
{ {