mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-29 07:14:24 +08:00
251 lines
9.0 KiB
QML
251 lines
9.0 KiB
QML
// Copyright (c) 2018 Ultimaker B.V.
|
|
// Cura is released under the terms of the LGPLv3 or higher.
|
|
|
|
import QtQuick 2.2
|
|
import QtQuick.Controls 2.0
|
|
import UM 1.3 as UM
|
|
import Cura 1.0 as Cura
|
|
|
|
/**
|
|
* A Print Job Card is essentially just a filled-in Expandable Card item. All
|
|
* data within it is derived from being passed a printJob property.
|
|
*
|
|
* NOTE: For most labels, a fixed height with vertical alignment is used to make
|
|
* layouts more deterministic (like the fixed-size textboxes used in original
|
|
* mock-ups). This is also a stand-in for CSS's 'line-height' property. Denoted
|
|
* with '// FIXED-LINE-HEIGHT:'.
|
|
*/
|
|
Item
|
|
{
|
|
id: base
|
|
|
|
// The print job which all other data is derived from
|
|
property var printJob: null
|
|
|
|
width: parent.width
|
|
height: childrenRect.height
|
|
|
|
ExpandableCard
|
|
{
|
|
enabled: printJob != null
|
|
borderColor: printJob && printJob.configurationChanges.length !== 0 ? UM.Theme.getColor("warning") : UM.Theme.getColor("monitor_card_border")
|
|
headerItem: Row
|
|
{
|
|
height: 48 * screenScaleFactor // TODO: Theme!
|
|
anchors.left: parent.left
|
|
anchors.leftMargin: 24 * screenScaleFactor // TODO: Theme!
|
|
spacing: 18 * screenScaleFactor // TODO: Theme!
|
|
|
|
MonitorPrintJobPreview
|
|
{
|
|
printJob: base.printJob
|
|
size: 32 * screenScaleFactor // TODO: Theme!
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
}
|
|
|
|
Item
|
|
{
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
height: 18 * screenScaleFactor // TODO: Theme!
|
|
width: UM.Theme.getSize("monitor_column").width
|
|
Rectangle
|
|
{
|
|
color: UM.Theme.getColor("monitor_skeleton_loading")
|
|
width: Math.round(parent.width / 2)
|
|
height: parent.height
|
|
visible: !printJob
|
|
radius: 2 * screenScaleFactor // TODO: Theme!
|
|
}
|
|
Label
|
|
{
|
|
text: printJob && printJob.name ? printJob.name : ""
|
|
color: UM.Theme.getColor("monitor_text_primary")
|
|
elide: Text.ElideRight
|
|
font: UM.Theme.getFont("medium") // 14pt, regular
|
|
visible: printJob
|
|
|
|
// FIXED-LINE-HEIGHT:
|
|
height: parent.height
|
|
verticalAlignment: Text.AlignVCenter
|
|
renderType: Text.NativeRendering
|
|
}
|
|
}
|
|
|
|
Item
|
|
{
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
height: 18 * screenScaleFactor // TODO: Theme!
|
|
width: UM.Theme.getSize("monitor_column").width
|
|
Rectangle
|
|
{
|
|
color: UM.Theme.getColor("monitor_skeleton_loading")
|
|
width: Math.round(parent.width / 3)
|
|
height: parent.height
|
|
visible: !printJob
|
|
radius: 2 * screenScaleFactor // TODO: Theme!
|
|
}
|
|
Label
|
|
{
|
|
text: printJob ? OutputDevice.formatDuration(printJob.timeTotal) : ""
|
|
color: UM.Theme.getColor("monitor_text_primary")
|
|
elide: Text.ElideRight
|
|
font: UM.Theme.getFont("medium") // 14pt, regular
|
|
visible: printJob
|
|
|
|
// FIXED-LINE-HEIGHT:
|
|
height: 18 * screenScaleFactor // TODO: Theme!
|
|
verticalAlignment: Text.AlignVCenter
|
|
renderType: Text.NativeRendering
|
|
}
|
|
}
|
|
|
|
Item
|
|
{
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
height: 18 * screenScaleFactor // TODO: This should be childrenRect.height but QML throws warnings
|
|
width: childrenRect.width
|
|
|
|
Rectangle
|
|
{
|
|
color: UM.Theme.getColor("monitor_skeleton_loading")
|
|
width: 72 * screenScaleFactor // TODO: Theme!
|
|
height: parent.height
|
|
visible: !printJob
|
|
radius: 2 * screenScaleFactor // TODO: Theme!
|
|
}
|
|
|
|
Label
|
|
{
|
|
id: printerAssignmentLabel
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
color: UM.Theme.getColor("monitor_text_primary")
|
|
elide: Text.ElideRight
|
|
font: UM.Theme.getFont("medium") // 14pt, regular
|
|
text: {
|
|
if (printJob !== null) {
|
|
if (printJob.assignedPrinter == null)
|
|
{
|
|
if (printJob.state == "error")
|
|
{
|
|
return catalog.i18nc("@label", "Unavailable printer")
|
|
}
|
|
return catalog.i18nc("@label", "First available")
|
|
}
|
|
return printJob.assignedPrinter.name
|
|
}
|
|
return ""
|
|
}
|
|
visible: printJob
|
|
width: 120 * screenScaleFactor // TODO: Theme!
|
|
|
|
// FIXED-LINE-HEIGHT:
|
|
height: parent.height
|
|
verticalAlignment: Text.AlignVCenter
|
|
renderType: Text.NativeRendering
|
|
}
|
|
|
|
Row
|
|
{
|
|
id: printerFamilyPills
|
|
anchors
|
|
{
|
|
left: printerAssignmentLabel.right;
|
|
leftMargin: 12 // TODO: Theme!
|
|
verticalCenter: parent.verticalCenter
|
|
}
|
|
height: childrenRect.height
|
|
spacing: 6 // TODO: Theme!
|
|
visible: printJob
|
|
|
|
MonitorPrinterPill
|
|
{
|
|
text: printJob.configuration.printerType
|
|
}
|
|
}
|
|
}
|
|
}
|
|
drawerItem: Row
|
|
{
|
|
anchors
|
|
{
|
|
left: parent.left
|
|
leftMargin: 74 * screenScaleFactor // TODO: Theme!
|
|
}
|
|
height: 108 * screenScaleFactor // TODO: Theme!
|
|
spacing: 18 * screenScaleFactor // TODO: Theme!
|
|
|
|
MonitorPrinterConfiguration
|
|
{
|
|
id: printerConfiguration
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
buildplate: catalog.i18nc("@label", "Glass")
|
|
configurations:
|
|
[
|
|
base.printJob.configuration.extruderConfigurations[0],
|
|
base.printJob.configuration.extruderConfigurations[1]
|
|
]
|
|
height: 72 * screenScaleFactor // TODO: Theme!
|
|
}
|
|
Label {
|
|
text: printJob && printJob.owner ? printJob.owner : ""
|
|
color: UM.Theme.getColor("monitor_text_primary")
|
|
elide: Text.ElideRight
|
|
font: UM.Theme.getFont("medium") // 14pt, regular
|
|
anchors.top: printerConfiguration.top
|
|
|
|
// FIXED-LINE-HEIGHT:
|
|
height: 18 * screenScaleFactor // TODO: Theme!
|
|
verticalAlignment: Text.AlignVCenter
|
|
renderType: Text.NativeRendering
|
|
}
|
|
}
|
|
}
|
|
|
|
MonitorContextMenuButton
|
|
{
|
|
id: contextMenuButton
|
|
anchors
|
|
{
|
|
right: parent.right
|
|
rightMargin: 8 * screenScaleFactor // TODO: Theme!
|
|
top: parent.top
|
|
topMargin: 8 * screenScaleFactor // TODO: Theme!
|
|
}
|
|
width: 32 * screenScaleFactor // TODO: Theme!
|
|
height: 32 * screenScaleFactor // TODO: Theme!
|
|
onClicked: enabled ? contextMenu.switchPopupState() : {}
|
|
visible:
|
|
{
|
|
if (!printJob) {
|
|
return false
|
|
}
|
|
var states = ["queued", "error", "sent_to_printer", "pre_print", "printing", "pausing", "paused", "resuming"]
|
|
return states.indexOf(printJob.state) !== -1
|
|
}
|
|
}
|
|
|
|
MonitorContextMenu
|
|
{
|
|
id: contextMenu
|
|
printJob: base.printJob ? base.printJob : null
|
|
target: contextMenuButton
|
|
}
|
|
|
|
// For cloud printing, add this mouse area over the disabled contextButton to indicate that it's not available
|
|
MouseArea
|
|
{
|
|
id: contextMenuDisabledButtonArea
|
|
anchors.fill: contextMenuButton
|
|
hoverEnabled: contextMenuButton.visible && !contextMenuButton.enabled
|
|
onEntered: contextMenuDisabledInfo.open()
|
|
onExited: contextMenuDisabledInfo.close()
|
|
enabled: !contextMenuButton.enabled
|
|
}
|
|
|
|
MonitorInfoBlurb
|
|
{
|
|
id: contextMenuDisabledInfo
|
|
text: catalog.i18nc("@info", "These options are not available because you are monitoring a cloud printer.")
|
|
target: contextMenuButton
|
|
}
|
|
} |