123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282 |
- // Copyright (c) 2018 Ultimaker B.V.
- // Cura is released under the terms of the LGPLv3 or higher.
- import QtQuick 2.7
- import QtQuick.Controls 2.3
- import UM 1.2 as UM
- import Cura 1.1 as Cura
- Cura.ExpandablePopup
- {
- id: machineSelector
- property bool isNetworkPrinter: Cura.MachineManager.activeMachineHasNetworkConnection
- property bool isConnectedCloudPrinter: Cura.MachineManager.activeMachineHasCloudConnection
- property bool isCloudRegistered: Cura.MachineManager.activeMachineHasCloudRegistration
- property bool isGroup: Cura.MachineManager.activeMachineIsGroup
- readonly property string connectionStatus: {
- if (isNetworkPrinter)
- {
- return "printer_connected"
- }
- else if (isConnectedCloudPrinter && Cura.API.connectionStatus.isInternetReachable)
- {
- return "printer_cloud_connected"
- }
- else if (isCloudRegistered)
- {
- return "printer_cloud_not_available"
- }
- else
- {
- return ""
- }
- }
- function getConnectionStatusMessage() {
- if (connectionStatus == "printer_cloud_not_available")
- {
- if(Cura.API.connectionStatus.isInternetReachable)
- {
- if (Cura.API.account.isLoggedIn)
- {
- if (Cura.MachineManager.activeMachineIsLinkedToCurrentAccount)
- {
- return catalog.i18nc("@status", "The cloud printer is offline. Please check if the printer is turned on and connected to the internet.")
- }
- else
- {
- return catalog.i18nc("@status", "This printer is not linked to your account. Please visit the Ultimaker Digital Factory to establish a connection.")
- }
- }
- else
- {
- return catalog.i18nc("@status", "The cloud connection is currently unavailable. Please sign in to connect to the cloud printer.")
- }
- } else
- {
- return catalog.i18nc("@status", "The cloud connection is currently unavailable. Please check your internet connection.")
- }
- }
- else
- {
- return ""
- }
- }
- contentPadding: UM.Theme.getSize("default_lining").width
- contentAlignment: Cura.ExpandablePopup.ContentAlignment.AlignLeft
- UM.I18nCatalog
- {
- id: catalog
- name: "cura"
- }
- headerItem: Cura.IconWithText
- {
- text:
- {
- if (isNetworkPrinter && Cura.MachineManager.activeMachineNetworkGroupName != "")
- {
- return Cura.MachineManager.activeMachineNetworkGroupName
- }
- if(Cura.MachineManager.activeMachine != null)
- {
- return Cura.MachineManager.activeMachine.name
- }
- return ""
- }
- source:
- {
- if (isGroup)
- {
- return UM.Theme.getIcon("PrinterTriple", "medium")
- }
- else if (isNetworkPrinter || isCloudRegistered)
- {
- return UM.Theme.getIcon("Printer", "medium")
- }
- else
- {
- return ""
- }
- }
- font: UM.Theme.getFont("medium")
- iconColor: UM.Theme.getColor("machine_selector_printer_icon")
- iconSize: source != "" ? UM.Theme.getSize("machine_selector_icon").width: 0
- UM.RecolorImage
- {
- id: connectionStatusImage
- anchors
- {
- bottom: parent.bottom
- bottomMargin: - Math.round(height * 1 / 6)
- left: parent.left
- leftMargin: iconSize - Math.round(width * 5 / 6)
- }
- source:
- {
- if (connectionStatus == "printer_connected")
- {
- return UM.Theme.getIcon("CheckBlueBG", "low")
- }
- else if (connectionStatus == "printer_cloud_connected" || connectionStatus == "printer_cloud_not_available")
- {
- return UM.Theme.getIcon("CloudBadge", "low")
- }
- else
- {
- return ""
- }
- }
- width: UM.Theme.getSize("printer_status_icon").width
- height: UM.Theme.getSize("printer_status_icon").height
- color: connectionStatus == "printer_cloud_not_available" ? UM.Theme.getColor("cloud_unavailable") : UM.Theme.getColor("primary")
- visible: isNetworkPrinter || isCloudRegistered
- // Make a themable circle in the background so we can change it in other themes
- Rectangle
- {
- id: iconBackground
- anchors.centerIn: parent
- width: parent.width - 1.5 //1.5 pixels smaller, (at least sqrt(2), regardless of screen pixel scale) so that the circle doesn't show up behind the icon due to anti-aliasing.
- height: parent.height - 1.5
- radius: width / 2
- color: UM.Theme.getColor("connection_badge_background")
- z: parent.z - 1
- }
- }
- MouseArea // Connection status tooltip hover area
- {
- id: connectionStatusTooltipHoverArea
- anchors.fill: parent
- hoverEnabled: getConnectionStatusMessage() !== ""
- acceptedButtons: Qt.NoButton // react to hover only, don't steal clicks
- onEntered:
- {
- machineSelector.mouseArea.entered() // we want both this and the outer area to be entered
- tooltip.tooltipText = getConnectionStatusMessage()
- tooltip.show()
- }
- onExited: { tooltip.hide() }
- }
- Cura.ToolTip
- {
- id: tooltip
- width: 250 * screenScaleFactor
- tooltipText: getConnectionStatusMessage()
- arrowSize: UM.Theme.getSize("button_tooltip_arrow").width
- x: connectionStatusImage.x - UM.Theme.getSize("narrow_margin").width
- y: connectionStatusImage.y + connectionStatusImage.height + UM.Theme.getSize("narrow_margin").height
- z: popup.z + 1
- targetPoint: Qt.point(
- connectionStatusImage.x + Math.round(connectionStatusImage.width / 2),
- connectionStatusImage.y
- )
- }
- }
- contentItem: Item
- {
- id: popup
- width: UM.Theme.getSize("machine_selector_widget_content").width
- ScrollView
- {
- id: scroll
- width: parent.width
- clip: true
- leftPadding: UM.Theme.getSize("default_lining").width
- rightPadding: UM.Theme.getSize("default_lining").width
- MachineSelectorList
- {
- id: machineSelectorList
- // Can't use parent.width since the parent is the flickable component and not the ScrollView
- width: scroll.width - scroll.leftPadding - scroll.rightPadding
- property real maximumHeight: UM.Theme.getSize("machine_selector_widget_content").height - buttonRow.height
- // We use an extra property here, since we only want to to be informed about the content size changes.
- onContentHeightChanged:
- {
- scroll.height = Math.min(contentHeight, maximumHeight)
- popup.height = scroll.height + buttonRow.height
- }
- Component.onCompleted:
- {
- scroll.height = Math.min(contentHeight, maximumHeight)
- popup.height = scroll.height + buttonRow.height
- }
- }
- }
- Rectangle
- {
- id: separator
- anchors.top: scroll.bottom
- width: parent.width
- height: UM.Theme.getSize("default_lining").height
- color: UM.Theme.getColor("lining")
- }
- Row
- {
- id: buttonRow
- // The separator is inside the buttonRow. This is to avoid some weird behaviours with the scroll bar.
- anchors.top: separator.top
- anchors.horizontalCenter: parent.horizontalCenter
- padding: UM.Theme.getSize("default_margin").width
- spacing: UM.Theme.getSize("default_margin").width
- Cura.SecondaryButton
- {
- id: addPrinterButton
- leftPadding: UM.Theme.getSize("default_margin").width
- rightPadding: UM.Theme.getSize("default_margin").width
- text: catalog.i18nc("@button", "Add printer")
- // The maximum width of the button is half of the total space, minus the padding of the parent, the left
- // padding of the component and half the spacing because of the space between buttons.
- fixedWidthMode: true
- width: UM.Theme.getSize("machine_selector_widget_content").width / 2 - leftPadding
- onClicked:
- {
- toggleContent()
- Cura.Actions.addMachine.trigger()
- }
- }
- Cura.SecondaryButton
- {
- id: managePrinterButton
- leftPadding: UM.Theme.getSize("default_margin").width
- rightPadding: UM.Theme.getSize("default_margin").width
- text: catalog.i18nc("@button", "Manage printers")
- fixedWidthMode: true
- // The maximum width of the button is half of the total space, minus the padding of the parent, the right
- // padding of the component and half the spacing because of the space between buttons.
- width: UM.Theme.getSize("machine_selector_widget_content").width / 2 - leftPadding
- onClicked:
- {
- toggleContent()
- Cura.Actions.configureMachines.trigger()
- }
- }
- }
- }
- }
|