123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- // Copyright (c) 2015 Ultimaker B.V.
- // Cura is released under the terms of the AGPLv3 or higher.
- import QtQuick 2.2
- import QtQuick.Controls 1.1
- import QtQuick.Controls.Styles 1.1
- import QtQuick.Layouts 1.1
- import UM 1.1 as UM
- Rectangle {
- id: base;
- property real progress: UM.Backend.progress;
- property bool activity: Printer.getPlatformActivity;
- Behavior on progress { NumberAnimation { duration: 250; } }
- property variant printDuration: PrintInformation.currentPrintTime;
- property real printMaterialAmount: PrintInformation.materialAmount;
- Rectangle{
- id: background
- implicitWidth: base.width;
- implicitHeight: parent.height;
- color: UM.Theme.colors.save_button_background;
- border.width: UM.Theme.sizes.save_button_border.width
- border.color: UM.Theme.colors.save_button_border
- Rectangle {
- id: infoBox
- width: parent.width - UM.Theme.sizes.default_margin.width * 2;
- height: UM.Theme.sizes.save_button_slicing_bar.height
- anchors.top: parent.top
- anchors.topMargin: UM.Theme.sizes.default_margin.height;
- anchors.left: parent.left
- anchors.leftMargin: UM.Theme.sizes.default_margin.width;
- border.width: UM.Theme.sizes.save_button_border.width
- border.color: UM.Theme.colors.save_button_border
- color: UM.Theme.colors.save_button_estimated_text_background;
- Label {
- id: label;
- anchors.verticalCenter: parent.verticalCenter
- anchors.left: parent.left
- anchors.leftMargin: UM.Theme.sizes.save_button_text_margin.width;
- visible: base.progress >= 0 && base.progress < 0.99 ? false : true
- color: UM.Theme.colors.save_button_estimated_text;
- font: UM.Theme.fonts.small;
- text: {
- if(base.activity == false) {
- //: Save button label
- return qsTr("Please load a 3D model");
- } else if (base.progress < 0.99) {
- //: Save button label
- return qsTr("Calculating Print-time");
- } else if (base.printDuration.days > 0 || base.progress == null){
- return qsTr("");
- }
- else if (base.progress > 0.99){
- //: Save button label
- return qsTr("Estimated Print-time");
- }
- return "";
- }
- }
- Label {
- id: printDurationLabel
- anchors.verticalCenter: parent.verticalCenter
- anchors.left: label.right;
- anchors.leftMargin: UM.Theme.sizes.save_button_text_margin.width;
- color: UM.Theme.colors.save_button_printtime_text;
- font: UM.Theme.fonts.small;
- visible: base.activity == false || base.progress < 0.99 ? false : true
- text: (!base.printDuration || !base.printDuration.valid) ? "" : base.printDuration.getDisplayString(UM.DurationFormat.Long);
- }
- Label {
- id: printMaterialLabel
- anchors.verticalCenter: parent.verticalCenter
- anchors.left: printDurationLabel.right;
- anchors.leftMargin: UM.Theme.sizes.save_button_text_margin.width;
- color: base.printDuration.days > 0 ? UM.Theme.colors.save_button_estimated_text : UM.Theme.colors.save_button_printtime_text;
- font: UM.Theme.fonts.small;
- property bool mediumLengthDuration: base.printDuration.hours > 9 && base.printMaterialAmount > 9.99 && base.printDuration.days == 0
- width: mediumLengthDuration ? 50 : undefined
- elide: mediumLengthDuration ? Text.ElideRight : Text.ElideNone
- visible: base.activity == false || base.progress < 0.99 ? false : true
- //: Print material amount save button label
- text: base.printMaterialAmount < 0 ? "" : qsTr("%1m of Material").arg(base.printMaterialAmount);
- }
- }
- Rectangle {
- id: infoBoxOverlay
- anchors {
- left: infoBox.left;
- top: infoBox.top;
- bottom: infoBox.bottom;
- }
- width: Math.max(infoBox.width * base.progress);
- color: UM.Theme.colors.save_button_active
- visible: progress > 0.99 ? false : true
- }
- Button {
- id: saveToButton
- anchors.top: infoBox.bottom
- anchors.topMargin: UM.Theme.sizes.save_button_text_margin.height;
- anchors.left: parent.left
- anchors.leftMargin: UM.Theme.sizes.default_margin.width;
- tooltip: UM.OutputDeviceManager.activeDeviceDescription;
- enabled: progress > 0.99 && base.activity == true
- width: infoBox.width/6*4.5
- height: UM.Theme.sizes.save_button_save_to_button.height
- text: UM.OutputDeviceManager.activeDeviceShortDescription;
- style: ButtonStyle {
- background: Rectangle {
- color: !control.enabled ? UM.Theme.colors.save_button_inactive : control.hovered ? UM.Theme.colors.save_button_active_hover : UM.Theme.colors.save_button_active;
- Label {
- anchors.centerIn: parent
- color: UM.Theme.colors.save_button_safe_to_text;
- font: UM.Theme.fonts.sidebar_save_to;
- text: control.text;
- }
- }
- label: Item { }
- }
- onClicked: UM.OutputDeviceManager.requestWriteToDevice(UM.OutputDeviceManager.activeDevice)
- }
- Button {
- id: deviceSelectionMenu;
- anchors.top: infoBox.bottom
- anchors.topMargin: UM.Theme.sizes.save_button_text_margin.height
- anchors.right: parent.right
- anchors.rightMargin: UM.Theme.sizes.default_margin.width;
- tooltip: qsTr("Select the active output device");
- width: infoBox.width/6*1.3 - UM.Theme.sizes.save_button_text_margin.height;
- height: UM.Theme.sizes.save_button_save_to_button.height
- iconSource: UM.Theme.icons[UM.OutputDeviceManager.activeDeviceIconName];
- style: ButtonStyle {
- background: Rectangle {
- color: UM.Theme.colors.save_button_background;
- border.width: control.hovered ? UM.Theme.sizes.save_button_border.width : 0
- border.color: UM.Theme.colors.save_button_border
- Rectangle {
- id: deviceSelectionIcon
- color: UM.Theme.colors.save_button_background;
- anchors.left: parent.left
- anchors.leftMargin: UM.Theme.sizes.save_button_text_margin.width / 2;
- anchors.verticalCenter: parent.verticalCenter;
- width: parent.height - UM.Theme.sizes.save_button_text_margin.width ;
- height: parent.height - UM.Theme.sizes.save_button_text_margin.width;
- UM.RecolorImage {
- anchors.fill: parent;
- sourceSize.width: width;
- sourceSize.height: height;
- color: UM.Theme.colors.save_button_active
- source: control.iconSource;
- }
- }
- Label {
- id: deviceSelectionArrow
- anchors.right: parent.right;
- anchors.rightMargin: UM.Theme.sizes.save_button_text_margin.height
- anchors.verticalCenter: parent.verticalCenter;
- text: "▼";
- font: UM.Theme.fonts.tiny;
- color: UM.Theme.colors.save_button_active;
- }
- }
- label: Item { }
- }
- menu: Menu {
- id: devicesMenu;
- Instantiator {
- model: devicesModel;
- MenuItem {
- text: model.description
- checkable: true;
- checked: model.id == UM.OutputDeviceManager.activeDevice;
- exclusiveGroup: devicesMenuGroup;
- onTriggered: {
- UM.OutputDeviceManager.setActiveDevice(model.id);
- }
- }
- onObjectAdded: devicesMenu.insertItem(index, object)
- onObjectRemoved: devicesMenu.removeItem(object)
- }
- ExclusiveGroup { id: devicesMenuGroup; }
- }
- }
- }
- UM.OutputDevicesModel {
- id: devicesModel;
- }
- }
|