123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257 |
- // 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
- // If the printer is a cloud printer or not. Other items base their enabled state off of this boolean. In the future
- // they might not need to though.
- property bool cloudConnection: Cura.MachineManager.activeMachineIsUsingCloudConnection
- 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: 216 * screenScaleFactor // TODO: Theme! (Should match column size)
- 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
- }
- }
- Item
- {
- anchors.verticalCenter: parent.verticalCenter
- height: 18 * screenScaleFactor // TODO: Theme!
- width: 216 * screenScaleFactor // TODO: Theme! (Should match column size)
- 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
- }
- }
- 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
- }
- Row
- {
- id: printerFamilyPills
- anchors
- {
- left: printerAssignmentLabel.right;
- leftMargin: 12 // TODO: Theme!
- verticalCenter: parent.verticalCenter
- }
- height: childrenRect.height
- spacing: 6 // TODO: Theme!
- visible: printJob
- Repeater
- {
- id: compatiblePills
- delegate: MonitorPrinterPill
- {
- text: modelData
- }
- model: printJob ? printJob.compatibleMachineFamilies : []
- }
- }
- }
- }
- 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
- }
- }
- }
- 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!
- enabled: !cloudConnection
- 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
- }
- }
|