mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-14 18:27:51 -06:00
Added rough outline of the redesigned cluster controlItem
CL-893
This commit is contained in:
parent
b074d2bdf3
commit
1fa3b60f94
3 changed files with 175 additions and 188 deletions
|
@ -1,5 +1,6 @@
|
||||||
import QtQuick 2.2
|
import QtQuick 2.2
|
||||||
import QtQuick.Controls 1.4
|
import QtQuick.Controls 1.4
|
||||||
|
import QtQuick.Controls.Styles 1.3
|
||||||
|
|
||||||
import UM 1.3 as UM
|
import UM 1.3 as UM
|
||||||
import Cura 1.0 as Cura
|
import Cura 1.0 as Cura
|
||||||
|
@ -9,11 +10,9 @@ Component
|
||||||
Rectangle
|
Rectangle
|
||||||
{
|
{
|
||||||
id: base
|
id: base
|
||||||
property var manager: Cura.MachineManager.printerOutputDevices[0]
|
|
||||||
property var lineColor: "#DCDCDC" // TODO: Should be linked to theme.
|
property var lineColor: "#DCDCDC" // TODO: Should be linked to theme.
|
||||||
property var cornerRadius: 4 * screenScaleFactor // TODO: Should be linked to theme.
|
property var cornerRadius: 4 * screenScaleFactor // TODO: Should be linked to theme.
|
||||||
|
visible: OutputDevice != null
|
||||||
visible: manager != null
|
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
color: UM.Theme.getColor("viewport_background")
|
color: UM.Theme.getColor("viewport_background")
|
||||||
|
|
||||||
|
@ -35,217 +34,201 @@ Component
|
||||||
right: parent.right
|
right: parent.right
|
||||||
}
|
}
|
||||||
|
|
||||||
text: Cura.MachineManager.printerOutputDevices[0].name
|
text: OutputDevice.name
|
||||||
elide: Text.ElideRight
|
elide: Text.ElideRight
|
||||||
}
|
}
|
||||||
|
|
||||||
Rectangle
|
|
||||||
{
|
|
||||||
id: printJobArea
|
|
||||||
|
|
||||||
border.width: UM.Theme.getSize("default_lining").width
|
ScrollView
|
||||||
border.color: lineColor
|
{
|
||||||
|
id: queuedPrintJobs
|
||||||
|
|
||||||
anchors
|
anchors
|
||||||
{
|
{
|
||||||
top: activePrintersLabel.bottom
|
top: activePrintersLabel.bottom
|
||||||
margins: UM.Theme.getSize("default_margin").width
|
|
||||||
left: parent.left
|
left: parent.left
|
||||||
right: parent.right
|
right: parent.right
|
||||||
|
margins: UM.Theme.getSize("default_margin").width
|
||||||
|
bottom: parent.bottom
|
||||||
}
|
}
|
||||||
|
ListView
|
||||||
|
{
|
||||||
|
anchors.fill: parent
|
||||||
|
spacing: UM.Theme.getSize("default_margin").height
|
||||||
|
|
||||||
radius: cornerRadius
|
model: OutputDevice.printers
|
||||||
height: childrenRect.height
|
delegate: Rectangle
|
||||||
|
{
|
||||||
|
width: parent.width
|
||||||
|
height: childrenRect.height + 2 * UM.Theme.getSize("default_margin").height
|
||||||
|
|
||||||
|
id: base
|
||||||
|
property var collapsed: true
|
||||||
Item
|
Item
|
||||||
{
|
{
|
||||||
id: printJobTitleBar
|
id: printerInfo
|
||||||
width: parent.width
|
height: machineIcon.height
|
||||||
height: printJobTitleLabel.height + 2 * UM.Theme.getSize("default_margin").height
|
|
||||||
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
id: printJobTitleLabel
|
|
||||||
anchors.left: parent.left
|
|
||||||
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
|
||||||
anchors.top: parent.top
|
|
||||||
anchors.topMargin: UM.Theme.getSize("default_margin").height
|
|
||||||
text: catalog.i18nc("@title", "Print jobs")
|
|
||||||
font: UM.Theme.getFont("default")
|
|
||||||
opacity: 0.75
|
|
||||||
}
|
|
||||||
Rectangle
|
|
||||||
{
|
|
||||||
anchors.bottom: parent.bottom
|
|
||||||
height: UM.Theme.getSize("default_lining").width
|
|
||||||
color: lineColor
|
|
||||||
width: parent.width
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Column
|
|
||||||
{
|
|
||||||
id: printJobColumn
|
|
||||||
|
|
||||||
anchors
|
anchors
|
||||||
{
|
{
|
||||||
top: printJobTitleBar.bottom
|
top: parent.top
|
||||||
margins: UM.Theme.getSize("default_margin").height
|
|
||||||
right: parent.right
|
|
||||||
left: parent.left
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
|
||||||
|
margins: UM.Theme.getSize("default_margin").width
|
||||||
}
|
}
|
||||||
|
|
||||||
Item
|
MouseArea
|
||||||
{
|
{
|
||||||
width: parent.width
|
anchors.fill: parent
|
||||||
height: childrenRect.height
|
onClicked: base.collapsed = !base.collapsed
|
||||||
opacity: 0.65
|
enabled: modelData.activePrintJob != null
|
||||||
Label
|
|
||||||
{
|
|
||||||
text: catalog.i18nc("@label", "Printing")
|
|
||||||
font: UM.Theme.getFont("very_small")
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
text: manager.activePrintJobs.length
|
|
||||||
font: UM.Theme.getFont("small")
|
|
||||||
anchors.right: parent.right
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Item
|
|
||||||
{
|
|
||||||
width: parent.width
|
|
||||||
height: childrenRect.height
|
|
||||||
opacity: 0.65
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
text: catalog.i18nc("@label", "Queued")
|
|
||||||
font: UM.Theme.getFont("very_small")
|
|
||||||
}
|
|
||||||
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
text: manager.queuedPrintJobs.length
|
|
||||||
font: UM.Theme.getFont("small")
|
|
||||||
anchors.right: parent.right
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
OpenPanelButton
|
|
||||||
{
|
|
||||||
anchors.top: printJobColumn.bottom
|
|
||||||
anchors.left: parent.left
|
|
||||||
anchors.right: parent.right
|
|
||||||
anchors.margins: UM.Theme.getSize("default_margin").height
|
|
||||||
id: configButton
|
|
||||||
onClicked: base.manager.openPrintJobControlPanel()
|
|
||||||
text: catalog.i18nc("@action:button", "View print jobs")
|
|
||||||
}
|
|
||||||
|
|
||||||
Item
|
|
||||||
{
|
|
||||||
// spacer
|
|
||||||
anchors.top: configButton.bottom
|
|
||||||
width: UM.Theme.getSize("default_margin").width
|
|
||||||
height: UM.Theme.getSize("default_margin").height
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Rectangle
|
Rectangle
|
||||||
{
|
{
|
||||||
id: printersArea
|
id: machineIcon
|
||||||
border.width: UM.Theme.getSize("default_lining").width
|
|
||||||
border.color: lineColor
|
|
||||||
anchors.top: printJobArea.bottom
|
|
||||||
anchors.topMargin: UM.Theme.getSize("default_margin").height
|
|
||||||
anchors.left: parent.left
|
|
||||||
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
|
||||||
anchors.right: parent.right
|
|
||||||
anchors.rightMargin:UM.Theme.getSize("default_margin").width
|
|
||||||
radius: cornerRadius
|
|
||||||
height: childrenRect.height
|
|
||||||
|
|
||||||
Item
|
|
||||||
{
|
|
||||||
id: printersTitleBar
|
|
||||||
width: parent.width
|
|
||||||
height: printJobTitleLabel.height + 2 * UM.Theme.getSize("default_margin").height
|
|
||||||
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
id: printersTitleLabel
|
|
||||||
anchors.left: parent.left
|
|
||||||
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
|
||||||
anchors.top: parent.top
|
anchors.top: parent.top
|
||||||
anchors.topMargin: UM.Theme.getSize("default_margin").height
|
width: 50
|
||||||
text: catalog.i18nc("@label:title", "Printers")
|
height: 50
|
||||||
font: UM.Theme.getFont("default")
|
color: "blue"
|
||||||
opacity: 0.75
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
id: machineNameLabel
|
||||||
|
text: modelData.name
|
||||||
|
anchors.top: machineIcon.top
|
||||||
|
anchors.left: machineIcon.right
|
||||||
|
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
anchors.right: collapseIcon.left
|
||||||
|
anchors.rightMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
elide: Text.ElideRight
|
||||||
|
}
|
||||||
|
|
||||||
|
UM.RecolorImage
|
||||||
|
{
|
||||||
|
id: collapseIcon
|
||||||
|
width: 15
|
||||||
|
height: 15
|
||||||
|
visible: modelData.activePrintJob != null
|
||||||
|
sourceSize.width: width
|
||||||
|
sourceSize.height: height
|
||||||
|
source: base.collapsed ? UM.Theme.getIcon("arrow_left") : UM.Theme.getIcon("arrow_bottom")
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
anchors.right: parent.right
|
||||||
|
anchors.rightMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
color: "black"
|
||||||
|
}
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
id: activeJobLabel
|
||||||
|
text: modelData.activePrintJob != null ? modelData.activePrintJob.name : "waiting"
|
||||||
|
anchors.top: machineNameLabel.bottom
|
||||||
|
anchors.left: machineNameLabel.left
|
||||||
|
anchors.right: collapseIcon.left
|
||||||
|
anchors.rightMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
elide: Text.ElideRight
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Item
|
||||||
|
{
|
||||||
|
id: detailedInfo
|
||||||
|
property var printJob: modelData.activePrintJob
|
||||||
|
visible: !base.collapsed
|
||||||
|
anchors.top: printerInfo.bottom
|
||||||
|
width: parent.width
|
||||||
|
height: visible ? childrenRect.height : 0
|
||||||
|
|
||||||
Rectangle
|
Rectangle
|
||||||
{
|
{
|
||||||
anchors.bottom: parent.bottom
|
id: topSpacer
|
||||||
height: UM.Theme.getSize("default_lining").width
|
color: "grey"
|
||||||
color: lineColor
|
height: 1
|
||||||
width: parent.width
|
anchors
|
||||||
}
|
|
||||||
}
|
|
||||||
Column
|
|
||||||
{
|
{
|
||||||
id: printersColumn
|
left: parent.left
|
||||||
anchors.top: printersTitleBar.bottom
|
right: parent.right
|
||||||
anchors.topMargin: UM.Theme.getSize("default_margin").height
|
margins: UM.Theme.getSize("default_margin").width
|
||||||
|
top: parent.top
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Row
|
||||||
|
{
|
||||||
|
id: extrudersInfo
|
||||||
|
anchors.top: topSpacer.bottom
|
||||||
|
anchors.topMargin : UM.Theme.getSize("default_margin").height
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
anchors.rightMargin: UM.Theme.getSize("default_margin").width
|
anchors.rightMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
height: childrenRect.height
|
||||||
|
spacing: UM.Theme.getSize("default_margin").width
|
||||||
|
|
||||||
Repeater
|
PrintCoreConfiguration
|
||||||
{
|
{
|
||||||
model: manager.connectedPrintersTypeCount
|
id: leftExtruderInfo
|
||||||
|
width: Math.round(parent.width / 2)
|
||||||
|
printCoreConfiguration: modelData.printerConfiguration.extruderConfigurations[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
PrintCoreConfiguration
|
||||||
|
{
|
||||||
|
id: rightExtruderInfo
|
||||||
|
width: Math.round(parent.width / 2)
|
||||||
|
printCoreConfiguration: modelData.printerConfiguration.extruderConfigurations[1]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Rectangle
|
||||||
|
{
|
||||||
|
id: jobSpacer
|
||||||
|
color: "grey"
|
||||||
|
height: 1
|
||||||
|
anchors
|
||||||
|
{
|
||||||
|
left: parent.left
|
||||||
|
right: parent.right
|
||||||
|
margins: UM.Theme.getSize("default_margin").width
|
||||||
|
top: extrudersInfo.bottom
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Item
|
Item
|
||||||
{
|
{
|
||||||
width: parent.width
|
id: jobInfo
|
||||||
height: childrenRect.height
|
anchors.top: jobSpacer.bottom
|
||||||
opacity: 0.65
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
text: modelData.machine_type
|
|
||||||
font: UM.Theme.getFont("very_small")
|
|
||||||
}
|
|
||||||
|
|
||||||
Label
|
|
||||||
{
|
|
||||||
text: modelData.count
|
|
||||||
font: UM.Theme.getFont("small")
|
|
||||||
anchors.right: parent.right
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
OpenPanelButton
|
|
||||||
{
|
|
||||||
anchors.top: printersColumn.bottom
|
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
anchors.margins: UM.Theme.getSize("default_margin").height
|
anchors.margins: UM.Theme.getSize("default_margin").width
|
||||||
id: printerConfigButton
|
height: childrenRect.height
|
||||||
onClicked: base.manager.openPrinterControlPanel()
|
Label
|
||||||
|
{
|
||||||
text: catalog.i18nc("@action:button", "View printers")
|
id: printJobName
|
||||||
|
text: modelData.activePrintJob.name
|
||||||
|
font: UM.Theme.getFont("default_bold")
|
||||||
|
}
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
id: ownerName
|
||||||
|
anchors.top: printJobName.bottom
|
||||||
|
text: modelData.activePrintJob.owner
|
||||||
}
|
}
|
||||||
|
|
||||||
Item
|
Image
|
||||||
{
|
{
|
||||||
// spacer
|
source: modelData.activePrintJob.preview_image_url
|
||||||
anchors.top: printerConfigButton.bottom
|
anchors.top: ownerName.bottom
|
||||||
width: UM.Theme.getSize("default_margin").width
|
anchors.horizontalCenter: parent.horizontalCenter
|
||||||
height: UM.Theme.getSize("default_margin").height
|
anchors.bottom: totalTimeLabel.top
|
||||||
|
width: height
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -351,6 +351,10 @@ class ClusterUM3OutputDevice(NetworkedPrinterOutputDevice):
|
||||||
result.append({"machine_type": machine_type, "count": str(printer_count[machine_type])})
|
result.append({"machine_type": machine_type, "count": str(printer_count[machine_type])})
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
@pyqtProperty("QVariantList", notify=clusterPrintersChanged)
|
||||||
|
def printers(self):
|
||||||
|
return self._printers
|
||||||
|
|
||||||
@pyqtSlot(int, result = str)
|
@pyqtSlot(int, result = str)
|
||||||
def formatDuration(self, seconds: int) -> str:
|
def formatDuration(self, seconds: int) -> str:
|
||||||
return Duration(seconds).getDisplayString(DurationFormat.Format.Short)
|
return Duration(seconds).getDisplayString(DurationFormat.Format.Short)
|
||||||
|
|
|
@ -193,7 +193,7 @@ Item
|
||||||
// PrintCore && Material config
|
// PrintCore && Material config
|
||||||
Row
|
Row
|
||||||
{
|
{
|
||||||
id: extruderInfo
|
id: extrudersInfo
|
||||||
anchors.bottom: parent.bottom
|
anchors.bottom: parent.bottom
|
||||||
|
|
||||||
anchors
|
anchors
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue