// 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 } }