// Copyright (c) 2021 Ultimaker B.V. // Cura is released under the terms of the LGPLv3 or higher. import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.1 import UM 1.6 as UM import Cura 1.6 as Cura RowLayout { id: manageButton property alias primaryText: primaryButton.text property alias secondaryText: secondaryButton.text property string busyPrimaryText: busyMessageText.text property string busySecondaryText: busyMessageText.text property string confirmedPrimaryText: confirmedMessageText.text property string confirmedSecondaryText: confirmedMessageText.text property bool enabled: true property bool busy: state == "busy" signal clicked(bool primary_action) Cura.PrimaryButton { id: primaryButton visible: false enabled: manageButton.enabled onClicked: { busyMessage.text = manageButton.busyPrimaryText confirmedMessage.text = manageButton.confirmedPrimaryText manageButton.clicked(true) } } Cura.SecondaryButton { id: secondaryButton visible: false enabled: manageButton.enabled onClicked: { busyMessage.text = manageButton.busySecondaryText confirmedMessage.text = manageButton.confirmedSecondaryText manageButton.clicked(false) } } Item { id: busyMessage visible: false property alias text: busyMessageText.text height: UM.Theme.getSize("action_button").height width: childrenRect.width UM.RecolorImage { id: busyIndicator visible: parent.visible width: height anchors.left: parent.left anchors.top: parent.top anchors.topMargin: UM.Theme.getSize("narrow_margin").height anchors.bottom: parent.bottom anchors.bottomMargin: anchors.topMargin source: UM.Theme.getIcon("Spinner") color: UM.Theme.getColor("primary") RotationAnimator { target: busyIndicator running: busyIndicator.visible from: 0 to: 360 loops: Animation.Infinite duration: 2500 } } Label { id: busyMessageText visible: parent.visible anchors.left: busyIndicator.right anchors.leftMargin: UM.Theme.getSize("narrow_margin").width anchors.verticalCenter: parent.verticalCenter font: UM.Theme.getFont("medium_bold") color: UM.Theme.getColor("primary") } } Item { id: confirmedMessage property alias text: confirmedMessageText.text visible: false height: UM.Theme.getSize("action_button").height width: childrenRect.width Label { id: confirmedMessageText visible: parent.visble anchors.verticalCenter: parent.verticalCenter font: UM.Theme.getFont("medium_bold") color: UM.Theme.getColor("primary") } } states: [ State { name: "primary" PropertyChanges { target: primaryButton visible: true } PropertyChanges { target: secondaryButton visible: false } PropertyChanges { target: busyMessage visible: false } PropertyChanges { target: confirmedMessage visible: false } }, State { name: "secondary" PropertyChanges { target: primaryButton visible: false } PropertyChanges { target: secondaryButton visible: true } PropertyChanges { target: busyMessage visible: false } PropertyChanges { target: confirmedMessage visible: false } }, State { name: "hidden" PropertyChanges { target: manageButton visible: false } }, State { name: "busy" PropertyChanges { target: primaryButton visible: false } PropertyChanges { target: secondaryButton visible: false } PropertyChanges { target: busyMessage visible: manageButton.visible } PropertyChanges { target: confirmedMessage visible: false } }, State { name: "confirmed" PropertyChanges { target: primaryButton visible: false } PropertyChanges { target: secondaryButton visible: false } PropertyChanges { target: busyMessage visible: false } PropertyChanges { target: confirmedMessage visible: manageButton.visible } } ] }